ng-zorro-antd
Version:
An enterprise-class UI components based on Ant Design and Angular
562 lines • 49.9 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,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, Optional, Output, QueryList, Renderer2, TemplateRef, ViewChild, ViewEncapsulation } from '@angular/core';
import { NavigationEnd, Router } from '@angular/router';
import { merge, Subject, Subscription } from 'rxjs';
import { toNumber, InputBoolean, NzConfigService, NzUpdateHostClassService, PREFIX, WithConfig } from 'ng-zorro-antd/core';
import { filter, startWith, takeUntil } from 'rxjs/operators';
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;
}
export class NzTabChangeEvent {
}
if (false) {
/** @type {?} */
NzTabChangeEvent.prototype.index;
/** @type {?} */
NzTabChangeEvent.prototype.tab;
}
export class NzTabSetComponent {
/**
* @param {?} nzConfigService
* @param {?} renderer
* @param {?} nzUpdateHostClassService
* @param {?} elementRef
* @param {?} cdr
* @param {?} router
*/
constructor(nzConfigService, renderer, nzUpdateHostClassService, elementRef, cdr, router) {
this.nzConfigService = nzConfigService;
this.renderer = renderer;
this.nzUpdateHostClassService = nzUpdateHostClassService;
this.elementRef = elementRef;
this.cdr = cdr;
this.router = router;
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.destroy$ = new Subject();
this.tabPositionMode = 'horizontal';
this.nzHideAll = false;
this.nzTabPosition = 'top';
this.nzLinkRouter = false;
this.nzLinkExact = true;
this.nzOnNextClick = new EventEmitter();
this.nzOnPrevClick = new EventEmitter();
this.nzSelectChange = new EventEmitter(true);
this.nzSelectedIndexChange = new EventEmitter();
}
/**
* @param {?} value
* @return {?}
*/
set nzSelectedIndex(value) {
this.indexToSelect = value ? toNumber(value, null) : null;
}
/**
* @return {?}
*/
get nzSelectedIndex() {
return this._selectedIndex;
}
/**
* @return {?}
*/
get inkBarAnimated() {
return this.nzAnimated === true || ((/** @type {?} */ (this.nzAnimated))).inkBar === true;
}
/**
* @return {?}
*/
get tabPaneAnimated() {
return this.nzAnimated === true || ((/** @type {?} */ (this.nzAnimated))).tabPane === true;
}
/**
* @param {?} value
* @return {?}
*/
setPosition(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 {?}
*/
setClassMap() {
this.nzUpdateHostClassService.updateHostClass(this.el, {
[`ant-tabs`]: true,
[`ant-tabs-vertical`]: this.nzTabPosition === 'left' || this.nzTabPosition === 'right',
[`ant-tabs-${this.nzTabPosition}`]: this.nzTabPosition,
[`ant-tabs-no-animation`]: this.nzAnimated === false || ((/** @type {?} */ (this.nzAnimated))).tabPane === false,
[`ant-tabs-${this.nzType}`]: this.nzType,
[`ant-tabs-large`]: this.nzSize === 'large',
[`ant-tabs-small`]: this.nzSize === 'small'
});
}
/**
* @param {?} index
* @param {?} disabled
* @return {?}
*/
clickLabel(index, disabled) {
if (!disabled) {
/** @type {?} */
const tabs = this.listOfNzTabComponent.toArray();
this.nzSelectedIndex = index;
tabs[index].nzClick.emit();
}
}
/**
* @param {?} index
* @return {?}
*/
createChangeEvent(index) {
/** @type {?} */
const 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 {?}
*/
(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.
* @private
* @param {?} index
* @return {?}
*/
clampTabIndex(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 {?}
*/
subscribeToTabLabels() {
if (this.tabLabelSubscription) {
this.tabLabelSubscription.unsubscribe();
}
this.tabLabelSubscription = merge(...this.listOfNzTabComponent.map((/**
* @param {?} tab
* @return {?}
*/
tab => tab.stateChanges))).subscribe((/**
* @return {?}
*/
() => this.cdr.markForCheck()));
}
/**
* @param {?} changes
* @return {?}
*/
ngOnChanges(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 {?}
*/
ngOnInit() {
this.setClassMap();
}
/**
* @return {?}
*/
ngAfterContentChecked() {
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 {?} */
const indexToSelect = (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) {
/** @type {?} */
const isFirstRun = this._selectedIndex == null;
if (!isFirstRun) {
this.nzSelectChange.emit(this.createChangeEvent(indexToSelect));
}
// Changing these values after change detection has run
// since the checked content may contain references to them.
Promise.resolve().then((/**
* @return {?}
*/
() => {
this.listOfNzTabComponent.forEach((/**
* @param {?} tab
* @param {?} index
* @return {?}
*/
(tab, index) => (tab.isActive = index === indexToSelect)));
if (!isFirstRun) {
this.nzSelectedIndexChange.emit(indexToSelect);
}
}));
}
// Setup the position for each tab and optionally setup an origin on the next selected tab.
this.listOfNzTabComponent.forEach((/**
* @param {?} tab
* @param {?} index
* @return {?}
*/
(tab, index) => {
tab.position = index - indexToSelect;
// 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 - this._selectedIndex;
}
}));
if (this._selectedIndex !== indexToSelect) {
this._selectedIndex = indexToSelect;
this.cdr.markForCheck();
}
}
}
/**
* @return {?}
*/
ngAfterContentInit() {
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 {?}
*/
() => {
/** @type {?} */
const 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 {?} */
const tabs = this.listOfNzTabComponent.toArray();
for (let 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 {?}
*/
ngOnDestroy() {
this.tabsSubscription.unsubscribe();
this.tabLabelSubscription.unsubscribe();
}
/**
* @return {?}
*/
ngAfterViewInit() {
this.setPosition(this.nzTabPosition);
if (this.nzLinkRouter) {
if (!this.router) {
throw new Error(`${PREFIX} you should import 'RouterModule' if you want to use 'nzLinkRouter'!`);
}
this.router.events
.pipe(takeUntil(this.destroy$), filter((/**
* @param {?} e
* @return {?}
*/
e => e instanceof NavigationEnd)), startWith(true))
.subscribe((/**
* @return {?}
*/
() => {
this.updateRouterActive();
this.cdr.markForCheck();
}));
}
}
/**
* @private
* @return {?}
*/
updateRouterActive() {
if (this.router.navigated) {
/** @type {?} */
const index = this.findShouldActiveTabIndex();
if (index !== this._selectedIndex) {
this.nzSelectedIndex = index;
this.nzSelectedIndexChange.emit(index);
}
this.nzHideAll = index === -1;
}
}
/**
* @private
* @return {?}
*/
findShouldActiveTabIndex() {
/** @type {?} */
const tabs = this.listOfNzTabComponent.toArray();
/** @type {?} */
const isActive = this.isLinkActive(this.router);
return tabs.findIndex((/**
* @param {?} tab
* @return {?}
*/
tab => {
/** @type {?} */
const c = tab.linkDirective;
return c ? isActive(c.routerLink) || isActive(c.routerLinkWithHref) : false;
}));
}
/**
* @private
* @param {?} router
* @return {?}
*/
isLinkActive(router) {
return (/**
* @param {?=} link
* @return {?}
*/
(link) => (link ? router.isActive(link.urlTree, this.nzLinkExact) : false));
}
}
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.title\">{{ 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-card-content]=\"nzType === 'card'\"\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: [`
nz-tabset {
display: block;
}
`]
}] }
];
/** @nocollapse */
NzTabSetComponent.ctorParameters = () => [
{ type: NzConfigService },
{ type: Renderer2 },
{ type: NzUpdateHostClassService },
{ type: ElementRef },
{ type: ChangeDetectorRef },
{ type: Router, decorators: [{ type: Optional }] }
];
NzTabSetComponent.propDecorators = {
listOfNzTabComponent: [{ type: ContentChildren, args: [NzTabComponent,] }],
nzTabsNavComponent: [{ type: ViewChild, args: [NzTabsNavComponent, { static: false },] }],
tabContent: [{ type: ViewChild, args: ['tabContent', { static: false },] }],
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 }],
nzLinkRouter: [{ type: Input }],
nzLinkExact: [{ type: Input }],
nzOnNextClick: [{ type: Output }],
nzOnPrevClick: [{ type: Output }],
nzSelectChange: [{ type: Output }],
nzSelectedIndexChange: [{ type: Output }],
nzSelectedIndex: [{ type: Input }]
};
tslib_1.__decorate([
WithConfig(true),
tslib_1.__metadata("design:type", Boolean)
], NzTabSetComponent.prototype, "nzShowPagination", void 0);
tslib_1.__decorate([
WithConfig(true),
tslib_1.__metadata("design:type", Object)
], NzTabSetComponent.prototype, "nzAnimated", void 0);
tslib_1.__decorate([
WithConfig('default'),
tslib_1.__metadata("design:type", String)
], NzTabSetComponent.prototype, "nzSize", void 0);
tslib_1.__decorate([
WithConfig(),
tslib_1.__metadata("design:type", Number)
], NzTabSetComponent.prototype, "nzTabBarGutter", void 0);
tslib_1.__decorate([
WithConfig('line'),
tslib_1.__metadata("design:type", String)
], NzTabSetComponent.prototype, "nzType", void 0);
tslib_1.__decorate([
InputBoolean(),
tslib_1.__metadata("design:type", Object)
], NzTabSetComponent.prototype, "nzLinkRouter", void 0);
tslib_1.__decorate([
InputBoolean(),
tslib_1.__metadata("design:type", Object)
], NzTabSetComponent.prototype, "nzLinkExact", void 0);
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 {?}
* @private
*/
NzTabSetComponent.prototype.destroy$;
/** @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.nzLinkRouter;
/** @type {?} */
NzTabSetComponent.prototype.nzLinkExact;
/** @type {?} */
NzTabSetComponent.prototype.nzOnNextClick;
/** @type {?} */
NzTabSetComponent.prototype.nzOnPrevClick;
/** @type {?} */
NzTabSetComponent.prototype.nzSelectChange;
/** @type {?} */
NzTabSetComponent.prototype.nzSelectedIndexChange;
/** @type {?} */
NzTabSetComponent.prototype.nzConfigService;
/**
* @type {?}
* @private
*/
NzTabSetComponent.prototype.renderer;
/**
* @type {?}
* @private
*/
NzTabSetComponent.prototype.nzUpdateHostClassService;
/**
* @type {?}
* @private
*/
NzTabSetComponent.prototype.elementRef;
/**
* @type {?}
* @private
*/
NzTabSetComponent.prototype.cdr;
/**
* @type {?}
* @private
*/
NzTabSetComponent.prototype.router;
}
//# 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  Optional,\n  Output,\n  QueryList,\n  Renderer2,\n  SimpleChanges,\n  TemplateRef,\n  ViewChild,\n  ViewEncapsulation\n} from '@angular/core';\nimport { NavigationEnd, Router, RouterLink, RouterLinkWithHref } from '@angular/router';\nimport { merge, Subject, Subscription } from 'rxjs';\n\nimport {\n  toNumber,\n  InputBoolean,\n  NzConfigService,\n  NzFourDirectionType,\n  NzSizeLDSType,\n  NzUpdateHostClassService,\n  PREFIX,\n  WithConfig\n} from 'ng-zorro-antd/core';\nimport { filter, startWith, takeUntil } from 'rxjs/operators';\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 = NzFourDirectionType;\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\n  private destroy$ = new Subject<void>();\n\n  tabPositionMode: NzTabPositionMode = 'horizontal';\n  @ContentChildren(NzTabComponent) listOfNzTabComponent: QueryList<NzTabComponent>;\n  @ViewChild(NzTabsNavComponent, { static: false }) nzTabsNavComponent: NzTabsNavComponent;\n  @ViewChild('tabContent', { static: false }) tabContent: ElementRef;\n\n  @Input() nzTabBarExtraContent: TemplateRef<void>;\n  @Input() @WithConfig(true) nzShowPagination: boolean;\n  @Input() @WithConfig(true) nzAnimated: NzAnimatedInterface | boolean;\n  @Input() nzHideAll = false;\n  @Input() nzTabPosition: NzTabPosition = 'top';\n  @Input() @WithConfig('default') nzSize: NzSizeLDSType;\n  @Input() @WithConfig() nzTabBarGutter: number;\n  @Input() nzTabBarStyle: { [key: string]: string };\n  @Input() @WithConfig('line') nzType: NzTabType;\n\n  @Input() @InputBoolean() nzLinkRouter = false;\n  @Input() @InputBoolean() nzLinkExact = true;\n\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      const tabs = this.listOfNzTabComponent.toArray();\n      this.nzSelectedIndex = index;\n      tabs[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    public nzConfigService: NzConfigService,\n    private renderer: Renderer2,\n    private nzUpdateHostClassService: NzUpdateHostClassService,\n    private elementRef: ElementRef,\n    private cdr: ChangeDetectorRef,\n    @Optional() private router: Router\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    if (this.nzLinkRouter) {\n      if (!this.router) {\n        throw new Error(`${PREFIX} you should import 'RouterModule' if you want to use 'nzLinkRouter'!`);\n      }\n\n      this.router.events\n        .pipe(\n          takeUntil(this.destroy$),\n          filter(e => e instanceof NavigationEnd),\n          startWith(true)\n        )\n        .subscribe(() => {\n          this.updateRouterActive();\n          this.cdr.markForCheck();\n        });\n    }\n  }\n\n  private updateRouterActive(): void {\n    if (this.router.navigated) {\n      const index = this.findShouldActiveTabIndex();\n      if (index !== this._selectedIndex) {\n        this.nzSelectedIndex = index;\n        this.nzSelectedIndexChange.emit(index);\n      }\n      this.nzHideAll = index === -1;\n    }\n  }\n\n  private findShouldActiveTabIndex(): number {\n    const tabs = this.listOfNzTabComponent.toArray();\n    const isActive = this.isLinkActive(this.router);\n\n    return tabs.findIndex(tab => {\n      const c = tab.linkDirective;\n      return c ? isActive(c.routerLink) || isActive(c.routerLinkWithHref) : false;\n    });\n  }\n\n  private isLinkActive(router: Router): (link?: RouterLink | RouterLinkWithHref) => boolean {\n    return (link?: RouterLink | RouterLinkWithHref) => (link ? router.isActive(link.urlTree, this.nzLinkExact) : false);\n  }\n}\n"]}