UNPKG

devextreme

Version:

HTML5 JavaScript Component Suite for Responsive Web Development

100 lines (98 loc) 3.69 kB
/** * DevExtreme (cjs/__internal/events/pointer/m_base.js) * Version: 24.2.6 * Build date: Mon Mar 17 2025 * * Copyright (c) 2012 - 2025 Developer Express Inc. ALL RIGHTS RESERVED * Read about DevExtreme licensing here: https://js.devexpress.com/Licensing/ */ "use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _events_engine = _interopRequireDefault(require("../../../common/core/events/core/events_engine")); var _event_target = require("../../../common/core/events/utils/event_target"); var _index = require("../../../common/core/events/utils/index"); var _class = _interopRequireDefault(require("../../../core/class")); var _dom_adapter = _interopRequireDefault(require("../../../core/dom_adapter")); var _browser = _interopRequireDefault(require("../../../core/utils/browser")); function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e } } const POINTER_EVENTS_NAMESPACE = "dxPointerEvents"; const BaseStrategy = _class.default.inherit({ ctor(eventName, originalEvents) { this._eventName = eventName; this._originalEvents = (0, _index.addNamespace)(originalEvents, "dxPointerEvents"); this._handlerCount = 0; this.noBubble = this._isNoBubble() }, _isNoBubble() { const eventName = this._eventName; return "dxpointerenter" === eventName || "dxpointerleave" === eventName }, _handler(e) { const delegateTarget = this._getDelegateTarget(e); const event = { type: this._eventName, pointerType: e.pointerType || (0, _index.eventSource)(e), originalEvent: e, delegateTarget: delegateTarget, timeStamp: _browser.default.mozilla ? (new Date).getTime() : e.timeStamp }; const target = (0, _event_target.getEventTarget)(e); event.target = target; return this._fireEvent(event) }, _getDelegateTarget(e) { let delegateTarget; if (this.noBubble) { delegateTarget = e.delegateTarget } return delegateTarget }, _fireEvent: args => (0, _index.fireEvent)(args), _setSelector(handleObj) { this._selector = this.noBubble && handleObj ? handleObj.selector : null }, _getSelector() { return this._selector }, setup: () => true, add(element, handleObj) { if (this._handlerCount <= 0 || this.noBubble) { element = this.noBubble ? element : _dom_adapter.default.getDocument(); this._setSelector(handleObj); const that = this; _events_engine.default.on(element, this._originalEvents, this._getSelector(), (e => { that._handler(e) })) } if (!this.noBubble) { this._handlerCount++ } }, remove(handleObj) { this._setSelector(handleObj); if (!this.noBubble) { this._handlerCount-- } }, teardown(element) { if (this._handlerCount && !this.noBubble) { return } element = this.noBubble ? element : _dom_adapter.default.getDocument(); if (".dxPointerEvents" !== this._originalEvents) { _events_engine.default.off(element, this._originalEvents, this._getSelector()) } }, dispose(element) { element = this.noBubble ? element : _dom_adapter.default.getDocument(); _events_engine.default.off(element, this._originalEvents) } }); var _default = exports.default = BaseStrategy;