ng-zorro-antd
Version:
An enterprise-class UI components based on Ant Design and Angular
605 lines • 54.7 kB
JavaScript
/**
* @fileoverview added by tsickle
* Generated from: tabs-nav.component.ts
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { __decorate, __metadata } 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
*/
/** code from https://github.com/angular/material2 */
import { Directionality } from '@angular/cdk/bidi';
import { Platform } from '@angular/cdk/platform';
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ContentChildren, ElementRef, EventEmitter, Input, NgZone, Optional, Output, QueryList, Renderer2, TemplateRef, ViewChild, ViewEncapsulation } from '@angular/core';
import { NzResizeService } from 'ng-zorro-antd/core/services';
import { InputBoolean, pxToNumber } from 'ng-zorro-antd/core/util';
import { merge, of as observableOf, Subject } from 'rxjs';
import { startWith, takeUntil } from 'rxjs/operators';
import { NzTabLabelDirective } from './tab-label.directive';
import { NzTabsInkBarDirective } from './tabs-ink-bar.directive';
/** @type {?} */
const EXAGGERATED_OVERSCROLL = 64;
export class NzTabsNavComponent {
/**
* @param {?} elementRef
* @param {?} ngZone
* @param {?} renderer
* @param {?} cdr
* @param {?} platform
* @param {?} resizeService
* @param {?} dir
*/
constructor(elementRef, ngZone, renderer, cdr, platform, resizeService, dir) {
this.elementRef = elementRef;
this.ngZone = ngZone;
this.renderer = renderer;
this.cdr = cdr;
this.platform = platform;
this.resizeService = resizeService;
this.dir = dir;
this._tabPositionMode = 'horizontal';
this._scrollDistance = 0;
this._selectedIndex = 0;
this.destroy$ = new Subject();
this.showPaginationControls = false;
this.disableScrollAfter = true;
this.disableScrollBefore = true;
this.selectedIndexChanged = false;
this.realignInkBar = null;
this.nzOnNextClick = new EventEmitter();
this.nzOnPrevClick = new EventEmitter();
this.nzAnimated = true;
this.nzHideBar = false;
this.nzShowPagination = true;
this.nzType = 'line';
this.nzTabPosition = 'top';
}
/**
* @param {?} value
* @return {?}
*/
set nzPositionMode(value) {
this._tabPositionMode = value;
this.alignInkBarToSelectedTab();
if (this.nzShowPagination) {
Promise.resolve().then((/**
* @return {?}
*/
() => {
this.updatePagination();
}));
}
}
/**
* @return {?}
*/
get nzPositionMode() {
return this._tabPositionMode;
}
/**
* @param {?} value
* @return {?}
*/
set selectedIndex(value) {
this.selectedIndexChanged = this._selectedIndex !== value;
this._selectedIndex = value;
}
/**
* @return {?}
*/
get selectedIndex() {
return this._selectedIndex;
}
/**
* @return {?}
*/
onContentChanges() {
/** @type {?} */
const textContent = this.elementRef.nativeElement.textContent;
// We need to diff the text content of the header, because the MutationObserver callback
// will fire even if the text content didn't change which is inefficient and is prone
// to infinite loops if a poorly constructed expression is passed in (see #14249).
if (textContent !== this.currentTextContent) {
this.currentTextContent = textContent;
this.ngZone.run((/**
* @return {?}
*/
() => {
if (this.nzShowPagination) {
this.updatePagination();
}
this.alignInkBarToSelectedTab();
this.cdr.markForCheck();
}));
}
}
/**
* @param {?} scrollDir
* @return {?}
*/
scrollHeader(scrollDir) {
if (scrollDir === 'before' && !this.disableScrollBefore) {
this.nzOnPrevClick.emit();
}
else if (scrollDir === 'after' && !this.disableScrollAfter) {
this.nzOnNextClick.emit();
}
// Move the scroll distance one-third the length of the tab list's viewport.
this.scrollDistance += ((scrollDir === 'before' ? -1 : 1) * this.viewWidthHeightPix) / 3;
}
/**
* @return {?}
*/
ngAfterContentChecked() {
if (this.tabLabelCount !== this.listOfNzTabLabelDirective.length) {
if (this.nzShowPagination) {
this.updatePagination();
}
this.tabLabelCount = this.listOfNzTabLabelDirective.length;
this.cdr.markForCheck();
}
if (this.selectedIndexChanged) {
this.scrollToLabel(this._selectedIndex);
if (this.nzShowPagination) {
this.checkScrollingControls();
}
this.alignInkBarToSelectedTab();
this.selectedIndexChanged = false;
this.cdr.markForCheck();
}
if (this.scrollDistanceChanged) {
if (this.nzShowPagination) {
this.updateTabScrollPosition();
}
this.scrollDistanceChanged = false;
this.cdr.markForCheck();
}
}
/**
* @return {?}
*/
ngAfterContentInit() {
this.realignInkBar = this.ngZone.runOutsideAngular((/**
* @return {?}
*/
() => {
/** @type {?} */
const dirChange = this.dir ? this.dir.change : observableOf(null);
/** @type {?} */
const resize = typeof window !== 'undefined' ? this.resizeService.subscribe().pipe(takeUntil(this.destroy$)) : observableOf(null);
return merge(dirChange, resize)
.pipe(startWith(null))
.subscribe((/**
* @return {?}
*/
() => {
if (this.nzShowPagination) {
this.updatePagination();
}
this.alignInkBarToSelectedTab();
}));
}));
}
/**
* @return {?}
*/
ngOnDestroy() {
this.destroy$.next();
this.destroy$.complete();
if (this.realignInkBar) {
this.realignInkBar.unsubscribe();
}
}
/**
* @return {?}
*/
updateTabScrollPosition() {
/** @type {?} */
const scrollDistance = this.scrollDistance;
if (this.nzPositionMode === 'horizontal') {
/** @type {?} */
const translateX = this.getLayoutDirection() === 'ltr' ? -scrollDistance : scrollDistance;
this.renderer.setStyle(this.navListElement.nativeElement, 'transform', `translate3d(${translateX}px, 0, 0)`);
}
else {
this.renderer.setStyle(this.navListElement.nativeElement, 'transform', `translate3d(0,${-scrollDistance}px, 0)`);
}
}
/**
* @return {?}
*/
updatePagination() {
this.checkPaginationEnabled();
this.checkScrollingControls();
this.updateTabScrollPosition();
}
/**
* @return {?}
*/
checkPaginationEnabled() {
/** @type {?} */
const isEnabled = this.tabListScrollWidthHeightPix > this.tabListScrollOffSetWidthHeight;
if (!isEnabled) {
this.scrollDistance = 0;
}
if (isEnabled !== this.showPaginationControls) {
this.cdr.markForCheck();
}
this.showPaginationControls = isEnabled;
}
/**
* @param {?} labelIndex
* @return {?}
*/
scrollToLabel(labelIndex) {
/** @type {?} */
const selectedLabel = this.listOfNzTabLabelDirective ? this.listOfNzTabLabelDirective.toArray()[labelIndex] : null;
if (selectedLabel) {
// The view length is the visible width of the tab labels.
/** @type {?} */
let labelBeforePos;
/** @type {?} */
let labelAfterPos;
if (this.nzPositionMode === 'horizontal') {
if (this.getLayoutDirection() === 'ltr') {
labelBeforePos = selectedLabel.getOffsetLeft();
labelAfterPos = labelBeforePos + selectedLabel.getOffsetWidth();
}
else {
labelAfterPos = this.navListElement.nativeElement.offsetWidth - selectedLabel.getOffsetLeft();
labelBeforePos = labelAfterPos - selectedLabel.getOffsetWidth();
}
}
else {
labelBeforePos = selectedLabel.getOffsetTop();
labelAfterPos = labelBeforePos + selectedLabel.getOffsetHeight();
}
/** @type {?} */
const beforeVisiblePos = this.scrollDistance;
/** @type {?} */
const afterVisiblePos = this.scrollDistance + this.viewWidthHeightPix;
if (labelBeforePos < beforeVisiblePos) {
// Scroll header to move label to the before direction
this.scrollDistance -= beforeVisiblePos - labelBeforePos + EXAGGERATED_OVERSCROLL;
}
else if (labelAfterPos > afterVisiblePos) {
// Scroll header to move label to the after direction
this.scrollDistance += labelAfterPos - afterVisiblePos + EXAGGERATED_OVERSCROLL;
}
}
}
/**
* @return {?}
*/
checkScrollingControls() {
// Check if the pagination arrows should be activated.
this.disableScrollBefore = this.scrollDistance === 0;
this.disableScrollAfter = this.scrollDistance === this.getMaxScrollDistance();
this.cdr.markForCheck();
}
/**
* Determines what is the maximum length in pixels that can be set for the scroll distance. This
* is equal to the difference in width between the tab list container and tab header container.
*
* This is an expensive call that forces a layout reflow to compute box and scroll metrics and
* should be called sparingly.
* @return {?}
*/
getMaxScrollDistance() {
return this.tabListScrollWidthHeightPix - this.viewWidthHeightPix || 0;
}
/**
* Sets the distance in pixels that the tab header should be transformed in the X-axis.
* @param {?} v
* @return {?}
*/
set scrollDistance(v) {
this._scrollDistance = Math.max(0, Math.min(this.getMaxScrollDistance(), v));
// Mark that the scroll distance has changed so that after the view is checked, the CSS
// transformation can move the header.
this.scrollDistanceChanged = true;
this.checkScrollingControls();
}
/**
* @return {?}
*/
get scrollDistance() {
return this._scrollDistance;
}
/**
* @return {?}
*/
get viewWidthHeightPix() {
/** @type {?} */
let PAGINATION_PIX = 0;
if (this.showPaginationControls) {
PAGINATION_PIX = this.navContainerScrollPaddingPix;
}
if (this.nzPositionMode === 'horizontal') {
return this.navContainerElement.nativeElement.offsetWidth - PAGINATION_PIX;
}
else {
return this.navContainerElement.nativeElement.offsetHeight - PAGINATION_PIX;
}
}
/**
* @return {?}
*/
get navContainerScrollPaddingPix() {
if (this.platform.isBrowser) {
/** @type {?} */
const navContainer = this.navContainerElement.nativeElement;
/** @type {?} */
const originStyle = window.getComputedStyle
? window.getComputedStyle(navContainer)
: ((/** @type {?} */ (navContainer))).currentStyle;
if (this.nzPositionMode === 'horizontal') {
return pxToNumber(originStyle.paddingLeft) + pxToNumber(originStyle.paddingRight);
}
else {
return pxToNumber(originStyle.paddingTop) + pxToNumber(originStyle.paddingBottom);
}
}
else {
return 0;
}
}
/**
* @return {?}
*/
get tabListScrollWidthHeightPix() {
if (this.nzPositionMode === 'horizontal') {
return this.navListElement.nativeElement.scrollWidth;
}
else {
return this.navListElement.nativeElement.scrollHeight;
}
}
/**
* @return {?}
*/
get tabListScrollOffSetWidthHeight() {
if (this.nzPositionMode === 'horizontal') {
return this.scrollListElement.nativeElement.offsetWidth;
}
else {
return this.elementRef.nativeElement.offsetHeight;
}
}
/**
* @return {?}
*/
getLayoutDirection() {
return this.dir && this.dir.value === 'rtl' ? 'rtl' : 'ltr';
}
/**
* @return {?}
*/
alignInkBarToSelectedTab() {
if (this.nzType === 'line') {
/** @type {?} */
const selectedLabelWrapper = this.listOfNzTabLabelDirective && this.listOfNzTabLabelDirective.length
? this.listOfNzTabLabelDirective.toArray()[this.selectedIndex].elementRef.nativeElement
: null;
if (this.nzTabsInkBarDirective) {
this.nzTabsInkBarDirective.alignToElement(selectedLabelWrapper);
}
}
}
}
NzTabsNavComponent.decorators = [
{ type: Component, args: [{
selector: 'nz-tabs-nav',
exportAs: 'nzTabsNav',
preserveWhitespaces: false,
changeDetection: ChangeDetectionStrategy.OnPush,
encapsulation: ViewEncapsulation.None,
template: `
<div style="float:right;" *ngIf="nzTabBarExtraContent" class="ant-tabs-extra-content">
<ng-template [ngTemplateOutlet]="nzTabBarExtraContent"></ng-template>
</div>
<div class="ant-tabs-nav-container" [class.ant-tabs-nav-container-scrolling]="showPaginationControls" #navContainerElement>
<span
class="ant-tabs-tab-prev"
(click)="scrollHeader('before')"
[class.ant-tabs-tab-btn-disabled]="disableScrollBefore"
[class.ant-tabs-tab-arrow-show]="showPaginationControls"
>
<span class="ant-tabs-tab-prev-icon">
<i nz-icon [nzType]="nzPositionMode === 'horizontal' ? 'left' : 'up'" class="ant-tabs-tab-prev-icon-target"></i>
</span>
</span>
<span
class="ant-tabs-tab-next"
(click)="scrollHeader('after')"
[class.ant-tabs-tab-btn-disabled]="disableScrollAfter"
[class.ant-tabs-tab-arrow-show]="showPaginationControls"
>
<span class="ant-tabs-tab-next-icon">
<i nz-icon [nzType]="nzPositionMode === 'horizontal' ? 'right' : 'down'" class="ant-tabs-tab-next-icon-target"></i>
</span>
</span>
<div class="ant-tabs-nav-wrap">
<div class="ant-tabs-nav-scroll" #scrollListElement>
<div class="ant-tabs-nav" [class.ant-tabs-nav-animated]="nzAnimated" #navListElement (cdkObserveContent)="onContentChanges()">
<div>
<ng-content></ng-content>
</div>
<div
nz-tabs-ink-bar
[hidden]="nzHideBar"
[nzAnimated]="nzAnimated"
[nzPositionMode]="nzPositionMode"
style="display: block;"
></div>
</div>
</div>
</div>
</div>
`,
host: {
'[class.ant-tabs-bar]': 'true',
'[class.ant-tabs-card-bar]': `nzType === 'card'`,
'[class.ant-tabs-top-bar]': `nzTabPosition === 'top'`,
'[class.ant-tabs-bottom-bar]': `nzTabPosition === 'bottom'`,
'[class.ant-tabs-left-bar]': `nzTabPosition === 'left'`,
'[class.ant-tabs-right-bar]': `nzTabPosition === 'right'`,
'[class.ant-tabs-small-bar]': `nzSize === 'small'`,
'[class.ant-tabs-default-bar]': `nzSize === 'default'`,
'[class.ant-tabs-large-bar]': `nzSize === 'large'`
}
}] }
];
/** @nocollapse */
NzTabsNavComponent.ctorParameters = () => [
{ type: ElementRef },
{ type: NgZone },
{ type: Renderer2 },
{ type: ChangeDetectorRef },
{ type: Platform },
{ type: NzResizeService },
{ type: Directionality, decorators: [{ type: Optional }] }
];
NzTabsNavComponent.propDecorators = {
listOfNzTabLabelDirective: [{ type: ContentChildren, args: [NzTabLabelDirective,] }],
nzTabsInkBarDirective: [{ type: ViewChild, args: [NzTabsInkBarDirective, { static: true },] }],
navContainerElement: [{ type: ViewChild, args: ['navContainerElement', { static: true },] }],
navListElement: [{ type: ViewChild, args: ['navListElement', { static: true },] }],
scrollListElement: [{ type: ViewChild, args: ['scrollListElement', { static: true },] }],
nzOnNextClick: [{ type: Output }],
nzOnPrevClick: [{ type: Output }],
nzTabBarExtraContent: [{ type: Input }],
nzAnimated: [{ type: Input }],
nzHideBar: [{ type: Input }],
nzShowPagination: [{ type: Input }],
nzType: [{ type: Input }],
nzSize: [{ type: Input }],
nzTabPosition: [{ type: Input }],
nzPositionMode: [{ type: Input }],
selectedIndex: [{ type: Input }]
};
__decorate([
InputBoolean(),
__metadata("design:type", Object)
], NzTabsNavComponent.prototype, "nzAnimated", void 0);
__decorate([
InputBoolean(),
__metadata("design:type", Object)
], NzTabsNavComponent.prototype, "nzHideBar", void 0);
__decorate([
InputBoolean(),
__metadata("design:type", Object)
], NzTabsNavComponent.prototype, "nzShowPagination", void 0);
if (false) {
/** @type {?} */
NzTabsNavComponent.ngAcceptInputType_nzAnimated;
/** @type {?} */
NzTabsNavComponent.ngAcceptInputType_nzHideBar;
/** @type {?} */
NzTabsNavComponent.ngAcceptInputType_nzShowPagination;
/**
* @type {?}
* @private
*/
NzTabsNavComponent.prototype._tabPositionMode;
/**
* @type {?}
* @private
*/
NzTabsNavComponent.prototype._scrollDistance;
/**
* @type {?}
* @private
*/
NzTabsNavComponent.prototype._selectedIndex;
/**
* Cached text content of the header.
* @type {?}
* @private
*/
NzTabsNavComponent.prototype.currentTextContent;
/**
* @type {?}
* @private
*/
NzTabsNavComponent.prototype.destroy$;
/** @type {?} */
NzTabsNavComponent.prototype.showPaginationControls;
/** @type {?} */
NzTabsNavComponent.prototype.disableScrollAfter;
/** @type {?} */
NzTabsNavComponent.prototype.disableScrollBefore;
/** @type {?} */
NzTabsNavComponent.prototype.selectedIndexChanged;
/** @type {?} */
NzTabsNavComponent.prototype.realignInkBar;
/** @type {?} */
NzTabsNavComponent.prototype.tabLabelCount;
/** @type {?} */
NzTabsNavComponent.prototype.scrollDistanceChanged;
/** @type {?} */
NzTabsNavComponent.prototype.listOfNzTabLabelDirective;
/** @type {?} */
NzTabsNavComponent.prototype.nzTabsInkBarDirective;
/** @type {?} */
NzTabsNavComponent.prototype.navContainerElement;
/** @type {?} */
NzTabsNavComponent.prototype.navListElement;
/** @type {?} */
NzTabsNavComponent.prototype.scrollListElement;
/** @type {?} */
NzTabsNavComponent.prototype.nzOnNextClick;
/** @type {?} */
NzTabsNavComponent.prototype.nzOnPrevClick;
/** @type {?} */
NzTabsNavComponent.prototype.nzTabBarExtraContent;
/** @type {?} */
NzTabsNavComponent.prototype.nzAnimated;
/** @type {?} */
NzTabsNavComponent.prototype.nzHideBar;
/** @type {?} */
NzTabsNavComponent.prototype.nzShowPagination;
/** @type {?} */
NzTabsNavComponent.prototype.nzType;
/** @type {?} */
NzTabsNavComponent.prototype.nzSize;
/** @type {?} */
NzTabsNavComponent.prototype.nzTabPosition;
/** @type {?} */
NzTabsNavComponent.prototype.elementRef;
/**
* @type {?}
* @private
*/
NzTabsNavComponent.prototype.ngZone;
/**
* @type {?}
* @private
*/
NzTabsNavComponent.prototype.renderer;
/**
* @type {?}
* @private
*/
NzTabsNavComponent.prototype.cdr;
/**
* @type {?}
* @private
*/
NzTabsNavComponent.prototype.platform;
/**
* @type {?}
* @private
*/
NzTabsNavComponent.prototype.resizeService;
/**
* @type {?}
* @private
*/
NzTabsNavComponent.prototype.dir;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tabs-nav.component.js","sourceRoot":"ng://ng-zorro-antd/tabs/","sources":["tabs-nav.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/** code from https://github.com/angular/material2 */\nimport { Direction, Directionality } from '@angular/cdk/bidi';\nimport { Platform } from '@angular/cdk/platform';\nimport {\n  AfterContentChecked,\n  AfterContentInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChildren,\n  ElementRef,\n  EventEmitter,\n  Input,\n  NgZone,\n  OnDestroy,\n  Optional,\n  Output,\n  QueryList,\n  Renderer2,\n  TemplateRef,\n  ViewChild,\n  ViewEncapsulation\n} from '@angular/core';\nimport { NzResizeService } from 'ng-zorro-antd/core/services';\nimport { BooleanInput, NzSafeAny, NzSizeLDSType } from 'ng-zorro-antd/core/types';\nimport { InputBoolean, pxToNumber } from 'ng-zorro-antd/core/util';\nimport { merge, of as observableOf, Subject, Subscription } from 'rxjs';\nimport { startWith, takeUntil } from 'rxjs/operators';\n\nimport { NzTabLabelDirective } from './tab-label.directive';\nimport { NzTabPosition, NzTabPositionMode } from './table.types';\nimport { NzTabsInkBarDirective } from './tabs-ink-bar.directive';\n\nconst EXAGGERATED_OVERSCROLL = 64;\nexport type ScrollDirection = 'after' | 'before';\n\n@Component({\n  selector: 'nz-tabs-nav',\n  exportAs: 'nzTabsNav',\n  preserveWhitespaces: false,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  template: `\n    <div style=\"float:right;\" *ngIf=\"nzTabBarExtraContent\" class=\"ant-tabs-extra-content\">\n      <ng-template [ngTemplateOutlet]=\"nzTabBarExtraContent\"></ng-template>\n    </div>\n    <div class=\"ant-tabs-nav-container\" [class.ant-tabs-nav-container-scrolling]=\"showPaginationControls\" #navContainerElement>\n      <span\n        class=\"ant-tabs-tab-prev\"\n        (click)=\"scrollHeader('before')\"\n        [class.ant-tabs-tab-btn-disabled]=\"disableScrollBefore\"\n        [class.ant-tabs-tab-arrow-show]=\"showPaginationControls\"\n      >\n        <span class=\"ant-tabs-tab-prev-icon\">\n          <i nz-icon [nzType]=\"nzPositionMode === 'horizontal' ? 'left' : 'up'\" class=\"ant-tabs-tab-prev-icon-target\"></i>\n        </span>\n      </span>\n      <span\n        class=\"ant-tabs-tab-next\"\n        (click)=\"scrollHeader('after')\"\n        [class.ant-tabs-tab-btn-disabled]=\"disableScrollAfter\"\n        [class.ant-tabs-tab-arrow-show]=\"showPaginationControls\"\n      >\n        <span class=\"ant-tabs-tab-next-icon\">\n          <i nz-icon [nzType]=\"nzPositionMode === 'horizontal' ? 'right' : 'down'\" class=\"ant-tabs-tab-next-icon-target\"></i>\n        </span>\n      </span>\n      <div class=\"ant-tabs-nav-wrap\">\n        <div class=\"ant-tabs-nav-scroll\" #scrollListElement>\n          <div class=\"ant-tabs-nav\" [class.ant-tabs-nav-animated]=\"nzAnimated\" #navListElement (cdkObserveContent)=\"onContentChanges()\">\n            <div>\n              <ng-content></ng-content>\n            </div>\n            <div\n              nz-tabs-ink-bar\n              [hidden]=\"nzHideBar\"\n              [nzAnimated]=\"nzAnimated\"\n              [nzPositionMode]=\"nzPositionMode\"\n              style=\"display: block;\"\n            ></div>\n          </div>\n        </div>\n      </div>\n    </div>\n  `,\n  host: {\n    '[class.ant-tabs-bar]': 'true',\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  }\n})\nexport class NzTabsNavComponent implements AfterContentChecked, AfterContentInit, OnDestroy {\n  static ngAcceptInputType_nzAnimated: BooleanInput;\n  static ngAcceptInputType_nzHideBar: BooleanInput;\n  static ngAcceptInputType_nzShowPagination: BooleanInput;\n\n  private _tabPositionMode: NzTabPositionMode = 'horizontal';\n  private _scrollDistance = 0;\n  private _selectedIndex = 0;\n  /** Cached text content of the header. */\n  private currentTextContent?: string;\n  private destroy$ = new Subject<void>();\n  showPaginationControls = false;\n  disableScrollAfter = true;\n  disableScrollBefore = true;\n  selectedIndexChanged = false;\n  realignInkBar: Subscription | null = null;\n  tabLabelCount?: number;\n  scrollDistanceChanged?: boolean;\n  @ContentChildren(NzTabLabelDirective) listOfNzTabLabelDirective!: QueryList<NzTabLabelDirective>;\n  @ViewChild(NzTabsInkBarDirective, { static: true }) nzTabsInkBarDirective!: NzTabsInkBarDirective;\n  @ViewChild('navContainerElement', { static: true }) navContainerElement!: ElementRef<HTMLDivElement>;\n  @ViewChild('navListElement', { static: true }) navListElement!: ElementRef<HTMLDivElement>;\n  @ViewChild('scrollListElement', { static: true }) scrollListElement!: ElementRef<HTMLDivElement>;\n  @Output() readonly nzOnNextClick = new EventEmitter<void>();\n  @Output() readonly nzOnPrevClick = new EventEmitter<void>();\n  @Input() nzTabBarExtraContent?: TemplateRef<void>;\n  @Input() @InputBoolean() nzAnimated = true;\n  @Input() @InputBoolean() nzHideBar = false;\n  @Input() @InputBoolean() nzShowPagination = true;\n  @Input() nzType = 'line';\n  @Input() nzSize?: NzSizeLDSType;\n  @Input() nzTabPosition: NzTabPosition = 'top';\n\n  @Input()\n  set nzPositionMode(value: NzTabPositionMode) {\n    this._tabPositionMode = value;\n    this.alignInkBarToSelectedTab();\n    if (this.nzShowPagination) {\n      Promise.resolve().then(() => {\n        this.updatePagination();\n      });\n    }\n  }\n\n  get nzPositionMode(): NzTabPositionMode {\n    return this._tabPositionMode;\n  }\n\n  @Input()\n  set selectedIndex(value: number) {\n    this.selectedIndexChanged = this._selectedIndex !== value;\n    this._selectedIndex = value;\n  }\n\n  get selectedIndex(): number {\n    return this._selectedIndex;\n  }\n\n  constructor(\n    public elementRef: ElementRef,\n    private ngZone: NgZone,\n    private renderer: Renderer2,\n    private cdr: ChangeDetectorRef,\n    private platform: Platform,\n    private resizeService: NzResizeService,\n    @Optional() private dir: Directionality\n  ) {}\n\n  onContentChanges(): void {\n    const textContent = this.elementRef.nativeElement.textContent;\n    // We need to diff the text content of the header, because the MutationObserver callback\n    // will fire even if the text content didn't change which is inefficient and is prone\n    // to infinite loops if a poorly constructed expression is passed in (see #14249).\n    if (textContent !== this.currentTextContent) {\n      this.currentTextContent = textContent;\n      this.ngZone.run(() => {\n        if (this.nzShowPagination) {\n          this.updatePagination();\n        }\n        this.alignInkBarToSelectedTab();\n        this.cdr.markForCheck();\n      });\n    }\n  }\n\n  scrollHeader(scrollDir: ScrollDirection): void {\n    if (scrollDir === 'before' && !this.disableScrollBefore) {\n      this.nzOnPrevClick.emit();\n    } else if (scrollDir === 'after' && !this.disableScrollAfter) {\n      this.nzOnNextClick.emit();\n    }\n    // Move the scroll distance one-third the length of the tab list's viewport.\n    this.scrollDistance += ((scrollDir === 'before' ? -1 : 1) * this.viewWidthHeightPix) / 3;\n  }\n\n  ngAfterContentChecked(): void {\n    if (this.tabLabelCount !== this.listOfNzTabLabelDirective.length) {\n      if (this.nzShowPagination) {\n        this.updatePagination();\n      }\n      this.tabLabelCount = this.listOfNzTabLabelDirective.length;\n      this.cdr.markForCheck();\n    }\n    if (this.selectedIndexChanged) {\n      this.scrollToLabel(this._selectedIndex);\n      if (this.nzShowPagination) {\n        this.checkScrollingControls();\n      }\n      this.alignInkBarToSelectedTab();\n      this.selectedIndexChanged = false;\n      this.cdr.markForCheck();\n    }\n    if (this.scrollDistanceChanged) {\n      if (this.nzShowPagination) {\n        this.updateTabScrollPosition();\n      }\n      this.scrollDistanceChanged = false;\n      this.cdr.markForCheck();\n    }\n  }\n\n  ngAfterContentInit(): void {\n    this.realignInkBar = this.ngZone.runOutsideAngular(() => {\n      const dirChange = this.dir ? this.dir.change : observableOf(null);\n      const resize = typeof window !== 'undefined' ? this.resizeService.subscribe().pipe(takeUntil(this.destroy$)) : observableOf(null);\n      return merge(dirChange, resize)\n        .pipe(startWith(null))\n        .subscribe(() => {\n          if (this.nzShowPagination) {\n            this.updatePagination();\n          }\n          this.alignInkBarToSelectedTab();\n        });\n    });\n  }\n\n  ngOnDestroy(): void {\n    this.destroy$.next();\n    this.destroy$.complete();\n\n    if (this.realignInkBar) {\n      this.realignInkBar.unsubscribe();\n    }\n  }\n\n  updateTabScrollPosition(): void {\n    const scrollDistance = this.scrollDistance;\n    if (this.nzPositionMode === 'horizontal') {\n      const translateX = this.getLayoutDirection() === 'ltr' ? -scrollDistance : scrollDistance;\n      this.renderer.setStyle(this.navListElement.nativeElement, 'transform', `translate3d(${translateX}px, 0, 0)`);\n    } else {\n      this.renderer.setStyle(this.navListElement.nativeElement, 'transform', `translate3d(0,${-scrollDistance}px, 0)`);\n    }\n  }\n\n  updatePagination(): void {\n    this.checkPaginationEnabled();\n    this.checkScrollingControls();\n    this.updateTabScrollPosition();\n  }\n\n  checkPaginationEnabled(): void {\n    const isEnabled = this.tabListScrollWidthHeightPix > this.tabListScrollOffSetWidthHeight;\n    if (!isEnabled) {\n      this.scrollDistance = 0;\n    }\n    if (isEnabled !== this.showPaginationControls) {\n      this.cdr.markForCheck();\n    }\n    this.showPaginationControls = isEnabled;\n  }\n\n  scrollToLabel(labelIndex: number): void {\n    const selectedLabel = this.listOfNzTabLabelDirective ? this.listOfNzTabLabelDirective.toArray()[labelIndex] : null;\n\n    if (selectedLabel) {\n      // The view length is the visible width of the tab labels.\n\n      let labelBeforePos: number;\n      let labelAfterPos: number;\n      if (this.nzPositionMode === 'horizontal') {\n        if (this.getLayoutDirection() === 'ltr') {\n          labelBeforePos = selectedLabel.getOffsetLeft();\n          labelAfterPos = labelBeforePos + selectedLabel.getOffsetWidth();\n        } else {\n          labelAfterPos = this.navListElement.nativeElement.offsetWidth - selectedLabel.getOffsetLeft();\n          labelBeforePos = labelAfterPos - selectedLabel.getOffsetWidth();\n        }\n      } else {\n        labelBeforePos = selectedLabel.getOffsetTop();\n        labelAfterPos = labelBeforePos + selectedLabel.getOffsetHeight();\n      }\n      const beforeVisiblePos = this.scrollDistance;\n      const afterVisiblePos = this.scrollDistance + this.viewWidthHeightPix;\n\n      if (labelBeforePos < beforeVisiblePos) {\n        // Scroll header to move label to the before direction\n        this.scrollDistance -= beforeVisiblePos - labelBeforePos + EXAGGERATED_OVERSCROLL;\n      } else if (labelAfterPos > afterVisiblePos) {\n        // Scroll header to move label to the afte