ionic-angular
Version:
A powerful framework for building mobile and progressive web apps with JavaScript and Angular 2
129 lines • 4.15 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 { GESTURE_MENU_SWIPE } from '../../gestures/gesture-controller';
import { SlideEdgeGesture } from '../../gestures/slide-edge-gesture';
/**
* Gesture attached to the content which the menu is assigned to
*/
export var MenuContentGesture = (function (_super) {
__extends(MenuContentGesture, _super);
/**
* @param {?} plt
* @param {?} menu
* @param {?} gestureCtrl
* @param {?} domCtrl
*/
function MenuContentGesture(plt, menu, gestureCtrl, domCtrl) {
_super.call(this, plt, plt.doc().body, {
direction: 'x',
edge: menu.side,
threshold: 5,
maxEdgeStart: menu.maxEdgeStart || 50,
zone: false,
passive: true,
domController: domCtrl,
gesture: gestureCtrl.createGesture({
name: GESTURE_MENU_SWIPE,
priority: 10 /* MenuSwipe */,
disableScroll: true
})
});
this.menu = menu;
}
/**
* @param {?} ev
* @return {?}
*/
MenuContentGesture.prototype.canStart = function (ev) {
var /** @type {?} */ menu = this.menu;
if (!menu.canSwipe()) {
return false;
}
if (menu.isOpen) {
return true;
}
else if (menu.getMenuController().getOpen()) {
return false;
}
return _super.prototype.canStart.call(this, ev);
};
/**
* @param {?} ev
* @return {?}
*/
MenuContentGesture.prototype.onSlideBeforeStart = function (ev) {
(void 0) /* console.debug */;
this.menu._swipeBeforeStart();
};
/**
* @return {?}
*/
MenuContentGesture.prototype.onSlideStart = function () {
(void 0) /* console.debug */;
this.menu._swipeStart();
};
/**
* @param {?} slide
* @param {?} ev
* @return {?}
*/
MenuContentGesture.prototype.onSlide = function (slide, ev) {
var /** @type {?} */ z = (this.menu.side === 'right' ? slide.min : slide.max);
var /** @type {?} */ stepValue = (slide.distance / z);
this.menu._swipeProgress(stepValue);
};
/**
* @param {?} slide
* @param {?} ev
* @return {?}
*/
MenuContentGesture.prototype.onSlideEnd = function (slide, ev) {
var /** @type {?} */ z = (this.menu.side === 'right' ? slide.min : slide.max);
var /** @type {?} */ currentStepValue = (slide.distance / z);
var /** @type {?} */ velocity = slide.velocity;
z = Math.abs(z * 0.5);
var /** @type {?} */ shouldCompleteRight = (velocity >= 0)
&& (velocity > 0.2 || slide.delta > z);
var /** @type {?} */ shouldCompleteLeft = (velocity <= 0)
&& (velocity < -0.2 || slide.delta < -z);
(void 0) /* console.debug */;
this.menu._swipeEnd(shouldCompleteLeft, shouldCompleteRight, currentStepValue, velocity);
};
/**
* @param {?} slide
* @param {?} ev
* @return {?}
*/
MenuContentGesture.prototype.getElementStartPos = function (slide, ev) {
if (this.menu.side === 'right') {
return this.menu.isOpen ? slide.min : slide.max;
}
// left menu
return this.menu.isOpen ? slide.max : slide.min;
};
/**
* @return {?}
*/
MenuContentGesture.prototype.getSlideBoundaries = function () {
if (this.menu.side === 'right') {
return {
min: -this.menu.width(),
max: 0
};
}
// left menu
return {
min: 0,
max: this.menu.width()
};
};
return MenuContentGesture;
}(SlideEdgeGesture));
function MenuContentGesture_tsickle_Closure_declarations() {
/** @type {?} */
MenuContentGesture.prototype.menu;
}
//# sourceMappingURL=menu-gestures.js.map