UNPKG

ng-zorro-antd-mobile

Version:

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

366 lines 40.6 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Component, Input, QueryList, Renderer2, ViewChild, ElementRef, HostBinding, ContentChildren, ChangeDetectorRef } from '@angular/core'; export class DefaultTabBarComponent { /** * @param {?} _renderer * @param {?} _ref */ constructor(_renderer, _ref) { this._renderer = _renderer; this._ref = _ref; this.prefixCls = 'am-tabs-default-bar'; this.inkBarStyle = {}; this.tabsBarStyle = {}; this.showPrev = false; this.showNext = false; this.selectedKey = 0; this.inkBarOffSet = 0; this.inkBarLength = 0; this.tabBarNavSwipedPosition = 0; this.tabBarNavSwipingPosition = 0; this._startPosition = 0; this.page = 5; this.animated = true; this.tabBarBackgroundColor = '#FFF'; this.tabTitleSize = 0; this.tabBarPosition = 'top'; this.tabBarWrap = true; this.getTabSize = (/** * @param {?} page * @param {?} tabLength * @return {?} */ (page, tabLength) => 100 / Math.min(page, tabLength)); } /** * @return {?} */ get activeTab() { return this.selectedKey; } /** * @param {?} index * @return {?} */ set activeTab(index) { if (index !== this.selectedKey) { this.selectedKey = index; if (this.tabTitles && this.tabTitles.length > 0) { this.setTabBarStyleCenter(); this.setInkBarStatus(this.selectedKey); } } } /** * @param {?} event * @return {?} */ onTouchStart(event) { if ((this.tabTitleSize > 0 && this.tabTitleSize * this.tabTitles.length > ('top' === this.tabBarPosition || 'bottom' === this.tabBarPosition ? this.tabsBarSwipe.nativeElement.offsetWidth : this.tabsBarSwipe.nativeElement.offsetHeight)) || (this.tabTitleSize <= 0 && this.page < this.tabTitles.length)) { if ('top' === this.tabBarPosition || 'bottom' === this.tabBarPosition) { this._startPosition = event && event.changedTouches && event.changedTouches[0] && event.changedTouches[0].clientX; } else { this._startPosition = event && event.changedTouches && event.changedTouches[0] && event.changedTouches[0].clientY; } } } /** * @param {?} event * @return {?} */ onTouchMove(event) { event.preventDefault(); event.stopPropagation(); if ((this.tabTitleSize > 0 && this.tabTitleSize * this.tabTitles.length > ('top' === this.tabBarPosition || 'bottom' === this.tabBarPosition ? this.tabsBarSwipe.nativeElement.offsetWidth : this.tabsBarSwipe.nativeElement.offsetHeight)) || (this.tabTitleSize <= 0 && this.page < this.tabTitles.length)) { if ('top' === this.tabBarPosition || 'bottom' === this.tabBarPosition) { this.setTabBarNavSwipingPosition(event.changedTouches[0].clientX - this._startPosition, this.tabTitles.first.nativeElement.offsetWidth, this.tabsBarSwipe.nativeElement.offsetWidth); this.tabsBarStyle = { transition: '0ms', transform: 'translate3d(' + this.tabBarNavSwipingPosition + 'px, 0px, 0px)', webkitTransform: 'translate3d(' + this.tabBarNavSwipingPosition + 'px, 0px, 0px)' }; } else { this.setTabBarNavSwipingPosition(event.changedTouches[0].clientY - this._startPosition, this.tabTitles.first.nativeElement.offsetHeight, this.tabsBarSwipe.nativeElement.offsetHeight); this.tabsBarStyle = { transition: '0ms', transform: 'translate3d(0, ' + this.tabBarNavSwipingPosition + 'px, 0px)', webkitTransform: 'translate3d(0, ' + this.tabBarNavSwipingPosition + 'px, 0px)' }; } } } /** * @return {?} */ onTouchEnd() { if ((this.tabTitleSize > 0 && this.tabTitleSize * this.tabTitles.length > ('top' === this.tabBarPosition || 'bottom' === this.tabBarPosition ? this.tabsBarSwipe.nativeElement.offsetWidth : this.tabsBarSwipe.nativeElement.offsetHeight)) || (this.tabTitleSize <= 0 && this.page < this.tabTitles.length)) { this.tabBarNavSwipedPosition = this.tabBarNavSwipingPosition; } } /** * @return {?} */ onContentChange() { this.setTabsStyle(); this.setInkBarStatus(this.selectedKey); } /** * @return {?} */ ngAfterContentInit() { this.setTabsStyle(); this.setTabBarStyleCenter(); this.setInkBarStatus(this.selectedKey); } /** * @private * @return {?} */ setTabsStyle() { if (this.tabTitles && this.tabTitles.length > 0) { if ('top' === this.tabBarPosition || 'bottom' === this.tabBarPosition) { this.tabTitles.forEach((/** * @param {?} tabTitle * @return {?} */ (tabTitle) => { this._renderer.setStyle(tabTitle.nativeElement, 'width', this.tabTitleSize > 0 ? this.tabTitleSize + 'px' : this.getTabSize(this.page, this.tabTitles.length) + '%'); })); } else { this.tabTitles.forEach((/** * @param {?} tabTitle * @return {?} */ (tabTitle) => { this._renderer.setStyle(tabTitle.nativeElement, 'height', this.tabTitleSize > 0 ? this.tabTitleSize + 'px' : this.getTabSize(this.page, this.tabTitles.length) + '%'); })); } } } /** * @private * @return {?} */ setTabBarStyleCenter() { if ('top' === this.tabBarPosition || 'bottom' === this.tabBarPosition) { this.setTabBarNavSwipedPosition(this.tabTitleSize > 0 ? this.tabTitleSize : this.tabsBarSwipe.nativeElement.offsetWidth / Math.min(this.tabTitles.length, this.page), this.tabsBarSwipe.nativeElement.offsetWidth); this.tabsBarStyle = { transform: 'translate3d(' + this.tabBarNavSwipedPosition + 'px, 0px, 0px)', webkitTransform: 'translate3d(' + this.tabBarNavSwipedPosition + ', 0px, 0px)' }; } else { this.setTabBarNavSwipedPosition(this.tabTitleSize > 0 ? this.tabTitleSize : this.tabsBarSwipe.nativeElement.offsetHeight / Math.min(this.tabTitles.length, this.page), this.tabsBarSwipe.nativeElement.offsetHeight); this.tabsBarStyle = { transform: 'translate3d(0, ' + this.tabBarNavSwipedPosition + 'px, 0px)', webkitTransform: 'translate3d(0, ' + this.tabBarNavSwipedPosition + 'px, 0px)' }; } } /** * @private * @param {?} key * @return {?} */ setInkBarStatus(key) { if (this.tabTitles && this.tabTitles.length > 0) { if ('top' === this.tabBarPosition || 'bottom' === this.tabBarPosition) { this.inkBarOffSet = this.tabTitles.toArray()[key].nativeElement.offsetLeft; this.inkBarLength = this.tabTitles.toArray()[key].nativeElement.style.width; this.inkBarStyle = { width: this.inkBarLength, left: this.tabTitleSize > 0 ? this.selectedKey * this.tabTitleSize + 'px' : (this.selectedKey * 100) / Math.min(this.tabTitles.length, this.page) + '%' }; Object.assign(this.inkBarStyle, this.tabBarUnderlineStyle); } else { this.inkBarOffSet = this.tabTitles.toArray()[key].nativeElement.offsetTop; this.inkBarLength = this.tabTitles.toArray()[key].nativeElement.style.height; this.inkBarStyle = { height: this.inkBarLength, top: this.tabTitleSize > 0 ? this.selectedKey * this.tabTitleSize + 'px' : (this.selectedKey * 100) / Math.min(this.tabTitles.length, this.page) + '%' }; Object.assign(this.inkBarStyle, this.tabBarUnderlineStyle); } this._ref.detectChanges(); } } /** * @private * @param {?} swipingDistance * @param {?} swipingItemLength * @param {?} viewportLength * @return {?} */ setTabBarNavSwipingPosition(swipingDistance, swipingItemLength, viewportLength) { if (this.tabBarNavSwipedPosition + swipingDistance > 0) { this.tabBarNavSwipingPosition = 0; } else if (this.tabBarNavSwipedPosition + swipingDistance < viewportLength - swipingItemLength * this.tabTitles.length) { this.tabBarNavSwipingPosition = viewportLength - swipingItemLength * this.tabTitles.length; this.showNext = false; } else { this.tabBarNavSwipingPosition = this.tabBarNavSwipedPosition + swipingDistance; this.showNext = true; } if (this.tabBarNavSwipingPosition < 0) { this.showPrev = true; } else { this.showPrev = false; } } /** * @private * @param {?} swipingItemLength * @param {?} viewportLength * @return {?} */ setTabBarNavSwipedPosition(swipingItemLength, viewportLength) { if (this.selectedKey * swipingItemLength + this.tabBarNavSwipedPosition <= 0) { if (0 === this.selectedKey) { this.tabBarNavSwipedPosition = 0; } else { this.tabBarNavSwipedPosition = (1 - this.selectedKey) * swipingItemLength; } } else if ((this.selectedKey + 1) * swipingItemLength >= viewportLength - this.tabBarNavSwipedPosition) { if (this.tabTitles.length - 1 === this.selectedKey) { this.tabBarNavSwipedPosition = viewportLength - (this.selectedKey + 1) * swipingItemLength; } else { this.tabBarNavSwipedPosition = viewportLength - (this.selectedKey + 2) * swipingItemLength; } } if (this.tabBarNavSwipedPosition < 0) { this.showPrev = true; } else { this.showPrev = false; } if (this.tabBarNavSwipedPosition + swipingItemLength * this.tabTitles.length - viewportLength > 0) { this.showNext = true; } else { this.showNext = false; } } } DefaultTabBarComponent.decorators = [ { type: Component, args: [{ selector: 'DefaultTabBar, nzm-default-tab-bar', template: "<div\n class=\"{{ prefixCls }} {{ prefixCls }}-{{ tabBarPosition }}\"\n [ngClass]=\"{ 'am-tabs-default-bar-animated': animated }\"\n [ngStyle]=\"{ backgroundColor: tabBarBackgroundColor || '#FFF' }\"\n>\n <div *ngIf=\"showPrev\" class=\"{{ prefixCls }}-prevpage\"></div>\n <div\n #TabsBarSwipe\n class=\"{{ prefixCls }}-content\"\n [ngStyle]=\"tabsBarStyle\"\n (touchstart)=\"onTouchStart($event)\"\n (touchmove)=\"onTouchMove($event)\"\n (touchend)=\"onTouchEnd()\"\n (cdkObserveContent)=\"onContentChange()\"\n >\n <ng-content></ng-content>\n <div class=\"{{ prefixCls }}-underline\" [ngStyle]=\"inkBarStyle\"></div>\n </div>\n <div *ngIf=\"showNext\" class=\"{{ prefixCls }}-nextpage\"></div>\n</div>\n" }] } ]; /** @nocollapse */ DefaultTabBarComponent.ctorParameters = () => [ { type: Renderer2 }, { type: ChangeDetectorRef } ]; DefaultTabBarComponent.propDecorators = { tabTitles: [{ type: ContentChildren, args: ['TabTitle',] }], tabsBarSwipe: [{ type: ViewChild, args: ['TabsBarSwipe', { static: true },] }], page: [{ type: Input }], animated: [{ type: Input }], tabBarUnderlineStyle: [{ type: Input }], tabBarBackgroundColor: [{ type: Input }], tabTitleSize: [{ type: Input }], tabBarPosition: [{ type: Input }], activeTab: [{ type: Input }], tabBarWrap: [{ type: HostBinding, args: ['class.am-tabs-tab-bar-wrap',] }] }; if (false) { /** @type {?} */ DefaultTabBarComponent.prototype.prefixCls; /** @type {?} */ DefaultTabBarComponent.prototype.inkBarStyle; /** @type {?} */ DefaultTabBarComponent.prototype.tabsBarStyle; /** @type {?} */ DefaultTabBarComponent.prototype.showPrev; /** @type {?} */ DefaultTabBarComponent.prototype.showNext; /** @type {?} */ DefaultTabBarComponent.prototype.selectedKey; /** @type {?} */ DefaultTabBarComponent.prototype.inkBarOffSet; /** @type {?} */ DefaultTabBarComponent.prototype.inkBarLength; /** @type {?} */ DefaultTabBarComponent.prototype.tabBarNavSwipedPosition; /** @type {?} */ DefaultTabBarComponent.prototype.tabBarNavSwipingPosition; /** * @type {?} * @private */ DefaultTabBarComponent.prototype._startPosition; /** @type {?} */ DefaultTabBarComponent.prototype.tabTitles; /** @type {?} */ DefaultTabBarComponent.prototype.tabsBarSwipe; /** @type {?} */ DefaultTabBarComponent.prototype.page; /** @type {?} */ DefaultTabBarComponent.prototype.animated; /** @type {?} */ DefaultTabBarComponent.prototype.tabBarUnderlineStyle; /** @type {?} */ DefaultTabBarComponent.prototype.tabBarBackgroundColor; /** @type {?} */ DefaultTabBarComponent.prototype.tabTitleSize; /** @type {?} */ DefaultTabBarComponent.prototype.tabBarPosition; /** @type {?} */ DefaultTabBarComponent.prototype.tabBarWrap; /** * @type {?} * @private */ DefaultTabBarComponent.prototype.getTabSize; /** * @type {?} * @private */ DefaultTabBarComponent.prototype._renderer; /** * @type {?} * @private */ DefaultTabBarComponent.prototype._ref; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"default-tab-bar.component.js","sourceRoot":"ng://ng-zorro-antd-mobile/","sources":["tabs/default-tab-bar.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  QueryList,\n  Renderer2,\n  ViewChild,\n  ElementRef,\n  HostBinding,\n  AfterContentInit,\n  ContentChildren,\n  ChangeDetectorRef\n} from '@angular/core';\n\nimport { TabBarPositionType } from './PropsType';\n\n@Component({\n  selector: 'DefaultTabBar, nzm-default-tab-bar',\n  templateUrl: './default-tab-bar.component.html'\n})\nexport class DefaultTabBarComponent implements AfterContentInit {\n  prefixCls: string = 'am-tabs-default-bar';\n  inkBarStyle: object = {};\n  tabsBarStyle: object = {};\n  showPrev: boolean = false;\n  showNext: boolean = false;\n  selectedKey: number = 0;\n  inkBarOffSet: number = 0;\n  inkBarLength: number = 0;\n  tabBarNavSwipedPosition: number = 0;\n  tabBarNavSwipingPosition: number = 0;\n\n  private _startPosition: number = 0;\n\n  @ContentChildren('TabTitle')\n  tabTitles: QueryList<ElementRef>;\n\n  @ViewChild('TabsBarSwipe', { static: true })\n  tabsBarSwipe: ElementRef;\n\n  @Input()\n  page: number = 5;\n  @Input()\n  animated: boolean = true;\n  @Input()\n  tabBarUnderlineStyle: object;\n  @Input()\n  tabBarBackgroundColor: string = '#FFF';\n  @Input()\n  tabTitleSize: number = 0;\n  @Input()\n  tabBarPosition: TabBarPositionType = 'top';\n  @Input()\n  get activeTab(): number {\n    return this.selectedKey;\n  }\n  set activeTab(index: number) {\n    if (index !== this.selectedKey) {\n      this.selectedKey = index;\n      if (this.tabTitles && this.tabTitles.length > 0) {\n        this.setTabBarStyleCenter();\n        this.setInkBarStatus(this.selectedKey);\n      }\n    }\n  }\n\n  @HostBinding('class.am-tabs-tab-bar-wrap')\n  tabBarWrap = true;\n\n  constructor(private _renderer: Renderer2, private _ref: ChangeDetectorRef) {}\n\n  onTouchStart(event) {\n    if (\n      (this.tabTitleSize > 0 &&\n        this.tabTitleSize * this.tabTitles.length >\n          ('top' === this.tabBarPosition || 'bottom' === this.tabBarPosition\n            ? this.tabsBarSwipe.nativeElement.offsetWidth\n            : this.tabsBarSwipe.nativeElement.offsetHeight)) ||\n      (this.tabTitleSize <= 0 && this.page < this.tabTitles.length)\n    ) {\n      if ('top' === this.tabBarPosition || 'bottom' === this.tabBarPosition) {\n        this._startPosition =\n          event && event.changedTouches && event.changedTouches[0] && event.changedTouches[0].clientX;\n      } else {\n        this._startPosition =\n          event && event.changedTouches && event.changedTouches[0] && event.changedTouches[0].clientY;\n      }\n    }\n  }\n\n  onTouchMove(event) {\n    event.preventDefault();\n    event.stopPropagation();\n    if (\n      (this.tabTitleSize > 0 &&\n        this.tabTitleSize * this.tabTitles.length >\n          ('top' === this.tabBarPosition || 'bottom' === this.tabBarPosition\n            ? this.tabsBarSwipe.nativeElement.offsetWidth\n            : this.tabsBarSwipe.nativeElement.offsetHeight)) ||\n      (this.tabTitleSize <= 0 && this.page < this.tabTitles.length)\n    ) {\n      if ('top' === this.tabBarPosition || 'bottom' === this.tabBarPosition) {\n        this.setTabBarNavSwipingPosition(\n          event.changedTouches[0].clientX - this._startPosition,\n          this.tabTitles.first.nativeElement.offsetWidth,\n          this.tabsBarSwipe.nativeElement.offsetWidth\n        );\n        this.tabsBarStyle = {\n          transition: '0ms',\n          transform: 'translate3d(' + this.tabBarNavSwipingPosition + 'px, 0px, 0px)',\n          webkitTransform: 'translate3d(' + this.tabBarNavSwipingPosition + 'px, 0px, 0px)'\n        };\n      } else {\n        this.setTabBarNavSwipingPosition(\n          event.changedTouches[0].clientY - this._startPosition,\n          this.tabTitles.first.nativeElement.offsetHeight,\n          this.tabsBarSwipe.nativeElement.offsetHeight\n        );\n        this.tabsBarStyle = {\n          transition: '0ms',\n          transform: 'translate3d(0, ' + this.tabBarNavSwipingPosition + 'px, 0px)',\n          webkitTransform: 'translate3d(0, ' + this.tabBarNavSwipingPosition + 'px, 0px)'\n        };\n      }\n    }\n  }\n\n  onTouchEnd() {\n    if (\n      (this.tabTitleSize > 0 &&\n        this.tabTitleSize * this.tabTitles.length >\n          ('top' === this.tabBarPosition || 'bottom' === this.tabBarPosition\n            ? this.tabsBarSwipe.nativeElement.offsetWidth\n            : this.tabsBarSwipe.nativeElement.offsetHeight)) ||\n      (this.tabTitleSize <= 0 && this.page < this.tabTitles.length)\n    ) {\n      this.tabBarNavSwipedPosition = this.tabBarNavSwipingPosition;\n    }\n  }\n\n  onContentChange() {\n    this.setTabsStyle();\n    this.setInkBarStatus(this.selectedKey);\n  }\n\n  ngAfterContentInit() {\n    this.setTabsStyle();\n    this.setTabBarStyleCenter();\n    this.setInkBarStatus(this.selectedKey);\n  }\n\n  private setTabsStyle() {\n    if (this.tabTitles && this.tabTitles.length > 0) {\n      if ('top' === this.tabBarPosition || 'bottom' === this.tabBarPosition) {\n        this.tabTitles.forEach((tabTitle: any) => {\n          this._renderer.setStyle(\n            tabTitle.nativeElement,\n            'width',\n            this.tabTitleSize > 0 ? this.tabTitleSize + 'px' : this.getTabSize(this.page, this.tabTitles.length) + '%'\n          );\n        });\n      } else {\n        this.tabTitles.forEach((tabTitle: any) => {\n          this._renderer.setStyle(\n            tabTitle.nativeElement,\n            'height',\n            this.tabTitleSize > 0 ? this.tabTitleSize + 'px' : this.getTabSize(this.page, this.tabTitles.length) + '%'\n          );\n        });\n      }\n    }\n  }\n\n  private setTabBarStyleCenter() {\n    if ('top' === this.tabBarPosition || 'bottom' === this.tabBarPosition) {\n      this.setTabBarNavSwipedPosition(\n        this.tabTitleSize > 0\n          ? this.tabTitleSize\n          : this.tabsBarSwipe.nativeElement.offsetWidth / Math.min(this.tabTitles.length, this.page),\n        this.tabsBarSwipe.nativeElement.offsetWidth\n      );\n      this.tabsBarStyle = {\n        transform: 'translate3d(' + this.tabBarNavSwipedPosition + 'px, 0px, 0px)',\n        webkitTransform: 'translate3d(' + this.tabBarNavSwipedPosition + ', 0px, 0px)'\n      };\n    } else {\n      this.setTabBarNavSwipedPosition(\n        this.tabTitleSize > 0\n          ? this.tabTitleSize\n          : this.tabsBarSwipe.nativeElement.offsetHeight / Math.min(this.tabTitles.length, this.page),\n        this.tabsBarSwipe.nativeElement.offsetHeight\n      );\n      this.tabsBarStyle = {\n        transform: 'translate3d(0, ' + this.tabBarNavSwipedPosition + 'px, 0px)',\n        webkitTransform: 'translate3d(0, ' + this.tabBarNavSwipedPosition + 'px, 0px)'\n      };\n    }\n  }\n\n  private setInkBarStatus(key: number) {\n    if (this.tabTitles && this.tabTitles.length > 0) {\n      if ('top' === this.tabBarPosition || 'bottom' === this.tabBarPosition) {\n        this.inkBarOffSet = this.tabTitles.toArray()[key].nativeElement.offsetLeft;\n        this.inkBarLength = this.tabTitles.toArray()[key].nativeElement.style.width;\n        this.inkBarStyle = {\n          width: this.inkBarLength,\n          left:\n            this.tabTitleSize > 0\n              ? this.selectedKey * this.tabTitleSize + 'px'\n              : (this.selectedKey * 100) / Math.min(this.tabTitles.length, this.page) + '%'\n        };\n        Object.assign(this.inkBarStyle, this.tabBarUnderlineStyle);\n      } else {\n        this.inkBarOffSet = this.tabTitles.toArray()[key].nativeElement.offsetTop;\n        this.inkBarLength = this.tabTitles.toArray()[key].nativeElement.style.height;\n        this.inkBarStyle = {\n          height: this.inkBarLength,\n          top:\n            this.tabTitleSize > 0\n              ? this.selectedKey * this.tabTitleSize + 'px'\n              : (this.selectedKey * 100) / Math.min(this.tabTitles.length, this.page) + '%'\n        };\n        Object.assign(this.inkBarStyle, this.tabBarUnderlineStyle);\n      }\n      this._ref.detectChanges();\n    }\n  }\n\n  private setTabBarNavSwipingPosition(swipingDistance: number, swipingItemLength: number, viewportLength: number) {\n    if (this.tabBarNavSwipedPosition + swipingDistance > 0) {\n      this.tabBarNavSwipingPosition = 0;\n    } else if (\n      this.tabBarNavSwipedPosition + swipingDistance <\n      viewportLength - swipingItemLength * this.tabTitles.length\n    ) {\n      this.tabBarNavSwipingPosition = viewportLength - swipingItemLength * this.tabTitles.length;\n      this.showNext = false;\n    } else {\n      this.tabBarNavSwipingPosition = this.tabBarNavSwipedPosition + swipingDistance;\n      this.showNext = true;\n    }\n    if (this.tabBarNavSwipingPosition < 0) {\n      this.showPrev = true;\n    } else {\n      this.showPrev = false;\n    }\n  }\n\n  private setTabBarNavSwipedPosition(swipingItemLength: number, viewportLength: number) {\n    if (this.selectedKey * swipingItemLength + this.tabBarNavSwipedPosition <= 0) {\n      if (0 === this.selectedKey) {\n        this.tabBarNavSwipedPosition = 0;\n      } else {\n        this.tabBarNavSwipedPosition = (1 - this.selectedKey) * swipingItemLength;\n      }\n    } else if ((this.selectedKey + 1) * swipingItemLength >= viewportLength - this.tabBarNavSwipedPosition) {\n      if (this.tabTitles.length - 1 === this.selectedKey) {\n        this.tabBarNavSwipedPosition = viewportLength - (this.selectedKey + 1) * swipingItemLength;\n      } else {\n        this.tabBarNavSwipedPosition = viewportLength - (this.selectedKey + 2) * swipingItemLength;\n      }\n    }\n    if (this.tabBarNavSwipedPosition < 0) {\n      this.showPrev = true;\n    } else {\n      this.showPrev = false;\n    }\n    if (this.tabBarNavSwipedPosition + swipingItemLength * this.tabTitles.length - viewportLength > 0) {\n      this.showNext = true;\n    } else {\n      this.showNext = false;\n    }\n  }\n\n  private getTabSize = (page: number, tabLength: number) => 100 / Math.min(page, tabLength);\n}\n"]}