tracker.js 9.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272
  1. /**
  2. * DevExtreme (viz/range_selector/tracker.js)
  3. * Version: 19.1.16
  4. * Build date: Tue Oct 18 2022
  5. *
  6. * Copyright (c) 2012 - 2022 Developer Express Inc. ALL RIGHTS RESERVED
  7. * Read about DevExtreme licensing here: https://js.devexpress.com/Licensing/
  8. */
  9. "use strict";
  10. Object.defineProperty(exports, "__esModule", {
  11. value: true
  12. });
  13. exports.Tracker = Tracker;
  14. var _events_engine = require("../../events/core/events_engine");
  15. var _events_engine2 = _interopRequireDefault(_events_engine);
  16. var _pointer = require("../../events/pointer");
  17. var _pointer2 = _interopRequireDefault(_pointer);
  18. var _window = require("../../core/utils/window");
  19. var _window2 = _interopRequireDefault(_window);
  20. var _dom_adapter = require("../../core/dom_adapter");
  21. var _dom_adapter2 = _interopRequireDefault(_dom_adapter);
  22. var _iterator = require("../../core/utils/iterator");
  23. var _support = require("../../core/utils/support");
  24. function _interopRequireDefault(obj) {
  25. return obj && obj.__esModule ? obj : {
  26. "default": obj
  27. }
  28. }
  29. function _defineProperty(obj, key, value) {
  30. if (key in obj) {
  31. Object.defineProperty(obj, key, {
  32. value: value,
  33. enumerable: true,
  34. configurable: true,
  35. writable: true
  36. })
  37. } else {
  38. obj[key] = value
  39. }
  40. return obj
  41. }
  42. var MIN_MANUAL_SELECTING_WIDTH = 10;
  43. var window = _window2.default.getWindow();
  44. function isLeftButtonPressed(event) {
  45. var e = event || window.event;
  46. var originalEvent = e.originalEvent;
  47. var touches = e.touches;
  48. var pointerType = originalEvent ? originalEvent.pointerType : false;
  49. var eventTouches = originalEvent ? originalEvent.touches : false;
  50. var isMSPointerLeftClick = originalEvent && void 0 !== pointerType && (pointerType === (originalEvent.MSPOINTER_TYPE_TOUCH || "touch") || pointerType === (originalEvent.MSPOINTER_TYPE_MOUSE || "mouse") && 1 === originalEvent.buttons);
  51. var isTouches = touches && touches.length > 0 || eventTouches && eventTouches.length > 0;
  52. return 1 === e.which || isMSPointerLeftClick || isTouches
  53. }
  54. function isMultiTouches(event) {
  55. var originalEvent = event.originalEvent;
  56. var touches = event.touches;
  57. var eventTouches = originalEvent && originalEvent.touches;
  58. return touches && touches.length > 1 || eventTouches && eventTouches.length > 1 || null
  59. }
  60. function preventDefault(e) {
  61. if (!isMultiTouches(e)) {
  62. e.preventDefault()
  63. }
  64. }
  65. function stopPropagationAndPreventDefault(e) {
  66. if (!isMultiTouches(e)) {
  67. e.stopPropagation();
  68. e.preventDefault()
  69. }
  70. }
  71. function isTouchEventArgs(e) {
  72. return e && e.type && 0 === e.type.indexOf("touch")
  73. }
  74. function getEventPageX(event) {
  75. var originalEvent = event.originalEvent;
  76. var result = 0;
  77. if (event.pageX) {
  78. result = event.pageX
  79. } else {
  80. if (originalEvent && originalEvent.pageX) {
  81. result = originalEvent.pageX
  82. }
  83. }
  84. if (originalEvent && originalEvent.touches) {
  85. if (originalEvent.touches.length > 0) {
  86. result = originalEvent.touches[0].pageX
  87. } else {
  88. if (originalEvent.changedTouches.length > 0) {
  89. result = originalEvent.changedTouches[0].pageX
  90. }
  91. }
  92. }
  93. return result
  94. }
  95. function initializeAreaEvents(controller, area, state, getRootOffsetLeft) {
  96. var _docEvents;
  97. var isTouchEvent;
  98. var isActive = false;
  99. var initialPosition;
  100. var movingHandler = null;
  101. var docEvents = (_docEvents = {}, _defineProperty(_docEvents, _pointer2.default.move, function(e) {
  102. var position;
  103. var offset;
  104. if (isTouchEvent !== isTouchEventArgs(e)) {
  105. return
  106. }
  107. if (!isLeftButtonPressed(e)) {
  108. cancel(e)
  109. }
  110. if (isActive) {
  111. position = getEventPageX(e);
  112. offset = getRootOffsetLeft();
  113. if (movingHandler) {
  114. movingHandler(position - offset, e)
  115. } else {
  116. if (state.manualRangeSelectionEnabled && Math.abs(initialPosition - position) >= MIN_MANUAL_SELECTING_WIDTH) {
  117. movingHandler = controller.placeSliderAndBeginMoving(initialPosition - offset, position - offset, e)
  118. }
  119. }
  120. }
  121. }), _defineProperty(_docEvents, _pointer2.default.up, function(e) {
  122. var position;
  123. if (isActive) {
  124. position = getEventPageX(e);
  125. if (!movingHandler && state.moveSelectedRangeByClick && Math.abs(initialPosition - position) < MIN_MANUAL_SELECTING_WIDTH) {
  126. controller.moveSelectedArea(position - getRootOffsetLeft(), e)
  127. }
  128. cancel(e)
  129. }
  130. }), _docEvents);
  131. function cancel(e) {
  132. if (isActive) {
  133. isActive = false;
  134. if (movingHandler) {
  135. movingHandler.complete(e);
  136. movingHandler = null
  137. }
  138. }
  139. }
  140. area.on(_pointer2.default.down, function(e) {
  141. if (!state.enabled || !isLeftButtonPressed(e) || isActive) {
  142. return
  143. }
  144. isActive = true;
  145. isTouchEvent = isTouchEventArgs(e);
  146. initialPosition = getEventPageX(e)
  147. });
  148. return docEvents
  149. }
  150. function initializeSelectedAreaEvents(controller, area, state, getRootOffsetLeft) {
  151. var _docEvents2;
  152. var isTouchEvent;
  153. var isActive = false;
  154. var movingHandler = null;
  155. var docEvents = (_docEvents2 = {}, _defineProperty(_docEvents2, _pointer2.default.move, function(e) {
  156. if (isTouchEvent !== isTouchEventArgs(e)) {
  157. return
  158. }
  159. if (!isLeftButtonPressed(e)) {
  160. cancel(e)
  161. }
  162. if (isActive) {
  163. preventDefault(e);
  164. movingHandler(getEventPageX(e) - getRootOffsetLeft(), e)
  165. }
  166. }), _defineProperty(_docEvents2, _pointer2.default.up, cancel), _docEvents2);
  167. function cancel(e) {
  168. if (isActive) {
  169. isActive = false;
  170. movingHandler.complete(e);
  171. movingHandler = null
  172. }
  173. }
  174. area.on(_pointer2.default.down, function(e) {
  175. if (!state.enabled || !isLeftButtonPressed(e) || isActive) {
  176. return
  177. }
  178. isActive = true;
  179. isTouchEvent = isTouchEventArgs(e);
  180. movingHandler = controller.beginSelectedAreaMoving(getEventPageX(e) - getRootOffsetLeft());
  181. stopPropagationAndPreventDefault(e)
  182. });
  183. return docEvents
  184. }
  185. function initializeSliderEvents(controller, sliders, state, getRootOffsetLeft) {
  186. var _docEvents3;
  187. var isTouchEvent;
  188. var isActive = false;
  189. var movingHandler = null;
  190. var docEvents = (_docEvents3 = {}, _defineProperty(_docEvents3, _pointer2.default.move, function(e) {
  191. if (isTouchEvent !== isTouchEventArgs(e)) {
  192. return
  193. }
  194. if (!isLeftButtonPressed(e)) {
  195. cancel(e)
  196. }
  197. if (isActive) {
  198. preventDefault(e);
  199. movingHandler(getEventPageX(e) - getRootOffsetLeft(), e)
  200. }
  201. }), _defineProperty(_docEvents3, _pointer2.default.up, cancel), _docEvents3);
  202. (0, _iterator.each)(sliders, function(i, slider) {
  203. var _slider$on;
  204. slider.on((_slider$on = {}, _defineProperty(_slider$on, _pointer2.default.down, function(e) {
  205. if (!state.enabled || !isLeftButtonPressed(e) || isActive) {
  206. return
  207. }
  208. isActive = true;
  209. isTouchEvent = isTouchEventArgs(e);
  210. movingHandler = controller.beginSliderMoving(i, getEventPageX(e) - getRootOffsetLeft());
  211. stopPropagationAndPreventDefault(e)
  212. }), _defineProperty(_slider$on, _pointer2.default.move, function() {
  213. if (!movingHandler) {
  214. controller.foregroundSlider(i)
  215. }
  216. }), _slider$on))
  217. });
  218. function cancel(e) {
  219. if (isActive) {
  220. isActive = false;
  221. movingHandler.complete(e);
  222. movingHandler = null
  223. }
  224. }
  225. return docEvents
  226. }
  227. function Tracker(params) {
  228. var state = this._state = {};
  229. var targets = params.controller.getTrackerTargets();
  230. if (_support.pointer) {
  231. params.renderer.root.css({
  232. msTouchAction: "pinch-zoom"
  233. })
  234. }
  235. this._docEvents = [initializeSelectedAreaEvents(params.controller, targets.selectedArea, state, getRootOffsetLeft), initializeAreaEvents(params.controller, targets.area, state, getRootOffsetLeft), initializeSliderEvents(params.controller, targets.sliders, state, getRootOffsetLeft)];
  236. (0, _iterator.each)(this._docEvents, function(_, events) {
  237. _events_engine2.default.on(_dom_adapter2.default.getDocument(), events)
  238. });
  239. function getRootOffsetLeft() {
  240. return params.renderer.getRootOffset().left
  241. }
  242. }
  243. Tracker.prototype = {
  244. constructor: Tracker,
  245. dispose: function() {
  246. (0, _iterator.each)(this._docEvents, function(_, events) {
  247. _events_engine2.default.off(_dom_adapter2.default.getDocument(), events)
  248. })
  249. },
  250. update: function(enabled, behavior) {
  251. var state = this._state;
  252. state.enabled = enabled;
  253. state.moveSelectedRangeByClick = behavior.moveSelectedRangeByClick;
  254. state.manualRangeSelectionEnabled = behavior.manualRangeSelectionEnabled
  255. }
  256. };