mirror of
https://github.com/Alfresco/alfresco-content-app.git
synced 2025-05-12 17:04:46 +00:00
* [ACS-9266] Make notification and user menu accessible with keyboard * [ACS-9266] cr fixes * [ACS-9266] cr fix * [link-adf:dev-mmaliarchuk/ACS-9266-Notification-and-user-menu-are-not-accessible-with-keyboard][ci:force] * empty commit
74 lines
2.8 KiB
TypeScript
74 lines
2.8 KiB
TypeScript
/*!
|
|
* 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 <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
import { AfterViewInit, Component, inject, Input, OnInit, QueryList, ViewChild, ViewChildren, ViewEncapsulation } from '@angular/core';
|
|
import { ContentActionRef, DynamicExtensionComponent } from '@alfresco/adf-extensions';
|
|
import { CommonModule } from '@angular/common';
|
|
import { MatButtonModule } from '@angular/material/button';
|
|
import { TranslateModule } from '@ngx-translate/core';
|
|
import { MatMenu, MatMenuItem, MatMenuModule } from '@angular/material/menu';
|
|
import { ToolbarMenuItemComponent, UserProfileService } from '@alfresco/aca-shared';
|
|
|
|
@Component({
|
|
standalone: true,
|
|
imports: [CommonModule, TranslateModule, MatButtonModule, MatMenuModule, ToolbarMenuItemComponent, DynamicExtensionComponent],
|
|
selector: 'aca-user-menu',
|
|
templateUrl: './user-menu.component.html',
|
|
styleUrls: ['./user-menu.component.scss'],
|
|
encapsulation: ViewEncapsulation.None,
|
|
host: { class: 'aca-user-menu' }
|
|
})
|
|
export class UserMenuComponent implements OnInit, AfterViewInit {
|
|
private userProfileService = inject(UserProfileService);
|
|
|
|
user$ = this.userProfileService.userProfile$;
|
|
|
|
@Input()
|
|
actionRef: ContentActionRef;
|
|
|
|
@Input()
|
|
data: { items: any[] };
|
|
|
|
@ViewChild(MatMenu)
|
|
menu: MatMenu;
|
|
|
|
@ViewChildren(ToolbarMenuItemComponent)
|
|
toolbarMenuItems: QueryList<ToolbarMenuItemComponent>;
|
|
|
|
ngOnInit() {
|
|
if (this.data?.items) {
|
|
this.data.items.sort((a, b) => a.order - b.order);
|
|
}
|
|
}
|
|
|
|
ngAfterViewInit() {
|
|
const menuItems = this.toolbarMenuItems.map((toolbarMenuItem) => toolbarMenuItem.menuItem).filter((menuItem) => menuItem !== undefined);
|
|
|
|
const menuItemsQueryList = new QueryList<MatMenuItem>();
|
|
menuItemsQueryList.reset(menuItems);
|
|
this.menu._allItems = menuItemsQueryList;
|
|
this.menu.ngAfterContentInit();
|
|
}
|
|
}
|