/*! * Copyright © 2005-2023 Hyland Software, Inc. and its affiliates. All rights reserved. * * Alfresco Example Content Application * * This file is part of the Alfresco Example Content Application. * If the software was purchased under a paid Alfresco license, the terms of * the paid license agreement will prevail. Otherwise, the software is * provided under the following open source license terms: * * The Alfresco Example Content Application is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * The Alfresco Example Content Application is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * from Hyland Software. If not, see . */ import { Component, Input, ViewEncapsulation, HostListener, ViewChild, ViewChildren, QueryList, AfterViewInit } from '@angular/core'; import { ContentActionRef } from '@alfresco/adf-extensions'; import { MatMenu, MatMenuItem, MatMenuTrigger } from '@angular/material/menu'; import { ThemePalette } from '@angular/material/core'; import { ToolbarMenuItemComponent } from '../toolbar-menu-item/toolbar-menu-item.component'; @Component({ selector: 'app-toolbar-menu', templateUrl: './toolbar-menu.component.html', encapsulation: ViewEncapsulation.None, host: { class: 'app-toolbar-menu' } }) export class ToolbarMenuComponent implements AfterViewInit { @Input() actionRef: ContentActionRef; @Input() color: ThemePalette; @ViewChild('matTrigger') matTrigger: MatMenuTrigger; @ViewChild(MatMenu) menu: MatMenu; @ViewChildren(ToolbarMenuItemComponent) toolbarMenuItems: QueryList; @Input() data: { menuType?: string; color?: string; }; get type(): string { return this.data?.menuType || 'default'; } @HostListener('document:keydown.Escape') handleKeydownEscape() { this.matTrigger.closeMenu(); } ngAfterViewInit(): void { const menuItems: MatMenuItem[] = []; this.toolbarMenuItems.forEach((toolbarMenuItem: ToolbarMenuItemComponent) => { if (toolbarMenuItem.menuItem !== undefined) { menuItems.push(toolbarMenuItem.menuItem); } }); const menuItemsQueryList: QueryList = new QueryList(); menuItemsQueryList.reset(menuItems); this.menu._allItems = menuItemsQueryList; this.menu.ngAfterContentInit(); } trackByActionId(_: number, obj: ContentActionRef): string { return obj.id; } }