@eui/components 17.0.3-snapshot-1703212038654 → 17.0.3-snapshot-1704334309393

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 (44) hide show
  1. package/docs/components/EuiAppSidebarMenuComponent.html +49 -1
  2. package/docs/components/EuiMenuComponent.html +49 -1
  3. package/docs/components/EuiMenuItemComponent.html +52 -4
  4. package/docs/components/EuiPageColumnComponent.html +91 -373
  5. package/docs/components/EuiPageColumnsComponent.html +87 -0
  6. package/docs/components/EuiSidebarMenuComponent.html +74 -327
  7. package/docs/components/EuiTimepickerComponent.html +26 -1
  8. package/docs/dependencies.html +2 -2
  9. package/docs/js/search/search_index.js +2 -2
  10. package/docs/miscellaneous/variables.html +21 -0
  11. package/esm2022/eui-menu/eui-menu-item.component.mjs +22 -19
  12. package/esm2022/eui-menu/eui-menu.component.mjs +20 -3
  13. package/esm2022/eui-page/components/eui-page-column/eui-page-column.component.mjs +58 -58
  14. package/esm2022/eui-page/components/eui-page-columns/eui-page-columns.component.mjs +19 -4
  15. package/esm2022/eui-sidebar-menu/eui-sidebar-menu.component.mjs +27 -45
  16. package/esm2022/eui-timepicker/eui-timepicker.component.mjs +21 -6
  17. package/esm2022/layout/eui-app/eui-app-sidebar/sidebar-menu/sidebar-menu.component.mjs +11 -3
  18. package/esm2022/layout/eui-app/eui-app.component.mjs +1 -1
  19. package/esm2022/layout/eui-toolbar/toolbar.component.mjs +2 -2
  20. package/eui-menu/eui-menu-item.component.d.ts +11 -5
  21. package/eui-menu/eui-menu-item.component.d.ts.map +1 -1
  22. package/eui-menu/eui-menu.component.d.ts +5 -1
  23. package/eui-menu/eui-menu.component.d.ts.map +1 -1
  24. package/eui-page/components/eui-page-column/eui-page-column.component.d.ts +24 -25
  25. package/eui-page/components/eui-page-column/eui-page-column.component.d.ts.map +1 -1
  26. package/eui-page/components/eui-page-columns/eui-page-columns.component.d.ts +10 -1
  27. package/eui-page/components/eui-page-columns/eui-page-columns.component.d.ts.map +1 -1
  28. package/eui-sidebar-menu/eui-sidebar-menu.component.d.ts +15 -17
  29. package/eui-sidebar-menu/eui-sidebar-menu.component.d.ts.map +1 -1
  30. package/eui-timepicker/eui-timepicker.component.d.ts +5 -3
  31. package/eui-timepicker/eui-timepicker.component.d.ts.map +1 -1
  32. package/fesm2022/eui-components-eui-menu.mjs +41 -21
  33. package/fesm2022/eui-components-eui-menu.mjs.map +1 -1
  34. package/fesm2022/eui-components-eui-page.mjs +74 -60
  35. package/fesm2022/eui-components-eui-page.mjs.map +1 -1
  36. package/fesm2022/eui-components-eui-sidebar-menu.mjs +26 -44
  37. package/fesm2022/eui-components-eui-sidebar-menu.mjs.map +1 -1
  38. package/fesm2022/eui-components-eui-timepicker.mjs +20 -5
  39. package/fesm2022/eui-components-eui-timepicker.mjs.map +1 -1
  40. package/fesm2022/eui-components-layout.mjs +13 -5
  41. package/fesm2022/eui-components-layout.mjs.map +1 -1
  42. package/layout/eui-app/eui-app-sidebar/sidebar-menu/sidebar-menu.component.d.ts +5 -1
  43. package/layout/eui-app/eui-app-sidebar/sidebar-menu/sidebar-menu.component.d.ts.map +1 -1
  44. package/package.json +7 -7
@@ -1,6 +1,7 @@
1
- import { coerceBooleanProperty } from '@angular/cdk/coercion';
2
- import { Component, HostBinding, ViewEncapsulation, Input, Output, Directive, ContentChild, forwardRef, EventEmitter, HostListener, } from '@angular/core';
1
+ import { Component, HostBinding, ViewEncapsulation, Input, Output, Directive, ContentChild, forwardRef, EventEmitter, HostListener, Host, Optional, Inject, booleanAttribute, } from '@angular/core';
2
+ import { Subject, debounceTime, takeUntil } from 'rxjs';
3
3
  import { BaseDirective } from '@eui/components/shared';
4
+ import { EuiPageColumnsComponent } from '../eui-page-columns/eui-page-columns.component';
4
5
  import * as i0 from "@angular/core";
5
6
  import * as i1 from "@eui/core";
6
7
  import * as i2 from "@angular/common";
@@ -8,42 +9,6 @@ import * as i3 from "@eui/components/eui-button";
8
9
  import * as i4 from "@eui/components/eui-icon";
9
10
  import * as i5 from "@angular/cdk/scrolling";
10
11
  export class EuiPageColumnComponent extends BaseDirective {
11
- get isCollapsible() {
12
- return this._isCollapsible;
13
- }
14
- set isCollapsible(value) {
15
- this._isCollapsible = coerceBooleanProperty(value);
16
- }
17
- get isCollapsed() {
18
- return this._isCollapsed;
19
- }
20
- set isCollapsed(value) {
21
- this._isCollapsed = coerceBooleanProperty(value);
22
- }
23
- get isHighlighted() {
24
- return this._isHighlighted;
25
- }
26
- set isHighlighted(value) {
27
- this._isHighlighted = coerceBooleanProperty(value);
28
- }
29
- get isCollapsedWithIcons() {
30
- return this._isCollapsedWithIcons;
31
- }
32
- set isCollapsedWithIcons(value) {
33
- this._isCollapsedWithIcons = coerceBooleanProperty(value);
34
- }
35
- get hasSidebarMenu() {
36
- return this._hasSidebarMenu;
37
- }
38
- set hasSidebarMenu(value) {
39
- this._hasSidebarMenu = coerceBooleanProperty(value);
40
- }
41
- get hasHeaderBodyShrinkable() {
42
- return this._hasHeaderBodyShrinkable;
43
- }
44
- set hasHeaderBodyShrinkable(value) {
45
- this._hasHeaderBodyShrinkable = coerceBooleanProperty(value);
46
- }
47
12
  get cssClasses() {
48
13
  return [
49
14
  super.getCssClasses('eui-page-column'),
@@ -58,9 +23,17 @@ export class EuiPageColumnComponent extends BaseDirective {
58
23
  .join(' ')
59
24
  .trim();
60
25
  }
61
- constructor(asService) {
26
+ constructor(pageColumnsParentInjected, asService) {
62
27
  super();
63
28
  this.asService = asService;
29
+ this.autoCollapseParentColumnsContainerWidth = null;
30
+ this.isCollapsible = false;
31
+ this.isCollapsed = false;
32
+ this.isHighlighted = false;
33
+ this.isCollapsedWithIcons = false;
34
+ this.hasSidebarMenu = false;
35
+ this.hasHeaderBodyShrinkable = false;
36
+ this.isParentColumnsObserverActive = false;
64
37
  this.collapse = new EventEmitter();
65
38
  this.headerCollapse = new EventEmitter();
66
39
  this.isActive = false;
@@ -68,12 +41,8 @@ export class EuiPageColumnComponent extends BaseDirective {
68
41
  this.currentOffset = 0;
69
42
  this.previousOffset = 0;
70
43
  this.treshHold = 50;
71
- this._isCollapsible = false;
72
- this._isCollapsed = false;
73
- this._isHighlighted = false;
74
- this._isCollapsedWithIcons = false; // contains ux-layout-sidebar-items
75
- this._hasSidebarMenu = false; // contains eui-sidebar-menu
76
- this._hasHeaderBodyShrinkable = false; // allow to track scroll event Up & Down
44
+ this.destroy$ = new Subject();
45
+ this.pageColumnsParent = pageColumnsParentInjected;
77
46
  }
78
47
  onBodyScoll(event) {
79
48
  if (this.hasHeaderBodyShrinkable && event.target) {
@@ -97,42 +66,73 @@ export class EuiPageColumnComponent extends BaseDirective {
97
66
  }
98
67
  ngOnInit() {
99
68
  this.euiSizeS = false; // Bypass size default
69
+ if (this.pageColumnsParent && this.isParentColumnsObserverActive && this.autoCollapseParentColumnsContainerWidth) {
70
+ this.pageColumnsParent.width.pipe(debounceTime(100), takeUntil(this.destroy$)).subscribe((parentWidth) => {
71
+ console.log(parentWidth);
72
+ if (parentWidth <= this.autoCollapseParentColumnsContainerWidth) {
73
+ this.isCollapsed = true;
74
+ this.collapse.emit(this.isCollapsed);
75
+ }
76
+ });
77
+ }
78
+ }
79
+ ngOnDestroy() {
80
+ this.destroy$.next(true);
81
+ this.destroy$.unsubscribe();
100
82
  }
101
83
  onToggle() {
102
84
  this.isCollapsed = !this.isCollapsed;
103
85
  this.collapse.emit(this.isCollapsed);
104
86
  }
105
- /** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.6", ngImport: i0, type: EuiPageColumnComponent, deps: [{ token: i1.EuiAppShellService }], target: i0.ɵɵFactoryTarget.Component }); }
106
- /** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.0.6", type: EuiPageColumnComponent, selector: "eui-page-column", inputs: { size: "size", label: "label", subLabel: "subLabel", isCollapsible: "isCollapsible", isCollapsed: "isCollapsed", isHighlighted: "isHighlighted", isCollapsedWithIcons: "isCollapsedWithIcons", hasSidebarMenu: "hasSidebarMenu", hasHeaderBodyShrinkable: "hasHeaderBodyShrinkable" }, outputs: { collapse: "collapse", headerCollapse: "headerCollapse" }, host: { listeners: { "window:scroll": "onBodyScoll($event)" }, properties: { "class": "this.cssClasses" } }, queries: [{ propertyName: "customHeaderBodyContent", first: true, predicate: i0.forwardRef(() => EuiPageColumnHeaderBodyContentDirective), descendants: true }, { propertyName: "customHeaderLeftContent", first: true, predicate: i0.forwardRef(() => EuiPageColumnHeaderLeftContentDirective), descendants: true }, { propertyName: "customHeaderRightContent", first: true, predicate: i0.forwardRef(() => EuiPageColumnHeaderRightContentDirective), descendants: true }, { propertyName: "customHeaderCollapsedContent", first: true, predicate: i0.forwardRef(() => EuiPageColumnHeaderCollapsedContentDirective), descendants: true }, { propertyName: "customFooterContent", first: true, predicate: i0.forwardRef(() => EuiPageColumnFooterContentDirective), descendants: true }], usesInheritance: true, ngImport: i0, template: "<div\n *ngIf=\"label || subLabel || customHeaderLeftContent || customHeaderRightContent || isCollapsible\"\n class=\"eui-page-column__header\"\n [class.eui-page-column__header--with-icons]=\"isCollapsedWithIcons\">\n <div *ngIf=\"!customHeaderLeftContent\" class=\"eui-page-column__header-left-content\">\n <div *ngIf=\"label\" class=\"eui-page-column__header-left-content-label\">\n <ng-content *ngIf=\"customHeaderCollapsedContent\" select=\"eui-page-column-header-collapsed-content\"></ng-content>\n <ng-container *ngIf=\"!isCollapsedWithIcons\">\n {{ label }}\n </ng-container>\n </div>\n <div *ngIf=\"subLabel\" class=\"eui-page-column__header-left-content-sub-label\">\n {{ subLabel }}\n </div>\n </div>\n <div *ngIf=\"customHeaderLeftContent\" class=\"eui-page-column__header-left-content\">\n <ng-content select=\"eui-page-column-header-left-content\"></ng-content>\n </div>\n\n <div class=\"eui-page-column__header-right-content\">\n <span *ngIf=\"customHeaderRightContent\" class=\"eui-page-column__header-right-content-body\">\n <ng-content select=\"eui-page-column-header-right-content\"></ng-content>\n </span>\n <button\n *ngIf=\"isCollapsible\"\n euiButton\n euiBasicButton\n euiSecondary\n euiRounded\n euiIconButton\n euiSizeS\n type=\"button\"\n (click)=\"onToggle()\"\n [attr.aria-label]=\"isCollapsed ? 'Expand' : 'Collapse'\"\n class=\"eui-page-column__header-toggle\">\n @if (isCollapsed) {\n @if ((asService.state$ | async).breakpoints.isMobile) {\n <eui-icon-svg icon=\"eui-chevron-down\"></eui-icon-svg>\n } @else {\n <eui-icon-svg icon=\"eui-chevron-forward\"></eui-icon-svg>\n }\n } @else {\n @if ((asService.state$ | async).breakpoints.isMobile) {\n <eui-icon-svg icon=\"eui-chevron-up\"></eui-icon-svg>\n } @else {\n <eui-icon-svg icon=\"eui-chevron-back\"></eui-icon-svg>\n }\n }\n </button>\n </div>\n</div>\n<!-- On new line to not interfere with expand/collapse & custom right content -->\n<div\n *ngIf=\"customHeaderBodyContent\"\n class=\"eui-page-column__header-left-content-body\"\n [class.eui-page-column__header-left-content-body--shrinked]=\"isHeaderBodyShrinked\">\n <ng-content select=\"eui-page-column-header-body\"></ng-content>\n</div>\n<div\n class=\"eui-page-column__body\"\n cdkScrollable\n tabindex=\"0\"\n [class.eui-page-column--collapsed-with-icons]=\"isCollapsedWithIcons\"\n (scroll)=\"hasHeaderBodyShrinkable ? onBodyScoll($event) : null\">\n <ng-content select=\"eui-page-column-body\"></ng-content>\n</div>\n<div *ngIf=\"customFooterContent\" class=\"eui-page-column__footer\" [class.eui-page-column__footer--highlighted]=\"isHighlighted\">\n <ng-content select=\"eui-page-column-footer\"></ng-content>\n</div>\n", dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.EuiButtonComponent, selector: "button[euiButton], a[euiButton]", inputs: ["e2eAttr", "id", "euiBasicButton", "euiButtonCall", "euiBlockButton", "isLoading", "euiIconButton", "euiLineWrap"], outputs: ["buttonClick"] }, { kind: "component", type: i4.EuiIconSvgComponent, selector: "eui-icon-svg, span[euiIconSvg], i[euiIconSvg]", inputs: ["icon", "size", "fillColor", "set", "ariaLabelledby", "role", "style", "iconUrl", "transform", "aria-label", "ariaHidden", "focusable", "isLoading"] }, { kind: "directive", type: i5.CdkScrollable, selector: "[cdk-scrollable], [cdkScrollable]" }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }], encapsulation: i0.ViewEncapsulation.None }); }
87
+ /** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.6", ngImport: i0, type: EuiPageColumnComponent, deps: [{ token: forwardRef(() => EuiPageColumnsComponent), host: true, optional: true }, { token: i1.EuiAppShellService }], target: i0.ɵɵFactoryTarget.Component }); }
88
+ /** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.0.6", type: EuiPageColumnComponent, selector: "eui-page-column", inputs: { size: "size", label: "label", subLabel: "subLabel", autoCollapseParentColumnsContainerWidth: "autoCollapseParentColumnsContainerWidth", isCollapsible: ["isCollapsible", "isCollapsible", booleanAttribute], isCollapsed: ["isCollapsed", "isCollapsed", booleanAttribute], isHighlighted: ["isHighlighted", "isHighlighted", booleanAttribute], isCollapsedWithIcons: ["isCollapsedWithIcons", "isCollapsedWithIcons", booleanAttribute], hasSidebarMenu: ["hasSidebarMenu", "hasSidebarMenu", booleanAttribute], hasHeaderBodyShrinkable: ["hasHeaderBodyShrinkable", "hasHeaderBodyShrinkable", booleanAttribute], isParentColumnsObserverActive: ["isParentColumnsObserverActive", "isParentColumnsObserverActive", booleanAttribute] }, outputs: { collapse: "collapse", headerCollapse: "headerCollapse" }, host: { listeners: { "window:scroll": "onBodyScoll($event)" }, properties: { "class": "this.cssClasses" } }, queries: [{ propertyName: "customHeaderBodyContent", first: true, predicate: i0.forwardRef(() => EuiPageColumnHeaderBodyContentDirective), descendants: true }, { propertyName: "customHeaderLeftContent", first: true, predicate: i0.forwardRef(() => EuiPageColumnHeaderLeftContentDirective), descendants: true }, { propertyName: "customHeaderRightContent", first: true, predicate: i0.forwardRef(() => EuiPageColumnHeaderRightContentDirective), descendants: true }, { propertyName: "customHeaderCollapsedContent", first: true, predicate: i0.forwardRef(() => EuiPageColumnHeaderCollapsedContentDirective), descendants: true }, { propertyName: "customFooterContent", first: true, predicate: i0.forwardRef(() => EuiPageColumnFooterContentDirective), descendants: true }], usesInheritance: true, ngImport: i0, template: "<div\n *ngIf=\"label || subLabel || customHeaderLeftContent || customHeaderRightContent || isCollapsible\"\n class=\"eui-page-column__header\"\n [class.eui-page-column__header--with-icons]=\"isCollapsedWithIcons\">\n <div *ngIf=\"!customHeaderLeftContent\" class=\"eui-page-column__header-left-content\">\n <div *ngIf=\"label\" class=\"eui-page-column__header-left-content-label\">\n <ng-content *ngIf=\"customHeaderCollapsedContent\" select=\"eui-page-column-header-collapsed-content\"></ng-content>\n <ng-container *ngIf=\"!isCollapsedWithIcons\">\n {{ label }}\n </ng-container>\n </div>\n <div *ngIf=\"subLabel\" class=\"eui-page-column__header-left-content-sub-label\">\n {{ subLabel }}\n </div>\n </div>\n <div *ngIf=\"customHeaderLeftContent\" class=\"eui-page-column__header-left-content\">\n <ng-content select=\"eui-page-column-header-left-content\"></ng-content>\n </div>\n\n <div class=\"eui-page-column__header-right-content\">\n <span *ngIf=\"customHeaderRightContent\" class=\"eui-page-column__header-right-content-body\">\n <ng-content select=\"eui-page-column-header-right-content\"></ng-content>\n </span>\n <button\n *ngIf=\"isCollapsible\"\n euiButton\n euiBasicButton\n euiSecondary\n euiRounded\n euiIconButton\n euiSizeS\n type=\"button\"\n (click)=\"onToggle()\"\n [attr.aria-label]=\"isCollapsed ? 'Expand' : 'Collapse'\"\n class=\"eui-page-column__header-toggle\">\n @if (isCollapsed) {\n @if ((asService.state$ | async).breakpoints.isMobile) {\n <eui-icon-svg icon=\"eui-chevron-down\"></eui-icon-svg>\n } @else {\n <eui-icon-svg icon=\"eui-chevron-forward\"></eui-icon-svg>\n }\n } @else {\n @if ((asService.state$ | async).breakpoints.isMobile) {\n <eui-icon-svg icon=\"eui-chevron-up\"></eui-icon-svg>\n } @else {\n <eui-icon-svg icon=\"eui-chevron-back\"></eui-icon-svg>\n }\n }\n </button>\n </div>\n</div>\n<!-- On new line to not interfere with expand/collapse & custom right content -->\n<div\n *ngIf=\"customHeaderBodyContent\"\n class=\"eui-page-column__header-left-content-body\"\n [class.eui-page-column__header-left-content-body--shrinked]=\"isHeaderBodyShrinked\">\n <ng-content select=\"eui-page-column-header-body\"></ng-content>\n</div>\n<div\n class=\"eui-page-column__body\"\n cdkScrollable\n tabindex=\"0\"\n [class.eui-page-column--collapsed-with-icons]=\"isCollapsedWithIcons\"\n (scroll)=\"hasHeaderBodyShrinkable ? onBodyScoll($event) : null\">\n <ng-content select=\"eui-page-column-body\"></ng-content>\n</div>\n<div *ngIf=\"customFooterContent\" class=\"eui-page-column__footer\" [class.eui-page-column__footer--highlighted]=\"isHighlighted\">\n <ng-content select=\"eui-page-column-footer\"></ng-content>\n</div>\n", dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.EuiButtonComponent, selector: "button[euiButton], a[euiButton]", inputs: ["e2eAttr", "id", "euiBasicButton", "euiButtonCall", "euiBlockButton", "isLoading", "euiIconButton", "euiLineWrap"], outputs: ["buttonClick"] }, { kind: "component", type: i4.EuiIconSvgComponent, selector: "eui-icon-svg, span[euiIconSvg], i[euiIconSvg]", inputs: ["icon", "size", "fillColor", "set", "ariaLabelledby", "role", "style", "iconUrl", "transform", "aria-label", "ariaHidden", "focusable", "isLoading"] }, { kind: "directive", type: i5.CdkScrollable, selector: "[cdk-scrollable], [cdkScrollable]" }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }], encapsulation: i0.ViewEncapsulation.None }); }
107
89
  }
108
90
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.6", ngImport: i0, type: EuiPageColumnComponent, decorators: [{
109
91
  type: Component,
110
92
  args: [{ selector: 'eui-page-column', encapsulation: ViewEncapsulation.None, template: "<div\n *ngIf=\"label || subLabel || customHeaderLeftContent || customHeaderRightContent || isCollapsible\"\n class=\"eui-page-column__header\"\n [class.eui-page-column__header--with-icons]=\"isCollapsedWithIcons\">\n <div *ngIf=\"!customHeaderLeftContent\" class=\"eui-page-column__header-left-content\">\n <div *ngIf=\"label\" class=\"eui-page-column__header-left-content-label\">\n <ng-content *ngIf=\"customHeaderCollapsedContent\" select=\"eui-page-column-header-collapsed-content\"></ng-content>\n <ng-container *ngIf=\"!isCollapsedWithIcons\">\n {{ label }}\n </ng-container>\n </div>\n <div *ngIf=\"subLabel\" class=\"eui-page-column__header-left-content-sub-label\">\n {{ subLabel }}\n </div>\n </div>\n <div *ngIf=\"customHeaderLeftContent\" class=\"eui-page-column__header-left-content\">\n <ng-content select=\"eui-page-column-header-left-content\"></ng-content>\n </div>\n\n <div class=\"eui-page-column__header-right-content\">\n <span *ngIf=\"customHeaderRightContent\" class=\"eui-page-column__header-right-content-body\">\n <ng-content select=\"eui-page-column-header-right-content\"></ng-content>\n </span>\n <button\n *ngIf=\"isCollapsible\"\n euiButton\n euiBasicButton\n euiSecondary\n euiRounded\n euiIconButton\n euiSizeS\n type=\"button\"\n (click)=\"onToggle()\"\n [attr.aria-label]=\"isCollapsed ? 'Expand' : 'Collapse'\"\n class=\"eui-page-column__header-toggle\">\n @if (isCollapsed) {\n @if ((asService.state$ | async).breakpoints.isMobile) {\n <eui-icon-svg icon=\"eui-chevron-down\"></eui-icon-svg>\n } @else {\n <eui-icon-svg icon=\"eui-chevron-forward\"></eui-icon-svg>\n }\n } @else {\n @if ((asService.state$ | async).breakpoints.isMobile) {\n <eui-icon-svg icon=\"eui-chevron-up\"></eui-icon-svg>\n } @else {\n <eui-icon-svg icon=\"eui-chevron-back\"></eui-icon-svg>\n }\n }\n </button>\n </div>\n</div>\n<!-- On new line to not interfere with expand/collapse & custom right content -->\n<div\n *ngIf=\"customHeaderBodyContent\"\n class=\"eui-page-column__header-left-content-body\"\n [class.eui-page-column__header-left-content-body--shrinked]=\"isHeaderBodyShrinked\">\n <ng-content select=\"eui-page-column-header-body\"></ng-content>\n</div>\n<div\n class=\"eui-page-column__body\"\n cdkScrollable\n tabindex=\"0\"\n [class.eui-page-column--collapsed-with-icons]=\"isCollapsedWithIcons\"\n (scroll)=\"hasHeaderBodyShrinkable ? onBodyScoll($event) : null\">\n <ng-content select=\"eui-page-column-body\"></ng-content>\n</div>\n<div *ngIf=\"customFooterContent\" class=\"eui-page-column__footer\" [class.eui-page-column__footer--highlighted]=\"isHighlighted\">\n <ng-content select=\"eui-page-column-footer\"></ng-content>\n</div>\n" }]
111
- }], ctorParameters: () => [{ type: i1.EuiAppShellService }], propDecorators: { size: [{
93
+ }], ctorParameters: () => [{ type: undefined, decorators: [{
94
+ type: Host
95
+ }, {
96
+ type: Optional
97
+ }, {
98
+ type: Inject,
99
+ args: [forwardRef(() => EuiPageColumnsComponent)]
100
+ }] }, { type: i1.EuiAppShellService }], propDecorators: { cssClasses: [{
101
+ type: HostBinding,
102
+ args: ['class']
103
+ }], size: [{
112
104
  type: Input
113
105
  }], label: [{
114
106
  type: Input
115
107
  }], subLabel: [{
116
108
  type: Input
117
- }], isCollapsible: [{
109
+ }], autoCollapseParentColumnsContainerWidth: [{
118
110
  type: Input
111
+ }], isCollapsible: [{
112
+ type: Input,
113
+ args: [{ transform: booleanAttribute }]
119
114
  }], isCollapsed: [{
120
- type: Input
115
+ type: Input,
116
+ args: [{ transform: booleanAttribute }]
121
117
  }], isHighlighted: [{
122
- type: Input
118
+ type: Input,
119
+ args: [{ transform: booleanAttribute }]
123
120
  }], isCollapsedWithIcons: [{
124
- type: Input
121
+ type: Input,
122
+ args: [{ transform: booleanAttribute }]
125
123
  }], hasSidebarMenu: [{
126
- type: Input
124
+ type: Input,
125
+ args: [{ transform: booleanAttribute }]
127
126
  }], hasHeaderBodyShrinkable: [{
128
- type: Input
127
+ type: Input,
128
+ args: [{ transform: booleanAttribute }]
129
+ }], isParentColumnsObserverActive: [{
130
+ type: Input,
131
+ args: [{ transform: booleanAttribute }]
129
132
  }], collapse: [{
130
133
  type: Output
131
134
  }], headerCollapse: [{
132
135
  type: Output
133
- }], cssClasses: [{
134
- type: HostBinding,
135
- args: ['class']
136
136
  }], customHeaderBodyContent: [{
137
137
  type: ContentChild,
138
138
  args: [forwardRef(() => EuiPageColumnHeaderBodyContentDirective)]
@@ -201,4 +201,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.6", ngImpor
201
201
  type: Directive,
202
202
  args: [{ selector: 'eui-page-column-footer' }]
203
203
  }] });
204
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eui-page-column.component.js","sourceRoot":"","sources":["../../../../../eui-page/components/eui-page-column/eui-page-column.component.ts","../../../../../eui-page/components/eui-page-column/eui-page-column.component.html"],"names":[],"mappings":"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","sourcesContent":["import { coerceBooleanProperty, BooleanInput } from '@angular/cdk/coercion';\nimport {\n    Component,\n    HostBinding,\n    ViewEncapsulation,\n    Input,\n    Output,\n    OnInit,\n    Directive,\n    ContentChild,\n    forwardRef,\n    QueryList,\n    EventEmitter,\n    HostListener,\n} from '@angular/core';\nimport { BaseDirective } from '@eui/components/shared';\nimport { EuiAppShellService } from '@eui/core';\n\n@Component({\n    selector: 'eui-page-column',\n    templateUrl: './eui-page-column.component.html',\n    encapsulation: ViewEncapsulation.None,\n})\nexport class EuiPageColumnComponent extends BaseDirective implements OnInit {\n    @Input() size;\n    @Input() label;\n    @Input() subLabel;\n    @Input()\n    get isCollapsible(): boolean {\n        return this._isCollapsible;\n    }\n    set isCollapsible(value: BooleanInput) {\n        this._isCollapsible = coerceBooleanProperty(value);\n    }\n    @Input()\n    get isCollapsed(): boolean {\n        return this._isCollapsed;\n    }\n    set isCollapsed(value: BooleanInput) {\n        this._isCollapsed = coerceBooleanProperty(value);\n    }\n    @Input()\n    get isHighlighted(): boolean {\n        return this._isHighlighted;\n    }\n    set isHighlighted(value: BooleanInput) {\n        this._isHighlighted = coerceBooleanProperty(value);\n    }\n    @Input()\n    get isCollapsedWithIcons(): boolean {\n        return this._isCollapsedWithIcons;\n    }\n    set isCollapsedWithIcons(value: BooleanInput) {\n        this._isCollapsedWithIcons = coerceBooleanProperty(value);\n    }\n    @Input()\n    get hasSidebarMenu(): boolean {\n        return this._hasSidebarMenu;\n    }\n    set hasSidebarMenu(value: BooleanInput) {\n        this._hasSidebarMenu = coerceBooleanProperty(value);\n    }\n    @Input()\n    get hasHeaderBodyShrinkable(): boolean {\n        return this._hasHeaderBodyShrinkable;\n    }\n    set hasHeaderBodyShrinkable(value: BooleanInput) {\n        this._hasHeaderBodyShrinkable = coerceBooleanProperty(value);\n    }\n    @Output() collapse = new EventEmitter();\n    @Output() headerCollapse = new EventEmitter();\n    isActive = false;\n\n    isHeaderBodyShrinked = false;\n    @HostBinding('class')\n    get cssClasses(): string {\n        return [\n            super.getCssClasses('eui-page-column'),\n            this.size && !this.isCollapsed ? `eui-page-column--size-${this.size}` : '',\n            this.isCollapsed ? 'eui-page-column--collapsed' : '',\n            this.isCollapsedWithIcons ? 'eui-page-column__header--with-icons' : '',\n            this.isHighlighted ? 'eui-page-column--highlighted' : '',\n            this.isActive ? 'eui-page-column--active' : '',\n            this.hasSidebarMenu ? 'eui-page-column--has-sidebar-menu' : '',\n            this.isHeaderBodyShrinked ? 'eui-page-column__header--shrinked' : '',\n        ]\n            .join(' ')\n            .trim();\n    }\n\n    @ContentChild(forwardRef(() => EuiPageColumnHeaderBodyContentDirective))\n    customHeaderBodyContent: QueryList<EuiPageColumnHeaderBodyContentDirective>;\n\n    @ContentChild(forwardRef(() => EuiPageColumnHeaderLeftContentDirective))\n    customHeaderLeftContent: QueryList<EuiPageColumnHeaderLeftContentDirective>;\n\n    @ContentChild(forwardRef(() => EuiPageColumnHeaderRightContentDirective))\n    customHeaderRightContent: QueryList<EuiPageColumnHeaderRightContentDirective>;\n\n    @ContentChild(forwardRef(() => EuiPageColumnHeaderCollapsedContentDirective))\n    customHeaderCollapsedContent: QueryList<EuiPageColumnHeaderCollapsedContentDirective>;\n\n    @ContentChild(forwardRef(() => EuiPageColumnFooterContentDirective))\n    customFooterContent: QueryList<EuiPageColumnFooterContentDirective>;\n\n    currentOffset = 0;\n\n    previousOffset = 0;\n    treshHold = 50;\n    private _isCollapsible = false;\n    private _isCollapsed = false;\n    private _isHighlighted = false;\n    private _isCollapsedWithIcons = false; // contains ux-layout-sidebar-items\n    private _hasSidebarMenu = false; // contains eui-sidebar-menu\n    private _hasHeaderBodyShrinkable = false; // allow to track scroll event Up & Down\n\n    constructor(public asService: EuiAppShellService) {\n        super();\n    }\n\n    @HostListener('window:scroll', ['$event'])\n    onBodyScoll(event): void {\n        if (this.hasHeaderBodyShrinkable && event.target) {\n            this.currentOffset = event.target.scrollTop;\n            // Scroll DOWN\n            if (this.currentOffset > this.previousOffset && this.currentOffset > this.treshHold) {\n                // console.log('Scroll DOWN:', this.currentOffset);\n                this.isHeaderBodyShrinked = true;\n                this.headerCollapse.emit(true);\n            }\n            // Scroll UP\n            if (this.currentOffset <= this.previousOffset) {\n                // console.log('Scroll UP:', this.currentOffset);\n                if (this.currentOffset <= this.treshHold) {\n                    this.isHeaderBodyShrinked = false;\n                    this.headerCollapse.emit(false);\n                }\n            }\n            this.previousOffset = this.currentOffset;\n        }\n    }\n\n    ngOnInit(): void {\n        this.euiSizeS = false; // Bypass size default\n    }\n\n    public onToggle(): void {\n        this.isCollapsed = !this.isCollapsed;\n        this.collapse.emit(this.isCollapsed);\n    }\n}\n\n/* eslint-disable */\n@Directive({ selector: 'eui-page-column-header-body' })\nexport class EuiPageColumnHeaderBodyContentDirective { }\n@Directive({ selector: 'eui-page-column-header-left-content' })\nexport class EuiPageColumnHeaderLeftContentDirective { }\n@Directive({ selector: 'eui-page-column-header-right-content' })\nexport class EuiPageColumnHeaderRightContentDirective { }\n@Directive({ selector: 'eui-page-column-header-collapsed-content' })\nexport class EuiPageColumnHeaderCollapsedContentDirective { }\n@Directive({ selector: 'eui-page-column-body' })\nexport class EuiPageColumnBodyContentDirective { }\n@Directive({ selector: 'eui-page-column-footer' })\nexport class EuiPageColumnFooterContentDirective { }\n/* eslint-enable */\n","<div\n    *ngIf=\"label || subLabel || customHeaderLeftContent || customHeaderRightContent || isCollapsible\"\n    class=\"eui-page-column__header\"\n    [class.eui-page-column__header--with-icons]=\"isCollapsedWithIcons\">\n    <div *ngIf=\"!customHeaderLeftContent\" class=\"eui-page-column__header-left-content\">\n        <div *ngIf=\"label\" class=\"eui-page-column__header-left-content-label\">\n            <ng-content *ngIf=\"customHeaderCollapsedContent\" select=\"eui-page-column-header-collapsed-content\"></ng-content>\n            <ng-container *ngIf=\"!isCollapsedWithIcons\">\n                {{ label }}\n            </ng-container>\n        </div>\n        <div *ngIf=\"subLabel\" class=\"eui-page-column__header-left-content-sub-label\">\n            {{ subLabel }}\n        </div>\n    </div>\n    <div *ngIf=\"customHeaderLeftContent\" class=\"eui-page-column__header-left-content\">\n        <ng-content select=\"eui-page-column-header-left-content\"></ng-content>\n    </div>\n\n    <div class=\"eui-page-column__header-right-content\">\n        <span *ngIf=\"customHeaderRightContent\" class=\"eui-page-column__header-right-content-body\">\n            <ng-content select=\"eui-page-column-header-right-content\"></ng-content>\n        </span>\n        <button\n            *ngIf=\"isCollapsible\"\n            euiButton\n            euiBasicButton\n            euiSecondary\n            euiRounded\n            euiIconButton\n            euiSizeS\n            type=\"button\"\n            (click)=\"onToggle()\"\n            [attr.aria-label]=\"isCollapsed ? 'Expand' : 'Collapse'\"\n            class=\"eui-page-column__header-toggle\">\n            @if (isCollapsed) {\n                @if ((asService.state$ | async).breakpoints.isMobile) {\n                    <eui-icon-svg icon=\"eui-chevron-down\"></eui-icon-svg>\n                } @else {\n                    <eui-icon-svg icon=\"eui-chevron-forward\"></eui-icon-svg>\n                }\n            } @else {\n                @if ((asService.state$ | async).breakpoints.isMobile) {\n                    <eui-icon-svg icon=\"eui-chevron-up\"></eui-icon-svg>\n                } @else {\n                    <eui-icon-svg icon=\"eui-chevron-back\"></eui-icon-svg>\n                }\n            }\n        </button>\n    </div>\n</div>\n<!-- On new line to not interfere with expand/collapse & custom right content -->\n<div\n    *ngIf=\"customHeaderBodyContent\"\n    class=\"eui-page-column__header-left-content-body\"\n    [class.eui-page-column__header-left-content-body--shrinked]=\"isHeaderBodyShrinked\">\n    <ng-content select=\"eui-page-column-header-body\"></ng-content>\n</div>\n<div\n    class=\"eui-page-column__body\"\n    cdkScrollable\n    tabindex=\"0\"\n    [class.eui-page-column--collapsed-with-icons]=\"isCollapsedWithIcons\"\n    (scroll)=\"hasHeaderBodyShrinkable ? onBodyScoll($event) : null\">\n    <ng-content select=\"eui-page-column-body\"></ng-content>\n</div>\n<div *ngIf=\"customFooterContent\" class=\"eui-page-column__footer\" [class.eui-page-column__footer--highlighted]=\"isHighlighted\">\n    <ng-content select=\"eui-page-column-footer\"></ng-content>\n</div>\n"]}
204
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eui-page-column.component.js","sourceRoot":"","sources":["../../../../../eui-page/components/eui-page-column/eui-page-column.component.ts","../../../../../eui-page/components/eui-page-column/eui-page-column.component.html"],"names":[],"mappings":"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","sourcesContent":["import { coerceBooleanProperty, BooleanInput } from '@angular/cdk/coercion';\nimport {\n    Component,\n    HostBinding,\n    ViewEncapsulation,\n    Input,\n    Output,\n    OnInit,\n    Directive,\n    ContentChild,\n    forwardRef,\n    QueryList,\n    EventEmitter,\n    HostListener,\n    Host,\n    Optional,\n    Inject,\n    booleanAttribute,\n    OnDestroy,\n} from '@angular/core';\nimport { Subject, debounce, debounceTime, takeUntil } from 'rxjs';\nimport { BaseDirective } from '@eui/components/shared';\nimport { EuiAppShellService } from '@eui/core';\nimport { EuiPageColumnsComponent } from '../eui-page-columns/eui-page-columns.component';\n\n@Component({\n    selector: 'eui-page-column',\n    templateUrl: './eui-page-column.component.html',\n    encapsulation: ViewEncapsulation.None,\n})\nexport class EuiPageColumnComponent extends BaseDirective implements OnInit, OnDestroy {\n    @HostBinding('class')\n    get cssClasses(): string {\n        return [\n            super.getCssClasses('eui-page-column'),\n            this.size && !this.isCollapsed ? `eui-page-column--size-${this.size}` : '',\n            this.isCollapsed ? 'eui-page-column--collapsed' : '',\n            this.isCollapsedWithIcons ? 'eui-page-column__header--with-icons' : '',\n            this.isHighlighted ? 'eui-page-column--highlighted' : '',\n            this.isActive ? 'eui-page-column--active' : '',\n            this.hasSidebarMenu ? 'eui-page-column--has-sidebar-menu' : '',\n            this.isHeaderBodyShrinked ? 'eui-page-column__header--shrinked' : '',\n        ]\n            .join(' ')\n            .trim();\n    }\n\n    @Input() size;\n    @Input() label;\n    @Input() subLabel;\n    @Input() autoCollapseParentColumnsContainerWidth: number = null;\n\n    @Input({ transform: booleanAttribute }) isCollapsible = false;\n    @Input({ transform: booleanAttribute }) isCollapsed = false;\n    @Input({ transform: booleanAttribute }) isHighlighted = false;\n    @Input({ transform: booleanAttribute }) isCollapsedWithIcons = false;\n    @Input({ transform: booleanAttribute }) hasSidebarMenu = false;\n    @Input({ transform: booleanAttribute }) hasHeaderBodyShrinkable = false;\n    @Input({ transform: booleanAttribute }) isParentColumnsObserverActive = false;\n\n    @Output() collapse = new EventEmitter();\n    @Output() headerCollapse = new EventEmitter();\n    isActive = false;\n\n    isHeaderBodyShrinked = false;\n\n    @ContentChild(forwardRef(() => EuiPageColumnHeaderBodyContentDirective))\n    customHeaderBodyContent: QueryList<EuiPageColumnHeaderBodyContentDirective>;\n\n    @ContentChild(forwardRef(() => EuiPageColumnHeaderLeftContentDirective))\n    customHeaderLeftContent: QueryList<EuiPageColumnHeaderLeftContentDirective>;\n\n    @ContentChild(forwardRef(() => EuiPageColumnHeaderRightContentDirective))\n    customHeaderRightContent: QueryList<EuiPageColumnHeaderRightContentDirective>;\n\n    @ContentChild(forwardRef(() => EuiPageColumnHeaderCollapsedContentDirective))\n    customHeaderCollapsedContent: QueryList<EuiPageColumnHeaderCollapsedContentDirective>;\n\n    @ContentChild(forwardRef(() => EuiPageColumnFooterContentDirective))\n    customFooterContent: QueryList<EuiPageColumnFooterContentDirective>;\n\n    currentOffset = 0;\n\n    previousOffset = 0;\n    treshHold = 50;\n\n    private pageColumnsParent: EuiPageColumnsComponent;\n    private destroy$ = new Subject<boolean>();\n\n    constructor(\n        @Host() @Optional() @Inject(forwardRef(() => EuiPageColumnsComponent)) pageColumnsParentInjected,\n        public asService: EuiAppShellService,\n    ) {\n        super();\n        this.pageColumnsParent = pageColumnsParentInjected as EuiPageColumnsComponent;\n    }\n\n    @HostListener('window:scroll', ['$event'])\n    onBodyScoll(event): void {\n        if (this.hasHeaderBodyShrinkable && event.target) {\n            this.currentOffset = event.target.scrollTop;\n            // Scroll DOWN\n            if (this.currentOffset > this.previousOffset && this.currentOffset > this.treshHold) {\n                // console.log('Scroll DOWN:', this.currentOffset);\n                this.isHeaderBodyShrinked = true;\n                this.headerCollapse.emit(true);\n            }\n            // Scroll UP\n            if (this.currentOffset <= this.previousOffset) {\n                // console.log('Scroll UP:', this.currentOffset);\n                if (this.currentOffset <= this.treshHold) {\n                    this.isHeaderBodyShrinked = false;\n                    this.headerCollapse.emit(false);\n                }\n            }\n            this.previousOffset = this.currentOffset;\n        }\n    }\n\n    ngOnInit(): void {\n        this.euiSizeS = false; // Bypass size default\n        if (this.pageColumnsParent && this.isParentColumnsObserverActive && this.autoCollapseParentColumnsContainerWidth) {\n            this.pageColumnsParent.width.pipe(\n                debounceTime(100),\n                takeUntil(this.destroy$),\n            ).subscribe((parentWidth: number) => {\n                console.log(parentWidth);\n                if (parentWidth <= this.autoCollapseParentColumnsContainerWidth) {\n                    this.isCollapsed = true;\n                    this.collapse.emit(this.isCollapsed);\n                }\n            });\n        }\n    }\n\n    ngOnDestroy(): void {\n        this.destroy$.next(true);\n        this.destroy$.unsubscribe();\n    }\n\n    public onToggle(): void {\n        this.isCollapsed = !this.isCollapsed;\n        this.collapse.emit(this.isCollapsed);\n    }\n}\n\n/* eslint-disable */\n@Directive({ selector: 'eui-page-column-header-body' })\nexport class EuiPageColumnHeaderBodyContentDirective { }\n@Directive({ selector: 'eui-page-column-header-left-content' })\nexport class EuiPageColumnHeaderLeftContentDirective { }\n@Directive({ selector: 'eui-page-column-header-right-content' })\nexport class EuiPageColumnHeaderRightContentDirective { }\n@Directive({ selector: 'eui-page-column-header-collapsed-content' })\nexport class EuiPageColumnHeaderCollapsedContentDirective { }\n@Directive({ selector: 'eui-page-column-body' })\nexport class EuiPageColumnBodyContentDirective { }\n@Directive({ selector: 'eui-page-column-footer' })\nexport class EuiPageColumnFooterContentDirective { }\n/* eslint-enable */\n","<div\n    *ngIf=\"label || subLabel || customHeaderLeftContent || customHeaderRightContent || isCollapsible\"\n    class=\"eui-page-column__header\"\n    [class.eui-page-column__header--with-icons]=\"isCollapsedWithIcons\">\n    <div *ngIf=\"!customHeaderLeftContent\" class=\"eui-page-column__header-left-content\">\n        <div *ngIf=\"label\" class=\"eui-page-column__header-left-content-label\">\n            <ng-content *ngIf=\"customHeaderCollapsedContent\" select=\"eui-page-column-header-collapsed-content\"></ng-content>\n            <ng-container *ngIf=\"!isCollapsedWithIcons\">\n                {{ label }}\n            </ng-container>\n        </div>\n        <div *ngIf=\"subLabel\" class=\"eui-page-column__header-left-content-sub-label\">\n            {{ subLabel }}\n        </div>\n    </div>\n    <div *ngIf=\"customHeaderLeftContent\" class=\"eui-page-column__header-left-content\">\n        <ng-content select=\"eui-page-column-header-left-content\"></ng-content>\n    </div>\n\n    <div class=\"eui-page-column__header-right-content\">\n        <span *ngIf=\"customHeaderRightContent\" class=\"eui-page-column__header-right-content-body\">\n            <ng-content select=\"eui-page-column-header-right-content\"></ng-content>\n        </span>\n        <button\n            *ngIf=\"isCollapsible\"\n            euiButton\n            euiBasicButton\n            euiSecondary\n            euiRounded\n            euiIconButton\n            euiSizeS\n            type=\"button\"\n            (click)=\"onToggle()\"\n            [attr.aria-label]=\"isCollapsed ? 'Expand' : 'Collapse'\"\n            class=\"eui-page-column__header-toggle\">\n            @if (isCollapsed) {\n                @if ((asService.state$ | async).breakpoints.isMobile) {\n                    <eui-icon-svg icon=\"eui-chevron-down\"></eui-icon-svg>\n                } @else {\n                    <eui-icon-svg icon=\"eui-chevron-forward\"></eui-icon-svg>\n                }\n            } @else {\n                @if ((asService.state$ | async).breakpoints.isMobile) {\n                    <eui-icon-svg icon=\"eui-chevron-up\"></eui-icon-svg>\n                } @else {\n                    <eui-icon-svg icon=\"eui-chevron-back\"></eui-icon-svg>\n                }\n            }\n        </button>\n    </div>\n</div>\n<!-- On new line to not interfere with expand/collapse & custom right content -->\n<div\n    *ngIf=\"customHeaderBodyContent\"\n    class=\"eui-page-column__header-left-content-body\"\n    [class.eui-page-column__header-left-content-body--shrinked]=\"isHeaderBodyShrinked\">\n    <ng-content select=\"eui-page-column-header-body\"></ng-content>\n</div>\n<div\n    class=\"eui-page-column__body\"\n    cdkScrollable\n    tabindex=\"0\"\n    [class.eui-page-column--collapsed-with-icons]=\"isCollapsedWithIcons\"\n    (scroll)=\"hasHeaderBodyShrinkable ? onBodyScoll($event) : null\">\n    <ng-content select=\"eui-page-column-body\"></ng-content>\n</div>\n<div *ngIf=\"customFooterContent\" class=\"eui-page-column__footer\" [class.eui-page-column__footer--highlighted]=\"isHighlighted\">\n    <ng-content select=\"eui-page-column-footer\"></ng-content>\n</div>\n"]}
@@ -1,16 +1,31 @@
1
1
  import { Component, HostBinding, ViewEncapsulation } from '@angular/core';
2
+ import { Subject } from 'rxjs';
2
3
  import * as i0 from "@angular/core";
3
4
  export class EuiPageColumnsComponent {
4
- constructor() {
5
+ constructor(host, zone) {
6
+ this.host = host;
7
+ this.zone = zone;
5
8
  this.class = 'eui-page-columns';
9
+ this.width = new Subject;
6
10
  }
7
- /** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.6", ngImport: i0, type: EuiPageColumnsComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
11
+ ngOnInit() {
12
+ this.observer = new ResizeObserver(entries => {
13
+ this.zone.run(() => {
14
+ this.width.next(entries[0].contentRect.width);
15
+ });
16
+ });
17
+ this.observer.observe(this.host.nativeElement);
18
+ }
19
+ ngOnDestroy() {
20
+ this.observer.unobserve(this.host.nativeElement);
21
+ }
22
+ /** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.6", ngImport: i0, type: EuiPageColumnsComponent, deps: [{ token: i0.ElementRef }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component }); }
8
23
  /** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.6", type: EuiPageColumnsComponent, selector: "eui-page-columns", host: { properties: { "class": "this.class" } }, ngImport: i0, template: "<ng-content></ng-content>\n", encapsulation: i0.ViewEncapsulation.None }); }
9
24
  }
10
25
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.6", ngImport: i0, type: EuiPageColumnsComponent, decorators: [{
11
26
  type: Component,
12
27
  args: [{ selector: 'eui-page-columns', encapsulation: ViewEncapsulation.None, template: "<ng-content></ng-content>\n" }]
13
- }], propDecorators: { class: [{
28
+ }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.NgZone }], propDecorators: { class: [{
14
29
  type: HostBinding
15
30
  }] } });
16
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXVpLXBhZ2UtY29sdW1ucy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9ldWktcGFnZS9jb21wb25lbnRzL2V1aS1wYWdlLWNvbHVtbnMvZXVpLXBhZ2UtY29sdW1ucy5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9ldWktcGFnZS9jb21wb25lbnRzL2V1aS1wYWdlLWNvbHVtbnMvZXVpLXBhZ2UtY29sdW1ucy5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFdBQVcsRUFBRSxpQkFBaUIsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFPMUUsTUFBTSxPQUFPLHVCQUF1QjtJQUxwQztRQU1tQixVQUFLLEdBQUcsa0JBQWtCLENBQUM7S0FDN0M7aUlBRlksdUJBQXVCO3FIQUF2Qix1QkFBdUIseUdDUHBDLDZCQUNBOzsyRkRNYSx1QkFBdUI7a0JBTG5DLFNBQVM7K0JBQ0ksa0JBQWtCLGlCQUViLGlCQUFpQixDQUFDLElBQUk7OEJBR3RCLEtBQUs7c0JBQW5CLFdBQVciLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEhvc3RCaW5kaW5nLCBWaWV3RW5jYXBzdWxhdGlvbiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ2V1aS1wYWdlLWNvbHVtbnMnLFxuICAgIHRlbXBsYXRlVXJsOiAnLi9ldWktcGFnZS1jb2x1bW5zLmNvbXBvbmVudC5odG1sJyxcbiAgICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lLFxufSlcbmV4cG9ydCBjbGFzcyBFdWlQYWdlQ29sdW1uc0NvbXBvbmVudCB7XG4gICAgQEhvc3RCaW5kaW5nKCkgY2xhc3MgPSAnZXVpLXBhZ2UtY29sdW1ucyc7XG59XG4iLCI8bmctY29udGVudD48L25nLWNvbnRlbnQ+XG4iXX0=
31
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXVpLXBhZ2UtY29sdW1ucy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9ldWktcGFnZS9jb21wb25lbnRzL2V1aS1wYWdlLWNvbHVtbnMvZXVpLXBhZ2UtY29sdW1ucy5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9ldWktcGFnZS9jb21wb25lbnRzL2V1aS1wYWdlLWNvbHVtbnMvZXVpLXBhZ2UtY29sdW1ucy5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFjLFdBQVcsRUFBNkIsaUJBQWlCLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDakgsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLE1BQU0sQ0FBQzs7QUFVL0IsTUFBTSxPQUFPLHVCQUF1QjtJQU1oQyxZQUFvQixJQUFnQixFQUFVLElBQVk7UUFBdEMsU0FBSSxHQUFKLElBQUksQ0FBWTtRQUFVLFNBQUksR0FBSixJQUFJLENBQVE7UUFMM0MsVUFBSyxHQUFHLGtCQUFrQixDQUFDO1FBRW5DLFVBQUssR0FBRyxJQUFJLE9BQU8sQ0FBQztJQUdrQyxDQUFDO0lBRTlELFFBQVE7UUFDTixJQUFJLENBQUMsUUFBUSxHQUFHLElBQUksY0FBYyxDQUFDLE9BQU8sQ0FBQyxFQUFFO1lBQzNDLElBQUksQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLEdBQUcsRUFBRTtnQkFDakIsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxDQUFDLFdBQVcsQ0FBQyxLQUFLLENBQUMsQ0FBQztZQUNoRCxDQUFDLENBQUMsQ0FBQztRQUNMLENBQUMsQ0FBQyxDQUFDO1FBQ0gsSUFBSSxDQUFDLFFBQVEsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsQ0FBQztJQUNqRCxDQUFDO0lBRUQsV0FBVztRQUNULElBQUksQ0FBQyxRQUFRLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsYUFBYSxDQUFDLENBQUM7SUFDbkQsQ0FBQztpSUFuQlEsdUJBQXVCO3FIQUF2Qix1QkFBdUIseUdDWHBDLDZCQUNBOzsyRkRVYSx1QkFBdUI7a0JBTG5DLFNBQVM7K0JBQ0ksa0JBQWtCLGlCQUViLGlCQUFpQixDQUFDLElBQUk7b0dBR3RCLEtBQUs7c0JBQW5CLFdBQVciLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEVsZW1lbnRSZWYsIEhvc3RCaW5kaW5nLCBOZ1pvbmUsIE9uRGVzdHJveSwgT25Jbml0LCBWaWV3RW5jYXBzdWxhdGlvbiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgU3ViamVjdCB9IGZyb20gJ3J4anMnO1xuXG4vLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmVcbmRlY2xhcmUgdmFyIFJlc2l6ZU9ic2VydmVyO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ2V1aS1wYWdlLWNvbHVtbnMnLFxuICAgIHRlbXBsYXRlVXJsOiAnLi9ldWktcGFnZS1jb2x1bW5zLmNvbXBvbmVudC5odG1sJyxcbiAgICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lLFxufSlcbmV4cG9ydCBjbGFzcyBFdWlQYWdlQ29sdW1uc0NvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCwgT25EZXN0cm95IHtcbiAgICBASG9zdEJpbmRpbmcoKSBjbGFzcyA9ICdldWktcGFnZS1jb2x1bW5zJztcblxuICAgIHB1YmxpYyB3aWR0aCA9IG5ldyBTdWJqZWN0O1xuICAgIHByaXZhdGUgb2JzZXJ2ZXI7XG5cbiAgICBjb25zdHJ1Y3Rvcihwcml2YXRlIGhvc3Q6IEVsZW1lbnRSZWYsIHByaXZhdGUgem9uZTogTmdab25lKSB7fVxuXG4gICAgbmdPbkluaXQoKTp2b2lkIHtcbiAgICAgIHRoaXMub2JzZXJ2ZXIgPSBuZXcgUmVzaXplT2JzZXJ2ZXIoZW50cmllcyA9PiB7XG4gICAgICAgIHRoaXMuem9uZS5ydW4oKCkgPT4ge1xuICAgICAgICAgIHRoaXMud2lkdGgubmV4dChlbnRyaWVzWzBdLmNvbnRlbnRSZWN0LndpZHRoKTtcbiAgICAgICAgfSk7XG4gICAgICB9KTtcbiAgICAgIHRoaXMub2JzZXJ2ZXIub2JzZXJ2ZSh0aGlzLmhvc3QubmF0aXZlRWxlbWVudCk7XG4gICAgfVxuXG4gICAgbmdPbkRlc3Ryb3koKTp2b2lkIHtcbiAgICAgIHRoaXMub2JzZXJ2ZXIudW5vYnNlcnZlKHRoaXMuaG9zdC5uYXRpdmVFbGVtZW50KTtcbiAgICB9XG59XG4iLCI8bmctY29udGVudD48L25nLWNvbnRlbnQ+XG4iXX0=
@@ -1,5 +1,4 @@
1
- import { coerceBooleanProperty } from '@angular/cdk/coercion';
2
- import { Component, HostBinding, ChangeDetectionStrategy, Input, Output, EventEmitter, ViewEncapsulation } from '@angular/core';
1
+ import { Component, HostBinding, ChangeDetectionStrategy, Input, Output, EventEmitter, ViewEncapsulation, booleanAttribute } from '@angular/core';
3
2
  import * as i0 from "@angular/core";
4
3
  import * as i1 from "@eui/components/eui-menu";
5
4
  export class EuiSidebarMenuComponent {
@@ -8,46 +7,18 @@ export class EuiSidebarMenuComponent {
8
7
  // TODO: find the correct type or turn into a generic, https://www.typescriptlang.org/docs/handbook/2/generics.html
9
8
  // eslint-disable-next-line @typescript-eslint/no-explicit-any
10
9
  this.items = [];
10
+ this.hasCollapsedInitials = false;
11
+ this.isCollapsed = false;
12
+ this.hasFilter = false;
13
+ this.hasIcons = false;
14
+ this.hasTooltip = false;
15
+ this.expandAllItems = false;
16
+ this.hasLowercaseItems = false;
11
17
  this.style = '';
12
18
  // TODO: find the correct type or turn into a generic, https://www.typescriptlang.org/docs/handbook/2/generics.html
13
19
  // eslint-disable-next-line @typescript-eslint/no-explicit-any, @angular-eslint/no-output-on-prefix
14
20
  this.menuClick = new EventEmitter();
15
21
  this.itemClick = new EventEmitter();
16
- this._isCollapsed = false;
17
- this._hasFilter = false;
18
- this._hasIcons = false;
19
- this._hasTooltip = false;
20
- this._expandAllItems = false;
21
- }
22
- get isCollapsed() {
23
- return this._isCollapsed;
24
- }
25
- set isCollapsed(value) {
26
- this._isCollapsed = coerceBooleanProperty(value);
27
- }
28
- get hasFilter() {
29
- return this._hasFilter;
30
- }
31
- set hasFilter(value) {
32
- this._hasFilter = coerceBooleanProperty(value);
33
- }
34
- get hasIcons() {
35
- return this._hasIcons;
36
- }
37
- set hasIcons(value) {
38
- this._hasIcons = coerceBooleanProperty(value);
39
- }
40
- get hasTooltip() {
41
- return this._hasTooltip;
42
- }
43
- set hasTooltip(value) {
44
- this._hasTooltip = coerceBooleanProperty(value);
45
- }
46
- get expandAllItems() {
47
- return this._expandAllItems;
48
- }
49
- set expandAllItems(value) {
50
- this._expandAllItems = coerceBooleanProperty(value);
51
22
  }
52
23
  onMenuItemClicked(item) {
53
24
  this.itemClick.emit(item);
@@ -63,26 +34,37 @@ export class EuiSidebarMenuComponent {
63
34
  this.isCollapsed = event;
64
35
  }
65
36
  /** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.6", ngImport: i0, type: EuiSidebarMenuComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
66
- /** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.6", type: EuiSidebarMenuComponent, selector: "eui-sidebar-menu", inputs: { items: "items", isCollapsed: "isCollapsed", hasFilter: "hasFilter", hasIcons: "hasIcons", hasTooltip: "hasTooltip", expandAllItems: "expandAllItems", style: "style", fragmentId: "fragmentId", searchFilterLabel: "searchFilterLabel", externalTarget: "externalTarget" }, outputs: { menuClick: "menuClick", itemClick: "itemClick" }, host: { properties: { "class": "this.string" } }, ngImport: i0, template: "<div class=\"eui-sidebar-menu__container\" [class.eui-sidebar-menu__container--collapsed]=\"isCollapsed\" [style]=\"style\">\n <div class=\"eui-sidebar-menu__content\">\n <eui-menu\n [items]=\"items\"\n [hasFilter]=\"hasFilter\"\n [hasIcons]=\"hasIcons\"\n [hasTooltip]=\"hasTooltip\"\n [isCollapsed]=\"isCollapsed\"\n [expandAllItems]=\"expandAllItems\"\n [fragmentId]=\"fragmentId\"\n [searchFilterLabel]=\"searchFilterLabel\"\n (isClick)=\"onMenuClicked($event)\"\n (itemClick)=\"onMenuItemClicked($event)\">\n </eui-menu>\n </div>\n</div>\n", styles: [".eui-sidebar-menu{display:flex;height:100%;width:100%}.eui-sidebar-menu__container{background-color:var(--eui-base-color-grey-2);height:100%;position:relative;transition:top .1s ease,width .1s ease-in,margin-left .1s ease-in-out;width:100%}.eui-sidebar-menu__container--collapsed{top:var(--eui-spacing);width:var(--eui-app-sidebar-width-close-active)}.eui-sidebar-menu__content{border-right:1px solid var(--eui-base-color-grey-5);box-shadow:0 8px 10px #b7c0ce33;display:flex;flex-direction:column;height:100%;margin-bottom:var(--eui-base-spacing-xs);overflow-x:hidden;overflow-y:auto;position:relative}.eui-sidebar-menu__content::-webkit-scrollbar{display:inherit;height:6px;width:6px;background-color:var(--eui-base-color-grey-5)}.eui-sidebar-menu__content::-webkit-scrollbar-thumb{background-color:var(--eui-base-color-grey-20);border-radius:5rem}.eui-sidebar-menu__content::-webkit-scrollbar-thumb:hover{background-color:var(--eui-base-color-grey-50)}.eui-sidebar-menu__content::-webkit-scrollbar-track{background-color:var(--eui-base-color-grey-5);border-radius:0}.eui-page-column__body .eui-sidebar-menu__content{box-shadow:inherit}\n"], dependencies: [{ kind: "component", type: i1.EuiMenuComponent, selector: "eui-menu", inputs: ["items", "searchFilterLabel", "externalLinkLabel", "fragmentId", "isCollapsed", "hasFilter", "hasIcons", "hasTooltip", "expandAllItems", "isFlat", "hasScrollToItem"], outputs: ["isClick", "itemClick"] }], changeDetection: i0.ChangeDetectionStrategy.Default, encapsulation: i0.ViewEncapsulation.None }); }
37
+ /** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "16.1.0", version: "17.0.6", type: EuiSidebarMenuComponent, selector: "eui-sidebar-menu", inputs: { items: "items", hasCollapsedInitials: ["hasCollapsedInitials", "hasCollapsedInitials", booleanAttribute], isCollapsed: ["isCollapsed", "isCollapsed", booleanAttribute], hasFilter: ["hasFilter", "hasFilter", booleanAttribute], hasIcons: ["hasIcons", "hasIcons", booleanAttribute], hasTooltip: ["hasTooltip", "hasTooltip", booleanAttribute], expandAllItems: ["expandAllItems", "expandAllItems", booleanAttribute], hasLowercaseItems: ["hasLowercaseItems", "hasLowercaseItems", booleanAttribute], style: "style", fragmentId: "fragmentId", searchFilterLabel: "searchFilterLabel", externalTarget: "externalTarget" }, outputs: { menuClick: "menuClick", itemClick: "itemClick" }, host: { properties: { "class": "this.string" } }, ngImport: i0, template: "<div class=\"eui-sidebar-menu__container\" [class.eui-sidebar-menu__container--collapsed]=\"isCollapsed\" [style]=\"style\">\n <div class=\"eui-sidebar-menu__content\">\n <eui-menu\n [items]=\"items\"\n [hasFilter]=\"hasFilter\"\n [hasIcons]=\"hasIcons\"\n [hasTooltip]=\"hasTooltip\"\n [isCollapsed]=\"isCollapsed\"\n [hasCollapsedInitials]=\"hasCollapsedInitials\"\n [hasLowercaseItems]=\"hasLowercaseItems\"\n [expandAllItems]=\"expandAllItems\"\n [fragmentId]=\"fragmentId\"\n [searchFilterLabel]=\"searchFilterLabel\"\n (isClick)=\"onMenuClicked($event)\"\n (itemClick)=\"onMenuItemClicked($event)\">\n </eui-menu>\n </div>\n</div>\n", styles: [".eui-sidebar-menu{display:flex;height:100%;width:100%}.eui-sidebar-menu__container{background-color:var(--eui-base-color-grey-2);height:100%;position:relative;transition:top .1s ease,width .1s ease-in,margin-left .1s ease-in-out;width:100%}.eui-sidebar-menu__container--collapsed{top:var(--eui-spacing);width:var(--eui-app-sidebar-width-close-active)}.eui-sidebar-menu__content{border-right:1px solid var(--eui-base-color-grey-5);box-shadow:0 8px 10px #b7c0ce33;display:flex;flex-direction:column;height:100%;margin-bottom:var(--eui-base-spacing-xs);overflow-x:hidden;overflow-y:auto;position:relative}.eui-sidebar-menu__content::-webkit-scrollbar{display:inherit;height:6px;width:6px;background-color:var(--eui-base-color-grey-5)}.eui-sidebar-menu__content::-webkit-scrollbar-thumb{background-color:var(--eui-base-color-grey-20);border-radius:5rem}.eui-sidebar-menu__content::-webkit-scrollbar-thumb:hover{background-color:var(--eui-base-color-grey-50)}.eui-sidebar-menu__content::-webkit-scrollbar-track{background-color:var(--eui-base-color-grey-5);border-radius:0}.eui-page-column__body .eui-sidebar-menu__content{box-shadow:inherit}\n"], dependencies: [{ kind: "component", type: i1.EuiMenuComponent, selector: "eui-menu", inputs: ["items", "searchFilterLabel", "externalLinkLabel", "fragmentId", "isCollapsed", "hasCollapsedInitials", "hasFilter", "hasIcons", "hasTooltip", "expandAllItems", "isFlat", "hasScrollToItem", "hasLowercaseItems"], outputs: ["isClick", "itemClick"] }], changeDetection: i0.ChangeDetectionStrategy.Default, encapsulation: i0.ViewEncapsulation.None }); }
67
38
  }
68
39
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.6", ngImport: i0, type: EuiSidebarMenuComponent, decorators: [{
69
40
  type: Component,
70
- args: [{ selector: 'eui-sidebar-menu', changeDetection: ChangeDetectionStrategy.Default, encapsulation: ViewEncapsulation.None, template: "<div class=\"eui-sidebar-menu__container\" [class.eui-sidebar-menu__container--collapsed]=\"isCollapsed\" [style]=\"style\">\n <div class=\"eui-sidebar-menu__content\">\n <eui-menu\n [items]=\"items\"\n [hasFilter]=\"hasFilter\"\n [hasIcons]=\"hasIcons\"\n [hasTooltip]=\"hasTooltip\"\n [isCollapsed]=\"isCollapsed\"\n [expandAllItems]=\"expandAllItems\"\n [fragmentId]=\"fragmentId\"\n [searchFilterLabel]=\"searchFilterLabel\"\n (isClick)=\"onMenuClicked($event)\"\n (itemClick)=\"onMenuItemClicked($event)\">\n </eui-menu>\n </div>\n</div>\n", styles: [".eui-sidebar-menu{display:flex;height:100%;width:100%}.eui-sidebar-menu__container{background-color:var(--eui-base-color-grey-2);height:100%;position:relative;transition:top .1s ease,width .1s ease-in,margin-left .1s ease-in-out;width:100%}.eui-sidebar-menu__container--collapsed{top:var(--eui-spacing);width:var(--eui-app-sidebar-width-close-active)}.eui-sidebar-menu__content{border-right:1px solid var(--eui-base-color-grey-5);box-shadow:0 8px 10px #b7c0ce33;display:flex;flex-direction:column;height:100%;margin-bottom:var(--eui-base-spacing-xs);overflow-x:hidden;overflow-y:auto;position:relative}.eui-sidebar-menu__content::-webkit-scrollbar{display:inherit;height:6px;width:6px;background-color:var(--eui-base-color-grey-5)}.eui-sidebar-menu__content::-webkit-scrollbar-thumb{background-color:var(--eui-base-color-grey-20);border-radius:5rem}.eui-sidebar-menu__content::-webkit-scrollbar-thumb:hover{background-color:var(--eui-base-color-grey-50)}.eui-sidebar-menu__content::-webkit-scrollbar-track{background-color:var(--eui-base-color-grey-5);border-radius:0}.eui-page-column__body .eui-sidebar-menu__content{box-shadow:inherit}\n"] }]
41
+ args: [{ selector: 'eui-sidebar-menu', changeDetection: ChangeDetectionStrategy.Default, encapsulation: ViewEncapsulation.None, template: "<div class=\"eui-sidebar-menu__container\" [class.eui-sidebar-menu__container--collapsed]=\"isCollapsed\" [style]=\"style\">\n <div class=\"eui-sidebar-menu__content\">\n <eui-menu\n [items]=\"items\"\n [hasFilter]=\"hasFilter\"\n [hasIcons]=\"hasIcons\"\n [hasTooltip]=\"hasTooltip\"\n [isCollapsed]=\"isCollapsed\"\n [hasCollapsedInitials]=\"hasCollapsedInitials\"\n [hasLowercaseItems]=\"hasLowercaseItems\"\n [expandAllItems]=\"expandAllItems\"\n [fragmentId]=\"fragmentId\"\n [searchFilterLabel]=\"searchFilterLabel\"\n (isClick)=\"onMenuClicked($event)\"\n (itemClick)=\"onMenuItemClicked($event)\">\n </eui-menu>\n </div>\n</div>\n", styles: [".eui-sidebar-menu{display:flex;height:100%;width:100%}.eui-sidebar-menu__container{background-color:var(--eui-base-color-grey-2);height:100%;position:relative;transition:top .1s ease,width .1s ease-in,margin-left .1s ease-in-out;width:100%}.eui-sidebar-menu__container--collapsed{top:var(--eui-spacing);width:var(--eui-app-sidebar-width-close-active)}.eui-sidebar-menu__content{border-right:1px solid var(--eui-base-color-grey-5);box-shadow:0 8px 10px #b7c0ce33;display:flex;flex-direction:column;height:100%;margin-bottom:var(--eui-base-spacing-xs);overflow-x:hidden;overflow-y:auto;position:relative}.eui-sidebar-menu__content::-webkit-scrollbar{display:inherit;height:6px;width:6px;background-color:var(--eui-base-color-grey-5)}.eui-sidebar-menu__content::-webkit-scrollbar-thumb{background-color:var(--eui-base-color-grey-20);border-radius:5rem}.eui-sidebar-menu__content::-webkit-scrollbar-thumb:hover{background-color:var(--eui-base-color-grey-50)}.eui-sidebar-menu__content::-webkit-scrollbar-track{background-color:var(--eui-base-color-grey-5);border-radius:0}.eui-page-column__body .eui-sidebar-menu__content{box-shadow:inherit}\n"] }]
71
42
  }], propDecorators: { string: [{
72
43
  type: HostBinding,
73
44
  args: ['class']
74
45
  }], items: [{
75
46
  type: Input
47
+ }], hasCollapsedInitials: [{
48
+ type: Input,
49
+ args: [{ transform: booleanAttribute }]
76
50
  }], isCollapsed: [{
77
- type: Input
51
+ type: Input,
52
+ args: [{ transform: booleanAttribute }]
78
53
  }], hasFilter: [{
79
- type: Input
54
+ type: Input,
55
+ args: [{ transform: booleanAttribute }]
80
56
  }], hasIcons: [{
81
- type: Input
57
+ type: Input,
58
+ args: [{ transform: booleanAttribute }]
82
59
  }], hasTooltip: [{
83
- type: Input
60
+ type: Input,
61
+ args: [{ transform: booleanAttribute }]
84
62
  }], expandAllItems: [{
85
- type: Input
63
+ type: Input,
64
+ args: [{ transform: booleanAttribute }]
65
+ }], hasLowercaseItems: [{
66
+ type: Input,
67
+ args: [{ transform: booleanAttribute }]
86
68
  }], style: [{
87
69
  type: Input
88
70
  }], fragmentId: [{
@@ -96,4 +78,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.6", ngImpor
96
78
  }], itemClick: [{
97
79
  type: Output
98
80
  }] } });
99
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eui-sidebar-menu.component.js","sourceRoot":"","sources":["../../../eui-sidebar-menu/eui-sidebar-menu.component.ts","../../../eui-sidebar-menu/eui-sidebar-menu.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,qBAAqB,EAAgB,MAAM,uBAAuB,CAAC;AAC5E,OAAO,EAAE,SAAS,EAAE,WAAW,EAAE,uBAAuB,EAAE,KAAK,EAAE,MAAM,EAAE,YAAY,EAAE,iBAAiB,EAAE,MAAM,eAAe,CAAC;;;AAUhI,MAAM,OAAO,uBAAuB;IAPpC;QAQ0B,WAAM,GAAG,kBAAkB,CAAC;QAElD,mHAAmH;QACnH,8DAA8D;QACrD,UAAK,GAAU,EAAE,CAAC;QAoClB,UAAK,GAAG,EAAE,CAAC;QAIpB,mHAAmH;QACnH,mGAAmG;QACzF,cAAS,GAAsB,IAAI,YAAY,EAAE,CAAC;QAClD,cAAS,GAA8B,IAAI,YAAY,EAAE,CAAC;QAC5D,iBAAY,GAAG,KAAK,CAAC;QACrB,eAAU,GAAG,KAAK,CAAC;QACnB,cAAS,GAAG,KAAK,CAAC;QAClB,gBAAW,GAAG,KAAK,CAAC;QACpB,oBAAe,GAAG,KAAK,CAAC;KAiBnC;IAhEG,IACI,WAAW;QACX,OAAO,IAAI,CAAC,YAAY,CAAC;IAC7B,CAAC;IACD,IAAI,WAAW,CAAC,KAAmB;QAC/B,IAAI,CAAC,YAAY,GAAG,qBAAqB,CAAC,KAAK,CAAC,CAAC;IACrD,CAAC;IACD,IACI,SAAS;QACT,OAAO,IAAI,CAAC,UAAU,CAAC;IAC3B,CAAC;IACD,IAAI,SAAS,CAAC,KAAmB;QAC7B,IAAI,CAAC,UAAU,GAAG,qBAAqB,CAAC,KAAK,CAAC,CAAC;IACnD,CAAC;IACD,IACI,QAAQ;QACR,OAAO,IAAI,CAAC,SAAS,CAAC;IAC1B,CAAC;IACD,IAAI,QAAQ,CAAC,KAAmB;QAC5B,IAAI,CAAC,SAAS,GAAG,qBAAqB,CAAC,KAAK,CAAC,CAAC;IAClD,CAAC;IACD,IACI,UAAU;QACV,OAAO,IAAI,CAAC,WAAW,CAAC;IAC5B,CAAC;IACD,IAAI,UAAU,CAAC,KAAmB;QAC9B,IAAI,CAAC,WAAW,GAAG,qBAAqB,CAAC,KAAK,CAAC,CAAC;IACpD,CAAC;IACD,IACI,cAAc;QACd,OAAO,IAAI,CAAC,eAAe,CAAC;IAChC,CAAC;IACD,IAAI,cAAc,CAAC,KAAmB;QAClC,IAAI,CAAC,eAAe,GAAG,qBAAqB,CAAC,KAAK,CAAC,CAAC;IACxD,CAAC;IAeM,iBAAiB,CAAC,IAAiB;QACtC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC9B,CAAC;IAED,mHAAmH;IACnH,8DAA8D;IACvD,aAAa,CAAC,KAAU;QAC3B,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC/B,CAAC;IAED,mHAAmH;IACnH,8DAA8D;IACvD,eAAe,CAAC,KAAU;QAC7B,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;IAC7B,CAAC;iIArEQ,uBAAuB;qHAAvB,uBAAuB,6bCXpC,oqBAgBA;;2FDLa,uBAAuB;kBAPnC,SAAS;+BACI,kBAAkB,mBAGX,uBAAuB,CAAC,OAAO,iBACjC,iBAAiB,CAAC,IAAI;8BAGf,MAAM;sBAA3B,WAAW;uBAAC,OAAO;gBAIX,KAAK;sBAAb,KAAK;gBAEF,WAAW;sBADd,KAAK;gBAQF,SAAS;sBADZ,KAAK;gBAQF,QAAQ;sBADX,KAAK;gBAQF,UAAU;sBADb,KAAK;gBAQF,cAAc;sBADjB,KAAK;gBAOG,KAAK;sBAAb,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,iBAAiB;sBAAzB,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBAGI,SAAS;sBAAlB,MAAM;gBACG,SAAS;sBAAlB,MAAM","sourcesContent":["import { coerceBooleanProperty, BooleanInput } from '@angular/cdk/coercion';\nimport { Component, HostBinding, ChangeDetectionStrategy, Input, Output, EventEmitter, ViewEncapsulation } from '@angular/core';\nimport { EuiMenuItem } from '@eui/components/eui-menu';\n\n@Component({\n    selector: 'eui-sidebar-menu',\n    templateUrl: './eui-sidebar-menu.component.html',\n    styleUrls: ['./_styles/_index.scss'],\n    changeDetection: ChangeDetectionStrategy.Default,\n    encapsulation: ViewEncapsulation.None,\n})\nexport class EuiSidebarMenuComponent {\n    @HostBinding('class') string = 'eui-sidebar-menu';\n\n    // TODO: find the correct type or turn into a generic, https://www.typescriptlang.org/docs/handbook/2/generics.html\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    @Input() items: any[] = [];\n    @Input()\n    get isCollapsed(): boolean {\n        return this._isCollapsed;\n    }\n    set isCollapsed(value: BooleanInput) {\n        this._isCollapsed = coerceBooleanProperty(value);\n    }\n    @Input()\n    get hasFilter(): boolean {\n        return this._hasFilter;\n    }\n    set hasFilter(value: BooleanInput) {\n        this._hasFilter = coerceBooleanProperty(value);\n    }\n    @Input()\n    get hasIcons(): boolean {\n        return this._hasIcons;\n    }\n    set hasIcons(value: BooleanInput) {\n        this._hasIcons = coerceBooleanProperty(value);\n    }\n    @Input()\n    get hasTooltip(): boolean {\n        return this._hasTooltip;\n    }\n    set hasTooltip(value: BooleanInput) {\n        this._hasTooltip = coerceBooleanProperty(value);\n    }\n    @Input()\n    get expandAllItems(): boolean {\n        return this._expandAllItems;\n    }\n    set expandAllItems(value: BooleanInput) {\n        this._expandAllItems = coerceBooleanProperty(value);\n    }\n    @Input() style = '';\n    @Input() fragmentId: string; // Anchor to navigate to (see eui-menu)\n    @Input() searchFilterLabel: string;\n    @Input() externalTarget: string;\n    // TODO: find the correct type or turn into a generic, https://www.typescriptlang.org/docs/handbook/2/generics.html\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any, @angular-eslint/no-output-on-prefix\n    @Output() menuClick: EventEmitter<any> = new EventEmitter();\n    @Output() itemClick: EventEmitter<EuiMenuItem> = new EventEmitter();\n    private _isCollapsed = false;\n    private _hasFilter = false;\n    private _hasIcons = false;\n    private _hasTooltip = false;\n    private _expandAllItems = false;\n\n    public onMenuItemClicked(item: EuiMenuItem): void {\n        this.itemClick.emit(item);\n    }\n\n    // TODO: find the correct type or turn into a generic, https://www.typescriptlang.org/docs/handbook/2/generics.html\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    public onMenuClicked(event: any): void {\n        this.menuClick.emit(event);\n    }\n\n    // TODO: find the correct type or turn into a generic, https://www.typescriptlang.org/docs/handbook/2/generics.html\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    public onMenuCollapsed(event: any): void {\n        this.isCollapsed = event;\n    }\n}\n","<div class=\"eui-sidebar-menu__container\" [class.eui-sidebar-menu__container--collapsed]=\"isCollapsed\" [style]=\"style\">\n    <div class=\"eui-sidebar-menu__content\">\n        <eui-menu\n            [items]=\"items\"\n            [hasFilter]=\"hasFilter\"\n            [hasIcons]=\"hasIcons\"\n            [hasTooltip]=\"hasTooltip\"\n            [isCollapsed]=\"isCollapsed\"\n            [expandAllItems]=\"expandAllItems\"\n            [fragmentId]=\"fragmentId\"\n            [searchFilterLabel]=\"searchFilterLabel\"\n            (isClick)=\"onMenuClicked($event)\"\n            (itemClick)=\"onMenuItemClicked($event)\">\n        </eui-menu>\n    </div>\n</div>\n"]}
81
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXVpLXNpZGViYXItbWVudS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9ldWktc2lkZWJhci1tZW51L2V1aS1zaWRlYmFyLW1lbnUuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vZXVpLXNpZGViYXItbWVudS9ldWktc2lkZWJhci1tZW51LmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsV0FBVyxFQUFFLHVCQUF1QixFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsWUFBWSxFQUFFLGlCQUFpQixFQUFFLGdCQUFnQixFQUFFLE1BQU0sZUFBZSxDQUFDOzs7QUFVbEosTUFBTSxPQUFPLHVCQUF1QjtJQVBwQztRQVEwQixXQUFNLEdBQUcsa0JBQWtCLENBQUM7UUFFbEQsbUhBQW1IO1FBQ25ILDhEQUE4RDtRQUNyRCxVQUFLLEdBQVUsRUFBRSxDQUFDO1FBRWEseUJBQW9CLEdBQUcsS0FBSyxDQUFDO1FBQzdCLGdCQUFXLEdBQUcsS0FBSyxDQUFDO1FBQ3BCLGNBQVMsR0FBRyxLQUFLLENBQUM7UUFDbEIsYUFBUSxHQUFHLEtBQUssQ0FBQztRQUNqQixlQUFVLEdBQUcsS0FBSyxDQUFDO1FBQ25CLG1CQUFjLEdBQUcsS0FBSyxDQUFDO1FBQ3ZCLHNCQUFpQixHQUFHLEtBQUssQ0FBQztRQUV6RCxVQUFLLEdBQUcsRUFBRSxDQUFDO1FBSXBCLG1IQUFtSDtRQUNuSCxtR0FBbUc7UUFDekYsY0FBUyxHQUFzQixJQUFJLFlBQVksRUFBRSxDQUFDO1FBQ2xELGNBQVMsR0FBOEIsSUFBSSxZQUFZLEVBQUUsQ0FBQztLQWlCdkU7SUFmVSxpQkFBaUIsQ0FBQyxJQUFpQjtRQUN0QyxJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUM5QixDQUFDO0lBRUQsbUhBQW1IO0lBQ25ILDhEQUE4RDtJQUN2RCxhQUFhLENBQUMsS0FBVTtRQUMzQixJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUMvQixDQUFDO0lBRUQsbUhBQW1IO0lBQ25ILDhEQUE4RDtJQUN2RCxlQUFlLENBQUMsS0FBVTtRQUM3QixJQUFJLENBQUMsV0FBVyxHQUFHLEtBQUssQ0FBQztJQUM3QixDQUFDO2lJQXRDUSx1QkFBdUI7cUhBQXZCLHVCQUF1QixpSUFPWixnQkFBZ0IsK0NBQ2hCLGdCQUFnQix5Q0FDaEIsZ0JBQWdCLHNDQUNoQixnQkFBZ0IsNENBQ2hCLGdCQUFnQix3REFDaEIsZ0JBQWdCLGlFQUNoQixnQkFBZ0IsZ1FDdkJ4Qyx3eEJBa0JBOzsyRkRSYSx1QkFBdUI7a0JBUG5DLFNBQVM7K0JBQ0ksa0JBQWtCLG1CQUdYLHVCQUF1QixDQUFDLE9BQU8saUJBQ2pDLGlCQUFpQixDQUFDLElBQUk7OEJBR2YsTUFBTTtzQkFBM0IsV0FBVzt1QkFBQyxPQUFPO2dCQUlYLEtBQUs7c0JBQWIsS0FBSztnQkFFa0Msb0JBQW9CO3NCQUEzRCxLQUFLO3VCQUFDLEVBQUUsU0FBUyxFQUFFLGdCQUFnQixFQUFFO2dCQUNFLFdBQVc7c0JBQWxELEtBQUs7dUJBQUMsRUFBRSxTQUFTLEVBQUUsZ0JBQWdCLEVBQUU7Z0JBQ0UsU0FBUztzQkFBaEQsS0FBSzt1QkFBQyxFQUFFLFNBQVMsRUFBRSxnQkFBZ0IsRUFBRTtnQkFDRSxRQUFRO3NCQUEvQyxLQUFLO3VCQUFDLEVBQUUsU0FBUyxFQUFFLGdCQUFnQixFQUFFO2dCQUNFLFVBQVU7c0JBQWpELEtBQUs7dUJBQUMsRUFBRSxTQUFTLEVBQUUsZ0JBQWdCLEVBQUU7Z0JBQ0UsY0FBYztzQkFBckQsS0FBSzt1QkFBQyxFQUFFLFNBQVMsRUFBRSxnQkFBZ0IsRUFBRTtnQkFDRSxpQkFBaUI7c0JBQXhELEtBQUs7dUJBQUMsRUFBRSxTQUFTLEVBQUUsZ0JBQWdCLEVBQUU7Z0JBRTdCLEtBQUs7c0JBQWIsS0FBSztnQkFDRyxVQUFVO3NCQUFsQixLQUFLO2dCQUNHLGlCQUFpQjtzQkFBekIsS0FBSztnQkFDRyxjQUFjO3NCQUF0QixLQUFLO2dCQUdJLFNBQVM7c0JBQWxCLE1BQU07Z0JBQ0csU0FBUztzQkFBbEIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSG9zdEJpbmRpbmcsIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBJbnB1dCwgT3V0cHV0LCBFdmVudEVtaXR0ZXIsIFZpZXdFbmNhcHN1bGF0aW9uLCBib29sZWFuQXR0cmlidXRlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBFdWlNZW51SXRlbSB9IGZyb20gJ0BldWkvY29tcG9uZW50cy9ldWktbWVudSc7XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAnZXVpLXNpZGViYXItbWVudScsXG4gICAgdGVtcGxhdGVVcmw6ICcuL2V1aS1zaWRlYmFyLW1lbnUuY29tcG9uZW50Lmh0bWwnLFxuICAgIHN0eWxlVXJsczogWycuL19zdHlsZXMvX2luZGV4LnNjc3MnXSxcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LkRlZmF1bHQsXG4gICAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZSxcbn0pXG5leHBvcnQgY2xhc3MgRXVpU2lkZWJhck1lbnVDb21wb25lbnQge1xuICAgIEBIb3N0QmluZGluZygnY2xhc3MnKSBzdHJpbmcgPSAnZXVpLXNpZGViYXItbWVudSc7XG5cbiAgICAvLyBUT0RPOiBmaW5kIHRoZSBjb3JyZWN0IHR5cGUgb3IgdHVybiBpbnRvIGEgZ2VuZXJpYywgaHR0cHM6Ly93d3cudHlwZXNjcmlwdGxhbmcub3JnL2RvY3MvaGFuZGJvb2svMi9nZW5lcmljcy5odG1sXG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uby1leHBsaWNpdC1hbnlcbiAgICBASW5wdXQoKSBpdGVtczogYW55W10gPSBbXTtcblxuICAgIEBJbnB1dCh7IHRyYW5zZm9ybTogYm9vbGVhbkF0dHJpYnV0ZSB9KSBoYXNDb2xsYXBzZWRJbml0aWFscyA9IGZhbHNlO1xuICAgIEBJbnB1dCh7IHRyYW5zZm9ybTogYm9vbGVhbkF0dHJpYnV0ZSB9KSBpc0NvbGxhcHNlZCA9IGZhbHNlO1xuICAgIEBJbnB1dCh7IHRyYW5zZm9ybTogYm9vbGVhbkF0dHJpYnV0ZSB9KSBoYXNGaWx0ZXIgPSBmYWxzZTtcbiAgICBASW5wdXQoeyB0cmFuc2Zvcm06IGJvb2xlYW5BdHRyaWJ1dGUgfSkgaGFzSWNvbnMgPSBmYWxzZTtcbiAgICBASW5wdXQoeyB0cmFuc2Zvcm06IGJvb2xlYW5BdHRyaWJ1dGUgfSkgaGFzVG9vbHRpcCA9IGZhbHNlO1xuICAgIEBJbnB1dCh7IHRyYW5zZm9ybTogYm9vbGVhbkF0dHJpYnV0ZSB9KSBleHBhbmRBbGxJdGVtcyA9IGZhbHNlO1xuICAgIEBJbnB1dCh7IHRyYW5zZm9ybTogYm9vbGVhbkF0dHJpYnV0ZSB9KSBoYXNMb3dlcmNhc2VJdGVtcyA9IGZhbHNlO1xuXG4gICAgQElucHV0KCkgc3R5bGUgPSAnJztcbiAgICBASW5wdXQoKSBmcmFnbWVudElkOiBzdHJpbmc7IC8vIEFuY2hvciB0byBuYXZpZ2F0ZSB0byAoc2VlIGV1aS1tZW51KVxuICAgIEBJbnB1dCgpIHNlYXJjaEZpbHRlckxhYmVsOiBzdHJpbmc7XG4gICAgQElucHV0KCkgZXh0ZXJuYWxUYXJnZXQ6IHN0cmluZztcbiAgICAvLyBUT0RPOiBmaW5kIHRoZSBjb3JyZWN0IHR5cGUgb3IgdHVybiBpbnRvIGEgZ2VuZXJpYywgaHR0cHM6Ly93d3cudHlwZXNjcmlwdGxhbmcub3JnL2RvY3MvaGFuZGJvb2svMi9nZW5lcmljcy5odG1sXG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uby1leHBsaWNpdC1hbnksIEBhbmd1bGFyLWVzbGludC9uby1vdXRwdXQtb24tcHJlZml4XG4gICAgQE91dHB1dCgpIG1lbnVDbGljazogRXZlbnRFbWl0dGVyPGFueT4gPSBuZXcgRXZlbnRFbWl0dGVyKCk7XG4gICAgQE91dHB1dCgpIGl0ZW1DbGljazogRXZlbnRFbWl0dGVyPEV1aU1lbnVJdGVtPiA9IG5ldyBFdmVudEVtaXR0ZXIoKTtcblxuICAgIHB1YmxpYyBvbk1lbnVJdGVtQ2xpY2tlZChpdGVtOiBFdWlNZW51SXRlbSk6IHZvaWQge1xuICAgICAgICB0aGlzLml0ZW1DbGljay5lbWl0KGl0ZW0pO1xuICAgIH1cblxuICAgIC8vIFRPRE86IGZpbmQgdGhlIGNvcnJlY3QgdHlwZSBvciB0dXJuIGludG8gYSBnZW5lcmljLCBodHRwczovL3d3dy50eXBlc2NyaXB0bGFuZy5vcmcvZG9jcy9oYW5kYm9vay8yL2dlbmVyaWNzLmh0bWxcbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25vLWV4cGxpY2l0LWFueVxuICAgIHB1YmxpYyBvbk1lbnVDbGlja2VkKGV2ZW50OiBhbnkpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5tZW51Q2xpY2suZW1pdChldmVudCk7XG4gICAgfVxuXG4gICAgLy8gVE9ETzogZmluZCB0aGUgY29ycmVjdCB0eXBlIG9yIHR1cm4gaW50byBhIGdlbmVyaWMsIGh0dHBzOi8vd3d3LnR5cGVzY3JpcHRsYW5nLm9yZy9kb2NzL2hhbmRib29rLzIvZ2VuZXJpY3MuaHRtbFxuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tZXhwbGljaXQtYW55XG4gICAgcHVibGljIG9uTWVudUNvbGxhcHNlZChldmVudDogYW55KTogdm9pZCB7XG4gICAgICAgIHRoaXMuaXNDb2xsYXBzZWQgPSBldmVudDtcbiAgICB9XG59XG4iLCI8ZGl2IGNsYXNzPVwiZXVpLXNpZGViYXItbWVudV9fY29udGFpbmVyXCIgW2NsYXNzLmV1aS1zaWRlYmFyLW1lbnVfX2NvbnRhaW5lci0tY29sbGFwc2VkXT1cImlzQ29sbGFwc2VkXCIgW3N0eWxlXT1cInN0eWxlXCI+XG4gICAgPGRpdiBjbGFzcz1cImV1aS1zaWRlYmFyLW1lbnVfX2NvbnRlbnRcIj5cbiAgICAgICAgPGV1aS1tZW51XG4gICAgICAgICAgICBbaXRlbXNdPVwiaXRlbXNcIlxuICAgICAgICAgICAgW2hhc0ZpbHRlcl09XCJoYXNGaWx0ZXJcIlxuICAgICAgICAgICAgW2hhc0ljb25zXT1cImhhc0ljb25zXCJcbiAgICAgICAgICAgIFtoYXNUb29sdGlwXT1cImhhc1Rvb2x0aXBcIlxuICAgICAgICAgICAgW2lzQ29sbGFwc2VkXT1cImlzQ29sbGFwc2VkXCJcbiAgICAgICAgICAgIFtoYXNDb2xsYXBzZWRJbml0aWFsc109XCJoYXNDb2xsYXBzZWRJbml0aWFsc1wiXG4gICAgICAgICAgICBbaGFzTG93ZXJjYXNlSXRlbXNdPVwiaGFzTG93ZXJjYXNlSXRlbXNcIlxuICAgICAgICAgICAgW2V4cGFuZEFsbEl0ZW1zXT1cImV4cGFuZEFsbEl0ZW1zXCJcbiAgICAgICAgICAgIFtmcmFnbWVudElkXT1cImZyYWdtZW50SWRcIlxuICAgICAgICAgICAgW3NlYXJjaEZpbHRlckxhYmVsXT1cInNlYXJjaEZpbHRlckxhYmVsXCJcbiAgICAgICAgICAgIChpc0NsaWNrKT1cIm9uTWVudUNsaWNrZWQoJGV2ZW50KVwiXG4gICAgICAgICAgICAoaXRlbUNsaWNrKT1cIm9uTWVudUl0ZW1DbGlja2VkKCRldmVudClcIj5cbiAgICAgICAgPC9ldWktbWVudT5cbiAgICA8L2Rpdj5cbjwvZGl2PlxuIl19