@eui/components 18.0.0-next.63 → 18.0.0-next.64
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/docs/components/CollapsedBreadcrumbComponent.html +1 -1
- package/docs/components/EuiAppSidebarHeaderUserProfileComponent.html +1 -1
- package/docs/components/EuiAppTopMessageComponent.html +1 -1
- package/docs/components/EuiBreadcrumbItemComponent.html +1 -1
- package/docs/components/EuiCardFooterMenuContentComponent.html +1 -1
- package/docs/components/EuiCardHeaderComponent.html +1 -1
- package/docs/components/EuiChipListComponent.html +1 -1
- package/docs/components/EuiDialogContainerComponent.html +1 -1
- package/docs/components/EuiDiscussionThreadItemComponent.html +1 -1
- package/docs/components/EuiDropdownItemComponent.html +1 -1
- package/docs/components/EuiEditorComponent.html +1 -1
- package/docs/components/EuiFilePreviewComponent.html +1 -1
- package/docs/components/EuiGrowlComponent.html +1 -1
- package/docs/components/EuiIconButtonExpanderComponent.html +1 -1
- package/docs/components/EuiListItemComponent.html +1 -1
- package/docs/components/EuiMenuComponent.html +1 -1
- package/docs/components/EuiMenuItemComponent.html +1 -1
- package/docs/components/EuiNotificationItemComponent.html +1 -1
- package/docs/components/EuiNotificationItemV2Component.html +1 -1
- package/docs/components/EuiNotificationsComponent.html +1 -1
- package/docs/components/EuiNotificationsV2Component.html +1 -1
- package/docs/components/EuiOverlayHeaderTitleComponent.html +1 -1
- package/docs/components/EuiPageColumnComponent.html +1 -1
- package/docs/components/EuiPageHeaderComponent.html +1 -1
- package/docs/components/EuiPaginatorComponent.html +1 -1
- package/docs/components/EuiPopoverComponent.html +1 -1
- package/docs/components/EuiSearchComponent.html +1 -1
- package/docs/components/EuiTableFilterComponent.html +1 -1
- package/docs/components/EuiTableSortableColComponent.html +1 -1
- package/docs/components/EuiTableV2FilterComponent.html +1 -1
- package/docs/components/EuiTableV2SortableColComponent.html +1 -1
- package/docs/components/EuiTabsComponent.html +1 -1
- package/docs/components/EuiTimebarComponent.html +1 -1
- package/docs/components/EuiTimepickerComponent.html +1 -1
- package/docs/components/EuiToolbarMenuComponent.html +1 -1
- package/docs/components/EuiToolbarNavbarComponent.html +1 -1
- package/docs/components/EuiTreeComponent.html +3 -3
- package/docs/components/EuiTreeListToolbarComponent.html +1 -1
- package/docs/components/EuiUserProfileCardComponent.html +1 -1
- package/docs/components/EuiUserProfileComponent.html +1 -1
- package/docs/components/EuiWizardComponent.html +1 -1
- package/docs/dependencies.html +1 -1
- package/docs/js/menu-wc.js +3 -3
- package/docs/js/menu-wc_es5.js +1 -1
- package/docs/js/search/search_index.js +2 -2
- package/esm2022/eui-card/components/eui-card-footer/eui-card-footer-menu-content.component.mjs +3 -3
- package/esm2022/eui-card/components/eui-card-header/eui-card-header.component.mjs +3 -3
- package/esm2022/eui-card/eui-card.component.mjs +2 -2
- package/esm2022/eui-chip-list/eui-chip-list.component.mjs +3 -3
- package/esm2022/eui-dialog/container/eui-dialog-container.component.mjs +3 -3
- package/esm2022/eui-dialog/eui-dialog.component.mjs +2 -2
- package/esm2022/eui-discussion-thread/eui-discussion-thread-item.component.mjs +3 -3
- package/esm2022/eui-dropdown/dropdown-item/eui-dropdown-item.component.mjs +3 -3
- package/esm2022/eui-file-upload/file-preview/file-preview.component.mjs +3 -3
- package/esm2022/eui-growl/eui-growl.component.mjs +3 -3
- package/esm2022/eui-icon/eui-icon-button-expander/eui-icon-button-expander.component.mjs +3 -3
- package/esm2022/eui-icon/eui-icon-svg.component.mjs +2 -2
- package/esm2022/eui-list/eui-list-item/eui-list-item.component.mjs +3 -3
- package/esm2022/eui-list/eui-list.component.mjs +2 -2
- package/esm2022/eui-menu/eui-menu-item.component.mjs +3 -3
- package/esm2022/eui-menu/eui-menu.component.mjs +3 -3
- package/esm2022/eui-overlay/components/eui-overlay-header/eui-overlay-header-title/eui-overlay-header-title.component.mjs +3 -3
- package/esm2022/eui-page/components/eui-page-column/eui-page-column.component.mjs +3 -3
- package/esm2022/eui-page/components/eui-page-header/eui-page-header.component.mjs +3 -3
- package/esm2022/eui-paginator/eui-paginator.component.mjs +3 -3
- package/esm2022/eui-popover/eui-popover.component.mjs +3 -3
- package/esm2022/eui-table/filter/eui-table-filter.component.mjs +3 -3
- package/esm2022/eui-table/sortable-col/eui-table-sortable-col.component.mjs +3 -3
- package/esm2022/eui-table-v2/filter/eui-table-v2-filter.component.mjs +3 -3
- package/esm2022/eui-table-v2/sortable-col/eui-table-v2-sortable-col.component.mjs +3 -3
- package/esm2022/eui-tabs/eui-tabs.component.mjs +3 -3
- package/esm2022/eui-timebar/eui-timebar.component.mjs +3 -3
- package/esm2022/eui-timepicker/eui-timepicker.component.mjs +3 -3
- package/esm2022/eui-tree/eui-tree.component.mjs +5 -5
- package/esm2022/eui-tree-list/toolbar/toolbar.component.mjs +3 -3
- package/esm2022/eui-user-profile/user-profile-card/user-profile-card.component.mjs +3 -3
- package/esm2022/eui-user-profile/user-profile.component.mjs +3 -3
- package/esm2022/eui-wizard/eui-wizard.component.mjs +3 -3
- package/esm2022/externals/eui-editor/eui-editor.component.mjs +3 -3
- package/esm2022/layout/eui-app/eui-app-sidebar/sidebar-header-user-profile/sidebar-header-user-profile.component.mjs +3 -3
- package/esm2022/layout/eui-app/eui-app-top-message/top-message.component.mjs +3 -3
- package/esm2022/layout/eui-breadcrumb/collapsed-breadcrumb/collapsed-breadcrumb.component.mjs +3 -3
- package/esm2022/layout/eui-breadcrumb/item/breadcrumb-item.component.mjs +3 -3
- package/esm2022/layout/eui-notifications/eui-notification-item.component.mjs +3 -3
- package/esm2022/layout/eui-notifications/eui-notifications.component.mjs +3 -3
- package/esm2022/layout/eui-notifications-v2/eui-notification-item.component.mjs +3 -3
- package/esm2022/layout/eui-notifications-v2/eui-notifications.component.mjs +3 -3
- package/esm2022/layout/eui-search/search.component.mjs +3 -3
- package/esm2022/layout/eui-toolbar/toolbar-menu/toolbar-menu.component.mjs +3 -3
- package/esm2022/layout/eui-toolbar/toolbar-navbar/toolbar-navbar.component.mjs +3 -3
- package/eui-list/eui-list-item/eui-list-item.component.d.ts +1 -1
- package/eui-tree/eui-tree.component.d.ts.map +1 -1
- package/fesm2022/eui-components-eui-card.mjs +6 -6
- package/fesm2022/eui-components-eui-card.mjs.map +2 -2
- package/fesm2022/eui-components-eui-chip-list.mjs +4 -4
- package/fesm2022/eui-components-eui-chip-list.mjs.map +1 -1
- package/fesm2022/eui-components-eui-dialog.mjs +18 -18
- package/fesm2022/eui-components-eui-dialog.mjs.map +2 -2
- package/fesm2022/eui-components-eui-discussion-thread.mjs +8 -8
- package/fesm2022/eui-components-eui-discussion-thread.mjs.map +1 -1
- package/fesm2022/eui-components-eui-dropdown.mjs +2 -2
- package/fesm2022/eui-components-eui-dropdown.mjs.map +2 -2
- package/fesm2022/eui-components-eui-file-upload.mjs +2 -2
- package/fesm2022/eui-components-eui-file-upload.mjs.map +2 -2
- package/fesm2022/eui-components-eui-growl.mjs +2 -2
- package/fesm2022/eui-components-eui-growl.mjs.map +1 -1
- package/fesm2022/eui-components-eui-icon.mjs +10 -10
- package/fesm2022/eui-components-eui-icon.mjs.map +2 -2
- package/fesm2022/eui-components-eui-list.mjs +4 -4
- package/fesm2022/eui-components-eui-list.mjs.map +2 -2
- package/fesm2022/eui-components-eui-menu.mjs +18 -18
- package/fesm2022/eui-components-eui-menu.mjs.map +2 -2
- package/fesm2022/eui-components-eui-overlay.mjs +2 -2
- package/fesm2022/eui-components-eui-overlay.mjs.map +2 -2
- package/fesm2022/eui-components-eui-page.mjs +4 -4
- package/fesm2022/eui-components-eui-page.mjs.map +2 -2
- package/fesm2022/eui-components-eui-paginator.mjs +8 -8
- package/fesm2022/eui-components-eui-paginator.mjs.map +1 -1
- package/fesm2022/eui-components-eui-popover.mjs +2 -2
- package/fesm2022/eui-components-eui-popover.mjs.map +2 -2
- package/fesm2022/eui-components-eui-table-v2.mjs +8 -8
- package/fesm2022/eui-components-eui-table-v2.mjs.map +1 -1
- package/fesm2022/eui-components-eui-table.mjs +14 -14
- package/fesm2022/eui-components-eui-table.mjs.map +1 -1
- package/fesm2022/eui-components-eui-tabs.mjs +2 -2
- package/fesm2022/eui-components-eui-tabs.mjs.map +2 -2
- package/fesm2022/eui-components-eui-timebar.mjs +6 -6
- package/fesm2022/eui-components-eui-timebar.mjs.map +1 -1
- package/fesm2022/eui-components-eui-timepicker.mjs +12 -12
- package/fesm2022/eui-components-eui-timepicker.mjs.map +1 -1
- package/fesm2022/eui-components-eui-tree-list.mjs +6 -6
- package/fesm2022/eui-components-eui-tree-list.mjs.map +1 -1
- package/fesm2022/eui-components-eui-tree.mjs +6 -6
- package/fesm2022/eui-components-eui-tree.mjs.map +1 -1
- package/fesm2022/eui-components-eui-user-profile.mjs +4 -4
- package/fesm2022/eui-components-eui-user-profile.mjs.map +2 -2
- package/fesm2022/eui-components-eui-wizard.mjs +2 -2
- package/fesm2022/eui-components-eui-wizard.mjs.map +2 -2
- package/fesm2022/eui-components-externals-eui-editor.mjs +8 -8
- package/fesm2022/eui-components-externals-eui-editor.mjs.map +1 -1
- package/fesm2022/eui-components-layout.mjs +36 -36
- package/fesm2022/eui-components-layout.mjs.map +2 -2
- package/package.json +21 -21
@@ -436,7 +436,7 @@ export class EuiMenuComponent {
|
|
436
436
|
}
|
437
437
|
}
|
438
438
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0-rc.1", ngImport: i0, type: EuiMenuComponent, deps: [{ token: i1.Router }, { token: i1.ActivatedRoute }, { token: i2.BaseStatesDirective }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
439
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.0-rc.1", type: EuiMenuComponent, selector: "eui-menu", inputs: { items: "items", searchFilterLabel: "searchFilterLabel", externalLinkLabel: "externalLinkLabel", fragmentId: "fragmentId", filterValue: "filterValue", isCollapsed: ["isCollapsed", "isCollapsed", booleanAttribute], hasCollapsedInitials: ["hasCollapsedInitials", "hasCollapsedInitials", booleanAttribute], hasFilter: ["hasFilter", "hasFilter", booleanAttribute], hasIcons: ["hasIcons", "hasIcons", booleanAttribute], hasTooltip: ["hasTooltip", "hasTooltip", booleanAttribute], expandAllItems: ["expandAllItems", "expandAllItems", booleanAttribute], isFlat: ["isFlat", "isFlat", booleanAttribute], hasScrollToItem: ["hasScrollToItem", "hasScrollToItem", booleanAttribute], hasBoldRootLevel: ["hasBoldRootLevel", "hasBoldRootLevel", booleanAttribute] }, outputs: { isClick: "isClick", itemClick: "itemClick" }, host: { listeners: { "click": "stopPropagation($event)" }, properties: { "class": "this.cssClasses" } }, viewQueries: [{ propertyName: "focusableItems", predicate: EuiMenuItemComponent, descendants: true }], usesOnChanges: true, hostDirectives: [{ directive: i2.BaseStatesDirective }], ngImport: i0, template: "@if (hasFilter && !isCollapsed) {\n <div class=\"eui-menu-filter\" (click)=\"onMenuFilterClick($event)\">\n <eui-icon-input>\n <eui-icon-svg icon=\"eui-search\" fillColor=\"neutral-lighter\" aria-label=\"Search Icon\"></eui-icon-svg>\n <input\n euiInputText\n [euiClearable]=\"true\"\n (input)=\"onFilter($event)\"\n [placeholder]=\"searchFilterLabel\"\n [attr.aria-label]=\"searchFilterLabel\"\n [value]=\"filterValue\" />\n </eui-icon-input>\n </div>\n}\n\n<ul euiList class=\"eui-menu\" role=\"menubar\" aria-orientation=\"vertical\" tabindex=\"0\" (keydown)=\"onKeydown($event)\">\n @if (items) {\n <ng-template ngFor let-item let-index [ngForOf]=\"items\">\n <ng-template [ngTemplateOutlet]=\"menuItemTemplateRef\" [ngTemplateOutletContext]=\"{ menuItem: item, index: index }\"> </ng-template>\n </ng-template>\n } @else {\n <span class=\"eui-menu--no-items\">No menu items defined</span>\n }\n</ul>\n\n<!-- describe the recursive template of the menu item -->\n<ng-template #menuItemTemplateRef let-item=\"menuItem\" let-parent=\"parent\" let-i=\"index\">\n <!-- render the menu item-->\n <eui-menu-item\n *ngIf=\"item.filtered\"\n [item]=\"item\"\n [parent]=\"parent\"\n [hasIcon]=\"hasIcons\"\n [hasTooltip]=\"hasTooltip\"\n [isCollapsed]=\"isCollapsed\"\n [hasBoldRootLevel]=\"hasBoldRootLevel\"\n [hasCollapsedInitials]=\"hasCollapsedInitials\"\n (expandToggle)=\"onExpandToggle($event)\"\n (itemClick)=\"onClick($event)\">\n <!-- if the menu item has children, render the children -->\n <ul euiList *ngIf=\"item.children && item.expanded\" class=\"eui-menu eui-menu-sub\" role=\"menu\" [attr.aria-label]=\"item.label\" tabindex=\"-1\">\n <ng-container *ngFor=\"let child of item.children; let childIndex = index\">\n <ng-template [ngTemplateOutlet]=\"menuItemTemplateRef\" [ngTemplateOutletContext]=\"{ menuItem: child, index: childIndex, parent: item }\">\n </ng-template>\n </ng-container>\n </ul>\n </eui-menu-item>\n</ng-template>\n", styles: [".eui-menu{display:flex;flex-direction:column;gap:0;list-style:none;margin-block-start:0;margin-block-end:0;margin:0;padding:0;width:100%}.eui-menu:focus:not([readonly]){outline:2px solid var(--eui-c-focus)!important;outline-offset:-2px!important;transition:none}.eui-menu:focus-visible:not([readonly]){outline:2px solid var(--eui-c-focus-visible)!important;outline-offset:-2px!important;transition:none}.eui-menu [tabindex=\"0\"]:focus:not([readonly]){outline:2px solid var(--eui-c-focus-visible)!important;outline-offset:-2px!important;transition:none}.eui-menu--collapsed .eui-menu-filter{transition:none;visibility:hidden}.eui-menu--collapsed .eui-menu-item__link{padding-left:var(--eui-s-m)}.eui-menu--collapsed .eui-menu-item__link-start-block{gap:0}.eui-menu--collapsed .eui-menu-item__link-content-block,.eui-menu--collapsed .eui-menu-item__link-end-block{visibility:hidden}.eui-menu--collapsed .eui-menu-item__link-end-block .eui-menu-item__link-action-icon{display:none}.eui-menu--collapsed .eui-menu-item__link-end-block .eui-menu-item__link-dotted-badge{position:absolute;top:var(--eui-s-2xs);right:var(--eui-s-2xs);visibility:visible}.eui-menu--collapsed .eui-menu-item__link-end-block .eui-menu-item__link-toggle{display:inherit;position:absolute;right:calc(-1 * var(--eui-s-xs));transform:scale(.75);visibility:visible}.eui-menu--collapsed .eui-menu-item__link-initials{display:flex;background-color:var(--eui-c-neutral-bg-light);border:var(--eui-bw-xs) solid var(--eui-c-neutral-lightest);border-radius:var(--eui-s-xs);font:var(--eui-f-s-bold);justify-content:center;margin-left:calc(-1 * var(--eui-s-2xs));min-width:var(--eui-s-2xl)}.eui-menu--collapsed .eui-menu-item--expanded:first-child{border-bottom:none;padding-bottom:0}.eui-menu--collapsed .eui-menu-item--expanded .eui-menu-sub .eui-menu-item__link,.eui-menu--collapsed .eui-menu-item--expanded .eui-menu-item--expanded .eui-menu-sub .eui-menu-item__link{padding-left:var(--eui-s-s)}.eui-menu--no-items{color:var(--eui-c-neutral-lighter);text-align:center}.eui-menu-filter{display:flex;padding:var(--eui-s-m);position:relative;width:100%}.eui-menu-item{display:flex;position:relative;width:100%;border:var(--eui-bw-xs) solid transparent}.eui-menu-item:focus:not([readonly]){outline:2px solid var(--eui-c-focus)!important;outline-offset:-2px!important;transition:none}.eui-menu-item:focus-visible:not([readonly]){outline:2px solid var(--eui-c-focus-visible)!important;outline-offset:-2px!important;transition:none}.eui-menu-item [tabindex=\"0\"]:focus:not([readonly]){outline:2px solid var(--eui-c-focus-visible)!important;outline-offset:-2px!important;transition:none}.eui-menu-item .eui-menu-item__content{align-items:center;display:flex;position:relative;width:100%}.eui-menu-item__link{align-items:center;color:var(--eui-c-text);cursor:pointer;display:flex;font:var(--eui-f-m);gap:var(--eui-s-xs);padding:var(--eui-s-xs) var(--eui-s-2xs) calc(var(--eui-s-xs) - 2px) var(--eui-s-m);border-top:1px solid var(--eui-c-neutral-bg);text-decoration:none;width:100%}.eui-menu-item__link-start-block{align-items:center;display:flex;gap:var(--eui-s-xs)}.eui-menu-item__link-start-block:empty{display:none}.eui-menu-item__link-content-block{display:flex;flex-direction:column;width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.eui-menu-item__link-content-block .eui-menu-item__link-label-container{align-items:center;display:flex;position:relative;width:100%}.eui-menu-item__link-content-block .eui-menu-item__link-label-container .eui-menu-item__link-label{color:var(--eui-c-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.eui-menu-item__link-content-block .eui-menu-item__link-label-container .eui-menu-item__link-label-category{cursor:default;color:var(--eui-c-info-light);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.eui-menu-item__link-end-block{align-items:center;display:flex;gap:var(--eui-s-xs)}.eui-menu-item__link:hover:not(.eui-menu-item--disabled):not(.eui-menu-item__link-category){background-color:var(--eui-c-primary-bg);text-decoration:none}.eui-menu-item__link--disabled{opacity:var(--eui-o-50);pointer-events:none}.eui-menu-item__link--active:not(.eui-menu-item--disabled){background-color:var(--eui-c-primary-bg);font:var(--eui-f-m-bold)}.eui-menu-item__link--active:not(.eui-menu-item--disabled) .eui-menu-item__link-label{color:var(--eui-c-primary)}.eui-menu-item--expanded{display:flex;flex-direction:column}.eui-menu-item--expanded .eui-menu-item--expanded .eui-menu-sub .eui-menu-item__link{padding-left:var(--eui-s-3xl)}.eui-menu-item .eui-menu-sub .eui-menu-item__link{padding-left:var(--eui-s-xl);padding-bottom:var(--eui-s-2xs);padding-top:var(--eui-s-2xs);border-top:0}.eui-menu-item--bold>.eui-menu-item__content>.eui-menu-item__link{font:var(--eui-f-m-bold)}\n"], dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i4.EuiIconSvgComponent, selector: "eui-icon-svg, span[euiIconSvg], i[euiIconSvg]", inputs: ["icon", "fillColor", "set", "size", "ariaLabelledby", "role", "style", "iconUrl", "transform", "aria-label", "ariaHidden", "focusable", "isLoading", "isInputIcon", "euiStart", "euiEnd"] }, { kind: "component", type: i4.EuiIconInputComponent, selector: "eui-icon-input", inputs: ["euiIconPositionStart", "euiIconPositionEnd"] }, { kind: "component", type: i5.EuiInputTextComponent, selector: "input[euiInputText]", inputs: ["isInvalid"] }, { kind: "component", type: i6.EuiMenuItemComponent, selector: "eui-menu-item", inputs: ["item", "parent", "hasIcon", "hasTooltip", "isCollapsed", "hasCollapsedInitials", "hasBoldRootLevel"], outputs: ["expandToggle", "itemClick"] }], encapsulation: i0.ViewEncapsulation.None }); }
|
439
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.0-rc.1", type: EuiMenuComponent, selector: "eui-menu", inputs: { items: "items", searchFilterLabel: "searchFilterLabel", externalLinkLabel: "externalLinkLabel", fragmentId: "fragmentId", filterValue: "filterValue", isCollapsed: ["isCollapsed", "isCollapsed", booleanAttribute], hasCollapsedInitials: ["hasCollapsedInitials", "hasCollapsedInitials", booleanAttribute], hasFilter: ["hasFilter", "hasFilter", booleanAttribute], hasIcons: ["hasIcons", "hasIcons", booleanAttribute], hasTooltip: ["hasTooltip", "hasTooltip", booleanAttribute], expandAllItems: ["expandAllItems", "expandAllItems", booleanAttribute], isFlat: ["isFlat", "isFlat", booleanAttribute], hasScrollToItem: ["hasScrollToItem", "hasScrollToItem", booleanAttribute], hasBoldRootLevel: ["hasBoldRootLevel", "hasBoldRootLevel", booleanAttribute] }, outputs: { isClick: "isClick", itemClick: "itemClick" }, host: { listeners: { "click": "stopPropagation($event)" }, properties: { "class": "this.cssClasses" } }, viewQueries: [{ propertyName: "focusableItems", predicate: EuiMenuItemComponent, descendants: true }], usesOnChanges: true, hostDirectives: [{ directive: i2.BaseStatesDirective }], ngImport: i0, template: "@if (hasFilter && !isCollapsed) {\n <div class=\"eui-menu-filter\" (click)=\"onMenuFilterClick($event)\">\n <eui-icon-input>\n <eui-icon-svg icon=\"eui-ecl-search\" fillColor=\"neutral-lighter\" aria-label=\"Search Icon\"></eui-icon-svg>\n <input\n euiInputText\n [euiClearable]=\"true\"\n (input)=\"onFilter($event)\"\n [placeholder]=\"searchFilterLabel\"\n [attr.aria-label]=\"searchFilterLabel\"\n [value]=\"filterValue\" />\n </eui-icon-input>\n </div>\n}\n\n<ul euiList class=\"eui-menu\" role=\"menubar\" aria-orientation=\"vertical\" tabindex=\"0\" (keydown)=\"onKeydown($event)\">\n @if (items) {\n <ng-template ngFor let-item let-index [ngForOf]=\"items\">\n <ng-template [ngTemplateOutlet]=\"menuItemTemplateRef\" [ngTemplateOutletContext]=\"{ menuItem: item, index: index }\"> </ng-template>\n </ng-template>\n } @else {\n <span class=\"eui-menu--no-items\">No menu items defined</span>\n }\n</ul>\n\n<!-- describe the recursive template of the menu item -->\n<ng-template #menuItemTemplateRef let-item=\"menuItem\" let-parent=\"parent\" let-i=\"index\">\n <!-- render the menu item-->\n <eui-menu-item\n *ngIf=\"item.filtered\"\n [item]=\"item\"\n [parent]=\"parent\"\n [hasIcon]=\"hasIcons\"\n [hasTooltip]=\"hasTooltip\"\n [isCollapsed]=\"isCollapsed\"\n [hasBoldRootLevel]=\"hasBoldRootLevel\"\n [hasCollapsedInitials]=\"hasCollapsedInitials\"\n (expandToggle)=\"onExpandToggle($event)\"\n (itemClick)=\"onClick($event)\">\n <!-- if the menu item has children, render the children -->\n <ul euiList *ngIf=\"item.children && item.expanded\" class=\"eui-menu eui-menu-sub\" role=\"menu\" [attr.aria-label]=\"item.label\" tabindex=\"-1\">\n <ng-container *ngFor=\"let child of item.children; let childIndex = index\">\n <ng-template [ngTemplateOutlet]=\"menuItemTemplateRef\" [ngTemplateOutletContext]=\"{ menuItem: child, index: childIndex, parent: item }\">\n </ng-template>\n </ng-container>\n </ul>\n </eui-menu-item>\n</ng-template>\n", styles: [".eui-menu{display:flex;flex-direction:column;gap:0;list-style:none;margin-block-start:0;margin-block-end:0;margin:0;padding:0;width:100%}.eui-menu:focus:not([readonly]){outline:2px solid var(--eui-c-focus)!important;outline-offset:-2px!important;transition:none}.eui-menu:focus-visible:not([readonly]){outline:2px solid var(--eui-c-focus-visible)!important;outline-offset:-2px!important;transition:none}.eui-menu [tabindex=\"0\"]:focus:not([readonly]){outline:2px solid var(--eui-c-focus-visible)!important;outline-offset:-2px!important;transition:none}.eui-menu--collapsed .eui-menu-filter{transition:none;visibility:hidden}.eui-menu--collapsed .eui-menu-item__link{padding-left:var(--eui-s-m)}.eui-menu--collapsed .eui-menu-item__link-start-block{gap:0}.eui-menu--collapsed .eui-menu-item__link-content-block,.eui-menu--collapsed .eui-menu-item__link-end-block{visibility:hidden}.eui-menu--collapsed .eui-menu-item__link-end-block .eui-menu-item__link-action-icon{display:none}.eui-menu--collapsed .eui-menu-item__link-end-block .eui-menu-item__link-dotted-badge{position:absolute;top:var(--eui-s-2xs);right:var(--eui-s-2xs);visibility:visible}.eui-menu--collapsed .eui-menu-item__link-end-block .eui-menu-item__link-toggle{display:inherit;position:absolute;right:calc(-1 * var(--eui-s-xs));transform:scale(.75);visibility:visible}.eui-menu--collapsed .eui-menu-item__link-initials{display:flex;background-color:var(--eui-c-neutral-bg-light);border:var(--eui-bw-xs) solid var(--eui-c-neutral-lightest);border-radius:var(--eui-s-xs);font:var(--eui-f-s-bold);justify-content:center;margin-left:calc(-1 * var(--eui-s-2xs));min-width:var(--eui-s-2xl)}.eui-menu--collapsed .eui-menu-item--expanded:first-child{border-bottom:none;padding-bottom:0}.eui-menu--collapsed .eui-menu-item--expanded .eui-menu-sub .eui-menu-item__link,.eui-menu--collapsed .eui-menu-item--expanded .eui-menu-item--expanded .eui-menu-sub .eui-menu-item__link{padding-left:var(--eui-s-s)}.eui-menu--no-items{color:var(--eui-c-neutral-lighter);text-align:center}.eui-menu-filter{display:flex;padding:var(--eui-s-m);position:relative;width:100%}.eui-menu-item{display:flex;position:relative;width:100%;border:var(--eui-bw-xs) solid transparent}.eui-menu-item:focus:not([readonly]){outline:2px solid var(--eui-c-focus)!important;outline-offset:-2px!important;transition:none}.eui-menu-item:focus-visible:not([readonly]){outline:2px solid var(--eui-c-focus-visible)!important;outline-offset:-2px!important;transition:none}.eui-menu-item [tabindex=\"0\"]:focus:not([readonly]){outline:2px solid var(--eui-c-focus-visible)!important;outline-offset:-2px!important;transition:none}.eui-menu-item .eui-menu-item__content{align-items:center;display:flex;position:relative;width:100%}.eui-menu-item__link{align-items:center;color:var(--eui-c-text);cursor:pointer;display:flex;font:var(--eui-f-m);gap:var(--eui-s-xs);padding:var(--eui-s-xs) var(--eui-s-2xs) calc(var(--eui-s-xs) - 2px) var(--eui-s-m);border-top:1px solid var(--eui-c-neutral-bg);text-decoration:none;width:100%}.eui-menu-item__link-start-block{align-items:center;display:flex;gap:var(--eui-s-xs)}.eui-menu-item__link-start-block:empty{display:none}.eui-menu-item__link-content-block{display:flex;flex-direction:column;width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.eui-menu-item__link-content-block .eui-menu-item__link-label-container{align-items:center;display:flex;position:relative;width:100%}.eui-menu-item__link-content-block .eui-menu-item__link-label-container .eui-menu-item__link-label{color:var(--eui-c-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.eui-menu-item__link-content-block .eui-menu-item__link-label-container .eui-menu-item__link-label-category{cursor:default;color:var(--eui-c-info-light);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.eui-menu-item__link-end-block{align-items:center;display:flex;gap:var(--eui-s-xs)}.eui-menu-item__link:hover:not(.eui-menu-item--disabled):not(.eui-menu-item__link-category){background-color:var(--eui-c-primary-bg);text-decoration:none}.eui-menu-item__link--disabled{opacity:var(--eui-o-50);pointer-events:none}.eui-menu-item__link--active:not(.eui-menu-item--disabled){background-color:var(--eui-c-primary-bg);font:var(--eui-f-m-bold)}.eui-menu-item__link--active:not(.eui-menu-item--disabled) .eui-menu-item__link-label{color:var(--eui-c-primary)}.eui-menu-item--expanded{display:flex;flex-direction:column}.eui-menu-item--expanded .eui-menu-item--expanded .eui-menu-sub .eui-menu-item__link{padding-left:var(--eui-s-3xl)}.eui-menu-item .eui-menu-sub .eui-menu-item__link{padding-left:var(--eui-s-xl);padding-bottom:var(--eui-s-2xs);padding-top:var(--eui-s-2xs);border-top:0}.eui-menu-item--bold>.eui-menu-item__content>.eui-menu-item__link{font:var(--eui-f-m-bold)}\n"], dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i4.EuiIconSvgComponent, selector: "eui-icon-svg, span[euiIconSvg], i[euiIconSvg]", inputs: ["icon", "fillColor", "set", "size", "ariaLabelledby", "role", "style", "iconUrl", "transform", "aria-label", "ariaHidden", "focusable", "isLoading", "isInputIcon", "euiStart", "euiEnd"] }, { kind: "component", type: i4.EuiIconInputComponent, selector: "eui-icon-input", inputs: ["euiIconPositionStart", "euiIconPositionEnd"] }, { kind: "component", type: i5.EuiInputTextComponent, selector: "input[euiInputText]", inputs: ["isInvalid"] }, { kind: "component", type: i6.EuiMenuItemComponent, selector: "eui-menu-item", inputs: ["item", "parent", "hasIcon", "hasTooltip", "isCollapsed", "hasCollapsedInitials", "hasBoldRootLevel"], outputs: ["expandToggle", "itemClick"] }], encapsulation: i0.ViewEncapsulation.None }); }
|
440
440
|
}
|
441
441
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-rc.1", ngImport: i0, type: EuiMenuComponent, decorators: [{
|
442
442
|
type: Component,
|
@@ -444,7 +444,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-rc.1", ng
|
|
444
444
|
{
|
445
445
|
directive: BaseStatesDirective,
|
446
446
|
},
|
447
|
-
], encapsulation: ViewEncapsulation.None, template: "@if (hasFilter && !isCollapsed) {\n <div class=\"eui-menu-filter\" (click)=\"onMenuFilterClick($event)\">\n <eui-icon-input>\n <eui-icon-svg icon=\"eui-search\" fillColor=\"neutral-lighter\" aria-label=\"Search Icon\"></eui-icon-svg>\n <input\n euiInputText\n [euiClearable]=\"true\"\n (input)=\"onFilter($event)\"\n [placeholder]=\"searchFilterLabel\"\n [attr.aria-label]=\"searchFilterLabel\"\n [value]=\"filterValue\" />\n </eui-icon-input>\n </div>\n}\n\n<ul euiList class=\"eui-menu\" role=\"menubar\" aria-orientation=\"vertical\" tabindex=\"0\" (keydown)=\"onKeydown($event)\">\n @if (items) {\n <ng-template ngFor let-item let-index [ngForOf]=\"items\">\n <ng-template [ngTemplateOutlet]=\"menuItemTemplateRef\" [ngTemplateOutletContext]=\"{ menuItem: item, index: index }\"> </ng-template>\n </ng-template>\n } @else {\n <span class=\"eui-menu--no-items\">No menu items defined</span>\n }\n</ul>\n\n<!-- describe the recursive template of the menu item -->\n<ng-template #menuItemTemplateRef let-item=\"menuItem\" let-parent=\"parent\" let-i=\"index\">\n <!-- render the menu item-->\n <eui-menu-item\n *ngIf=\"item.filtered\"\n [item]=\"item\"\n [parent]=\"parent\"\n [hasIcon]=\"hasIcons\"\n [hasTooltip]=\"hasTooltip\"\n [isCollapsed]=\"isCollapsed\"\n [hasBoldRootLevel]=\"hasBoldRootLevel\"\n [hasCollapsedInitials]=\"hasCollapsedInitials\"\n (expandToggle)=\"onExpandToggle($event)\"\n (itemClick)=\"onClick($event)\">\n <!-- if the menu item has children, render the children -->\n <ul euiList *ngIf=\"item.children && item.expanded\" class=\"eui-menu eui-menu-sub\" role=\"menu\" [attr.aria-label]=\"item.label\" tabindex=\"-1\">\n <ng-container *ngFor=\"let child of item.children; let childIndex = index\">\n <ng-template [ngTemplateOutlet]=\"menuItemTemplateRef\" [ngTemplateOutletContext]=\"{ menuItem: child, index: childIndex, parent: item }\">\n </ng-template>\n </ng-container>\n </ul>\n </eui-menu-item>\n</ng-template>\n", styles: [".eui-menu{display:flex;flex-direction:column;gap:0;list-style:none;margin-block-start:0;margin-block-end:0;margin:0;padding:0;width:100%}.eui-menu:focus:not([readonly]){outline:2px solid var(--eui-c-focus)!important;outline-offset:-2px!important;transition:none}.eui-menu:focus-visible:not([readonly]){outline:2px solid var(--eui-c-focus-visible)!important;outline-offset:-2px!important;transition:none}.eui-menu [tabindex=\"0\"]:focus:not([readonly]){outline:2px solid var(--eui-c-focus-visible)!important;outline-offset:-2px!important;transition:none}.eui-menu--collapsed .eui-menu-filter{transition:none;visibility:hidden}.eui-menu--collapsed .eui-menu-item__link{padding-left:var(--eui-s-m)}.eui-menu--collapsed .eui-menu-item__link-start-block{gap:0}.eui-menu--collapsed .eui-menu-item__link-content-block,.eui-menu--collapsed .eui-menu-item__link-end-block{visibility:hidden}.eui-menu--collapsed .eui-menu-item__link-end-block .eui-menu-item__link-action-icon{display:none}.eui-menu--collapsed .eui-menu-item__link-end-block .eui-menu-item__link-dotted-badge{position:absolute;top:var(--eui-s-2xs);right:var(--eui-s-2xs);visibility:visible}.eui-menu--collapsed .eui-menu-item__link-end-block .eui-menu-item__link-toggle{display:inherit;position:absolute;right:calc(-1 * var(--eui-s-xs));transform:scale(.75);visibility:visible}.eui-menu--collapsed .eui-menu-item__link-initials{display:flex;background-color:var(--eui-c-neutral-bg-light);border:var(--eui-bw-xs) solid var(--eui-c-neutral-lightest);border-radius:var(--eui-s-xs);font:var(--eui-f-s-bold);justify-content:center;margin-left:calc(-1 * var(--eui-s-2xs));min-width:var(--eui-s-2xl)}.eui-menu--collapsed .eui-menu-item--expanded:first-child{border-bottom:none;padding-bottom:0}.eui-menu--collapsed .eui-menu-item--expanded .eui-menu-sub .eui-menu-item__link,.eui-menu--collapsed .eui-menu-item--expanded .eui-menu-item--expanded .eui-menu-sub .eui-menu-item__link{padding-left:var(--eui-s-s)}.eui-menu--no-items{color:var(--eui-c-neutral-lighter);text-align:center}.eui-menu-filter{display:flex;padding:var(--eui-s-m);position:relative;width:100%}.eui-menu-item{display:flex;position:relative;width:100%;border:var(--eui-bw-xs) solid transparent}.eui-menu-item:focus:not([readonly]){outline:2px solid var(--eui-c-focus)!important;outline-offset:-2px!important;transition:none}.eui-menu-item:focus-visible:not([readonly]){outline:2px solid var(--eui-c-focus-visible)!important;outline-offset:-2px!important;transition:none}.eui-menu-item [tabindex=\"0\"]:focus:not([readonly]){outline:2px solid var(--eui-c-focus-visible)!important;outline-offset:-2px!important;transition:none}.eui-menu-item .eui-menu-item__content{align-items:center;display:flex;position:relative;width:100%}.eui-menu-item__link{align-items:center;color:var(--eui-c-text);cursor:pointer;display:flex;font:var(--eui-f-m);gap:var(--eui-s-xs);padding:var(--eui-s-xs) var(--eui-s-2xs) calc(var(--eui-s-xs) - 2px) var(--eui-s-m);border-top:1px solid var(--eui-c-neutral-bg);text-decoration:none;width:100%}.eui-menu-item__link-start-block{align-items:center;display:flex;gap:var(--eui-s-xs)}.eui-menu-item__link-start-block:empty{display:none}.eui-menu-item__link-content-block{display:flex;flex-direction:column;width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.eui-menu-item__link-content-block .eui-menu-item__link-label-container{align-items:center;display:flex;position:relative;width:100%}.eui-menu-item__link-content-block .eui-menu-item__link-label-container .eui-menu-item__link-label{color:var(--eui-c-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.eui-menu-item__link-content-block .eui-menu-item__link-label-container .eui-menu-item__link-label-category{cursor:default;color:var(--eui-c-info-light);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.eui-menu-item__link-end-block{align-items:center;display:flex;gap:var(--eui-s-xs)}.eui-menu-item__link:hover:not(.eui-menu-item--disabled):not(.eui-menu-item__link-category){background-color:var(--eui-c-primary-bg);text-decoration:none}.eui-menu-item__link--disabled{opacity:var(--eui-o-50);pointer-events:none}.eui-menu-item__link--active:not(.eui-menu-item--disabled){background-color:var(--eui-c-primary-bg);font:var(--eui-f-m-bold)}.eui-menu-item__link--active:not(.eui-menu-item--disabled) .eui-menu-item__link-label{color:var(--eui-c-primary)}.eui-menu-item--expanded{display:flex;flex-direction:column}.eui-menu-item--expanded .eui-menu-item--expanded .eui-menu-sub .eui-menu-item__link{padding-left:var(--eui-s-3xl)}.eui-menu-item .eui-menu-sub .eui-menu-item__link{padding-left:var(--eui-s-xl);padding-bottom:var(--eui-s-2xs);padding-top:var(--eui-s-2xs);border-top:0}.eui-menu-item--bold>.eui-menu-item__content>.eui-menu-item__link{font:var(--eui-f-m-bold)}\n"] }]
|
447
|
+
], encapsulation: ViewEncapsulation.None, template: "@if (hasFilter && !isCollapsed) {\n <div class=\"eui-menu-filter\" (click)=\"onMenuFilterClick($event)\">\n <eui-icon-input>\n <eui-icon-svg icon=\"eui-ecl-search\" fillColor=\"neutral-lighter\" aria-label=\"Search Icon\"></eui-icon-svg>\n <input\n euiInputText\n [euiClearable]=\"true\"\n (input)=\"onFilter($event)\"\n [placeholder]=\"searchFilterLabel\"\n [attr.aria-label]=\"searchFilterLabel\"\n [value]=\"filterValue\" />\n </eui-icon-input>\n </div>\n}\n\n<ul euiList class=\"eui-menu\" role=\"menubar\" aria-orientation=\"vertical\" tabindex=\"0\" (keydown)=\"onKeydown($event)\">\n @if (items) {\n <ng-template ngFor let-item let-index [ngForOf]=\"items\">\n <ng-template [ngTemplateOutlet]=\"menuItemTemplateRef\" [ngTemplateOutletContext]=\"{ menuItem: item, index: index }\"> </ng-template>\n </ng-template>\n } @else {\n <span class=\"eui-menu--no-items\">No menu items defined</span>\n }\n</ul>\n\n<!-- describe the recursive template of the menu item -->\n<ng-template #menuItemTemplateRef let-item=\"menuItem\" let-parent=\"parent\" let-i=\"index\">\n <!-- render the menu item-->\n <eui-menu-item\n *ngIf=\"item.filtered\"\n [item]=\"item\"\n [parent]=\"parent\"\n [hasIcon]=\"hasIcons\"\n [hasTooltip]=\"hasTooltip\"\n [isCollapsed]=\"isCollapsed\"\n [hasBoldRootLevel]=\"hasBoldRootLevel\"\n [hasCollapsedInitials]=\"hasCollapsedInitials\"\n (expandToggle)=\"onExpandToggle($event)\"\n (itemClick)=\"onClick($event)\">\n <!-- if the menu item has children, render the children -->\n <ul euiList *ngIf=\"item.children && item.expanded\" class=\"eui-menu eui-menu-sub\" role=\"menu\" [attr.aria-label]=\"item.label\" tabindex=\"-1\">\n <ng-container *ngFor=\"let child of item.children; let childIndex = index\">\n <ng-template [ngTemplateOutlet]=\"menuItemTemplateRef\" [ngTemplateOutletContext]=\"{ menuItem: child, index: childIndex, parent: item }\">\n </ng-template>\n </ng-container>\n </ul>\n </eui-menu-item>\n</ng-template>\n", styles: [".eui-menu{display:flex;flex-direction:column;gap:0;list-style:none;margin-block-start:0;margin-block-end:0;margin:0;padding:0;width:100%}.eui-menu:focus:not([readonly]){outline:2px solid var(--eui-c-focus)!important;outline-offset:-2px!important;transition:none}.eui-menu:focus-visible:not([readonly]){outline:2px solid var(--eui-c-focus-visible)!important;outline-offset:-2px!important;transition:none}.eui-menu [tabindex=\"0\"]:focus:not([readonly]){outline:2px solid var(--eui-c-focus-visible)!important;outline-offset:-2px!important;transition:none}.eui-menu--collapsed .eui-menu-filter{transition:none;visibility:hidden}.eui-menu--collapsed .eui-menu-item__link{padding-left:var(--eui-s-m)}.eui-menu--collapsed .eui-menu-item__link-start-block{gap:0}.eui-menu--collapsed .eui-menu-item__link-content-block,.eui-menu--collapsed .eui-menu-item__link-end-block{visibility:hidden}.eui-menu--collapsed .eui-menu-item__link-end-block .eui-menu-item__link-action-icon{display:none}.eui-menu--collapsed .eui-menu-item__link-end-block .eui-menu-item__link-dotted-badge{position:absolute;top:var(--eui-s-2xs);right:var(--eui-s-2xs);visibility:visible}.eui-menu--collapsed .eui-menu-item__link-end-block .eui-menu-item__link-toggle{display:inherit;position:absolute;right:calc(-1 * var(--eui-s-xs));transform:scale(.75);visibility:visible}.eui-menu--collapsed .eui-menu-item__link-initials{display:flex;background-color:var(--eui-c-neutral-bg-light);border:var(--eui-bw-xs) solid var(--eui-c-neutral-lightest);border-radius:var(--eui-s-xs);font:var(--eui-f-s-bold);justify-content:center;margin-left:calc(-1 * var(--eui-s-2xs));min-width:var(--eui-s-2xl)}.eui-menu--collapsed .eui-menu-item--expanded:first-child{border-bottom:none;padding-bottom:0}.eui-menu--collapsed .eui-menu-item--expanded .eui-menu-sub .eui-menu-item__link,.eui-menu--collapsed .eui-menu-item--expanded .eui-menu-item--expanded .eui-menu-sub .eui-menu-item__link{padding-left:var(--eui-s-s)}.eui-menu--no-items{color:var(--eui-c-neutral-lighter);text-align:center}.eui-menu-filter{display:flex;padding:var(--eui-s-m);position:relative;width:100%}.eui-menu-item{display:flex;position:relative;width:100%;border:var(--eui-bw-xs) solid transparent}.eui-menu-item:focus:not([readonly]){outline:2px solid var(--eui-c-focus)!important;outline-offset:-2px!important;transition:none}.eui-menu-item:focus-visible:not([readonly]){outline:2px solid var(--eui-c-focus-visible)!important;outline-offset:-2px!important;transition:none}.eui-menu-item [tabindex=\"0\"]:focus:not([readonly]){outline:2px solid var(--eui-c-focus-visible)!important;outline-offset:-2px!important;transition:none}.eui-menu-item .eui-menu-item__content{align-items:center;display:flex;position:relative;width:100%}.eui-menu-item__link{align-items:center;color:var(--eui-c-text);cursor:pointer;display:flex;font:var(--eui-f-m);gap:var(--eui-s-xs);padding:var(--eui-s-xs) var(--eui-s-2xs) calc(var(--eui-s-xs) - 2px) var(--eui-s-m);border-top:1px solid var(--eui-c-neutral-bg);text-decoration:none;width:100%}.eui-menu-item__link-start-block{align-items:center;display:flex;gap:var(--eui-s-xs)}.eui-menu-item__link-start-block:empty{display:none}.eui-menu-item__link-content-block{display:flex;flex-direction:column;width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.eui-menu-item__link-content-block .eui-menu-item__link-label-container{align-items:center;display:flex;position:relative;width:100%}.eui-menu-item__link-content-block .eui-menu-item__link-label-container .eui-menu-item__link-label{color:var(--eui-c-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.eui-menu-item__link-content-block .eui-menu-item__link-label-container .eui-menu-item__link-label-category{cursor:default;color:var(--eui-c-info-light);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.eui-menu-item__link-end-block{align-items:center;display:flex;gap:var(--eui-s-xs)}.eui-menu-item__link:hover:not(.eui-menu-item--disabled):not(.eui-menu-item__link-category){background-color:var(--eui-c-primary-bg);text-decoration:none}.eui-menu-item__link--disabled{opacity:var(--eui-o-50);pointer-events:none}.eui-menu-item__link--active:not(.eui-menu-item--disabled){background-color:var(--eui-c-primary-bg);font:var(--eui-f-m-bold)}.eui-menu-item__link--active:not(.eui-menu-item--disabled) .eui-menu-item__link-label{color:var(--eui-c-primary)}.eui-menu-item--expanded{display:flex;flex-direction:column}.eui-menu-item--expanded .eui-menu-item--expanded .eui-menu-sub .eui-menu-item__link{padding-left:var(--eui-s-3xl)}.eui-menu-item .eui-menu-sub .eui-menu-item__link{padding-left:var(--eui-s-xl);padding-bottom:var(--eui-s-2xs);padding-top:var(--eui-s-2xs);border-top:0}.eui-menu-item--bold>.eui-menu-item__content>.eui-menu-item__link{font:var(--eui-f-m-bold)}\n"] }]
|
448
448
|
}], ctorParameters: () => [{ type: i1.Router }, { type: i1.ActivatedRoute }, { type: i2.BaseStatesDirective }, { type: i0.ChangeDetectorRef }], propDecorators: { focusableItems: [{
|
449
449
|
type: ViewChildren,
|
450
450
|
args: [EuiMenuItemComponent]
|
@@ -496,4 +496,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-rc.1", ng
|
|
496
496
|
type: HostListener,
|
497
497
|
args: ['click', ['$event']]
|
498
498
|
}] } });
|
499
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eui-menu.component.js","sourceRoot":"","sources":["../../../eui-menu/eui-menu.component.ts","../../../eui-menu/eui-menu.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    HostBinding,\n    ViewEncapsulation,\n    Input,\n    OnInit,\n    Output,\n    EventEmitter,\n    OnChanges,\n    SimpleChanges,\n    HostListener,\n    booleanAttribute,\n    OnDestroy,\n    AfterViewInit,\n    ViewChildren,\n    QueryList,\n    ChangeDetectorRef,\n} from '@angular/core';\nimport { Router, ActivatedRoute } from '@angular/router';\nimport { coerceBooleanProperty } from '@angular/cdk/coercion';\nimport { FocusKeyManager } from '@angular/cdk/a11y';\nimport { Subscription } from 'rxjs';\nimport * as uuid from 'uuid';\n\nimport { consumeEvent } from '@eui/core';\nimport { BaseStatesDirective } from '@eui/components/shared';\nimport { EuiMenuItemComponent } from './eui-menu-item.component';\nimport { EuiMenuItem } from '@eui/base';\n@Component({\n    selector: 'eui-menu',\n    templateUrl: './eui-menu.component.html',\n    styleUrls: ['./styles/_index.scss'],\n    hostDirectives: [\n        {\n            directive: BaseStatesDirective,\n        },\n    ],\n    encapsulation: ViewEncapsulation.None,\n})\nexport class EuiMenuComponent implements OnInit, OnChanges, OnDestroy, AfterViewInit {\n    @ViewChildren(EuiMenuItemComponent) focusableItems: QueryList<EuiMenuItemComponent>;\n\n    @HostBinding('class')\n    public get cssClasses(): string {\n        return [this.baseStatesDirective.getCssClasses('eui-menu'),\n            this.isCollapsed ? 'eui-menu--collapsed' : '',\n            !this.hasIcons ? 'eui-menu--no-icons' : '',\n            this.isFlat ? 'eui-menu--flat': '',\n        ].join(' ').trim();\n    }\n\n    @Input() items: EuiMenuItem[];\n    @Input() searchFilterLabel: string;\n    @Input() externalLinkLabel: string;\n    @Input() fragmentId: string;\n    @Input() filterValue = '';\n\n    @Input({ transform: booleanAttribute }) isCollapsed = false;\n    @Input({ transform: booleanAttribute }) hasCollapsedInitials = false;\n    @Input({ transform: booleanAttribute }) hasFilter = false;\n    @Input({ transform: booleanAttribute }) hasIcons = false;\n    @Input({ transform: booleanAttribute }) hasTooltip = false;\n    @Input({ transform: booleanAttribute }) expandAllItems = false;\n    @Input({ transform: booleanAttribute }) isFlat = false;\n    @Input({ transform: booleanAttribute }) hasScrollToItem = false;\n    @Input({ transform: booleanAttribute }) hasBoldRootLevel = false;\n\n    @Output() isClick: EventEmitter<boolean> = new EventEmitter();\n    @Output() itemClick: EventEmitter<EuiMenuItem> = new EventEmitter<EuiMenuItem>();\n\n    // 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    itemsState: any[];\n    private subscription: Subscription;\n    private focusKeyManager: FocusKeyManager<EuiMenuItemComponent>;\n\n    constructor(\n        private router: Router,\n        private route: ActivatedRoute,\n        public baseStatesDirective: BaseStatesDirective,\n        private cd: ChangeDetectorRef,\n    ) {}\n\n    @HostListener('click', ['$event'])\n    stopPropagation(event: Event): void {\n        event.stopPropagation();\n    }\n\n    onKeydown(event: KeyboardEvent): void {\n        // finds first child when ArrowDown\n        const firstChild = this.focusKeyManager.activeItem?.item.children? this.findFirstFilteredItem(this.focusKeyManager.activeItem?.item.children) : undefined;\n        const firstFocusableItem = this.findFocusableItem(firstChild);\n        // finds the parent element\n        const parent = this.focusKeyManager.activeItem?.item.parent;\n        const parentFocusableItem = this.findFocusableItem(parent);\n        switch (event.key) {\n            case 'Enter': {\n                if (\n                    (this.focusKeyManager.activeItem.isLinkItem || this.focusKeyManager.activeItem.isUrlItem) &&\n                    !this.focusKeyManager.activeItem.disabled\n                ) {\n                    this.focusKeyManager.activeItem.onClick(event);\n                    event.preventDefault();\n                }\n                break;\n            }\n            case 'ArrowRight': {\n                if(this.focusKeyManager.activeItem?.item.actionIcon){\n                    this.checkActionIconFocusState();\n                    break;\n                } else {\n                    if (!this.focusKeyManager.activeItem?.item.expanded) {\n                        this.focusKeyManager.activeItem?.onExpandToggle(event);\n                        this.cd.detectChanges();\n                    }\n                    break;\n                }\n            }\n            case 'ArrowLeft': {\n                if(this.focusKeyManager.activeItem?.item.actionIcon){\n                    this.checkActionIconFocusState();\n                    break;\n                } else {\n                    if (this.focusKeyManager.activeItem?.item.expanded) {\n                        this.focusKeyManager.activeItem.onExpandToggle(event);\n                        this.cd.detectChanges();\n                        event.preventDefault();\n                    }\n                    break;\n                }\n            }\n            case 'ArrowDown': {\n                event.preventDefault();\n                if (this.focusKeyManager.activeItem?.item.children && this.focusKeyManager.activeItem?.item.expanded) {\n                    //focuses first child\n                    firstFocusableItem?.focus();\n                    this.focusKeyManager.updateActiveItem(firstFocusableItem);\n                } else if (parent) {\n                    // finds last filtered child when ArrowDown and navigating within submenu\n                    const filteredChildren = this.findFilteredItems(parent.children);\n                    const lastChildIndex = (filteredChildren?.length) - 1;\n                    const lastChild = filteredChildren[lastChildIndex];\n                    const lastFocusableItem = this.findFocusableItem(lastChild);\n                    // if the active item is the last child, puts the focus on the next parent\n                    if(this.focusKeyManager.activeItem === lastFocusableItem){\n                       this.focusKeyManager.updateActiveItem(parentFocusableItem);\n                       this.focusKeyManager.setNextItemActive();\n                    } else {\n                        this.focusKeyManager.setActiveItem(this.focusKeyManager.activeItemIndex +1);\n                    }\n                } else {\n                    // skips remaining childen in the query list when there is expanded node\n                    this.focusKeyManager.skipPredicate(menuItem => menuItem.parent != undefined || menuItem.item.visible === false);\n                    this.focusKeyManager.onKeydown(event);\n                }\n                break;\n            }\n            case 'ArrowUp': {\n                event.preventDefault();\n                if (parent) {\n                    // finds first filtered child when ArrowUp\n                    const filteredChildren = this.findFilteredItems(parent.children);\n                    const firstChildUp = filteredChildren['0']\n                    const firstFocusableItemUp = this.findFocusableItem(firstChildUp);\n                    // when navigating up on a submenu focuses the parent if the active item is the first child\n                    if(this.focusKeyManager.activeItem === firstFocusableItemUp){\n                        this.focusKeyManager.setActiveItem(parentFocusableItem);\n                     } else {\n                        this.focusKeyManager.setActiveItem(this.focusKeyManager.activeItemIndex -1);\n                     }\n                } else {\n                    this.focusKeyManager.onKeydown(event);\n                    // when navigating up from a parent element to an expanded submenu, finds the last child and focuses it\n                    if(this.focusKeyManager.activeItem?.item.children && this.focusKeyManager.activeItem?.item.expanded){\n                        const filteredChildren = this.findFilteredItems(this.focusKeyManager.activeItem?.item.children);\n                        const lastChildIndexUp = (filteredChildren.length) - 1;\n                        const lastFocusableItemUp =this.findFocusableItem(filteredChildren[lastChildIndexUp]);\n                        this.focusKeyManager.setActiveItem(lastFocusableItemUp);\n                    }\n                }\n                break;\n            }\n            default: {\n                this.focusKeyManager.onKeydown(event);\n                break;\n            }\n        }\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (changes.items) {\n            this.items = this.configureItems(this.items);\n            // get current url\n            const currentUrl = this.router.url;\n            // find an item that matches the current url or the most relevant one\n            const item = this.findMostRelevantItem(currentUrl, this.items);\n            // expand to that item\n            if (item) {\n                this.expandToGivenItem(item);\n            }\n        }\n\n        // Expand / Collapse All items\n        if (changes.expandAllItems) {\n            this.items = this.setExpandedToAllItems(coerceBooleanProperty(changes.expandAllItems.currentValue), this.items);\n        }\n\n        if (changes.filterValue && this.hasFilter) {\n            this.onFilter(changes.filterValue.currentValue ?? '');\n        }\n\n        // Refresh when interactive collapsed to initials\n        if (changes.hasCollapsedInitials) {\n            this.hasCollapsedInitials = changes.hasCollapsedInitials.currentValue;\n            this.items = this.configureItems(this.items);\n        }\n    }\n\n    ngOnInit(): void {\n        // Labels default values - TODO : translations\n        if (!this.searchFilterLabel) {\n            this.searchFilterLabel = 'Search filter';\n        }\n\n        const elementIsVisibleInViewport = (el, partiallyVisible = false): boolean => {\n            const { top, left, bottom, right } = el.getBoundingClientRect();\n            const { innerHeight, innerWidth } = window;\n            return partiallyVisible\n            ? ((top > 0 && top < innerHeight) ||\n            (bottom > 0 && bottom < innerHeight)) &&\n            ((left > 0 && left < innerWidth) || (right > 0 && right < innerWidth))\n            : top >= 0 && left >= 0 && bottom <= innerHeight && right <= innerWidth;\n        };\n\n        // subscription to routes url changes for activating the scrollIntoView (optional)\n        if (this.hasScrollToItem) {\n            const item = this.findMostRelevantItem(this.router.url, this.items);\n            if (item) {\n                setTimeout(_ => {\n                    const element = document.getElementById(item.id);\n                    if (!elementIsVisibleInViewport(element)) {\n                        element.scrollIntoView({ behavior: 'smooth' });\n                    }\n                }, 1);\n            }\n        }\n    }\n\n    ngAfterViewInit(): void {\n        // instantiates FocusKeyManager with the query list of items enabling wrapping\n        this.focusKeyManager = new FocusKeyManager(this.focusableItems).withWrap();\n    }\n\n    ngOnDestroy():void {\n        if (this.subscription) {\n            this.subscription.unsubscribe();\n        }\n    }\n\n    public onClick(item: EuiMenuItem): void {\n        if (!item.disabled) {\n            if (item.urlExternal) {\n                window.open(item.urlExternal, item.urlExternalTarget);\n            } else if (item.url) {\n                this.router.navigate([item.url], { relativeTo: this.route, fragment: this.fragmentId });\n            } else {\n                if (typeof item.command === 'function') {\n                    item.command();\n                } else {\n                    this.onExpandToggle(item);\n                }\n            }\n\n            if (item.link) {\n                this.items = this.items?.map((it) => {\n                    it.active = false;\n                    if (it.id === item.id) {\n                        it.active = true;\n                    }\n                    return it;\n                });\n            }\n        }\n\n        this.isClick.emit(true);\n        this.itemClick.emit(item);\n\n        const focusedItem = this.findFocusableItem(item);\n        this.focusKeyManager.updateActiveItem(focusedItem);\n    }\n\n    public onExpandToggle(item: EuiMenuItem): void {\n        if (item.children) {\n            this.onExpandToggled(item, this.items);\n            // TODO: investigate why the above is needed. Can it be simply \"item.expanded = !item.expanded;\" ?\n        }\n    }\n\n    public onMenuFilterClick(event: MouseEvent): void {\n        consumeEvent(event);\n    }\n\n    public onFilter(event: Event)\n    public onFilter(value: string)\n    public onFilter(eventOrValue: Event | string): void {\n        const value = eventOrValue instanceof Event\n            ? (eventOrValue.target as HTMLInputElement).value\n            : eventOrValue;\n        this._onToggleExpandAllItems(value ? true : false);\n\n        this.items = this.filterMenuItems(this.items, value);\n    }\n\n    private _onToggleExpandAllItems(state: boolean): void {\n        this.items = this.setExpandedToAllItems(state, this.items);\n    }\n\n    /**\n     * finds the EuiMenuItemComponent in the queried focusableItems[] that  matches the passed EuiMenuItem object\n     *\n     * @param menuItem an EuiMenuItem\n     * @private\n     */\n    private findFocusableItem(menuItem: EuiMenuItem ): EuiMenuItemComponent {\n        return this.focusableItems.find(\n            (focusableItem) => focusableItem.item.label === menuItem?.label && focusableItem.item.id === menuItem.id,\n        );\n    }\n\n    /**\n     * finds the first item that is filtered\n     *\n     * @param menuItems an array of EuiMenuItem\n     * @private\n     */\n    private findFirstFilteredItem(menuItems: EuiMenuItem []): EuiMenuItem {\n        return menuItems.find((item) => item.filtered);\n    }\n\n    /**\n     * finds all filtered menu items\n     *\n     * @param menuItems an array of EuiMenuItem\n     * @private\n     */\n    private findFilteredItems(menuItems: EuiMenuItem []): EuiMenuItem [] {\n        return menuItems.filter((items) => items.filtered);\n    }\n\n    /**\n     * checks the focus state of the action icon\n     *\n     * @private\n     */\n    private checkActionIconFocusState(): void {\n        // check if the action icon is focused and if not focus it, otherwise focus the active item\n        !this.focusKeyManager.activeItem.isActionIconFocused ? this.focusKeyManager.activeItem.focusActionIcon() : this.focusKeyManager.activeItem.focus();\n    }\n\n    /**\n     * filter all menu items given a value\n     *\n     * @param menuItems an array of menu items\n     * @param filterValue the value to filter menu items\n     * @private\n     */\n    private filterMenuItems(menuItems: EuiMenuItem[], filterValue: string): EuiMenuItem[] {\n        return menuItems?.map((item: EuiMenuItem) => {\n            const found = item.label.toLowerCase().indexOf(filterValue.toLowerCase()) !== -1;\n            if (item.children) {\n                item.children = this.filterMenuItems(item.children, filterValue);\n                item.filtered = item.children.filter((l) => l['filtered'] === true).length > 0;\n            } else if (found) {\n                item.filtered = found;\n            } else {\n                item.filtered = false;\n            }\n            return item;\n        });\n    }\n\n    /**\n     * expand / collapse all items\n     *\n     * @param isExpanded\n     * @param items\n     * @private\n     */\n    private setExpandedToAllItems(isExpanded, items: EuiMenuItem[]): EuiMenuItem[] {\n        return items?.map((item) => {\n            if (item.children) {\n                item.expanded = isExpanded;\n                item.children = this.setExpandedToAllItems(isExpanded, item.children);\n            }\n            return Object.assign(item, { visible: item.visible === undefined ? true : item.visible });\n        });\n    }\n\n    /**\n     * expand / collapse a menu item\n     *\n     * @param item The item where the \"expand\" had been toggled\n     * @param items The items list (used for recursion)\n     * @private\n     */\n    private onExpandToggled(item: EuiMenuItem, items: EuiMenuItem[]): void {\n        const itemIdx = items?.indexOf(item);\n        if (itemIdx > -1) {\n            items[itemIdx].expanded = !items[itemIdx].expanded;\n        } else {\n            items.forEach((i) => {\n                if (i.children) {\n                    this.onExpandToggled(item, i.children);\n                }\n            });\n        }\n    }\n\n    /**\n     * configure an array of items with visible, filtered and expand (in case of expandAllItems flag enabled) properties\n     *\n     * @param items An array of EuiMenuItem\n     * @param parent the parent item of items if exists\n     * @private\n     */\n    private configureItems(items: EuiMenuItem[], parent?: EuiMenuItem): EuiMenuItem[] {\n        return items?.map((item) => {\n            // recursion in case there are children\n            if (item.children) {\n                item.children = this.configureItems(item.children, item);\n                // expand all parents with children\n                if (this.expandAllItems) {\n                    item.expanded = true;\n                }\n            }\n            // point to the parent\n            if (parent) {\n                item.parent = parent;\n            }\n\n            if (!item.id && this.hasScrollToItem) {\n                item.id = uuid.v4();\n            }\n\n            if (item.label && this.hasCollapsedInitials) {\n                const words = item.label.split(' ');\n                if (words.length === 1) {\n                    item.initials = `${item.label.substring(0, 1)}${item.label.substring(1, 1)}`;\n\n                } else {\n                    item.initials = `${words[0].substring(0, 1)}${words[1].substring(0, 1)}`;\n                }\n            }\n\n            return Object.assign(item, { visible: item.visible === undefined ? true : item.visible, filtered: true });\n        });\n    }\n\n    /**\n     * Given a URL and a list of items, it will expand the item that matches the URL. If not item matches exactly the url, then it will\n     * match the item that is most relevant to that url.\n     *\n     * @param items\n     * @param value\n     * @private\n     */\n    private findMostRelevantItem(url: string, items: EuiMenuItem[], relevantItem?: EuiMenuItem): EuiMenuItem {\n        if (!items) {\n            return null;\n        }\n\n        items.forEach((item) => {\n            if (item.url && url.indexOf(item.url.substr(1)) > -1) {\n                relevantItem = this.getMostRelevantItem(url, relevantItem, item);\n            }\n\n            if (item.children) {\n                relevantItem = this.findMostRelevantItem(url, item.children, relevantItem);\n            }\n        });\n\n        return relevantItem;\n    }\n\n    /**\n     * Given two items with url return the one with the most relevant url that matches given url\n     *\n     * @param url A URL to be matched with the one of given items\n     * @param item1\n     * @param item2\n     * @private\n     */\n    private getMostRelevantItem(url: string, item1: EuiMenuItem, item2: EuiMenuItem): EuiMenuItem {\n        const remainder1 = url.replace(item1?.url || '', '');\n        const remainder2 = url.replace(item2?.url || '', '');\n\n        return remainder1.length < remainder2.length ? item1 : item2;\n    }\n\n    /**\n     * Given an item, if there's a parent expand it until you reach the root item\n     *\n     * @param item Given menu item\n     * @private\n     */\n    private expandToGivenItem(item: EuiMenuItem): void {\n        if (item.parent) {\n            setTimeout(() => (item.parent.expanded = true));\n            this.expandToGivenItem(item.parent);\n        }\n    }\n}\n","@if (hasFilter && !isCollapsed) {\n    <div class=\"eui-menu-filter\" (click)=\"onMenuFilterClick($event)\">\n        <eui-icon-input>\n            <eui-icon-svg icon=\"eui-search\" fillColor=\"neutral-lighter\" aria-label=\"Search Icon\"></eui-icon-svg>\n            <input\n                euiInputText\n                [euiClearable]=\"true\"\n                (input)=\"onFilter($event)\"\n                [placeholder]=\"searchFilterLabel\"\n                [attr.aria-label]=\"searchFilterLabel\"\n                [value]=\"filterValue\" />\n        </eui-icon-input>\n    </div>\n}\n\n<ul euiList class=\"eui-menu\" role=\"menubar\" aria-orientation=\"vertical\" tabindex=\"0\" (keydown)=\"onKeydown($event)\">\n    @if (items) {\n        <ng-template ngFor let-item let-index [ngForOf]=\"items\">\n            <ng-template [ngTemplateOutlet]=\"menuItemTemplateRef\" [ngTemplateOutletContext]=\"{ menuItem: item, index: index }\"> </ng-template>\n        </ng-template>\n    } @else {\n        <span class=\"eui-menu--no-items\">No menu items defined</span>\n    }\n</ul>\n\n<!-- describe the recursive template of the menu item -->\n<ng-template #menuItemTemplateRef let-item=\"menuItem\" let-parent=\"parent\" let-i=\"index\">\n    <!-- render the menu item-->\n    <eui-menu-item\n        *ngIf=\"item.filtered\"\n        [item]=\"item\"\n        [parent]=\"parent\"\n        [hasIcon]=\"hasIcons\"\n        [hasTooltip]=\"hasTooltip\"\n        [isCollapsed]=\"isCollapsed\"\n        [hasBoldRootLevel]=\"hasBoldRootLevel\"\n        [hasCollapsedInitials]=\"hasCollapsedInitials\"\n        (expandToggle)=\"onExpandToggle($event)\"\n        (itemClick)=\"onClick($event)\">\n        <!-- if the menu item has children, render the children -->\n        <ul euiList *ngIf=\"item.children && item.expanded\" class=\"eui-menu eui-menu-sub\" role=\"menu\" [attr.aria-label]=\"item.label\" tabindex=\"-1\">\n            <ng-container *ngFor=\"let child of item.children; let childIndex = index\">\n                <ng-template [ngTemplateOutlet]=\"menuItemTemplateRef\" [ngTemplateOutletContext]=\"{ menuItem: child, index: childIndex, parent: item }\">\n                </ng-template>\n            </ng-container>\n        </ul>\n    </eui-menu-item>\n</ng-template>\n"]}
|
499
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eui-menu.component.js","sourceRoot":"","sources":["../../../eui-menu/eui-menu.component.ts","../../../eui-menu/eui-menu.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    HostBinding,\n    ViewEncapsulation,\n    Input,\n    OnInit,\n    Output,\n    EventEmitter,\n    OnChanges,\n    SimpleChanges,\n    HostListener,\n    booleanAttribute,\n    OnDestroy,\n    AfterViewInit,\n    ViewChildren,\n    QueryList,\n    ChangeDetectorRef,\n} from '@angular/core';\nimport { Router, ActivatedRoute } from '@angular/router';\nimport { coerceBooleanProperty } from '@angular/cdk/coercion';\nimport { FocusKeyManager } from '@angular/cdk/a11y';\nimport { Subscription } from 'rxjs';\nimport * as uuid from 'uuid';\n\nimport { consumeEvent } from '@eui/core';\nimport { BaseStatesDirective } from '@eui/components/shared';\nimport { EuiMenuItemComponent } from './eui-menu-item.component';\nimport { EuiMenuItem } from '@eui/base';\n@Component({\n    selector: 'eui-menu',\n    templateUrl: './eui-menu.component.html',\n    styleUrls: ['./styles/_index.scss'],\n    hostDirectives: [\n        {\n            directive: BaseStatesDirective,\n        },\n    ],\n    encapsulation: ViewEncapsulation.None,\n})\nexport class EuiMenuComponent implements OnInit, OnChanges, OnDestroy, AfterViewInit {\n    @ViewChildren(EuiMenuItemComponent) focusableItems: QueryList<EuiMenuItemComponent>;\n\n    @HostBinding('class')\n    public get cssClasses(): string {\n        return [this.baseStatesDirective.getCssClasses('eui-menu'),\n            this.isCollapsed ? 'eui-menu--collapsed' : '',\n            !this.hasIcons ? 'eui-menu--no-icons' : '',\n            this.isFlat ? 'eui-menu--flat': '',\n        ].join(' ').trim();\n    }\n\n    @Input() items: EuiMenuItem[];\n    @Input() searchFilterLabel: string;\n    @Input() externalLinkLabel: string;\n    @Input() fragmentId: string;\n    @Input() filterValue = '';\n\n    @Input({ transform: booleanAttribute }) isCollapsed = false;\n    @Input({ transform: booleanAttribute }) hasCollapsedInitials = false;\n    @Input({ transform: booleanAttribute }) hasFilter = false;\n    @Input({ transform: booleanAttribute }) hasIcons = false;\n    @Input({ transform: booleanAttribute }) hasTooltip = false;\n    @Input({ transform: booleanAttribute }) expandAllItems = false;\n    @Input({ transform: booleanAttribute }) isFlat = false;\n    @Input({ transform: booleanAttribute }) hasScrollToItem = false;\n    @Input({ transform: booleanAttribute }) hasBoldRootLevel = false;\n\n    @Output() isClick: EventEmitter<boolean> = new EventEmitter();\n    @Output() itemClick: EventEmitter<EuiMenuItem> = new EventEmitter<EuiMenuItem>();\n\n    // 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    itemsState: any[];\n    private subscription: Subscription;\n    private focusKeyManager: FocusKeyManager<EuiMenuItemComponent>;\n\n    constructor(\n        private router: Router,\n        private route: ActivatedRoute,\n        public baseStatesDirective: BaseStatesDirective,\n        private cd: ChangeDetectorRef,\n    ) {}\n\n    @HostListener('click', ['$event'])\n    stopPropagation(event: Event): void {\n        event.stopPropagation();\n    }\n\n    onKeydown(event: KeyboardEvent): void {\n        // finds first child when ArrowDown\n        const firstChild = this.focusKeyManager.activeItem?.item.children? this.findFirstFilteredItem(this.focusKeyManager.activeItem?.item.children) : undefined;\n        const firstFocusableItem = this.findFocusableItem(firstChild);\n        // finds the parent element\n        const parent = this.focusKeyManager.activeItem?.item.parent;\n        const parentFocusableItem = this.findFocusableItem(parent);\n        switch (event.key) {\n            case 'Enter': {\n                if (\n                    (this.focusKeyManager.activeItem.isLinkItem || this.focusKeyManager.activeItem.isUrlItem) &&\n                    !this.focusKeyManager.activeItem.disabled\n                ) {\n                    this.focusKeyManager.activeItem.onClick(event);\n                    event.preventDefault();\n                }\n                break;\n            }\n            case 'ArrowRight': {\n                if(this.focusKeyManager.activeItem?.item.actionIcon){\n                    this.checkActionIconFocusState();\n                    break;\n                } else {\n                    if (!this.focusKeyManager.activeItem?.item.expanded) {\n                        this.focusKeyManager.activeItem?.onExpandToggle(event);\n                        this.cd.detectChanges();\n                    }\n                    break;\n                }\n            }\n            case 'ArrowLeft': {\n                if(this.focusKeyManager.activeItem?.item.actionIcon){\n                    this.checkActionIconFocusState();\n                    break;\n                } else {\n                    if (this.focusKeyManager.activeItem?.item.expanded) {\n                        this.focusKeyManager.activeItem.onExpandToggle(event);\n                        this.cd.detectChanges();\n                        event.preventDefault();\n                    }\n                    break;\n                }\n            }\n            case 'ArrowDown': {\n                event.preventDefault();\n                if (this.focusKeyManager.activeItem?.item.children && this.focusKeyManager.activeItem?.item.expanded) {\n                    //focuses first child\n                    firstFocusableItem?.focus();\n                    this.focusKeyManager.updateActiveItem(firstFocusableItem);\n                } else if (parent) {\n                    // finds last filtered child when ArrowDown and navigating within submenu\n                    const filteredChildren = this.findFilteredItems(parent.children);\n                    const lastChildIndex = (filteredChildren?.length) - 1;\n                    const lastChild = filteredChildren[lastChildIndex];\n                    const lastFocusableItem = this.findFocusableItem(lastChild);\n                    // if the active item is the last child, puts the focus on the next parent\n                    if(this.focusKeyManager.activeItem === lastFocusableItem){\n                       this.focusKeyManager.updateActiveItem(parentFocusableItem);\n                       this.focusKeyManager.setNextItemActive();\n                    } else {\n                        this.focusKeyManager.setActiveItem(this.focusKeyManager.activeItemIndex +1);\n                    }\n                } else {\n                    // skips remaining childen in the query list when there is expanded node\n                    this.focusKeyManager.skipPredicate(menuItem => menuItem.parent != undefined || menuItem.item.visible === false);\n                    this.focusKeyManager.onKeydown(event);\n                }\n                break;\n            }\n            case 'ArrowUp': {\n                event.preventDefault();\n                if (parent) {\n                    // finds first filtered child when ArrowUp\n                    const filteredChildren = this.findFilteredItems(parent.children);\n                    const firstChildUp = filteredChildren['0']\n                    const firstFocusableItemUp = this.findFocusableItem(firstChildUp);\n                    // when navigating up on a submenu focuses the parent if the active item is the first child\n                    if(this.focusKeyManager.activeItem === firstFocusableItemUp){\n                        this.focusKeyManager.setActiveItem(parentFocusableItem);\n                     } else {\n                        this.focusKeyManager.setActiveItem(this.focusKeyManager.activeItemIndex -1);\n                     }\n                } else {\n                    this.focusKeyManager.onKeydown(event);\n                    // when navigating up from a parent element to an expanded submenu, finds the last child and focuses it\n                    if(this.focusKeyManager.activeItem?.item.children && this.focusKeyManager.activeItem?.item.expanded){\n                        const filteredChildren = this.findFilteredItems(this.focusKeyManager.activeItem?.item.children);\n                        const lastChildIndexUp = (filteredChildren.length) - 1;\n                        const lastFocusableItemUp =this.findFocusableItem(filteredChildren[lastChildIndexUp]);\n                        this.focusKeyManager.setActiveItem(lastFocusableItemUp);\n                    }\n                }\n                break;\n            }\n            default: {\n                this.focusKeyManager.onKeydown(event);\n                break;\n            }\n        }\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (changes.items) {\n            this.items = this.configureItems(this.items);\n            // get current url\n            const currentUrl = this.router.url;\n            // find an item that matches the current url or the most relevant one\n            const item = this.findMostRelevantItem(currentUrl, this.items);\n            // expand to that item\n            if (item) {\n                this.expandToGivenItem(item);\n            }\n        }\n\n        // Expand / Collapse All items\n        if (changes.expandAllItems) {\n            this.items = this.setExpandedToAllItems(coerceBooleanProperty(changes.expandAllItems.currentValue), this.items);\n        }\n\n        if (changes.filterValue && this.hasFilter) {\n            this.onFilter(changes.filterValue.currentValue ?? '');\n        }\n\n        // Refresh when interactive collapsed to initials\n        if (changes.hasCollapsedInitials) {\n            this.hasCollapsedInitials = changes.hasCollapsedInitials.currentValue;\n            this.items = this.configureItems(this.items);\n        }\n    }\n\n    ngOnInit(): void {\n        // Labels default values - TODO : translations\n        if (!this.searchFilterLabel) {\n            this.searchFilterLabel = 'Search filter';\n        }\n\n        const elementIsVisibleInViewport = (el, partiallyVisible = false): boolean => {\n            const { top, left, bottom, right } = el.getBoundingClientRect();\n            const { innerHeight, innerWidth } = window;\n            return partiallyVisible\n            ? ((top > 0 && top < innerHeight) ||\n            (bottom > 0 && bottom < innerHeight)) &&\n            ((left > 0 && left < innerWidth) || (right > 0 && right < innerWidth))\n            : top >= 0 && left >= 0 && bottom <= innerHeight && right <= innerWidth;\n        };\n\n        // subscription to routes url changes for activating the scrollIntoView (optional)\n        if (this.hasScrollToItem) {\n            const item = this.findMostRelevantItem(this.router.url, this.items);\n            if (item) {\n                setTimeout(_ => {\n                    const element = document.getElementById(item.id);\n                    if (!elementIsVisibleInViewport(element)) {\n                        element.scrollIntoView({ behavior: 'smooth' });\n                    }\n                }, 1);\n            }\n        }\n    }\n\n    ngAfterViewInit(): void {\n        // instantiates FocusKeyManager with the query list of items enabling wrapping\n        this.focusKeyManager = new FocusKeyManager(this.focusableItems).withWrap();\n    }\n\n    ngOnDestroy():void {\n        if (this.subscription) {\n            this.subscription.unsubscribe();\n        }\n    }\n\n    public onClick(item: EuiMenuItem): void {\n        if (!item.disabled) {\n            if (item.urlExternal) {\n                window.open(item.urlExternal, item.urlExternalTarget);\n            } else if (item.url) {\n                this.router.navigate([item.url], { relativeTo: this.route, fragment: this.fragmentId });\n            } else {\n                if (typeof item.command === 'function') {\n                    item.command();\n                } else {\n                    this.onExpandToggle(item);\n                }\n            }\n\n            if (item.link) {\n                this.items = this.items?.map((it) => {\n                    it.active = false;\n                    if (it.id === item.id) {\n                        it.active = true;\n                    }\n                    return it;\n                });\n            }\n        }\n\n        this.isClick.emit(true);\n        this.itemClick.emit(item);\n\n        const focusedItem = this.findFocusableItem(item);\n        this.focusKeyManager.updateActiveItem(focusedItem);\n    }\n\n    public onExpandToggle(item: EuiMenuItem): void {\n        if (item.children) {\n            this.onExpandToggled(item, this.items);\n            // TODO: investigate why the above is needed. Can it be simply \"item.expanded = !item.expanded;\" ?\n        }\n    }\n\n    public onMenuFilterClick(event: MouseEvent): void {\n        consumeEvent(event);\n    }\n\n    public onFilter(event: Event)\n    public onFilter(value: string)\n    public onFilter(eventOrValue: Event | string): void {\n        const value = eventOrValue instanceof Event\n            ? (eventOrValue.target as HTMLInputElement).value\n            : eventOrValue;\n        this._onToggleExpandAllItems(value ? true : false);\n\n        this.items = this.filterMenuItems(this.items, value);\n    }\n\n    private _onToggleExpandAllItems(state: boolean): void {\n        this.items = this.setExpandedToAllItems(state, this.items);\n    }\n\n    /**\n     * finds the EuiMenuItemComponent in the queried focusableItems[] that  matches the passed EuiMenuItem object\n     *\n     * @param menuItem an EuiMenuItem\n     * @private\n     */\n    private findFocusableItem(menuItem: EuiMenuItem ): EuiMenuItemComponent {\n        return this.focusableItems.find(\n            (focusableItem) => focusableItem.item.label === menuItem?.label && focusableItem.item.id === menuItem.id,\n        );\n    }\n\n    /**\n     * finds the first item that is filtered\n     *\n     * @param menuItems an array of EuiMenuItem\n     * @private\n     */\n    private findFirstFilteredItem(menuItems: EuiMenuItem []): EuiMenuItem {\n        return menuItems.find((item) => item.filtered);\n    }\n\n    /**\n     * finds all filtered menu items\n     *\n     * @param menuItems an array of EuiMenuItem\n     * @private\n     */\n    private findFilteredItems(menuItems: EuiMenuItem []): EuiMenuItem [] {\n        return menuItems.filter((items) => items.filtered);\n    }\n\n    /**\n     * checks the focus state of the action icon\n     *\n     * @private\n     */\n    private checkActionIconFocusState(): void {\n        // check if the action icon is focused and if not focus it, otherwise focus the active item\n        !this.focusKeyManager.activeItem.isActionIconFocused ? this.focusKeyManager.activeItem.focusActionIcon() : this.focusKeyManager.activeItem.focus();\n    }\n\n    /**\n     * filter all menu items given a value\n     *\n     * @param menuItems an array of menu items\n     * @param filterValue the value to filter menu items\n     * @private\n     */\n    private filterMenuItems(menuItems: EuiMenuItem[], filterValue: string): EuiMenuItem[] {\n        return menuItems?.map((item: EuiMenuItem) => {\n            const found = item.label.toLowerCase().indexOf(filterValue.toLowerCase()) !== -1;\n            if (item.children) {\n                item.children = this.filterMenuItems(item.children, filterValue);\n                item.filtered = item.children.filter((l) => l['filtered'] === true).length > 0;\n            } else if (found) {\n                item.filtered = found;\n            } else {\n                item.filtered = false;\n            }\n            return item;\n        });\n    }\n\n    /**\n     * expand / collapse all items\n     *\n     * @param isExpanded\n     * @param items\n     * @private\n     */\n    private setExpandedToAllItems(isExpanded, items: EuiMenuItem[]): EuiMenuItem[] {\n        return items?.map((item) => {\n            if (item.children) {\n                item.expanded = isExpanded;\n                item.children = this.setExpandedToAllItems(isExpanded, item.children);\n            }\n            return Object.assign(item, { visible: item.visible === undefined ? true : item.visible });\n        });\n    }\n\n    /**\n     * expand / collapse a menu item\n     *\n     * @param item The item where the \"expand\" had been toggled\n     * @param items The items list (used for recursion)\n     * @private\n     */\n    private onExpandToggled(item: EuiMenuItem, items: EuiMenuItem[]): void {\n        const itemIdx = items?.indexOf(item);\n        if (itemIdx > -1) {\n            items[itemIdx].expanded = !items[itemIdx].expanded;\n        } else {\n            items.forEach((i) => {\n                if (i.children) {\n                    this.onExpandToggled(item, i.children);\n                }\n            });\n        }\n    }\n\n    /**\n     * configure an array of items with visible, filtered and expand (in case of expandAllItems flag enabled) properties\n     *\n     * @param items An array of EuiMenuItem\n     * @param parent the parent item of items if exists\n     * @private\n     */\n    private configureItems(items: EuiMenuItem[], parent?: EuiMenuItem): EuiMenuItem[] {\n        return items?.map((item) => {\n            // recursion in case there are children\n            if (item.children) {\n                item.children = this.configureItems(item.children, item);\n                // expand all parents with children\n                if (this.expandAllItems) {\n                    item.expanded = true;\n                }\n            }\n            // point to the parent\n            if (parent) {\n                item.parent = parent;\n            }\n\n            if (!item.id && this.hasScrollToItem) {\n                item.id = uuid.v4();\n            }\n\n            if (item.label && this.hasCollapsedInitials) {\n                const words = item.label.split(' ');\n                if (words.length === 1) {\n                    item.initials = `${item.label.substring(0, 1)}${item.label.substring(1, 1)}`;\n\n                } else {\n                    item.initials = `${words[0].substring(0, 1)}${words[1].substring(0, 1)}`;\n                }\n            }\n\n            return Object.assign(item, { visible: item.visible === undefined ? true : item.visible, filtered: true });\n        });\n    }\n\n    /**\n     * Given a URL and a list of items, it will expand the item that matches the URL. If not item matches exactly the url, then it will\n     * match the item that is most relevant to that url.\n     *\n     * @param items\n     * @param value\n     * @private\n     */\n    private findMostRelevantItem(url: string, items: EuiMenuItem[], relevantItem?: EuiMenuItem): EuiMenuItem {\n        if (!items) {\n            return null;\n        }\n\n        items.forEach((item) => {\n            if (item.url && url.indexOf(item.url.substr(1)) > -1) {\n                relevantItem = this.getMostRelevantItem(url, relevantItem, item);\n            }\n\n            if (item.children) {\n                relevantItem = this.findMostRelevantItem(url, item.children, relevantItem);\n            }\n        });\n\n        return relevantItem;\n    }\n\n    /**\n     * Given two items with url return the one with the most relevant url that matches given url\n     *\n     * @param url A URL to be matched with the one of given items\n     * @param item1\n     * @param item2\n     * @private\n     */\n    private getMostRelevantItem(url: string, item1: EuiMenuItem, item2: EuiMenuItem): EuiMenuItem {\n        const remainder1 = url.replace(item1?.url || '', '');\n        const remainder2 = url.replace(item2?.url || '', '');\n\n        return remainder1.length < remainder2.length ? item1 : item2;\n    }\n\n    /**\n     * Given an item, if there's a parent expand it until you reach the root item\n     *\n     * @param item Given menu item\n     * @private\n     */\n    private expandToGivenItem(item: EuiMenuItem): void {\n        if (item.parent) {\n            setTimeout(() => (item.parent.expanded = true));\n            this.expandToGivenItem(item.parent);\n        }\n    }\n}\n","@if (hasFilter && !isCollapsed) {\n    <div class=\"eui-menu-filter\" (click)=\"onMenuFilterClick($event)\">\n        <eui-icon-input>\n            <eui-icon-svg icon=\"eui-ecl-search\" fillColor=\"neutral-lighter\" aria-label=\"Search Icon\"></eui-icon-svg>\n            <input\n                euiInputText\n                [euiClearable]=\"true\"\n                (input)=\"onFilter($event)\"\n                [placeholder]=\"searchFilterLabel\"\n                [attr.aria-label]=\"searchFilterLabel\"\n                [value]=\"filterValue\" />\n        </eui-icon-input>\n    </div>\n}\n\n<ul euiList class=\"eui-menu\" role=\"menubar\" aria-orientation=\"vertical\" tabindex=\"0\" (keydown)=\"onKeydown($event)\">\n    @if (items) {\n        <ng-template ngFor let-item let-index [ngForOf]=\"items\">\n            <ng-template [ngTemplateOutlet]=\"menuItemTemplateRef\" [ngTemplateOutletContext]=\"{ menuItem: item, index: index }\"> </ng-template>\n        </ng-template>\n    } @else {\n        <span class=\"eui-menu--no-items\">No menu items defined</span>\n    }\n</ul>\n\n<!-- describe the recursive template of the menu item -->\n<ng-template #menuItemTemplateRef let-item=\"menuItem\" let-parent=\"parent\" let-i=\"index\">\n    <!-- render the menu item-->\n    <eui-menu-item\n        *ngIf=\"item.filtered\"\n        [item]=\"item\"\n        [parent]=\"parent\"\n        [hasIcon]=\"hasIcons\"\n        [hasTooltip]=\"hasTooltip\"\n        [isCollapsed]=\"isCollapsed\"\n        [hasBoldRootLevel]=\"hasBoldRootLevel\"\n        [hasCollapsedInitials]=\"hasCollapsedInitials\"\n        (expandToggle)=\"onExpandToggle($event)\"\n        (itemClick)=\"onClick($event)\">\n        <!-- if the menu item has children, render the children -->\n        <ul euiList *ngIf=\"item.children && item.expanded\" class=\"eui-menu eui-menu-sub\" role=\"menu\" [attr.aria-label]=\"item.label\" tabindex=\"-1\">\n            <ng-container *ngFor=\"let child of item.children; let childIndex = index\">\n                <ng-template [ngTemplateOutlet]=\"menuItemTemplateRef\" [ngTemplateOutletContext]=\"{ menuItem: child, index: childIndex, parent: item }\">\n                </ng-template>\n            </ng-container>\n        </ul>\n    </eui-menu-item>\n</ng-template>\n"]}
|
@@ -19,11 +19,11 @@ export class EuiOverlayHeaderTitleComponent {
|
|
19
19
|
this.hide.emit();
|
20
20
|
}
|
21
21
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0-rc.1", ngImport: i0, type: EuiOverlayHeaderTitleComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
22
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.0-rc.1", type: EuiOverlayHeaderTitleComponent, selector: "eui-overlay-header-title", inputs: { headerTitleLabel: "headerTitleLabel", headerTitleHideLabel: "headerTitleHideLabel", headerTitleCount: "headerTitleCount" }, outputs: { hide: "hide" }, host: { properties: { "class": "this.cssClasses" } }, ngImport: i0, template: "<div class=\"eui-overlay-header-title\">\n <div class=\"eui-overlay-header-title__label-wrapper\">\n <div class=\"eui-overlay-header-title__label\">\n {{ headerTitleLabel }}\n <eui-badge euiSizeL *ngIf=\"headerTitleCount\" class=\"eui-overlay-header-title__label-count eui-u-ml-s\">\n {{ headerTitleCount }}\n </eui-badge>\n </div>\n\n <div class=\"eui-overlay-header-title__actions\">\n <div *ngIf=\"headerTitleHideLabel\" class=\"eui-overlay-header-title__actions-hide\">\n <a (click)=\"onHide()\" class=\"eui-overlay-header-title__actions-hide-link eui-u-text-link\" role=\"button\" tabindex=\"0\">\n <span euiLabel>{{ headerTitleHideLabel }}</span>\n <eui-icon-svg icon=\"
|
22
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.0-rc.1", type: EuiOverlayHeaderTitleComponent, selector: "eui-overlay-header-title", inputs: { headerTitleLabel: "headerTitleLabel", headerTitleHideLabel: "headerTitleHideLabel", headerTitleCount: "headerTitleCount" }, outputs: { hide: "hide" }, host: { properties: { "class": "this.cssClasses" } }, ngImport: i0, template: "<div class=\"eui-overlay-header-title\">\n <div class=\"eui-overlay-header-title__label-wrapper\">\n <div class=\"eui-overlay-header-title__label\">\n {{ headerTitleLabel }}\n <eui-badge euiSizeL *ngIf=\"headerTitleCount\" class=\"eui-overlay-header-title__label-count eui-u-ml-s\">\n {{ headerTitleCount }}\n </eui-badge>\n </div>\n\n <div class=\"eui-overlay-header-title__actions\">\n <div *ngIf=\"headerTitleHideLabel\" class=\"eui-overlay-header-title__actions-hide\">\n <a (click)=\"onHide()\" class=\"eui-overlay-header-title__actions-hide-link eui-u-text-link\" role=\"button\" tabindex=\"0\">\n <span euiLabel>{{ headerTitleHideLabel }}</span>\n <eui-icon-svg icon=\"chevron-forward:sharp\" size=\"s\" fillColor=\"primary\" class=\"eui-u-ml-xs\"></eui-icon-svg>\n </a>\n </div>\n </div>\n </div>\n\n <div class=\"eui-overlay-header-title__subactions-bar\">\n <ng-content></ng-content>\n </div>\n</div>\n", dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.EuiBadgeComponent, selector: "div[euiBadge], span[euiBadge], eui-badge", inputs: ["e2eAttr", "aria-label"] }, { kind: "component", type: i3.EuiIconSvgComponent, selector: "eui-icon-svg, span[euiIconSvg], i[euiIconSvg]", inputs: ["icon", "fillColor", "set", "size", "ariaLabelledby", "role", "style", "iconUrl", "transform", "aria-label", "ariaHidden", "focusable", "isLoading", "isInputIcon", "euiStart", "euiEnd"] }], encapsulation: i0.ViewEncapsulation.None }); }
|
23
23
|
}
|
24
24
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-rc.1", ngImport: i0, type: EuiOverlayHeaderTitleComponent, decorators: [{
|
25
25
|
type: Component,
|
26
|
-
args: [{ selector: 'eui-overlay-header-title', encapsulation: ViewEncapsulation.None, template: "<div class=\"eui-overlay-header-title\">\n <div class=\"eui-overlay-header-title__label-wrapper\">\n <div class=\"eui-overlay-header-title__label\">\n {{ headerTitleLabel }}\n <eui-badge euiSizeL *ngIf=\"headerTitleCount\" class=\"eui-overlay-header-title__label-count eui-u-ml-s\">\n {{ headerTitleCount }}\n </eui-badge>\n </div>\n\n <div class=\"eui-overlay-header-title__actions\">\n <div *ngIf=\"headerTitleHideLabel\" class=\"eui-overlay-header-title__actions-hide\">\n <a (click)=\"onHide()\" class=\"eui-overlay-header-title__actions-hide-link eui-u-text-link\" role=\"button\" tabindex=\"0\">\n <span euiLabel>{{ headerTitleHideLabel }}</span>\n <eui-icon-svg icon=\"
|
26
|
+
args: [{ selector: 'eui-overlay-header-title', encapsulation: ViewEncapsulation.None, template: "<div class=\"eui-overlay-header-title\">\n <div class=\"eui-overlay-header-title__label-wrapper\">\n <div class=\"eui-overlay-header-title__label\">\n {{ headerTitleLabel }}\n <eui-badge euiSizeL *ngIf=\"headerTitleCount\" class=\"eui-overlay-header-title__label-count eui-u-ml-s\">\n {{ headerTitleCount }}\n </eui-badge>\n </div>\n\n <div class=\"eui-overlay-header-title__actions\">\n <div *ngIf=\"headerTitleHideLabel\" class=\"eui-overlay-header-title__actions-hide\">\n <a (click)=\"onHide()\" class=\"eui-overlay-header-title__actions-hide-link eui-u-text-link\" role=\"button\" tabindex=\"0\">\n <span euiLabel>{{ headerTitleHideLabel }}</span>\n <eui-icon-svg icon=\"chevron-forward:sharp\" size=\"s\" fillColor=\"primary\" class=\"eui-u-ml-xs\"></eui-icon-svg>\n </a>\n </div>\n </div>\n </div>\n\n <div class=\"eui-overlay-header-title__subactions-bar\">\n <ng-content></ng-content>\n </div>\n</div>\n" }]
|
27
27
|
}], propDecorators: { cssClasses: [{
|
28
28
|
type: HostBinding,
|
29
29
|
args: ['class']
|
@@ -36,4 +36,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-rc.1", ng
|
|
36
36
|
}], hide: [{
|
37
37
|
type: Output
|
38
38
|
}] } });
|
39
|
-
//# sourceMappingURL=data:application/json;base64,
|
39
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXVpLW92ZXJsYXktaGVhZGVyLXRpdGxlLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2V1aS1vdmVybGF5L2NvbXBvbmVudHMvZXVpLW92ZXJsYXktaGVhZGVyL2V1aS1vdmVybGF5LWhlYWRlci10aXRsZS9ldWktb3ZlcmxheS1oZWFkZXItdGl0bGUuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vZXVpLW92ZXJsYXkvY29tcG9uZW50cy9ldWktb3ZlcmxheS1oZWFkZXIvZXVpLW92ZXJsYXktaGVhZGVyLXRpdGxlL2V1aS1vdmVybGF5LWhlYWRlci10aXRsZS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFdBQVcsRUFBRSxpQkFBaUIsRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLFlBQVksRUFBRSxNQUFNLGVBQWUsQ0FBQzs7Ozs7QUFPdkcsTUFBTSxPQUFPLDhCQUE4QjtJQUwzQztRQVdhLHFCQUFnQixHQUFXLElBQUksQ0FBQztRQUNoQyx5QkFBb0IsR0FBVyxJQUFJLENBQUM7UUFDcEMscUJBQWdCLEdBQVcsSUFBSSxDQUFDO1FBRXpDLG1IQUFtSDtRQUNuSCw4REFBOEQ7UUFDcEQsU0FBSSxHQUFzQixJQUFJLFlBQVksRUFBTyxDQUFDO0tBSy9EO0lBaEJHLElBQ0ksVUFBVTtRQUNWLE9BQU8sMEJBQTBCLENBQUM7SUFDdEMsQ0FBQztJQVVELE1BQU07UUFDRixJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDO0lBQ3JCLENBQUM7bUhBaEJRLDhCQUE4Qjt1R0FBOUIsOEJBQThCLHVSQ1AzQywya0NBdUJBOztnR0RoQmEsOEJBQThCO2tCQUwxQyxTQUFTOytCQUNJLDBCQUEwQixpQkFFckIsaUJBQWlCLENBQUMsSUFBSTs4QkFJakMsVUFBVTtzQkFEYixXQUFXO3VCQUFDLE9BQU87Z0JBS1gsZ0JBQWdCO3NCQUF4QixLQUFLO2dCQUNHLG9CQUFvQjtzQkFBNUIsS0FBSztnQkFDRyxnQkFBZ0I7c0JBQXhCLEtBQUs7Z0JBSUksSUFBSTtzQkFBYixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBIb3N0QmluZGluZywgVmlld0VuY2Fwc3VsYXRpb24sIElucHV0LCBPdXRwdXQsIEV2ZW50RW1pdHRlciB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ2V1aS1vdmVybGF5LWhlYWRlci10aXRsZScsXG4gICAgdGVtcGxhdGVVcmw6ICcuL2V1aS1vdmVybGF5LWhlYWRlci10aXRsZS5jb21wb25lbnQuaHRtbCcsXG4gICAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZSxcbn0pXG5leHBvcnQgY2xhc3MgRXVpT3ZlcmxheUhlYWRlclRpdGxlQ29tcG9uZW50IHtcbiAgICBASG9zdEJpbmRpbmcoJ2NsYXNzJylcbiAgICBnZXQgY3NzQ2xhc3NlcygpOiBzdHJpbmcge1xuICAgICAgICByZXR1cm4gJ2V1aS1vdmVybGF5LWhlYWRlci10aXRsZSc7XG4gICAgfVxuXG4gICAgQElucHV0KCkgaGVhZGVyVGl0bGVMYWJlbDogc3RyaW5nID0gbnVsbDtcbiAgICBASW5wdXQoKSBoZWFkZXJUaXRsZUhpZGVMYWJlbDogc3RyaW5nID0gbnVsbDtcbiAgICBASW5wdXQoKSBoZWFkZXJUaXRsZUNvdW50OiBzdHJpbmcgPSBudWxsO1xuXG4gICAgLy8gVE9ETzogZmluZCB0aGUgY29ycmVjdCB0eXBlIG9yIHR1cm4gaW50byBhIGdlbmVyaWMsIGh0dHBzOi8vd3d3LnR5cGVzY3JpcHRsYW5nLm9yZy9kb2NzL2hhbmRib29rLzIvZ2VuZXJpY3MuaHRtbFxuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tZXhwbGljaXQtYW55XG4gICAgQE91dHB1dCgpIGhpZGU6IEV2ZW50RW1pdHRlcjxhbnk+ID0gbmV3IEV2ZW50RW1pdHRlcjxhbnk+KCk7XG5cbiAgICBvbkhpZGUoKTogdm9pZCB7XG4gICAgICAgIHRoaXMuaGlkZS5lbWl0KCk7XG4gICAgfVxufVxuIiwiPGRpdiBjbGFzcz1cImV1aS1vdmVybGF5LWhlYWRlci10aXRsZVwiPlxuICAgIDxkaXYgY2xhc3M9XCJldWktb3ZlcmxheS1oZWFkZXItdGl0bGVfX2xhYmVsLXdyYXBwZXJcIj5cbiAgICAgICAgPGRpdiBjbGFzcz1cImV1aS1vdmVybGF5LWhlYWRlci10aXRsZV9fbGFiZWxcIj5cbiAgICAgICAgICAgIHt7IGhlYWRlclRpdGxlTGFiZWwgfX1cbiAgICAgICAgICAgIDxldWktYmFkZ2UgZXVpU2l6ZUwgKm5nSWY9XCJoZWFkZXJUaXRsZUNvdW50XCIgY2xhc3M9XCJldWktb3ZlcmxheS1oZWFkZXItdGl0bGVfX2xhYmVsLWNvdW50IGV1aS11LW1sLXNcIj5cbiAgICAgICAgICAgICAgICB7eyBoZWFkZXJUaXRsZUNvdW50IH19XG4gICAgICAgICAgICA8L2V1aS1iYWRnZT5cbiAgICAgICAgPC9kaXY+XG5cbiAgICAgICAgPGRpdiBjbGFzcz1cImV1aS1vdmVybGF5LWhlYWRlci10aXRsZV9fYWN0aW9uc1wiPlxuICAgICAgICAgICAgPGRpdiAqbmdJZj1cImhlYWRlclRpdGxlSGlkZUxhYmVsXCIgY2xhc3M9XCJldWktb3ZlcmxheS1oZWFkZXItdGl0bGVfX2FjdGlvbnMtaGlkZVwiPlxuICAgICAgICAgICAgICAgIDxhIChjbGljayk9XCJvbkhpZGUoKVwiIGNsYXNzPVwiZXVpLW92ZXJsYXktaGVhZGVyLXRpdGxlX19hY3Rpb25zLWhpZGUtbGluayBldWktdS10ZXh0LWxpbmtcIiByb2xlPVwiYnV0dG9uXCIgdGFiaW5kZXg9XCIwXCI+XG4gICAgICAgICAgICAgICAgICAgIDxzcGFuIGV1aUxhYmVsPnt7IGhlYWRlclRpdGxlSGlkZUxhYmVsIH19PC9zcGFuPlxuICAgICAgICAgICAgICAgICAgICA8ZXVpLWljb24tc3ZnIGljb249XCJjaGV2cm9uLWZvcndhcmQ6c2hhcnBcIiBzaXplPVwic1wiIGZpbGxDb2xvcj1cInByaW1hcnlcIiBjbGFzcz1cImV1aS11LW1sLXhzXCI+PC9ldWktaWNvbi1zdmc+XG4gICAgICAgICAgICAgICAgPC9hPlxuICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgIDwvZGl2PlxuICAgIDwvZGl2PlxuXG4gICAgPGRpdiBjbGFzcz1cImV1aS1vdmVybGF5LWhlYWRlci10aXRsZV9fc3ViYWN0aW9ucy1iYXJcIj5cbiAgICAgICAgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxuICAgIDwvZGl2PlxuPC9kaXY+XG4iXX0=
|
@@ -86,7 +86,7 @@ export class EuiPageColumnComponent {
|
|
86
86
|
this.collapse.emit(this.isCollapsed);
|
87
87
|
}
|
88
88
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0-rc.1", ngImport: i0, type: EuiPageColumnComponent, deps: [{ token: forwardRef(() => EuiPageColumnsComponent), host: true, optional: true }, { token: i1.EuiAppShellService }, { token: i2.BaseStatesDirective }], target: i0.ɵɵFactoryTarget.Component }); }
|
89
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.0-rc.1", type: EuiPageColumnComponent, selector: "eui-page-column", inputs: { size: "size", label: "label", subLabel: "subLabel", autocloseContainerWidth: "autocloseContainerWidth", expandAriaLabel: "expandAriaLabel", collapseAriaLabel: "collapseAriaLabel", isCollapsible: ["isCollapsible", "isCollapsible", booleanAttribute], isCollapsed: ["isCollapsed", "isCollapsed", booleanAttribute], isHighlighted: ["isHighlighted", "isHighlighted", booleanAttribute], isCollapsedWithIcons: ["isCollapsedWithIcons", "isCollapsedWithIcons", booleanAttribute], hasSidebarMenu: ["hasSidebarMenu", "hasSidebarMenu", booleanAttribute], hasHeaderBodyShrinkable: ["hasHeaderBodyShrinkable", "hasHeaderBodyShrinkable", booleanAttribute], isAutocloseOnContainerResize: ["isAutocloseOnContainerResize", "isAutocloseOnContainerResize", 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 }], hostDirectives: [{ directive: i2.BaseStatesDirective, inputs: ["euiSizeS", "euiSizeS", "euiSizeM", "euiSizeM", "euiSizeL", "euiSizeL", "euiSizeXL", "euiSizeXL", "euiSize2XL", "euiSize2XL", "euiSize3XL", "euiSize3XL", "euiSize4XL", "euiSize4XL", "euiSizeVariant", "euiSizeVariant", "euiHighlighted", "euiHighlighted"] }], 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 ? expandAriaLabel : collapseAriaLabel\"\n class=\"eui-page-column__header-toggle\">\n @if (isCollapsed) {\n @if ((asService.state$ | async).breakpoints.isMobile) {\n <eui-icon-svg icon=\"
|
89
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.0-rc.1", type: EuiPageColumnComponent, selector: "eui-page-column", inputs: { size: "size", label: "label", subLabel: "subLabel", autocloseContainerWidth: "autocloseContainerWidth", expandAriaLabel: "expandAriaLabel", collapseAriaLabel: "collapseAriaLabel", isCollapsible: ["isCollapsible", "isCollapsible", booleanAttribute], isCollapsed: ["isCollapsed", "isCollapsed", booleanAttribute], isHighlighted: ["isHighlighted", "isHighlighted", booleanAttribute], isCollapsedWithIcons: ["isCollapsedWithIcons", "isCollapsedWithIcons", booleanAttribute], hasSidebarMenu: ["hasSidebarMenu", "hasSidebarMenu", booleanAttribute], hasHeaderBodyShrinkable: ["hasHeaderBodyShrinkable", "hasHeaderBodyShrinkable", booleanAttribute], isAutocloseOnContainerResize: ["isAutocloseOnContainerResize", "isAutocloseOnContainerResize", 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 }], hostDirectives: [{ directive: i2.BaseStatesDirective, inputs: ["euiSizeS", "euiSizeS", "euiSizeM", "euiSizeM", "euiSizeL", "euiSizeL", "euiSizeXL", "euiSizeXL", "euiSize2XL", "euiSize2XL", "euiSize3XL", "euiSize3XL", "euiSize4XL", "euiSize4XL", "euiSizeVariant", "euiSizeVariant", "euiHighlighted", "euiHighlighted"] }], 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 ? expandAriaLabel : collapseAriaLabel\"\n class=\"eui-page-column__header-toggle\">\n @if (isCollapsed) {\n @if ((asService.state$ | async).breakpoints.isMobile) {\n <eui-icon-svg icon=\"chevron-down:sharp\"></eui-icon-svg>\n } @else {\n <eui-icon-svg icon=\"chevron-forward:sharp\"></eui-icon-svg>\n }\n } @else {\n @if ((asService.state$ | async).breakpoints.isMobile) {\n <eui-icon-svg icon=\"chevron-up:sharp\"></eui-icon-svg>\n } @else {\n <eui-icon-svg icon=\"chevron-back:sharp\"></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: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.EuiButtonComponent, selector: "button[euiButton], a[euiButton]", inputs: ["e2eAttr", "id", "euiBasicButton", "euiButtonCall", "euiBlockButton", "euiIconButton", "euiLineWrap", "isChecked", "euiDisabled"], outputs: ["buttonClick"] }, { kind: "component", type: i5.EuiIconSvgComponent, selector: "eui-icon-svg, span[euiIconSvg], i[euiIconSvg]", inputs: ["icon", "fillColor", "set", "size", "ariaLabelledby", "role", "style", "iconUrl", "transform", "aria-label", "ariaHidden", "focusable", "isLoading", "isInputIcon", "euiStart", "euiEnd"] }, { kind: "directive", type: i6.CdkScrollable, selector: "[cdk-scrollable], [cdkScrollable]" }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }], encapsulation: i0.ViewEncapsulation.None }); }
|
90
90
|
}
|
91
91
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-rc.1", ngImport: i0, type: EuiPageColumnComponent, decorators: [{
|
92
92
|
type: Component,
|
@@ -105,7 +105,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-rc.1", ng
|
|
105
105
|
'euiHighlighted',
|
106
106
|
],
|
107
107
|
},
|
108
|
-
], 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 ? expandAriaLabel : collapseAriaLabel\"\n class=\"eui-page-column__header-toggle\">\n @if (isCollapsed) {\n @if ((asService.state$ | async).breakpoints.isMobile) {\n <eui-icon-svg icon=\"
|
108
|
+
], 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 ? expandAriaLabel : collapseAriaLabel\"\n class=\"eui-page-column__header-toggle\">\n @if (isCollapsed) {\n @if ((asService.state$ | async).breakpoints.isMobile) {\n <eui-icon-svg icon=\"chevron-down:sharp\"></eui-icon-svg>\n } @else {\n <eui-icon-svg icon=\"chevron-forward:sharp\"></eui-icon-svg>\n }\n } @else {\n @if ((asService.state$ | async).breakpoints.isMobile) {\n <eui-icon-svg icon=\"chevron-up:sharp\"></eui-icon-svg>\n } @else {\n <eui-icon-svg icon=\"chevron-back:sharp\"></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" }]
|
109
109
|
}], ctorParameters: () => [{ type: undefined, decorators: [{
|
110
110
|
type: Host
|
111
111
|
}, {
|
@@ -221,4 +221,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-rc.1", ng
|
|
221
221
|
type: Directive,
|
222
222
|
args: [{ selector: 'eui-page-column-footer' }]
|
223
223
|
}] });
|
224
|
-
//# 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 {\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, debounceTime, takeUntil } from 'rxjs';\nimport { EuiAppShellService } from '@eui/core';\nimport { EuiPageColumnsComponent } from '../eui-page-columns/eui-page-columns.component';\nimport { BaseStatesDirective } from '@eui/components/shared';\n\n@Component({\n    selector: 'eui-page-column',\n    templateUrl: './eui-page-column.component.html',\n    encapsulation: ViewEncapsulation.None,\n    hostDirectives: [\n        {\n            directive: BaseStatesDirective,\n            inputs: [\n                'euiSizeS',\n                'euiSizeM',\n                'euiSizeL',\n                'euiSizeXL',\n                'euiSize2XL',\n                'euiSize3XL',\n                'euiSize4XL',\n                'euiSizeVariant',\n                'euiHighlighted',\n            ],\n        },\n    ],\n})\nexport class EuiPageColumnComponent implements OnInit, OnDestroy {\n    @HostBinding('class')\n    get cssClasses(): string {\n        return [\n            this.baseStatesDirective.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; // TODO v18 - deprecate in favor of baseStatesDirective size coerces\n    @Input() label;\n    @Input() subLabel;\n    @Input() autocloseContainerWidth: number = null;\n    @Input() expandAriaLabel = 'Expand';\n    @Input() collapseAriaLabel = 'Collapse';\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 }) isAutocloseOnContainerResize = 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        protected baseStatesDirective: BaseStatesDirective,\n    ) {\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                this.isHeaderBodyShrinked = true;\n                this.headerCollapse.emit(true);\n            }\n            // Scroll UP\n            if (this.currentOffset <= this.previousOffset) {\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.baseStatesDirective.euiSizeS = false; // Bypass size default\n        if (this.pageColumnsParent && this.isAutocloseOnContainerResize && this.autocloseContainerWidth) {\n            this.pageColumnsParent.width.pipe(\n                debounceTime(100),\n                takeUntil(this.destroy$),\n            ).subscribe((parentWidth: number) => {\n                // console.log(parentWidth);\n                if (parentWidth <= this.autocloseContainerWidth) {\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 ? expandAriaLabel : collapseAriaLabel\"\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"]}
|
224
|
+
//# 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 {\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, debounceTime, takeUntil } from 'rxjs';\nimport { EuiAppShellService } from '@eui/core';\nimport { EuiPageColumnsComponent } from '../eui-page-columns/eui-page-columns.component';\nimport { BaseStatesDirective } from '@eui/components/shared';\n\n@Component({\n    selector: 'eui-page-column',\n    templateUrl: './eui-page-column.component.html',\n    encapsulation: ViewEncapsulation.None,\n    hostDirectives: [\n        {\n            directive: BaseStatesDirective,\n            inputs: [\n                'euiSizeS',\n                'euiSizeM',\n                'euiSizeL',\n                'euiSizeXL',\n                'euiSize2XL',\n                'euiSize3XL',\n                'euiSize4XL',\n                'euiSizeVariant',\n                'euiHighlighted',\n            ],\n        },\n    ],\n})\nexport class EuiPageColumnComponent implements OnInit, OnDestroy {\n    @HostBinding('class')\n    get cssClasses(): string {\n        return [\n            this.baseStatesDirective.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; // TODO v18 - deprecate in favor of baseStatesDirective size coerces\n    @Input() label;\n    @Input() subLabel;\n    @Input() autocloseContainerWidth: number = null;\n    @Input() expandAriaLabel = 'Expand';\n    @Input() collapseAriaLabel = 'Collapse';\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 }) isAutocloseOnContainerResize = 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        protected baseStatesDirective: BaseStatesDirective,\n    ) {\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                this.isHeaderBodyShrinked = true;\n                this.headerCollapse.emit(true);\n            }\n            // Scroll UP\n            if (this.currentOffset <= this.previousOffset) {\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.baseStatesDirective.euiSizeS = false; // Bypass size default\n        if (this.pageColumnsParent && this.isAutocloseOnContainerResize && this.autocloseContainerWidth) {\n            this.pageColumnsParent.width.pipe(\n                debounceTime(100),\n                takeUntil(this.destroy$),\n            ).subscribe((parentWidth: number) => {\n                // console.log(parentWidth);\n                if (parentWidth <= this.autocloseContainerWidth) {\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 ? expandAriaLabel : collapseAriaLabel\"\n            class=\"eui-page-column__header-toggle\">\n            @if (isCollapsed) {\n                @if ((asService.state$ | async).breakpoints.isMobile) {\n                    <eui-icon-svg icon=\"chevron-down:sharp\"></eui-icon-svg>\n                } @else {\n                    <eui-icon-svg icon=\"chevron-forward:sharp\"></eui-icon-svg>\n                }\n            } @else {\n                @if ((asService.state$ | async).breakpoints.isMobile) {\n                    <eui-icon-svg icon=\"chevron-up:sharp\"></eui-icon-svg>\n                } @else {\n                    <eui-icon-svg icon=\"chevron-back:sharp\"></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"]}
|