UNPKG

ng-zorro-antd-yj

Version:

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

473 lines 43.4 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import * as tslib_1 from "tslib"; /** code from https://github.com/angular/material2 */ import { Directionality } from '@angular/cdk/bidi'; import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ContentChildren, ElementRef, EventEmitter, Input, NgZone, Optional, Output, QueryList, Renderer2, TemplateRef, ViewChild, ViewEncapsulation } from '@angular/core'; import { fromEvent, merge, of as observableOf } from 'rxjs'; import { auditTime, startWith } from 'rxjs/operators'; import { InputBoolean } from '../core/util/convert'; import { NzTabLabelDirective } from './nz-tab-label.directive'; import { NzTabsInkBarDirective } from './nz-tabs-ink-bar.directive'; /** @type {?} */ const EXAGGERATED_OVERSCROLL = 64; export class NzTabsNavComponent { /** * @param {?} elementRef * @param {?} ngZone * @param {?} renderer * @param {?} cdr * @param {?} dir */ constructor(elementRef, ngZone, renderer, cdr, dir) { this.elementRef = elementRef; this.ngZone = ngZone; this.renderer = renderer; this.cdr = cdr; this.dir = dir; this._tabPositionMode = 'horizontal'; this._scrollDistance = 0; this._selectedIndex = 0; 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'; } /** * @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.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' ? fromEvent(window, 'resize').pipe(auditTime(10)) : observableOf(null); return merge(dirChange, resize) .pipe(startWith(null)) .subscribe((/** * @return {?} */ () => { if (this.nzShowPagination) { this.updatePagination(); } this.alignInkBarToSelectedTab(); })); })); } /** * @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 = 64; } if (this.nzPositionMode === 'horizontal') { return this.navContainerElement.nativeElement.offsetWidth - PAGINATION_PIX; } else { return this.navContainerElement.nativeElement.offsetHeight - PAGINATION_PIX; } } /** * @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]', preserveWhitespaces: false, changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, template: "<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\"\n [class.ant-tabs-nav-container-scrolling]=\"showPaginationControls\"\n #navContainerElement>\n <span 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 <span class=\"ant-tabs-tab-prev-icon\">\n <i nz-icon [type]=\"nzPositionMode === 'horizontal' ? 'left' : 'up'\" class=\"ant-tabs-tab-prev-icon-target\"></i>\n </span>\n </span>\n <span 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 <span class=\"ant-tabs-tab-next-icon\">\n <i nz-icon [type]=\"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\"\n [class.ant-tabs-nav-animated]=\"nzAnimated\"\n #navListElement\n (cdkObserveContent)=\"onContentChanges()\">\n <div>\n <ng-content></ng-content>\n </div>\n <div nz-tabs-ink-bar [hidden]=\"nzHideBar\" [nzAnimated]=\"nzAnimated\" [nzPositionMode]=\"nzPositionMode\" style=\"display: block;\"></div>\n </div>\n </div>\n </div>\n</div>" }] } ]; /** @nocollapse */ NzTabsNavComponent.ctorParameters = () => [ { type: ElementRef }, { type: NgZone }, { type: Renderer2 }, { type: ChangeDetectorRef }, { type: Directionality, decorators: [{ type: Optional }] } ]; NzTabsNavComponent.propDecorators = { listOfNzTabLabelDirective: [{ type: ContentChildren, args: [NzTabLabelDirective,] }], nzTabsInkBarDirective: [{ type: ViewChild, args: [NzTabsInkBarDirective,] }], navContainerElement: [{ type: ViewChild, args: ['navContainerElement',] }], navListElement: [{ type: ViewChild, args: ['navListElement',] }], scrollListElement: [{ type: ViewChild, args: ['scrollListElement',] }], nzOnNextClick: [{ type: Output }], nzOnPrevClick: [{ type: Output }], nzTabBarExtraContent: [{ type: Input }], nzAnimated: [{ type: Input }], nzHideBar: [{ type: Input }], nzShowPagination: [{ type: Input }], nzType: [{ type: Input }], nzPositionMode: [{ type: Input }], selectedIndex: [{ type: Input }] }; tslib_1.__decorate([ InputBoolean(), tslib_1.__metadata("design:type", Object) ], NzTabsNavComponent.prototype, "nzAnimated", void 0); tslib_1.__decorate([ InputBoolean(), tslib_1.__metadata("design:type", Object) ], NzTabsNavComponent.prototype, "nzHideBar", void 0); tslib_1.__decorate([ InputBoolean(), tslib_1.__metadata("design:type", Object) ], NzTabsNavComponent.prototype, "nzShowPagination", void 0); if (false) { /** * @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 {?} */ 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.elementRef; /** * @type {?} * @private */ NzTabsNavComponent.prototype.ngZone; /** * @type {?} * @private */ NzTabsNavComponent.prototype.renderer; /** * @type {?} * @private */ NzTabsNavComponent.prototype.cdr; /** * @type {?} * @private */ NzTabsNavComponent.prototype.dir; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nz-tabs-nav.component.js","sourceRoot":"ng://ng-zorro-antd-yj/","sources":["tabs/nz-tabs-nav.component.ts"],"names":[],"mappings":"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","sourcesContent":["/** code from https://github.com/angular/material2 */\nimport { Direction, Directionality } from '@angular/cdk/bidi';\nimport {\n  AfterContentChecked,\n  AfterContentInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChildren,\n  ElementRef,\n  EventEmitter,\n  Input,\n  NgZone,\n  Optional,\n  Output,\n  QueryList,\n  Renderer2,\n  TemplateRef,\n  ViewChild,\n  ViewEncapsulation\n} from '@angular/core';\nimport { fromEvent, merge, of as observableOf, Subscription } from 'rxjs';\nimport { auditTime, startWith } from 'rxjs/operators';\n\nimport { InputBoolean } from '../core/util/convert';\n\nimport { NzTabLabelDirective } from './nz-tab-label.directive';\nimport { NzTabsInkBarDirective } from './nz-tabs-ink-bar.directive';\nimport { NzTabPositionMode } from './nz-tabset.component';\n\nconst EXAGGERATED_OVERSCROLL = 64;\nexport type ScrollDirection = 'after' | 'before';\n\n@Component({\n  selector: '[nz-tabs-nav]',\n  preserveWhitespaces: false,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  templateUrl: './nz-tabs-nav.component.html'\n})\nexport class NzTabsNavComponent implements AfterContentChecked, AfterContentInit {\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  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) nzTabsInkBarDirective: NzTabsInkBarDirective;\n  @ViewChild('navContainerElement') navContainerElement: ElementRef;\n  @ViewChild('navListElement') navListElement: ElementRef;\n  @ViewChild('scrollListElement') scrollListElement: ElementRef;\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\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    @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.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 =\n        typeof window !== 'undefined' ? fromEvent(window, 'resize').pipe(auditTime(10)) : 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  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 after direction\n        this.scrollDistance += labelAfterPos - afterVisiblePos + EXAGGERATED_OVERSCROLL;\n      }\n    }\n  }\n\n  checkScrollingControls(): void {\n    // Check if the pagination arrows should be activated.\n    this.disableScrollBefore = this.scrollDistance === 0;\n    this.disableScrollAfter = this.scrollDistance === this.getMaxScrollDistance();\n    this.cdr.markForCheck();\n  }\n\n  /**\n   * Determines what is the maximum length in pixels that can be set for the scroll distance. This\n   * is equal to the difference in width between the tab list container and tab header container.\n   *\n   * This is an expensive call that forces a layout reflow to compute box and scroll metrics and\n   * should be called sparingly.\n   */\n  getMaxScrollDistance(): number {\n    return this.tabListScrollWidthHeightPix - this.viewWidthHeightPix || 0;\n  }\n\n  /** Sets the distance in pixels that the tab header should be transformed in the X-axis. */\n  set scrollDistance(v: number) {\n    this._scrollDistance = Math.max(0, Math.min(this.getMaxScrollDistance(), v));\n\n    // Mark that the scroll distance has changed so that after the view is checked, the CSS\n    // transformation can move the header.\n    this.scrollDistanceChanged = true;\n\n    this.checkScrollingControls();\n  }\n\n  get scrollDistance(): number {\n    return this._scrollDistance;\n  }\n\n  get viewWidthHeightPix(): number {\n    let PAGINATION_PIX = 0;\n    if (this.showPaginationControls) {\n      PAGINATION_PIX = 64;\n    }\n    if (this.nzPositionMode === 'horizontal') {\n      return this.navContainerElement.nativeElement.offsetWidth - PAGINATION_PIX;\n    } else {\n      return this.navContainerElement.nativeElement.offsetHeight - PAGINATION_PIX;\n    }\n  }\n\n  get tabListScrollWidthHeightPix(): number {\n    if (this.nzPositionMode === 'horizontal') {\n      return this.navListElement.nativeElement.scrollWidth;\n    } else {\n      return this.navListElement.nativeElement.scrollHeight;\n    }\n  }\n\n  get tabListScrollOffSetWidthHeight(): number {\n    if (this.nzPositionMode === 'horizontal') {\n      return this.scrollListElement.nativeElement.offsetWidth;\n    } else {\n      return this.elementRef.nativeElement.offsetHeight;\n    }\n  }\n\n  getLayoutDirection(): Direction {\n    return this.dir && this.dir.value === 'rtl' ? 'rtl' : 'ltr';\n  }\n\n  alignInkBarToSelectedTab(): void {\n    if (this.nzType === 'line') {\n      const selectedLabelWrapper =\n        this.listOfNzTabLabelDirective && this.listOfNzTabLabelDirective.length\n          ? this.listOfNzTabLabelDirective.toArray()[this.selectedIndex].elementRef.nativeElement\n          : null;\n      if (this.nzTabsInkBarDirective) {\n        this.nzTabsInkBarDirective.alignToElement(selectedLabelWrapper);\n      }\n    }\n  }\n}\n"]}