/*! * @license * Copyright 2016 Alfresco Software, Ltd. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ import { AfterContentChecked, AfterViewInit, Component, EventEmitter, Input, Output } from '@angular/core'; import { FormFieldModel, TabModel } from './../core/index'; declare var componentHandler: any; @Component({ selector: 'tabs-widget', templateUrl: './tabs.widget.html' }) export class TabsWidgetComponent implements AfterContentChecked, AfterViewInit { @Input() tabs: TabModel[] = []; @Output() formTabChanged: EventEmitter = new EventEmitter(); visibleTabs: TabModel[] = []; hasTabs() { return this.tabs && this.tabs.length > 0; } ngAfterContentChecked() { this.filterVisibleTabs(); } ngAfterViewInit() { this.setupMaterialComponents(); } filterVisibleTabs() { this.visibleTabs = this.tabs.filter(tab => { return tab.isVisible; }); } setupMaterialComponents(): boolean { // workaround for MDL issues with dynamic components if (componentHandler) { componentHandler.upgradeAllRegistered(); return true; } return false; } tabChanged(field: FormFieldModel) { this.formTabChanged.emit(field); } }