ng-zorro-antd-mobile
Version:
An enterprise-class mobile UI components based on Ant Design and Angular
503 lines • 44 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Input, Output, Component, ViewChild, forwardRef, TemplateRef, HostBinding, EventEmitter, HostListener, ViewContainerRef, ViewEncapsulation, ElementRef } from '@angular/core';
import { NG_VALUE_ACCESSOR } from '@angular/forms';
/**
* @record
*/
export function Indicator() { }
if (false) {
/** @type {?|undefined} */
Indicator.prototype.activate;
/** @type {?|undefined} */
Indicator.prototype.deactivate;
/** @type {?|undefined} */
Indicator.prototype.release;
/** @type {?|undefined} */
Indicator.prototype.finish;
}
export class PullToRefreshComponent {
/**
* @param {?} ele
*/
constructor(ele) {
this.ele = ele;
this.transtionCls = {};
this.style = {
'-webkit-transform': 'translate3d( 0, 0, 0 )',
transform: 'translate3d( 0, 0, 0 )'
};
this.state = {
currentState: 'deactivate',
drag: false
};
this._headerIndicator = {
activate: '松开立即刷新',
deactivate: '下拉可以刷新',
release: '刷新中。。。',
finish: '完成刷新'
};
this._footerIndicator = {
activate: '松开立即刷新',
deactivate: '上拉可以刷新',
release: '刷新中。。。',
finish: '完成刷新'
};
this._startTime = 0;
this._endTime = 0;
this._endReach = false;
this._direction = '';
this._clientHeight = 0;
this._currentContentHeight = 0;
this._lastContentOffset = 0;
this.distanceToRefresh = 25; //触发刷新距离
//触发刷新距离
this.damping = 100; // 下拉的最大距离
// 下拉的最大距离
this.endReachedRefresh = false;
this.refreshing = false;
this.onRefresh = new EventEmitter();
this.refresh = true;
this.container = true;
this.refreshUp = this._direction === 'up' || this._direction === '';
this.refreshDown = this._direction === 'down' || this._direction === '';
}
/**
* @return {?}
*/
get direction() {
return this._direction;
}
/**
* @param {?} value
* @return {?}
*/
set direction(value) {
this._direction = value;
this.refreshUp = this._direction === 'up' || this._direction === '';
this.refreshDown = this._direction === 'down' || this._direction === '';
}
/**
* @return {?}
*/
get headerIndicator() {
return this._headerIndicator;
}
/**
* @param {?} value
* @return {?}
*/
set headerIndicator(value) {
Object.assign(this._headerIndicator, value);
}
/**
* @return {?}
*/
get footerIndicator() {
return this._footerIndicator;
}
/**
* @param {?} value
* @return {?}
*/
set footerIndicator(value) {
Object.assign(this._footerIndicator, value);
}
/**
* @param {?} e
* @return {?}
*/
touchstart(e) {
this._startTime = Date.now();
if (this._direction === 'down' || (this._direction === '' && !this._endReach)) {
if (this.ele.nativeElement.scrollTop > 0) {
this.startY = undefined;
return;
}
this.startY = e && e.changedTouches && e.changedTouches[0] && e.changedTouches[0].clientY;
this.state.drag = undefined;
}
else {
this.startY = e && e.changedTouches && e.changedTouches[0] && e.changedTouches[0].clientY;
this._clientHeight = this._pullToRefresh.element.nativeElement.clientHeight;
this._currentContentHeight = document.getElementsByTagName('pulltorefresh')[0].clientHeight;
}
this.transtionCls = '';
}
/**
* @param {?} e
* @return {?}
*/
touchmove(e) {
if (this._direction === 'down' || (this._direction === '' && !this._endReach)) {
if (this.ele.nativeElement.scrollTop > 0) {
return;
}
/** @type {?} */
let distanceY = e.changedTouches[0].clientY - this.startY;
this.state.drag = distanceY >= 0;
if (this.state.drag) {
// 禁止滚动
if (e.cancelable) {
e.preventDefault();
}
}
else {
return;
}
if (distanceY > this.damping) {
//当超过设定阈值是,缓慢增加
distanceY = (distanceY / (distanceY + this.damping)) * this.damping * 2;
}
else if (distanceY < 0) {
distanceY = 0;
}
if (distanceY > this.distanceToRefresh) {
this.state.currentState = 'activate';
if (this._ngModelOnChange) {
this._ngModelOnChange(this.state);
}
}
this.style = {
'-webkit-transform': 'translate3d( 0, ' + distanceY + 'px, 0 )',
transform: 'translate3d( 0, ' + distanceY + 'px, 0 )'
};
}
else {
/** @type {?} */
let distanceY = e.changedTouches[0].clientY - this.startY;
//向上拉动的时候,如果当前窗口内容没有滚到最后,则不实现拖动的动作;向下滚动不实现拖动动作
if (Math.abs(this._lastContentOffset) < this._clientHeight - this._currentContentHeight - this.distanceToRefresh ||
distanceY > 0) {
// 滚动
this.state.drag = false;
}
else {
// 上拉
this.state.drag = true;
}
if (this.state.drag) {
// 禁止滚动
if (e.cancelable) {
e.preventDefault();
}
}
else {
return;
}
//如果滑动到底部了,滑动距离随着拉动的距离增加缓慢增加
distanceY = -(distanceY / (distanceY - this.damping)) * this.damping;
if (Math.abs(distanceY) > this.distanceToRefresh) {
this.state.currentState = 'activate';
if (this._ngModelOnChange) {
this._ngModelOnChange(this.state);
}
}
this.style = {
'-webkit-transform': 'translate3d( 0, ' + distanceY + 'px, 0 )',
transform: 'translate3d( 0, ' + distanceY + 'px, 0 )'
};
}
}
/**
* @param {?} e
* @return {?}
*/
touchend(e) {
if (!this.startY || this.state.drag === false) {
return;
}
/** @type {?} */
const distanceY = e.changedTouches[0].clientY - this.startY;
if (Math.abs(distanceY) >= this.distanceToRefresh) {
this.state.currentState = 'release';
if (this._direction === 'down' || (this._direction === '' && !this._endReach)) {
this.translateY(this.distanceToRefresh + 1);
}
else {
this.translateY(-this.distanceToRefresh - 1);
}
if (this._ngModelOnChange) {
this._ngModelOnChange(this.state);
}
setTimeout((/**
* @return {?}
*/
() => {
this.state.currentState = 'finish';
if (this._ngModelOnChange) {
this._ngModelOnChange(this.state);
}
if (this._direction === 'down' || (this._direction === '' && !this._endReach)) {
this.onRefresh.emit('down');
}
else {
this.translateY(-this.distanceToRefresh - 1);
this.onRefresh.emit('up');
}
setTimeout((/**
* @return {?}
*/
() => {
this.state.currentState = 'deactivate';
if (this._ngModelOnChange) {
this._ngModelOnChange(this.state);
}
this.translateY(0);
}), 0);
}), 500);
}
else {
this.translateY(0);
}
}
/**
* @return {?}
*/
touchcancel() {
this.translateY(0);
}
/**
* @param {?} evt
* @return {?}
*/
scroll(evt) {
this._endTime = Date.now();
/** @type {?} */
const contentOffset = evt.target.scrollTop;
this._lastContentOffset = contentOffset;
if (this._direction === '') {
if (contentOffset > 0 &&
evt.target.scrollTop + this.ele.nativeElement.clientHeight === evt.target.scrollHeight) {
setTimeout((/**
* @return {?}
*/
() => {
this._endReach = true;
}), 100);
}
else {
this._endReach = false;
}
}
if (!this.endReachedRefresh || this._direction !== 'down') {
return;
}
if (contentOffset > 0 &&
evt.target.scrollTop + this.ele.nativeElement.clientHeight > evt.target.scrollHeight - this.distanceToRefresh &&
this._endTime - this._startTime >= 100) {
this._startTime = this._endTime;
if (this.refreshing) {
this.state.currentState = 'release';
if (this._ngModelOnChange) {
this._ngModelOnChange(this.state);
}
}
setTimeout((/**
* @return {?}
*/
() => {
if (this.endReachedRefresh) {
this.onRefresh.emit('endReachedRefresh');
}
if (this.refreshing) {
this.state.currentState = 'finish';
if (this._ngModelOnChange) {
this._ngModelOnChange(this.state);
}
}
}), 500);
}
else {
setTimeout((/**
* @return {?}
*/
() => {
if (this.refreshing) {
this.state.currentState = 'finish';
if (this._ngModelOnChange) {
this._ngModelOnChange(this.state);
}
}
}), 500);
}
}
/**
* @param {?} value
* @return {?}
*/
isTemplateRef(value) {
return value instanceof TemplateRef;
}
/**
* @param {?} distanceY
* @return {?}
*/
translateY(distanceY) {
this.transtionCls = 'am-pull-to-refresh-transition';
this.style = {
'-webkit-transform': 'translate3d( 0, ' + distanceY + 'px, 0 )',
transform: 'translate3d( 0, ' + distanceY + 'px, 0 )'
};
}
/**
* @param {?} value
* @return {?}
*/
writeValue(value) {
if (value !== null) {
this.state = value;
}
}
/**
* @param {?} fn
* @return {?}
*/
registerOnChange(fn) {
this._ngModelOnChange = fn;
}
/**
* @param {?} fn
* @return {?}
*/
registerOnTouched(fn) {
this._ngModelOnTouched = fn;
}
}
PullToRefreshComponent.decorators = [
{ type: Component, args: [{
selector: 'PullToRefresh, nzm-pull-to-refresh',
template: "<div class=\"am-pull-to-refresh-content-wrapper\">\n <div class=\"am-pull-to-refresh-content\" [ngClass]=\"transtionCls\" [ngStyle]=\"style\">\n <div\n *ngIf=\"refreshDown\"\n class=\"am-pull-to-refresh-indicator am-pull-to-refresh-header-indicator\"\n >\n <ng-template\n *ngIf=\"isTemplateRef(headerIndicator[state.currentState])\"\n [ngTemplateOutlet]=\"headerIndicator[state.currentState]\"\n ></ng-template>\n <ng-container *ngIf=\"!isTemplateRef(headerIndicator[state.currentState])\">{{\n headerIndicator[state.currentState]\n }}</ng-container>\n </div>\n <div #pullToRefresh>\n <ng-content></ng-content>\n <div\n *ngIf=\"direction === 'down' && endReachedRefresh\"\n class=\"am-pull-to-refresh-indicator am-pull-to-refresh-footer-indicator\"\n >\n <ng-template\n *ngIf=\"isTemplateRef(footerIndicator[state.currentState])\"\n [ngTemplateOutlet]=\"footerIndicator[state.currentState]\"\n ></ng-template>\n <ng-container *ngIf=\"!isTemplateRef(footerIndicator[state.currentState])\">{{\n footerIndicator[state.currentState]\n }}</ng-container>\n </div>\n </div>\n <div\n *ngIf=\"refreshUp\"\n class=\"am-pull-to-refresh-indicator am-pull-to-refresh-footer-indicator\"\n >\n <ng-template\n *ngIf=\"isTemplateRef(footerIndicator[state.currentState])\"\n [ngTemplateOutlet]=\"footerIndicator[state.currentState]\"\n ></ng-template>\n <ng-container *ngIf=\"!isTemplateRef(footerIndicator[state.currentState])\">{{\n footerIndicator[state.currentState]\n }}</ng-container>\n </div>\n </div>\n</div>\n",
encapsulation: ViewEncapsulation.None,
providers: [
{
provide: NG_VALUE_ACCESSOR,
useExisting: forwardRef((/**
* @return {?}
*/
() => PullToRefreshComponent)),
multi: true
}
]
}] }
];
/** @nocollapse */
PullToRefreshComponent.ctorParameters = () => [
{ type: ElementRef }
];
PullToRefreshComponent.propDecorators = {
_pullToRefresh: [{ type: ViewChild, args: ['pullToRefresh', { read: ViewContainerRef, static: true },] }],
distanceToRefresh: [{ type: Input }],
damping: [{ type: Input }],
endReachedRefresh: [{ type: Input }],
refreshing: [{ type: Input }],
direction: [{ type: Input }],
headerIndicator: [{ type: Input }],
footerIndicator: [{ type: Input }],
onRefresh: [{ type: Output }],
refresh: [{ type: HostBinding, args: ['class.am-pull-to-refresh',] }],
container: [{ type: HostBinding, args: ['class.super-container',] }],
refreshUp: [{ type: HostBinding, args: ['class.am-pull-to-refresh-up',] }],
refreshDown: [{ type: HostBinding, args: ['class.am-pull-to-refresh-down',] }],
touchstart: [{ type: HostListener, args: ['touchstart', ['$event'],] }],
touchmove: [{ type: HostListener, args: ['touchmove', ['$event'],] }],
touchend: [{ type: HostListener, args: ['touchend', ['$event'],] }],
touchcancel: [{ type: HostListener, args: ['touchcancel',] }],
scroll: [{ type: HostListener, args: ['scroll', ['$event'],] }]
};
if (false) {
/** @type {?} */
PullToRefreshComponent.prototype.transtionCls;
/** @type {?} */
PullToRefreshComponent.prototype.style;
/** @type {?} */
PullToRefreshComponent.prototype.startY;
/** @type {?} */
PullToRefreshComponent.prototype.state;
/**
* @type {?}
* @private
*/
PullToRefreshComponent.prototype._headerIndicator;
/**
* @type {?}
* @private
*/
PullToRefreshComponent.prototype._footerIndicator;
/**
* @type {?}
* @private
*/
PullToRefreshComponent.prototype._startTime;
/**
* @type {?}
* @private
*/
PullToRefreshComponent.prototype._endTime;
/**
* @type {?}
* @private
*/
PullToRefreshComponent.prototype._endReach;
/**
* @type {?}
* @private
*/
PullToRefreshComponent.prototype._direction;
/**
* @type {?}
* @private
*/
PullToRefreshComponent.prototype._clientHeight;
/**
* @type {?}
* @private
*/
PullToRefreshComponent.prototype._currentContentHeight;
/**
* @type {?}
* @private
*/
PullToRefreshComponent.prototype._lastContentOffset;
/**
* @type {?}
* @private
*/
PullToRefreshComponent.prototype._ngModelOnChange;
/**
* @type {?}
* @private
*/
PullToRefreshComponent.prototype._ngModelOnTouched;
/**
* @type {?}
* @private
*/
PullToRefreshComponent.prototype._pullToRefresh;
/** @type {?} */
PullToRefreshComponent.prototype.distanceToRefresh;
/** @type {?} */
PullToRefreshComponent.prototype.damping;
/** @type {?} */
PullToRefreshComponent.prototype.endReachedRefresh;
/** @type {?} */
PullToRefreshComponent.prototype.refreshing;
/** @type {?} */
PullToRefreshComponent.prototype.onRefresh;
/** @type {?} */
PullToRefreshComponent.prototype.refresh;
/** @type {?} */
PullToRefreshComponent.prototype.container;
/** @type {?} */
PullToRefreshComponent.prototype.refreshUp;
/** @type {?} */
PullToRefreshComponent.prototype.refreshDown;
/**
* @type {?}
* @private
*/
PullToRefreshComponent.prototype.ele;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pull-to-refresh.component.js","sourceRoot":"ng://ng-zorro-antd-mobile/","sources":["pull-to-refresh/pull-to-refresh.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Input,\n  Output,\n  Component,\n  ViewChild,\n  forwardRef,\n  TemplateRef,\n  HostBinding,\n  EventEmitter,\n  HostListener,\n  ViewContainerRef,\n  ViewEncapsulation,\n  ElementRef\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nexport interface Indicator {\n  activate?: any;\n  deactivate?: any;\n  release?: any;\n  finish?: any;\n}\n\n@Component({\n  selector: 'PullToRefresh, nzm-pull-to-refresh',\n  templateUrl: './pull-to-refresh.component.html',\n  encapsulation: ViewEncapsulation.None,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => PullToRefreshComponent),\n      multi: true\n    }\n  ]\n})\nexport class PullToRefreshComponent implements ControlValueAccessor {\n  transtionCls: any = {};\n  style: object = {\n    '-webkit-transform': 'translate3d( 0, 0, 0 )',\n    transform: 'translate3d( 0, 0, 0 )'\n  };\n  startY: number;\n  state: any = {\n    currentState: 'deactivate',\n    drag: false\n  };\n\n  private _headerIndicator: Indicator = {\n    activate: '松开立即刷新',\n    deactivate: '下拉可以刷新',\n    release: '刷新中。。。',\n    finish: '完成刷新'\n  };\n\n  private _footerIndicator: Indicator = {\n    activate: '松开立即刷新',\n    deactivate: '上拉可以刷新',\n    release: '刷新中。。。',\n    finish: '完成刷新'\n  };\n\n  private _startTime: number = 0;\n  private _endTime: number = 0;\n  private _endReach: boolean = false;\n  private _direction: string = '';\n  private _clientHeight: number = 0;\n  private _currentContentHeight: number = 0;\n  private _lastContentOffset: number = 0;\n  private _ngModelOnChange: (value: object) => {};\n  private _ngModelOnTouched: () => {};\n\n  @ViewChild('pullToRefresh', { read: ViewContainerRef, static: true })\n  private _pullToRefresh: ViewContainerRef;\n\n  @Input()\n  distanceToRefresh: number = 25; //触发刷新距离\n  @Input()\n  damping: number = 100; // 下拉的最大距离\n  @Input()\n  endReachedRefresh: boolean = false;\n  @Input()\n  refreshing: boolean = false;\n  @Input()\n  get direction(): string {\n    return this._direction;\n  }\n  set direction(value: string) {\n    this._direction = value;\n    this.refreshUp = this._direction === 'up' || this._direction === '';\n    this.refreshDown = this._direction === 'down' || this._direction === '';\n  }\n  @Input()\n  get headerIndicator(): Indicator {\n    return this._headerIndicator;\n  }\n  set headerIndicator(value: Indicator) {\n    Object.assign(this._headerIndicator, value);\n  }\n  @Input()\n  get footerIndicator(): Indicator {\n    return this._footerIndicator;\n  }\n  set footerIndicator(value: Indicator) {\n    Object.assign(this._footerIndicator, value);\n  }\n  @Output()\n  onRefresh: EventEmitter<any> = new EventEmitter();\n\n  @HostBinding('class.am-pull-to-refresh')\n  refresh: boolean = true;\n  @HostBinding('class.super-container')\n  container: boolean = true;\n  @HostBinding('class.am-pull-to-refresh-up')\n  refreshUp: boolean = this._direction === 'up' || this._direction === '';\n  @HostBinding('class.am-pull-to-refresh-down')\n  refreshDown: boolean = this._direction === 'down' || this._direction === '';\n\n  @HostListener('touchstart', ['$event'])\n  touchstart(e) {\n    this._startTime = Date.now();\n    if (this._direction === 'down' || (this._direction === '' && !this._endReach)) {\n      if (this.ele.nativeElement.scrollTop > 0) {\n        this.startY = undefined;\n        return;\n      }\n      this.startY = e && e.changedTouches && e.changedTouches[0] && e.changedTouches[0].clientY;\n      this.state.drag = undefined;\n    } else {\n      this.startY = e && e.changedTouches && e.changedTouches[0] && e.changedTouches[0].clientY;\n      this._clientHeight = this._pullToRefresh.element.nativeElement.clientHeight;\n      this._currentContentHeight = document.getElementsByTagName('pulltorefresh')[0].clientHeight;\n    }\n    this.transtionCls = '';\n  }\n  @HostListener('touchmove', ['$event'])\n  touchmove(e) {\n    if (this._direction === 'down' || (this._direction === '' && !this._endReach)) {\n      if (this.ele.nativeElement.scrollTop > 0) {\n        return;\n      }\n      let distanceY = e.changedTouches[0].clientY - this.startY;\n      this.state.drag = distanceY >= 0;\n      if (this.state.drag) {\n        // 禁止滚动\n        if (e.cancelable) {\n          e.preventDefault();\n        }\n      } else {\n        return;\n      }\n      if (distanceY > this.damping) {\n        //当超过设定阈值是，缓慢增加\n        distanceY = (distanceY / (distanceY + this.damping)) * this.damping * 2;\n      } else if (distanceY < 0) {\n        distanceY = 0;\n      }\n      if (distanceY > this.distanceToRefresh) {\n        this.state.currentState = 'activate';\n        if (this._ngModelOnChange) {\n          this._ngModelOnChange(this.state);\n        }\n      }\n      this.style = {\n        '-webkit-transform': 'translate3d( 0, ' + distanceY + 'px, 0 )',\n        transform: 'translate3d( 0, ' + distanceY + 'px, 0 )'\n      };\n    } else {\n      let distanceY = e.changedTouches[0].clientY - this.startY;\n      //向上拉动的时候，如果当前窗口内容没有滚到最后，则不实现拖动的动作；向下滚动不实现拖动动作\n      if (\n        Math.abs(this._lastContentOffset) < this._clientHeight - this._currentContentHeight - this.distanceToRefresh ||\n        distanceY > 0\n      ) {\n        // 滚动\n        this.state.drag = false;\n      } else {\n        // 上拉\n        this.state.drag = true;\n      }\n      if (this.state.drag) {\n        // 禁止滚动\n        if (e.cancelable) {\n          e.preventDefault();\n        }\n      } else {\n        return;\n      }\n      //如果滑动到底部了，滑动距离随着拉动的距离增加缓慢增加\n      distanceY = -(distanceY / (distanceY - this.damping)) * this.damping;\n      if (Math.abs(distanceY) > this.distanceToRefresh) {\n        this.state.currentState = 'activate';\n        if (this._ngModelOnChange) {\n          this._ngModelOnChange(this.state);\n        }\n      }\n      this.style = {\n        '-webkit-transform': 'translate3d( 0, ' + distanceY + 'px, 0 )',\n        transform: 'translate3d( 0, ' + distanceY + 'px, 0 )'\n      };\n    }\n  }\n  @HostListener('touchend', ['$event'])\n  touchend(e) {\n    if (!this.startY || this.state.drag === false) {\n      return;\n    }\n    const distanceY = e.changedTouches[0].clientY - this.startY;\n    if (Math.abs(distanceY) >= this.distanceToRefresh) {\n      this.state.currentState = 'release';\n      if (this._direction === 'down' || (this._direction === '' && !this._endReach)) {\n        this.translateY(this.distanceToRefresh + 1);\n      } else {\n        this.translateY(-this.distanceToRefresh - 1);\n      }\n      if (this._ngModelOnChange) {\n        this._ngModelOnChange(this.state);\n      }\n      setTimeout(() => {\n        this.state.currentState = 'finish';\n        if (this._ngModelOnChange) {\n          this._ngModelOnChange(this.state);\n        }\n        if (this._direction === 'down' || (this._direction === '' && !this._endReach)) {\n          this.onRefresh.emit('down');\n        } else {\n          this.translateY(-this.distanceToRefresh - 1);\n          this.onRefresh.emit('up');\n        }\n        setTimeout(() => {\n          this.state.currentState = 'deactivate';\n          if (this._ngModelOnChange) {\n            this._ngModelOnChange(this.state);\n          }\n          this.translateY(0);\n        }, 0);\n      }, 500);\n    } else {\n      this.translateY(0);\n    }\n  }\n  @HostListener('touchcancel')\n  touchcancel() {\n    this.translateY(0);\n  }\n  @HostListener('scroll', ['$event'])\n  scroll(evt) {\n    this._endTime = Date.now();\n    const contentOffset = evt.target.scrollTop;\n    this._lastContentOffset = contentOffset;\n    if (this._direction === '') {\n      if (\n        contentOffset > 0 &&\n        evt.target.scrollTop + this.ele.nativeElement.clientHeight === evt.target.scrollHeight\n      ) {\n        setTimeout(() => {\n          this._endReach = true;\n        }, 100);\n      } else {\n        this._endReach = false;\n      }\n    }\n    if (!this.endReachedRefresh || this._direction !== 'down') {\n      return;\n    }\n    if (\n      contentOffset > 0 &&\n      evt.target.scrollTop + this.ele.nativeElement.clientHeight > evt.target.scrollHeight - this.distanceToRefresh &&\n      this._endTime - this._startTime >= 100\n    ) {\n      this._startTime = this._endTime;\n      if (this.refreshing) {\n        this.state.currentState = 'release';\n        if (this._ngModelOnChange) {\n          this._ngModelOnChange(this.state);\n        }\n      }\n      setTimeout(() => {\n        if (this.endReachedRefresh) {\n          this.onRefresh.emit('endReachedRefresh');\n        }\n        if (this.refreshing) {\n          this.state.currentState = 'finish';\n          if (this._ngModelOnChange) {\n            this._ngModelOnChange(this.state);\n          }\n        }\n      }, 500);\n    } else {\n      setTimeout(() => {\n        if (this.refreshing) {\n          this.state.currentState = 'finish';\n          if (this._ngModelOnChange) {\n            this._ngModelOnChange(this.state);\n          }\n        }\n      }, 500);\n    }\n  }\n\n  constructor(private ele: ElementRef) {}\n\n  isTemplateRef(value) {\n    return value instanceof TemplateRef;\n  }\n\n  translateY(distanceY) {\n    this.transtionCls = 'am-pull-to-refresh-transition';\n    this.style = {\n      '-webkit-transform': 'translate3d( 0, ' + distanceY + 'px, 0 )',\n      transform: 'translate3d( 0, ' + distanceY + 'px, 0 )'\n    };\n  }\n\n  writeValue(value: object): void {\n    if (value !== null) {\n      this.state = value;\n    }\n  }\n\n  registerOnChange(fn: (_: object) => {}): void {\n    this._ngModelOnChange = fn;\n  }\n\n  registerOnTouched(fn: () => {}): void {\n    this._ngModelOnTouched = fn;\n  }\n}\n"]}