@eui/ecl 18.0.0-next.21 → 18.0.0-next.23
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/docs/components/EclAccordionItemComponent.html +1 -1
- package/docs/components/EclGalleryComponent.html +25 -142
- package/docs/components/EclGalleryFooterComponent.html +1 -1
- package/docs/components/EclGalleryItemComponent.html +2 -90
- package/docs/components/EclInpageNavigationComponent.html +102 -1
- package/docs/components/EclInpageNavigationItemComponent.html +1 -1
- package/docs/components/EclMenuComponent.html +1 -1
- package/docs/components/EclMenuItemComponent.html +1 -1
- package/docs/components/EclMenuMegaComponent.html +0 -24
- package/docs/components/EclMenuMegaItemComponent.html +66 -2
- package/docs/dependencies.html +1 -1
- package/docs/directives/EclLinkDirective.html +3 -3
- package/docs/index.html +1 -1
- package/docs/js/menu-wc.js +3 -6
- package/docs/js/menu-wc_es5.js +1 -1
- package/docs/js/search/search_index.js +2 -2
- package/esm2022/lib/components/ecl-accordion/ecl-accordion-item.component.mjs +4 -5
- package/esm2022/lib/components/ecl-breadcrumb/ecl-breadcrumb-segment.component.mjs +1 -1
- package/esm2022/lib/components/ecl-gallery/ecl-gallery-footer.component.mjs +5 -6
- package/esm2022/lib/components/ecl-gallery/ecl-gallery-item.component.mjs +8 -27
- package/esm2022/lib/components/ecl-gallery/ecl-gallery.component.mjs +18 -76
- package/esm2022/lib/components/ecl-icon/ecl-icon.component.mjs +2 -2
- 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 +33 -15
- package/esm2022/lib/components/ecl-inpage-navigation/ecl-inpage-navigation.module.mjs +5 -5
- package/esm2022/lib/components/ecl-link/ecl-link.directive.mjs +5 -5
- package/esm2022/lib/components/ecl-list/ecl-description-list-definition/ecl-description-list-definition.component.mjs +1 -1
- 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 +9 -12
- package/esm2022/lib/components/ecl-menu/ecl-menu-mega/ecl-menu-mega-item.component.mjs +37 -19
- package/esm2022/lib/components/ecl-menu/ecl-menu-mega/ecl-menu-mega.component.mjs +4 -16
- package/esm2022/lib/components/ecl-pagination/ecl-pagination-item.component.mjs +1 -1
- package/esm2022/lib/components/ecl-site-footer/ecl-footer-elements/ec/ecl-site-footer-fixed-content.mjs +1 -1
- package/esm2022/lib/components/ecl-site-footer/ecl-footer-elements/eu/ecl-site-footer-fixed-content.mjs +1 -1
- package/esm2022/lib/components/ecl-site-header/ecl-site-header.component.mjs +1 -1
- package/esm2022/lib/components/ecl-site-header/language/ecl-site-header-language-popover.component.mjs +1 -1
- package/esm2022/lib/components/ecl-social-media-follow/ecl-social-media-follow-item.component.mjs +1 -1
- package/esm2022/lib/components/ecl-social-media-share/ecl-social-media-share-item.component.mjs +1 -1
- package/esm2022/lib/components/ecl-tabs/ecl-tab.component.mjs +1 -1
- package/fesm2022/eui-ecl.mjs +854 -889
- package/fesm2022/eui-ecl.mjs.map +4 -4
- package/lib/components/ecl-gallery/ecl-gallery-item.component.d.ts +4 -10
- package/lib/components/ecl-gallery/ecl-gallery-item.component.d.ts.map +1 -1
- package/lib/components/ecl-gallery/ecl-gallery.component.d.ts +15 -38
- package/lib/components/ecl-gallery/ecl-gallery.component.d.ts.map +1 -1
- package/lib/components/ecl-icon/ecl-icon.component.d.ts.map +1 -1
- package/lib/components/ecl-inpage-navigation/ecl-inpage-navigation.component.d.ts +10 -2
- package/lib/components/ecl-inpage-navigation/ecl-inpage-navigation.component.d.ts.map +1 -1
- package/lib/components/ecl-link/ecl-link.directive.d.ts +3 -3
- package/lib/components/ecl-link/ecl-link.directive.d.ts.map +1 -1
- package/lib/components/ecl-menu/ecl-menu/ecl-menu.component.d.ts +2 -1
- package/lib/components/ecl-menu/ecl-menu/ecl-menu.component.d.ts.map +1 -1
- package/lib/components/ecl-menu/ecl-menu-mega/ecl-menu-mega-item.component.d.ts +11 -5
- package/lib/components/ecl-menu/ecl-menu-mega/ecl-menu-mega-item.component.d.ts.map +1 -1
- package/lib/components/ecl-menu/ecl-menu-mega/ecl-menu-mega.component.d.ts +1 -5
- package/lib/components/ecl-menu/ecl-menu-mega/ecl-menu-mega.component.d.ts.map +1 -1
- package/package.json +1 -1
- package/docs/classes/EclGalleryDownloadEvent.html +0 -382
|
@@ -3,11 +3,12 @@ import { Subject, fromEvent } from 'rxjs';
|
|
|
3
3
|
import { takeUntil } from 'rxjs/operators';
|
|
4
4
|
import { EclInpageNavigationItemComponent } from './ecl-inpage-navigation-item.component';
|
|
5
5
|
import { ECLBaseDirective } from '../ecl-base.directive';
|
|
6
|
-
import { EclBaseEvent } from '../../model
|
|
6
|
+
import { EclBaseEvent } from '../../model';
|
|
7
7
|
import * as i0 from "@angular/core";
|
|
8
|
-
import * as i1 from "
|
|
9
|
-
import * as i2 from "../ecl-
|
|
10
|
-
import * as i3 from "
|
|
8
|
+
import * as i1 from "../../services";
|
|
9
|
+
import * as i2 from "../ecl-sticky-container/ecl-sticky-container.component";
|
|
10
|
+
import * as i3 from "../ecl-icon/ecl-icon.component";
|
|
11
|
+
import * as i4 from "@ngx-translate/core";
|
|
11
12
|
export class EclInpageNavigationSectionEnterEvent extends EclBaseEvent {
|
|
12
13
|
constructor(sectionId) {
|
|
13
14
|
super();
|
|
@@ -15,14 +16,27 @@ export class EclInpageNavigationSectionEnterEvent extends EclBaseEvent {
|
|
|
15
16
|
}
|
|
16
17
|
}
|
|
17
18
|
export class EclInpageNavigationComponent extends ECLBaseDirective {
|
|
18
|
-
|
|
19
|
-
|
|
19
|
+
get currentNavigationLinkItem() {
|
|
20
|
+
return this.eclNavigationLinkItems.find((item) => item.sectionElement === this.currentSectionElement);
|
|
21
|
+
}
|
|
22
|
+
constructor(eclThemeService, renderer) {
|
|
23
|
+
super();
|
|
24
|
+
this.eclThemeService = eclThemeService;
|
|
25
|
+
this.renderer = renderer;
|
|
20
26
|
this.sectionEnter = new EventEmitter();
|
|
21
27
|
this.isButtonExpanded = false;
|
|
28
|
+
this.ICON_SIZE_FOR_EC_THEME_ON = 'xs';
|
|
29
|
+
this.ICON_SIZE_FOR_EU_THEME_ON = 's';
|
|
30
|
+
this.HEADING_ACTIVATED_CLASS = 'ecl-inpage-navigation__heading--active';
|
|
22
31
|
this.destroy$ = new Subject();
|
|
23
32
|
}
|
|
24
|
-
get
|
|
25
|
-
|
|
33
|
+
get sizeIcon() {
|
|
34
|
+
if (this.eclThemeService.isECTheme()) {
|
|
35
|
+
return this.ICON_SIZE_FOR_EC_THEME_ON;
|
|
36
|
+
}
|
|
37
|
+
else {
|
|
38
|
+
return this.ICON_SIZE_FOR_EU_THEME_ON;
|
|
39
|
+
}
|
|
26
40
|
}
|
|
27
41
|
ngAfterContentInit() {
|
|
28
42
|
this.handleNavigationItemsScroll();
|
|
@@ -64,8 +78,12 @@ export class EclInpageNavigationComponent extends ECLBaseDirective {
|
|
|
64
78
|
handleNavigationLinksHighlight(sectionElements) {
|
|
65
79
|
const currentSectionElement = this.findActiveSectionElement(sectionElements);
|
|
66
80
|
if (currentSectionElement !== this.currentSectionElement) {
|
|
67
|
-
this.currentSectionElement
|
|
68
|
-
|
|
81
|
+
if (this.currentSectionElement) {
|
|
82
|
+
this.renderer.removeClass(this.currentSectionElement, this.HEADING_ACTIVATED_CLASS);
|
|
83
|
+
}
|
|
84
|
+
if (currentSectionElement) {
|
|
85
|
+
this.renderer.addClass(currentSectionElement, this.HEADING_ACTIVATED_CLASS);
|
|
86
|
+
}
|
|
69
87
|
this.currentSectionElement = currentSectionElement;
|
|
70
88
|
this.onSectionScrollTrigger(currentSectionElement);
|
|
71
89
|
const sectionId = this.currentNavigationLinkItem ? this.currentNavigationLinkItem.sectionId : undefined;
|
|
@@ -92,13 +110,13 @@ export class EclInpageNavigationComponent extends ECLBaseDirective {
|
|
|
92
110
|
hasScrollHitBottom() {
|
|
93
111
|
return window.pageYOffset + window.innerHeight === document.documentElement.scrollHeight;
|
|
94
112
|
}
|
|
95
|
-
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0-next.3", ngImport: i0, type: EclInpageNavigationComponent, deps:
|
|
96
|
-
/** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.0-next.3", type: EclInpageNavigationComponent, selector: "ecl-inpage-navigation", inputs: { eclTitle: "eclTitle", marginTop: "marginTop", marginBottom: "marginBottom" }, outputs: { sectionEnter: "sectionEnter" }, queries: [{ propertyName: "eclNavigationLinkItems", predicate: EclInpageNavigationItemComponent }], usesInheritance: true, ngImport: i0, template: "<ecl-sticky-container [marginTop]=\"marginTop\" [marginBottom]=\"marginBottom\">\n <nav\n aria-labelledby=\"ecl-inpage-navigation-default\"\n class=\"ecl-inpage-navigation\"\n [class.ecl-inpage-navigation--visible]=\"currentSectionElement\">\n <div id=\"ecl-inpage-navigation-default\" class=\"ecl-inpage-navigation__title\">\n {{ eclTitle || 'ecl.inpage-navigation.PAGE-CONTENTS' | translate }}\n </div>\n <div class=\"ecl-inpage-navigation__body\">\n <button\n
|
|
113
|
+
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0-next.3", ngImport: i0, type: EclInpageNavigationComponent, deps: [{ token: i1.EclThemeService }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
114
|
+
/** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.0-next.3", type: EclInpageNavigationComponent, selector: "ecl-inpage-navigation", inputs: { eclTitle: "eclTitle", marginTop: "marginTop", marginBottom: "marginBottom" }, outputs: { sectionEnter: "sectionEnter" }, queries: [{ propertyName: "eclNavigationLinkItems", predicate: EclInpageNavigationItemComponent }], usesInheritance: true, ngImport: i0, template: "<ecl-sticky-container [marginTop]=\"marginTop\" [marginBottom]=\"marginBottom\">\n <nav\n aria-labelledby=\"ecl-inpage-navigation-default\"\n class=\"ecl-inpage-navigation\"\n [class.ecl-inpage-navigation--visible]=\"currentSectionElement\">\n <div id=\"ecl-inpage-navigation-default\" class=\"ecl-inpage-navigation__title\">\n {{ eclTitle || 'ecl.inpage-navigation.PAGE-CONTENTS' | translate }}\n </div>\n <div class=\"ecl-inpage-navigation__body\">\n <div class=\"ecl-inpage-navigation__trigger-wrapper\">\n <button\n id=\"ecl-inpage-navigation-default-trigger\"\n type=\"button\"\n class=\"ecl-inpage-navigation__trigger\"\n aria-controls=\"ecl-inpage-navigation-list\"\n [attr.aria-expanded]=\"isButtonExpanded\"\n (click)=\"onExpandButtonClick($event)\">\n <span class=\"ecl-inpage-navigation__trigger-current\">\n {{ currentNavigationLinkItem?.label }}\n </span>\n <ecl-icon icon=\"corner-arrow\" [size]=\"sizeIcon\" transform=\"rotate-180\" class=\"ecl-inpage-navigation__trigger-icon\"> </ecl-icon>\n </button>\n </div>\n <ul\n id=\"ecl-inpage-navigation-default-list\"\n class=\"ecl-inpage-navigation__list\"\n [class.ecl-inpage-navigation__list--visible]=\"isButtonExpanded\"\n [attr.aria-expanded]=\"isButtonExpanded\"\n aria-labelledby=\"ecl-inpage-navigation-trigger\">\n <ng-content></ng-content>\n </ul>\n </div>\n </nav>\n</ecl-sticky-container>\n", styles: ["@media (min-width: 996px){.ecl-inpage-navigation__list{display:block!important}}\n"], dependencies: [{ kind: "component", type: i2.EclStickyContainerComponent, selector: "ecl-sticky-container", inputs: ["isEnabled", "marginTop", "marginBottom"] }, { kind: "component", type: i3.EclIconComponent, selector: "ecl-icon", inputs: ["iconSet", "icon", "size", "color", "transform", "ariaLabelledby", "role", "ariaHidden", "focusable"] }, { kind: "pipe", type: i4.TranslatePipe, name: "translate" }] }); }
|
|
97
115
|
}
|
|
98
116
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-next.3", ngImport: i0, type: EclInpageNavigationComponent, decorators: [{
|
|
99
117
|
type: Component,
|
|
100
|
-
args: [{ selector: 'ecl-inpage-navigation', template: "<ecl-sticky-container [marginTop]=\"marginTop\" [marginBottom]=\"marginBottom\">\n <nav\n aria-labelledby=\"ecl-inpage-navigation-default\"\n class=\"ecl-inpage-navigation\"\n [class.ecl-inpage-navigation--visible]=\"currentSectionElement\">\n <div id=\"ecl-inpage-navigation-default\" class=\"ecl-inpage-navigation__title\">\n {{ eclTitle || 'ecl.inpage-navigation.PAGE-CONTENTS' | translate }}\n </div>\n <div class=\"ecl-inpage-navigation__body\">\n <button\n
|
|
101
|
-
}], propDecorators: { eclTitle: [{
|
|
118
|
+
args: [{ selector: 'ecl-inpage-navigation', template: "<ecl-sticky-container [marginTop]=\"marginTop\" [marginBottom]=\"marginBottom\">\n <nav\n aria-labelledby=\"ecl-inpage-navigation-default\"\n class=\"ecl-inpage-navigation\"\n [class.ecl-inpage-navigation--visible]=\"currentSectionElement\">\n <div id=\"ecl-inpage-navigation-default\" class=\"ecl-inpage-navigation__title\">\n {{ eclTitle || 'ecl.inpage-navigation.PAGE-CONTENTS' | translate }}\n </div>\n <div class=\"ecl-inpage-navigation__body\">\n <div class=\"ecl-inpage-navigation__trigger-wrapper\">\n <button\n id=\"ecl-inpage-navigation-default-trigger\"\n type=\"button\"\n class=\"ecl-inpage-navigation__trigger\"\n aria-controls=\"ecl-inpage-navigation-list\"\n [attr.aria-expanded]=\"isButtonExpanded\"\n (click)=\"onExpandButtonClick($event)\">\n <span class=\"ecl-inpage-navigation__trigger-current\">\n {{ currentNavigationLinkItem?.label }}\n </span>\n <ecl-icon icon=\"corner-arrow\" [size]=\"sizeIcon\" transform=\"rotate-180\" class=\"ecl-inpage-navigation__trigger-icon\"> </ecl-icon>\n </button>\n </div>\n <ul\n id=\"ecl-inpage-navigation-default-list\"\n class=\"ecl-inpage-navigation__list\"\n [class.ecl-inpage-navigation__list--visible]=\"isButtonExpanded\"\n [attr.aria-expanded]=\"isButtonExpanded\"\n aria-labelledby=\"ecl-inpage-navigation-trigger\">\n <ng-content></ng-content>\n </ul>\n </div>\n </nav>\n</ecl-sticky-container>\n", styles: ["@media (min-width: 996px){.ecl-inpage-navigation__list{display:block!important}}\n"] }]
|
|
119
|
+
}], ctorParameters: () => [{ type: i1.EclThemeService }, { type: i0.Renderer2 }], propDecorators: { eclTitle: [{
|
|
102
120
|
type: Input
|
|
103
121
|
}], marginTop: [{
|
|
104
122
|
type: Input
|
|
@@ -110,4 +128,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-next.3",
|
|
|
110
128
|
type: ContentChildren,
|
|
111
129
|
args: [EclInpageNavigationItemComponent]
|
|
112
130
|
}] } });
|
|
113
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecl-inpage-navigation.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/ecl-inpage-navigation/ecl-inpage-navigation.component.ts","../../../../../src/lib/components/ecl-inpage-navigation/ecl-inpage-navigation.component.html"],"names":[],"mappings":"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","sourcesContent":["import { EventEmitter, Component, Input, AfterContentInit, OnDestroy, ContentChildren, QueryList, Output } from '@angular/core';\nimport { Subject, fromEvent } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\nimport { EclInpageNavigationItemComponent } from './ecl-inpage-navigation-item.component';\nimport { ECLBaseDirective } from '../ecl-base.directive';\nimport { EclBaseEvent } from '../../model/ecl-base.event';\n\nexport class EclInpageNavigationSectionEnterEvent extends EclBaseEvent {\n    constructor(public sectionId: string) {\n        super();\n    }\n}\n\n@Component({\n    selector: 'ecl-inpage-navigation',\n    templateUrl: './ecl-inpage-navigation.component.html',\n    styles: [\n        `\n            @media (min-width: 996px) {\n                .ecl-inpage-navigation__list {\n                    display: block !important;\n                }\n            }\n        `,\n    ],\n})\nexport class EclInpageNavigationComponent extends ECLBaseDirective implements AfterContentInit, OnDestroy {\n    @Input() eclTitle: string;\n    @Input() marginTop: number;\n    @Input() marginBottom: number;\n\n    @Output() sectionEnter = new EventEmitter<EclInpageNavigationSectionEnterEvent>();\n\n    @ContentChildren(EclInpageNavigationItemComponent) eclNavigationLinkItems: QueryList<EclInpageNavigationItemComponent>;\n\n    isButtonExpanded = false;\n    currentSectionElement: HTMLElement;\n\n    private destroy$: Subject<boolean> = new Subject<boolean>();\n\n    get currentNavigationLinkItem(): EclInpageNavigationItemComponent {\n        return this.eclNavigationLinkItems.find((item) => item.sectionElement === this.currentSectionElement);\n    }\n\n    ngAfterContentInit(): void {\n        this.handleNavigationItemsScroll();\n        this.handleNavigationItemsClick();\n    }\n\n    ngOnDestroy(): void {\n        this.destroy$.next(true);\n        this.destroy$.unsubscribe();\n    }\n\n    onExpandButtonClick(evt): void {\n        this.isButtonExpanded = !this.isButtonExpanded;\n    }\n\n    private handleNavigationItemsScroll(): void {\n        const scrollableContainer: EventTarget = window;\n        const sectionElementIds = this.eclNavigationLinkItems.map((item) => item.sectionId);\n\n        fromEvent(scrollableContainer, 'scroll')\n            .pipe(takeUntil(this.destroy$))\n            .subscribe((event) => {\n                const sectionElements: Array<HTMLElement> = sectionElementIds.map((id) => document.querySelector(`#${id}`));\n                this.handleNavigationLinksHighlight(sectionElements);\n            });\n    }\n\n    private handleNavigationItemsClick(): void {\n        this.eclNavigationLinkItems.forEach((item) => {\n            item.itemClick.pipe(takeUntil(this.destroy$)).subscribe((evt) => {\n                this.selectNavigationItem(this.eclNavigationLinkItems, item.sectionElement);\n\n                if (item.sectionElement) {\n                    item.sectionElement.scrollIntoView();\n                }\n\n                this.isButtonExpanded = false;\n            });\n        });\n    }\n\n    private selectNavigationItem(items: QueryList<EclInpageNavigationItemComponent>, itemElement: HTMLElement): void {\n        items.forEach((it) => {\n            it.isActive = it.sectionElement === itemElement ? true : false;\n        });\n    }\n\n    private handleNavigationLinksHighlight(sectionElements: Array<HTMLElement>): void {\n        const currentSectionElement: HTMLElement = this.findActiveSectionElement(sectionElements);\n\n        if (currentSectionElement !== this.currentSectionElement) {\n            this.currentSectionElement?.classList.remove('ecl-inpage-navigation__heading--active');\n            currentSectionElement?.classList.add('ecl-inpage-navigation__heading--active');\n            this.currentSectionElement = currentSectionElement;\n            this.onSectionScrollTrigger(currentSectionElement);\n\n            const sectionId = this.currentNavigationLinkItem ? this.currentNavigationLinkItem.sectionId : undefined;\n            this.sectionEnter.next(new EclInpageNavigationSectionEnterEvent(sectionId));\n        }\n    }\n\n    private onSectionScrollTrigger(sectionElement: HTMLElement): void {\n        this.eclNavigationLinkItems.forEach((item) => {\n            item.isActive = item.sectionElement === sectionElement ? true : false;\n        });\n    }\n\n    private findActiveSectionElement(sectionElements: Array<HTMLElement>): HTMLElement {\n        let currentSection: HTMLElement;\n\n        sectionElements.forEach((sectionElement) => {\n            if (sectionElement && sectionElement.getBoundingClientRect().top <= 1) {\n                currentSection = sectionElement;\n            }\n        });\n\n        if (this.hasScrollHitBottom()) {\n            currentSection = sectionElements[sectionElements.length - 1];\n        }\n\n        return currentSection;\n    }\n\n    private hasScrollHitBottom(): boolean {\n        return window.pageYOffset + window.innerHeight === document.documentElement.scrollHeight;\n    }\n}\n","<ecl-sticky-container [marginTop]=\"marginTop\" [marginBottom]=\"marginBottom\">\n    <nav\n        aria-labelledby=\"ecl-inpage-navigation-default\"\n        class=\"ecl-inpage-navigation\"\n        [class.ecl-inpage-navigation--visible]=\"currentSectionElement\">\n        <div id=\"ecl-inpage-navigation-default\" class=\"ecl-inpage-navigation__title\">\n            {{ eclTitle || 'ecl.inpage-navigation.PAGE-CONTENTS' | translate }}\n        </div>\n        <div class=\"ecl-inpage-navigation__body\">\n            <button\n                id=\"ecl-inpage-navigation-default-trigger\"\n                type=\"button\"\n                class=\"ecl-inpage-navigation__trigger\"\n                aria-controls=\"ecl-inpage-navigation-list\"\n                [attr.aria-expanded]=\"isButtonExpanded\"\n                (click)=\"onExpandButtonClick($event)\">\n                <span class=\"ecl-inpage-navigation__trigger-current\">\n                    {{ currentNavigationLinkItem?.label }}\n                </span>\n                <ecl-icon icon=\"corner-arrow\" size=\"s\" transform=\"rotate-180\" class=\"ecl-inpage-navigation__trigger-icon\"> </ecl-icon>\n            </button>\n            <ul\n                id=\"ecl-inpage-navigation-default-list\"\n                class=\"ecl-inpage-navigation__list\"\n                [class.ecl-inpage-navigation__list--visible]=\"isButtonExpanded\"\n                [attr.aria-expanded]=\"isButtonExpanded\"\n                aria-labelledby=\"ecl-inpage-navigation-trigger\">\n                <ng-content></ng-content>\n            </ul>\n        </div>\n    </nav>\n</ecl-sticky-container>\n"]}
|
|
131
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecl-inpage-navigation.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/ecl-inpage-navigation/ecl-inpage-navigation.component.ts","../../../../../src/lib/components/ecl-inpage-navigation/ecl-inpage-navigation.component.html"],"names":[],"mappings":"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","sourcesContent":["import { EventEmitter, Component, Input, AfterContentInit, OnDestroy, ContentChildren, QueryList, Output, Renderer2 } from '@angular/core';\nimport { Subject, fromEvent } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\nimport { EclInpageNavigationItemComponent } from './ecl-inpage-navigation-item.component';\nimport { ECLBaseDirective } from '../ecl-base.directive';\nimport { EclBaseEvent } from '../../model';\nimport { EclThemeService } from '../../services';\n\nexport class EclInpageNavigationSectionEnterEvent extends EclBaseEvent {\n    constructor(public sectionId: string) {\n        super();\n    }\n}\n\n@Component({\n    selector: 'ecl-inpage-navigation',\n    templateUrl: './ecl-inpage-navigation.component.html',\n    styles: [\n        `\n            @media (min-width: 996px) {\n                .ecl-inpage-navigation__list {\n                    display: block !important;\n                }\n            }\n        `,\n    ],\n})\nexport class EclInpageNavigationComponent extends ECLBaseDirective implements AfterContentInit, OnDestroy {\n    @Input() eclTitle: string;\n    @Input() marginTop: number;\n    @Input() marginBottom: number;\n\n    @Output() sectionEnter = new EventEmitter<EclInpageNavigationSectionEnterEvent>();\n\n    @ContentChildren(EclInpageNavigationItemComponent) eclNavigationLinkItems: QueryList<EclInpageNavigationItemComponent>;\n\n    isButtonExpanded = false;\n    currentSectionElement: HTMLElement;\n    private readonly ICON_SIZE_FOR_EC_THEME_ON = 'xs';\n    private readonly ICON_SIZE_FOR_EU_THEME_ON = 's';\n    private readonly HEADING_ACTIVATED_CLASS = 'ecl-inpage-navigation__heading--active'\n    private destroy$: Subject<boolean> = new Subject<boolean>();\n\n    get currentNavigationLinkItem(): EclInpageNavigationItemComponent {\n        return this.eclNavigationLinkItems.find((item) => item.sectionElement === this.currentSectionElement);\n    }\n\n    constructor(public eclThemeService: EclThemeService, private renderer: Renderer2) {\n        super();\n    }\n\n    get sizeIcon(): string {\n        if (this.eclThemeService.isECTheme()) {\n            return this.ICON_SIZE_FOR_EC_THEME_ON;\n        } else {\n            return this.ICON_SIZE_FOR_EU_THEME_ON;\n        }\n    }\n\n    ngAfterContentInit(): void {\n        this.handleNavigationItemsScroll();\n        this.handleNavigationItemsClick();\n    }\n\n    ngOnDestroy(): void {\n        this.destroy$.next(true);\n        this.destroy$.unsubscribe();\n    }\n\n    onExpandButtonClick(evt): void {\n        this.isButtonExpanded = !this.isButtonExpanded;\n    }\n\n    private handleNavigationItemsScroll(): void {\n        const scrollableContainer: EventTarget = window;\n        const sectionElementIds = this.eclNavigationLinkItems.map((item) => item.sectionId);\n\n        fromEvent(scrollableContainer, 'scroll')\n            .pipe(takeUntil(this.destroy$))\n            .subscribe((event) => {\n                const sectionElements: Array<HTMLElement> = sectionElementIds.map((id) => document.querySelector(`#${id}`));\n                this.handleNavigationLinksHighlight(sectionElements);\n            });\n    }\n\n    private handleNavigationItemsClick(): void {\n        this.eclNavigationLinkItems.forEach((item) => {\n            item.itemClick.pipe(takeUntil(this.destroy$)).subscribe((evt) => {\n                this.selectNavigationItem(this.eclNavigationLinkItems, item.sectionElement);\n\n                if (item.sectionElement) {\n                    item.sectionElement.scrollIntoView();\n                }\n\n                this.isButtonExpanded = false;\n            });\n        });\n    }\n\n    private selectNavigationItem(items: QueryList<EclInpageNavigationItemComponent>, itemElement: HTMLElement): void {\n        items.forEach((it) => {\n            it.isActive = it.sectionElement === itemElement ? true : false;\n        });\n    }\n\n    private handleNavigationLinksHighlight(sectionElements: Array<HTMLElement>): void {\n        const currentSectionElement: HTMLElement = this.findActiveSectionElement(sectionElements);\n\n        if (currentSectionElement !== this.currentSectionElement) {\n            if (this.currentSectionElement) {\n                this.renderer.removeClass(this.currentSectionElement, this.HEADING_ACTIVATED_CLASS)\n            }\n\n            if (currentSectionElement) {\n                this.renderer.addClass(currentSectionElement, this.HEADING_ACTIVATED_CLASS)\n            }\n            this.currentSectionElement = currentSectionElement;\n            this.onSectionScrollTrigger(currentSectionElement);\n\n            const sectionId = this.currentNavigationLinkItem ? this.currentNavigationLinkItem.sectionId : undefined;\n            this.sectionEnter.next(new EclInpageNavigationSectionEnterEvent(sectionId));\n        }\n    }\n\n    private onSectionScrollTrigger(sectionElement: HTMLElement): void {\n        this.eclNavigationLinkItems.forEach((item) => {\n            item.isActive = item.sectionElement === sectionElement ? true : false;\n        });\n    }\n\n    private findActiveSectionElement(sectionElements: Array<HTMLElement>): HTMLElement {\n        let currentSection: HTMLElement;\n\n        sectionElements.forEach((sectionElement) => {\n            if (sectionElement && sectionElement.getBoundingClientRect().top <= 1) {\n                currentSection = sectionElement;\n            }\n        });\n\n        if (this.hasScrollHitBottom()) {\n            currentSection = sectionElements[sectionElements.length - 1];\n        }\n\n        return currentSection;\n    }\n\n    private hasScrollHitBottom(): boolean {\n        return window.pageYOffset + window.innerHeight === document.documentElement.scrollHeight;\n    }\n}\n","<ecl-sticky-container [marginTop]=\"marginTop\" [marginBottom]=\"marginBottom\">\n    <nav\n        aria-labelledby=\"ecl-inpage-navigation-default\"\n        class=\"ecl-inpage-navigation\"\n        [class.ecl-inpage-navigation--visible]=\"currentSectionElement\">\n        <div id=\"ecl-inpage-navigation-default\" class=\"ecl-inpage-navigation__title\">\n            {{ eclTitle || 'ecl.inpage-navigation.PAGE-CONTENTS' | translate }}\n        </div>\n        <div class=\"ecl-inpage-navigation__body\">\n            <div class=\"ecl-inpage-navigation__trigger-wrapper\">\n                <button\n                    id=\"ecl-inpage-navigation-default-trigger\"\n                    type=\"button\"\n                    class=\"ecl-inpage-navigation__trigger\"\n                    aria-controls=\"ecl-inpage-navigation-list\"\n                    [attr.aria-expanded]=\"isButtonExpanded\"\n                    (click)=\"onExpandButtonClick($event)\">\n                    <span class=\"ecl-inpage-navigation__trigger-current\">\n                        {{ currentNavigationLinkItem?.label }}\n                    </span>\n                    <ecl-icon icon=\"corner-arrow\" [size]=\"sizeIcon\" transform=\"rotate-180\" class=\"ecl-inpage-navigation__trigger-icon\"> </ecl-icon>\n                </button>\n             </div>\n            <ul\n                id=\"ecl-inpage-navigation-default-list\"\n                class=\"ecl-inpage-navigation__list\"\n                [class.ecl-inpage-navigation__list--visible]=\"isButtonExpanded\"\n                [attr.aria-expanded]=\"isButtonExpanded\"\n                aria-labelledby=\"ecl-inpage-navigation-trigger\">\n                <ng-content></ng-content>\n            </ul>\n        </div>\n    </nav>\n</ecl-sticky-container>\n"]}
|
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
import { NgModule } from '@angular/core';
|
|
2
2
|
import { CommonModule } from '@angular/common';
|
|
3
|
-
import { EclLinkDirectiveModule } from '../ecl-link/ecl-link.module';
|
|
4
|
-
import { EclIconComponentModule } from '../ecl-icon/ecl-icon.module';
|
|
5
|
-
import { EclInpageNavigationItemComponent } from './ecl-inpage-navigation-item.component';
|
|
6
3
|
import { TranslateModule } from '@ngx-translate/core';
|
|
7
|
-
import {
|
|
4
|
+
import { EclLinkDirectiveModule } from '../ecl-link';
|
|
5
|
+
import { EclIconComponentModule } from '../ecl-icon';
|
|
6
|
+
import { EclInpageNavigationItemComponent } from './ecl-inpage-navigation-item.component';
|
|
7
|
+
import { EclStickyContainerComponentModule } from '../ecl-sticky-container';
|
|
8
8
|
import { EclInpageNavigationComponent } from './ecl-inpage-navigation.component';
|
|
9
9
|
import * as i0 from "@angular/core";
|
|
10
10
|
export class EclInpageNavigationComponentModule {
|
|
@@ -20,4 +20,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-next.3",
|
|
|
20
20
|
declarations: [EclInpageNavigationComponent, EclInpageNavigationItemComponent],
|
|
21
21
|
}]
|
|
22
22
|
}] });
|
|
23
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
23
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWNsLWlucGFnZS1uYXZpZ2F0aW9uLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9saWIvY29tcG9uZW50cy9lY2wtaW5wYWdlLW5hdmlnYXRpb24vZWNsLWlucGFnZS1uYXZpZ2F0aW9uLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDdEQsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sYUFBYSxDQUFDO0FBQ3JELE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLGFBQWEsQ0FBQztBQUNyRCxPQUFPLEVBQUUsZ0NBQWdDLEVBQUUsTUFBTSx3Q0FBd0MsQ0FBQztBQUMxRixPQUFPLEVBQUUsaUNBQWlDLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUM1RSxPQUFPLEVBQUUsNEJBQTRCLEVBQUUsTUFBTSxtQ0FBbUMsQ0FBQzs7QUFPakYsTUFBTSxPQUFPLGtDQUFrQzt3SUFBbEMsa0NBQWtDO3lJQUFsQyxrQ0FBa0MsaUJBRjVCLDRCQUE0QixFQUFFLGdDQUFnQyxhQUZuRSxZQUFZLEVBQUUsZUFBZSxFQUFFLGlDQUFpQyxFQUFFLHNCQUFzQixFQUFFLHNCQUFzQixhQUNoSCw0QkFBNEIsRUFBRSxnQ0FBZ0M7eUlBRy9ELGtDQUFrQyxZQUpqQyxZQUFZLEVBQUUsZUFBZSxFQUFFLGlDQUFpQyxFQUFFLHNCQUFzQixFQUFFLHNCQUFzQjs7a0dBSWpILGtDQUFrQztrQkFMOUMsUUFBUTttQkFBQztvQkFDTixPQUFPLEVBQUUsQ0FBQyxZQUFZLEVBQUUsZUFBZSxFQUFFLGlDQUFpQyxFQUFFLHNCQUFzQixFQUFFLHNCQUFzQixDQUFDO29CQUMzSCxPQUFPLEVBQUUsQ0FBQyw0QkFBNEIsRUFBRSxnQ0FBZ0MsQ0FBQztvQkFDekUsWUFBWSxFQUFFLENBQUMsNEJBQTRCLEVBQUUsZ0NBQWdDLENBQUM7aUJBQ2pGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBUcmFuc2xhdGVNb2R1bGUgfSBmcm9tICdAbmd4LXRyYW5zbGF0ZS9jb3JlJztcbmltcG9ydCB7IEVjbExpbmtEaXJlY3RpdmVNb2R1bGUgfSBmcm9tICcuLi9lY2wtbGluayc7XG5pbXBvcnQgeyBFY2xJY29uQ29tcG9uZW50TW9kdWxlIH0gZnJvbSAnLi4vZWNsLWljb24nO1xuaW1wb3J0IHsgRWNsSW5wYWdlTmF2aWdhdGlvbkl0ZW1Db21wb25lbnQgfSBmcm9tICcuL2VjbC1pbnBhZ2UtbmF2aWdhdGlvbi1pdGVtLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBFY2xTdGlja3lDb250YWluZXJDb21wb25lbnRNb2R1bGUgfSBmcm9tICcuLi9lY2wtc3RpY2t5LWNvbnRhaW5lcic7XG5pbXBvcnQgeyBFY2xJbnBhZ2VOYXZpZ2F0aW9uQ29tcG9uZW50IH0gZnJvbSAnLi9lY2wtaW5wYWdlLW5hdmlnYXRpb24uY29tcG9uZW50JztcblxuQE5nTW9kdWxlKHtcbiAgICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlLCBUcmFuc2xhdGVNb2R1bGUsIEVjbFN0aWNreUNvbnRhaW5lckNvbXBvbmVudE1vZHVsZSwgRWNsTGlua0RpcmVjdGl2ZU1vZHVsZSwgRWNsSWNvbkNvbXBvbmVudE1vZHVsZV0sXG4gICAgZXhwb3J0czogW0VjbElucGFnZU5hdmlnYXRpb25Db21wb25lbnQsIEVjbElucGFnZU5hdmlnYXRpb25JdGVtQ29tcG9uZW50XSxcbiAgICBkZWNsYXJhdGlvbnM6IFtFY2xJbnBhZ2VOYXZpZ2F0aW9uQ29tcG9uZW50LCBFY2xJbnBhZ2VOYXZpZ2F0aW9uSXRlbUNvbXBvbmVudF0sXG59KVxuZXhwb3J0IGNsYXNzIEVjbElucGFnZU5hdmlnYXRpb25Db21wb25lbnRNb2R1bGUge31cbiJdfQ==
|
|
@@ -16,19 +16,19 @@ export class EclLinkDirective extends ECLBaseDirective {
|
|
|
16
16
|
super();
|
|
17
17
|
this.el = el;
|
|
18
18
|
this.isInverted = false;
|
|
19
|
-
this.
|
|
19
|
+
this.isIconOnly = false;
|
|
20
20
|
}
|
|
21
21
|
ngAfterContentInit() {
|
|
22
22
|
if (this.eclIconComponents) {
|
|
23
23
|
setTimeout(() => {
|
|
24
24
|
this.eclIconComponents.forEach((icn) => {
|
|
25
|
-
icn.class = icn.class + ' ecl-link__icon';
|
|
25
|
+
icn.class = icn.class ? icn.class + ' ecl-link__icon' : 'ecl-link__icon';
|
|
26
26
|
});
|
|
27
27
|
});
|
|
28
28
|
}
|
|
29
29
|
}
|
|
30
30
|
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0-next.3", ngImport: i0, type: EclLinkDirective, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
31
|
-
/** @nocollapse */ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "16.1.0", version: "18.0.0-next.3", type: EclLinkDirective, selector: "[eclLink]", inputs: { isInverted: ["isInverted", "isInverted", booleanAttribute],
|
|
31
|
+
/** @nocollapse */ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "16.1.0", version: "18.0.0-next.3", type: EclLinkDirective, selector: "[eclLink]", inputs: { isInverted: ["isInverted", "isInverted", booleanAttribute], isIconOnly: ["isIconOnly", "isIconOnly", booleanAttribute], isNoVisited: ["isNoVisited", "isNoVisited", booleanAttribute], variant: "variant" }, host: { properties: { "class": "this.cssClasses", "class.ecl-link--icon": "this.hasIcon", "class.ecl-link--no-visited": "this.isLinkNoVisited", "class.ecl-link--inverted": "this.isInverted", "class.ecl-link--icon-only": "this.isIconOnly" } }, queries: [{ propertyName: "eclIconComponents", predicate: i0.forwardRef(() => EclIconComponent) }], usesInheritance: true, ngImport: i0 }); }
|
|
32
32
|
}
|
|
33
33
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-next.3", ngImport: i0, type: EclLinkDirective, decorators: [{
|
|
34
34
|
type: Directive,
|
|
@@ -50,7 +50,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-next.3",
|
|
|
50
50
|
}, {
|
|
51
51
|
type: HostBinding,
|
|
52
52
|
args: ['class.ecl-link--inverted']
|
|
53
|
-
}],
|
|
53
|
+
}], isIconOnly: [{
|
|
54
54
|
type: Input,
|
|
55
55
|
args: [{ transform: booleanAttribute }]
|
|
56
56
|
}, {
|
|
@@ -65,4 +65,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-next.3",
|
|
|
65
65
|
type: ContentChildren,
|
|
66
66
|
args: [forwardRef(() => EclIconComponent)]
|
|
67
67
|
}] } });
|
|
68
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
68
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWNsLWxpbmsuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL2xpYi9jb21wb25lbnRzL2VjbC1saW5rL2VjbC1saW5rLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFdBQVcsRUFBRSxLQUFLLEVBQUUsVUFBVSxFQUFFLGVBQWUsRUFBYSxnQkFBZ0IsRUFBZ0MsTUFBTSxlQUFlLENBQUM7QUFFdEosT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sZ0NBQWdDLENBQUM7QUFDbEUsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sdUJBQXVCLENBQUM7O0FBS3pELE1BQU0sT0FBTyxnQkFBaUIsU0FBUSxnQkFBZ0I7SUFFbEQsSUFDSSxVQUFVO1FBQ1YsT0FBTyxDQUFDLEtBQUssQ0FBQyxhQUFhLENBQUMsVUFBVSxDQUFDLEVBQUUsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsYUFBYSxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUMvRyxDQUFDO0lBQ0QsSUFDSSxPQUFPO1FBQ1AsT0FBTyxJQUFJLENBQUMsaUJBQWlCLElBQUksSUFBSSxDQUFDLGlCQUFpQixDQUFDLE1BQU0sR0FBRyxDQUFDLENBQUM7SUFDdkUsQ0FBQztJQUVELElBQ0ksZUFBZTtRQUNmLE9BQU8sSUFBSSxDQUFDLFdBQVcsQ0FBQztJQUM1QixDQUFDO0lBU0QsWUFBbUIsRUFBYztRQUM3QixLQUFLLEVBQUUsQ0FBQztRQURPLE9BQUUsR0FBRixFQUFFLENBQVk7UUFQZ0QsZUFBVSxHQUFHLEtBQUssQ0FBQztRQUNsQixlQUFVLEdBQUcsS0FBSyxDQUFDO0lBUXJHLENBQUM7SUFFRCxrQkFBa0I7UUFDZCxJQUFJLElBQUksQ0FBQyxpQkFBaUIsRUFBRSxDQUFDO1lBQ3pCLFVBQVUsQ0FBQyxHQUFHLEVBQUU7Z0JBQ1osSUFBSSxDQUFDLGlCQUFpQixDQUFDLE9BQU8sQ0FBQyxDQUFDLEdBQUcsRUFBRSxFQUFFO29CQUNuQyxHQUFHLENBQUMsS0FBSyxHQUFHLEdBQUcsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxLQUFLLEdBQUcsaUJBQWlCLENBQUMsQ0FBQyxDQUFDLGdCQUFnQixDQUFDO2dCQUM3RSxDQUFDLENBQUMsQ0FBQztZQUNQLENBQUMsQ0FBQyxDQUFDO1FBQ1AsQ0FBQztJQUNMLENBQUM7d0lBbkNRLGdCQUFnQjs0SEFBaEIsZ0JBQWdCLDRFQWdCTCxnQkFBZ0IsNENBQ2hCLGdCQUFnQiwrQ0FDaEIsZ0JBQWdCLDBWQUdGLGdCQUFnQjs7a0dBckJ6QyxnQkFBZ0I7a0JBSDVCLFNBQVM7bUJBQUM7b0JBQ1AsUUFBUSxFQUFFLFdBQVc7aUJBQ3hCOytFQUlPLFVBQVU7c0JBRGIsV0FBVzt1QkFBQyxPQUFPO2dCQUtoQixPQUFPO3NCQURWLFdBQVc7dUJBQUMsc0JBQXNCO2dCQU0vQixlQUFlO3NCQURsQixXQUFXO3VCQUFDLDRCQUE0QjtnQkFLd0MsVUFBVTtzQkFBMUYsS0FBSzt1QkFBQyxFQUFFLFNBQVMsRUFBRSxnQkFBZ0IsRUFBRTs7c0JBQUcsV0FBVzt1QkFBQywwQkFBMEI7Z0JBQ0csVUFBVTtzQkFBM0YsS0FBSzt1QkFBQyxFQUFFLFNBQVMsRUFBRSxnQkFBZ0IsRUFBRTs7c0JBQUcsV0FBVzt1QkFBQywyQkFBMkI7Z0JBQ3hDLFdBQVc7c0JBQWxELEtBQUs7dUJBQUMsRUFBRSxTQUFTLEVBQUUsZ0JBQWdCLEVBQUU7Z0JBQzdCLE9BQU87c0JBQWYsS0FBSztnQkFFK0MsaUJBQWlCO3NCQUFyRSxlQUFlO3VCQUFDLFVBQVUsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxnQkFBZ0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgSG9zdEJpbmRpbmcsIElucHV0LCBmb3J3YXJkUmVmLCBDb250ZW50Q2hpbGRyZW4sIFF1ZXJ5TGlzdCwgYm9vbGVhbkF0dHJpYnV0ZSwgRWxlbWVudFJlZiwgQWZ0ZXJDb250ZW50SW5pdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBFY2xJY29uQ29tcG9uZW50IH0gZnJvbSAnLi4vZWNsLWljb24vZWNsLWljb24uY29tcG9uZW50JztcbmltcG9ydCB7IEVDTEJhc2VEaXJlY3RpdmUgfSBmcm9tICcuLi9lY2wtYmFzZS5kaXJlY3RpdmUnO1xuXG5ARGlyZWN0aXZlKHtcbiAgICBzZWxlY3RvcjogJ1tlY2xMaW5rXScsXG59KVxuZXhwb3J0IGNsYXNzIEVjbExpbmtEaXJlY3RpdmUgZXh0ZW5kcyBFQ0xCYXNlRGlyZWN0aXZlIGltcGxlbWVudHMgQWZ0ZXJDb250ZW50SW5pdCB7XG5cbiAgICBASG9zdEJpbmRpbmcoJ2NsYXNzJylcbiAgICBnZXQgY3NzQ2xhc3NlcygpOiBzdHJpbmcge1xuICAgICAgICByZXR1cm4gW3N1cGVyLmdldENzc0NsYXNzZXMoJ2VjbC1saW5rJyksIHRoaXMudmFyaWFudCA/IGBlY2wtbGluay0tJHt0aGlzLnZhcmlhbnR9YCA6ICcnXS5qb2luKCcgJykudHJpbSgpO1xuICAgIH1cbiAgICBASG9zdEJpbmRpbmcoJ2NsYXNzLmVjbC1saW5rLS1pY29uJylcbiAgICBnZXQgaGFzSWNvbigpOiBib29sZWFuIHtcbiAgICAgICAgcmV0dXJuIHRoaXMuZWNsSWNvbkNvbXBvbmVudHMgJiYgdGhpcy5lY2xJY29uQ29tcG9uZW50cy5sZW5ndGggPiAwO1xuICAgIH1cblxuICAgIEBIb3N0QmluZGluZygnY2xhc3MuZWNsLWxpbmstLW5vLXZpc2l0ZWQnKVxuICAgIGdldCBpc0xpbmtOb1Zpc2l0ZWQoKTogYm9vbGVhbiB7XG4gICAgICAgIHJldHVybiB0aGlzLmlzTm9WaXNpdGVkO1xuICAgIH1cblxuICAgIEBJbnB1dCh7IHRyYW5zZm9ybTogYm9vbGVhbkF0dHJpYnV0ZSB9KSBASG9zdEJpbmRpbmcoJ2NsYXNzLmVjbC1saW5rLS1pbnZlcnRlZCcpIGlzSW52ZXJ0ZWQgPSBmYWxzZTtcbiAgICBASW5wdXQoeyB0cmFuc2Zvcm06IGJvb2xlYW5BdHRyaWJ1dGUgfSkgQEhvc3RCaW5kaW5nKCdjbGFzcy5lY2wtbGluay0taWNvbi1vbmx5JykgaXNJY29uT25seSA9IGZhbHNlO1xuICAgIEBJbnB1dCh7IHRyYW5zZm9ybTogYm9vbGVhbkF0dHJpYnV0ZSB9KSBpc05vVmlzaXRlZDogYm9vbGVhbjtcbiAgICBASW5wdXQoKSB2YXJpYW50OiAnc3RhbmRhbG9uZScgfCAnY3RhJyB8ICdwcmltYXJ5JyB8ICdzZWNvbmRhcnknO1xuXG4gICAgQENvbnRlbnRDaGlsZHJlbihmb3J3YXJkUmVmKCgpID0+IEVjbEljb25Db21wb25lbnQpKSBlY2xJY29uQ29tcG9uZW50czogUXVlcnlMaXN0PEVjbEljb25Db21wb25lbnQ+O1xuXG4gICAgY29uc3RydWN0b3IocHVibGljIGVsOiBFbGVtZW50UmVmKSB7XG4gICAgICAgIHN1cGVyKCk7XG4gICAgfVxuXG4gICAgbmdBZnRlckNvbnRlbnRJbml0KCk6IHZvaWQge1xuICAgICAgICBpZiAodGhpcy5lY2xJY29uQ29tcG9uZW50cykge1xuICAgICAgICAgICAgc2V0VGltZW91dCgoKSA9PiB7XG4gICAgICAgICAgICAgICAgdGhpcy5lY2xJY29uQ29tcG9uZW50cy5mb3JFYWNoKChpY24pID0+IHtcbiAgICAgICAgICAgICAgICAgICAgaWNuLmNsYXNzID0gaWNuLmNsYXNzID8gaWNuLmNsYXNzICsgJyBlY2wtbGlua19faWNvbicgOiAnZWNsLWxpbmtfX2ljb24nO1xuICAgICAgICAgICAgICAgIH0pO1xuICAgICAgICAgICAgfSk7XG4gICAgICAgIH1cbiAgICB9XG59XG4iXX0=
|
|
@@ -57,7 +57,7 @@ export class EclDescriptionListDefinitionComponent extends ECLBaseDirective {
|
|
|
57
57
|
return this.eclListItems.filter((item, cnt) => cnt < this._maxVisibleItems).pop();
|
|
58
58
|
}
|
|
59
59
|
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0-next.3", ngImport: i0, type: EclDescriptionListDefinitionComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
60
|
-
/** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.0-next.3", type: EclDescriptionListDefinitionComponent, selector: "[eclDescriptionListDefinition]", inputs: { variant: "variant" }, host: { properties: { "class": "this.cssClasses" } }, queries: [{ propertyName: "eclListItems", predicate: EclDescriptionListDefinitionItemDirective, descendants: true }], usesInheritance: true, ngImport: i0, template: "<ng-content></ng-content>\n@if(hasSeeAll) {\n<a eclLink class=\"ecl-description-list__see_more\" href (click)=\"onShowAllItems($event)\">{{\n 'ecl.list.SEE-ALL-ITEMS' | translate\n }}</a>\n}", dependencies: [{ kind: "directive", type: i1.EclLinkDirective, selector: "[eclLink]", inputs: ["isInverted", "
|
|
60
|
+
/** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.0-next.3", type: EclDescriptionListDefinitionComponent, selector: "[eclDescriptionListDefinition]", inputs: { variant: "variant" }, host: { properties: { "class": "this.cssClasses" } }, queries: [{ propertyName: "eclListItems", predicate: EclDescriptionListDefinitionItemDirective, descendants: true }], usesInheritance: true, ngImport: i0, template: "<ng-content></ng-content>\n@if(hasSeeAll) {\n<a eclLink class=\"ecl-description-list__see_more\" href (click)=\"onShowAllItems($event)\">{{\n 'ecl.list.SEE-ALL-ITEMS' | translate\n }}</a>\n}", dependencies: [{ kind: "directive", type: i1.EclLinkDirective, selector: "[eclLink]", inputs: ["isInverted", "isIconOnly", "isNoVisited", "variant"] }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }] }); }
|
|
61
61
|
}
|
|
62
62
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-next.3", ngImport: i0, type: EclDescriptionListDefinitionComponent, decorators: [{
|
|
63
63
|
type: Component,
|
|
@@ -296,11 +296,11 @@ export class EclMenuItemComponent extends ECLBaseDirective {
|
|
|
296
296
|
});
|
|
297
297
|
}
|
|
298
298
|
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0-next.3", ngImport: i0, type: EclMenuItemComponent, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i0.ApplicationRef }, { token: i1.BreakpointObserver }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
299
|
-
/** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.0-next.3", type: EclMenuItemComponent, selector: "ecl-menu-item", inputs: { id: "id", label: "label", routerLink: "routerLink", queryParams: "queryParams", queryParamsHandling: "queryParamsHandling", href: "href", target: "target", isCurrent: "isCurrent" }, outputs: { menuItemSelect: "menuItemSelect", menuItemCaret: "menuItemCaret", menuItemHover: "menuItemHover", menuItemHoverOut: "menuItemHoverOut", menuMegaItemSelect: "menuMegaItemSelect", menuItemFocus: "menuItemFocus", menuItemKeydown: "menuItemKeydown" }, host: { listeners: { "mouseenter": "onItemMouseEnter($event)", "mouseleave": "onItemMouseLeave($event)" }, properties: { "attr.role": "this.role", "class": "this.cssClasses", "class.ecl-menu__item--has-children": "this.hasEclChildrenDataAttribute", "attr.aria-haspopup": "this.hasEclChildrenDataAttribute", "attr.aria-expanded": "this.isAriaExpanded" } }, queries: [{ propertyName: "submenu", first: true, predicate: i0.forwardRef(() => EclMenuMegaComponent), descendants: true }], viewQueries: [{ propertyName: "menuLink", first: true, predicate: ["menuLink"], descendants: true }, { propertyName: "menuButton", first: true, predicate: EclButtonComponent, descendants: true }], usesInheritance: true, ngImport: i0, template: "<a\n #menuLink\n *ngIf=\"href\"\n [href]=\"href\"\n [target]=\"target\"\n class=\"ecl-menu__link\"\n [class.ecl-menu__link--current]=\"isCurrent\"\n (focus)=\"onItemFocus($event)\"\n (click)=\"onItemClick($event)\"\n (keydown)=\"onLinkKeydown($event)\">\n {{ label }}\n <ng-container *ngTemplateOutlet=\"content\"></ng-container>\n</a>\n<a\n #menuLink\n *ngIf=\"!href\"\n tabindex=\"0\"\n [routerLink]=\"routerLink\"\n [queryParams]=\"queryParams\"\n [queryParamsHandling]=\"queryParamsHandling\"\n class=\"ecl-menu__link\"\n [class.ecl-menu__link--current]=\"isCurrent\"\n (focus)=\"onItemFocus($event)\"\n (click)=\"onItemClick($event)\"\n (keydown)=\"onLinkKeydown($event)\">\n {{ label }}\n <ng-container *ngTemplateOutlet=\"content\"></ng-container>\n</a>\n<button\n eclButton\n *ngIf=\"hasChildren && isMobileBreakpoint\"\n variant=\"
|
|
299
|
+
/** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.0-next.3", type: EclMenuItemComponent, selector: "ecl-menu-item", inputs: { id: "id", label: "label", routerLink: "routerLink", queryParams: "queryParams", queryParamsHandling: "queryParamsHandling", href: "href", target: "target", isCurrent: "isCurrent" }, outputs: { menuItemSelect: "menuItemSelect", menuItemCaret: "menuItemCaret", menuItemHover: "menuItemHover", menuItemHoverOut: "menuItemHoverOut", menuMegaItemSelect: "menuMegaItemSelect", menuItemFocus: "menuItemFocus", menuItemKeydown: "menuItemKeydown" }, host: { listeners: { "mouseenter": "onItemMouseEnter($event)", "mouseleave": "onItemMouseLeave($event)" }, properties: { "attr.role": "this.role", "class": "this.cssClasses", "class.ecl-menu__item--has-children": "this.hasEclChildrenDataAttribute", "attr.aria-haspopup": "this.hasEclChildrenDataAttribute", "attr.aria-expanded": "this.isAriaExpanded" } }, queries: [{ propertyName: "submenu", first: true, predicate: i0.forwardRef(() => EclMenuMegaComponent), descendants: true }], viewQueries: [{ propertyName: "menuLink", first: true, predicate: ["menuLink"], descendants: true }, { propertyName: "menuButton", first: true, predicate: EclButtonComponent, descendants: true }], usesInheritance: true, ngImport: i0, template: "<a\n #menuLink\n variant=\"standalone\"\n *ngIf=\"href\"\n [href]=\"href\"\n [target]=\"target\"\n class=\"ecl-menu__link\"\n [class.ecl-menu__link--current]=\"isCurrent\"\n (focus)=\"onItemFocus($event)\"\n (click)=\"onItemClick($event)\"\n (keydown)=\"onLinkKeydown($event)\">\n {{ label }}\n <ng-container *ngTemplateOutlet=\"content\"></ng-container>\n</a>\n<a\n #menuLink\n variant=\"standalone\"\n *ngIf=\"!href\"\n tabindex=\"0\"\n [routerLink]=\"routerLink\"\n [queryParams]=\"queryParams\"\n [queryParamsHandling]=\"queryParamsHandling\"\n class=\"ecl-menu__link\"\n [class.ecl-menu__link--current]=\"isCurrent\"\n (focus)=\"onItemFocus($event)\"\n (click)=\"onItemClick($event)\"\n (keydown)=\"onLinkKeydown($event)\">\n {{ label }}\n <ng-container *ngTemplateOutlet=\"content\"></ng-container>\n</a>\n<button\n eclButton\n isIconOnly\n *ngIf=\"hasChildren && isMobileBreakpoint\"\n variant=\"ghost\"\n class=\"ecl-menu__button-caret\"\n type=\"button\"\n aria-label=\"Access item's children\"\n (click)=\"onItemCaretClick($event)\"\n (keydown)=\"onButtonKeydown($event)\">\n <ecl-icon icon=\"corner-arrow\" size=\"xs\" transform=\"rotate-180\" class=\"ecl-button__icon\"></ecl-icon>\n</button>\n<button\n eclButton\n isIconOnly\n *ngIf=\"hasChildren && !isMobileBreakpoint\"\n variant=\"ghost\"\n class=\"ecl-menu__button-caret\"\n type=\"button\"\n aria-label=\"Access item's children\"\n [attr.aria-expanded]=\"isAriaExpanded\"\n (keydown)=\"onButtonKeydown($event)\">\n <ecl-icon icon=\"corner-arrow\" size=\"xs\" transform=\"rotate-180\" class=\"ecl-button__icon\"></ecl-icon>\n</button>\n<ng-content select=\"ecl-menu-mega\"></ng-content>\n\n<ng-template #content>\n <ng-content></ng-content>\n</ng-template>\n", dependencies: [{ kind: "component", type: i2.EclButtonComponent, selector: "button[eclButton], button[ecl-button], a[eclButton]", inputs: ["isIconOnly", "variant", "containerStyleClass"] }, { kind: "component", type: i3.EclIconComponent, selector: "ecl-icon", inputs: ["iconSet", "icon", "size", "color", "transform", "ariaLabelledby", "role", "ariaHidden", "focusable"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i5.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }], encapsulation: i0.ViewEncapsulation.None }); }
|
|
300
300
|
}
|
|
301
301
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-next.3", ngImport: i0, type: EclMenuItemComponent, decorators: [{
|
|
302
302
|
type: Component,
|
|
303
|
-
args: [{ selector: 'ecl-menu-item', encapsulation: ViewEncapsulation.None, template: "<a\n #menuLink\n *ngIf=\"href\"\n [href]=\"href\"\n [target]=\"target\"\n class=\"ecl-menu__link\"\n [class.ecl-menu__link--current]=\"isCurrent\"\n (focus)=\"onItemFocus($event)\"\n (click)=\"onItemClick($event)\"\n (keydown)=\"onLinkKeydown($event)\">\n {{ label }}\n <ng-container *ngTemplateOutlet=\"content\"></ng-container>\n</a>\n<a\n #menuLink\n *ngIf=\"!href\"\n tabindex=\"0\"\n [routerLink]=\"routerLink\"\n [queryParams]=\"queryParams\"\n [queryParamsHandling]=\"queryParamsHandling\"\n class=\"ecl-menu__link\"\n [class.ecl-menu__link--current]=\"isCurrent\"\n (focus)=\"onItemFocus($event)\"\n (click)=\"onItemClick($event)\"\n (keydown)=\"onLinkKeydown($event)\">\n {{ label }}\n <ng-container *ngTemplateOutlet=\"content\"></ng-container>\n</a>\n<button\n eclButton\n *ngIf=\"hasChildren && isMobileBreakpoint\"\n variant=\"
|
|
303
|
+
args: [{ selector: 'ecl-menu-item', encapsulation: ViewEncapsulation.None, template: "<a\n #menuLink\n variant=\"standalone\"\n *ngIf=\"href\"\n [href]=\"href\"\n [target]=\"target\"\n class=\"ecl-menu__link\"\n [class.ecl-menu__link--current]=\"isCurrent\"\n (focus)=\"onItemFocus($event)\"\n (click)=\"onItemClick($event)\"\n (keydown)=\"onLinkKeydown($event)\">\n {{ label }}\n <ng-container *ngTemplateOutlet=\"content\"></ng-container>\n</a>\n<a\n #menuLink\n variant=\"standalone\"\n *ngIf=\"!href\"\n tabindex=\"0\"\n [routerLink]=\"routerLink\"\n [queryParams]=\"queryParams\"\n [queryParamsHandling]=\"queryParamsHandling\"\n class=\"ecl-menu__link\"\n [class.ecl-menu__link--current]=\"isCurrent\"\n (focus)=\"onItemFocus($event)\"\n (click)=\"onItemClick($event)\"\n (keydown)=\"onLinkKeydown($event)\">\n {{ label }}\n <ng-container *ngTemplateOutlet=\"content\"></ng-container>\n</a>\n<button\n eclButton\n isIconOnly\n *ngIf=\"hasChildren && isMobileBreakpoint\"\n variant=\"ghost\"\n class=\"ecl-menu__button-caret\"\n type=\"button\"\n aria-label=\"Access item's children\"\n (click)=\"onItemCaretClick($event)\"\n (keydown)=\"onButtonKeydown($event)\">\n <ecl-icon icon=\"corner-arrow\" size=\"xs\" transform=\"rotate-180\" class=\"ecl-button__icon\"></ecl-icon>\n</button>\n<button\n eclButton\n isIconOnly\n *ngIf=\"hasChildren && !isMobileBreakpoint\"\n variant=\"ghost\"\n class=\"ecl-menu__button-caret\"\n type=\"button\"\n aria-label=\"Access item's children\"\n [attr.aria-expanded]=\"isAriaExpanded\"\n (keydown)=\"onButtonKeydown($event)\">\n <ecl-icon icon=\"corner-arrow\" size=\"xs\" transform=\"rotate-180\" class=\"ecl-button__icon\"></ecl-icon>\n</button>\n<ng-content select=\"ecl-menu-mega\"></ng-content>\n\n<ng-template #content>\n <ng-content></ng-content>\n</ng-template>\n" }]
|
|
304
304
|
}], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i0.ApplicationRef }, { type: i1.BreakpointObserver }], propDecorators: { id: [{
|
|
305
305
|
type: Input
|
|
306
306
|
}], label: [{
|
|
@@ -362,4 +362,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-next.3",
|
|
|
362
362
|
type: HostListener,
|
|
363
363
|
args: ['mouseleave', ['$event']]
|
|
364
364
|
}] } });
|
|
365
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecl-menu-item.component.js","sourceRoot":"","sources":["../../../../../../src/lib/components/ecl-menu/ecl-menu/ecl-menu-item.component.ts","../../../../../../src/lib/components/ecl-menu/ecl-menu/ecl-menu-item.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterContentInit,\n    ApplicationRef,\n    Component,\n    ContentChild,\n    ElementRef,\n    EventEmitter,\n    forwardRef,\n    HostBinding,\n    HostListener,\n    Input,\n    OnDestroy,\n    Output,\n    Renderer2,\n    ViewChild,\n    ViewEncapsulation,\n} from '@angular/core';\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\nimport { EclMenuItem } from '../../../model/ecl-menu-item.model';\nimport { ECLBaseDirective } from '../../ecl-base.directive';\nimport {\n    EclMenuItemCaretEvent,\n    EclMenuItemFocusEvent,\n    EclMenuItemHoverEvent,\n    EclMenuItemHoverOutEvent,\n    EclMenuItemKeydownEvent,\n    EclMenuItemParentFocusEvent,\n    EclMenuItemSelectEvent,\n} from '../common/ecl-menu-item.event';\nimport { EclMenuMegaComponent } from '../ecl-menu-mega/ecl-menu-mega.component';\nimport { Params, QueryParamsHandling } from '@angular/router';\nimport { EclButtonComponent } from '../../ecl-button';\nimport { KeyCode } from '../../../utils';\nimport { BreakpointObserver, Breakpoints } from '@angular/cdk/layout';\n\nconst enum ColTrigger {\n    COL1_TRIGGER = 5,\n    COL2_TRIGGER = 9,\n    COL3_TRIGGER = 13,\n}\n\n@Component({\n    selector: 'ecl-menu-item',\n    templateUrl: './ecl-menu-item.component.html',\n    encapsulation: ViewEncapsulation.None,\n})\nexport class EclMenuItemComponent extends ECLBaseDirective implements EclMenuItem, AfterContentInit, OnDestroy {\n    @Input() id: string;\n    @Input() label: string;\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    @Input() routerLink: string | any[] = null;\n    @Input() queryParams: Params | null = null;\n    @Input() queryParamsHandling: QueryParamsHandling = null;\n    @Input() href = '';\n    @Input() target = '';\n    @Input() isCurrent = false;\n\n    isExpanded: boolean;\n    isFull = false;\n    isHovered = false;\n    isMobileBreakpoint = false;\n    isVisible = true;\n\n    @HostBinding('attr.role') role = 'listitem';\n    @HostBinding('class')\n    get cssClasses(): string {\n        return [\n            super.getCssClasses('ecl-menu__item'),\n            this.isCurrent ? 'ecl-menu__item--current' : '',\n            this.isExpanded ? 'ecl-menu__item--expanded' : '',\n            this.getClassDependingChildrenCnt(),\n        ]\n            .join(' ')\n            .trim();\n    }\n\n    @ContentChild(forwardRef(() => EclMenuMegaComponent)) submenu: EclMenuMegaComponent;\n    @ViewChild('menuLink') menuLink: ElementRef<HTMLAnchorElement>;\n    @ViewChild(EclButtonComponent) menuButton: EclButtonComponent;\n\n    @Output() menuItemSelect = new EventEmitter<EclMenuItemSelectEvent>();\n    @Output() menuItemCaret = new EventEmitter<EclMenuItemCaretEvent>();\n    @Output() menuItemHover = new EventEmitter<EclMenuItemHoverEvent>();\n    @Output() menuItemHoverOut = new EventEmitter<EclMenuItemHoverOutEvent>();\n    @Output() menuMegaItemSelect = new EventEmitter<EclMenuItemSelectEvent>();\n    @Output() menuItemFocus = new EventEmitter<EclMenuItemFocusEvent>();\n    @Output() menuItemKeydown = new EventEmitter<EclMenuItemKeydownEvent>();\n\n    @HostBinding('class.ecl-menu__item--has-children')\n    @HostBinding('attr.aria-haspopup')\n    get hasEclChildrenDataAttribute(): boolean {\n        return this.hasChildren || undefined;\n    }\n\n    @HostBinding('attr.aria-expanded')\n    get isAriaExpanded(): boolean {\n        return this.hasChildren ? this.isHovered : null;\n    }\n\n    get hasChildren(): boolean {\n        return !!this.submenu;\n    }\n\n    get children(): Array<EclMenuItem> {\n        return this.hasChildren ? this.submenu.eclMenuMegaItems.toArray() : [];\n    }\n\n    private destroy$: Subject<boolean> = new Subject<boolean>();\n\n    constructor(\n        public el: ElementRef,\n        private renderer: Renderer2,\n        private arf: ApplicationRef,\n        private cdkBreakpointObserver: BreakpointObserver,\n    ) {\n        super();\n    }\n\n    onItemFocus(evt: FocusEvent): void {\n        this.menuItemFocus.next(new EclMenuItemFocusEvent(this, evt));\n    }\n\n    onItemClick(evt: Event): void {\n        this.menuItemSelect.next(new EclMenuItemSelectEvent(this, evt));\n\n        if (!this.href) {\n            evt.stopPropagation();\n        }\n    }\n\n    onItemCaretClick(evt: MouseEvent): void {\n        this.menuItemCaret.next(new EclMenuItemCaretEvent(this, evt));\n    }\n\n    @HostListener('mouseenter', ['$event'])\n    onItemMouseEnter(evt: MouseEvent): void {\n        this.menuItemHover.next(new EclMenuItemHoverEvent(this, evt));\n    }\n\n    @HostListener('mouseleave', ['$event'])\n    onItemMouseLeave(evt: MouseEvent): void {\n        this.menuItemHoverOut.next(new EclMenuItemHoverOutEvent(this, evt));\n    }\n\n    ngAfterContentInit(): void {\n        if (this.submenu) {\n            this.submenu.menuItemSelect.pipe(takeUntil(this.destroy$)).subscribe((it: EclMenuItemSelectEvent) => {\n                this.menuMegaItemSelect.next(new EclMenuItemSelectEvent(it.menuItem, it.domEvent));\n            });\n            this.submenu.menuMegaItemParentFocus.pipe(takeUntil(this.destroy$)).subscribe((it: EclMenuItemParentFocusEvent) => {\n                this.onFocusFromSubmenu();\n            });\n\n            if (this.hasSubmenuAnySelections()) {\n                this.isCurrent = true;\n            }\n        }\n        this.observeBreakpointChanges();\n    }\n\n    ngOnDestroy(): void {\n        this.destroy$.next(true);\n        this.destroy$.unsubscribe();\n    }\n\n    onFocusFromSubmenu(): void {\n        this.onButtonFocus();\n        this.isHovered = false;\n        this.isExpanded = false;\n    }\n\n    onFocusFromNext(): void {\n        if (this.menuButton) {\n            this.onButtonFocus();\n        } else {\n            this.onLinkFocus();\n        }\n    }\n\n    onFocusFromPrev(): void {\n        this.onLinkFocus();\n    }\n\n    onButtonKeydown(evt: Event): void {\n        switch ((evt as KeyboardEvent).key) {\n            case KeyCode.ARROW_DOWN: {\n                evt.preventDefault();\n                if (this.isHovered) {\n                    this.selectFirstMegaMenuItem();\n                } else {\n                    this.menuItemKeydown.next(new EclMenuItemKeydownEvent(this, evt as KeyboardEvent));\n                }\n                break;\n            }\n            case KeyCode.ARROW_UP: {\n                evt.preventDefault();\n                this.onLinkFocus();\n                break;\n            }\n            case KeyCode.ARROW_RIGHT: {\n                evt.preventDefault();\n                this.menuItemKeydown.next(new EclMenuItemKeydownEvent(this, evt as KeyboardEvent));\n                break;\n            }\n            case KeyCode.ARROW_LEFT: {\n                evt.preventDefault();\n                this.onLinkFocus();\n                break;\n            }\n            case KeyCode.TAB: {\n                this.menuItemKeydown.next(new EclMenuItemKeydownEvent(this, evt as KeyboardEvent));\n                break;\n            }\n            case KeyCode.ENTER: {\n                evt.preventDefault();\n                this.menuItemKeydown.next(new EclMenuItemKeydownEvent(this, evt as KeyboardEvent));\n                break;\n            }\n            case KeyCode.ESCAPE: {\n                evt.preventDefault();\n                this.menuItemKeydown.next(new EclMenuItemKeydownEvent(this, evt as KeyboardEvent));\n                break;\n            }\n            default: {\n                break;\n            }\n        }\n    }\n\n    onLinkKeydown(evt: Event): void {\n        switch ((evt as KeyboardEvent).key) {\n            case KeyCode.ARROW_DOWN: {\n                evt.preventDefault();\n                this.onLinkNextFocus(evt);\n                break;\n            }\n            case KeyCode.ARROW_UP: {\n                evt.preventDefault();\n                this.menuItemKeydown.next(new EclMenuItemKeydownEvent(this, evt as KeyboardEvent));\n                break;\n            }\n            case KeyCode.ARROW_RIGHT: {\n                evt.preventDefault();\n                this.onLinkNextFocus(evt);\n                break;\n            }\n            case KeyCode.ARROW_LEFT: {\n                evt.preventDefault();\n                this.menuItemKeydown.next(new EclMenuItemKeydownEvent(this, evt as KeyboardEvent));\n                break;\n            }\n            case KeyCode.ENTER: {\n                evt.preventDefault();\n                this.onItemClick(evt);\n                break;\n            }\n            case KeyCode.ESCAPE: {\n                evt.preventDefault();\n                this.onLinkEscape(evt);\n                break;\n            }\n            default: {\n                break;\n            }\n        }\n    }\n\n    checkMenuItem(maxLines: number, isMobileBreakpoint: boolean): void {\n        if (maxLines < 1) return;\n\n        const currentItem = this.el.nativeElement;\n        const currentLink = this.menuLink.nativeElement;\n        if (isMobileBreakpoint) {\n            currentLink.style.width = '100%';\n            return;\n        }\n        this.renderer.setStyle(currentItem, 'alignItems', 'flex-start');\n        const linkStyle = window.getComputedStyle(currentLink);\n\n        const maxHeight = this.getMenuItemLinkMaxHeight(linkStyle, maxLines);\n\n        if (currentLink.offsetHeight > maxHeight) {\n            this.changeMenuItemLinkWidth(currentLink, maxLines, linkStyle);\n        }\n        this.renderer.removeStyle(currentItem, 'alignItems');\n    }\n\n    private onLinkEscape(evt: Event): void {\n        if (this.menuButton) {\n            this.menuButton.el.nativeElement.focus();\n            evt.stopPropagation();\n        } else {\n            this.menuLink.nativeElement.blur();\n        }\n    }\n\n    private selectFirstMegaMenuItem(): void {\n        this.submenu.selectFirstSubItem();\n    }\n\n    private onLinkFocus(): void {\n        this.menuLink.nativeElement.focus();\n    }\n\n    private onLinkNextFocus(evt: Event): void {\n        if (this.menuButton) {\n            this.onButtonFocus();\n        } else {\n            this.menuItemKeydown.next(new EclMenuItemKeydownEvent(this, evt as KeyboardEvent));\n        }\n    }\n\n    private onButtonFocus(): void {\n        this.menuButton.el.nativeElement.focus();\n    }\n\n    private getMenuItemLinkMaxHeight(linkStyle: CSSStyleDeclaration, maxLines: number): number {\n        return parseInt(linkStyle.lineHeight, 10) * maxLines + parseInt(linkStyle.paddingTop, 10) + parseInt(linkStyle.paddingBottom, 10);\n    }\n\n    private changeMenuItemLinkWidth(currentLink: HTMLAnchorElement, maxLines: number, linkStyle: CSSStyleDeclaration): void {\n        this.renderer.setStyle(currentLink, 'white-space', 'nowrap');\n        const linkWidth = currentLink.offsetWidth;\n        if (maxLines === 1) {\n            currentLink.style.width = `${linkWidth + parseInt(linkStyle.paddingLeft, 10) + parseInt(linkStyle.paddingRight, 10)}px`;\n            this.renderer.removeStyle(currentLink, 'white-space');\n            return;\n        }\n        const textSize = currentLink.text.length;\n        const letterWidth = Math.ceil(linkWidth / textSize);\n        const wordsArray = currentLink.text.trim().split(' ');\n        const goalWidth = Math.ceil(linkWidth / maxLines);\n        const firstWord = wordsArray[0];\n        let cnt = 1;\n        let wordWidth = Math.ceil((firstWord.length + 1) * letterWidth);\n        while (wordWidth < goalWidth) {\n            wordWidth += Math.ceil((wordsArray[cnt].length + 1) * letterWidth);\n            cnt++;\n        }\n        currentLink.style.width = `${wordWidth + parseInt(linkStyle.paddingLeft, 10) + parseInt(linkStyle.paddingRight, 10)}px`;\n        this.renderer.removeStyle(currentLink, 'white-space');\n    }\n\n    private getClassDependingChildrenCnt(): string {\n        if (this.hasChildren) {\n            if (this.submenu.eclMenuMegaItems.length < ColTrigger.COL1_TRIGGER) {\n                return 'ecl-menu__item--col1';\n            } else if (this.submenu.eclMenuMegaItems.length < ColTrigger.COL2_TRIGGER) {\n                return 'ecl-menu__item--col2';\n            } else if (this.submenu.eclMenuMegaItems.length < ColTrigger.COL3_TRIGGER) {\n                return 'ecl-menu__item--col3';\n            } else {\n                this.isFull = true;\n                return 'ecl-menu__item--full';\n            }\n        }\n        return '';\n    }\n\n    private hasSubmenuAnySelections(): boolean {\n        return this.submenu && !!this.submenu.eclMenuMegaItems.find((it) => it.isCurrent);\n    }\n\n    private observeBreakpointChanges(): void {\n        this.cdkBreakpointObserver\n            .observe([Breakpoints.Handset, Breakpoints.Tablet, Breakpoints.Small])\n            .pipe(takeUntil(this.destroy$))\n            .subscribe((result) => {\n                this.isMobileBreakpoint = result.matches;\n            });\n    }\n}\n","<a\n    #menuLink\n    *ngIf=\"href\"\n    [href]=\"href\"\n    [target]=\"target\"\n    class=\"ecl-menu__link\"\n    [class.ecl-menu__link--current]=\"isCurrent\"\n    (focus)=\"onItemFocus($event)\"\n    (click)=\"onItemClick($event)\"\n    (keydown)=\"onLinkKeydown($event)\">\n    {{ label }}\n    <ng-container *ngTemplateOutlet=\"content\"></ng-container>\n</a>\n<a\n    #menuLink\n    *ngIf=\"!href\"\n    tabindex=\"0\"\n    [routerLink]=\"routerLink\"\n    [queryParams]=\"queryParams\"\n    [queryParamsHandling]=\"queryParamsHandling\"\n    class=\"ecl-menu__link\"\n    [class.ecl-menu__link--current]=\"isCurrent\"\n    (focus)=\"onItemFocus($event)\"\n    (click)=\"onItemClick($event)\"\n    (keydown)=\"onLinkKeydown($event)\">\n    {{ label }}\n    <ng-container *ngTemplateOutlet=\"content\"></ng-container>\n</a>\n<button\n    eclButton\n    *ngIf=\"hasChildren && isMobileBreakpoint\"\n    variant=\"primary\"\n    class=\"ecl-menu__button-caret\"\n    type=\"button\"\n    aria-label=\"Access item's children\"\n    (click)=\"onItemCaretClick($event)\"\n    (keydown)=\"onButtonKeydown($event)\">\n    <ecl-icon icon=\"corner-arrow\" size=\"xs\" transform=\"rotate-180\" class=\"ecl-button__icon\"></ecl-icon>\n</button>\n<button\n    eclButton\n    *ngIf=\"hasChildren && !isMobileBreakpoint\"\n    variant=\"primary\"\n    class=\"ecl-menu__button-caret\"\n    type=\"button\"\n    aria-label=\"Access item's children\"\n    [attr.aria-expanded]=\"isAriaExpanded\"\n    (keydown)=\"onButtonKeydown($event)\">\n    <ecl-icon icon=\"corner-arrow\" size=\"xs\" transform=\"rotate-180\" class=\"ecl-button__icon\"></ecl-icon>\n</button>\n<ng-content select=\"ecl-menu-mega\"></ng-content>\n\n<ng-template #content>\n    <ng-content></ng-content>\n</ng-template>\n"]}
|
|
365
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecl-menu-item.component.js","sourceRoot":"","sources":["../../../../../../src/lib/components/ecl-menu/ecl-menu/ecl-menu-item.component.ts","../../../../../../src/lib/components/ecl-menu/ecl-menu/ecl-menu-item.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterContentInit,\n    ApplicationRef,\n    Component,\n    ContentChild,\n    ElementRef,\n    EventEmitter,\n    forwardRef,\n    HostBinding,\n    HostListener,\n    Input,\n    OnDestroy,\n    Output,\n    Renderer2,\n    ViewChild,\n    ViewEncapsulation,\n} from '@angular/core';\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\nimport { EclMenuItem } from '../../../model/ecl-menu-item.model';\nimport { ECLBaseDirective } from '../../ecl-base.directive';\nimport {\n    EclMenuItemCaretEvent,\n    EclMenuItemFocusEvent,\n    EclMenuItemHoverEvent,\n    EclMenuItemHoverOutEvent,\n    EclMenuItemKeydownEvent,\n    EclMenuItemParentFocusEvent,\n    EclMenuItemSelectEvent,\n} from '../common/ecl-menu-item.event';\nimport { EclMenuMegaComponent } from '../ecl-menu-mega/ecl-menu-mega.component';\nimport { Params, QueryParamsHandling } from '@angular/router';\nimport { EclButtonComponent } from '../../ecl-button';\nimport { KeyCode } from '../../../utils';\nimport { BreakpointObserver, Breakpoints } from '@angular/cdk/layout';\n\nconst enum ColTrigger {\n    COL1_TRIGGER = 5,\n    COL2_TRIGGER = 9,\n    COL3_TRIGGER = 13,\n}\n\n@Component({\n    selector: 'ecl-menu-item',\n    templateUrl: './ecl-menu-item.component.html',\n    encapsulation: ViewEncapsulation.None,\n})\nexport class EclMenuItemComponent extends ECLBaseDirective implements EclMenuItem, AfterContentInit, OnDestroy {\n    @Input() id: string;\n    @Input() label: string;\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    @Input() routerLink: string | any[] = null;\n    @Input() queryParams: Params | null = null;\n    @Input() queryParamsHandling: QueryParamsHandling = null;\n    @Input() href = '';\n    @Input() target = '';\n    @Input() isCurrent = false;\n\n    isExpanded: boolean;\n    isFull = false;\n    isHovered = false;\n    isMobileBreakpoint = false;\n    isVisible = true;\n\n    @HostBinding('attr.role') role = 'listitem';\n    @HostBinding('class')\n    get cssClasses(): string {\n        return [\n            super.getCssClasses('ecl-menu__item'),\n            this.isCurrent ? 'ecl-menu__item--current' : '',\n            this.isExpanded ? 'ecl-menu__item--expanded' : '',\n            this.getClassDependingChildrenCnt(),\n        ]\n            .join(' ')\n            .trim();\n    }\n\n    @ContentChild(forwardRef(() => EclMenuMegaComponent)) submenu: EclMenuMegaComponent;\n    @ViewChild('menuLink') menuLink: ElementRef<HTMLAnchorElement>;\n    @ViewChild(EclButtonComponent) menuButton: EclButtonComponent;\n\n    @Output() menuItemSelect = new EventEmitter<EclMenuItemSelectEvent>();\n    @Output() menuItemCaret = new EventEmitter<EclMenuItemCaretEvent>();\n    @Output() menuItemHover = new EventEmitter<EclMenuItemHoverEvent>();\n    @Output() menuItemHoverOut = new EventEmitter<EclMenuItemHoverOutEvent>();\n    @Output() menuMegaItemSelect = new EventEmitter<EclMenuItemSelectEvent>();\n    @Output() menuItemFocus = new EventEmitter<EclMenuItemFocusEvent>();\n    @Output() menuItemKeydown = new EventEmitter<EclMenuItemKeydownEvent>();\n\n    @HostBinding('class.ecl-menu__item--has-children')\n    @HostBinding('attr.aria-haspopup')\n    get hasEclChildrenDataAttribute(): boolean {\n        return this.hasChildren || undefined;\n    }\n\n    @HostBinding('attr.aria-expanded')\n    get isAriaExpanded(): boolean {\n        return this.hasChildren ? this.isHovered : null;\n    }\n\n    get hasChildren(): boolean {\n        return !!this.submenu;\n    }\n\n    get children(): Array<EclMenuItem> {\n        return this.hasChildren ? this.submenu.eclMenuMegaItems.toArray() : [];\n    }\n\n    private destroy$: Subject<boolean> = new Subject<boolean>();\n\n    constructor(\n        public el: ElementRef,\n        private renderer: Renderer2,\n        private arf: ApplicationRef,\n        private cdkBreakpointObserver: BreakpointObserver,\n    ) {\n        super();\n    }\n\n    onItemFocus(evt: FocusEvent): void {\n        this.menuItemFocus.next(new EclMenuItemFocusEvent(this, evt));\n    }\n\n    onItemClick(evt: Event): void {\n        this.menuItemSelect.next(new EclMenuItemSelectEvent(this, evt));\n\n        if (!this.href) {\n            evt.stopPropagation();\n        }\n    }\n\n    onItemCaretClick(evt: MouseEvent): void {\n        this.menuItemCaret.next(new EclMenuItemCaretEvent(this, evt));\n    }\n\n    @HostListener('mouseenter', ['$event'])\n    onItemMouseEnter(evt: MouseEvent): void {\n        this.menuItemHover.next(new EclMenuItemHoverEvent(this, evt));\n    }\n\n    @HostListener('mouseleave', ['$event'])\n    onItemMouseLeave(evt: MouseEvent): void {\n        this.menuItemHoverOut.next(new EclMenuItemHoverOutEvent(this, evt));\n    }\n\n    ngAfterContentInit(): void {\n        if (this.submenu) {\n            this.submenu.menuItemSelect.pipe(takeUntil(this.destroy$)).subscribe((it: EclMenuItemSelectEvent) => {\n                this.menuMegaItemSelect.next(new EclMenuItemSelectEvent(it.menuItem, it.domEvent));\n            });\n            this.submenu.menuMegaItemParentFocus.pipe(takeUntil(this.destroy$)).subscribe((it: EclMenuItemParentFocusEvent) => {\n                this.onFocusFromSubmenu();\n            });\n\n            if (this.hasSubmenuAnySelections()) {\n                this.isCurrent = true;\n            }\n        }\n        this.observeBreakpointChanges();\n    }\n\n    ngOnDestroy(): void {\n        this.destroy$.next(true);\n        this.destroy$.unsubscribe();\n    }\n\n    onFocusFromSubmenu(): void {\n        this.onButtonFocus();\n        this.isHovered = false;\n        this.isExpanded = false;\n    }\n\n    onFocusFromNext(): void {\n        if (this.menuButton) {\n            this.onButtonFocus();\n        } else {\n            this.onLinkFocus();\n        }\n    }\n\n    onFocusFromPrev(): void {\n        this.onLinkFocus();\n    }\n\n    onButtonKeydown(evt: Event): void {\n        switch ((evt as KeyboardEvent).key) {\n            case KeyCode.ARROW_DOWN: {\n                evt.preventDefault();\n                if (this.isHovered) {\n                    this.selectFirstMegaMenuItem();\n                } else {\n                    this.menuItemKeydown.next(new EclMenuItemKeydownEvent(this, evt as KeyboardEvent));\n                }\n                break;\n            }\n            case KeyCode.ARROW_UP: {\n                evt.preventDefault();\n                this.onLinkFocus();\n                break;\n            }\n            case KeyCode.ARROW_RIGHT: {\n                evt.preventDefault();\n                this.menuItemKeydown.next(new EclMenuItemKeydownEvent(this, evt as KeyboardEvent));\n                break;\n            }\n            case KeyCode.ARROW_LEFT: {\n                evt.preventDefault();\n                this.onLinkFocus();\n                break;\n            }\n            case KeyCode.TAB: {\n                this.menuItemKeydown.next(new EclMenuItemKeydownEvent(this, evt as KeyboardEvent));\n                break;\n            }\n            case KeyCode.ENTER: {\n                evt.preventDefault();\n                this.menuItemKeydown.next(new EclMenuItemKeydownEvent(this, evt as KeyboardEvent));\n                break;\n            }\n            case KeyCode.ESCAPE: {\n                evt.preventDefault();\n                this.menuItemKeydown.next(new EclMenuItemKeydownEvent(this, evt as KeyboardEvent));\n                break;\n            }\n            default: {\n                break;\n            }\n        }\n    }\n\n    onLinkKeydown(evt: Event): void {\n        switch ((evt as KeyboardEvent).key) {\n            case KeyCode.ARROW_DOWN: {\n                evt.preventDefault();\n                this.onLinkNextFocus(evt);\n                break;\n            }\n            case KeyCode.ARROW_UP: {\n                evt.preventDefault();\n                this.menuItemKeydown.next(new EclMenuItemKeydownEvent(this, evt as KeyboardEvent));\n                break;\n            }\n            case KeyCode.ARROW_RIGHT: {\n                evt.preventDefault();\n                this.onLinkNextFocus(evt);\n                break;\n            }\n            case KeyCode.ARROW_LEFT: {\n                evt.preventDefault();\n                this.menuItemKeydown.next(new EclMenuItemKeydownEvent(this, evt as KeyboardEvent));\n                break;\n            }\n            case KeyCode.ENTER: {\n                evt.preventDefault();\n                this.onItemClick(evt);\n                break;\n            }\n            case KeyCode.ESCAPE: {\n                evt.preventDefault();\n                this.onLinkEscape(evt);\n                break;\n            }\n            default: {\n                break;\n            }\n        }\n    }\n\n    checkMenuItem(maxLines: number, isMobileBreakpoint: boolean): void {\n        if (maxLines < 1) return;\n\n        const currentItem = this.el.nativeElement;\n        const currentLink = this.menuLink.nativeElement;\n        if (isMobileBreakpoint) {\n            currentLink.style.width = '100%';\n            return;\n        }\n        this.renderer.setStyle(currentItem, 'alignItems', 'flex-start');\n        const linkStyle = window.getComputedStyle(currentLink);\n\n        const maxHeight = this.getMenuItemLinkMaxHeight(linkStyle, maxLines);\n\n        if (currentLink.offsetHeight > maxHeight) {\n            this.changeMenuItemLinkWidth(currentLink, maxLines, linkStyle);\n        }\n        this.renderer.removeStyle(currentItem, 'alignItems');\n    }\n\n    private onLinkEscape(evt: Event): void {\n        if (this.menuButton) {\n            this.menuButton.el.nativeElement.focus();\n            evt.stopPropagation();\n        } else {\n            this.menuLink.nativeElement.blur();\n        }\n    }\n\n    private selectFirstMegaMenuItem(): void {\n        this.submenu.selectFirstSubItem();\n    }\n\n    private onLinkFocus(): void {\n        this.menuLink.nativeElement.focus();\n    }\n\n    private onLinkNextFocus(evt: Event): void {\n        if (this.menuButton) {\n            this.onButtonFocus();\n        } else {\n            this.menuItemKeydown.next(new EclMenuItemKeydownEvent(this, evt as KeyboardEvent));\n        }\n    }\n\n    private onButtonFocus(): void {\n        this.menuButton.el.nativeElement.focus();\n    }\n\n    private getMenuItemLinkMaxHeight(linkStyle: CSSStyleDeclaration, maxLines: number): number {\n        return parseInt(linkStyle.lineHeight, 10) * maxLines + parseInt(linkStyle.paddingTop, 10) + parseInt(linkStyle.paddingBottom, 10);\n    }\n\n    private changeMenuItemLinkWidth(currentLink: HTMLAnchorElement, maxLines: number, linkStyle: CSSStyleDeclaration): void {\n        this.renderer.setStyle(currentLink, 'white-space', 'nowrap');\n        const linkWidth = currentLink.offsetWidth;\n        if (maxLines === 1) {\n            currentLink.style.width = `${linkWidth + parseInt(linkStyle.paddingLeft, 10) + parseInt(linkStyle.paddingRight, 10)}px`;\n            this.renderer.removeStyle(currentLink, 'white-space');\n            return;\n        }\n        const textSize = currentLink.text.length;\n        const letterWidth = Math.ceil(linkWidth / textSize);\n        const wordsArray = currentLink.text.trim().split(' ');\n        const goalWidth = Math.ceil(linkWidth / maxLines);\n        const firstWord = wordsArray[0];\n        let cnt = 1;\n        let wordWidth = Math.ceil((firstWord.length + 1) * letterWidth);\n        while (wordWidth < goalWidth) {\n            wordWidth += Math.ceil((wordsArray[cnt].length + 1) * letterWidth);\n            cnt++;\n        }\n        currentLink.style.width = `${wordWidth + parseInt(linkStyle.paddingLeft, 10) + parseInt(linkStyle.paddingRight, 10)}px`;\n        this.renderer.removeStyle(currentLink, 'white-space');\n    }\n\n    private getClassDependingChildrenCnt(): string {\n        if (this.hasChildren) {\n            if (this.submenu.eclMenuMegaItems.length < ColTrigger.COL1_TRIGGER) {\n                return 'ecl-menu__item--col1';\n            } else if (this.submenu.eclMenuMegaItems.length < ColTrigger.COL2_TRIGGER) {\n                return 'ecl-menu__item--col2';\n            } else if (this.submenu.eclMenuMegaItems.length < ColTrigger.COL3_TRIGGER) {\n                return 'ecl-menu__item--col3';\n            } else {\n                this.isFull = true;\n                return 'ecl-menu__item--full';\n            }\n        }\n        return '';\n    }\n\n    private hasSubmenuAnySelections(): boolean {\n        return this.submenu && !!this.submenu.eclMenuMegaItems.find((it) => it.isCurrent);\n    }\n\n    private observeBreakpointChanges(): void {\n        this.cdkBreakpointObserver\n            .observe([Breakpoints.Handset, Breakpoints.Tablet, Breakpoints.Small])\n            .pipe(takeUntil(this.destroy$))\n            .subscribe((result) => {\n                this.isMobileBreakpoint = result.matches;\n            });\n    }\n}\n","<a\n    #menuLink\n    variant=\"standalone\"\n    *ngIf=\"href\"\n    [href]=\"href\"\n    [target]=\"target\"\n    class=\"ecl-menu__link\"\n    [class.ecl-menu__link--current]=\"isCurrent\"\n    (focus)=\"onItemFocus($event)\"\n    (click)=\"onItemClick($event)\"\n    (keydown)=\"onLinkKeydown($event)\">\n    {{ label }}\n    <ng-container *ngTemplateOutlet=\"content\"></ng-container>\n</a>\n<a\n    #menuLink\n    variant=\"standalone\"\n    *ngIf=\"!href\"\n    tabindex=\"0\"\n    [routerLink]=\"routerLink\"\n    [queryParams]=\"queryParams\"\n    [queryParamsHandling]=\"queryParamsHandling\"\n    class=\"ecl-menu__link\"\n    [class.ecl-menu__link--current]=\"isCurrent\"\n    (focus)=\"onItemFocus($event)\"\n    (click)=\"onItemClick($event)\"\n    (keydown)=\"onLinkKeydown($event)\">\n    {{ label }}\n    <ng-container *ngTemplateOutlet=\"content\"></ng-container>\n</a>\n<button\n    eclButton\n    isIconOnly\n    *ngIf=\"hasChildren && isMobileBreakpoint\"\n    variant=\"ghost\"\n    class=\"ecl-menu__button-caret\"\n    type=\"button\"\n    aria-label=\"Access item's children\"\n    (click)=\"onItemCaretClick($event)\"\n    (keydown)=\"onButtonKeydown($event)\">\n    <ecl-icon icon=\"corner-arrow\" size=\"xs\" transform=\"rotate-180\" class=\"ecl-button__icon\"></ecl-icon>\n</button>\n<button\n    eclButton\n    isIconOnly\n    *ngIf=\"hasChildren && !isMobileBreakpoint\"\n    variant=\"ghost\"\n    class=\"ecl-menu__button-caret\"\n    type=\"button\"\n    aria-label=\"Access item's children\"\n    [attr.aria-expanded]=\"isAriaExpanded\"\n    (keydown)=\"onButtonKeydown($event)\">\n    <ecl-icon icon=\"corner-arrow\" size=\"xs\" transform=\"rotate-180\" class=\"ecl-button__icon\"></ecl-icon>\n</button>\n<ng-content select=\"ecl-menu-mega\"></ng-content>\n\n<ng-template #content>\n    <ng-content></ng-content>\n</ng-template>\n"]}
|