devextreme
Version:
HTML5 JavaScript Component Suite for Responsive Web Development
93 lines (92 loc) • 3.18 kB
JavaScript
/**
* DevExtreme (esm/events/pointer/base.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 eventsEngine from "../../events/core/events_engine";
import browser from "../../core/utils/browser";
import domAdapter from "../../core/dom_adapter";
import Class from "../../core/class";
import {
addNamespace,
eventSource,
fireEvent
} from "../utils/index";
var POINTER_EVENTS_NAMESPACE = "dxPointerEvents";
var BaseStrategy = Class.inherit({
ctor: function(eventName, originalEvents) {
this._eventName = eventName;
this._originalEvents = addNamespace(originalEvents, POINTER_EVENTS_NAMESPACE);
this._handlerCount = 0;
this.noBubble = this._isNoBubble()
},
_isNoBubble: function() {
var eventName = this._eventName;
return "dxpointerenter" === eventName || "dxpointerleave" === eventName
},
_handler: function(e) {
var delegateTarget = this._getDelegateTarget(e);
return this._fireEvent({
type: this._eventName,
pointerType: e.pointerType || eventSource(e),
originalEvent: e,
delegateTarget: delegateTarget,
timeStamp: browser.mozilla ? (new Date).getTime() : e.timeStamp
})
},
_getDelegateTarget: function(e) {
var delegateTarget;
if (this.noBubble) {
delegateTarget = e.delegateTarget
}
return delegateTarget
},
_fireEvent: function(args) {
return fireEvent(args)
},
_setSelector: function(handleObj) {
this._selector = this.noBubble && handleObj ? handleObj.selector : null
},
_getSelector: function() {
return this._selector
},
setup: function() {
return true
},
add: function(element, handleObj) {
if (this._handlerCount <= 0 || this.noBubble) {
element = this.noBubble ? element : domAdapter.getDocument();
this._setSelector(handleObj);
var that = this;
eventsEngine.on(element, this._originalEvents, this._getSelector(), (function(e) {
that._handler(e)
}))
}
if (!this.noBubble) {
this._handlerCount++
}
},
remove: function(handleObj) {
this._setSelector(handleObj);
if (!this.noBubble) {
this._handlerCount--
}
},
teardown: function(element) {
if (this._handlerCount && !this.noBubble) {
return
}
element = this.noBubble ? element : domAdapter.getDocument();
if (this._originalEvents !== "." + POINTER_EVENTS_NAMESPACE) {
eventsEngine.off(element, this._originalEvents, this._getSelector())
}
},
dispose: function(element) {
element = this.noBubble ? element : domAdapter.getDocument();
eventsEngine.off(element, this._originalEvents)
}
});
export default BaseStrategy;