var Hammer = require('./module/hammer');
|
|
|
|
/**
|
|
* Register a touch event, taking place before a gesture
|
|
* @param {Hammer} hammer A hammer instance
|
|
* @param {function} callback Callback, called as callback(event)
|
|
*/
|
|
exports.onTouch = function (hammer, callback) {
|
|
callback.inputHandler = function (event) {
|
|
if (event.isFirst && !isTouching) {
|
|
callback(event);
|
|
|
|
isTouching = true;
|
|
setTimeout(function () {
|
|
isTouching = false;
|
|
}, 0);
|
|
}
|
|
};
|
|
|
|
hammer.on('hammer.input', callback.inputHandler);
|
|
};
|
|
|
|
// isTouching is true while a touch action is being emitted
|
|
// this is a hack to prevent `touch` from being fired twice
|
|
var isTouching = false;
|
|
|
|
/**
|
|
* Register a release event, taking place after a gesture
|
|
* @param {Hammer} hammer A hammer instance
|
|
* @param {function} callback Callback, called as callback(event)
|
|
*/
|
|
exports.onRelease = function (hammer, callback) {
|
|
callback.inputHandler = function (event) {
|
|
if (event.isFinal && !isReleasing) {
|
|
callback(event);
|
|
|
|
isReleasing = true;
|
|
setTimeout(function () {
|
|
isReleasing = false;
|
|
}, 0);
|
|
}
|
|
};
|
|
|
|
return hammer.on('hammer.input', callback.inputHandler);
|
|
};
|
|
// isReleasing is true while a release action is being emitted
|
|
// this is a hack to prevent `release` from being fired twice
|
|
var isReleasing = false;
|
|
|
|
|
|
/**
|
|
* Unregister a touch event, taking place before a gesture
|
|
* @param {Hammer} hammer A hammer instance
|
|
* @param {function} callback Callback, called as callback(event)
|
|
*/
|
|
exports.offTouch = function (hammer, callback) {
|
|
hammer.off('hammer.input', callback.inputHandler);
|
|
};
|
|
|
|
/**
|
|
* Unregister a release event, taking place before a gesture
|
|
* @param {Hammer} hammer A hammer instance
|
|
* @param {function} callback Callback, called as callback(event)
|
|
*/
|
|
exports.offRelease = exports.offTouch;
|