UNPKG

@fivethree/core

Version:
299 lines 22.5 kB
/** * @fileoverview added by tsickle * Generated from: lib/pull/pull.directive.ts * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Directive, ElementRef, Input, Output, EventEmitter } from '@angular/core'; import { IonContent, Platform } from '@ionic/angular'; import { fromEvent, merge } from 'rxjs'; import { filter, map, skipWhile, takeUntil, takeLast } from 'rxjs/operators'; var FivPull = /** @class */ (function () { function FivPull(element, platform, content) { this.element = element; this.platform = platform; this.content = content; this.minPullHeight = 112; this.maxPullHeight = 168; this.enabled = true; this.enableScroll = false; this.direction = 'down'; this.fivRefresh = new EventEmitter(); this.fivCancel = new EventEmitter(); this.fivPull = new EventEmitter(); } /** * @return {?} */ FivPull.prototype.ngOnInit = /** * @return {?} */ function () { this.init(); }; /** * @param {?=} minPullHeight * @param {?=} maxPullHeight * @param {?=} direction * @return {?} */ FivPull.prototype.init = /** * @param {?=} minPullHeight * @param {?=} maxPullHeight * @param {?=} direction * @return {?} */ function (minPullHeight, maxPullHeight, direction) { var _this = this; if (minPullHeight === void 0) { minPullHeight = 112; } if (maxPullHeight === void 0) { maxPullHeight = 168; } if (direction === void 0) { direction = 'down'; } this.minPullHeight = minPullHeight; this.maxPullHeight = maxPullHeight; this.direction = direction; this.content.scrollEvents = true; this.content.getScrollElement().then((/** * @param {?} s * @return {?} */ function (s) { _this.scrollY = s; // needed for scrollTop _this.setupPanListener(); })); }; /** * @private * @return {?} */ FivPull.prototype.setupPanListener = /** * @private * @return {?} */ function () { var _this = this; /** @type {?} */ var touchstart$ = fromEvent(this.element.nativeElement, 'touchstart', { passive: true }); /** @type {?} */ var touchmove$ = fromEvent(this.element.nativeElement, 'touchmove', { passive: true }); /** @type {?} */ var touchend$ = fromEvent(this.element.nativeElement, 'touchend', { passive: true }); /** @type {?} */ var touchcancel$ = fromEvent(this.element.nativeElement, 'touchcancel', { passive: true }); /** @type {?} */ var end$ = merge(touchend$, touchcancel$); /** @type {?} */ var dragAtTop = touchstart$.pipe(filter((/** * @param {?} e * @return {?} */ function (e) { return (_this.scrollY.scrollTop === 0 || _this.enableScroll) && _this.direction === 'down' && _this.enabled; }))); /** @type {?} */ var dragAtBottom = touchstart$.pipe(filter((/** * @param {?} e * @return {?} */ function (e) { return (_this.scrollY.scrollTop === _this.scrollY.clientHeight - _this.platform.height() || _this.enableScroll) && _this.direction === 'up' && _this.enabled; }))); /** @type {?} */ var dragTopDown = dragAtTop.pipe(map((/** * @param {?} start * @return {?} */ function (start) { /** @type {?} */ var startY = start.touches[0].pageY; return touchmove$.pipe(map((/** * @param {?} move * @return {?} */ function (move) { /** @type {?} */ var currentY = move.touches[0].pageY; return { startEvent: start, moveEvent: move, startY: startY, currentY: currentY, offset: currentY - startY }; })), skipWhile((/** * @param {?} drag * @return {?} */ function (drag) { return drag.offset < 0; })), takeUntil(end$)); }))); dragTopDown.forEach((/** * @param {?} drags * @return {?} */ function (drags) { drags.forEach((/** * @param {?} drag * @return {?} */ function (drag) { /** @type {?} */ var offset = drag.offset / 2; if (offset < 0 || offset > _this.maxPullHeight) { return; } if (offset <= _this.maxPullHeight) { } _this.fivPull.emit(offset / _this.maxPullHeight); })); drags.pipe(takeLast(1)).subscribe((/** * @param {?} drag * @return {?} */ function (drag) { /** @type {?} */ var offset = drag.offset / 2; /** @type {?} */ var refresh = offset >= _this.minPullHeight; if (refresh) { _this.fivRefresh.emit(offset / _this.maxPullHeight); } else { _this.fivCancel.emit(offset / _this.maxPullHeight); } })); })); /** @type {?} */ var dragBottomUp = dragAtBottom.pipe(map((/** * @param {?} start * @return {?} */ function (start) { /** @type {?} */ var startY = start.touches[0].pageY; return touchmove$.pipe(map((/** * @param {?} move * @return {?} */ function (move) { /** @type {?} */ var currentY = move.touches[0].pageY; return { startEvent: start, moveEvent: move, startY: startY, currentY: currentY, offset: startY - currentY }; })), skipWhile((/** * @param {?} drag * @return {?} */ function (drag) { return drag.offset < 0; })), takeUntil(end$)); }))); dragBottomUp.forEach((/** * @param {?} drags * @return {?} */ function (drags) { drags.forEach((/** * @param {?} drag * @return {?} */ function (drag) { /** @type {?} */ var offset = drag.offset / 2; if (offset < 0 || offset > _this.maxPullHeight) { return; } _this.fivPull.emit(offset / _this.maxPullHeight); })); drags.pipe(takeLast(1)).subscribe((/** * @param {?} drag * @return {?} */ function (drag) { /** @type {?} */ var offset = drag.offset / 2; /** @type {?} */ var refresh = offset >= _this.minPullHeight; if (refresh) { _this.fivRefresh.emit(offset / _this.maxPullHeight); } else { _this.fivCancel.emit(offset / _this.maxPullHeight); } })); })); }; FivPull.decorators = [ { type: Directive, args: [{ selector: '[fivPull]' },] } ]; /** @nocollapse */ FivPull.ctorParameters = function () { return [ { type: ElementRef }, { type: Platform }, { type: IonContent } ]; }; FivPull.propDecorators = { minPullHeight: [{ type: Input }], maxPullHeight: [{ type: Input }], enabled: [{ type: Input }], enableScroll: [{ type: Input }], direction: [{ type: Input }], fivRefresh: [{ type: Output }], fivCancel: [{ type: Output }], fivPull: [{ type: Output }] }; return FivPull; }()); export { FivPull }; if (false) { /** @type {?} */ FivPull.prototype.minPullHeight; /** @type {?} */ FivPull.prototype.maxPullHeight; /** @type {?} */ FivPull.prototype.enabled; /** @type {?} */ FivPull.prototype.enableScroll; /** @type {?} */ FivPull.prototype.direction; /** @type {?} */ FivPull.prototype.fivRefresh; /** @type {?} */ FivPull.prototype.fivCancel; /** @type {?} */ FivPull.prototype.fivPull; /** @type {?} */ FivPull.prototype.scrollY; /** * @type {?} * @private */ FivPull.prototype.element; /** * @type {?} * @private */ FivPull.prototype.platform; /** * @type {?} * @private */ FivPull.prototype.content; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pull.directive.js","sourceRoot":"ng://@fivethree/core/","sources":["lib/pull/pull.directive.ts"],"names":[],"mappings":";;;;;AAAA,OAAO,EACL,SAAS,EAET,UAAU,EACV,KAAK,EACL,MAAM,EACN,YAAY,EACb,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,UAAU,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AACtD,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,MAAM,CAAC;AACxC,OAAO,EAAE,MAAM,EAAE,GAAG,EAAE,SAAS,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AAE7E;IAgBE,iBACU,OAAmB,EACnB,QAAkB,EAClB,OAAmB;QAFnB,YAAO,GAAP,OAAO,CAAY;QACnB,aAAQ,GAAR,QAAQ,CAAU;QAClB,YAAO,GAAP,OAAO,CAAY;QAfpB,kBAAa,GAAG,GAAG,CAAC;QACpB,kBAAa,GAAG,GAAG,CAAC;QACpB,YAAO,GAAG,IAAI,CAAC;QACf,iBAAY,GAAG,KAAK,CAAC;QACrB,cAAS,GAAkB,MAAM,CAAC;QAEjC,eAAU,GAAG,IAAI,YAAY,EAAO,CAAC;QACrC,cAAS,GAAG,IAAI,YAAY,EAAU,CAAC;QACvC,YAAO,GAAG,IAAI,YAAY,EAAU,CAAC;IAQ5C,CAAC;;;;IAEJ,0BAAQ;;;IAAR;QACE,IAAI,CAAC,IAAI,EAAE,CAAC;IACd,CAAC;;;;;;;IACD,sBAAI;;;;;;IAAJ,UACE,aAAmB,EACnB,aAAmB,EACnB,SAAiC;QAHnC,iBAaC;QAZC,8BAAA,EAAA,mBAAmB;QACnB,8BAAA,EAAA,mBAAmB;QACnB,0BAAA,EAAA,kBAAiC;QAEjC,IAAI,CAAC,aAAa,GAAG,aAAa,CAAC;QACnC,IAAI,CAAC,aAAa,GAAG,aAAa,CAAC;QACnC,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;QAC3B,IAAI,CAAC,OAAO,CAAC,YAAY,GAAG,IAAI,CAAC;QACjC,IAAI,CAAC,OAAO,CAAC,gBAAgB,EAAE,CAAC,IAAI;;;;QAAC,UAAA,CAAC;YACpC,KAAI,CAAC,OAAO,GAAG,CAAC,CAAC,CAAC,uBAAuB;YACzC,KAAI,CAAC,gBAAgB,EAAE,CAAC;QAC1B,CAAC,EAAC,CAAC;IACL,CAAC;;;;;IAEO,kCAAgB;;;;IAAxB;QAAA,iBAoHC;;YAnHO,WAAW,GAAG,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,aAAa,EAAE,YAAY,EAAE;YACtE,OAAO,EAAE,IAAI;SACd,CAAC;;YACI,UAAU,GAAG,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,aAAa,EAAE,WAAW,EAAE;YACpE,OAAO,EAAE,IAAI;SACd,CAAC;;YACI,SAAS,GAAG,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,aAAa,EAAE,UAAU,EAAE;YAClE,OAAO,EAAE,IAAI;SACd,CAAC;;YACI,YAAY,GAAG,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,aAAa,EAAE,aAAa,EAAE;YACxE,OAAO,EAAE,IAAI;SACd,CAAC;;YACI,IAAI,GAAG,KAAK,CAAC,SAAS,EAAE,YAAY,CAAC;;YAErC,SAAS,GAAG,WAAW,CAAC,IAAI,CAChC,MAAM;;;;QACJ,UAAA,CAAC;YACC,OAAA,CAAC,KAAI,CAAC,OAAO,CAAC,SAAS,KAAK,CAAC,IAAI,KAAI,CAAC,YAAY,CAAC;gBACnD,KAAI,CAAC,SAAS,KAAK,MAAM;gBACzB,KAAI,CAAC,OAAO;QAFZ,CAEY,EACf,CACF;;YAEK,YAAY,GAAG,WAAW,CAAC,IAAI,CACnC,MAAM;;;;QACJ,UAAA,CAAC;YACC,OAAA,CAAC,KAAI,CAAC,OAAO,CAAC,SAAS;gBACrB,KAAI,CAAC,OAAO,CAAC,YAAY,GAAG,KAAI,CAAC,QAAQ,CAAC,MAAM,EAAE;gBAClD,KAAI,CAAC,YAAY,CAAC;gBACpB,KAAI,CAAC,SAAS,KAAK,IAAI;gBACvB,KAAI,CAAC,OAAO;QAJZ,CAIY,EACf,CACF;;YAEK,WAAW,GAAG,SAAS,CAAC,IAAI,CAChC,GAAG;;;;QAAC,UAAC,KAAU;;gBACP,MAAM,GAAG,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,KAAK;YACrC,OAAO,UAAU,CAAC,IAAI,CACpB,GAAG;;;;YAAC,UAAC,IAAS;;oBACN,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,KAAK;gBACtC,OAAO;oBACL,UAAU,EAAE,KAAK;oBACjB,SAAS,EAAE,IAAI;oBACf,MAAM,EAAE,MAAM;oBACd,QAAQ,EAAE,QAAQ;oBAClB,MAAM,EAAE,QAAQ,GAAG,MAAM;iBAC1B,CAAC;YACJ,CAAC,EAAC,EACF,SAAS;;;;YAAC,UAAA,IAAI,IAAI,OAAA,IAAI,CAAC,MAAM,GAAG,CAAC,EAAf,CAAe,EAAC,EAClC,SAAS,CAAC,IAAI,CAAC,CAChB,CAAC;QACJ,CAAC,EAAC,CACH;QAED,WAAW,CAAC,OAAO;;;;QAAC,UAAA,KAAK;YACvB,KAAK,CAAC,OAAO;;;;YAAC,UAAA,IAAI;;oBACV,MAAM,GAAG,IAAI,CAAC,MAAM,GAAG,CAAC;gBAC9B,IAAI,MAAM,GAAG,CAAC,IAAI,MAAM,GAAG,KAAI,CAAC,aAAa,EAAE;oBAC7C,OAAO;iBACR;gBACD,IAAI,MAAM,IAAI,KAAI,CAAC,aAAa,EAAE;iBACjC;gBACD,KAAI,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM,GAAG,KAAI,CAAC,aAAa,CAAC,CAAC;YACjD,CAAC,EAAC,CAAC;YAEH,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS;;;;YAAC,UAAA,IAAI;;oBAC9B,MAAM,GAAG,IAAI,CAAC,MAAM,GAAG,CAAC;;oBACxB,OAAO,GAAG,MAAM,IAAI,KAAI,CAAC,aAAa;gBAC5C,IAAI,OAAO,EAAE;oBACX,KAAI,CAAC,UAAU,CAAC,IAAI,CAAC,MAAM,GAAG,KAAI,CAAC,aAAa,CAAC,CAAC;iBACnD;qBAAM;oBACL,KAAI,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,GAAG,KAAI,CAAC,aAAa,CAAC,CAAC;iBAClD;YACH,CAAC,EAAC,CAAC;QACL,CAAC,EAAC,CAAC;;YAEG,YAAY,GAAG,YAAY,CAAC,IAAI,CACpC,GAAG;;;;QAAC,UAAC,KAAU;;gBACP,MAAM,GAAG,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,KAAK;YACrC,OAAO,UAAU,CAAC,IAAI,CACpB,GAAG;;;;YAAC,UAAC,IAAS;;oBACN,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,KAAK;gBACtC,OAAO;oBACL,UAAU,EAAE,KAAK;oBACjB,SAAS,EAAE,IAAI;oBACf,MAAM,EAAE,MAAM;oBACd,QAAQ,EAAE,QAAQ;oBAClB,MAAM,EAAE,MAAM,GAAG,QAAQ;iBAC1B,CAAC;YACJ,CAAC,EAAC,EACF,SAAS;;;;YAAC,UAAA,IAAI,IAAI,OAAA,IAAI,CAAC,MAAM,GAAG,CAAC,EAAf,CAAe,EAAC,EAClC,SAAS,CAAC,IAAI,CAAC,CAChB,CAAC;QACJ,CAAC,EAAC,CACH;QAED,YAAY,CAAC,OAAO;;;;QAAC,UAAA,KAAK;YACxB,KAAK,CAAC,OAAO;;;;YAAC,UAAA,IAAI;;oBACV,MAAM,GAAG,IAAI,CAAC,MAAM,GAAG,CAAC;gBAC9B,IAAI,MAAM,GAAG,CAAC,IAAI,MAAM,GAAG,KAAI,CAAC,aAAa,EAAE;oBAC7C,OAAO;iBACR;gBACD,KAAI,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM,GAAG,KAAI,CAAC,aAAa,CAAC,CAAC;YACjD,CAAC,EAAC,CAAC;YAEH,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS;;;;YAAC,UAAA,IAAI;;oBAC9B,MAAM,GAAG,IAAI,CAAC,MAAM,GAAG,CAAC;;oBACxB,OAAO,GAAG,MAAM,IAAI,KAAI,CAAC,aAAa;gBAC5C,IAAI,OAAO,EAAE;oBACX,KAAI,CAAC,UAAU,CAAC,IAAI,CAAC,MAAM,GAAG,KAAI,CAAC,aAAa,CAAC,CAAC;iBACnD;qBAAM;oBACL,KAAI,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,GAAG,KAAI,CAAC,aAAa,CAAC,CAAC;iBAClD;YACH,CAAC,EAAC,CAAC;QACL,CAAC,EAAC,CAAC;IACL,CAAC;;gBA5JF,SAAS,SAAC;oBACT,QAAQ,EAAE,WAAW;iBACtB;;;;gBAXC,UAAU;gBAKS,QAAQ;gBAApB,UAAU;;;gCAQhB,KAAK;gCACL,KAAK;0BACL,KAAK;+BACL,KAAK;4BACL,KAAK;6BAEL,MAAM;4BACN,MAAM;0BACN,MAAM;;IAiJT,cAAC;CAAA,AA7JD,IA6JC;SA1JY,OAAO;;;IAClB,gCAA6B;;IAC7B,gCAA6B;;IAC7B,0BAAwB;;IACxB,+BAA8B;;IAC9B,4BAA2C;;IAE3C,6BAA+C;;IAC/C,4BAAiD;;IACjD,0BAA+C;;IAE/C,0BAAqB;;;;;IAGnB,0BAA2B;;;;;IAC3B,2BAA0B;;;;;IAC1B,0BAA2B","sourcesContent":["import {\n  Directive,\n  OnInit,\n  ElementRef,\n  Input,\n  Output,\n  EventEmitter\n} from '@angular/core';\nimport { IonContent, Platform } from '@ionic/angular';\nimport { fromEvent, merge } from 'rxjs';\nimport { filter, map, skipWhile, takeUntil, takeLast } from 'rxjs/operators';\n\n@Directive({\n  selector: '[fivPull]'\n})\nexport class FivPull implements OnInit {\n  @Input() minPullHeight = 112;\n  @Input() maxPullHeight = 168;\n  @Input() enabled = true;\n  @Input() enableScroll = false;\n  @Input() direction: 'up' | 'down' = 'down';\n\n  @Output() fivRefresh = new EventEmitter<any>();\n  @Output() fivCancel = new EventEmitter<number>();\n  @Output() fivPull = new EventEmitter<number>();\n\n  scrollY: HTMLElement;\n\n  constructor(\n    private element: ElementRef,\n    private platform: Platform,\n    private content: IonContent\n  ) {}\n\n  ngOnInit(): void {\n    this.init();\n  }\n  init(\n    minPullHeight = 112,\n    maxPullHeight = 168,\n    direction: 'up' | 'down' = 'down'\n  ) {\n    this.minPullHeight = minPullHeight;\n    this.maxPullHeight = maxPullHeight;\n    this.direction = direction;\n    this.content.scrollEvents = true;\n    this.content.getScrollElement().then(s => {\n      this.scrollY = s; // needed for scrollTop\n      this.setupPanListener();\n    });\n  }\n\n  private setupPanListener() {\n    const touchstart$ = fromEvent(this.element.nativeElement, 'touchstart', {\n      passive: true\n    });\n    const touchmove$ = fromEvent(this.element.nativeElement, 'touchmove', {\n      passive: true\n    });\n    const touchend$ = fromEvent(this.element.nativeElement, 'touchend', {\n      passive: true\n    });\n    const touchcancel$ = fromEvent(this.element.nativeElement, 'touchcancel', {\n      passive: true\n    });\n    const end$ = merge(touchend$, touchcancel$);\n\n    const dragAtTop = touchstart$.pipe(\n      filter(\n        e =>\n          (this.scrollY.scrollTop === 0 || this.enableScroll) &&\n          this.direction === 'down' &&\n          this.enabled\n      )\n    );\n\n    const dragAtBottom = touchstart$.pipe(\n      filter(\n        e =>\n          (this.scrollY.scrollTop ===\n            this.scrollY.clientHeight - this.platform.height() ||\n            this.enableScroll) &&\n          this.direction === 'up' &&\n          this.enabled\n      )\n    );\n\n    const dragTopDown = dragAtTop.pipe(\n      map((start: any) => {\n        const startY = start.touches[0].pageY;\n        return touchmove$.pipe(\n          map((move: any) => {\n            const currentY = move.touches[0].pageY;\n            return {\n              startEvent: start,\n              moveEvent: move,\n              startY: startY,\n              currentY: currentY,\n              offset: currentY - startY\n            };\n          }),\n          skipWhile(drag => drag.offset < 0),\n          takeUntil(end$)\n        );\n      })\n    );\n\n    dragTopDown.forEach(drags => {\n      drags.forEach(drag => {\n        const offset = drag.offset / 2;\n        if (offset < 0 || offset > this.maxPullHeight) {\n          return;\n        }\n        if (offset <= this.maxPullHeight) {\n        }\n        this.fivPull.emit(offset / this.maxPullHeight);\n      });\n\n      drags.pipe(takeLast(1)).subscribe(drag => {\n        const offset = drag.offset / 2;\n        const refresh = offset >= this.minPullHeight;\n        if (refresh) {\n          this.fivRefresh.emit(offset / this.maxPullHeight);\n        } else {\n          this.fivCancel.emit(offset / this.maxPullHeight);\n        }\n      });\n    });\n\n    const dragBottomUp = dragAtBottom.pipe(\n      map((start: any) => {\n        const startY = start.touches[0].pageY;\n        return touchmove$.pipe(\n          map((move: any) => {\n            const currentY = move.touches[0].pageY;\n            return {\n              startEvent: start,\n              moveEvent: move,\n              startY: startY,\n              currentY: currentY,\n              offset: startY - currentY\n            };\n          }),\n          skipWhile(drag => drag.offset < 0),\n          takeUntil(end$)\n        );\n      })\n    );\n\n    dragBottomUp.forEach(drags => {\n      drags.forEach(drag => {\n        const offset = drag.offset / 2;\n        if (offset < 0 || offset > this.maxPullHeight) {\n          return;\n        }\n        this.fivPull.emit(offset / this.maxPullHeight);\n      });\n\n      drags.pipe(takeLast(1)).subscribe(drag => {\n        const offset = drag.offset / 2;\n        const refresh = offset >= this.minPullHeight;\n        if (refresh) {\n          this.fivRefresh.emit(offset / this.maxPullHeight);\n        } else {\n          this.fivCancel.emit(offset / this.maxPullHeight);\n        }\n      });\n    });\n  }\n}\n"]}