materialize-angular
Version:
Material UI Angular library
168 lines • 15.1 kB
JavaScript
/**
* @fileoverview added by tsickle
* Generated from: app/completed-components/tab-group/tab-group.component.ts
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
/**
* @license
* Copyright Workylab. All Rights Reserved.
*
* Use of this source code is governed by an MIT-style license that can be
* found in the LICENSE file at https://raw.githubusercontent.com/workylab/materialize-angular/master/LICENSE
*/
import { Component, ContentChildren, ElementRef, EventEmitter, Input, Output, QueryList, Renderer2, ViewChild } from '@angular/core';
import { config } from '../../config';
import { Router } from '@angular/router';
import { supportedEvents } from '../../utils/get-supported-events.util';
import { TabComponent } from './tab/tab.component';
export class TabGroupComponent {
/**
* @param {?} router
* @param {?} renderer
*/
constructor(router, renderer) {
this.router = router;
this.renderer = renderer;
this.className = TabGroupComponent.defaultProps.className;
this.selectedIndex = TabGroupComponent.defaultProps.selectedIndex;
this.transitionDuration = TabGroupComponent.defaultProps.transitionDuration;
this.prefix = config.components.prefix;
this.onTabSelectEmitter = new EventEmitter();
this.supportedEvents = supportedEvents();
this.update = this.update.bind(this);
window.addEventListener(this.supportedEvents.resize, this.update);
}
/**
* @return {?}
*/
ngAfterViewInit() {
setTimeout(this.update, 250);
}
/**
* @param {?} changes
* @return {?}
*/
ngOnChanges(changes) {
if (changes.selectedIndex && !changes.selectedIndex.isFirstChange()) {
this.moveIndicator(changes.selectedIndex.currentValue, true);
}
}
/**
* @return {?}
*/
update() {
this.moveIndicator(this.selectedIndex, false);
}
/**
* @param {?} index
* @return {?}
*/
selectTab(index) {
/** @type {?} */
const tabs = this.tabs.toArray();
/** @type {?} */
const selectedTab = tabs[index];
if (!selectedTab.disabled) {
this.selectedIndex = index;
this.onTabSelectEmitter.emit(index);
this.moveIndicator(this.selectedIndex, true);
if (selectedTab.link) {
setTimeout((/**
* @return {?}
*/
() => {
this.router.navigate([selectedTab.link]);
}), this.transitionDuration);
}
}
}
/**
* @param {?} index
* @return {?}
*/
activateIndex(index) {
this.tabs.forEach((/**
* @param {?} tab
* @param {?} i
* @return {?}
*/
(tab, i) => {
tab.isActive = i === index;
}));
}
/**
* @param {?} index
* @param {?} hasAnimation
* @return {?}
*/
moveIndicator(index, hasAnimation) {
this.activateIndex(index);
/** @type {?} */
const child = this.headerRef.nativeElement.children[index];
/** @type {?} */
const transitionDuration = hasAnimation
? `${this.transitionDuration}ms`
: null;
this.renderer.setStyle(this.indicatorRef.nativeElement, 'transitionDuration', transitionDuration);
this.renderer.setStyle(this.indicatorRef.nativeElement, 'width', `${child.offsetWidth}px`);
this.renderer.setStyle(this.indicatorRef.nativeElement, 'transform', `translateX(${child.offsetLeft}px)`);
}
}
TabGroupComponent.defaultProps = {
className: '',
selectedIndex: 0,
transitionDuration: 450
};
TabGroupComponent.decorators = [
{ type: Component, args: [{
selector: `${config.components.prefix}-tab-group }`,
template: "<div [ngClass]=\"className\">\n <ul [ngClass]=\"prefix + '-tab-group'\" #header>\n\n <li (click)=\"selectTab(i)\"\n *ngFor=\"let tab of tabs; let i = index\"\n\n [ngClass]=\"prefix + '-tab-group-item'\"\n [class.active]=\"i === selectedIndex\"\n [class.disabled]=\"tab.disabled\"\n [isRippleActive]=\"!tab.disabled\"\n\n materializeRipple\n >\n {{ tab.title }}\n </li>\n\n <div [ngClass]=\"prefix + '-tab-group-indicator-container'\" #indicator>\n <div [ngClass]=\"prefix + '-tab-group-indicator'\"></div>\n </div>\n </ul>\n \n <div>\n <ng-content select=\"materialize-tab\"></ng-content>\n </div>\n</div>\n"
}] }
];
/** @nocollapse */
TabGroupComponent.ctorParameters = () => [
{ type: Router },
{ type: Renderer2 }
];
TabGroupComponent.propDecorators = {
tabs: [{ type: ContentChildren, args: [TabComponent,] }],
indicatorRef: [{ type: ViewChild, args: ['indicator', { static: true },] }],
headerRef: [{ type: ViewChild, args: ['header', { static: true },] }],
onTabSelectEmitter: [{ type: Output, args: ['onSelectTab',] }],
className: [{ type: Input }],
selectedIndex: [{ type: Input }],
transitionDuration: [{ type: Input }]
};
if (false) {
/** @type {?} */
TabGroupComponent.defaultProps;
/** @type {?} */
TabGroupComponent.prototype.tabs;
/** @type {?} */
TabGroupComponent.prototype.indicatorRef;
/** @type {?} */
TabGroupComponent.prototype.headerRef;
/** @type {?} */
TabGroupComponent.prototype.onTabSelectEmitter;
/** @type {?} */
TabGroupComponent.prototype.className;
/** @type {?} */
TabGroupComponent.prototype.selectedIndex;
/** @type {?} */
TabGroupComponent.prototype.transitionDuration;
/** @type {?} */
TabGroupComponent.prototype.prefix;
/** @type {?} */
TabGroupComponent.prototype.supportedEvents;
/**
* @type {?}
* @private
*/
TabGroupComponent.prototype.router;
/**
* @type {?}
* @private
*/
TabGroupComponent.prototype.renderer;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tab-group.component.js","sourceRoot":"ng://materialize-angular/","sources":["app/completed-components/tab-group/tab-group.component.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Workylab. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://raw.githubusercontent.com/workylab/materialize-angular/master/LICENSE\n */\n\nimport {\n  AfterViewInit,\n  Component,\n  ContentChildren,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnChanges,\n  Output,\n  QueryList,\n  Renderer2,\n  SimpleChanges,\n  ViewChild\n} from '@angular/core';\nimport { config } from '../../config';\nimport { Router } from '@angular/router';\nimport { supportedEvents } from '../../utils/get-supported-events.util';\nimport { SupportedEventsModel } from '../../components/common/models/supported-events.model';\nimport { TabComponent } from './tab/tab.component';\nimport { TabGroupModel } from './tab-group.model';\n\n@Component({\n  selector: `${ config.components.prefix }-tab-group }`,\n  templateUrl: './tab-group.component.html'\n})\nexport class TabGroupComponent implements AfterViewInit, OnChanges {\n  static readonly defaultProps: TabGroupModel = {\n    className: '',\n    selectedIndex: 0,\n    transitionDuration: 450\n  };\n\n  @ContentChildren(TabComponent) tabs: QueryList<TabComponent>;\n\n  @ViewChild('indicator', { static: true }) indicatorRef: ElementRef;\n  @ViewChild('header', { static: true }) headerRef: ElementRef;\n\n  @Output('onSelectTab') onTabSelectEmitter: EventEmitter<number>;\n\n  @Input() className: string = TabGroupComponent.defaultProps.className;\n  @Input() selectedIndex: number = TabGroupComponent.defaultProps.selectedIndex;\n  @Input() transitionDuration: number = TabGroupComponent.defaultProps.transitionDuration;\n\n  public prefix = config.components.prefix;\n  public supportedEvents: SupportedEventsModel;\n\n  constructor(private router: Router, private renderer: Renderer2) {\n    this.onTabSelectEmitter = new EventEmitter<number>();\n    this.supportedEvents = supportedEvents();\n\n    this.update = this.update.bind(this);\n\n    window.addEventListener(this.supportedEvents.resize, this.update);\n  }\n\n  ngAfterViewInit() {\n    setTimeout(this.update, 250);\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes.selectedIndex && !changes.selectedIndex.isFirstChange()) {\n      this.moveIndicator(changes.selectedIndex.currentValue, true);\n    }\n  }\n\n  update() {\n    this.moveIndicator(this.selectedIndex, false);\n  }\n\n  selectTab(index: number) {\n    const tabs = this.tabs.toArray();\n    const selectedTab = tabs[index];\n\n    if (!selectedTab.disabled) {\n      this.selectedIndex = index;\n\n      this.onTabSelectEmitter.emit(index);\n      this.moveIndicator(this.selectedIndex, true);\n\n      if (selectedTab.link) {\n        setTimeout(() => {\n          this.router.navigate([selectedTab.link]);\n        }, this.transitionDuration);\n      }\n    }\n  }\n\n  activateIndex(index: number) {\n    this.tabs.forEach((tab, i) => {\n      tab.isActive = i === index;\n    });\n  }\n\n  moveIndicator(index: number, hasAnimation: boolean) {\n    this.activateIndex(index);\n\n    const child = this.headerRef.nativeElement.children[index];\n    const transitionDuration = hasAnimation\n      ? `${ this.transitionDuration }ms`\n      : null;\n\n    this.renderer.setStyle(this.indicatorRef.nativeElement, 'transitionDuration', transitionDuration);\n    this.renderer.setStyle(this.indicatorRef.nativeElement, 'width', `${ child.offsetWidth }px`);\n    this.renderer.setStyle(this.indicatorRef.nativeElement, 'transform', `translateX(${ child.offsetLeft }px)`);\n  }\n}\n"]}