@eui/components 18.2.0-snapshot-1726794925687 → 18.2.0-snapshot-1727360980382

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.
Files changed (47) hide show
  1. package/directives/eui-maxlength.directive.d.ts +4 -0
  2. package/directives/eui-maxlength.directive.d.ts.map +1 -1
  3. package/docs/components/EuiHeaderComponent.html +0 -4
  4. package/docs/components/EuiHeaderLogoComponent.html +2 -5
  5. package/docs/components/EuiLanguageSelectorComponent.html +25 -1
  6. package/docs/components/EuiPaginatorComponent.html +25 -1
  7. package/docs/components/EuiPopoverComponent.html +1 -26
  8. package/docs/dependencies.html +2 -2
  9. package/docs/directives/EuiMaxLengthDirective.html +7 -0
  10. package/docs/js/menu-wc.js +3 -3
  11. package/docs/js/menu-wc_es5.js +1 -1
  12. package/docs/js/search/search_index.js +2 -2
  13. package/esm2022/directives/eui-maxlength.directive.mjs +14 -2
  14. package/esm2022/eui-language-selector/language-selector.component.mjs +7 -3
  15. package/esm2022/eui-menu/eui-menu-item.component.mjs +3 -7
  16. package/esm2022/eui-paginator/eui-paginator.component.mjs +7 -3
  17. package/esm2022/eui-popover/eui-popover.component.mjs +3 -5
  18. package/esm2022/externals/eui-editor/eui-editor.component.mjs +4 -4
  19. package/esm2022/layout/eui-app/eui-app-toolbar/toolbar.component.mjs +1 -1
  20. package/esm2022/layout/eui-header/header-logo/header-logo.component.mjs +8 -5
  21. package/esm2022/layout/eui-header/header.component.mjs +4 -4
  22. package/esm2022/layout/eui-header/header.module.mjs +3 -2
  23. package/eui-language-selector/language-selector.component.d.ts +2 -1
  24. package/eui-language-selector/language-selector.component.d.ts.map +1 -1
  25. package/eui-menu/eui-menu-item.component.d.ts.map +1 -1
  26. package/eui-paginator/eui-paginator.component.d.ts +3 -1
  27. package/eui-paginator/eui-paginator.component.d.ts.map +1 -1
  28. package/eui-popover/eui-popover.component.d.ts +0 -1
  29. package/eui-popover/eui-popover.component.d.ts.map +1 -1
  30. package/externals/eui-editor/eui-editor.component.d.ts.map +1 -1
  31. package/fesm2022/eui-components-directives.mjs +13 -1
  32. package/fesm2022/eui-components-directives.mjs.map +1 -1
  33. package/fesm2022/eui-components-eui-language-selector.mjs +6 -2
  34. package/fesm2022/eui-components-eui-language-selector.mjs.map +1 -1
  35. package/fesm2022/eui-components-eui-menu.mjs +2 -6
  36. package/fesm2022/eui-components-eui-menu.mjs.map +1 -1
  37. package/fesm2022/eui-components-eui-paginator.mjs +6 -2
  38. package/fesm2022/eui-components-eui-paginator.mjs.map +1 -1
  39. package/fesm2022/eui-components-eui-popover.mjs +2 -4
  40. package/fesm2022/eui-components-eui-popover.mjs.map +1 -1
  41. package/fesm2022/eui-components-externals-eui-editor.mjs +3 -3
  42. package/fesm2022/eui-components-externals-eui-editor.mjs.map +1 -1
  43. package/fesm2022/eui-components-layout.mjs +9 -7
  44. package/fesm2022/eui-components-layout.mjs.map +1 -1
  45. package/layout/eui-header/header-logo/header-logo.component.d.ts.map +1 -1
  46. package/layout/eui-header/header.component.d.ts.map +1 -1
  47. package/package.json +3 -3
@@ -36,10 +36,15 @@ export class EuiMaxLengthDirective {
36
36
  throw new Error('euiMaxlength of an input or a textarea cannot be negative.');
37
37
  }
38
38
  if (this.maxLength) {
39
+ // re-create in case you previously destroyed it
40
+ if (this.isShowMaxlength && !this.maxLengthSpan) {
41
+ this.createMaxLengthBox();
42
+ }
39
43
  this._refreshValue();
40
44
  }
41
45
  else {
42
46
  this.renderer.removeAttribute(this.el.nativeElement, 'maxLength');
47
+ this.destroyMaxLengthBox();
43
48
  }
44
49
  }
45
50
  }
@@ -71,7 +76,9 @@ export class EuiMaxLengthDirective {
71
76
  let value = (event.clipboardData || window['clipboardData']).getData('text');
72
77
  // calculate and set the maxLength based on the clipboard value
73
78
  let input = this.el.nativeElement;
74
- this.renderer.setProperty(input, 'maxLength', this.calculateMaxLength(value));
79
+ if (this.maxLength) {
80
+ this.renderer.setProperty(input, 'maxLength', this.calculateMaxLength(value));
81
+ }
75
82
  }
76
83
  setLengthCalcFactory(fn) {
77
84
  this.lengthCalcFn = () => {
@@ -90,6 +97,9 @@ export class EuiMaxLengthDirective {
90
97
  return (value?.length || (inputValue?.length || 0) - this.lengthCalcFn()) + this.maxLength;
91
98
  }
92
99
  _refreshValue() {
100
+ if (isNaN(this.maxLength)) {
101
+ return;
102
+ }
93
103
  let input = this.el.nativeElement;
94
104
  let valueLength = this.lengthCalcFn();
95
105
  let remainingLength = this.maxLength - valueLength;
@@ -156,6 +166,7 @@ export class EuiMaxLengthDirective {
156
166
  // removes maxlength element from DOM
157
167
  if (this.maxLengthSpan) {
158
168
  this.renderer.removeChild(this.maxLengthSpan.parentElement, this.maxLengthSpan);
169
+ this.maxLengthSpan = undefined;
159
170
  }
160
171
  // remove wrapper from DOM
161
172
  if (this.wrapper) {
@@ -166,6 +177,7 @@ export class EuiMaxLengthDirective {
166
177
  parent?.replaceChild(nativeElement, this.wrapper);
167
178
  // removes wrapper element from DOM
168
179
  this.renderer.removeChild(this.wrapper.parentElement, this.wrapper);
180
+ this.wrapper = undefined;
169
181
  }
170
182
  }
171
183
  /**
@@ -224,4 +236,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.1", ngImpor
224
236
  declarations: [EuiMaxLengthDirective]
225
237
  }]
226
238
  }] });
227
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eui-maxlength.directive.js","sourceRoot":"","sources":["../../../directives/eui-maxlength.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    Directive,\n    ElementRef,\n    Input,\n    Output,\n    AfterContentInit,\n    NgModule,\n    EventEmitter,\n    OnDestroy,\n    HostListener,\n    Optional,\n    Self,\n    OnChanges,\n    SimpleChanges,\n    Renderer2,\n    numberAttribute,\n    booleanAttribute,\n} from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { NgControl } from '@angular/forms';\nimport { Subscription } from 'rxjs';\n\n/* eslint-disable */\n@Directive({\n    selector: `\n    input[euiMaxlength],\n    textarea[euiMaxlength],\n    [ngModel][euiMaxlength],\n    [formControlName][euiMaxlength]`,\n})\nexport class EuiMaxLengthDirective implements AfterContentInit, OnDestroy, OnChanges {\n    @Input({ alias:'euiMaxlength', transform: numberAttribute }) maxLength: number;\n    @Input({ alias:'isShowMaxlength', transform: booleanAttribute }) isShowMaxlength: boolean = true;\n    @Output() maxLengthReached: EventEmitter<boolean> = new EventEmitter<boolean>();\n\n    valueChangesSubscription: Subscription;\n\n    private maxLengthSpan: HTMLSpanElement;\n    private wrapper: HTMLDivElement;\n    private lengthCalcFn: () => number;\n\n    constructor(private el: ElementRef,\n                private renderer: Renderer2,\n                @Self() @Optional() private control: NgControl) {\n        // set default length calculation behavior\n        this.setLengthCalcFactory((value) => value?.length || 0);\n    }\n\n    ngOnDestroy() {\n        // remove all DOM added elements\n        this.destroyMaxLengthBox();\n\n        // unsubscribe from valueChanges\n        if(this.valueChangesSubscription) {\n            this.valueChangesSubscription.unsubscribe();\n        }\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if(changes['isShowMaxlength'] && this.maxLengthSpan) {\n            if(this.isShowMaxlength) {\n                this.createMaxLengthBox();\n                this._refreshValue();\n            } else {\n                this.destroyMaxLengthBox();\n            }\n        }\n        if(changes['maxLength']) {\n            if(this.maxLength < 0) {\n                throw new Error('euiMaxlength of an input or a textarea cannot be negative.')\n            }\n            if(this.maxLength) {\n                this._refreshValue();\n            } else {\n                this.renderer.removeAttribute(this.el.nativeElement, 'maxLength');\n            }\n        }\n    }\n\n    ngAfterContentInit() {\n        if (this.maxLength) {\n            this.createMaxLengthBox();\n            this._refreshValue();\n        }\n\n        // this subscription is needed apart from HostListener to Changes in case usage of this directive\n        // in custom component that implements ngDefaultControl\n        if (this.control?.valueChanges) {\n            this.valueChangesSubscription = this.control.valueChanges.subscribe(() => {\n                this._refreshValue();\n            });\n        }\n    }\n\n    @HostListener('change', ['$event'])\n    onChange(event: Event) {\n        if(!this.control || this.control?.control.updateOn !== 'change') {\n            this._refreshValue();\n        }\n    }\n\n    @HostListener('input', ['$event'])\n    onInput(event: KeyboardEvent) {\n        if(!this.control || this.control?.control.updateOn !== 'change') {\n            this._refreshValue();\n        }\n    }\n\n    @HostListener('paste', ['$event'])\n    onPaste(event: ClipboardEvent) {\n        // get the value from clipboard\n        let value = (event.clipboardData || window['clipboardData']).getData('text');\n        // calculate and set the maxLength based on the clipboard value\n        let input = <HTMLInputElement>this.el.nativeElement;\n        this.renderer.setProperty(input, 'maxLength', this.calculateMaxLength(value));\n    }\n\n    public setLengthCalcFactory(fn: (input: string) => number): void {\n        this.lengthCalcFn = () => {\n            const value = this.getValue();\n            return fn(value);\n        }\n    }\n\n    /**\n     * calculates the maxLength of an input element. Calculation is made\n     * against the value of the Model or Input Element.\n     * @param value Optional the value to calculate max length against (override the Model one)\n     * @private\n     */\n    private calculateMaxLength(value?: string): number {\n        const inputValue = this.getValue();\n        return (value?.length || (inputValue?.length || 0) - this.lengthCalcFn()) + this.maxLength;\n    }\n\n    private _refreshValue() {\n        let input = <HTMLInputElement>this.el.nativeElement;\n        let valueLength = this.lengthCalcFn();\n        let remainingLength = this.maxLength - valueLength;\n\n        this.renderer.setProperty(input, 'maxLength', this.calculateMaxLength());\n        if(this.maxLengthSpan) {\n            // based on the remaining length add/remove the error class\n            if (remainingLength <= 0) {\n                this.renderer.addClass(this.maxLengthSpan, 'eui-input-maxlength--invalid')\n                this.maxLengthReached.emit(true);\n            } else {\n                this.renderer.removeClass(this.maxLengthSpan, 'eui-input-maxlength--invalid')\n                this.maxLengthReached.emit(false);\n            }\n            // set the value of remaining characters\n            if (remainingLength < 0) {\n                // this feature is only available when the calculation of length is not custom\n                // to support this feature you need to calculate this.maxLength also\n                if (this.control) {\n                    this.control.control.setValue(input.value.substring(0, this.calculateMaxLength()))\n                } else {\n                    input.value = input.value.substring(0, this.calculateMaxLength());\n                }\n                this.renderer.setProperty(this.maxLengthSpan, 'innerHTML', '0')\n            } else if (remainingLength >= 0) {\n                this.renderer.setProperty(this.maxLengthSpan, 'innerHTML', (this.maxLength - valueLength).toString())\n            }\n        }\n    }\n\n    /**\n     * creates the maxLength box by adding it to DOM and attaching correct Classes\n     * for Wrapper and Span (actual box holding max length)\n     * @private\n     */\n    private createMaxLengthBox() {\n        // creates the span that holds the max length value which changes according to input\n        this.maxLengthSpan = this.renderer.createElement('span');\n        this.renderer.addClass(this.maxLengthSpan, 'eui-input-maxlength')\n        this.renderer.setAttribute(this.maxLengthSpan, 'innerHTML', this.maxLength.toString());\n\n        // create wrapper element\n        let nativeElement: HTMLElement = this.el.nativeElement;\n        if (nativeElement != null) {\n            // set width to 100%\n            this.renderer.setStyle(nativeElement, 'width', '100%');\n            let parent: Node = nativeElement.parentNode;\n            if (parent != null && this.isShowMaxlength) {\n                // creates wrapper div of input and maxLength span\n                this.wrapper = this.renderer.createElement('div');\n                this.renderer.addClass(this.wrapper, 'eui-input-maxlength-wrapper');\n                // swap, wrapper should wrap the nativeElement and maxLength span\n                parent.replaceChild(this.wrapper, nativeElement);\n                this.renderer.appendChild(this.wrapper, nativeElement);\n                this.renderer.appendChild(this.wrapper, this.maxLengthSpan);\n            }\n        }\n    }\n\n    /**\n     * destroys the maxLength box from DOM\n     * @private\n     */\n    private destroyMaxLengthBox() {\n        // removes maxlength element from DOM\n        if(this.maxLengthSpan) {\n            this.renderer.removeChild(this.maxLengthSpan.parentElement, this.maxLengthSpan);\n        }\n\n        // remove wrapper from DOM\n        if(this.wrapper) {\n            // get parent node of wrapper\n            let parent: Node = this.wrapper.parentNode;\n            let nativeElement: HTMLElement = this.el.nativeElement;\n            // swap wrapper and nativeElement\n            parent?.replaceChild(nativeElement, this.wrapper);\n            // removes wrapper element from DOM\n            this.renderer.removeChild(this.wrapper.parentElement, this.wrapper);\n        }\n    }\n\n    /**\n     * returns the value based on whether control is present and control's\n     * updateOn strategy.\n     * @private\n     */\n    private getValue(): string {\n        let input = <HTMLInputElement>this.el.nativeElement;\n        return this.control && this.control.control.updateOn === 'change' ? this.control.value : input.value;\n    }\n}\n\n@NgModule({\n    imports: [CommonModule],\n    exports: [EuiMaxLengthDirective],\n    declarations: [EuiMaxLengthDirective]\n})\nexport class EuiMaxLengthDirectiveModule {\n}\n/* eslint-enable */\n"]}
239
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eui-maxlength.directive.js","sourceRoot":"","sources":["../../../directives/eui-maxlength.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    Directive,\n    ElementRef,\n    Input,\n    Output,\n    AfterContentInit,\n    NgModule,\n    EventEmitter,\n    OnDestroy,\n    HostListener,\n    Optional,\n    Self,\n    OnChanges,\n    SimpleChanges,\n    Renderer2,\n    numberAttribute,\n    booleanAttribute,\n} from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { NgControl } from '@angular/forms';\nimport { Subscription } from 'rxjs';\n\n/* eslint-disable */\n@Directive({\n    selector: `\n    input[euiMaxlength],\n    textarea[euiMaxlength],\n    [ngModel][euiMaxlength],\n    [formControlName][euiMaxlength]`,\n})\nexport class EuiMaxLengthDirective implements AfterContentInit, OnDestroy, OnChanges {\n    /**\n     * It accepts number values to indicate the maxLength of an input. To reset or disable it set the value to null.\n     * NULL value will remove any MaxLength indicator even if another input like isShowMaxlength equals true.\n     */\n    @Input({ alias:'euiMaxlength', transform: numberAttribute }) maxLength: number;\n    @Input({ alias:'isShowMaxlength', transform: booleanAttribute }) isShowMaxlength: boolean = true;\n    @Output() maxLengthReached: EventEmitter<boolean> = new EventEmitter<boolean>();\n\n    valueChangesSubscription: Subscription;\n\n    private maxLengthSpan: HTMLSpanElement;\n    private wrapper: HTMLDivElement;\n    private lengthCalcFn: () => number;\n\n    constructor(private el: ElementRef,\n                private renderer: Renderer2,\n                @Self() @Optional() private control: NgControl) {\n        // set default length calculation behavior\n        this.setLengthCalcFactory((value) => value?.length || 0);\n    }\n\n    ngOnDestroy() {\n        // remove all DOM added elements\n        this.destroyMaxLengthBox();\n\n        // unsubscribe from valueChanges\n        if(this.valueChangesSubscription) {\n            this.valueChangesSubscription.unsubscribe();\n        }\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if(changes['isShowMaxlength'] && this.maxLengthSpan) {\n            if(this.isShowMaxlength) {\n                this.createMaxLengthBox();\n                this._refreshValue();\n            } else {\n                this.destroyMaxLengthBox();\n            }\n        }\n        if(changes['maxLength']) {\n            if(this.maxLength < 0) {\n                throw new Error('euiMaxlength of an input or a textarea cannot be negative.')\n            }\n            if(this.maxLength) {\n                // re-create in case you previously destroyed it\n                if(this.isShowMaxlength && !this.maxLengthSpan) {\n                    this.createMaxLengthBox();\n                }\n                this._refreshValue();\n            } else {\n                this.renderer.removeAttribute(this.el.nativeElement, 'maxLength');\n                this.destroyMaxLengthBox();\n            }\n        }\n    }\n\n    ngAfterContentInit() {\n        if (this.maxLength) {\n            this.createMaxLengthBox();\n            this._refreshValue();\n        }\n\n        // this subscription is needed apart from HostListener to Changes in case usage of this directive\n        // in custom component that implements ngDefaultControl\n        if (this.control?.valueChanges) {\n            this.valueChangesSubscription = this.control.valueChanges.subscribe(() => {\n                this._refreshValue();\n            });\n        }\n    }\n\n    @HostListener('change', ['$event'])\n    onChange(event: Event) {\n        if(!this.control || this.control?.control.updateOn !== 'change') {\n            this._refreshValue();\n        }\n    }\n\n    @HostListener('input', ['$event'])\n    onInput(event: KeyboardEvent) {\n        if(!this.control || this.control?.control.updateOn !== 'change') {\n            this._refreshValue();\n        }\n    }\n\n    @HostListener('paste', ['$event'])\n    onPaste(event: ClipboardEvent) {\n        // get the value from clipboard\n        let value = (event.clipboardData || window['clipboardData']).getData('text');\n        // calculate and set the maxLength based on the clipboard value\n        let input = <HTMLInputElement>this.el.nativeElement;\n        if(this.maxLength) {\n            this.renderer.setProperty(input, 'maxLength', this.calculateMaxLength(value));\n        }\n    }\n\n    public setLengthCalcFactory(fn: (input: string) => number): void {\n        this.lengthCalcFn = () => {\n            const value = this.getValue();\n            return fn(value);\n        }\n    }\n\n    /**\n     * calculates the maxLength of an input element. Calculation is made\n     * against the value of the Model or Input Element.\n     * @param value Optional the value to calculate max length against (override the Model one)\n     * @private\n     */\n    private calculateMaxLength(value?: string): number {\n        const inputValue = this.getValue();\n        return (value?.length || (inputValue?.length || 0) - this.lengthCalcFn()) + this.maxLength;\n    }\n\n    private _refreshValue(): void {\n        if(isNaN(this.maxLength)) {\n            return;\n        }\n        let input = <HTMLInputElement>this.el.nativeElement;\n        let valueLength = this.lengthCalcFn();\n        let remainingLength = this.maxLength - valueLength;\n\n        this.renderer.setProperty(input, 'maxLength', this.calculateMaxLength());\n        if(this.maxLengthSpan) {\n            // based on the remaining length add/remove the error class\n            if (remainingLength <= 0) {\n                this.renderer.addClass(this.maxLengthSpan, 'eui-input-maxlength--invalid')\n                this.maxLengthReached.emit(true);\n            } else {\n                this.renderer.removeClass(this.maxLengthSpan, 'eui-input-maxlength--invalid')\n                this.maxLengthReached.emit(false);\n            }\n            // set the value of remaining characters\n            if (remainingLength < 0) {\n                // this feature is only available when the calculation of length is not custom\n                // to support this feature you need to calculate this.maxLength also\n                if (this.control) {\n                    this.control.control.setValue(input.value.substring(0, this.calculateMaxLength()))\n                } else {\n                    input.value = input.value.substring(0, this.calculateMaxLength());\n                }\n                this.renderer.setProperty(this.maxLengthSpan, 'innerHTML', '0')\n            } else if (remainingLength >= 0) {\n                this.renderer.setProperty(this.maxLengthSpan, 'innerHTML', (this.maxLength - valueLength).toString())\n            }\n        }\n    }\n\n    /**\n     * creates the maxLength box by adding it to DOM and attaching correct Classes\n     * for Wrapper and Span (actual box holding max length)\n     * @private\n     */\n    private createMaxLengthBox() {\n        // creates the span that holds the max length value which changes according to input\n        this.maxLengthSpan = this.renderer.createElement('span');\n        this.renderer.addClass(this.maxLengthSpan, 'eui-input-maxlength')\n        this.renderer.setAttribute(this.maxLengthSpan, 'innerHTML', this.maxLength.toString());\n\n        // create wrapper element\n        let nativeElement: HTMLElement = this.el.nativeElement;\n        if (nativeElement != null) {\n            // set width to 100%\n            this.renderer.setStyle(nativeElement, 'width', '100%');\n            let parent: Node = nativeElement.parentNode;\n            if (parent != null && this.isShowMaxlength) {\n                // creates wrapper div of input and maxLength span\n                this.wrapper = this.renderer.createElement('div');\n                this.renderer.addClass(this.wrapper, 'eui-input-maxlength-wrapper');\n                // swap, wrapper should wrap the nativeElement and maxLength span\n                parent.replaceChild(this.wrapper, nativeElement);\n                this.renderer.appendChild(this.wrapper, nativeElement);\n                this.renderer.appendChild(this.wrapper, this.maxLengthSpan);\n            }\n        }\n    }\n\n    /**\n     * destroys the maxLength box from DOM\n     * @private\n     */\n    private destroyMaxLengthBox() {\n        // removes maxlength element from DOM\n        if(this.maxLengthSpan) {\n            this.renderer.removeChild(this.maxLengthSpan.parentElement, this.maxLengthSpan);\n            this.maxLengthSpan = undefined;\n        }\n\n        // remove wrapper from DOM\n        if(this.wrapper) {\n            // get parent node of wrapper\n            let parent: Node = this.wrapper.parentNode;\n            let nativeElement: HTMLElement = this.el.nativeElement;\n            // swap wrapper and nativeElement\n            parent?.replaceChild(nativeElement, this.wrapper);\n            // removes wrapper element from DOM\n            this.renderer.removeChild(this.wrapper.parentElement, this.wrapper);\n            this.wrapper = undefined;\n        }\n    }\n\n    /**\n     * returns the value based on whether control is present and control's\n     * updateOn strategy.\n     * @private\n     */\n    private getValue(): string {\n        let input = <HTMLInputElement>this.el.nativeElement;\n        return this.control && this.control.control.updateOn === 'change' ? this.control.value : input.value;\n    }\n}\n\n@NgModule({\n    imports: [CommonModule],\n    exports: [EuiMaxLengthDirective],\n    declarations: [EuiMaxLengthDirective]\n})\nexport class EuiMaxLengthDirectiveModule {\n}\n/* eslint-enable */\n"]}
@@ -29,6 +29,7 @@ export class EuiLanguageSelectorComponent {
29
29
  this.hasLanguageSelection = true;
30
30
  this.isToolbarSelector = false;
31
31
  this.euiPrimary = false;
32
+ this.ariaLabel = 'Change Language';
32
33
  this.languageSelectorClick = new EventEmitter();
33
34
  this.destroy$ = new Subject();
34
35
  }
@@ -116,11 +117,11 @@ export class EuiLanguageSelectorComponent {
116
117
  return this.languages.find((lang) => lang.code === languageCode);
117
118
  }
118
119
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.1", ngImport: i0, type: EuiLanguageSelectorComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.EuiDialogService }, { token: i2.EuiAppShellService }, { token: i3.TranslateService }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
119
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.1", type: EuiLanguageSelectorComponent, selector: "eui-language-selector", inputs: { hasLanguageSelection: ["hasLanguageSelection", "hasLanguageSelection", booleanAttribute], isToolbarSelector: ["isToolbarSelector", "isToolbarSelector", booleanAttribute], euiPrimary: ["euiPrimary", "euiPrimary", booleanAttribute] }, outputs: { languageSelectorClick: "languageSelectorClick" }, host: { properties: { "class": "this.cssClasses" } }, ngImport: i0, template: "@if (!hasLanguageSelection) {\n <button class=\"eui-language-selector__button\"\n euiButton [euiBasicButton]=\"!isToolbarSelector\"\n [euiBranding]=\"isToolbarSelector\"\n (click)=\"onClick()\">\n <ng-template *ngTemplateOutlet=\"languageSelectorIcon\"></ng-template>\n <span class=\"eui-language-selector__code\">{{ (appShellService.state$ | async).activeLanguage }}</span>\n </button>\n\n} @else if (hasLanguageSelection && isShowDropDown) {\n <eui-dropdown>\n <button class=\"eui-language-selector__button\"\n euiButton [euiBasicButton]=\"!isToolbarSelector\"\n [euiBranding]=\"isToolbarSelector\">\n <ng-template *ngTemplateOutlet=\"languageSelectorIcon\"></ng-template>\n <span class=\"eui-language-selector__code\">{{ (appShellService.state$ | async).activeLanguage }}</span>\n </button>\n\n <eui-dropdown-content>\n <div class=\"eui-language-selector-menu\">\n <button\n *ngFor=\"let language of languages\"\n euiDropdownItem\n attr.data-e2e=\"eui-language-selector-item_{{ language.code }}\"\n class=\"eui-language-selector-menu-language-item\"\n (click)=\"onLanguageChanged(language)\">\n {{ language.label }} ({{ language.code }})\n </button>\n </div>\n </eui-dropdown-content>\n </eui-dropdown>\n\n} @else if (hasLanguageSelection && isShowModal) {\n <button class=\"eui-language-selector__button\"\n euiButton euiBasicButton\n [euiPrimary]=\"isToolbarSelector\"\n (click)=\"onOpen()\">\n <ng-template *ngTemplateOutlet=\"languageSelectorIcon\"></ng-template>\n <span class=\"eui-language-selector__code\">{{ (appShellService.state$ | async).activeLanguage }}</span>\n </button>\n}\n\n<ng-template #languageSelectorIcon>\n <eui-icon-svg icon=\"eui-ecl-global\"></eui-icon-svg>\n</ng-template>\n", styles: [".eui-18 .eui-language-selector{align-items:center;cursor:pointer;display:flex;position:relative}.eui-18 .eui-language-selector__button{padding-left:var(--eui-s-s);padding-right:var(--eui-s-s)}.eui-18 .eui-language-selector__code{text-transform:uppercase}.eui-18 .eui-language-selector-menu-language-item{padding:var(--eui-s-m);border-bottom:1px solid var(--eui-c-neutral-bg-light);text-align:center;cursor:pointer}.eui-18 .eui-language-selector-menu-language-item:hover{background:var(--eui-c-neutral-bg-light)}.eui-18 .eui-language-selector--empty{display:none}\n"], dependencies: [{ kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i5.EuiDropdownComponent, selector: "eui-dropdown", inputs: ["e2eAttr", "tabIndex", "width", "position", "isBlock", "isDropDownRightAligned", "hasClosedOnClickInside", "isLabelUpdatedFromSelectedItem", "isExpandOnHover", "hasTabNavigation", "isRightClickEnabled", "euiDisabled"], outputs: ["expand"] }, { kind: "component", type: i5.EuiDropdownItemComponent, selector: "eui-dropdown-item, [euiDropdownItem]", inputs: ["subDropdown", "isActive"] }, { kind: "directive", type: i5.EuiDropdownContentDirective, selector: "eui-dropdown-content" }, { kind: "component", type: i6.EuiButtonComponent, selector: "button[euiButton], a[euiButton]", inputs: ["e2eAttr", "id", "euiBasicButton", "euiButtonCall", "euiBlockButton", "euiIconButton", "euiLineWrap", "isChecked", "euiDisabled"], outputs: ["buttonClick"] }, { kind: "component", type: i7.EuiIconSvgComponent, selector: "eui-icon-svg, span[euiIconSvg], i[euiIconSvg]", inputs: ["icon", "fillColor", "set", "size", "style", "iconUrl", "transform", "euiVariant", "aria-label", "ariaHidden", "focusable", "isLoading", "isInputIcon", "euiStart", "euiEnd"] }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }], encapsulation: i0.ViewEncapsulation.None }); }
120
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.1", type: EuiLanguageSelectorComponent, selector: "eui-language-selector", inputs: { hasLanguageSelection: ["hasLanguageSelection", "hasLanguageSelection", booleanAttribute], isToolbarSelector: ["isToolbarSelector", "isToolbarSelector", booleanAttribute], euiPrimary: ["euiPrimary", "euiPrimary", booleanAttribute], ariaLabel: ["aria-label", "ariaLabel"] }, outputs: { languageSelectorClick: "languageSelectorClick" }, host: { properties: { "class": "this.cssClasses" } }, ngImport: i0, template: "@if (!hasLanguageSelection) {\n <button class=\"eui-language-selector__button\"\n euiButton [euiBasicButton]=\"!isToolbarSelector\"\n [euiBranding]=\"isToolbarSelector\"\n (click)=\"onClick()\"\n [attr.aria-label]=\"ariaLabel\">\n <ng-template *ngTemplateOutlet=\"languageSelectorIcon\"></ng-template>\n <span class=\"eui-language-selector__code\">{{ (appShellService.state$ | async).activeLanguage }}</span>\n </button>\n\n} @else if (hasLanguageSelection && isShowDropDown) {\n <eui-dropdown>\n <button class=\"eui-language-selector__button\"\n [attr.aria-label]=\"ariaLabel\"\n euiButton [euiBasicButton]=\"!isToolbarSelector\"\n [euiBranding]=\"isToolbarSelector\">\n <ng-template *ngTemplateOutlet=\"languageSelectorIcon\"></ng-template>\n <span class=\"eui-language-selector__code\">{{ (appShellService.state$ | async).activeLanguage }}</span>\n </button>\n\n <eui-dropdown-content>\n <div class=\"eui-language-selector-menu\">\n <button\n *ngFor=\"let language of languages\"\n euiDropdownItem\n attr.data-e2e=\"eui-language-selector-item_{{ language.code }}\"\n class=\"eui-language-selector-menu-language-item\"\n (click)=\"onLanguageChanged(language)\">\n {{ language.label }} ({{ language.code }})\n </button>\n </div>\n </eui-dropdown-content>\n </eui-dropdown>\n\n} @else if (hasLanguageSelection && isShowModal) {\n <button class=\"eui-language-selector__button\"\n euiButton euiBasicButton\n [euiPrimary]=\"isToolbarSelector\"\n (click)=\"onOpen()\"\n [attr.aria-label]=\"ariaLabel\">\n <ng-template *ngTemplateOutlet=\"languageSelectorIcon\"></ng-template>\n <span class=\"eui-language-selector__code\">{{ (appShellService.state$ | async).activeLanguage }}</span>\n </button>\n}\n\n<ng-template #languageSelectorIcon>\n <eui-icon-svg icon=\"eui-ecl-global\"></eui-icon-svg>\n</ng-template>\n", styles: [".eui-18 .eui-language-selector{align-items:center;cursor:pointer;display:flex;position:relative}.eui-18 .eui-language-selector__button{padding-left:var(--eui-s-s);padding-right:var(--eui-s-s)}.eui-18 .eui-language-selector__code{text-transform:uppercase}.eui-18 .eui-language-selector-menu-language-item{padding:var(--eui-s-m);border-bottom:1px solid var(--eui-c-neutral-bg-light);text-align:center;cursor:pointer}.eui-18 .eui-language-selector-menu-language-item:hover{background:var(--eui-c-neutral-bg-light)}.eui-18 .eui-language-selector--empty{display:none}\n"], dependencies: [{ kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i5.EuiDropdownComponent, selector: "eui-dropdown", inputs: ["e2eAttr", "tabIndex", "width", "position", "isBlock", "isDropDownRightAligned", "hasClosedOnClickInside", "isLabelUpdatedFromSelectedItem", "isExpandOnHover", "hasTabNavigation", "isRightClickEnabled", "euiDisabled"], outputs: ["expand"] }, { kind: "component", type: i5.EuiDropdownItemComponent, selector: "eui-dropdown-item, [euiDropdownItem]", inputs: ["subDropdown", "isActive"] }, { kind: "directive", type: i5.EuiDropdownContentDirective, selector: "eui-dropdown-content" }, { kind: "component", type: i6.EuiButtonComponent, selector: "button[euiButton], a[euiButton]", inputs: ["e2eAttr", "id", "euiBasicButton", "euiButtonCall", "euiBlockButton", "euiIconButton", "euiLineWrap", "isChecked", "euiDisabled"], outputs: ["buttonClick"] }, { kind: "component", type: i7.EuiIconSvgComponent, selector: "eui-icon-svg, span[euiIconSvg], i[euiIconSvg]", inputs: ["icon", "fillColor", "set", "size", "style", "iconUrl", "transform", "euiVariant", "aria-label", "ariaHidden", "focusable", "isLoading", "isInputIcon", "euiStart", "euiEnd"] }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }], encapsulation: i0.ViewEncapsulation.None }); }
120
121
  }
121
122
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.1", ngImport: i0, type: EuiLanguageSelectorComponent, decorators: [{
122
123
  type: Component,
123
- args: [{ selector: 'eui-language-selector', encapsulation: ViewEncapsulation.None, template: "@if (!hasLanguageSelection) {\n <button class=\"eui-language-selector__button\"\n euiButton [euiBasicButton]=\"!isToolbarSelector\"\n [euiBranding]=\"isToolbarSelector\"\n (click)=\"onClick()\">\n <ng-template *ngTemplateOutlet=\"languageSelectorIcon\"></ng-template>\n <span class=\"eui-language-selector__code\">{{ (appShellService.state$ | async).activeLanguage }}</span>\n </button>\n\n} @else if (hasLanguageSelection && isShowDropDown) {\n <eui-dropdown>\n <button class=\"eui-language-selector__button\"\n euiButton [euiBasicButton]=\"!isToolbarSelector\"\n [euiBranding]=\"isToolbarSelector\">\n <ng-template *ngTemplateOutlet=\"languageSelectorIcon\"></ng-template>\n <span class=\"eui-language-selector__code\">{{ (appShellService.state$ | async).activeLanguage }}</span>\n </button>\n\n <eui-dropdown-content>\n <div class=\"eui-language-selector-menu\">\n <button\n *ngFor=\"let language of languages\"\n euiDropdownItem\n attr.data-e2e=\"eui-language-selector-item_{{ language.code }}\"\n class=\"eui-language-selector-menu-language-item\"\n (click)=\"onLanguageChanged(language)\">\n {{ language.label }} ({{ language.code }})\n </button>\n </div>\n </eui-dropdown-content>\n </eui-dropdown>\n\n} @else if (hasLanguageSelection && isShowModal) {\n <button class=\"eui-language-selector__button\"\n euiButton euiBasicButton\n [euiPrimary]=\"isToolbarSelector\"\n (click)=\"onOpen()\">\n <ng-template *ngTemplateOutlet=\"languageSelectorIcon\"></ng-template>\n <span class=\"eui-language-selector__code\">{{ (appShellService.state$ | async).activeLanguage }}</span>\n </button>\n}\n\n<ng-template #languageSelectorIcon>\n <eui-icon-svg icon=\"eui-ecl-global\"></eui-icon-svg>\n</ng-template>\n", styles: [".eui-18 .eui-language-selector{align-items:center;cursor:pointer;display:flex;position:relative}.eui-18 .eui-language-selector__button{padding-left:var(--eui-s-s);padding-right:var(--eui-s-s)}.eui-18 .eui-language-selector__code{text-transform:uppercase}.eui-18 .eui-language-selector-menu-language-item{padding:var(--eui-s-m);border-bottom:1px solid var(--eui-c-neutral-bg-light);text-align:center;cursor:pointer}.eui-18 .eui-language-selector-menu-language-item:hover{background:var(--eui-c-neutral-bg-light)}.eui-18 .eui-language-selector--empty{display:none}\n"] }]
124
+ args: [{ selector: 'eui-language-selector', encapsulation: ViewEncapsulation.None, template: "@if (!hasLanguageSelection) {\n <button class=\"eui-language-selector__button\"\n euiButton [euiBasicButton]=\"!isToolbarSelector\"\n [euiBranding]=\"isToolbarSelector\"\n (click)=\"onClick()\"\n [attr.aria-label]=\"ariaLabel\">\n <ng-template *ngTemplateOutlet=\"languageSelectorIcon\"></ng-template>\n <span class=\"eui-language-selector__code\">{{ (appShellService.state$ | async).activeLanguage }}</span>\n </button>\n\n} @else if (hasLanguageSelection && isShowDropDown) {\n <eui-dropdown>\n <button class=\"eui-language-selector__button\"\n [attr.aria-label]=\"ariaLabel\"\n euiButton [euiBasicButton]=\"!isToolbarSelector\"\n [euiBranding]=\"isToolbarSelector\">\n <ng-template *ngTemplateOutlet=\"languageSelectorIcon\"></ng-template>\n <span class=\"eui-language-selector__code\">{{ (appShellService.state$ | async).activeLanguage }}</span>\n </button>\n\n <eui-dropdown-content>\n <div class=\"eui-language-selector-menu\">\n <button\n *ngFor=\"let language of languages\"\n euiDropdownItem\n attr.data-e2e=\"eui-language-selector-item_{{ language.code }}\"\n class=\"eui-language-selector-menu-language-item\"\n (click)=\"onLanguageChanged(language)\">\n {{ language.label }} ({{ language.code }})\n </button>\n </div>\n </eui-dropdown-content>\n </eui-dropdown>\n\n} @else if (hasLanguageSelection && isShowModal) {\n <button class=\"eui-language-selector__button\"\n euiButton euiBasicButton\n [euiPrimary]=\"isToolbarSelector\"\n (click)=\"onOpen()\"\n [attr.aria-label]=\"ariaLabel\">\n <ng-template *ngTemplateOutlet=\"languageSelectorIcon\"></ng-template>\n <span class=\"eui-language-selector__code\">{{ (appShellService.state$ | async).activeLanguage }}</span>\n </button>\n}\n\n<ng-template #languageSelectorIcon>\n <eui-icon-svg icon=\"eui-ecl-global\"></eui-icon-svg>\n</ng-template>\n", styles: [".eui-18 .eui-language-selector{align-items:center;cursor:pointer;display:flex;position:relative}.eui-18 .eui-language-selector__button{padding-left:var(--eui-s-s);padding-right:var(--eui-s-s)}.eui-18 .eui-language-selector__code{text-transform:uppercase}.eui-18 .eui-language-selector-menu-language-item{padding:var(--eui-s-m);border-bottom:1px solid var(--eui-c-neutral-bg-light);text-align:center;cursor:pointer}.eui-18 .eui-language-selector-menu-language-item:hover{background:var(--eui-c-neutral-bg-light)}.eui-18 .eui-language-selector--empty{display:none}\n"] }]
124
125
  }], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i1.EuiDialogService }, { type: i2.EuiAppShellService }, { type: i3.TranslateService }, { type: i0.ElementRef }], propDecorators: { cssClasses: [{
125
126
  type: HostBinding,
126
127
  args: ['class']
@@ -133,7 +134,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.1", ngImpor
133
134
  }], euiPrimary: [{
134
135
  type: Input,
135
136
  args: [{ transform: booleanAttribute }]
137
+ }], ariaLabel: [{
138
+ type: Input,
139
+ args: ['aria-label']
136
140
  }], languageSelectorClick: [{
137
141
  type: Output
138
142
  }] } });
139
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"language-selector.component.js","sourceRoot":"","sources":["../../../eui-language-selector/language-selector.component.ts","../../../eui-language-selector/language-selector.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    ViewEncapsulation,\n    HostBinding,\n    OnDestroy,\n    OnInit,\n    ChangeDetectorRef,\n    Input,\n    Output,\n    EventEmitter,\n    booleanAttribute,\n    ElementRef,\n    AfterContentInit,\n    AfterViewInit,\n} from '@angular/core';\nimport { distinctUntilKeyChanged, map, takeUntil } from 'rxjs/operators';\nimport { Subject } from 'rxjs';\nimport { TranslateService } from '@ngx-translate/core';\n\nimport { EuiEuLanguages, EuiLanguage } from '@eui/core';\nimport { EuiAppShellService } from '@eui/core';\nimport { EuiDialogConfig, EuiDialogService } from '@eui/components/eui-dialog';\n\nimport { EuiModalSelectorComponent } from './modal-selector/modal-selector.component';\n\n@Component({\n    selector: 'eui-language-selector',\n    templateUrl: './language-selector.component.html',\n    styleUrls: ['./_styles/_index.scss'],\n    encapsulation: ViewEncapsulation.None,\n})\nexport class EuiLanguageSelectorComponent implements OnInit, AfterViewInit, OnDestroy {\n    @HostBinding('class')\n    get cssClasses(): string {\n        return [\n            'eui-language-selector',\n            this.languages?.length <= 1 ? 'eui-language-selector--empty' : '',\n            this.isToolbarSelector ? 'eui-language-selector--toolbar-selector' : '',\n        ].join(' ').trim();\n    }\n\n    languages: EuiLanguage[];\n    selectedLanguage: EuiLanguage;\n\n    @Input({ transform: booleanAttribute }) hasLanguageSelection = true;\n    @Input({ transform: booleanAttribute }) isToolbarSelector = false;\n    @Input({ transform: booleanAttribute }) euiPrimary = false;\n\n    @Output() languageSelectorClick = new EventEmitter<null>();\n\n    private destroy$: Subject<boolean> = new Subject<boolean>();\n\n    constructor(\n        private cd: ChangeDetectorRef,\n        private euiDialogService: EuiDialogService,\n        public appShellService: EuiAppShellService,\n        private translateService: TranslateService,\n        private elRef: ElementRef,\n    ) {\n    }\n\n    /**\n     * returns true if there are at least one and max four languages.\n     */\n    get isShowDropDown(): boolean {\n        return this.languages?.length > 1 && this.languages?.length < 4;\n    }\n\n    /**\n     * returns true if there are at least five languages.\n     */\n    get isShowModal(): boolean {\n        return this.languages?.length >= 4;\n    }\n\n    ngOnInit(): void {\n        // update languages array based on AppShell State 'language' changes\n        this.appShellService.state$\n            .pipe(\n                takeUntil(this.destroy$),\n                distinctUntilKeyChanged('languages'),\n                map((state) => state.languages),\n            )\n            .subscribe((languages) => {\n                this.languages = languages ? EuiEuLanguages.getOrderedLanguages(languages) : EuiEuLanguages.getLanguages();\n                this.cd.detectChanges();\n            });\n\n        // update activeLanguage array based on AppShell State 'language' changes\n        this.appShellService.state$\n            .pipe(\n                takeUntil(this.destroy$),\n                distinctUntilKeyChanged('activeLanguage'),\n                map((state) => state.activeLanguage),\n            )\n            .subscribe((activeLanguage) => {\n                this.selectedLanguage = this.getLanguage(activeLanguage);\n                this.cd.detectChanges();\n            });\n    }\n\n    ngAfterViewInit(): void {\n        let hasToolbarParent = false;\n        try {\n            hasToolbarParent = this.elRef.nativeElement.closest('eui-toolbar');\n\n        } catch(e) {\n           // do nothing\n        }\n\n        if (hasToolbarParent) {\n            setTimeout(() => {\n                this.isToolbarSelector = true;\n            }, 1);\n        }\n    }\n\n    ngOnDestroy(): void {\n        this.destroy$.next(true);\n        this.destroy$.unsubscribe();\n    }\n\n    onLanguageChanged(language: EuiLanguage): void {\n        // Update the AppShellService state\n        this.appShellService.setState({\n            ...this.appShellService.state,\n            activeLanguage: language.code,\n        });\n    }\n\n    /**\n     * Opens the modal that renders the UxLanguage array with modal actions bindings to this Component\n     */\n    onOpen(titleLabel: string = this.translateService.instant('eui.languageSelector.modalTitle')): void {\n        this.euiDialogService.openDialog(\n            new EuiDialogConfig({\n                title: titleLabel,\n                hasFooter: false,\n                hasClosedOnClickOutside: true,\n                bodyComponent: {\n                    component: EuiModalSelectorComponent,\n                    config: {\n                        languages: this.languages,\n                        selectedLanguage: this.selectedLanguage,\n                        languageChanged: (language: EuiLanguage):void => this.onLanguageChanged(language),\n                    },\n                },\n            }),\n        );\n    }\n\n    onClick(): void {\n        this.languageSelectorClick.emit();\n    }\n\n    /**\n     * returns the UxLanguage Object from a given language code\n     *\n     * @param languageCode two char language code\n     * @protected\n     */\n    protected getLanguage(languageCode: string): EuiLanguage {\n        return this.languages.find((lang) => lang.code === languageCode);\n    }\n}\n","@if (!hasLanguageSelection) {\n    <button class=\"eui-language-selector__button\"\n        euiButton [euiBasicButton]=\"!isToolbarSelector\"\n        [euiBranding]=\"isToolbarSelector\"\n        (click)=\"onClick()\">\n        <ng-template *ngTemplateOutlet=\"languageSelectorIcon\"></ng-template>\n        <span class=\"eui-language-selector__code\">{{ (appShellService.state$ | async).activeLanguage }}</span>\n    </button>\n\n} @else if (hasLanguageSelection && isShowDropDown) {\n    <eui-dropdown>\n        <button class=\"eui-language-selector__button\"\n            euiButton [euiBasicButton]=\"!isToolbarSelector\"\n            [euiBranding]=\"isToolbarSelector\">\n            <ng-template *ngTemplateOutlet=\"languageSelectorIcon\"></ng-template>\n            <span class=\"eui-language-selector__code\">{{ (appShellService.state$ | async).activeLanguage }}</span>\n        </button>\n\n        <eui-dropdown-content>\n            <div class=\"eui-language-selector-menu\">\n                <button\n                    *ngFor=\"let language of languages\"\n                    euiDropdownItem\n                    attr.data-e2e=\"eui-language-selector-item_{{ language.code }}\"\n                    class=\"eui-language-selector-menu-language-item\"\n                    (click)=\"onLanguageChanged(language)\">\n                    {{ language.label }} ({{ language.code }})\n                </button>\n            </div>\n        </eui-dropdown-content>\n    </eui-dropdown>\n\n} @else if (hasLanguageSelection && isShowModal) {\n    <button class=\"eui-language-selector__button\"\n        euiButton euiBasicButton\n        [euiPrimary]=\"isToolbarSelector\"\n        (click)=\"onOpen()\">\n        <ng-template *ngTemplateOutlet=\"languageSelectorIcon\"></ng-template>\n        <span class=\"eui-language-selector__code\">{{ (appShellService.state$ | async).activeLanguage }}</span>\n    </button>\n}\n\n<ng-template #languageSelectorIcon>\n    <eui-icon-svg icon=\"eui-ecl-global\"></eui-icon-svg>\n</ng-template>\n"]}
143
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"language-selector.component.js","sourceRoot":"","sources":["../../../eui-language-selector/language-selector.component.ts","../../../eui-language-selector/language-selector.component.html"],"names":[],"mappings":"AAAA,OAAO,EACH,SAAS,EACT,iBAAiB,EACjB,WAAW,EAIX,KAAK,EACL,MAAM,EACN,YAAY,EACZ,gBAAgB,GAGnB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,uBAAuB,EAAE,GAAG,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AACzE,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAG/B,OAAO,EAAE,cAAc,EAAe,MAAM,WAAW,CAAC;AAExD,OAAO,EAAE,eAAe,EAAoB,MAAM,4BAA4B,CAAC;AAE/E,OAAO,EAAE,yBAAyB,EAAE,MAAM,2CAA2C,CAAC;;;;;;;;;AAQtF,MAAM,OAAO,4BAA4B;IACrC,IACI,UAAU;QACV,OAAO;YACH,uBAAuB;YACvB,IAAI,CAAC,SAAS,EAAE,MAAM,IAAI,CAAC,CAAC,CAAC,CAAC,8BAA8B,CAAC,CAAC,CAAC,EAAE;YACjE,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAC,yCAAyC,CAAC,CAAC,CAAC,EAAE;SAC1E,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,CAAC;IACvB,CAAC;IAcD,YACY,EAAqB,EACrB,gBAAkC,EACnC,eAAmC,EAClC,gBAAkC,EAClC,KAAiB;QAJjB,OAAE,GAAF,EAAE,CAAmB;QACrB,qBAAgB,GAAhB,gBAAgB,CAAkB;QACnC,oBAAe,GAAf,eAAe,CAAoB;QAClC,qBAAgB,GAAhB,gBAAgB,CAAkB;QAClC,UAAK,GAAL,KAAK,CAAY;QAdW,yBAAoB,GAAG,IAAI,CAAC;QAC5B,sBAAiB,GAAG,KAAK,CAAC;QAC1B,eAAU,GAAG,KAAK,CAAC;QACtC,cAAS,GAAG,iBAAiB,CAAC;QAEzC,0BAAqB,GAAG,IAAI,YAAY,EAAQ,CAAC;QAEnD,aAAQ,GAAqB,IAAI,OAAO,EAAW,CAAC;IAS5D,CAAC;IAED;;OAEG;IACH,IAAI,cAAc;QACd,OAAO,IAAI,CAAC,SAAS,EAAE,MAAM,GAAG,CAAC,IAAI,IAAI,CAAC,SAAS,EAAE,MAAM,GAAG,CAAC,CAAC;IACpE,CAAC;IAED;;OAEG;IACH,IAAI,WAAW;QACX,OAAO,IAAI,CAAC,SAAS,EAAE,MAAM,IAAI,CAAC,CAAC;IACvC,CAAC;IAED,QAAQ;QACJ,oEAAoE;QACpE,IAAI,CAAC,eAAe,CAAC,MAAM;aACtB,IAAI,CACD,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,EACxB,uBAAuB,CAAC,WAAW,CAAC,EACpC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,SAAS,CAAC,CAClC;aACA,SAAS,CAAC,CAAC,SAAS,EAAE,EAAE;YACrB,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC,CAAC,CAAC,cAAc,CAAC,mBAAmB,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,cAAc,CAAC,YAAY,EAAE,CAAC;YAC3G,IAAI,CAAC,EAAE,CAAC,aAAa,EAAE,CAAC;QAC5B,CAAC,CAAC,CAAC;QAEP,yEAAyE;QACzE,IAAI,CAAC,eAAe,CAAC,MAAM;aACtB,IAAI,CACD,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,EACxB,uBAAuB,CAAC,gBAAgB,CAAC,EACzC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,cAAc,CAAC,CACvC;aACA,SAAS,CAAC,CAAC,cAAc,EAAE,EAAE;YAC1B,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,WAAW,CAAC,cAAc,CAAC,CAAC;YACzD,IAAI,CAAC,EAAE,CAAC,aAAa,EAAE,CAAC;QAC5B,CAAC,CAAC,CAAC;IACX,CAAC;IAED,eAAe;QACX,IAAI,gBAAgB,GAAG,KAAK,CAAC;QAC7B,IAAI,CAAC;YACD,gBAAgB,GAAG,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC;QAEvE,CAAC;QAAC,OAAM,CAAC,EAAE,CAAC;YACT,aAAa;QAChB,CAAC;QAED,IAAI,gBAAgB,EAAE,CAAC;YACnB,UAAU,CAAC,GAAG,EAAE;gBACZ,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC;YAClC,CAAC,EAAE,CAAC,CAAC,CAAC;QACV,CAAC;IACL,CAAC;IAED,WAAW;QACP,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACzB,IAAI,CAAC,QAAQ,CAAC,WAAW,EAAE,CAAC;IAChC,CAAC;IAED,iBAAiB,CAAC,QAAqB;QACnC,mCAAmC;QACnC,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC;YAC1B,GAAG,IAAI,CAAC,eAAe,CAAC,KAAK;YAC7B,cAAc,EAAE,QAAQ,CAAC,IAAI;SAChC,CAAC,CAAC;IACP,CAAC;IAED;;OAEG;IACH,MAAM,CAAC,aAAqB,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,iCAAiC,CAAC;QACxF,IAAI,CAAC,gBAAgB,CAAC,UAAU,CAC5B,IAAI,eAAe,CAAC;YAChB,KAAK,EAAE,UAAU;YACjB,SAAS,EAAE,KAAK;YAChB,uBAAuB,EAAE,IAAI;YAC7B,aAAa,EAAE;gBACX,SAAS,EAAE,yBAAyB;gBACpC,MAAM,EAAE;oBACJ,SAAS,EAAE,IAAI,CAAC,SAAS;oBACzB,gBAAgB,EAAE,IAAI,CAAC,gBAAgB;oBACvC,eAAe,EAAE,CAAC,QAAqB,EAAO,EAAE,CAAC,IAAI,CAAC,iBAAiB,CAAC,QAAQ,CAAC;iBACpF;aACJ;SACJ,CAAC,CACL,CAAC;IACN,CAAC;IAED,OAAO;QACH,IAAI,CAAC,qBAAqB,CAAC,IAAI,EAAE,CAAC;IACtC,CAAC;IAED;;;;;OAKG;IACO,WAAW,CAAC,YAAoB;QACtC,OAAO,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,IAAI,KAAK,YAAY,CAAC,CAAC;IACrE,CAAC;8GArIQ,4BAA4B;kGAA5B,4BAA4B,sHAajB,gBAAgB,iEAChB,gBAAgB,4CAChB,gBAAgB,wLC7CxC,mnEAgDA;;2FDlBa,4BAA4B;kBANxC,SAAS;+BACI,uBAAuB,iBAGlB,iBAAiB,CAAC,IAAI;8MAIjC,UAAU;sBADb,WAAW;uBAAC,OAAO;gBAYoB,oBAAoB;sBAA3D,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE;gBACE,iBAAiB;sBAAxD,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE;gBACE,UAAU;sBAAjD,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE;gBACjB,SAAS;sBAA7B,KAAK;uBAAC,YAAY;gBAET,qBAAqB;sBAA9B,MAAM","sourcesContent":["import {\n    Component,\n    ViewEncapsulation,\n    HostBinding,\n    OnDestroy,\n    OnInit,\n    ChangeDetectorRef,\n    Input,\n    Output,\n    EventEmitter,\n    booleanAttribute,\n    ElementRef,\n    AfterViewInit,\n} from '@angular/core';\nimport { distinctUntilKeyChanged, map, takeUntil } from 'rxjs/operators';\nimport { Subject } from 'rxjs';\nimport { TranslateService } from '@ngx-translate/core';\n\nimport { EuiEuLanguages, EuiLanguage } from '@eui/core';\nimport { EuiAppShellService } from '@eui/core';\nimport { EuiDialogConfig, EuiDialogService } from '@eui/components/eui-dialog';\n\nimport { EuiModalSelectorComponent } from './modal-selector/modal-selector.component';\n\n@Component({\n    selector: 'eui-language-selector',\n    templateUrl: './language-selector.component.html',\n    styleUrls: ['./_styles/_index.scss'],\n    encapsulation: ViewEncapsulation.None,\n})\nexport class EuiLanguageSelectorComponent implements OnInit, AfterViewInit, OnDestroy {\n    @HostBinding('class')\n    get cssClasses(): string {\n        return [\n            'eui-language-selector',\n            this.languages?.length <= 1 ? 'eui-language-selector--empty' : '',\n            this.isToolbarSelector ? 'eui-language-selector--toolbar-selector' : '',\n        ].join(' ').trim();\n    }\n\n    languages: EuiLanguage[];\n    selectedLanguage: EuiLanguage;\n\n    @Input({ transform: booleanAttribute }) hasLanguageSelection = true;\n    @Input({ transform: booleanAttribute }) isToolbarSelector = false;\n    @Input({ transform: booleanAttribute }) euiPrimary = false;\n    @Input('aria-label') ariaLabel = 'Change Language';\n\n    @Output() languageSelectorClick = new EventEmitter<null>();\n\n    private destroy$: Subject<boolean> = new Subject<boolean>();\n\n    constructor(\n        private cd: ChangeDetectorRef,\n        private euiDialogService: EuiDialogService,\n        public appShellService: EuiAppShellService,\n        private translateService: TranslateService,\n        private elRef: ElementRef,\n    ) {\n    }\n\n    /**\n     * returns true if there are at least one and max four languages.\n     */\n    get isShowDropDown(): boolean {\n        return this.languages?.length > 1 && this.languages?.length < 4;\n    }\n\n    /**\n     * returns true if there are at least five languages.\n     */\n    get isShowModal(): boolean {\n        return this.languages?.length >= 4;\n    }\n\n    ngOnInit(): void {\n        // update languages array based on AppShell State 'language' changes\n        this.appShellService.state$\n            .pipe(\n                takeUntil(this.destroy$),\n                distinctUntilKeyChanged('languages'),\n                map((state) => state.languages),\n            )\n            .subscribe((languages) => {\n                this.languages = languages ? EuiEuLanguages.getOrderedLanguages(languages) : EuiEuLanguages.getLanguages();\n                this.cd.detectChanges();\n            });\n\n        // update activeLanguage array based on AppShell State 'language' changes\n        this.appShellService.state$\n            .pipe(\n                takeUntil(this.destroy$),\n                distinctUntilKeyChanged('activeLanguage'),\n                map((state) => state.activeLanguage),\n            )\n            .subscribe((activeLanguage) => {\n                this.selectedLanguage = this.getLanguage(activeLanguage);\n                this.cd.detectChanges();\n            });\n    }\n\n    ngAfterViewInit(): void {\n        let hasToolbarParent = false;\n        try {\n            hasToolbarParent = this.elRef.nativeElement.closest('eui-toolbar');\n\n        } catch(e) {\n           // do nothing\n        }\n\n        if (hasToolbarParent) {\n            setTimeout(() => {\n                this.isToolbarSelector = true;\n            }, 1);\n        }\n    }\n\n    ngOnDestroy(): void {\n        this.destroy$.next(true);\n        this.destroy$.unsubscribe();\n    }\n\n    onLanguageChanged(language: EuiLanguage): void {\n        // Update the AppShellService state\n        this.appShellService.setState({\n            ...this.appShellService.state,\n            activeLanguage: language.code,\n        });\n    }\n\n    /**\n     * Opens the modal that renders the UxLanguage array with modal actions bindings to this Component\n     */\n    onOpen(titleLabel: string = this.translateService.instant('eui.languageSelector.modalTitle')): void {\n        this.euiDialogService.openDialog(\n            new EuiDialogConfig({\n                title: titleLabel,\n                hasFooter: false,\n                hasClosedOnClickOutside: true,\n                bodyComponent: {\n                    component: EuiModalSelectorComponent,\n                    config: {\n                        languages: this.languages,\n                        selectedLanguage: this.selectedLanguage,\n                        languageChanged: (language: EuiLanguage):void => this.onLanguageChanged(language),\n                    },\n                },\n            }),\n        );\n    }\n\n    onClick(): void {\n        this.languageSelectorClick.emit();\n    }\n\n    /**\n     * returns the UxLanguage Object from a given language code\n     *\n     * @param languageCode two char language code\n     * @protected\n     */\n    protected getLanguage(languageCode: string): EuiLanguage {\n        return this.languages.find((lang) => lang.code === languageCode);\n    }\n}\n","@if (!hasLanguageSelection) {\n    <button class=\"eui-language-selector__button\"\n        euiButton [euiBasicButton]=\"!isToolbarSelector\"\n        [euiBranding]=\"isToolbarSelector\"\n        (click)=\"onClick()\"\n        [attr.aria-label]=\"ariaLabel\">\n        <ng-template *ngTemplateOutlet=\"languageSelectorIcon\"></ng-template>\n        <span class=\"eui-language-selector__code\">{{ (appShellService.state$ | async).activeLanguage }}</span>\n    </button>\n\n} @else if (hasLanguageSelection && isShowDropDown) {\n    <eui-dropdown>\n        <button class=\"eui-language-selector__button\"\n            [attr.aria-label]=\"ariaLabel\"\n            euiButton [euiBasicButton]=\"!isToolbarSelector\"\n            [euiBranding]=\"isToolbarSelector\">\n            <ng-template *ngTemplateOutlet=\"languageSelectorIcon\"></ng-template>\n            <span class=\"eui-language-selector__code\">{{ (appShellService.state$ | async).activeLanguage }}</span>\n        </button>\n\n        <eui-dropdown-content>\n            <div class=\"eui-language-selector-menu\">\n                <button\n                    *ngFor=\"let language of languages\"\n                    euiDropdownItem\n                    attr.data-e2e=\"eui-language-selector-item_{{ language.code }}\"\n                    class=\"eui-language-selector-menu-language-item\"\n                    (click)=\"onLanguageChanged(language)\">\n                    {{ language.label }} ({{ language.code }})\n                </button>\n            </div>\n        </eui-dropdown-content>\n    </eui-dropdown>\n\n} @else if (hasLanguageSelection && isShowModal) {\n    <button class=\"eui-language-selector__button\"\n        euiButton euiBasicButton\n        [euiPrimary]=\"isToolbarSelector\"\n        (click)=\"onOpen()\"\n        [attr.aria-label]=\"ariaLabel\">\n        <ng-template *ngTemplateOutlet=\"languageSelectorIcon\"></ng-template>\n        <span class=\"eui-language-selector__code\">{{ (appShellService.state$ | async).activeLanguage }}</span>\n    </button>\n}\n\n<ng-template #languageSelectorIcon>\n    <eui-icon-svg icon=\"eui-ecl-global\"></eui-icon-svg>\n</ng-template>\n"]}
@@ -49,12 +49,8 @@ export class EuiMenuItemComponent {
49
49
  if (!this.item.urlExternalTarget) {
50
50
  this.item.urlExternalTarget = '_blank';
51
51
  }
52
- if (this.item.filtered === undefined) {
53
- this.item.filtered = true;
54
- }
55
- if (this.item.disabled === undefined) {
56
- this.item.visible = true;
57
- }
52
+ this.item.filtered = typeof this.item.filtered == 'boolean' ? this.item.filtered : true;
53
+ this.item.visible = typeof this.item.visible == 'boolean' ? this.item.visible : true;
58
54
  }
59
55
  }
60
56
  /**
@@ -206,4 +202,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.1", ngImpor
206
202
  type: HostListener,
207
203
  args: ['click', ['$event']]
208
204
  }] } });
209
- //# 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    @Input() hasExpandIcon = true;\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    public stopPropagation(event: MouseEvent): void;\n    /**\n     * @deprecated pass the event as MouseEvent. Will be removed on next eUI release.\n     * @param event\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: MouseEvent | KeyboardEvent): void;\n    /**\n     * @deprecated pass the event as MouseEvent or KeyboardEvent. Will be removed on next eUI release.\n     * @param event\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: MouseEvent): void;\n    /**\n     * @deprecated pass the event as MouseEvent. Will be removed on next eUI release.\n     * @param event\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    @if (hasExpandIcon) {\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    }\n</ng-template>\n"]}
205
+ //# 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    @Input() hasExpandIcon = true;\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\n            this.item.filtered = typeof this.item.filtered == 'boolean' ? this.item.filtered : true;\n            this.item.visible = typeof this.item.visible == 'boolean' ? this.item.visible : true;\n        }\n    }\n\n    public stopPropagation(event: MouseEvent): void;\n    /**\n     * @deprecated pass the event as MouseEvent. Will be removed on next eUI release.\n     * @param event\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: MouseEvent | KeyboardEvent): void;\n    /**\n     * @deprecated pass the event as MouseEvent or KeyboardEvent. Will be removed on next eUI release.\n     * @param event\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: MouseEvent): void;\n    /**\n     * @deprecated pass the event as MouseEvent. Will be removed on next eUI release.\n     * @param event\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    @if (hasExpandIcon) {\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    }\n</ng-template>\n"]}