UNPKG

devextreme

Version:

HTML5 JavaScript Component Suite for Responsive Web Development

89 lines (87 loc) 3.4 kB
/** * DevExtreme (cjs/events/hover.js) * Version: 23.2.6 * Build date: Wed May 01 2024 * * Copyright (c) 2012 - 2024 Developer Express Inc. ALL RIGHTS RESERVED * Read about DevExtreme licensing here: https://js.devexpress.com/Licensing/ */ "use strict"; exports.start = exports.end = void 0; var _events_engine = _interopRequireDefault(require("../events/core/events_engine")); var _element_data = require("../core/element_data"); var _class = _interopRequireDefault(require("../core/class")); var _devices = _interopRequireDefault(require("../core/devices")); var _event_registrator = _interopRequireDefault(require("./core/event_registrator")); var _index = require("./utils/index"); var _pointer = _interopRequireDefault(require("./pointer")); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj } } const HOVERSTART_NAMESPACE = "dxHoverStart"; const HOVERSTART = "dxhoverstart"; exports.start = HOVERSTART; const POINTERENTER_NAMESPACED_EVENT_NAME = (0, _index.addNamespace)(_pointer.default.enter, "dxHoverStart"); const HOVEREND_NAMESPACE = "dxHoverEnd"; const HOVEREND = "dxhoverend"; exports.end = HOVEREND; const POINTERLEAVE_NAMESPACED_EVENT_NAME = (0, _index.addNamespace)(_pointer.default.leave, "dxHoverEnd"); const Hover = _class.default.inherit({ noBubble: true, ctor: function() { this._handlerArrayKeyPath = this._eventNamespace + "_HandlerStore" }, setup: function(element) { (0, _element_data.data)(element, this._handlerArrayKeyPath, {}) }, add: function(element, handleObj) { const that = this; const handler = function(e) { that._handler(e) }; _events_engine.default.on(element, this._originalEventName, handleObj.selector, handler); (0, _element_data.data)(element, this._handlerArrayKeyPath)[handleObj.guid] = handler }, _handler: function(e) { if ((0, _index.isTouchEvent)(e) || _devices.default.isSimulator()) { return }(0, _index.fireEvent)({ type: this._eventName, originalEvent: e, delegateTarget: e.delegateTarget }) }, remove: function(element, handleObj) { const handler = (0, _element_data.data)(element, this._handlerArrayKeyPath)[handleObj.guid]; _events_engine.default.off(element, this._originalEventName, handleObj.selector, handler) }, teardown: function(element) { (0, _element_data.removeData)(element, this._handlerArrayKeyPath) } }); const HoverStart = Hover.inherit({ ctor: function() { this._eventNamespace = "dxHoverStart"; this._eventName = HOVERSTART; this._originalEventName = POINTERENTER_NAMESPACED_EVENT_NAME; this.callBase() }, _handler: function(e) { const pointers = e.pointers || []; if (!pointers.length) { this.callBase(e) } } }); const HoverEnd = Hover.inherit({ ctor: function() { this._eventNamespace = "dxHoverEnd"; this._eventName = HOVEREND; this._originalEventName = POINTERLEAVE_NAMESPACED_EVENT_NAME; this.callBase() } }); (0, _event_registrator.default)(HOVERSTART, new HoverStart); (0, _event_registrator.default)(HOVEREND, new HoverEnd);