@fivethree/core
Version:
Fivethree Core Components
299 lines • 22.5 kB
JavaScript
/**
* @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":"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","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"]}