UNPKG

ng-zorro-antd

Version:

An enterprise-class UI components based on Ant Design and Angular

503 lines 43.2 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import * as tslib_1 from "tslib"; /** * @license * Copyright Alibaba.com 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://github.com/NG-ZORRO/ng-zorro-antd/blob/master/LICENSE */ /** get some code from https://github.com/angular/material2 */ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ContentChildren, ElementRef, EventEmitter, Input, Output, QueryList, Renderer2, TemplateRef, ViewChild, ViewEncapsulation } from '@angular/core'; import { merge, Subscription } from 'rxjs'; import { toNumber, NzUpdateHostClassService } from 'ng-zorro-antd/core'; import { NzTabComponent } from './nz-tab.component'; import { NzTabsNavComponent } from './nz-tabs-nav.component'; /** * @record */ export function NzAnimatedInterface() { } if (false) { /** @type {?} */ NzAnimatedInterface.prototype.inkBar; /** @type {?} */ NzAnimatedInterface.prototype.tabPane; } var NzTabChangeEvent = /** @class */ (function () { function NzTabChangeEvent() { } return NzTabChangeEvent; }()); export { NzTabChangeEvent }; if (false) { /** @type {?} */ NzTabChangeEvent.prototype.index; /** @type {?} */ NzTabChangeEvent.prototype.tab; } var NzTabSetComponent = /** @class */ (function () { function NzTabSetComponent(renderer, nzUpdateHostClassService, elementRef, cdr) { this.renderer = renderer; this.nzUpdateHostClassService = nzUpdateHostClassService; this.elementRef = elementRef; this.cdr = cdr; this.indexToSelect = 0; this.el = this.elementRef.nativeElement; this._selectedIndex = null; /** * Subscription to tabs being added/removed. */ this.tabsSubscription = Subscription.EMPTY; /** * Subscription to changes in the tab labels. */ this.tabLabelSubscription = Subscription.EMPTY; this.tabPositionMode = 'horizontal'; this.nzShowPagination = true; this.nzAnimated = true; this.nzHideAll = false; this.nzTabPosition = 'top'; this.nzSize = 'default'; this.nzType = 'line'; this.nzOnNextClick = new EventEmitter(); this.nzOnPrevClick = new EventEmitter(); this.nzSelectChange = new EventEmitter(true); this.nzSelectedIndexChange = new EventEmitter(); } Object.defineProperty(NzTabSetComponent.prototype, "nzSelectedIndex", { get: /** * @return {?} */ function () { return this._selectedIndex; }, set: /** * @param {?} value * @return {?} */ function (value) { this.indexToSelect = value ? toNumber(value, null) : null; }, enumerable: true, configurable: true }); Object.defineProperty(NzTabSetComponent.prototype, "inkBarAnimated", { get: /** * @return {?} */ function () { return this.nzAnimated === true || ((/** @type {?} */ (this.nzAnimated))).inkBar === true; }, enumerable: true, configurable: true }); Object.defineProperty(NzTabSetComponent.prototype, "tabPaneAnimated", { get: /** * @return {?} */ function () { return this.nzAnimated === true || ((/** @type {?} */ (this.nzAnimated))).tabPane === true; }, enumerable: true, configurable: true }); /** * @param {?} value * @return {?} */ NzTabSetComponent.prototype.setPosition = /** * @param {?} value * @return {?} */ function (value) { if (this.tabContent) { if (value === 'bottom') { this.renderer.insertBefore(this.el, this.tabContent.nativeElement, this.nzTabsNavComponent.elementRef.nativeElement); } else { this.renderer.insertBefore(this.el, this.nzTabsNavComponent.elementRef.nativeElement, this.tabContent.nativeElement); } } }; /** * @return {?} */ NzTabSetComponent.prototype.setClassMap = /** * @return {?} */ function () { var _a; this.nzUpdateHostClassService.updateHostClass(this.el, (_a = {}, _a["ant-tabs"] = true, _a["ant-tabs-vertical"] = this.nzTabPosition === 'left' || this.nzTabPosition === 'right', _a["ant-tabs-" + this.nzTabPosition] = this.nzTabPosition, _a["ant-tabs-no-animation"] = this.nzAnimated === false || ((/** @type {?} */ (this.nzAnimated))).tabPane === false, _a["ant-tabs-" + this.nzType] = this.nzType, _a["ant-tabs-large"] = this.nzSize === 'large', _a["ant-tabs-small"] = this.nzSize === 'small', _a)); }; /** * @param {?} index * @param {?} disabled * @return {?} */ NzTabSetComponent.prototype.clickLabel = /** * @param {?} index * @param {?} disabled * @return {?} */ function (index, disabled) { if (!disabled) { this.nzSelectedIndex = index; this.listOfNzTabComponent.toArray()[index].nzClick.emit(); } }; /** * @param {?} index * @return {?} */ NzTabSetComponent.prototype.createChangeEvent = /** * @param {?} index * @return {?} */ function (index) { /** @type {?} */ var event = new NzTabChangeEvent(); event.index = index; if (this.listOfNzTabComponent && this.listOfNzTabComponent.length) { event.tab = this.listOfNzTabComponent.toArray()[index]; this.listOfNzTabComponent.forEach((/** * @param {?} item * @param {?} i * @return {?} */ function (item, i) { if (i !== index) { item.nzDeselect.emit(); } })); event.tab.nzSelect.emit(); } return event; }; /** Clamps the given index to the bounds of 0 and the tabs length. */ /** * Clamps the given index to the bounds of 0 and the tabs length. * @private * @param {?} index * @return {?} */ NzTabSetComponent.prototype.clampTabIndex = /** * Clamps the given index to the bounds of 0 and the tabs length. * @private * @param {?} index * @return {?} */ function (index) { // Note the `|| 0`, which ensures that values like NaN can't get through // and which would otherwise throw the component into an infinite loop // (since Math.max(NaN, 0) === NaN). return Math.min(this.listOfNzTabComponent.length - 1, Math.max(index || 0, 0)); }; /** * @private * @return {?} */ NzTabSetComponent.prototype.subscribeToTabLabels = /** * @private * @return {?} */ function () { var _this = this; if (this.tabLabelSubscription) { this.tabLabelSubscription.unsubscribe(); } this.tabLabelSubscription = merge.apply(void 0, tslib_1.__spread(this.listOfNzTabComponent.map((/** * @param {?} tab * @return {?} */ function (tab) { return tab.stateChanges; })))).subscribe((/** * @return {?} */ function () { return _this.cdr.markForCheck(); })); }; /** * @param {?} changes * @return {?} */ NzTabSetComponent.prototype.ngOnChanges = /** * @param {?} changes * @return {?} */ function (changes) { if (changes.nzTabPosition) { if (this.nzTabPosition === 'top' || this.nzTabPosition === 'bottom') { this.tabPositionMode = 'horizontal'; } else { this.tabPositionMode = 'vertical'; } this.setPosition(this.nzTabPosition); } if (changes.nzType) { if (this.nzType === 'card') { this.nzAnimated = false; } } if (changes.nzSize || changes.nzAnimated || changes.nzTabPosition || changes.nzType) { this.setClassMap(); } }; /** * @return {?} */ NzTabSetComponent.prototype.ngOnInit = /** * @return {?} */ function () { this.setClassMap(); }; /** * @return {?} */ NzTabSetComponent.prototype.ngAfterContentChecked = /** * @return {?} */ function () { var _this = this; if (this.listOfNzTabComponent && this.listOfNzTabComponent.length) { // Don't clamp the `indexToSelect` immediately in the setter because it can happen that // the amount of tabs changes before the actual change detection runs. /** @type {?} */ var indexToSelect_1 = (this.indexToSelect = this.clampTabIndex(this.indexToSelect)); // If there is a change in selected index, emit a change event. Should not trigger if // the selected index has not yet been initialized. if (this._selectedIndex !== indexToSelect_1) { /** @type {?} */ var isFirstRun_1 = this._selectedIndex == null; if (!isFirstRun_1) { this.nzSelectChange.emit(this.createChangeEvent(indexToSelect_1)); } // Changing these values after change detection has run // since the checked content may contain references to them. Promise.resolve().then((/** * @return {?} */ function () { _this.listOfNzTabComponent.forEach((/** * @param {?} tab * @param {?} index * @return {?} */ function (tab, index) { return (tab.isActive = index === indexToSelect_1); })); if (!isFirstRun_1) { _this.nzSelectedIndexChange.emit(indexToSelect_1); } })); } // Setup the position for each tab and optionally setup an origin on the next selected tab. this.listOfNzTabComponent.forEach((/** * @param {?} tab * @param {?} index * @return {?} */ function (tab, index) { tab.position = index - indexToSelect_1; // If there is already a selected tab, then set up an origin for the next selected tab // if it doesn't have one already. if (_this._selectedIndex != null && tab.position === 0 && !tab.origin) { tab.origin = indexToSelect_1 - _this._selectedIndex; } })); if (this._selectedIndex !== indexToSelect_1) { this._selectedIndex = indexToSelect_1; this.cdr.markForCheck(); } } }; /** * @return {?} */ NzTabSetComponent.prototype.ngAfterContentInit = /** * @return {?} */ function () { var _this = this; this.subscribeToTabLabels(); // Subscribe to changes in the amount of tabs, in order to be // able to re-render the content as new tabs are added or removed. this.tabsSubscription = this.listOfNzTabComponent.changes.subscribe((/** * @return {?} */ function () { /** @type {?} */ var indexToSelect = _this.clampTabIndex(_this.indexToSelect); // Maintain the previously-selected tab if a new tab is added or removed and there is no // explicit change that selects a different tab. if (indexToSelect === _this._selectedIndex) { /** @type {?} */ var tabs = _this.listOfNzTabComponent.toArray(); for (var i = 0; i < tabs.length; i++) { if (tabs[i].isActive) { // Assign both to the `_indexToSelect` and `_selectedIndex` so we don't fire a changed // event, otherwise the consumer may end up in an infinite loop in some edge cases like // adding a tab within the `selectedIndexChange` event. _this.indexToSelect = _this._selectedIndex = i; break; } } } _this.subscribeToTabLabels(); _this.cdr.markForCheck(); })); }; /** * @return {?} */ NzTabSetComponent.prototype.ngOnDestroy = /** * @return {?} */ function () { this.tabsSubscription.unsubscribe(); this.tabLabelSubscription.unsubscribe(); }; /** * @return {?} */ NzTabSetComponent.prototype.ngAfterViewInit = /** * @return {?} */ function () { this.setPosition(this.nzTabPosition); }; NzTabSetComponent.decorators = [ { type: Component, args: [{ selector: 'nz-tabset', exportAs: 'nzTabset', preserveWhitespaces: false, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, providers: [NzUpdateHostClassService], template: "<ng-container *ngIf=\"listOfNzTabComponent\">\n <div nz-tabs-nav\n role=\"tablist\"\n tabindex=\"0\"\n class=\"ant-tabs-bar\"\n [class.ant-tabs-card-bar]=\"nzType === 'card'\"\n [class.ant-tabs-top-bar]=\"nzTabPosition === 'top'\"\n [class.ant-tabs-bottom-bar]=\"nzTabPosition === 'bottom'\"\n [class.ant-tabs-left-bar]=\"nzTabPosition === 'left'\"\n [class.ant-tabs-right-bar]=\"nzTabPosition === 'right'\"\n [class.ant-tabs-small-bar]=\"nzSize === 'small'\"\n [class.ant-tabs-default-bar]=\"nzSize === 'default'\"\n [class.ant-tabs-large-bar]=\"nzSize === 'large'\"\n [nzType]=\"nzType\"\n [nzShowPagination]=\"nzShowPagination\"\n [nzPositionMode]=\"tabPositionMode\"\n [nzAnimated]=\"inkBarAnimated\"\n [ngStyle]=\"nzTabBarStyle\"\n [nzHideBar]=\"nzHideAll\"\n [nzTabBarExtraContent]=\"nzTabBarExtraContent\"\n [selectedIndex]=\"nzSelectedIndex\"\n (nzOnNextClick)=\"nzOnNextClick.emit()\"\n (nzOnPrevClick)=\"nzOnPrevClick.emit()\">\n <div nz-tab-label\n role=\"tab\"\n [style.margin-right.px]=\"nzTabBarGutter\"\n [class.ant-tabs-tab-active]=\"(nzSelectedIndex == i) && !nzHideAll\"\n [disabled]=\"tab.nzDisabled\"\n (click)=\"clickLabel(i,tab.nzDisabled)\"\n *ngFor=\"let tab of listOfNzTabComponent; let i = index\">\n <ng-container *nzStringTemplateOutlet=\"tab.nzTitle\">{{ tab.nzTitle }}</ng-container>\n </div>\n </div>\n <div #tabContent\n class=\"ant-tabs-content\"\n [class.ant-tabs-top-content]=\"nzTabPosition === 'top'\"\n [class.ant-tabs-bottom-content]=\"nzTabPosition === 'bottom'\"\n [class.ant-tabs-left-content]=\"nzTabPosition === 'left'\"\n [class.ant-tabs-right-content]=\"nzTabPosition === 'right'\"\n [class.ant-tabs-content-animated]=\"tabPaneAnimated\"\n [class.ant-tabs-content-no-animated]=\"!tabPaneAnimated\"\n [style.margin-left.%]=\"(tabPositionMode === 'horizontal') && tabPaneAnimated && (-(nzSelectedIndex || 0 ) * 100)\">\n <div nz-tab-body\n class=\"ant-tabs-tabpane\"\n *ngFor=\"let tab of listOfNzTabComponent; let i = index\"\n [active]=\"(nzSelectedIndex == i) && !nzHideAll\"\n [forceRender]=\"tab.nzForceRender\"\n [content]=\"tab.template || tab.content\">\n </div>\n </div>\n</ng-container>", styles: ["\n nz-tabset {\n display: block;\n }\n "] }] } ]; /** @nocollapse */ NzTabSetComponent.ctorParameters = function () { return [ { type: Renderer2 }, { type: NzUpdateHostClassService }, { type: ElementRef }, { type: ChangeDetectorRef } ]; }; NzTabSetComponent.propDecorators = { listOfNzTabComponent: [{ type: ContentChildren, args: [NzTabComponent,] }], nzTabsNavComponent: [{ type: ViewChild, args: [NzTabsNavComponent,] }], tabContent: [{ type: ViewChild, args: ['tabContent',] }], nzTabBarExtraContent: [{ type: Input }], nzShowPagination: [{ type: Input }], nzAnimated: [{ type: Input }], nzHideAll: [{ type: Input }], nzTabPosition: [{ type: Input }], nzSize: [{ type: Input }], nzTabBarGutter: [{ type: Input }], nzTabBarStyle: [{ type: Input }], nzType: [{ type: Input }], nzOnNextClick: [{ type: Output }], nzOnPrevClick: [{ type: Output }], nzSelectChange: [{ type: Output }], nzSelectedIndexChange: [{ type: Output }], nzSelectedIndex: [{ type: Input }] }; return NzTabSetComponent; }()); export { NzTabSetComponent }; if (false) { /** * @type {?} * @private */ NzTabSetComponent.prototype.indexToSelect; /** * @type {?} * @private */ NzTabSetComponent.prototype.el; /** * @type {?} * @private */ NzTabSetComponent.prototype._selectedIndex; /** * Subscription to tabs being added/removed. * @type {?} * @private */ NzTabSetComponent.prototype.tabsSubscription; /** * Subscription to changes in the tab labels. * @type {?} * @private */ NzTabSetComponent.prototype.tabLabelSubscription; /** @type {?} */ NzTabSetComponent.prototype.tabPositionMode; /** @type {?} */ NzTabSetComponent.prototype.listOfNzTabComponent; /** @type {?} */ NzTabSetComponent.prototype.nzTabsNavComponent; /** @type {?} */ NzTabSetComponent.prototype.tabContent; /** @type {?} */ NzTabSetComponent.prototype.nzTabBarExtraContent; /** @type {?} */ NzTabSetComponent.prototype.nzShowPagination; /** @type {?} */ NzTabSetComponent.prototype.nzAnimated; /** @type {?} */ NzTabSetComponent.prototype.nzHideAll; /** @type {?} */ NzTabSetComponent.prototype.nzTabPosition; /** @type {?} */ NzTabSetComponent.prototype.nzSize; /** @type {?} */ NzTabSetComponent.prototype.nzTabBarGutter; /** @type {?} */ NzTabSetComponent.prototype.nzTabBarStyle; /** @type {?} */ NzTabSetComponent.prototype.nzType; /** @type {?} */ NzTabSetComponent.prototype.nzOnNextClick; /** @type {?} */ NzTabSetComponent.prototype.nzOnPrevClick; /** @type {?} */ NzTabSetComponent.prototype.nzSelectChange; /** @type {?} */ NzTabSetComponent.prototype.nzSelectedIndexChange; /** * @type {?} * @private */ NzTabSetComponent.prototype.renderer; /** * @type {?} * @private */ NzTabSetComponent.prototype.nzUpdateHostClassService; /** * @type {?} * @private */ NzTabSetComponent.prototype.elementRef; /** * @type {?} * @private */ NzTabSetComponent.prototype.cdr; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nz-tabset.component.js","sourceRoot":"ng://ng-zorro-antd/tabs/","sources":["nz-tabset.component.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Alibaba.com 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://github.com/NG-ZORRO/ng-zorro-antd/blob/master/LICENSE\n */\n\n/** get some code from https://github.com/angular/material2 */\n\nimport {\n  AfterContentChecked,\n  AfterContentInit,\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChildren,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output,\n  QueryList,\n  Renderer2,\n  SimpleChanges,\n  TemplateRef,\n  ViewChild,\n  ViewEncapsulation\n} from '@angular/core';\nimport { merge, Subscription } from 'rxjs';\n\nimport { toNumber, NzSizeLDSType, NzUpdateHostClassService } from 'ng-zorro-antd/core';\n\nimport { NzTabComponent } from './nz-tab.component';\nimport { NzTabsNavComponent } from './nz-tabs-nav.component';\n\nexport interface NzAnimatedInterface {\n  inkBar: boolean;\n  tabPane: boolean;\n}\n\nexport class NzTabChangeEvent {\n  index: number;\n  tab: NzTabComponent;\n}\n\nexport type NzTabPosition = 'top' | 'bottom' | 'left' | 'right';\nexport type NzTabPositionMode = 'horizontal' | 'vertical';\nexport type NzTabType = 'line' | 'card';\n\n@Component({\n  selector: 'nz-tabset',\n  exportAs: 'nzTabset',\n  preserveWhitespaces: false,\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [NzUpdateHostClassService],\n  templateUrl: './nz-tabset.component.html',\n  styles: [\n    `\n      nz-tabset {\n        display: block;\n      }\n    `\n  ]\n})\nexport class NzTabSetComponent\n  implements AfterContentChecked, OnInit, AfterViewInit, OnChanges, AfterContentInit, OnDestroy {\n  private indexToSelect: number | null = 0;\n  private el: HTMLElement = this.elementRef.nativeElement;\n  private _selectedIndex: number | null = null;\n  /** Subscription to tabs being added/removed. */\n  private tabsSubscription = Subscription.EMPTY;\n  /** Subscription to changes in the tab labels. */\n  private tabLabelSubscription = Subscription.EMPTY;\n  tabPositionMode: NzTabPositionMode = 'horizontal';\n  @ContentChildren(NzTabComponent) listOfNzTabComponent: QueryList<NzTabComponent>;\n  @ViewChild(NzTabsNavComponent) nzTabsNavComponent: NzTabsNavComponent;\n  @ViewChild('tabContent') tabContent: ElementRef;\n  @Input() nzTabBarExtraContent: TemplateRef<void>;\n  @Input() nzShowPagination = true;\n  @Input() nzAnimated: NzAnimatedInterface | boolean = true;\n  @Input() nzHideAll = false;\n  @Input() nzTabPosition: NzTabPosition = 'top';\n  @Input() nzSize: NzSizeLDSType = 'default';\n  @Input() nzTabBarGutter: number;\n  @Input() nzTabBarStyle: { [key: string]: string };\n  @Input() nzType: NzTabType = 'line';\n  @Output() readonly nzOnNextClick = new EventEmitter<void>();\n  @Output() readonly nzOnPrevClick = new EventEmitter<void>();\n  @Output() readonly nzSelectChange: EventEmitter<NzTabChangeEvent> = new EventEmitter<NzTabChangeEvent>(true);\n  @Output() readonly nzSelectedIndexChange: EventEmitter<number> = new EventEmitter<number>();\n\n  @Input()\n  set nzSelectedIndex(value: number | null) {\n    this.indexToSelect = value ? toNumber(value, null) : null;\n  }\n\n  get nzSelectedIndex(): number | null {\n    return this._selectedIndex;\n  }\n\n  get inkBarAnimated(): boolean {\n    return this.nzAnimated === true || (this.nzAnimated as NzAnimatedInterface).inkBar === true;\n  }\n\n  get tabPaneAnimated(): boolean {\n    return this.nzAnimated === true || (this.nzAnimated as NzAnimatedInterface).tabPane === true;\n  }\n\n  setPosition(value: NzTabPosition): void {\n    if (this.tabContent) {\n      if (value === 'bottom') {\n        this.renderer.insertBefore(\n          this.el,\n          this.tabContent.nativeElement,\n          this.nzTabsNavComponent.elementRef.nativeElement\n        );\n      } else {\n        this.renderer.insertBefore(\n          this.el,\n          this.nzTabsNavComponent.elementRef.nativeElement,\n          this.tabContent.nativeElement\n        );\n      }\n    }\n  }\n\n  setClassMap(): void {\n    this.nzUpdateHostClassService.updateHostClass(this.el, {\n      [`ant-tabs`]: true,\n      [`ant-tabs-vertical`]: this.nzTabPosition === 'left' || this.nzTabPosition === 'right',\n      [`ant-tabs-${this.nzTabPosition}`]: this.nzTabPosition,\n      [`ant-tabs-no-animation`]:\n        this.nzAnimated === false || (this.nzAnimated as NzAnimatedInterface).tabPane === false,\n      [`ant-tabs-${this.nzType}`]: this.nzType,\n      [`ant-tabs-large`]: this.nzSize === 'large',\n      [`ant-tabs-small`]: this.nzSize === 'small'\n    });\n  }\n\n  clickLabel(index: number, disabled: boolean): void {\n    if (!disabled) {\n      this.nzSelectedIndex = index;\n      this.listOfNzTabComponent.toArray()[index].nzClick.emit();\n    }\n  }\n\n  createChangeEvent(index: number): NzTabChangeEvent {\n    const event = new NzTabChangeEvent();\n    event.index = index;\n    if (this.listOfNzTabComponent && this.listOfNzTabComponent.length) {\n      event.tab = this.listOfNzTabComponent.toArray()[index];\n      this.listOfNzTabComponent.forEach((item, i) => {\n        if (i !== index) {\n          item.nzDeselect.emit();\n        }\n      });\n      event.tab.nzSelect.emit();\n    }\n    return event;\n  }\n\n  /** Clamps the given index to the bounds of 0 and the tabs length. */\n  private clampTabIndex(index: number | null): number {\n    // Note the `|| 0`, which ensures that values like NaN can't get through\n    // and which would otherwise throw the component into an infinite loop\n    // (since Math.max(NaN, 0) === NaN).\n    return Math.min(this.listOfNzTabComponent.length - 1, Math.max(index || 0, 0));\n  }\n\n  private subscribeToTabLabels(): void {\n    if (this.tabLabelSubscription) {\n      this.tabLabelSubscription.unsubscribe();\n    }\n    this.tabLabelSubscription = merge(...this.listOfNzTabComponent.map(tab => tab.stateChanges)).subscribe(() =>\n      this.cdr.markForCheck()\n    );\n  }\n\n  constructor(\n    private renderer: Renderer2,\n    private nzUpdateHostClassService: NzUpdateHostClassService,\n    private elementRef: ElementRef,\n    private cdr: ChangeDetectorRef\n  ) {}\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes.nzTabPosition) {\n      if (this.nzTabPosition === 'top' || this.nzTabPosition === 'bottom') {\n        this.tabPositionMode = 'horizontal';\n      } else {\n        this.tabPositionMode = 'vertical';\n      }\n      this.setPosition(this.nzTabPosition);\n    }\n    if (changes.nzType) {\n      if (this.nzType === 'card') {\n        this.nzAnimated = false;\n      }\n    }\n    if (changes.nzSize || changes.nzAnimated || changes.nzTabPosition || changes.nzType) {\n      this.setClassMap();\n    }\n  }\n\n  ngOnInit(): void {\n    this.setClassMap();\n  }\n\n  ngAfterContentChecked(): void {\n    if (this.listOfNzTabComponent && this.listOfNzTabComponent.length) {\n      // Don't clamp the `indexToSelect` immediately in the setter because it can happen that\n      // the amount of tabs changes before the actual change detection runs.\n      const indexToSelect = (this.indexToSelect = this.clampTabIndex(this.indexToSelect));\n      // If there is a change in selected index, emit a change event. Should not trigger if\n      // the selected index has not yet been initialized.\n      if (this._selectedIndex !== indexToSelect) {\n        const isFirstRun = this._selectedIndex == null;\n        if (!isFirstRun) {\n          this.nzSelectChange.emit(this.createChangeEvent(indexToSelect));\n        }\n\n        // Changing these values after change detection has run\n        // since the checked content may contain references to them.\n        Promise.resolve().then(() => {\n          this.listOfNzTabComponent.forEach((tab, index) => (tab.isActive = index === indexToSelect));\n\n          if (!isFirstRun) {\n            this.nzSelectedIndexChange.emit(indexToSelect);\n          }\n        });\n      }\n\n      // Setup the position for each tab and optionally setup an origin on the next selected tab.\n      this.listOfNzTabComponent.forEach((tab: NzTabComponent, index: number) => {\n        tab.position = index - indexToSelect;\n\n        // If there is already a selected tab, then set up an origin for the next selected tab\n        // if it doesn't have one already.\n        if (this._selectedIndex != null && tab.position === 0 && !tab.origin) {\n          tab.origin = indexToSelect - this._selectedIndex;\n        }\n      });\n\n      if (this._selectedIndex !== indexToSelect) {\n        this._selectedIndex = indexToSelect;\n        this.cdr.markForCheck();\n      }\n    }\n  }\n\n  ngAfterContentInit(): void {\n    this.subscribeToTabLabels();\n\n    // Subscribe to changes in the amount of tabs, in order to be\n    // able to re-render the content as new tabs are added or removed.\n    this.tabsSubscription = this.listOfNzTabComponent.changes.subscribe(() => {\n      const indexToSelect = this.clampTabIndex(this.indexToSelect);\n\n      // Maintain the previously-selected tab if a new tab is added or removed and there is no\n      // explicit change that selects a different tab.\n      if (indexToSelect === this._selectedIndex) {\n        const tabs = this.listOfNzTabComponent.toArray();\n\n        for (let i = 0; i < tabs.length; i++) {\n          if (tabs[i].isActive) {\n            // Assign both to the `_indexToSelect` and `_selectedIndex` so we don't fire a changed\n            // event, otherwise the consumer may end up in an infinite loop in some edge cases like\n            // adding a tab within the `selectedIndexChange` event.\n            this.indexToSelect = this._selectedIndex = i;\n            break;\n          }\n        }\n      }\n\n      this.subscribeToTabLabels();\n      this.cdr.markForCheck();\n    });\n  }\n\n  ngOnDestroy(): void {\n    this.tabsSubscription.unsubscribe();\n    this.tabLabelSubscription.unsubscribe();\n  }\n\n  ngAfterViewInit(): void {\n    this.setPosition(this.nzTabPosition);\n  }\n}\n"]}