UNPKG

ng-zorro-antd-mobile

Version:

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

332 lines 46 kB
import { Input, Output, Component, ViewChild, forwardRef, TemplateRef, HostBinding, EventEmitter, HostListener, ViewContainerRef, ViewEncapsulation, ElementRef } from '@angular/core'; import { NG_VALUE_ACCESSOR } from '@angular/forms'; import * as i0 from "@angular/core"; import * as i1 from "@angular/common"; export class PullToRefreshComponent { get direction() { return this._direction; } set direction(value) { this._direction = value; this.refreshUp = this._direction === 'up' || this._direction === ''; this.refreshDown = this._direction === 'down' || this._direction === ''; } get headerIndicator() { return this._headerIndicator; } set headerIndicator(value) { Object.assign(this._headerIndicator, value); } get footerIndicator() { return this._footerIndicator; } set footerIndicator(value) { Object.assign(this._footerIndicator, value); } 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 = this.ele.nativeElement.clientHeight; } this.transtionCls = ''; } touchmove(e) { if (this._direction === 'down' || (this._direction === '' && !this._endReach)) { if (this.ele.nativeElement.scrollTop > 0) { return; } 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 { 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 )' }; } } touchend(e) { if (!this.startY || this.state.drag === false) { return; } 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(() => { 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(() => { this.state.currentState = 'deactivate'; if (this._ngModelOnChange) { this._ngModelOnChange(this.state); } this.translateY(0); }, 0); }, 500); } else { this.translateY(0); } } touchcancel() { this.translateY(0); } scroll(evt) { this._endTime = Date.now(); 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(() => { 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(() => { if (this.endReachedRefresh) { this.onRefresh.emit('endReachedRefresh'); } if (this.refreshing) { this.state.currentState = 'finish'; if (this._ngModelOnChange) { this._ngModelOnChange(this.state); } } }, 500); } else { setTimeout(() => { if (this.refreshing) { this.state.currentState = 'finish'; if (this._ngModelOnChange) { this._ngModelOnChange(this.state); } } }, 500); } } 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 === ''; } isTemplateRef(value) { return value instanceof TemplateRef; } translateY(distanceY) { this.transtionCls = 'am-pull-to-refresh-transition'; this.style = { '-webkit-transform': 'translate3d( 0, ' + distanceY + 'px, 0 )', transform: 'translate3d( 0, ' + distanceY + 'px, 0 )' }; } writeValue(value) { if (value !== null) { this.state = value; } } registerOnChange(fn) { this._ngModelOnChange = fn; } registerOnTouched(fn) { this._ngModelOnTouched = fn; } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: PullToRefreshComponent, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.8", type: PullToRefreshComponent, selector: "PullToRefresh, nzm-pull-to-refresh", inputs: { distanceToRefresh: "distanceToRefresh", damping: "damping", endReachedRefresh: "endReachedRefresh", refreshing: "refreshing", direction: "direction", headerIndicator: "headerIndicator", footerIndicator: "footerIndicator" }, outputs: { onRefresh: "onRefresh" }, host: { listeners: { "touchstart": "touchstart($event)", "touchmove": "touchmove($event)", "touchend": "touchend($event)", "touchcancel": "touchcancel()", "scroll": "scroll($event)" }, properties: { "class.am-pull-to-refresh": "this.refresh", "class.super-container": "this.container", "class.am-pull-to-refresh-up": "this.refreshUp", "class.am-pull-to-refresh-down": "this.refreshDown" } }, providers: [ { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => PullToRefreshComponent), multi: true } ], viewQueries: [{ propertyName: "_pullToRefresh", first: true, predicate: ["pullToRefresh"], descendants: true, read: ViewContainerRef, static: true }], ngImport: i0, template: "<div class=\"am-pull-to-refresh-content-wrapper\">\n <div class=\"am-pull-to-refresh-content\" [ngClass]=\"transtionCls\" [ngStyle]=\"style\">\n <div *ngIf=\"refreshDown\" class=\"am-pull-to-refresh-indicator am-pull-to-refresh-header-indicator\">\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 *ngIf=\"refreshUp\" class=\"am-pull-to-refresh-indicator am-pull-to-refresh-footer-indicator\">\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", 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.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }], encapsulation: i0.ViewEncapsulation.None }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: PullToRefreshComponent, decorators: [{ type: Component, args: [{ selector: 'PullToRefresh, nzm-pull-to-refresh', encapsulation: ViewEncapsulation.None, providers: [ { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => PullToRefreshComponent), multi: true } ], template: "<div class=\"am-pull-to-refresh-content-wrapper\">\n <div class=\"am-pull-to-refresh-content\" [ngClass]=\"transtionCls\" [ngStyle]=\"style\">\n <div *ngIf=\"refreshDown\" class=\"am-pull-to-refresh-indicator am-pull-to-refresh-header-indicator\">\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 *ngIf=\"refreshUp\" class=\"am-pull-to-refresh-indicator am-pull-to-refresh-footer-indicator\">\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" }] }], ctorParameters: () => [{ type: i0.ElementRef }], 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']] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pull-to-refresh.component.js","sourceRoot":"","sources":["../../../components/pull-to-refresh/pull-to-refresh.component.ts","../../../components/pull-to-refresh/pull-to-refresh.component.html"],"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 = this.ele.nativeElement.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 (contentOffset > 0 && evt.target.scrollTop + this.ele.nativeElement.clientHeight === evt.target.scrollHeight) {\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","<div class=\"am-pull-to-refresh-content-wrapper\">\n  <div class=\"am-pull-to-refresh-content\" [ngClass]=\"transtionCls\" [ngStyle]=\"style\">\n    <div *ngIf=\"refreshDown\" class=\"am-pull-to-refresh-indicator am-pull-to-refresh-header-indicator\">\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 *ngIf=\"refreshUp\" class=\"am-pull-to-refresh-indicator am-pull-to-refresh-footer-indicator\">\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"]}