/*! * @license * Alfresco Example Content Application * * Copyright (C) 2005 - 2020 Alfresco Software Limited * * 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 * along with Alfresco. If not, see . */ import { Component, ViewEncapsulation, Output, EventEmitter, OnInit, Input } from '@angular/core'; import { Store } from '@ngrx/store'; import { Observable } from 'rxjs'; import { ContentActionRef } from '@alfresco/adf-extensions'; import { AppStore, getHeaderColor, getAppName, getLogoPath, getHeaderImagePath } from '@alfresco/aca-shared/store'; import { AppExtensionService } from '@alfresco/aca-shared'; @Component({ selector: 'app-header', templateUrl: './header.component.html', styleUrls: ['./header.component.scss'], encapsulation: ViewEncapsulation.None, host: { class: 'app-header' } }) export class AppHeaderComponent implements OnInit { @Output() toggleClicked = new EventEmitter(); @Input() expandedSidenav = true; appName$: Observable; headerColor$: Observable; logo$: Observable; actions: Array = []; constructor(store: Store, private appExtensions: AppExtensionService) { this.headerColor$ = store.select(getHeaderColor); this.appName$ = store.select(getAppName); this.logo$ = store.select(getLogoPath); store.select(getHeaderImagePath).subscribe((path) => { document.body.style.setProperty('--header-background-image', `url('${path}')`); }); } ngOnInit() { this.actions = this.appExtensions.getHeaderActions(); } trackByActionId(_: number, action: ContentActionRef) { return action.id; } }