ng-zorro-antd-mobile
Version:
An enterprise-class mobile UI components based on Ant Design and Angular
412 lines • 42.3 kB
JavaScript
/**
* @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';
var DefaultTabBarComponent = /** @class */ (function () {
function DefaultTabBarComponent(_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 {?}
*/
function (page, tabLength) { return 100 / Math.min(page, tabLength); });
}
Object.defineProperty(DefaultTabBarComponent.prototype, "activeTab", {
get: /**
* @return {?}
*/
function () {
return this.selectedKey;
},
set: /**
* @param {?} index
* @return {?}
*/
function (index) {
if (index !== this.selectedKey) {
this.selectedKey = index;
if (this.tabTitles && this.tabTitles.length > 0) {
this.setTabBarStyleCenter();
this.setInkBarStatus(this.selectedKey);
}
}
},
enumerable: true,
configurable: true
});
/**
* @param {?} event
* @return {?}
*/
DefaultTabBarComponent.prototype.onTouchStart = /**
* @param {?} event
* @return {?}
*/
function (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 {?}
*/
DefaultTabBarComponent.prototype.onTouchMove = /**
* @param {?} event
* @return {?}
*/
function (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 {?}
*/
DefaultTabBarComponent.prototype.onTouchEnd = /**
* @return {?}
*/
function () {
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 {?}
*/
DefaultTabBarComponent.prototype.onContentChange = /**
* @return {?}
*/
function () {
this.setTabsStyle();
this.setInkBarStatus(this.selectedKey);
};
/**
* @return {?}
*/
DefaultTabBarComponent.prototype.ngAfterContentInit = /**
* @return {?}
*/
function () {
this.setTabsStyle();
this.setTabBarStyleCenter();
this.setInkBarStatus(this.selectedKey);
};
/**
* @private
* @return {?}
*/
DefaultTabBarComponent.prototype.setTabsStyle = /**
* @private
* @return {?}
*/
function () {
var _this = this;
if (this.tabTitles && this.tabTitles.length > 0) {
if ('top' === this.tabBarPosition || 'bottom' === this.tabBarPosition) {
this.tabTitles.forEach((/**
* @param {?} tabTitle
* @return {?}
*/
function (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 {?}
*/
function (tabTitle) {
_this._renderer.setStyle(tabTitle.nativeElement, 'height', _this.tabTitleSize > 0 ? _this.tabTitleSize + 'px' : _this.getTabSize(_this.page, _this.tabTitles.length) + '%');
}));
}
}
};
/**
* @private
* @return {?}
*/
DefaultTabBarComponent.prototype.setTabBarStyleCenter = /**
* @private
* @return {?}
*/
function () {
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 {?}
*/
DefaultTabBarComponent.prototype.setInkBarStatus = /**
* @private
* @param {?} key
* @return {?}
*/
function (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 {?}
*/
DefaultTabBarComponent.prototype.setTabBarNavSwipingPosition = /**
* @private
* @param {?} swipingDistance
* @param {?} swipingItemLength
* @param {?} viewportLength
* @return {?}
*/
function (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 {?}
*/
DefaultTabBarComponent.prototype.setTabBarNavSwipedPosition = /**
* @private
* @param {?} swipingItemLength
* @param {?} viewportLength
* @return {?}
*/
function (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 = function () { return [
{ 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',] }]
};
return DefaultTabBarComponent;
}());
export { DefaultTabBarComponent };
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"]}