UNPKG

materialize-angular

Version:
168 lines 15.1 kB
/** * @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"]}