devextreme
Version:
HTML5 JavaScript Component Suite for Responsive Web Development
64 lines (63 loc) • 1.76 kB
JavaScript
/**
* DevExtreme (esm/events/hold.js)
* Version: 21.1.4
* Build date: Mon Jun 21 2021
*
* Copyright (c) 2012 - 2021 Developer Express Inc. ALL RIGHTS RESERVED
* Read about DevExtreme licensing here: https://js.devexpress.com/Licensing/
*/
import {
eventData,
eventDelta
} from "./utils/index";
import Emitter from "./core/emitter";
import registerEmitter from "./core/emitter_registrator";
var abs = Math.abs;
var HOLD_EVENT_NAME = "dxhold";
var HOLD_TIMEOUT = 750;
var TOUCH_BOUNDARY = 5;
var HoldEmitter = Emitter.inherit({
start: function(e) {
this._startEventData = 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 = eventDelta(this._startEventData, 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]
});
export default {
name: HOLD_EVENT_NAME
};