UNPKG

ng-zorro-antd-mobile

Version:

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

244 lines 40.8 kB
import { Component, Input, QueryList, Renderer2, ViewChild, ElementRef, HostBinding, ContentChildren, ChangeDetectorRef } from '@angular/core'; import * as i0 from "@angular/core"; import * as i1 from "@angular/common"; import * as i2 from "@angular/cdk/observers"; export class DefaultTabBarComponent { get activeTab() { return this.selectedKey; } set activeTab(index) { if (index !== this.selectedKey) { this.selectedKey = index; if (this.tabTitles && this.tabTitles.length > 0) { this.setTabBarStyleCenter(); this.setInkBarStatus(this.selectedKey); } } } 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 = (page, tabLength) => 100 / Math.min(page, tabLength); } 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; } } } 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)' }; } } } 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; } } onContentChange() { this.setTabsStyle(); this.setInkBarStatus(this.selectedKey); } ngAfterContentInit() { this.setTabsStyle(); this.setTabBarStyleCenter(); this.setInkBarStatus(this.selectedKey); } setTabsStyle() { if (this.tabTitles && this.tabTitles.length > 0) { if ('top' === this.tabBarPosition || 'bottom' === this.tabBarPosition) { this.tabTitles.forEach((tabTitle) => { this._renderer.setStyle(tabTitle.nativeElement, 'width', this.tabTitleSize > 0 ? this.tabTitleSize + 'px' : this.getTabSize(this.page, this.tabTitles.length) + '%'); }); } else { this.tabTitles.forEach((tabTitle) => { this._renderer.setStyle(tabTitle.nativeElement, 'height', this.tabTitleSize > 0 ? this.tabTitleSize + 'px' : this.getTabSize(this.page, this.tabTitles.length) + '%'); }); } } } 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)' }; } } 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(); } } 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; } } 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 / swipingItemLength - this.selectedKey - 1) * swipingItemLength; } else { this.tabBarNavSwipedPosition = (viewportLength / swipingItemLength - 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; } } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: DefaultTabBarComponent, deps: [{ token: i0.Renderer2 }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.8", type: DefaultTabBarComponent, selector: "DefaultTabBar, nzm-default-tab-bar", inputs: { page: "page", animated: "animated", tabBarUnderlineStyle: "tabBarUnderlineStyle", tabBarBackgroundColor: "tabBarBackgroundColor", tabTitleSize: "tabTitleSize", tabBarPosition: "tabBarPosition", activeTab: "activeTab" }, host: { properties: { "class.am-tabs-tab-bar-wrap": "this.tabBarWrap" } }, queries: [{ propertyName: "tabTitles", predicate: ["TabTitle"] }], viewQueries: [{ propertyName: "tabsBarSwipe", first: true, predicate: ["TabsBarSwipe"], descendants: true, static: true }], ngImport: i0, 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", dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: i2.CdkObserveContent, selector: "[cdkObserveContent]", inputs: ["cdkObserveContentDisabled", "debounce"], outputs: ["cdkObserveContent"], exportAs: ["cdkObserveContent"] }] }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: 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" }] }], ctorParameters: () => [{ type: i0.Renderer2 }, { type: i0.ChangeDetectorRef }], 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'] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"default-tab-bar.component.js","sourceRoot":"","sources":["../../../components/tabs/default-tab-bar.component.ts","../../../components/tabs/default-tab-bar.component.html"],"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 / swipingItemLength - this.selectedKey - 1) * swipingItemLength;\n      } else {\n        this.tabBarNavSwipedPosition = (viewportLength / swipingItemLength - 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","<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"]}