/*! * Copyright © 2005-2025 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 { AfterViewInit, Component, Input, ViewChild, ViewEncapsulation } from '@angular/core'; import { ContentActionRef, DynamicExtensionComponent } from '@alfresco/adf-extensions'; import { AppExtensionService } from '../../../services/app.extension.service'; import { MatMenuItem, MatMenuModule } from '@angular/material/menu'; import { CommonModule } from '@angular/common'; import { TranslatePipe } from '@ngx-translate/core'; import { MatDividerModule } from '@angular/material/divider'; import { IconComponent } from '@alfresco/adf-core'; @Component({ imports: [CommonModule, TranslatePipe, MatMenuModule, MatDividerModule, IconComponent, DynamicExtensionComponent], selector: 'app-toolbar-menu-item', templateUrl: './toolbar-menu-item.component.html', styleUrls: ['./toolbar-menu-item.component.scss'], encapsulation: ViewEncapsulation.None, host: { class: 'app-toolbar-menu-item' } }) export class ToolbarMenuItemComponent implements AfterViewInit { @Input() actionRef: ContentActionRef; @Input() menuId?: string; @ViewChild(MatMenuItem) menuItem: MatMenuItem; @ViewChild(DynamicExtensionComponent) dynamicComponent: DynamicExtensionComponent; constructor(private extensions: AppExtensionService) {} runAction() { if (this.hasClickAction(this.actionRef)) { this.extensions.runActionById( this.actionRef.actions.click, this.menuId ? { focusedElementOnCloseSelector: `#${this.menuId.replace(/\\/g, '\\\\').replace(/\./g, '\\.')}` } : undefined ); } } ngAfterViewInit() { if (this.dynamicComponent?.menuItem) { this.menuItem = this.dynamicComponent.menuItem; } } private hasClickAction(actionRef: ContentActionRef): boolean { return !!actionRef?.actions?.click; } trackByActionId(_: number, obj: ContentActionRef): string { return obj.id; } }