Files
alfresco-ng2-components/ng2-components/ng2-activiti-form/src/components/widgets/tabs/tabs.widget.ts
2017-08-01 10:20:16 +01:00

69 lines
1.8 KiB
TypeScript

/*!
* @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<FormFieldModel> = new EventEmitter<FormFieldModel>();
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);
}
}