UNPKG

kepler.gl

Version:

kepler.gl is a webgl based application to visualize large scale location data in the browser

136 lines (109 loc) 13.4 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports["default"] = void 0; var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck")); var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass")); var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _document = _interopRequireDefault(require("global/document")); // Copyright (c) 2021 Uber Technologies, Inc. // // Permission is hereby granted, free of charge, to any person obtaining a copy // of this software and associated documentation files (the "Software"), to deal // in the Software without restriction, including without limitation the rights // to use, copy, modify, merge, publish, distribute, sublicense, and/or sell // copies of the Software, and to permit persons to whom the Software is // furnished to do so, subject to the following conditions: // // The above copyright notice and this permission notice shall be included in // all copies or substantial portions of the Software. // // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN // THE SOFTWARE. function nope() {} var MouseEventHandler = /*#__PURE__*/function () { function MouseEventHandler(_ref) { var _this = this; var _ref$vertical = _ref.vertical, vertical = _ref$vertical === void 0 ? false : _ref$vertical, _ref$valueListener = _ref.valueListener, valueListener = _ref$valueListener === void 0 ? nope : _ref$valueListener, _ref$toggleMouseOver = _ref.toggleMouseOver, toggleMouseOver = _ref$toggleMouseOver === void 0 ? nope : _ref$toggleMouseOver, track = _ref.track, _ref$setAnchor = _ref.setAnchor, setAnchor = _ref$setAnchor === void 0 ? null : _ref$setAnchor; (0, _classCallCheck2["default"])(this, MouseEventHandler); (0, _defineProperty2["default"])(this, "handleMouseDown", function (e) { _document["default"].addEventListener('mouseup', _this._mouseup); _document["default"].addEventListener('mousemove', _this._mousemove); if (_this._setAnchor) { var pos = _this._getMousePos(e); _this._setAnchor(_this._getDistanceToTrack(pos)); } _this._toggleMouseOver(); }); (0, _defineProperty2["default"])(this, "_mouseup", function () { _document["default"].removeEventListener('mouseup', _this._mouseup); _document["default"].removeEventListener('mousemove', _this._mousemove); _this._toggleMouseOver(); }); (0, _defineProperty2["default"])(this, "_mousemove", function (e) { e.preventDefault(); var pos = _this._getMousePos(e); _this._valueListener(_this._getDistanceToTrack(pos)); }); (0, _defineProperty2["default"])(this, "handleTouchStart", function (e) { // TODO: fix touch event _document["default"].addEventListener('touchend', _this._touchend); _document["default"].addEventListener('touchmove', _this._touchmove); if (_this._setAnchor) { var pos = _this._getTouchPosition(e); _this._setAnchor(_this._getDistanceToTrack(pos)); } _this._toggleMouseOver(); }); (0, _defineProperty2["default"])(this, "_touchmove", function (e) { // TODO: touch not tested var pos = _this._getTouchPosition(e); _this._valueListener(_this._getDistanceToTrack(pos)); }); (0, _defineProperty2["default"])(this, "_touchend", function () { _document["default"].removeEventListener('touchend', _this._touchend); _document["default"].removeEventListener('touchmove', _this._touchmove); _this._toggleMouseOver(); }); this._vertical = vertical; this._valueListener = valueListener; this._toggleMouseOver = toggleMouseOver; this._track = track; this._setAnchor = setAnchor; } (0, _createClass2["default"])(MouseEventHandler, [{ key: "_getMousePos", value: function _getMousePos(e) { return this._vertical ? e.clientY : e.clientX; } }, { key: "_getTouchPosition", value: function _getTouchPosition(e) { return this._vertical ? e.touches[0].clientY : e.touches[0].clientX; } }, { key: "_getDistanceToTrack", value: function _getDistanceToTrack(pos) { var trackRect = this._track.current.getBoundingClientRect(); return pos - (this._vertical ? trackRect.bottom : trackRect.left); } }]); return MouseEventHandler; }(); exports["default"] = MouseEventHandler; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/common/slider/mouse-event.js"],"names":["nope","MouseEventHandler","vertical","valueListener","toggleMouseOver","track","setAnchor","e","document","addEventListener","_mouseup","_mousemove","_setAnchor","pos","_getMousePos","_getDistanceToTrack","_toggleMouseOver","removeEventListener","preventDefault","_valueListener","_touchend","_touchmove","_getTouchPosition","_vertical","_track","clientY","clientX","touches","trackRect","current","getBoundingClientRect","bottom","left"],"mappings":"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","sourcesContent":["// Copyright (c) 2021 Uber Technologies, Inc.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n// THE SOFTWARE.\n\nimport document from 'global/document';\n\nfunction nope(...args) {}\n\nexport default class MouseEventHandler {\n  constructor({\n    vertical = false,\n    valueListener = nope,\n    toggleMouseOver = nope,\n    track,\n    setAnchor = null\n  }) {\n    this._vertical = vertical;\n    this._valueListener = valueListener;\n    this._toggleMouseOver = toggleMouseOver;\n    this._track = track;\n    this._setAnchor = setAnchor;\n  }\n\n  handleMouseDown = e => {\n    document.addEventListener('mouseup', this._mouseup);\n    document.addEventListener('mousemove', this._mousemove);\n    if (this._setAnchor) {\n      const pos = this._getMousePos(e);\n      this._setAnchor(this._getDistanceToTrack(pos));\n    }\n    this._toggleMouseOver();\n  };\n\n  _getMousePos(e) {\n    return this._vertical ? e.clientY : e.clientX;\n  }\n\n  _getTouchPosition(e) {\n    return this._vertical ? e.touches[0].clientY : e.touches[0].clientX;\n  }\n\n  _mouseup = () => {\n    document.removeEventListener('mouseup', this._mouseup);\n    document.removeEventListener('mousemove', this._mousemove);\n    this._toggleMouseOver();\n  };\n\n  _getDistanceToTrack(pos) {\n    const trackRect = this._track.current.getBoundingClientRect();\n    return pos - (this._vertical ? trackRect.bottom : trackRect.left);\n  }\n\n  _mousemove = e => {\n    e.preventDefault();\n    const pos = this._getMousePos(e);\n    this._valueListener(this._getDistanceToTrack(pos));\n  };\n\n  handleTouchStart = e => {\n    // TODO: fix touch event\n    document.addEventListener('touchend', this._touchend);\n    document.addEventListener('touchmove', this._touchmove);\n    if (this._setAnchor) {\n      const pos = this._getTouchPosition(e);\n      this._setAnchor(this._getDistanceToTrack(pos));\n    }\n    this._toggleMouseOver();\n  };\n\n  _touchmove = e => {\n    // TODO: touch not tested\n    const pos = this._getTouchPosition(e);\n    this._valueListener(this._getDistanceToTrack(pos));\n  };\n\n  _touchend = () => {\n    document.removeEventListener('touchend', this._touchend);\n    document.removeEventListener('touchmove', this._touchmove);\n    this._toggleMouseOver();\n  };\n}\n"]}