kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
311 lines (252 loc) • 30.6 kB
JavaScript
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 _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
var _getPrototypeOf3 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized"));
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 _base = require("../../styles/base");
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);
function Portaled() {
var _getPrototypeOf2;
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 = (0, _possibleConstructorReturn2["default"])(this, (_getPrototypeOf2 = (0, _getPrototypeOf3["default"])(Portaled)).call.apply(_getPrototypeOf2, [this].concat(args)));
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "state", {
pos: null,
isVisible: false
});
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "element", (0, _react.createRef)());
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "child", (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;
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;
var _this$state = this.state,
isVisible = _this$state.isVisible,
pos = _this$state.pos;
var modalStyle = _objectSpread({}, defaultModalStyle, {
overlay: _objectSpread({}, defaultModalStyle.overlay, {
// needs to be on top of existing modal
zIndex: overlayZIndex || 9999
})
});
return _react["default"].createElement(_context.RootContext.Consumer, null, function (context) {
return _react["default"].createElement(Comp, {
ref: _this3.element
}, isOpened ? _react["default"].createElement(_reactModal["default"], (0, _extends2["default"])({
className: "modal-portal"
}, modalProps, {
ariaHideApp: false,
isOpen: true,
style: modalStyle,
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 || {
removeChild: function removeChild() {},
appendChild: function appendChild() {}
};
},
onRequestClose: onClose
}), _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)
}, _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","zIndex","context","removeChild","appendChild","position","opacity","transition","theme","marginTop","Component"],"mappings":"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","sourcesContent":["// Copyright (c) 2020 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    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      // Mordal\n      children,\n      modalProps\n    } = this.props;\n\n    const {isVisible, pos} = this.state;\n\n    const modalStyle = {\n      ...defaultModalStyle,\n      overlay: {\n        ...defaultModalStyle.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={modalStyle}\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                    (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                    ...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"]}
;