devextreme
Version:
HTML5 JavaScript Component Suite for Responsive Web Development
62 lines (61 loc) • 1.78 kB
JavaScript
/**
* DevExtreme (events/hold.js)
* Version: 18.1.3
* Build date: Tue May 15 2018
*
* Copyright (c) 2012 - 2018 Developer Express Inc. ALL RIGHTS RESERVED
* Read about DevExtreme licensing here: https://js.devexpress.com/Licensing/
*/
;
var eventUtils = require("./utils"),
Emitter = require("./core/emitter"),
registerEmitter = require("./core/emitter_registrator"),
abs = Math.abs;
var HOLD_EVENT_NAME = "dxhold",
HOLD_TIMEOUT = 750,
TOUCH_BOUNDARY = 5;
var HoldEmitter = Emitter.inherit({
start: function(e) {
this._startEventData = eventUtils.eventData(e);
this._startTimer(e)
},
_startTimer: function(e) {
var holdTimeout = "timeout" in this ? this.timeout : HOLD_TIMEOUT;
this._holdTimer = setTimeout(function() {
this._requestAccept(e);
this._fireEvent(HOLD_EVENT_NAME, e, {
target: e.target
});
this._forgetAccept()
}.bind(this), holdTimeout)
},
move: function(e) {
if (this._touchWasMoved(e)) {
this._cancel(e)
}
},
_touchWasMoved: function(e) {
var delta = eventUtils.eventDelta(this._startEventData, eventUtils.eventData(e));
return abs(delta.x) > TOUCH_BOUNDARY || abs(delta.y) > TOUCH_BOUNDARY
},
end: function() {
this._stopTimer()
},
_stopTimer: function() {
clearTimeout(this._holdTimer)
},
cancel: function() {
this._stopTimer()
},
dispose: function() {
this._stopTimer()
}
});
registerEmitter({
emitter: HoldEmitter,
bubble: true,
events: [HOLD_EVENT_NAME]
});
module.exports = {
name: HOLD_EVENT_NAME
};