/*! * 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, OnInit, OnDestroy, ViewEncapsulation } from '@angular/core'; import { ContentActionRef } from '@alfresco/adf-extensions'; import { takeUntil } from 'rxjs/operators'; import { Subject } from 'rxjs'; import { AppExtensionService } from '@alfresco/aca-shared'; @Component({ selector: 'app-create-menu', templateUrl: './create-menu.component.html', styleUrls: ['./create-menu.component.scss'], encapsulation: ViewEncapsulation.None, host: { class: 'app-create-menu' } }) export class CreateMenuComponent implements OnInit, OnDestroy { createActions: Array = []; onDestroy$: Subject = new Subject(); isMainActionPresent: boolean; @Input() showLabel: boolean; @Input() expanded: boolean; constructor(private extensions: AppExtensionService) {} ngOnInit() { this.extensions .getCreateActions() .pipe(takeUntil(this.onDestroy$)) .subscribe((createActions) => { this.createActions = createActions; }); this.extensions .getMainAction() .pipe(takeUntil(this.onDestroy$)) .subscribe((mainAction) => { this.isMainActionPresent = !!mainAction; }); } ngOnDestroy() { this.onDestroy$.next(true); this.onDestroy$.complete(); } trackByActionId(_: number, obj: ContentActionRef): string { return obj.id; } }