UNPKG

materialize-angular

Version:
190 lines 16 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'; var TabGroupComponent = /** @class */ (function () { function TabGroupComponent(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 {?} */ TabGroupComponent.prototype.ngAfterViewInit = /** * @return {?} */ function () { setTimeout(this.update, 250); }; /** * @param {?} changes * @return {?} */ TabGroupComponent.prototype.ngOnChanges = /** * @param {?} changes * @return {?} */ function (changes) { if (changes.selectedIndex && !changes.selectedIndex.isFirstChange()) { this.moveIndicator(changes.selectedIndex.currentValue, true); } }; /** * @return {?} */ TabGroupComponent.prototype.update = /** * @return {?} */ function () { this.moveIndicator(this.selectedIndex, false); }; /** * @param {?} index * @return {?} */ TabGroupComponent.prototype.selectTab = /** * @param {?} index * @return {?} */ function (index) { var _this = this; /** @type {?} */ var tabs = this.tabs.toArray(); /** @type {?} */ var selectedTab = tabs[index]; if (!selectedTab.disabled) { this.selectedIndex = index; this.onTabSelectEmitter.emit(index); this.moveIndicator(this.selectedIndex, true); if (selectedTab.link) { setTimeout((/** * @return {?} */ function () { _this.router.navigate([selectedTab.link]); }), this.transitionDuration); } } }; /** * @param {?} index * @return {?} */ TabGroupComponent.prototype.activateIndex = /** * @param {?} index * @return {?} */ function (index) { this.tabs.forEach((/** * @param {?} tab * @param {?} i * @return {?} */ function (tab, i) { tab.isActive = i === index; })); }; /** * @param {?} index * @param {?} hasAnimation * @return {?} */ TabGroupComponent.prototype.moveIndicator = /** * @param {?} index * @param {?} hasAnimation * @return {?} */ function (index, hasAnimation) { this.activateIndex(index); /** @type {?} */ var child = this.headerRef.nativeElement.children[index]; /** @type {?} */ var 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 = function () { return [ { 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 }] }; return TabGroupComponent; }()); export { TabGroupComponent }; 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"]}