ionic-angular
Version:
A powerful framework for building mobile and progressive web apps with JavaScript and Angular 2
82 lines • 3.02 kB
JavaScript
var __extends = (this && this.__extends) || function (d, b) {
for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
function __() { this.constructor = d; }
d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
};
import { swipeShouldReset } from '../util/util';
import { GESTURE_GO_BACK_SWIPE } from '../gestures/gesture-controller';
import { SlideEdgeGesture } from '../gestures/slide-edge-gesture';
export var SwipeBackGesture = (function (_super) {
__extends(SwipeBackGesture, _super);
/**
* @param {?} plt
* @param {?} _nav
* @param {?} gestureCtlr
* @param {?} domCtrl
*/
function SwipeBackGesture(plt, _nav, gestureCtlr, domCtrl) {
_super.call(this, plt, plt.doc().body, {
direction: 'x',
edge: 'left',
maxEdgeStart: 75,
threshold: 5,
zone: false,
domController: domCtrl,
gesture: gestureCtlr.createGesture({
name: GESTURE_GO_BACK_SWIPE,
priority: 20 /* GoBackSwipe */,
disableScroll: true
})
});
this._nav = _nav;
}
/**
* @param {?} ev
* @return {?}
*/
SwipeBackGesture.prototype.canStart = function (ev) {
// the gesture swipe angle must be mainly horizontal and the
// gesture distance would be relatively short for a swipe back
// and swipe back must be possible on this nav controller
return (this._nav.canSwipeBack() &&
_super.prototype.canStart.call(this, ev));
};
/**
* @param {?} ev
* @return {?}
*/
SwipeBackGesture.prototype.onSlideBeforeStart = function (ev) {
this._nav.swipeBackStart();
};
/**
* @param {?} slide
* @param {?} ev
* @return {?}
*/
SwipeBackGesture.prototype.onSlide = function (slide, ev) {
ev.preventDefault();
ev.stopPropagation();
var /** @type {?} */ stepValue = (slide.distance / slide.max);
this._nav.swipeBackProgress(stepValue);
};
/**
* @param {?} slide
* @param {?} ev
* @return {?}
*/
SwipeBackGesture.prototype.onSlideEnd = function (slide, ev) {
var /** @type {?} */ velocity = slide.velocity;
var /** @type {?} */ currentStepValue = (slide.distance / slide.max);
var /** @type {?} */ isResetDirecction = velocity < 0;
var /** @type {?} */ isMovingFast = Math.abs(slide.velocity) > 0.4;
var /** @type {?} */ isInResetZone = Math.abs(slide.delta) < Math.abs(slide.max) * 0.5;
var /** @type {?} */ shouldComplete = !swipeShouldReset(isResetDirecction, isMovingFast, isInResetZone);
this._nav.swipeBackEnd(shouldComplete, currentStepValue, velocity);
};
return SwipeBackGesture;
}(SlideEdgeGesture));
function SwipeBackGesture_tsickle_Closure_declarations() {
/** @type {?} */
SwipeBackGesture.prototype._nav;
}
//# sourceMappingURL=swipe-back.js.map