UNPKG

kepler.gl

Version:

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

107 lines (106 loc) 15.5 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); var _typeof = require("@babel/runtime/helpers/typeof"); Object.defineProperty(exports, "__esModule", { value: true }); exports["default"] = void 0; var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties")); var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck")); var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass")); var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn")); var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf")); var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits")); var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _react = _interopRequireWildcard(require("react")); var _reactVirtualized = require("react-virtualized"); var _lodash = _interopRequireDefault(require("lodash.isequal")); var _excluded = ["setGridRef"]; function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); } function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; } function _callSuper(t, o, e) { return o = (0, _getPrototypeOf2["default"])(o), (0, _possibleConstructorReturn2["default"])(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], (0, _getPrototypeOf2["default"])(t).constructor) : o.apply(t, e)); } function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); } // SPDX-License-Identifier: MIT // Copyright contributors to the kepler.gl project var GridHack = exports["default"] = /*#__PURE__*/function (_PureComponent) { function GridHack() { var _this; (0, _classCallCheck2["default"])(this, GridHack); for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { args[_key] = arguments[_key]; } _this = _callSuper(this, GridHack, [].concat(args)); (0, _defineProperty2["default"])(_this, "grid", null); (0, _defineProperty2["default"])(_this, "_preventScrollBack", function (e) { var scrollLeft = _this.props.scrollLeft; if (scrollLeft !== undefined && scrollLeft <= 0 && e.deltaX < 0) { // Prevent Scroll On Scrollable Elements, avoid browser backward navigation // https://alvarotrigo.com/blog/prevent-scroll-on-scrollable-element-js/ e.preventDefault(); e.stopPropagation(); return false; } return; }); (0, _defineProperty2["default"])(_this, "_updateRef", function (x) { if (!_this.grid && x) { var _this$grid; _this.grid = x; /* * This hack exists because we need to add wheel event listener to the div rendered by Grid * */ // @ts-expect-error _scrollingContainer not typed in Grid (_this$grid = _this.grid) === null || _this$grid === void 0 || (_this$grid = _this$grid._scrollingContainer) === null || _this$grid === void 0 || _this$grid.addEventListener('wheel', _this._preventScrollBack, { passive: false }); } }); return _this; } (0, _inherits2["default"])(GridHack, _PureComponent); return (0, _createClass2["default"])(GridHack, [{ key: "componentDidUpdate", value: function componentDidUpdate(preProps) { /* * This hack exists because in react-virtualized the * _columnWidthGetter is only called in the constructor * even though it is reassigned with new props resulting in * a new width for cells not being calculated so we must * force trigger a resize. * * https://github.com/bvaughn/react-virtualized/blob/master/source/Grid/Grid.js#L322 * */ if (!(0, _lodash["default"])(preProps.cellSizeCache, this.props.cellSizeCache)) { var _this$grid2; (_this$grid2 = this.grid) === null || _this$grid2 === void 0 || _this$grid2.recomputeGridSize(); } } }, { key: "componentWillUnmount", value: function componentWillUnmount() { var _this$grid3; // @ts-expect-error _scrollingContainer not typed in Grid (_this$grid3 = this.grid) === null || _this$grid3 === void 0 || (_this$grid3 = _this$grid3._scrollingContainer) === null || _this$grid3 === void 0 || _this$grid3.removeEventListener('wheel', this._preventScrollBack, { passive: false }); } }, { key: "render", value: function render() { var _this2 = this; var _this$props = this.props, setGridRef = _this$props.setGridRef, rest = (0, _objectWithoutProperties2["default"])(_this$props, _excluded); return /*#__PURE__*/_react["default"].createElement(_reactVirtualized.Grid, (0, _extends2["default"])({ ref: function ref(x) { if (setGridRef) setGridRef(x); _this2._updateRef(x); }, key: "grid-hack" }, rest)); } }]); }(_react.PureComponent); //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_reactVirtualized","_lodash","_interopRequireDefault","_excluded","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","_callSuper","o","_getPrototypeOf2","_possibleConstructorReturn2","_isNativeReflectConstruct","Reflect","construct","constructor","apply","Boolean","prototype","valueOf","GridHack","exports","_PureComponent","_this","_classCallCheck2","_len","arguments","length","args","Array","_key","concat","_defineProperty2","scrollLeft","props","undefined","deltaX","preventDefault","stopPropagation","x","grid","_this$grid","_scrollingContainer","addEventListener","_preventScrollBack","passive","_inherits2","_createClass2","key","value","componentDidUpdate","preProps","isEqual","cellSizeCache","_this$grid2","recomputeGridSize","componentWillUnmount","_this$grid3","removeEventListener","render","_this2","_this$props","setGridRef","rest","_objectWithoutProperties2","createElement","Grid","_extends2","ref","_updateRef","PureComponent"],"sources":["../../../src/common/data-table/grid.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React, {PureComponent} from 'react';\nimport {Grid, GridProps} from 'react-virtualized';\nimport isEqual from 'lodash.isequal';\n\nexport default class GridHack extends PureComponent<GridProps> {\n  grid: Grid | null = null;\n\n  componentDidUpdate(preProps) {\n    /*\n     * This hack exists because in react-virtualized the\n     * _columnWidthGetter is only called in the constructor\n     * even though it is reassigned with new props resulting in\n     * a new width for cells not being calculated so we must\n     * force trigger a resize.\n     *\n     * https://github.com/bvaughn/react-virtualized/blob/master/source/Grid/Grid.js#L322\n     *\n     */\n    if (!isEqual(preProps.cellSizeCache, this.props.cellSizeCache)) {\n      this.grid?.recomputeGridSize();\n    }\n  }\n\n  componentWillUnmount() {\n    // @ts-expect-error _scrollingContainer not typed in Grid\n    this.grid?._scrollingContainer?.removeEventListener('wheel', this._preventScrollBack, {\n      passive: false\n    });\n  }\n\n  _preventScrollBack = e => {\n    const {scrollLeft} = this.props;\n    if (scrollLeft !== undefined && scrollLeft <= 0 && e.deltaX < 0) {\n      // Prevent Scroll On Scrollable Elements, avoid browser backward navigation\n      // https://alvarotrigo.com/blog/prevent-scroll-on-scrollable-element-js/\n      e.preventDefault();\n      e.stopPropagation();\n      return false;\n    }\n    return;\n  };\n\n  _updateRef = x => {\n    if (!this.grid && x) {\n      this.grid = x;\n      /*\n       * This hack exists because we need to add wheel event listener to the div rendered by Grid\n       *\n       */\n      // @ts-expect-error _scrollingContainer not typed in Grid\n      this.grid?._scrollingContainer?.addEventListener('wheel', this._preventScrollBack, {\n        passive: false\n      });\n    }\n  };\n\n  render() {\n    const {setGridRef, ...rest} = this.props;\n    return (\n      <Grid\n        ref={x => {\n          if (setGridRef) setGridRef(x);\n          this._updateRef(x);\n        }}\n        key=\"grid-hack\"\n        {...rest}\n      />\n    );\n  }\n}\n"],"mappings":"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","ignoreList":[]}