UNPKG

kepler.gl

Version:

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

319 lines (257 loc) 32.3 kB
"use strict"; var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard"); var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports["default"] = exports.getChildPos = void 0; var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck")); var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass")); var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized")); var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits")); var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn")); var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf")); var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _react = _interopRequireWildcard(require("react")); var _lodash = _interopRequireDefault(require("lodash.debounce")); var _lodash2 = _interopRequireDefault(require("lodash.isequal")); var _exenv = require("exenv"); var _styledComponents = require("styled-components"); var _context = require("../context"); var _reactModal = _interopRequireDefault(require("react-modal")); var _window = _interopRequireDefault(require("global/window")); var _base = require("../../styles/base"); function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = (0, _getPrototypeOf2["default"])(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = (0, _getPrototypeOf2["default"])(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return (0, _possibleConstructorReturn2["default"])(this, result); }; } function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } } function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2["default"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } var listeners = {}; var startListening = function startListening() { return Object.keys(listeners).forEach(function (key) { return listeners[key](); }); }; var getPageOffset = function getPageOffset() { return { x: _window["default"].pageXOffset !== undefined ? _window["default"].pageXOffset : (document.documentElement || document.body.parentNode || document.body).scrollLeft, y: _window["default"].pageYOffset !== undefined ? _window["default"].pageYOffset : (document.documentElement || document.body.parentNode || document.body).scrollTop }; }; var addEventListeners = function addEventListeners() { if (document && document.body) document.body.addEventListener('mousewheel', (0, _lodash["default"])(startListening, 100, true)); _window["default"].addEventListener('resize', (0, _lodash["default"])(startListening, 50, true)); }; var getChildPos = function getChildPos(_ref) { var offsets = _ref.offsets, rect = _ref.rect, childRect = _ref.childRect, pageOffset = _ref.pageOffset, padding = _ref.padding; var topOffset = offsets.topOffset, leftOffset = offsets.leftOffset, rightOffset = offsets.rightOffset; var anchorLeft = leftOffset !== undefined; var pos = _objectSpread({ top: pageOffset.y + rect.top + (topOffset || 0) }, anchorLeft ? { left: pageOffset.x + rect.left + leftOffset } : { right: _window["default"].innerWidth - rect.right - pageOffset.x + (rightOffset || 0) }); var leftOrRight = anchorLeft ? 'left' : 'right'; if (pos[leftOrRight] && pos[leftOrRight] < 0) { pos[leftOrRight] = padding; } else if (pos[leftOrRight] && pos[leftOrRight] + childRect.width > _window["default"].innerWidth) { pos[leftOrRight] = _window["default"].innerWidth - childRect.width - padding; } if (pos.top < 0) { pos.top = padding; } else if (pos.top + childRect.height > _window["default"].innerHeight) { pos.top = _window["default"].innerHeight - childRect.height - padding; } return pos; }; exports.getChildPos = getChildPos; if (_exenv.canUseDOM) { if (document.body) { addEventListeners(); } else { document.addEventListener('DOMContentLoaded', addEventListeners); } } var listenerIdCounter = 0; function subscribe(fn) { listenerIdCounter += 1; var id = listenerIdCounter; listeners[id] = fn; return function () { return delete listeners[id]; }; } var defaultModalStyle = { content: { top: 0, left: 0, border: 0, right: 'auto', bottom: 'auto', padding: '0px 0px 0px 0px' }, overlay: { right: 'auto', bottom: 'auto', width: '100vw', height: '100vh', backgroundColor: 'rgba(0, 0, 0, 0)' } }; var WINDOW_PAD = 40; var noop = function noop() {}; var Portaled = /*#__PURE__*/function (_Component) { (0, _inherits2["default"])(Portaled, _Component); var _super = _createSuper(Portaled); function Portaled() { var _this; (0, _classCallCheck2["default"])(this, Portaled); for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { args[_key] = arguments[_key]; } _this = _super.call.apply(_super, [this].concat(args)); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "state", { pos: null, isVisible: false }); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "element", /*#__PURE__*/(0, _react.createRef)()); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "child", /*#__PURE__*/(0, _react.createRef)()); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "handleScroll", function () { if (_this.child.current) { var rect = _this.element.current.getBoundingClientRect(); var childRect = _this.child.current && _this.child.current.getBoundingClientRect(); var pageOffset = getPageOffset(); var _this$props = _this.props, topOffset = _this$props.top, leftOffset = _this$props.left, rightOffset = _this$props.right; var pos = getChildPos({ offsets: { topOffset: topOffset, leftOffset: leftOffset, rightOffset: rightOffset }, rect: rect, childRect: childRect, pageOffset: pageOffset, padding: WINDOW_PAD }); if (!(0, _lodash2["default"])(pos, _this.state.pos)) { _this.setState({ pos: pos }); } } }); return _this; } (0, _createClass2["default"])(Portaled, [{ key: "componentDidMount", value: function componentDidMount() { // relative this.unsubscribe = subscribe(this.handleScroll); this.handleScroll(); } }, { key: "componentDidUpdate", value: function componentDidUpdate(prevProps) { var _this2 = this; var didOpen = this.props.isOpened && !prevProps.isOpened; var didClose = !this.props.isOpened && prevProps.isOpened; if (didOpen || didClose) { _window["default"].requestAnimationFrame(function () { if (_this2._unmounted) return; _this2.setState({ isVisible: didOpen }); }); } this.handleScroll(); } }, { key: "componentWillUnmount", value: function componentWillUnmount() { this._unmounted = true; // @ts-ignore this.unsubscribe(); } }, { key: "render", value: function render() { var _this3 = this; var _this$props2 = this.props, Comp = _this$props2.component, overlayZIndex = _this$props2.overlayZIndex, isOpened = _this$props2.isOpened, onClose = _this$props2.onClose, children = _this$props2.children, modalProps = _this$props2.modalProps, _this$props2$modalSty = _this$props2.modalStyle, modalStyle = _this$props2$modalSty === void 0 ? {} : _this$props2$modalSty; var _this$state = this.state, isVisible = _this$state.isVisible, pos = _this$state.pos; var newModalStyle = _objectSpread(_objectSpread({}, defaultModalStyle), {}, { content: _objectSpread({}, modalStyle.content || {}), overlay: _objectSpread(_objectSpread(_objectSpread({}, defaultModalStyle.overlay), modalStyle.overlay || {}), {}, { // needs to be on top of existing modal zIndex: overlayZIndex || 9999 }) }); return /*#__PURE__*/_react["default"].createElement(_context.RootContext.Consumer, null, function (context) { return /*#__PURE__*/_react["default"].createElement(Comp, { ref: _this3.element }, isOpened ? /*#__PURE__*/_react["default"].createElement(_reactModal["default"], (0, _extends2["default"])({ className: "modal-portal" }, modalProps, { ariaHideApp: false, isOpen: true, style: newModalStyle, parentSelector: function parentSelector() { // React modal issue: https://github.com/reactjs/react-modal/issues/769 // failed to execute removeChild on parent node when it is already unmounted return (// @ts-ignore context && context.current || { removeChild: function removeChild() {}, appendChild: function appendChild() {} } ); }, onRequestClose: onClose }), /*#__PURE__*/_react["default"].createElement("div", { className: "portaled-content", key: "item", style: _objectSpread({ position: 'fixed', opacity: isVisible ? 1 : 0, top: _this3.state.top, transition: _this3.props.theme.transition, marginTop: isVisible ? '0px' : '14px' }, pos) }, /*#__PURE__*/_react["default"].createElement("div", { ref: _this3.child, style: { position: 'absolute', zIndex: overlayZIndex ? overlayZIndex + 1 : 10000 } }, children))) : null); }); } }]); return Portaled; }(_react.Component); (0, _defineProperty2["default"])(Portaled, "defaultProps", { component: 'div', onClose: noop, theme: _base.theme }); var _default = (0, _styledComponents.withTheme)(Portaled); exports["default"] = _default; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/common/portaled.js"],"names":["listeners","startListening","Object","keys","forEach","key","getPageOffset","x","window","pageXOffset","undefined","document","documentElement","body","parentNode","scrollLeft","y","pageYOffset","scrollTop","addEventListeners","addEventListener","getChildPos","offsets","rect","childRect","pageOffset","padding","topOffset","leftOffset","rightOffset","anchorLeft","pos","top","left","right","innerWidth","leftOrRight","width","height","innerHeight","canUseDOM","listenerIdCounter","subscribe","fn","id","defaultModalStyle","content","border","bottom","overlay","backgroundColor","WINDOW_PAD","noop","Portaled","isVisible","child","current","element","getBoundingClientRect","props","state","setState","unsubscribe","handleScroll","prevProps","didOpen","isOpened","didClose","requestAnimationFrame","_unmounted","Comp","component","overlayZIndex","onClose","children","modalProps","modalStyle","newModalStyle","zIndex","context","removeChild","appendChild","position","opacity","transition","theme","marginTop","Component"],"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 React, {Component, createRef} from 'react';\nimport debounce from 'lodash.debounce';\nimport isEqual from 'lodash.isequal';\n\nimport {canUseDOM} from 'exenv';\nimport {withTheme} from 'styled-components';\nimport {RootContext} from 'components/context';\nimport Modal from 'react-modal';\nimport window from 'global/window';\nimport {theme} from 'styles/base';\n\nconst listeners = {};\n\nconst startListening = () => Object.keys(listeners).forEach(key => listeners[key]());\n\nconst getPageOffset = () => ({\n  x:\n    window.pageXOffset !== undefined\n      ? window.pageXOffset\n      : (document.documentElement || document.body.parentNode || document.body).scrollLeft,\n  y:\n    window.pageYOffset !== undefined\n      ? window.pageYOffset\n      : (document.documentElement || document.body.parentNode || document.body).scrollTop\n});\n\nconst addEventListeners = () => {\n  if (document && document.body)\n    document.body.addEventListener('mousewheel', debounce(startListening, 100, true));\n  window.addEventListener('resize', debounce(startListening, 50, true));\n};\n\nexport const getChildPos = ({offsets, rect, childRect, pageOffset, padding}) => {\n  const {topOffset, leftOffset, rightOffset} = offsets;\n\n  const anchorLeft = leftOffset !== undefined;\n  const pos = {\n    top: pageOffset.y + rect.top + (topOffset || 0),\n    ...(anchorLeft\n      ? {left: pageOffset.x + rect.left + leftOffset}\n      : {right: window.innerWidth - rect.right - pageOffset.x + (rightOffset || 0)})\n  };\n\n  const leftOrRight = anchorLeft ? 'left' : 'right';\n\n  if (pos[leftOrRight] && pos[leftOrRight] < 0) {\n    pos[leftOrRight] = padding;\n  } else if (pos[leftOrRight] && pos[leftOrRight] + childRect.width > window.innerWidth) {\n    pos[leftOrRight] = window.innerWidth - childRect.width - padding;\n  }\n\n  if (pos.top < 0) {\n    pos.top = padding;\n  } else if (pos.top + childRect.height > window.innerHeight) {\n    pos.top = window.innerHeight - childRect.height - padding;\n  }\n\n  return pos;\n};\n\nif (canUseDOM) {\n  if (document.body) {\n    addEventListeners();\n  } else {\n    document.addEventListener('DOMContentLoaded', addEventListeners);\n  }\n}\n\nlet listenerIdCounter = 0;\nfunction subscribe(fn) {\n  listenerIdCounter += 1;\n  const id = listenerIdCounter;\n  listeners[id] = fn;\n  return () => delete listeners[id];\n}\n\nconst defaultModalStyle = {\n  content: {\n    top: 0,\n    left: 0,\n    border: 0,\n    right: 'auto',\n    bottom: 'auto',\n    padding: '0px 0px 0px 0px'\n  },\n  overlay: {\n    right: 'auto',\n    bottom: 'auto',\n    width: '100vw',\n    height: '100vh',\n    backgroundColor: 'rgba(0, 0, 0, 0)'\n  }\n};\n\nconst WINDOW_PAD = 40;\n\nconst noop = () => {};\n\nclass Portaled extends Component {\n  static defaultProps = {\n    component: 'div',\n    onClose: noop,\n    theme\n  };\n\n  state = {\n    pos: null,\n    isVisible: false\n  };\n\n  componentDidMount() {\n    // relative\n    this.unsubscribe = subscribe(this.handleScroll);\n    this.handleScroll();\n  }\n\n  componentDidUpdate(prevProps) {\n    const didOpen = this.props.isOpened && !prevProps.isOpened;\n    const didClose = !this.props.isOpened && prevProps.isOpened;\n    if (didOpen || didClose) {\n      window.requestAnimationFrame(() => {\n        if (this._unmounted) return;\n        this.setState({isVisible: didOpen});\n      });\n    }\n\n    this.handleScroll();\n  }\n\n  componentWillUnmount() {\n    this._unmounted = true;\n    // @ts-ignore\n    this.unsubscribe();\n  }\n\n  element = createRef();\n  child = createRef();\n\n  // eslint-disable-next-line complexity\n  handleScroll = () => {\n    if (this.child.current) {\n      const rect = this.element.current.getBoundingClientRect();\n      const childRect = this.child.current && this.child.current.getBoundingClientRect();\n      const pageOffset = getPageOffset();\n      const {top: topOffset, left: leftOffset, right: rightOffset} = this.props;\n\n      const pos = getChildPos({\n        offsets: {topOffset, leftOffset, rightOffset},\n        rect,\n        childRect,\n        pageOffset,\n        padding: WINDOW_PAD\n      });\n\n      if (!isEqual(pos, this.state.pos)) {\n        this.setState({pos});\n      }\n    }\n  };\n\n  render() {\n    const {\n      // relative\n      component: Comp,\n      overlayZIndex,\n      isOpened,\n      onClose,\n\n      // Modal\n      children,\n      modalProps,\n      modalStyle = {}\n    } = this.props;\n\n    const {isVisible, pos} = this.state;\n\n    const newModalStyle = {\n      ...defaultModalStyle,\n      content: {\n        ...(modalStyle.content || {})\n      },\n      overlay: {\n        ...defaultModalStyle.overlay,\n        ...(modalStyle.overlay || {}),\n        // needs to be on top of existing modal\n        zIndex: overlayZIndex || 9999\n      }\n    };\n\n    return (\n      <RootContext.Consumer>\n        {context => (\n          <Comp ref={this.element}>\n            {isOpened ? (\n              <Modal\n                className=\"modal-portal\"\n                {...modalProps}\n                ariaHideApp={false}\n                isOpen\n                style={newModalStyle}\n                parentSelector={() => {\n                  // React modal issue: https://github.com/reactjs/react-modal/issues/769\n                  // failed to execute removeChild on parent node when it is already unmounted\n                  return (\n                    // @ts-ignore\n                    (context && context.current) || {\n                      removeChild: () => {},\n                      appendChild: () => {}\n                    }\n                  );\n                }}\n                onRequestClose={onClose}\n              >\n                <div\n                  className=\"portaled-content\"\n                  key=\"item\"\n                  style={{\n                    position: 'fixed',\n                    opacity: isVisible ? 1 : 0,\n                    top: this.state.top,\n                    transition: this.props.theme.transition,\n                    marginTop: isVisible ? '0px' : '14px',\n                    // @ts-ignore\n                    ...pos\n                  }}\n                >\n                  <div\n                    ref={this.child}\n                    style={{\n                      position: 'absolute',\n                      zIndex: overlayZIndex ? overlayZIndex + 1 : 10000\n                    }}\n                  >\n                    {children}\n                  </div>\n                </div>\n              </Modal>\n            ) : null}\n          </Comp>\n        )}\n      </RootContext.Consumer>\n    );\n  }\n}\n\nexport default withTheme(Portaled);\n"]}