/*! * Copyright © 2005-2024 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, ViewEncapsulation, Input, OnDestroy } from '@angular/core'; import { Observable, Subject } from 'rxjs'; import { takeUntil } from 'rxjs/operators'; import { AppService } from '../../services/app.service'; import { CommonModule } from '@angular/common'; import { TranslateModule } from '@ngx-translate/core'; import { MatButtonModule } from '@angular/material/button'; import { MatIconModule } from '@angular/material/icon'; @Component({ standalone: true, imports: [CommonModule, TranslateModule, MatButtonModule, MatIconModule], selector: 'aca-page-layout', templateUrl: './page-layout.component.html', styleUrls: ['./page-layout.component.scss'], encapsulation: ViewEncapsulation.None, host: { class: 'aca-page-layout' } }) export class PageLayoutComponent implements OnDestroy { @Input() hasError = false; private onDestroy$ = new Subject(); appNavNarMode$: Observable<'collapsed' | 'expanded'>; constructor(private appService: AppService) { this.appNavNarMode$ = appService.appNavNarMode$.pipe(takeUntil(this.onDestroy$)); } toggleClick() { this.appService.toggleAppNavBar$.next(); } ngOnDestroy() { this.onDestroy$.next(true); this.onDestroy$.complete(); } }