UNPKG

kepler.gl

Version:

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

288 lines (286 loc) 41.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.getChildPos = exports["default"] = 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 _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 _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 _styles = require("@kepler.gl/styles"); 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; })(); } function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; } function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty2["default"])(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } // SPDX-License-Identifier: MIT // Copyright contributors to the kepler.gl project 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, { leading: true })); _window["default"].addEventListener('resize', (0, _lodash["default"])(startListening, 50, { leading: true })); }; var getChildPos = exports.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 || 0) } : { 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; }; 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() { return; }; var DefaultComponent = 'div'; var Portaled = /*#__PURE__*/function (_Component) { 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 = _callSuper(this, Portaled, [].concat(args)); (0, _defineProperty2["default"])(_this, "state", { pos: null, isVisible: false }); (0, _defineProperty2["default"])(_this, "unsubscribe", undefined); (0, _defineProperty2["default"])(_this, "_unmounted", false); (0, _defineProperty2["default"])(_this, "element", /*#__PURE__*/(0, _react.createRef)()); (0, _defineProperty2["default"])(_this, "child", /*#__PURE__*/(0, _react.createRef)()); // eslint-disable-next-line complexity (0, _defineProperty2["default"])(_this, "handleScroll", function () { if (_this.child.current && _this.element.current) { var rect = _this.element.current.getBoundingClientRect(); var childRect = _this.child.current.getBoundingClientRect(); var pageOffset = getPageOffset(); var _this$props = _this.props, topOffset = _this$props.top, _this$props$left = _this$props.left, leftOffset = _this$props$left === void 0 ? 0 : _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, _inherits2["default"])(Portaled, _Component); return (0, _createClass2["default"])(Portaled, [{ key: "componentDidMount", value: function componentDidMount() { this._unmounted = false; // 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: Boolean(didOpen) }); }); } this.handleScroll(); } // ColorPicker will throw a cross-origin error when it is closed // when the app is within an iframe. // This is a known issue of react-color component: // see: https://github.com/casesandberg/react-color/issues/806 }, { key: "componentDidCatch", value: function componentDidCatch() { // Do nothing here, since React will try to recreate this component // tree from scratch using the error boundary, which is this component // itself. This is a temporal fix for a crash. } }, { 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, _this$props2$componen = _this$props2.component, component = _this$props2$componen === void 0 ? DefaultComponent : _this$props2$componen, 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 }) }); var Comp = component; 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 context && context.current || document.body; }, onRequestClose: onClose }), /*#__PURE__*/_react["default"].createElement("div", { className: "portaled-content", key: "item", style: _objectSpread({ position: 'fixed', opacity: isVisible ? 1 : 0, transition: _this3.props.theme.transitionFast, marginTop: isVisible ? '0px' : '14px' }, pos) }, /*#__PURE__*/_react["default"].createElement("div", { ref: _this3.child, style: { position: 'absolute', zIndex: overlayZIndex ? overlayZIndex + 1 : 10000 } }, children))) : null); }); } }], [{ key: "getDerivedStateFromError", value: // Make Portaled a component with Error Boundary, so React can recreate // this component if the child 'ColorPicker' throws cross-origin error. // see function componentDidCatch() function getDerivedStateFromError() { return { hasError: true }; } }]); }(_react.Component); (0, _defineProperty2["default"])(Portaled, "defaultProps", { component: DefaultComponent, onClose: noop, theme: _styles.theme }); var _default = exports["default"] = (0, _styledComponents.withTheme)(Portaled); //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_lodash","_interopRequireDefault","_lodash2","_exenv","_styledComponents","_context","_reactModal","_window","_styles","_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","ownKeys","keys","getOwnPropertySymbols","filter","enumerable","push","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","listeners","startListening","key","getPageOffset","x","Window","pageXOffset","undefined","document","documentElement","body","parentNode","scrollLeft","y","pageYOffset","scrollTop","addEventListeners","addEventListener","debounce","leading","getChildPos","exports","_ref","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","DefaultComponent","Portaled","_Component","_this","_classCallCheck2","_len","args","Array","_key","concat","isVisible","createRef","child","current","element","getBoundingClientRect","_this$props","props","_this$props$left","isEqual","state","setState","_inherits2","_createClass2","value","componentDidMount","_unmounted","unsubscribe","handleScroll","componentDidUpdate","prevProps","_this2","didOpen","isOpened","didClose","requestAnimationFrame","componentDidCatch","componentWillUnmount","render","_this3","_this$props2","_this$props2$componen","component","overlayZIndex","onClose","children","modalProps","_this$props2$modalSty","modalStyle","_this$state","newModalStyle","zIndex","Comp","createElement","RootContext","Consumer","context","ref","_extends2","className","ariaHideApp","isOpen","style","parentSelector","onRequestClose","position","opacity","transition","theme","transitionFast","marginTop","getDerivedStateFromError","hasError","Component","_default","withTheme"],"sources":["../../src/common/portaled.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React, {Component, createRef, PropsWithChildren} 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 '../context';\nimport Modal from 'react-modal';\nimport Window from 'global/window';\nimport {theme} from '@kepler.gl/styles';\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, {leading: true}));\n  Window.addEventListener('resize', debounce(startListening, 50, {leading: true}));\n};\n\ninterface GetChildPosProps {\n  offsets: Partial<{\n    topOffset: number;\n    leftOffset: number;\n    rightOffset: number;\n  }>;\n  rect: DOMRect;\n  childRect: DOMRect;\n  pageOffset: {\n    x: number;\n    y: number;\n  };\n  padding: number;\n}\n\nexport const getChildPos = ({offsets, rect, childRect, pageOffset, padding}: GetChildPosProps) => {\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 || 0)}\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  return;\n};\n\ntype PortaledProps = PropsWithChildren<{\n  right?: number;\n  left?: number;\n  top?: number;\n  component?: React.ElementType<any>;\n  onClose?: (\n    event: React.MouseEvent<Element, globalThis.MouseEvent> | React.KeyboardEvent<Element>\n  ) => void;\n  topOffset?: number;\n  leftOffset?: number;\n  rightOffset?: number;\n  overlayZIndex?: number;\n  isOpened?: boolean;\n  modalProps?: Partial<ReactModal.Props>;\n  modalStyle?: Partial<typeof defaultModalStyle>;\n  theme?: any;\n}>;\n\ninterface PortaledState {\n  pos:\n    | {\n        left: number;\n        top: number;\n      }\n    | {\n        right: number;\n        top: number;\n      }\n    | null;\n  isVisible: boolean;\n}\n\nconst DefaultComponent = 'div';\n\nclass Portaled extends Component<PortaledProps, PortaledState> {\n  // Make Portaled a component with Error Boundary, so React can recreate\n  // this component if the child 'ColorPicker' throws cross-origin error.\n  // see function componentDidCatch()\n  static getDerivedStateFromError(): {hasError: boolean} {\n    return {hasError: true};\n  }\n\n  static defaultProps: PortaledProps = {\n    component: DefaultComponent,\n    onClose: noop,\n    theme\n  };\n\n  state = {\n    pos: null,\n    isVisible: false\n  };\n\n  unsubscribe: (() => boolean) | undefined = undefined;\n  _unmounted = false;\n\n  componentDidMount() {\n    this._unmounted = false;\n    // relative\n    this.unsubscribe = subscribe(this.handleScroll);\n    this.handleScroll();\n  }\n\n  componentDidUpdate(prevProps: PortaledProps) {\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: Boolean(didOpen)});\n      });\n    }\n\n    this.handleScroll();\n  }\n\n  // ColorPicker will throw a cross-origin error when it is closed\n  // when the app is within an iframe.\n  // This is a known issue of react-color component:\n  // see: https://github.com/casesandberg/react-color/issues/806\n  componentDidCatch() {\n    // Do nothing here, since React will try to recreate this component\n    // tree from scratch using the error boundary, which is this component\n    // itself. This is a temporal fix for a crash.\n  }\n\n  componentWillUnmount() {\n    this._unmounted = true;\n    // @ts-ignore\n    this.unsubscribe();\n  }\n\n  element = createRef<HTMLDivElement>();\n  child = createRef<HTMLDivElement>();\n\n  // eslint-disable-next-line complexity\n  handleScroll = () => {\n    if (this.child.current && this.element.current) {\n      const rect = this.element.current.getBoundingClientRect();\n      const childRect = this.child.current.getBoundingClientRect();\n      const pageOffset = getPageOffset();\n      const {top: topOffset, left: leftOffset = 0, 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(): JSX.Element {\n    const {\n      // relative\n      component = DefaultComponent,\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    const Comp = component;\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 (context && context.current) || document.body;\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                    transition: this.props.theme.transitionFast,\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"],"mappings":"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","ignoreList":[]}