@eui/components 18.0.1 → 18.0.2-snapshot-1718193852574

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.
@@ -1,5 +1,6 @@
1
1
  import { Component, HostBinding, ViewEncapsulation, Input, Output, EventEmitter, HostListener, booleanAttribute, } from '@angular/core';
2
2
  import { consumeEvent } from '@eui/core';
3
+ import { coerceBooleanProperty } from '@angular/cdk/coercion';
3
4
  import * as i0 from "@angular/core";
4
5
  import * as i1 from "@angular/common";
5
6
  import * as i2 from "@angular/router";
@@ -16,12 +17,7 @@ export class EuiMenuItemComponent {
16
17
  return this.item?.children?.length > 0 ? true : undefined;
17
18
  }
18
19
  get ariaExpanded() {
19
- if (this.item.children) {
20
- return this.item.expanded ? true : false;
21
- }
22
- else {
23
- return undefined;
24
- }
20
+ return this.item.children ? coerceBooleanProperty(this.item.expanded) : undefined;
25
21
  }
26
22
  get ariaDisabled() {
27
23
  return this.item.disabled;
@@ -101,7 +97,6 @@ export class EuiMenuItemComponent {
101
97
  }
102
98
  /**
103
99
  * Check if an element is visible in the viewport
104
- * @param el
105
100
  * @param partiallyVisible
106
101
  */
107
102
  elementIsVisibleInViewport(partiallyVisible = false) {
@@ -121,31 +116,16 @@ export class EuiMenuItemComponent {
121
116
  this.elementRef.nativeElement.scrollIntoView(properties);
122
117
  }
123
118
  getTooltipFromItem(item) {
124
- if (item.tagLabel && item.label) {
125
- return item.label + ' (' + item.tagLabel + ')';
126
- }
127
- else if (item.label) {
128
- return item.label;
129
- }
130
- else if (item.tagLabel) {
131
- return item.tagLabel;
132
- }
133
- return null;
119
+ return item.label && item.tagLabel ? `${item.label} (${item.tagLabel})` : item.label ||
120
+ item.tagLabel ||
121
+ null;
134
122
  }
135
123
  getAriaLabel() {
136
- if (this.item.label) {
137
- return this.item.label;
138
- }
139
- else if (this.item.tagLabel) {
140
- return this.item.tagLabel;
141
- }
142
- else if (this.item.actionIcon && this.item.actionIcon.label) {
143
- return this.item.actionIcon.label;
144
- }
145
- else if (this.item.iconLabel) {
146
- return this.item.iconLabel;
147
- }
148
- return 'Eui menu item';
124
+ return this.item.label ||
125
+ this.item.tagLabel ||
126
+ (this.item.actionIcon && this.item.actionIcon.label) ||
127
+ this.item.iconLabel ||
128
+ 'Eui menu item';
149
129
  }
150
130
  /**
151
131
  * Returns the default eui-menu-item class on the HostBinding function
@@ -211,4 +191,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.2", ngImpor
211
191
  type: HostListener,
212
192
  args: ['click', ['$event']]
213
193
  }] } });
214
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eui-menu-item.component.js","sourceRoot":"","sources":["../../../eui-menu/eui-menu-item.component.ts","../../../eui-menu/eui-menu-item.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    HostBinding,\n    ViewEncapsulation,\n    Input,\n    Output,\n    EventEmitter,\n    HostListener,\n    OnInit,\n    OnChanges,\n    SimpleChanges,\n    booleanAttribute,\n    ElementRef,\n} from '@angular/core';\nimport { FocusableOption } from '@angular/cdk/a11y';\n\nimport { consumeEvent } from '@eui/core';\nimport { EuiMenuItem } from './models/eui-menu-item.model';\n\n@Component({\n    selector: 'eui-menu-item',\n    templateUrl: './eui-menu-item.component.html',\n    styleUrls: ['./styles/_index.scss'],\n    encapsulation: ViewEncapsulation.None,\n})\nexport class EuiMenuItemComponent implements OnInit, OnChanges, FocusableOption {\n\n    @HostBinding('attr.role') role = 'menuitem';\n    @HostBinding('attr.aria-label') ariaLabel = '';\n\n    @HostBinding('class')\n    public get cssClasses(): string {\n        return this.getCssClasses();\n    }\n    @HostBinding('attr.tabindex') tabindex = '-1';\n    @HostBinding('attr.aria-haspopup')\n    get ariaHasPopup(): boolean {\n        return this.item?.children?.length > 0? true : undefined;\n    }\n    @HostBinding('attr.aria-expanded')\n    get ariaExpanded(): boolean {\n        if(this.item.children) {\n            return this.item.expanded ? true : false;\n        } else {\n            return undefined;\n        }\n    }\n    @HostBinding('attr.aria-disabled')\n    get ariaDisabled(): boolean {\n        return this.item.disabled\n    }\n\n    @Input() item: EuiMenuItem;\n    @Input() parent: EuiMenuItem;\n    @Output() expandToggle = new EventEmitter<EuiMenuItem>();\n    @Output() itemClick = new EventEmitter<EuiMenuItem>();\n\n    expandMenuLabel = 'Expand';\n    collapseMenuLabel = 'Collapse';\n\n    isUrlItem = false;\n    isLinkItem = false;\n    isLabelItem = false;\n    isActionIconFocused = false;\n\n    @Input({ transform: booleanAttribute }) hasIcon: boolean;\n    @Input({ transform: booleanAttribute }) hasTooltip: boolean;\n    @Input({ transform: booleanAttribute }) isCollapsed: boolean;\n    @Input({ transform: booleanAttribute }) hasCollapsedInitials: boolean;\n    @Input({ transform: booleanAttribute }) hasBoldRootLevel: boolean;\n\n    constructor(private elementRef: ElementRef) {}\n\n    ngOnInit(): void {\n        this.isUrlItem = (this.item.url || this.item.urlExternal || this.item.children || this.item.command) && !this.item.link;\n        this.isLabelItem = !this.item.url && !this.item.urlExternal && !this.item.command && !this.item.children && !this.item.link;\n\n        this.isLinkItem = !this.isUrlItem && !this.isLabelItem;\n        this.ariaLabel = this.getAriaLabel();\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (changes.item && changes.item.isFirstChange()) {\n            this.item = changes.item.currentValue;\n            if(!this.item.urlExternalTarget) {\n                this.item.urlExternalTarget = '_blank';\n            }\n            if(this.item.filtered === undefined) {\n                this.item.filtered = true;\n            }\n            if(this.item.disabled === undefined) {\n                this.item.visible = true;\n            }\n        }\n    }\n\n    @HostListener('click', ['$event'])\n    public stopPropagation(event: Event): void {\n        this.itemClick.emit(this.item);\n        consumeEvent(event);\n    }\n\n    get menuItemTooltip(): string {\n        if (this.hasTooltip && this.isCollapsed) {\n            return this.item.tooltip || this.getTooltipFromItem(this.item);\n        }\n        return null;\n    }\n\n    public onClick(event: Event): void {\n        this.itemClick.emit(this.item);\n        this.focus();\n        consumeEvent(event);\n    }\n\n    public onExpandToggle(event: Event): void {\n        this.expandToggle.emit(this.item);\n        consumeEvent(event);\n    }\n\n    public onActionIconClick(event: Event): void {\n        this.item.actionIcon?.action(event);\n        consumeEvent(event);\n    }\n\n    onActionIconKeyDown(event: KeyboardEvent): void {\n        if (event.key === 'Enter') {\n            this.item.actionIcon?.action(event);\n            consumeEvent(event);\n        }\n    }\n\n    public focusActionIcon(): void {\n        this.elementRef.nativeElement.querySelector('.eui-menu-item__link-action-icon').focus();\n        this.isActionIconFocused = true;\n    }\n\n    onActionIconFocusOut(): void {\n        this.isActionIconFocused = false;\n    }\n\n    public focus(): void {\n        this.elementRef.nativeElement.focus();\n    }\n\n    /**\n     * Check if an element is visible in the viewport\n     * @param el\n     * @param partiallyVisible\n     */\n    elementIsVisibleInViewport(partiallyVisible = false): boolean {\n        const { top, left, bottom, right } = this.elementRef.nativeElement.getBoundingClientRect();\n        const { innerHeight, innerWidth } = window;\n        return partiallyVisible\n            ? ((top > 0 && top < innerHeight) ||\n                (bottom > 0 && bottom < innerHeight)) &&\n            ((left > 0 && left < innerWidth) || (right > 0 && right < innerWidth))\n            : top >= 0 && left >= 0 && bottom <= innerHeight && right <= innerWidth;\n    }\n\n    /**\n     * Scroll the element into view\n     * @param properties\n     */\n    scrollIntoView(properties: unknown): void {\n        this.elementRef.nativeElement.scrollIntoView(properties);\n    }\n\n    private getTooltipFromItem(item: EuiMenuItem): string {\n        if (item.tagLabel && item.label) {\n            return item.label + ' (' + item.tagLabel + ')';\n        } else if (item.label) {\n            return item.label;\n        } else if (item.tagLabel) {\n            return item.tagLabel;\n        }\n        return null;\n    }\n\n    private getAriaLabel(): string {\n        if (this.item.label) {\n            return this.item.label;\n        } else if (this.item.tagLabel) {\n            return this.item.tagLabel;\n        } else if (this.item.actionIcon && this.item.actionIcon.label) {\n            return this.item.actionIcon.label;\n        } else if (this.item.iconLabel) {\n            return this.item.iconLabel;\n        }\n        return 'Eui menu item';\n    }\n\n    /**\n     * Returns the default eui-menu-item class on the HostBinding function\n     * @private\n     */\n    private getCssClasses(): string {\n        return [\n            'eui-menu-item',\n            !this.parent && this.hasBoldRootLevel ? 'eui-menu-item--bold' : '',\n        ].join(' ').trim();\n    }\n}\n","@if (item.visible && item.filtered) {\n    @if (isLabelItem) {\n        <li\n            role=\"none\"\n            id=\"{{item.id}}\"\n            class=\"eui-menu-item__content\"\n            [attr.data-e2e]=\"item.e2eAttr\"\n            [class.eui-menu-item--disabled]=\"item.disabled\"\n            [attr.aria-disabled]=\"item.disabled\"\n            [euiTooltip]=\"menuItemTooltip\"\n            tabindex=\"-1\"\n            position=\"after\">\n\n            <a\n                (click)=\"onClick($event)\"\n                tabindex=\"-1\"\n                class=\"eui-menu-item__link eui-menu-item__link-category\"\n                [class.eui-menu-item__link--disabled]=\"item.disabled\"\n                [class.eui-menu-item__link--active]=\"item.active\"\n                [class.eui-menu-item__link--has-sub]=\"item.children?.length > 0\"\n                href=\"javascript:void(0)\"\n                [euiTooltip]=\"menuItemTooltip\"\n                position=\"after\">\n\n                <div class=\"eui-menu-item__link-start-block\">\n                    <ng-template *ngTemplateOutlet=\"itemIconContent\" [ngTemplateOutletContext]=\"{ $implicit: item }\"></ng-template>\n                </div>\n\n                <div class=\"eui-menu-item__link-content-block\">\n                    <div class=\"eui-menu-item__link-label-container\">\n                        <span class=\"eui-menu-item__link-label-category\">{{ item.label }}</span>\n                    </div>\n                </div>\n\n                <div class=\"eui-menu-item__link-end-block\">\n                    <ng-template *ngTemplateOutlet=\"itemEndContent\" [ngTemplateOutletContext]=\"{ $implicit: item }\"></ng-template>\n                </div>\n            </a>\n        </li>\n    }\n\n    @if (isUrlItem) {\n        <li\n            role=\"none\"\n            id=\"{{item.id}}\"\n            [attr.data-e2e]=\"item.e2eAttr\"\n            class=\"eui-menu-item__content\"\n            [class.eui-menu-item--disabled]=\"item.disabled\"\n            [class.eui-menu-item--expanded]=\"item.expanded || item.filtered\"\n            [attr.aria-disabled]=\"item.disabled\">\n            <a\n                (click)=\"onClick($event)\"\n                class=\"eui-menu-item__link\"\n                [class.eui-menu-item__link--disabled]=\"item.disabled\"\n                [class.eui-menu-item__link--active]=\"item.active\"\n                [class.eui-menu-item__link--has-sub]=\"item.children?.length > 0\"\n                [routerLink]=\"item.url ? item.url : null\"\n                [routerLinkActive]=\"item.url ? 'eui-menu-item__link--active' : ''\"\n                [euiTooltip]=\"menuItemTooltip\"\n                position=\"after\"\n                tabindex=\"-1\">\n                <ng-template *ngTemplateOutlet=\"linkContent\" [ngTemplateOutletContext]=\"{ $implicit: item }\"></ng-template>\n            </a>\n\n            <ng-template *ngTemplateOutlet=\"content\"></ng-template>\n        </li>\n    }\n\n    @if (isLinkItem) {\n        <li\n            role=\"none\"\n            id=\"{{item.id}}\"\n            [attr.data-e2e]=\"item.e2eAttr\"\n            class=\"eui-menu-item__content\"\n            [class.eui-menu-item--disabled]=\"item.disabled\"\n            [class.eui-menu-item--expanded]=\"item.expanded || item.filtered\"\n            [attr.aria-disabled]=\"item.disabled\">\n            <a\n                (click)=\"onClick($event)\"\n                tabindex=\"-1\"\n                class=\"eui-menu-item__link\"\n                [class.eui-menu-item__link--disabled]=\"item.disabled\"\n                [class.eui-menu-item__link--active]=\"item.active\"\n                [class.eui-menu-item__link--has-sub]=\"item.children?.length > 0\"\n                href=\"javascript:void(0)\"\n                [euiTooltip]=\"menuItemTooltip\"\n                position=\"after\">\n                <ng-template *ngTemplateOutlet=\"linkContent\" [ngTemplateOutletContext]=\"{ $implicit: item }\"></ng-template>\n            </a>\n\n            <ng-template *ngTemplateOutlet=\"content\"></ng-template>\n        </li>\n    }\n}\n\n<ng-template #linkContent>\n    <div class=\"eui-menu-item__link-start-block\">\n        <ng-template *ngTemplateOutlet=\"itemIconContent\" [ngTemplateOutletContext]=\"{ $implicit: item }\"></ng-template>\n    </div>\n\n    <div class=\"eui-menu-item__link-content-block\">\n        <div class=\"eui-menu-item__link-label-container\">\n            <span class=\"eui-menu-item__link-label\">{{ item.label }}</span>\n            <eui-icon-svg\n                *ngIf=\"item.urlExternal && item.urlExternalTarget === '_blank'\"\n                class=\"eui-menu-item__label-external\"\n                icon=\"eui-ecl-external\"\n                size=\"2xs\"\n                aria-label=\"external link icon\"\n                euiEnd>\n            </eui-icon-svg>\n        </div>\n    </div>\n\n    <div class=\"eui-menu-item__link-end-block\">\n        <ng-template *ngTemplateOutlet=\"itemEndContent\" [ngTemplateOutletContext]=\"{ $implicit: item }\"></ng-template>\n    </div>\n</ng-template>\n\n<!-- PROJECTED CONTENT BLOCK -->\n<ng-template #content>\n    <ng-content></ng-content>\n</ng-template>\n\n<!-- PROJECTED START BLOCK -->\n<ng-template #itemIconContent>\n    @if (!isCollapsed) {\n        @if (hasIcon) {\n            @if (item.iconSvgName) {\n                <!-- SVG -->\n                <eui-icon-svg\n                    class=\"eui-menu-item__link-icon\"\n                    icon=\"{{ item.iconSvgName }}\"\n                    fillColor=\"{{ item.iconTypeClass }}\">\n                </eui-icon-svg>\n            } @else if (item.hasMarker) {\n                <!-- MARKER -->\n                <eui-icon-svg\n                    class=\"eui-menu-item__link-marker\"\n                    fillColor=\"{{ item?.markerTypeClass }}\"\n                    icon=\"ellipse:sharp\"\n                    size=\"2xs\"\n                    [aria-label]=\"item.markerTypeClass + ' ' + 'marker'\">\n                </eui-icon-svg>\n            }\n            @else if (!isLabelItem) {\n                <!-- DEFAULT for non category items -->\n                <eui-icon-svg\n                    class=\"eui-menu-item__link-icon\"\n                    icon=\"ellipse:sharp\"\n                    fillColor=\"neutral-light\"\n                    size=\"2xs\">\n                </eui-icon-svg>\n            }\n        } @else if (item.hasMarker) {\n            <eui-icon-svg\n                class=\"eui-menu-item__link-marker\"\n                fillColor=\"{{ item?.markerTypeClass }}\"\n                icon=\"ellipse:sharp\"\n                size=\"2xs\"\n                [aria-label]=\"item.markerTypeClass + ' ' + 'marker'\">\n            </eui-icon-svg>\n        }\n\n    } @else {\n        @if (hasCollapsedInitials) {\n            <span class=\"eui-menu-item__link-initials eui-u-c-bg-{{item.iconTypeClass}}\">\n                {{ item.initials }}\n            </span>\n        } @else {\n            @if (hasIcon) {\n                @if (item.iconSvgName) {\n                    <!-- SVG -->\n                    <eui-icon-svg\n                        class=\"eui-menu-item__link-icon\"\n                        icon=\"{{ item.iconSvgName }}\"\n                        fillColor=\"{{ item.iconTypeClass }}\">\n                    </eui-icon-svg>\n\n                } @else if (item.hasMarker) {\n                    <!-- MARKER -->\n                    <eui-icon-svg\n                        class=\"eui-menu-item__link-marker\"\n                        fillColor=\"{{ item?.markerTypeClass }}\"\n                        icon=\"ellipse:sharp\"\n                        size=\"2xs\"\n                        [aria-label]=\"item.markerTypeClass + ' ' + 'marker'\">\n                    </eui-icon-svg>\n                } @else {\n                    <!-- DEFAULT -->\n                    <eui-icon-svg\n                        class=\"eui-menu-item__link-icon\"\n                        icon=\"ellipse:sharp\"\n                        fillColor=\"neutral-light\"\n                        size=\"2xs\"\n                        [aria-label]=\"item.iconLabel\">\n                    </eui-icon-svg>\n                }\n            } @else {\n                <eui-icon-svg\n                    class=\"eui-menu-item__link-icon eui-u-ml-2xs\"\n                    icon=\"square:sharp\"\n                    fillColor=\"neutral-light\"\n                    size=\"2xs\">\n                </eui-icon-svg>\n            }\n        }\n    }\n</ng-template>\n\n<!-- PROJECTED END BLOCK -->\n<ng-template #itemEndContent>\n    @if (item.tagLabel) {\n        @if (isCollapsed) {\n            <eui-badge [euiVariant]=\"item.tagTypeClass\" class=\"eui-menu-item__link-dotted-badge\"></eui-badge>\n        } @else {\n            <eui-badge [euiVariant]=\"item.tagTypeClass\">\n                {{ item.tagLabel }}\n            </eui-badge>\n        }\n    }\n\n    <button\n        *ngIf=\"item.actionIcon\"\n        euiButton\n        euiRounded\n        euiIconButton\n        euiSizeS\n        euiBasicButton\n        type=\"button\"\n        tabindex=\"-1\"\n        (keydown)=\"onActionIconKeyDown($event)\"\n        (focusout)=\"onActionIconFocusOut()\"\n        (focus)=\"focusActionIcon()\"\n        class=\"eui-menu-item__link-action-icon\"\n        [euiDisabled]=\"item.disabled\"\n        [attr.aria-label]=\"item.actionIcon?.label\"\n        (click)=\"onActionIconClick($event)\">\n        <eui-icon-svg [icon]=\"item.actionIcon?.icon\" [fillColor]=\"item.actionIcon?.color\"></eui-icon-svg>\n    </button>\n\n    <eui-icon-button *ngIf=\"item.children?.length > 0\"\n        class=\"eui-menu-item__link-toggle\"\n        [icon]=\"item.expanded ? 'chevron-up:sharp': 'chevron-down:sharp'\"\n        (buttonClick)=\"onExpandToggle($event)\"\n        [ariaLabel]=\"item.expanded ? collapseMenuLabel : expandMenuLabel\"\n        euiRounded\n        size=\"s\"\n        [tabindex]=\"-1\"\n        [euiDisabled]=\"item.disabled\"/>\n</ng-template>\n"]}
194
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eui-menu-item.component.js","sourceRoot":"","sources":["../../../eui-menu/eui-menu-item.component.ts","../../../eui-menu/eui-menu-item.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    HostBinding,\n    ViewEncapsulation,\n    Input,\n    Output,\n    EventEmitter,\n    HostListener,\n    OnInit,\n    OnChanges,\n    SimpleChanges,\n    booleanAttribute,\n    ElementRef,\n} from '@angular/core';\nimport { FocusableOption } from '@angular/cdk/a11y';\n\nimport { consumeEvent } from '@eui/core';\nimport { EuiMenuItem } from './models/eui-menu-item.model';\nimport { coerceBooleanProperty } from '@angular/cdk/coercion';\n\n@Component({\n    selector: 'eui-menu-item',\n    templateUrl: './eui-menu-item.component.html',\n    styleUrls: ['./styles/_index.scss'],\n    encapsulation: ViewEncapsulation.None,\n})\nexport class EuiMenuItemComponent implements OnInit, OnChanges, FocusableOption {\n\n    @HostBinding('attr.role') role = 'menuitem';\n    @HostBinding('attr.aria-label') ariaLabel = '';\n\n    @HostBinding('class')\n    public get cssClasses(): string {\n        return this.getCssClasses();\n    }\n    @HostBinding('attr.tabindex') tabindex = '-1';\n    @HostBinding('attr.aria-haspopup')\n    get ariaHasPopup(): boolean {\n        return this.item?.children?.length > 0 ? true : undefined;\n    }\n    @HostBinding('attr.aria-expanded')\n    get ariaExpanded(): boolean {\n        return this.item.children ? coerceBooleanProperty(this.item.expanded) : undefined;\n    }\n    @HostBinding('attr.aria-disabled')\n    get ariaDisabled(): boolean {\n        return this.item.disabled\n    }\n\n    @Input() item: EuiMenuItem;\n    @Input() parent: EuiMenuItem;\n    @Output() expandToggle = new EventEmitter<EuiMenuItem>();\n    @Output() itemClick = new EventEmitter<EuiMenuItem>();\n\n    expandMenuLabel = 'Expand';\n    collapseMenuLabel = 'Collapse';\n\n    isUrlItem = false;\n    isLinkItem = false;\n    isLabelItem = false;\n    isActionIconFocused = false;\n\n    @Input({ transform: booleanAttribute }) hasIcon: boolean;\n    @Input({ transform: booleanAttribute }) hasTooltip: boolean;\n    @Input({ transform: booleanAttribute }) isCollapsed: boolean;\n    @Input({ transform: booleanAttribute }) hasCollapsedInitials: boolean;\n    @Input({ transform: booleanAttribute }) hasBoldRootLevel: boolean;\n\n    constructor(private elementRef: ElementRef) {}\n\n    ngOnInit(): void {\n        this.isUrlItem = (this.item.url || this.item.urlExternal || this.item.children || this.item.command) && !this.item.link;\n        this.isLabelItem = !this.item.url && !this.item.urlExternal && !this.item.command && !this.item.children && !this.item.link;\n\n        this.isLinkItem = !this.isUrlItem && !this.isLabelItem;\n        this.ariaLabel = this.getAriaLabel();\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (changes.item && changes.item.isFirstChange()) {\n            this.item = changes.item.currentValue;\n            if(!this.item.urlExternalTarget) {\n                this.item.urlExternalTarget = '_blank';\n            }\n            if(this.item.filtered === undefined) {\n                this.item.filtered = true;\n            }\n            if(this.item.disabled === undefined) {\n                this.item.visible = true;\n            }\n        }\n    }\n\n    @HostListener('click', ['$event'])\n    public stopPropagation(event: Event): void {\n        this.itemClick.emit(this.item);\n        consumeEvent(event);\n    }\n\n    get menuItemTooltip(): string {\n        if (this.hasTooltip && this.isCollapsed) {\n            return this.item.tooltip || this.getTooltipFromItem(this.item);\n        }\n        return null;\n    }\n\n    public onClick(event: Event): void {\n        this.itemClick.emit(this.item);\n        this.focus();\n        consumeEvent(event);\n    }\n\n    public onExpandToggle(event: Event): void {\n        this.expandToggle.emit(this.item);\n        consumeEvent(event);\n    }\n\n    public onActionIconClick(event: Event): void {\n        this.item.actionIcon?.action(event);\n        consumeEvent(event);\n    }\n\n    public onActionIconKeyDown(event: KeyboardEvent): void {\n        if (event.key === 'Enter') {\n            this.item.actionIcon?.action(event);\n            consumeEvent(event);\n        }\n    }\n\n    public focusActionIcon(): void {\n        this.elementRef.nativeElement.querySelector('.eui-menu-item__link-action-icon').focus();\n        this.isActionIconFocused = true;\n    }\n\n    onActionIconFocusOut(): void {\n        this.isActionIconFocused = false;\n    }\n\n    public focus(): void {\n        this.elementRef.nativeElement.focus();\n    }\n\n    /**\n     * Check if an element is visible in the viewport\n     * @param partiallyVisible\n     */\n    elementIsVisibleInViewport(partiallyVisible = false): boolean {\n        const { top, left, bottom, right } = this.elementRef.nativeElement.getBoundingClientRect();\n        const { innerHeight, innerWidth } = window as Window;\n        return partiallyVisible\n            ? ((top > 0 && top < innerHeight) ||\n                (bottom > 0 && bottom < innerHeight)) &&\n            ((left > 0 && left < innerWidth) || (right > 0 && right < innerWidth))\n            : top >= 0 && left >= 0 && bottom <= innerHeight && right <= innerWidth;\n    }\n\n    /**\n     * Scroll the element into view\n     * @param properties\n     */\n    scrollIntoView(properties: unknown): void {\n        this.elementRef.nativeElement.scrollIntoView(properties);\n    }\n\n    private getTooltipFromItem(item: EuiMenuItem): string {\n        return item.label && item.tagLabel ? `${item.label} (${item.tagLabel})` : item.label ||\n            item.tagLabel ||\n            null;\n    }\n\n    private getAriaLabel(): string {\n        return this.item.label ||\n            this.item.tagLabel ||\n            (this.item.actionIcon && this.item.actionIcon.label) ||\n            this.item.iconLabel ||\n            'Eui menu item';\n    }\n\n    /**\n     * Returns the default eui-menu-item class on the HostBinding function\n     * @private\n     */\n    private getCssClasses(): string {\n        return [\n            'eui-menu-item',\n            !this.parent && this.hasBoldRootLevel ? 'eui-menu-item--bold' : '',\n        ].join(' ').trim();\n    }\n}\n","@if (item.visible && item.filtered) {\n    @if (isLabelItem) {\n        <li\n            role=\"none\"\n            id=\"{{item.id}}\"\n            class=\"eui-menu-item__content\"\n            [attr.data-e2e]=\"item.e2eAttr\"\n            [class.eui-menu-item--disabled]=\"item.disabled\"\n            [attr.aria-disabled]=\"item.disabled\"\n            [euiTooltip]=\"menuItemTooltip\"\n            tabindex=\"-1\"\n            position=\"after\">\n\n            <a\n                (click)=\"onClick($event)\"\n                tabindex=\"-1\"\n                class=\"eui-menu-item__link eui-menu-item__link-category\"\n                [class.eui-menu-item__link--disabled]=\"item.disabled\"\n                [class.eui-menu-item__link--active]=\"item.active\"\n                [class.eui-menu-item__link--has-sub]=\"item.children?.length > 0\"\n                href=\"javascript:void(0)\"\n                [euiTooltip]=\"menuItemTooltip\"\n                position=\"after\">\n\n                <div class=\"eui-menu-item__link-start-block\">\n                    <ng-template *ngTemplateOutlet=\"itemIconContent\" [ngTemplateOutletContext]=\"{ $implicit: item }\"></ng-template>\n                </div>\n\n                <div class=\"eui-menu-item__link-content-block\">\n                    <div class=\"eui-menu-item__link-label-container\">\n                        <span class=\"eui-menu-item__link-label-category\">{{ item.label }}</span>\n                    </div>\n                </div>\n\n                <div class=\"eui-menu-item__link-end-block\">\n                    <ng-template *ngTemplateOutlet=\"itemEndContent\" [ngTemplateOutletContext]=\"{ $implicit: item }\"></ng-template>\n                </div>\n            </a>\n        </li>\n    }\n\n    @if (isUrlItem) {\n        <li\n            role=\"none\"\n            id=\"{{item.id}}\"\n            [attr.data-e2e]=\"item.e2eAttr\"\n            class=\"eui-menu-item__content\"\n            [class.eui-menu-item--disabled]=\"item.disabled\"\n            [class.eui-menu-item--expanded]=\"item.expanded || item.filtered\"\n            [attr.aria-disabled]=\"item.disabled\">\n            <a\n                (click)=\"onClick($event)\"\n                class=\"eui-menu-item__link\"\n                [class.eui-menu-item__link--disabled]=\"item.disabled\"\n                [class.eui-menu-item__link--active]=\"item.active\"\n                [class.eui-menu-item__link--has-sub]=\"item.children?.length > 0\"\n                [routerLink]=\"item.url ? item.url : null\"\n                [routerLinkActive]=\"item.url ? 'eui-menu-item__link--active' : ''\"\n                [euiTooltip]=\"menuItemTooltip\"\n                position=\"after\"\n                tabindex=\"-1\">\n                <ng-template *ngTemplateOutlet=\"linkContent\" [ngTemplateOutletContext]=\"{ $implicit: item }\"></ng-template>\n            </a>\n\n            <ng-template *ngTemplateOutlet=\"content\"></ng-template>\n        </li>\n    }\n\n    @if (isLinkItem) {\n        <li\n            role=\"none\"\n            id=\"{{item.id}}\"\n            [attr.data-e2e]=\"item.e2eAttr\"\n            class=\"eui-menu-item__content\"\n            [class.eui-menu-item--disabled]=\"item.disabled\"\n            [class.eui-menu-item--expanded]=\"item.expanded || item.filtered\"\n            [attr.aria-disabled]=\"item.disabled\">\n            <a\n                (click)=\"onClick($event)\"\n                tabindex=\"-1\"\n                class=\"eui-menu-item__link\"\n                [class.eui-menu-item__link--disabled]=\"item.disabled\"\n                [class.eui-menu-item__link--active]=\"item.active\"\n                [class.eui-menu-item__link--has-sub]=\"item.children?.length > 0\"\n                href=\"javascript:void(0)\"\n                [euiTooltip]=\"menuItemTooltip\"\n                position=\"after\">\n                <ng-template *ngTemplateOutlet=\"linkContent\" [ngTemplateOutletContext]=\"{ $implicit: item }\"></ng-template>\n            </a>\n\n            <ng-template *ngTemplateOutlet=\"content\"></ng-template>\n        </li>\n    }\n}\n\n<ng-template #linkContent>\n    <div class=\"eui-menu-item__link-start-block\">\n        <ng-template *ngTemplateOutlet=\"itemIconContent\" [ngTemplateOutletContext]=\"{ $implicit: item }\"></ng-template>\n    </div>\n\n    <div class=\"eui-menu-item__link-content-block\">\n        <div class=\"eui-menu-item__link-label-container\">\n            <span class=\"eui-menu-item__link-label\">{{ item.label }}</span>\n            <eui-icon-svg\n                *ngIf=\"item.urlExternal && item.urlExternalTarget === '_blank'\"\n                class=\"eui-menu-item__label-external\"\n                icon=\"eui-ecl-external\"\n                size=\"2xs\"\n                aria-label=\"external link icon\"\n                euiEnd>\n            </eui-icon-svg>\n        </div>\n    </div>\n\n    <div class=\"eui-menu-item__link-end-block\">\n        <ng-template *ngTemplateOutlet=\"itemEndContent\" [ngTemplateOutletContext]=\"{ $implicit: item }\"></ng-template>\n    </div>\n</ng-template>\n\n<!-- PROJECTED CONTENT BLOCK -->\n<ng-template #content>\n    <ng-content></ng-content>\n</ng-template>\n\n<!-- PROJECTED START BLOCK -->\n<ng-template #itemIconContent>\n    @if (!isCollapsed) {\n        @if (hasIcon) {\n            @if (item.iconSvgName) {\n                <!-- SVG -->\n                <eui-icon-svg\n                    class=\"eui-menu-item__link-icon\"\n                    icon=\"{{ item.iconSvgName }}\"\n                    fillColor=\"{{ item.iconTypeClass }}\">\n                </eui-icon-svg>\n            } @else if (item.hasMarker) {\n                <!-- MARKER -->\n                <eui-icon-svg\n                    class=\"eui-menu-item__link-marker\"\n                    fillColor=\"{{ item?.markerTypeClass }}\"\n                    icon=\"ellipse:sharp\"\n                    size=\"2xs\"\n                    [aria-label]=\"item.markerTypeClass + ' ' + 'marker'\">\n                </eui-icon-svg>\n            }\n            @else if (!isLabelItem) {\n                <!-- DEFAULT for non category items -->\n                <eui-icon-svg\n                    class=\"eui-menu-item__link-icon\"\n                    icon=\"ellipse:sharp\"\n                    fillColor=\"neutral-light\"\n                    size=\"2xs\">\n                </eui-icon-svg>\n            }\n        } @else if (item.hasMarker) {\n            <eui-icon-svg\n                class=\"eui-menu-item__link-marker\"\n                fillColor=\"{{ item?.markerTypeClass }}\"\n                icon=\"ellipse:sharp\"\n                size=\"2xs\"\n                [aria-label]=\"item.markerTypeClass + ' ' + 'marker'\">\n            </eui-icon-svg>\n        }\n\n    } @else {\n        @if (hasCollapsedInitials) {\n            <span class=\"eui-menu-item__link-initials eui-u-c-bg-{{item.iconTypeClass}}\">\n                {{ item.initials }}\n            </span>\n        } @else {\n            @if (hasIcon) {\n                @if (item.iconSvgName) {\n                    <!-- SVG -->\n                    <eui-icon-svg\n                        class=\"eui-menu-item__link-icon\"\n                        icon=\"{{ item.iconSvgName }}\"\n                        fillColor=\"{{ item.iconTypeClass }}\">\n                    </eui-icon-svg>\n\n                } @else if (item.hasMarker) {\n                    <!-- MARKER -->\n                    <eui-icon-svg\n                        class=\"eui-menu-item__link-marker\"\n                        fillColor=\"{{ item?.markerTypeClass }}\"\n                        icon=\"ellipse:sharp\"\n                        size=\"2xs\"\n                        [aria-label]=\"item.markerTypeClass + ' ' + 'marker'\">\n                    </eui-icon-svg>\n                } @else {\n                    <!-- DEFAULT -->\n                    <eui-icon-svg\n                        class=\"eui-menu-item__link-icon\"\n                        icon=\"ellipse:sharp\"\n                        fillColor=\"neutral-light\"\n                        size=\"2xs\"\n                        [aria-label]=\"item.iconLabel\">\n                    </eui-icon-svg>\n                }\n            } @else {\n                <eui-icon-svg\n                    class=\"eui-menu-item__link-icon eui-u-ml-2xs\"\n                    icon=\"square:sharp\"\n                    fillColor=\"neutral-light\"\n                    size=\"2xs\">\n                </eui-icon-svg>\n            }\n        }\n    }\n</ng-template>\n\n<!-- PROJECTED END BLOCK -->\n<ng-template #itemEndContent>\n    @if (item.tagLabel) {\n        @if (isCollapsed) {\n            <eui-badge [euiVariant]=\"item.tagTypeClass\" class=\"eui-menu-item__link-dotted-badge\"></eui-badge>\n        } @else {\n            <eui-badge [euiVariant]=\"item.tagTypeClass\">\n                {{ item.tagLabel }}\n            </eui-badge>\n        }\n    }\n\n    <button\n        *ngIf=\"item.actionIcon\"\n        euiButton\n        euiRounded\n        euiIconButton\n        euiSizeS\n        euiBasicButton\n        type=\"button\"\n        tabindex=\"-1\"\n        (keydown)=\"onActionIconKeyDown($event)\"\n        (focusout)=\"onActionIconFocusOut()\"\n        (focus)=\"focusActionIcon()\"\n        class=\"eui-menu-item__link-action-icon\"\n        [euiDisabled]=\"item.disabled\"\n        [attr.aria-label]=\"item.actionIcon?.label\"\n        (click)=\"onActionIconClick($event)\">\n        <eui-icon-svg [icon]=\"item.actionIcon?.icon\" [fillColor]=\"item.actionIcon?.color\"></eui-icon-svg>\n    </button>\n\n    <eui-icon-button *ngIf=\"item.children?.length > 0\"\n        class=\"eui-menu-item__link-toggle\"\n        [icon]=\"item.expanded ? 'chevron-up:sharp': 'chevron-down:sharp'\"\n        (buttonClick)=\"onExpandToggle($event)\"\n        [ariaLabel]=\"item.expanded ? collapseMenuLabel : expandMenuLabel\"\n        euiRounded\n        size=\"s\"\n        [tabindex]=\"-1\"\n        [euiDisabled]=\"item.disabled\"/>\n</ng-template>\n"]}
@@ -55,7 +55,7 @@ export class EuiMenuComponent {
55
55
  case 'Enter': {
56
56
  if ((this.focusKeyManager.activeItem.isLinkItem || this.focusKeyManager.activeItem.isUrlItem) &&
57
57
  !this.focusKeyManager.activeItem.disabled) {
58
- this.focusKeyManager.activeItem.onClick(event);
58
+ this.focusKeyManager.activeItem.onClick(undefined);
59
59
  event.preventDefault();
60
60
  }
61
61
  break;
@@ -453,21 +453,6 @@ export class EuiMenuComponent {
453
453
  }
454
454
  return item;
455
455
  }
456
- /**
457
- * Check if an element is visible in the viewport
458
- * @param el
459
- * @param partiallyVisible
460
- * @private
461
- */
462
- elementIsVisibleInViewport(el, partiallyVisible = false) {
463
- const { top, left, bottom, right } = el.getBoundingClientRect();
464
- const { innerHeight, innerWidth } = window;
465
- return partiallyVisible
466
- ? ((top > 0 && top < innerHeight) ||
467
- (bottom > 0 && bottom < innerHeight)) &&
468
- ((left > 0 && left < innerWidth) || (right > 0 && right < innerWidth))
469
- : top >= 0 && left >= 0 && bottom <= innerHeight && right <= innerWidth;
470
- }
471
456
  /**
472
457
  * Scroll to an item if it's not visible in the viewport
473
458
  * @param url
@@ -546,4 +531,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.2", ngImpor
546
531
  type: HostListener,
547
532
  args: ['click', ['$event']]
548
533
  }] } });
549
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eui-menu.component.js","sourceRoot":"","sources":["../../../eui-menu/eui-menu.component.ts","../../../eui-menu/eui-menu.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    HostBinding,\n    ViewEncapsulation,\n    Input,\n    OnInit,\n    Output,\n    EventEmitter,\n    OnChanges,\n    SimpleChanges,\n    HostListener,\n    booleanAttribute,\n    OnDestroy,\n    AfterViewInit,\n    ViewChildren,\n    QueryList,\n    ChangeDetectorRef,\n    ViewChild,\n    ElementRef,\n} from '@angular/core';\nimport { Router, ActivatedRoute, NavigationEnd } from '@angular/router';\nimport { coerceBooleanProperty } from '@angular/cdk/coercion';\nimport { FocusKeyManager } from '@angular/cdk/a11y';\nimport { Subscription } from 'rxjs';\n\nimport { consumeEvent } from '@eui/core';\nimport { EuiMenuItemComponent } from './eui-menu-item.component';\nimport { EuiMenuItem } from './models/eui-menu-item.model';\n\n@Component({\n    selector: 'eui-menu',\n    templateUrl: './eui-menu.component.html',\n    styleUrls: ['./styles/_index.scss'],\n    encapsulation: ViewEncapsulation.None,\n})\nexport class EuiMenuComponent implements OnInit, OnChanges, OnDestroy, AfterViewInit {\n    @ViewChildren(EuiMenuItemComponent) protected menuItemsComponents: QueryList<EuiMenuItemComponent>;\n    @ViewChild('filterInput', { read: ElementRef }) protected filterInput: ElementRef<HTMLInputElement>;\n\n    @HostBinding('class')\n    public get cssClasses(): string {\n        return [\n            'eui-menu',\n            this.isCollapsed ? 'eui-menu--collapsed' : '',\n            !this.hasIcons ? 'eui-menu--no-icons' : '',\n            this.isFlat ? 'eui-menu--flat': '',\n        ].join(' ').trim();\n    }\n\n    @Input() items: EuiMenuItem[];\n    @Input() searchFilterLabel: string;\n    @Input() externalLinkLabel: string;\n    @Input() fragmentId: string;\n    @Input() filterValue = '';\n\n    @Input({ transform: booleanAttribute }) isCollapsed = false;\n    @Input({ transform: booleanAttribute }) hasCollapsedInitials = false;\n    @Input({ transform: booleanAttribute }) hasFilter = false;\n    @Input({ transform: booleanAttribute }) hasIcons = false;\n    @Input({ transform: booleanAttribute }) hasTooltip = true;\n    /**\n     * Expand all items in the menu. Affects only items that have no expanded property set.\n     * e.g. items = [{label: test, expanded: true}, {label: test2, expanded: false}, {label: test3}] will expand only test3.\n     */\n    @Input({ transform: booleanAttribute }) expandAllItems = false;\n    @Input({ transform: booleanAttribute }) isFlat = false;\n    @Input({ transform: booleanAttribute }) hasScrollToItem = false;\n    @Input({ transform: booleanAttribute }) hasBoldRootLevel = false;\n\n    @Output() isClick: EventEmitter<boolean> = new EventEmitter();\n    @Output() itemClick: EventEmitter<EuiMenuItem> = new EventEmitter<EuiMenuItem>();\n\n    private subscription: Subscription;\n    private focusKeyManager: FocusKeyManager<EuiMenuItemComponent>;\n\n    constructor(\n        private router: Router,\n        private route: ActivatedRoute,\n        private cd: ChangeDetectorRef,\n    ) {}\n\n    @HostListener('click', ['$event'])\n    stopPropagation(event: Event): void {\n        event.stopPropagation();\n    }\n\n    onKeydown(event: KeyboardEvent): void {\n        // finds first child when ArrowDown\n        const firstChild = this.focusKeyManager.activeItem?.item.children? this.findFirstFilteredItem(this.focusKeyManager.activeItem?.item.children) : undefined;\n        const firstFocusableItem = this.findFocusableItem(firstChild);\n        // finds the parent element\n        const parent = this.focusKeyManager.activeItem?.item.parent;\n        const parentFocusableItem = this.findFocusableItem(parent);\n        switch (event.key) {\n            case 'Enter': {\n                if (\n                    (this.focusKeyManager.activeItem.isLinkItem || this.focusKeyManager.activeItem.isUrlItem) &&\n                    !this.focusKeyManager.activeItem.disabled\n                ) {\n                    this.focusKeyManager.activeItem.onClick(event);\n                    event.preventDefault();\n                }\n                break;\n            }\n            case 'ArrowRight': {\n                if(this.focusKeyManager.activeItem?.item.actionIcon){\n                    this.checkActionIconFocusState();\n                    break;\n                } else {\n                    if (!this.focusKeyManager.activeItem?.item.expanded) {\n                        this.focusKeyManager.activeItem?.onExpandToggle(event);\n                        this.cd.detectChanges();\n                    }\n                    break;\n                }\n            }\n            case 'ArrowLeft': {\n                if(this.focusKeyManager.activeItem?.item.actionIcon){\n                    this.checkActionIconFocusState();\n                    break;\n                } else {\n                    if (this.focusKeyManager.activeItem?.item.expanded) {\n                        this.focusKeyManager.activeItem.onExpandToggle(event);\n                        this.cd.detectChanges();\n                        event.preventDefault();\n                    }\n                    break;\n                }\n            }\n            case 'ArrowDown': {\n                event.preventDefault();\n                if (this.focusKeyManager.activeItem?.item.children && this.focusKeyManager.activeItem?.item.expanded) {\n                    //focuses first child\n                    firstFocusableItem?.focus();\n                    this.focusKeyManager.updateActiveItem(firstFocusableItem);\n                } else if (parent) {\n                    // finds last filtered child when ArrowDown and navigating within submenu\n                    const filteredChildren = this.findFilteredItems(parent.children);\n                    const lastChildIndex = (filteredChildren?.length) - 1;\n                    const lastChild = filteredChildren[lastChildIndex];\n                    const lastFocusableItem = this.findFocusableItem(lastChild);\n                    // if the active item is the last child, puts the focus on the next parent\n                    if(this.focusKeyManager.activeItem === lastFocusableItem){\n                       this.focusKeyManager.updateActiveItem(parentFocusableItem);\n                       this.focusKeyManager.setNextItemActive();\n                    } else {\n                        this.focusKeyManager.setActiveItem(this.focusKeyManager.activeItemIndex +1);\n                    }\n                } else {\n                    // skips remaining children in the query list when there is expanded node\n                    this.focusKeyManager.skipPredicate(menuItem => menuItem.parent != undefined || menuItem.item.visible === false);\n                    this.focusKeyManager.onKeydown(event);\n                }\n                break;\n            }\n            case 'ArrowUp': {\n                event.preventDefault();\n                if (parent) {\n                    // finds first filtered child when ArrowUp\n                    const filteredChildren = this.findFilteredItems(parent.children);\n                    const firstChildUp = filteredChildren['0']\n                    const firstFocusableItemUp = this.findFocusableItem(firstChildUp);\n                    // when navigating up on a submenu focuses the parent if the active item is the first child\n                    if(this.focusKeyManager.activeItem === firstFocusableItemUp){\n                        this.focusKeyManager.setActiveItem(parentFocusableItem);\n                     } else {\n                        this.focusKeyManager.setActiveItem(this.focusKeyManager.activeItemIndex -1);\n                     }\n                } else {\n                    this.focusKeyManager.onKeydown(event);\n                    // when navigating up from a parent element to an expanded submenu, finds the last child and focuses it\n                    if(this.focusKeyManager.activeItem?.item.children && this.focusKeyManager.activeItem?.item.expanded){\n                        const filteredChildren = this.findFilteredItems(this.focusKeyManager.activeItem?.item.children);\n                        const lastChildIndexUp = (filteredChildren.length) - 1;\n                        const lastFocusableItemUp =this.findFocusableItem(filteredChildren[lastChildIndexUp]);\n                        this.focusKeyManager.setActiveItem(lastFocusableItemUp);\n                    }\n                }\n                break;\n            }\n            default: {\n                this.focusKeyManager.onKeydown(event);\n                break;\n            }\n        }\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (changes.items) {\n            this.items = this.configureItems(this.items);\n            // get current url\n            const currentUrl = this.router.url;\n            // find an item that matches the current url or the most relevant one\n            const item = this.findMostRelevantItem(currentUrl, this.items);\n            // expand to that item\n            if (item) {\n                this.expandToGivenItem(item);\n            }\n        }\n\n        // Expand / Collapse All items\n        if (changes.expandAllItems) {\n            this.items = this.setExpandedToAllItems(coerceBooleanProperty(changes.expandAllItems.currentValue), this.items);\n        }\n\n        if (changes.filterValue && this.hasFilter) {\n            this.onFilter(changes.filterValue.currentValue ?? '');\n        }\n\n        // Refresh when interactive collapsed to initials\n        if (changes.hasCollapsedInitials) {\n            this.hasCollapsedInitials = changes.hasCollapsedInitials.currentValue;\n            this.items = this.configureItems(this.items);\n        }\n\n        if(changes.hasScrollToItem){\n            this.hasScrollToItem = changes.hasScrollToItem.currentValue;\n            if(this.hasScrollToItem){\n                this.scrollToItem(this.router.url);\n            }\n        }\n\n        if(changes.hasFilter){\n            this.hasFilter = changes.hasFilter.currentValue;\n            if(!this.hasFilter) {\n                // iterate through all items and reset the filtered property\n                this.items = this.filterMenuItems(this.items, '')\n            }\n        }\n    }\n\n    ngOnInit(): void {\n        // Labels default values - TODO : translations\n        if (!this.searchFilterLabel) {\n            this.searchFilterLabel = 'Search filter';\n        }\n\n        // subscription to routes url changes for activating the scrollIntoView\n        this.router.events.subscribe((event) => {\n            // Handle route change event\n            if (event instanceof NavigationEnd) {\n                if (this.hasScrollToItem) {\n                    this.scrollToItem(event.url);\n                }\n            }\n        });\n    }\n\n    ngAfterViewInit(): void {\n        // instantiates FocusKeyManager with the query list of items enabling wrapping\n        this.focusKeyManager = new FocusKeyManager(this.menuItemsComponents).withWrap();\n\n        // scrolls to the item that matches the current url\n        if(this.hasScrollToItem){\n            this.scrollToItem(this.router.url);\n        }\n    }\n\n    ngOnDestroy():void {\n        if (this.subscription) {\n            this.subscription.unsubscribe();\n        }\n    }\n\n    protected onClick(item: EuiMenuItem): void {\n        if (!item.disabled) {\n            if (item.urlExternal) {\n                window.open(item.urlExternal, item.urlExternalTarget || '_blank');\n            } else if (item.url) {\n                this.router.navigate([item.url], { relativeTo: this.route, fragment: this.fragmentId });\n            } else {\n                if (typeof item.command === 'function') {\n                    item.command();\n                } else {\n                    this.onExpandToggle(item);\n                }\n            }\n\n            if (item.link) {\n                this.items = this.items?.map((it) => {\n                    it.active = false;\n                    if (it.id === item.id) {\n                        it.active = true;\n                    }\n                    return it;\n                });\n            }\n        }\n\n        this.isClick.emit(true);\n        this.itemClick.emit(item);\n\n        const focusedItem = this.findFocusableItem(item);\n        this.focusKeyManager.updateActiveItem(focusedItem);\n    }\n\n    protected onExpandToggle(item: EuiMenuItem): void {\n        if (item.children) {\n            this.onExpandToggled(item, this.items);\n            // TODO: investigate why the above is needed. Can it be simply \"item.expanded = !item.expanded;\" ?\n        }\n    }\n\n    protected onMenuFilterClick(event: MouseEvent): void {\n        consumeEvent(event);\n    }\n\n    /**\n     * Filter the menu items based on the input value\n     * @param event\n     * @protected\n     */\n    protected onFilter(event: Event): void;\n    protected onFilter(value: string): void;\n    protected onFilter(eventOrValue: Event | string): void {\n        const value = eventOrValue instanceof Event\n            ? (eventOrValue.target as HTMLInputElement).value\n            : eventOrValue;\n        this.items = this.filterMenuItems(this.items, value);\n    }\n\n    /**\n     * finds the EuiMenuItemComponent in the queried focusableItems[] that  matches the passed EuiMenuItem object\n     *\n     * @param menuItem an EuiMenuItem\n     * @private\n     */\n    private findFocusableItem(menuItem: EuiMenuItem ): EuiMenuItemComponent {\n        return this.menuItemsComponents.find(\n            (focusableItem) => focusableItem.item.label === menuItem?.label && focusableItem.item.id === menuItem.id,\n        );\n    }\n\n    /**\n     * finds the first item that is filtered\n     *\n     * @param menuItems an array of EuiMenuItem\n     * @private\n     */\n    private findFirstFilteredItem(menuItems: EuiMenuItem []): EuiMenuItem {\n        return menuItems.find((item) => item.filtered);\n    }\n\n    /**\n     * finds all filtered menu items\n     *\n     * @param menuItems an array of EuiMenuItem\n     * @private\n     */\n    private findFilteredItems(menuItems: EuiMenuItem []): EuiMenuItem [] {\n        return menuItems.filter((items) => items.filtered);\n    }\n\n    /**\n     * checks the focus state of the action icon\n     *\n     * @private\n     */\n    private checkActionIconFocusState(): void {\n        // check if the action icon is focused and if not focus it, otherwise focus the active item\n        !this.focusKeyManager.activeItem.isActionIconFocused ? this.focusKeyManager.activeItem.focusActionIcon() : this.focusKeyManager.activeItem.focus();\n    }\n\n    /**\n     * filter all menu items given a value\n     *\n     * @param menuItems an array of menu items\n     * @param filterValue the value to filter menu items\n     * @private\n     */\n    private filterMenuItems(menuItems: EuiMenuItem[], filterValue: string): EuiMenuItem[] {\n        return menuItems?.map((item: EuiMenuItem) => {\n            const found = item.label?.toLowerCase().indexOf(filterValue.toLowerCase()) !== -1;\n            if (item.children) {\n                item.children = this.filterMenuItems(item.children, filterValue);\n                item.filtered = item.children.filter((l) => l['filtered'] === true).length > 0;\n            } else if (found) {\n                item.filtered = found;\n            } else {\n                item.filtered = false;\n            }\n            return item;\n        }) || [];\n    }\n\n    /**\n     * expand / collapse all items\n     *\n     * @param isExpanded\n     * @param items\n     * @private\n     */\n    private setExpandedToAllItems(isExpanded: boolean, items: EuiMenuItem[]): EuiMenuItem[] {\n        return items?.map((item) => {\n            if (item.children) {\n                item.expanded = item.expanded ?? isExpanded;\n                item.children = this.setExpandedToAllItems(isExpanded, item.children);\n            }\n            return Object.assign(item, { visible: item.visible === undefined ? true : item.visible });\n        });\n    }\n\n    /**\n     * expand / collapse a menu item\n     *\n     * @param item The item where the \"expand\" had been toggled\n     * @param items The items list (used for recursion)\n     * @private\n     */\n    private onExpandToggled(item: EuiMenuItem, items: EuiMenuItem[]): void {\n        const itemIdx = items?.indexOf(item);\n        if (itemIdx > -1) {\n            items[itemIdx].expanded = !items[itemIdx].expanded;\n        } else {\n            items.forEach((i) => {\n                if (i.children) {\n                    this.onExpandToggled(item, i.children);\n                }\n            });\n        }\n    }\n\n    /**\n     * configure an array of items with visible, filtered and expand (in case of expandAllItems flag enabled) properties\n     *\n     * @param items An array of EuiMenuItem\n     * @param parent the parent item of items if exists\n     * @private\n     */\n    private configureItems(items: EuiMenuItem[], parent?: EuiMenuItem): EuiMenuItem[] {\n        return items?.map((item) => {\n            // recursion in case there are children\n            if (item.children) {\n                item.children = this.configureItems(item.children, item);\n                // expand all parents with children\n                if (this.expandAllItems) {\n                    item.expanded = true;\n                }\n            }\n            // point to the parent\n            if (parent) {\n                item.parent = parent;\n            }\n\n            // make sure the items are configured with a unique id\n            this.items = this.items?.map((item) => this.setRandomId(item));\n\n            if (item.label && this.hasCollapsedInitials) {\n                const words = item.label.split(' ');\n                if (words.length === 1) {\n                    item.initials = `${item.label.substring(0, 1)}${item.label.substring(1, 1)}`;\n\n                } else {\n                    item.initials = `${words[0].substring(0, 1)}${words[1].substring(0, 1)}`;\n                }\n            }\n\n            return Object.assign(item, { visible: item.visible === undefined ? true : item.visible, filtered: true });\n        });\n    }\n\n    /**\n     * Given a URL and a list of items, it will expand the item that matches the URL. If not item matches exactly the url, then it will\n     * match the item that is most relevant to that url.\n     *\n     * @param url\n     * @param items\n     * @param relevantItem\n     * @private\n     */\n    private findMostRelevantItem(url: string, items: EuiMenuItem[], relevantItem?: EuiMenuItem): EuiMenuItem {\n        if (!items) {\n            return null;\n        }\n\n        items.forEach((item) => {\n            if (item.url && url.indexOf(item.url.substring(1)) > -1) {\n                relevantItem = this.getMostRelevantItem(url, relevantItem, item);\n            }\n\n            if (item.children) {\n                relevantItem = this.findMostRelevantItem(url, item.children, relevantItem);\n            }\n        });\n\n        return relevantItem;\n    }\n\n    /**\n     * Given two items with url return the one with the most relevant url that matches given url\n     *\n     * @param url A URL to be matched with the one of given items\n     * @param item1\n     * @param item2\n     * @private\n     */\n    private getMostRelevantItem(url: string, item1: EuiMenuItem, item2: EuiMenuItem): EuiMenuItem {\n        const remainder1 = url.replace(item1?.url || '', '');\n        const remainder2 = url.replace(item2?.url || '', '');\n\n        return remainder1.length < remainder2.length ? item1 : item2;\n    }\n\n    /**\n     * Given an item, if there's a parent expand it until you reach the root item\n     *\n     * @param item Given menu item\n     * @private\n     */\n    private expandToGivenItem(item: EuiMenuItem): void {\n        if (item.parent) {\n            setTimeout(() => (item.parent.expanded = true));\n            this.expandToGivenItem(item.parent);\n        }\n    }\n\n    /**\n     * Set a random id to an item and its child if they don't have one\n     * @param item\n     * @private\n     */\n    private setRandomId(item: EuiMenuItem): EuiMenuItem {\n        item.id = item.id || crypto.randomUUID();\n        if(item.children){\n            item.children = item.children.map((child) => {\n                return this.setRandomId(child);\n            });\n        }\n        return item;\n    }\n\n    /**\n     * Check if an element is visible in the viewport\n     * @param el\n     * @param partiallyVisible\n     * @private\n     */\n    private elementIsVisibleInViewport(el: HTMLElement, partiallyVisible = false): boolean {\n        const { top, left, bottom, right } = el.getBoundingClientRect();\n        const { innerHeight, innerWidth } = window;\n        return partiallyVisible\n            ? ((top > 0 && top < innerHeight) ||\n                (bottom > 0 && bottom < innerHeight)) &&\n            ((left > 0 && left < innerWidth) || (right > 0 && right < innerWidth))\n            : top >= 0 && left >= 0 && bottom <= innerHeight && right <= innerWidth;\n    }\n\n    /**\n     * Scroll to an item if it's not visible in the viewport\n     * @param url\n     * @private\n     */\n    private scrollToItem(url: string): void {\n        const item = this.findMostRelevantItem(url, this.items);\n        if (item) {\n            // change the state of that item to expanded if it's not\n            this.expandToGivenItem(item);\n            setTimeout(_ => {\n                const menuItem = this.menuItemsComponents?.find((menuItem) => menuItem.item.id === item.id);\n                if(menuItem && !menuItem.elementIsVisibleInViewport()){\n                    menuItem.scrollIntoView({ behavior: 'smooth' });\n                }\n            }, 300);\n        }\n    }\n}\n","@if (hasFilter) {\n    <div class=\"eui-menu-filter\" [class.eui-menu-filter--collapsed]=\"isCollapsed\" (click)=\"onMenuFilterClick($event)\">\n        <eui-icon-input>\n            <eui-icon-svg icon=\"eui-ecl-search\" fillColor=\"neutral-lighter\" aria-label=\"Search Icon\"></eui-icon-svg>\n            <input\n                #filterInput\n                euiInputText\n                [euiClearable]=\"true\"\n                (input)=\"onFilter($event)\"\n                [placeholder]=\"searchFilterLabel\"\n                [attr.aria-label]=\"searchFilterLabel\"\n                [value]=\"filterValue\" />\n        </eui-icon-input>\n    </div>\n}\n\n<ul euiList class=\"eui-menu\" role=\"menubar\" aria-orientation=\"vertical\" tabindex=\"0\" (keydown)=\"onKeydown($event)\">\n    @if (items) {\n        @for (item of items; track item.id; let index = $index) {\n            <ng-template [ngTemplateOutlet]=\"menuItemTemplateRef\" [ngTemplateOutletContext]=\"{ menuItem: item, index: index }\"></ng-template>\n        }\n    } @else {\n        <span class=\"eui-menu--no-items\">No menu items defined</span>\n    }\n</ul>\n\n<!-- describe the recursive template of the menu item -->\n<ng-template #menuItemTemplateRef let-item=\"menuItem\" let-parent=\"parent\" let-i=\"index\">\n    <!-- render the menu item-->\n    <eui-menu-item\n        *ngIf=\"item.filtered\"\n        [item]=\"item\"\n        [parent]=\"parent\"\n        [hasIcon]=\"hasIcons\"\n        [hasTooltip]=\"hasTooltip\"\n        [isCollapsed]=\"isCollapsed\"\n        [hasBoldRootLevel]=\"hasBoldRootLevel\"\n        [hasCollapsedInitials]=\"hasCollapsedInitials\"\n        (expandToggle)=\"onExpandToggle($event)\"\n        (itemClick)=\"onClick($event)\">\n        <!-- if the menu item has children, render the children -->\n        @if (item.children && (item.expanded || (hasFilter && item.filtered && filterInput?.nativeElement?.value.length > 0))) {\n            <ul euiList class=\"eui-menu eui-menu-sub\" role=\"menu\" [attr.aria-label]=\"item.label\" tabindex=\"-1\">\n                @for (child of item.children; track child.id; let childIndex = $index) {\n                    <ng-template [ngTemplateOutlet]=\"menuItemTemplateRef\" [ngTemplateOutletContext]=\"{ menuItem: child, index: childIndex, parent: item }\">\n                    </ng-template>\n                }\n            </ul>\n        }\n    </eui-menu-item>\n</ng-template>\n"]}
534
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eui-menu.component.js","sourceRoot":"","sources":["../../../eui-menu/eui-menu.component.ts","../../../eui-menu/eui-menu.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    HostBinding,\n    ViewEncapsulation,\n    Input,\n    OnInit,\n    Output,\n    EventEmitter,\n    OnChanges,\n    SimpleChanges,\n    HostListener,\n    booleanAttribute,\n    OnDestroy,\n    AfterViewInit,\n    ViewChildren,\n    QueryList,\n    ChangeDetectorRef,\n    ViewChild,\n    ElementRef,\n} from '@angular/core';\nimport { Router, ActivatedRoute, NavigationEnd } from '@angular/router';\nimport { coerceBooleanProperty } from '@angular/cdk/coercion';\nimport { FocusKeyManager } from '@angular/cdk/a11y';\nimport { Subscription } from 'rxjs';\n\nimport { consumeEvent } from '@eui/core';\nimport { EuiMenuItemComponent } from './eui-menu-item.component';\nimport { EuiMenuItem } from './models/eui-menu-item.model';\n\n@Component({\n    selector: 'eui-menu',\n    templateUrl: './eui-menu.component.html',\n    styleUrls: ['./styles/_index.scss'],\n    encapsulation: ViewEncapsulation.None,\n})\nexport class EuiMenuComponent implements OnInit, OnChanges, OnDestroy, AfterViewInit {\n    @ViewChildren(EuiMenuItemComponent) protected menuItemsComponents: QueryList<EuiMenuItemComponent>;\n    @ViewChild('filterInput', { read: ElementRef }) protected filterInput: ElementRef<HTMLInputElement>;\n\n    @HostBinding('class')\n    public get cssClasses(): string {\n        return [\n            'eui-menu',\n            this.isCollapsed ? 'eui-menu--collapsed' : '',\n            !this.hasIcons ? 'eui-menu--no-icons' : '',\n            this.isFlat ? 'eui-menu--flat': '',\n        ].join(' ').trim();\n    }\n\n    @Input() items: EuiMenuItem[];\n    @Input() searchFilterLabel: string;\n    @Input() externalLinkLabel: string;\n    @Input() fragmentId: string;\n    @Input() filterValue = '';\n\n    @Input({ transform: booleanAttribute }) isCollapsed = false;\n    @Input({ transform: booleanAttribute }) hasCollapsedInitials = false;\n    @Input({ transform: booleanAttribute }) hasFilter = false;\n    @Input({ transform: booleanAttribute }) hasIcons = false;\n    @Input({ transform: booleanAttribute }) hasTooltip = true;\n    /**\n     * Expand all items in the menu. Affects only items that have no expanded property set.\n     * e.g. items = [{label: test, expanded: true}, {label: test2, expanded: false}, {label: test3}] will expand only test3.\n     */\n    @Input({ transform: booleanAttribute }) expandAllItems = false;\n    @Input({ transform: booleanAttribute }) isFlat = false;\n    @Input({ transform: booleanAttribute }) hasScrollToItem = false;\n    @Input({ transform: booleanAttribute }) hasBoldRootLevel = false;\n\n    @Output() isClick: EventEmitter<boolean> = new EventEmitter();\n    @Output() itemClick: EventEmitter<EuiMenuItem> = new EventEmitter<EuiMenuItem>();\n\n    private subscription: Subscription;\n    private focusKeyManager: FocusKeyManager<EuiMenuItemComponent>;\n\n    constructor(\n        private router: Router,\n        private route: ActivatedRoute,\n        private cd: ChangeDetectorRef,\n    ) {}\n\n    @HostListener('click', ['$event'])\n    stopPropagation(event: Event): void {\n        event.stopPropagation();\n    }\n\n    onKeydown(event: KeyboardEvent): void {\n        // finds first child when ArrowDown\n        const firstChild = this.focusKeyManager.activeItem?.item.children? this.findFirstFilteredItem(this.focusKeyManager.activeItem?.item.children) : undefined;\n        const firstFocusableItem = this.findFocusableItem(firstChild);\n        // finds the parent element\n        const parent = this.focusKeyManager.activeItem?.item.parent;\n        const parentFocusableItem = this.findFocusableItem(parent);\n        switch (event.key) {\n            case 'Enter': {\n                if (\n                    (this.focusKeyManager.activeItem.isLinkItem || this.focusKeyManager.activeItem.isUrlItem) &&\n                    !this.focusKeyManager.activeItem.disabled\n                ) {\n                    this.focusKeyManager.activeItem.onClick(undefined);\n                    event.preventDefault();\n                }\n                break;\n            }\n            case 'ArrowRight': {\n                if(this.focusKeyManager.activeItem?.item.actionIcon){\n                    this.checkActionIconFocusState();\n                    break;\n                } else {\n                    if (!this.focusKeyManager.activeItem?.item.expanded) {\n                        this.focusKeyManager.activeItem?.onExpandToggle(event);\n                        this.cd.detectChanges();\n                    }\n                    break;\n                }\n            }\n            case 'ArrowLeft': {\n                if(this.focusKeyManager.activeItem?.item.actionIcon){\n                    this.checkActionIconFocusState();\n                    break;\n                } else {\n                    if (this.focusKeyManager.activeItem?.item.expanded) {\n                        this.focusKeyManager.activeItem.onExpandToggle(event);\n                        this.cd.detectChanges();\n                        event.preventDefault();\n                    }\n                    break;\n                }\n            }\n            case 'ArrowDown': {\n                event.preventDefault();\n                if (this.focusKeyManager.activeItem?.item.children && this.focusKeyManager.activeItem?.item.expanded) {\n                    //focuses first child\n                    firstFocusableItem?.focus();\n                    this.focusKeyManager.updateActiveItem(firstFocusableItem);\n                } else if (parent) {\n                    // finds last filtered child when ArrowDown and navigating within submenu\n                    const filteredChildren = this.findFilteredItems(parent.children);\n                    const lastChildIndex = (filteredChildren?.length) - 1;\n                    const lastChild = filteredChildren[lastChildIndex];\n                    const lastFocusableItem = this.findFocusableItem(lastChild);\n                    // if the active item is the last child, puts the focus on the next parent\n                    if(this.focusKeyManager.activeItem === lastFocusableItem){\n                       this.focusKeyManager.updateActiveItem(parentFocusableItem);\n                       this.focusKeyManager.setNextItemActive();\n                    } else {\n                        this.focusKeyManager.setActiveItem(this.focusKeyManager.activeItemIndex +1);\n                    }\n                } else {\n                    // skips remaining children in the query list when there is expanded node\n                    this.focusKeyManager.skipPredicate(menuItem => menuItem.parent != undefined || menuItem.item.visible === false);\n                    this.focusKeyManager.onKeydown(event);\n                }\n                break;\n            }\n            case 'ArrowUp': {\n                event.preventDefault();\n                if (parent) {\n                    // finds first filtered child when ArrowUp\n                    const filteredChildren = this.findFilteredItems(parent.children);\n                    const firstChildUp = filteredChildren['0']\n                    const firstFocusableItemUp = this.findFocusableItem(firstChildUp);\n                    // when navigating up on a submenu focuses the parent if the active item is the first child\n                    if(this.focusKeyManager.activeItem === firstFocusableItemUp){\n                        this.focusKeyManager.setActiveItem(parentFocusableItem);\n                     } else {\n                        this.focusKeyManager.setActiveItem(this.focusKeyManager.activeItemIndex -1);\n                     }\n                } else {\n                    this.focusKeyManager.onKeydown(event);\n                    // when navigating up from a parent element to an expanded submenu, finds the last child and focuses it\n                    if(this.focusKeyManager.activeItem?.item.children && this.focusKeyManager.activeItem?.item.expanded){\n                        const filteredChildren = this.findFilteredItems(this.focusKeyManager.activeItem?.item.children);\n                        const lastChildIndexUp = (filteredChildren.length) - 1;\n                        const lastFocusableItemUp =this.findFocusableItem(filteredChildren[lastChildIndexUp]);\n                        this.focusKeyManager.setActiveItem(lastFocusableItemUp);\n                    }\n                }\n                break;\n            }\n            default: {\n                this.focusKeyManager.onKeydown(event);\n                break;\n            }\n        }\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (changes.items) {\n            this.items = this.configureItems(this.items);\n            // get current url\n            const currentUrl = this.router.url;\n            // find an item that matches the current url or the most relevant one\n            const item = this.findMostRelevantItem(currentUrl, this.items);\n            // expand to that item\n            if (item) {\n                this.expandToGivenItem(item);\n            }\n        }\n\n        // Expand / Collapse All items\n        if (changes.expandAllItems) {\n            this.items = this.setExpandedToAllItems(coerceBooleanProperty(changes.expandAllItems.currentValue), this.items);\n        }\n\n        if (changes.filterValue && this.hasFilter) {\n            this.onFilter(changes.filterValue.currentValue ?? '');\n        }\n\n        // Refresh when interactive collapsed to initials\n        if (changes.hasCollapsedInitials) {\n            this.hasCollapsedInitials = changes.hasCollapsedInitials.currentValue;\n            this.items = this.configureItems(this.items);\n        }\n\n        if(changes.hasScrollToItem){\n            this.hasScrollToItem = changes.hasScrollToItem.currentValue;\n            if(this.hasScrollToItem){\n                this.scrollToItem(this.router.url);\n            }\n        }\n\n        if(changes.hasFilter){\n            this.hasFilter = changes.hasFilter.currentValue;\n            if(!this.hasFilter) {\n                // iterate through all items and reset the filtered property\n                this.items = this.filterMenuItems(this.items, '')\n            }\n        }\n    }\n\n    ngOnInit(): void {\n        // Labels default values - TODO : translations\n        if (!this.searchFilterLabel) {\n            this.searchFilterLabel = 'Search filter';\n        }\n\n        // subscription to routes url changes for activating the scrollIntoView\n        this.router.events.subscribe((event) => {\n            // Handle route change event\n            if (event instanceof NavigationEnd) {\n                if (this.hasScrollToItem) {\n                    this.scrollToItem(event.url);\n                }\n            }\n        });\n    }\n\n    ngAfterViewInit(): void {\n        // instantiates FocusKeyManager with the query list of items enabling wrapping\n        this.focusKeyManager = new FocusKeyManager(this.menuItemsComponents).withWrap();\n\n        // scrolls to the item that matches the current url\n        if(this.hasScrollToItem){\n            this.scrollToItem(this.router.url);\n        }\n    }\n\n    ngOnDestroy():void {\n        if (this.subscription) {\n            this.subscription.unsubscribe();\n        }\n    }\n\n    protected onClick(item: EuiMenuItem): void {\n        if (!item.disabled) {\n            if (item.urlExternal) {\n                window.open(item.urlExternal, item.urlExternalTarget || '_blank');\n            } else if (item.url) {\n                this.router.navigate([item.url], { relativeTo: this.route, fragment: this.fragmentId });\n            } else {\n                if (typeof item.command === 'function') {\n                    item.command();\n                } else {\n                    this.onExpandToggle(item);\n                }\n            }\n\n            if (item.link) {\n                this.items = this.items?.map((it) => {\n                    it.active = false;\n                    if (it.id === item.id) {\n                        it.active = true;\n                    }\n                    return it;\n                });\n            }\n        }\n\n        this.isClick.emit(true);\n        this.itemClick.emit(item);\n\n        const focusedItem = this.findFocusableItem(item);\n        this.focusKeyManager.updateActiveItem(focusedItem);\n    }\n\n    protected onExpandToggle(item: EuiMenuItem): void {\n        if (item.children) {\n            this.onExpandToggled(item, this.items);\n            // TODO: investigate why the above is needed. Can it be simply \"item.expanded = !item.expanded;\" ?\n        }\n    }\n\n    protected onMenuFilterClick(event: MouseEvent): void {\n        consumeEvent(event);\n    }\n\n    /**\n     * Filter the menu items based on the input value\n     * @param event\n     * @protected\n     */\n    protected onFilter(event: Event): void;\n    protected onFilter(value: string): void;\n    protected onFilter(eventOrValue: Event | string): void {\n        const value = eventOrValue instanceof Event\n            ? (eventOrValue.target as HTMLInputElement).value\n            : eventOrValue;\n        this.items = this.filterMenuItems(this.items, value);\n    }\n\n    /**\n     * finds the EuiMenuItemComponent in the queried focusableItems[] that  matches the passed EuiMenuItem object\n     *\n     * @param menuItem an EuiMenuItem\n     * @private\n     */\n    private findFocusableItem(menuItem: EuiMenuItem ): EuiMenuItemComponent {\n        return this.menuItemsComponents.find(\n            (focusableItem) => focusableItem.item.label === menuItem?.label && focusableItem.item.id === menuItem.id,\n        );\n    }\n\n    /**\n     * finds the first item that is filtered\n     *\n     * @param menuItems an array of EuiMenuItem\n     * @private\n     */\n    private findFirstFilteredItem(menuItems: EuiMenuItem []): EuiMenuItem {\n        return menuItems.find((item) => item.filtered);\n    }\n\n    /**\n     * finds all filtered menu items\n     *\n     * @param menuItems an array of EuiMenuItem\n     * @private\n     */\n    private findFilteredItems(menuItems: EuiMenuItem []): EuiMenuItem [] {\n        return menuItems.filter((items) => items.filtered);\n    }\n\n    /**\n     * checks the focus state of the action icon\n     *\n     * @private\n     */\n    private checkActionIconFocusState(): void {\n        // check if the action icon is focused and if not focus it, otherwise focus the active item\n        !this.focusKeyManager.activeItem.isActionIconFocused ? this.focusKeyManager.activeItem.focusActionIcon() : this.focusKeyManager.activeItem.focus();\n    }\n\n    /**\n     * filter all menu items given a value\n     *\n     * @param menuItems an array of menu items\n     * @param filterValue the value to filter menu items\n     * @private\n     */\n    private filterMenuItems(menuItems: EuiMenuItem[], filterValue: string): EuiMenuItem[] {\n        return menuItems?.map((item: EuiMenuItem) => {\n            const found = item.label?.toLowerCase().indexOf(filterValue.toLowerCase()) !== -1;\n            if (item.children) {\n                item.children = this.filterMenuItems(item.children, filterValue);\n                item.filtered = item.children.filter((l) => l['filtered'] === true).length > 0;\n            } else if (found) {\n                item.filtered = found;\n            } else {\n                item.filtered = false;\n            }\n            return item;\n        }) || [];\n    }\n\n    /**\n     * expand / collapse all items\n     *\n     * @param isExpanded\n     * @param items\n     * @private\n     */\n    private setExpandedToAllItems(isExpanded: boolean, items: EuiMenuItem[]): EuiMenuItem[] {\n        return items?.map((item) => {\n            if (item.children) {\n                item.expanded = item.expanded ?? isExpanded;\n                item.children = this.setExpandedToAllItems(isExpanded, item.children);\n            }\n            return Object.assign(item, { visible: item.visible === undefined ? true : item.visible });\n        });\n    }\n\n    /**\n     * expand / collapse a menu item\n     *\n     * @param item The item where the \"expand\" had been toggled\n     * @param items The items list (used for recursion)\n     * @private\n     */\n    private onExpandToggled(item: EuiMenuItem, items: EuiMenuItem[]): void {\n        const itemIdx = items?.indexOf(item);\n        if (itemIdx > -1) {\n            items[itemIdx].expanded = !items[itemIdx].expanded;\n        } else {\n            items.forEach((i) => {\n                if (i.children) {\n                    this.onExpandToggled(item, i.children);\n                }\n            });\n        }\n    }\n\n    /**\n     * configure an array of items with visible, filtered and expand (in case of expandAllItems flag enabled) properties\n     *\n     * @param items An array of EuiMenuItem\n     * @param parent the parent item of items if exists\n     * @private\n     */\n    private configureItems(items: EuiMenuItem[], parent?: EuiMenuItem): EuiMenuItem[] {\n        return items?.map((item) => {\n            // recursion in case there are children\n            if (item.children) {\n                item.children = this.configureItems(item.children, item);\n                // expand all parents with children\n                if (this.expandAllItems) {\n                    item.expanded = true;\n                }\n            }\n            // point to the parent\n            if (parent) {\n                item.parent = parent;\n            }\n\n            // make sure the items are configured with a unique id\n            this.items = this.items?.map((item) => this.setRandomId(item));\n\n            if (item.label && this.hasCollapsedInitials) {\n                const words = item.label.split(' ');\n                if (words.length === 1) {\n                    item.initials = `${item.label.substring(0, 1)}${item.label.substring(1, 1)}`;\n\n                } else {\n                    item.initials = `${words[0].substring(0, 1)}${words[1].substring(0, 1)}`;\n                }\n            }\n\n            return Object.assign(item, { visible: item.visible === undefined ? true : item.visible, filtered: true });\n        });\n    }\n\n    /**\n     * Given a URL and a list of items, it will expand the item that matches the URL. If not item matches exactly the url, then it will\n     * match the item that is most relevant to that url.\n     *\n     * @param url\n     * @param items\n     * @param relevantItem\n     * @private\n     */\n    private findMostRelevantItem(url: string, items: EuiMenuItem[], relevantItem?: EuiMenuItem): EuiMenuItem {\n        if (!items) {\n            return null;\n        }\n\n        items.forEach((item) => {\n            if (item.url && url.indexOf(item.url.substring(1)) > -1) {\n                relevantItem = this.getMostRelevantItem(url, relevantItem, item);\n            }\n\n            if (item.children) {\n                relevantItem = this.findMostRelevantItem(url, item.children, relevantItem);\n            }\n        });\n\n        return relevantItem;\n    }\n\n    /**\n     * Given two items with url return the one with the most relevant url that matches given url\n     *\n     * @param url A URL to be matched with the one of given items\n     * @param item1\n     * @param item2\n     * @private\n     */\n    private getMostRelevantItem(url: string, item1: EuiMenuItem, item2: EuiMenuItem): EuiMenuItem {\n        const remainder1 = url.replace(item1?.url || '', '');\n        const remainder2 = url.replace(item2?.url || '', '');\n\n        return remainder1.length < remainder2.length ? item1 : item2;\n    }\n\n    /**\n     * Given an item, if there's a parent expand it until you reach the root item\n     *\n     * @param item Given menu item\n     * @private\n     */\n    private expandToGivenItem(item: EuiMenuItem): void {\n        if (item.parent) {\n            setTimeout(() => (item.parent.expanded = true));\n            this.expandToGivenItem(item.parent);\n        }\n    }\n\n    /**\n     * Set a random id to an item and its child if they don't have one\n     * @param item\n     * @private\n     */\n    private setRandomId(item: EuiMenuItem): EuiMenuItem {\n        item.id = item.id || crypto.randomUUID();\n        if(item.children){\n            item.children = item.children.map((child) => {\n                return this.setRandomId(child);\n            });\n        }\n        return item;\n    }\n\n    /**\n     * Scroll to an item if it's not visible in the viewport\n     * @param url\n     * @private\n     */\n    private scrollToItem(url: string): void {\n        const item = this.findMostRelevantItem(url, this.items);\n        if (item) {\n            // change the state of that item to expanded if it's not\n            this.expandToGivenItem(item);\n            setTimeout(_ => {\n                const menuItem = this.menuItemsComponents?.find((menuItem) => menuItem.item.id === item.id);\n                if(menuItem && !menuItem.elementIsVisibleInViewport()){\n                    menuItem.scrollIntoView({ behavior: 'smooth' });\n                }\n            }, 300);\n        }\n    }\n}\n","@if (hasFilter) {\n    <div class=\"eui-menu-filter\" [class.eui-menu-filter--collapsed]=\"isCollapsed\" (click)=\"onMenuFilterClick($event)\">\n        <eui-icon-input>\n            <eui-icon-svg icon=\"eui-ecl-search\" fillColor=\"neutral-lighter\" aria-label=\"Search Icon\"></eui-icon-svg>\n            <input\n                #filterInput\n                euiInputText\n                [euiClearable]=\"true\"\n                (input)=\"onFilter($event)\"\n                [placeholder]=\"searchFilterLabel\"\n                [attr.aria-label]=\"searchFilterLabel\"\n                [value]=\"filterValue\" />\n        </eui-icon-input>\n    </div>\n}\n\n<ul euiList class=\"eui-menu\" role=\"menubar\" aria-orientation=\"vertical\" tabindex=\"0\" (keydown)=\"onKeydown($event)\">\n    @if (items) {\n        @for (item of items; track item.id; let index = $index) {\n            <ng-template [ngTemplateOutlet]=\"menuItemTemplateRef\" [ngTemplateOutletContext]=\"{ menuItem: item, index: index }\"></ng-template>\n        }\n    } @else {\n        <span class=\"eui-menu--no-items\">No menu items defined</span>\n    }\n</ul>\n\n<!-- describe the recursive template of the menu item -->\n<ng-template #menuItemTemplateRef let-item=\"menuItem\" let-parent=\"parent\" let-i=\"index\">\n    <!-- render the menu item-->\n    <eui-menu-item\n        *ngIf=\"item.filtered\"\n        [item]=\"item\"\n        [parent]=\"parent\"\n        [hasIcon]=\"hasIcons\"\n        [hasTooltip]=\"hasTooltip\"\n        [isCollapsed]=\"isCollapsed\"\n        [hasBoldRootLevel]=\"hasBoldRootLevel\"\n        [hasCollapsedInitials]=\"hasCollapsedInitials\"\n        (expandToggle)=\"onExpandToggle($event)\"\n        (itemClick)=\"onClick($event)\">\n        <!-- if the menu item has children, render the children -->\n        @if (item.children && (item.expanded || (hasFilter && item.filtered && filterInput?.nativeElement?.value.length > 0))) {\n            <ul euiList class=\"eui-menu eui-menu-sub\" role=\"menu\" [attr.aria-label]=\"item.label\" tabindex=\"-1\">\n                @for (child of item.children; track child.id; let childIndex = $index) {\n                    <ng-template [ngTemplateOutlet]=\"menuItemTemplateRef\" [ngTemplateOutletContext]=\"{ menuItem: child, index: childIndex, parent: item }\">\n                    </ng-template>\n                }\n            </ul>\n        }\n    </eui-menu-item>\n</ng-template>\n"]}