kepler.gl.geoiq
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
239 lines (197 loc) • 27 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _typeof = require("@babel/runtime/helpers/typeof");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = MapPopoverFactory;
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 _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
var _react = _interopRequireWildcard(require("react"));
var _styledComponents = _interopRequireDefault(require("styled-components"));
var _propTypes = _interopRequireDefault(require("prop-types"));
var _layerHoverInfo = _interopRequireDefault(require("./layer-hover-info"));
var _coordinateInfo = _interopRequireDefault(require("./coordinate-info"));
var _icons = require("../common/icons");
var _errorBoundary = _interopRequireDefault(require("../common/error-boundary"));
var _templateObject, _templateObject2;
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
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; }
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; } }
var MAX_WIDTH = 500;
var MAX_HEIGHT = 600;
var StyledMapPopover = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n ", ";\n font-size: 11px;\n font-weight: 500;\n background-color: ", ";\n color: ", ";\n z-index: 1001;\n position: absolute;\n overflow-x: auto;\n\n .gutter {\n height: 6px;\n }\n\n table {\n margin: 2px 12px 12px 12px;\n width: auto;\n\n tbody {\n border-top: transparent;\n border-bottom: transparent;\n }\n\n td {\n border-color: transparent;\n padding: 4px;\n color: ", ";\n }\n\n td.row__value {\n text-align: right;\n font-weight: 500;\n color: ", ";\n }\n }\n"])), function (props) {
return props.theme.scrollBar;
}, function (props) {
return props.theme.panelBackground;
}, function (props) {
return props.theme.textColor;
}, function (props) {
return props.theme.textColor;
}, function (props) {
return props.theme.textColorHl;
});
var StyledPin = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n position: absolute;\n left: 50%;\n transform: rotate(30deg);\n top: 10px;\n color: ", ";\n\n :hover {\n cursor: pointer;\n color: ", ";\n }\n"])), function (props) {
return props.theme.primaryBtnBgd;
}, function (props) {
return props.theme.linkBtnColor;
});
MapPopoverFactory.deps = [_layerHoverInfo["default"], _coordinateInfo["default"]];
function MapPopoverFactory(LayerHoverInfo, CoordinateInfo) {
var MapPopover = /*#__PURE__*/function (_PureComponent) {
(0, _inherits2["default"])(MapPopover, _PureComponent);
var _super = _createSuper(MapPopover);
function MapPopover(props) {
var _this;
(0, _classCallCheck2["default"])(this, MapPopover);
_this = _super.call(this, props);
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "popover", (0, _react.createRef)());
_this.state = {
width: 380,
height: 160
};
return _this;
}
(0, _createClass2["default"])(MapPopover, [{
key: "componentDidMount",
value: function componentDidMount() {
this._setContainerSize();
}
}, {
key: "componentDidUpdate",
value: function componentDidUpdate() {
this._setContainerSize();
}
}, {
key: "_setContainerSize",
value: function _setContainerSize() {
var node = this.popover.current;
if (!node) {
return;
}
var width = Math.min(Math.round(node.scrollWidth), MAX_WIDTH);
var height = Math.min(Math.round(node.scrollHeight), MAX_HEIGHT);
if (width !== this.state.width || height !== this.state.height) {
this.setState({
width: width,
height: height
});
}
}
}, {
key: "_getPosition",
value: function _getPosition(x, y) {
var topOffset = 20;
var leftOffset = 20;
var _this$props = this.props,
mapW = _this$props.mapW,
mapH = _this$props.mapH;
var _this$state = this.state,
width = _this$state.width,
height = _this$state.height;
var pos = {};
if (x + leftOffset + width > mapW) {
pos.right = mapW - x + leftOffset;
} else {
pos.left = x + leftOffset;
}
if (y + topOffset + height > mapH) {
pos.bottom = 10;
} else {
pos.top = y + topOffset;
}
return pos;
} // the commented part is from previous commits ...... incase commit below the comment does not work
// return (
// <StyledMapPopover
// innerRef={comp => {
// this.popover = comp;
// }}
// className={classnames('map-popover', {hidden})}
// style={{
// ...style,
// maxWidth: width
// }}
// onMouseEnter={() => {
// this.setState({isMouseOver: true});
// }}
// onMouseLeave={() => {
// this.setState({isMouseOver: false});
// }}
// >
// {freezed ? (
// <div className="map-popover__top">
// <div className="gutter" />
// <StyledPin className="popover-pin" onClick={this.props.onClose}>
// <Pin height="16px" />
// </StyledPin>
// </div>
// ) : null}
// <StyledLayerName className="map-popover__layer-name">
// <Layers height="12px" />
// {layer.config.label}
// </StyledLayerName>
// <table className="map-popover__table">
// {layer.isAggregated ? (
// layer.type === 'boundary' || layer.type === 'pincode' ? (
// <CellInfoBoundary {...infoProps} />
// ) : (
// <CellInfo {...infoProps} />
// )
// ) : (
// <EntryInfo {...infoProps} />
}, {
key: "render",
value: function render() {
var _this$props2 = this.props,
x = _this$props2.x,
y = _this$props2.y,
freezed = _this$props2.freezed,
coordinate = _this$props2.coordinate,
layerHoverProp = _this$props2.layerHoverProp;
var style = Number.isFinite(x) && Number.isFinite(y) ? this._getPosition(x, y) : {};
return (/*#__PURE__*/_react["default"].createElement(_errorBoundary["default"], null, /*#__PURE__*/_react["default"].createElement(StyledMapPopover, {
ref: this.popover,
className: "map-popover",
style: _objectSpread(_objectSpread({}, style), {}, {
maxWidth: MAX_WIDTH
})
}, freezed ? /*#__PURE__*/_react["default"].createElement("div", {
className: "map-popover__top"
}, /*#__PURE__*/_react["default"].createElement("div", {
className: "gutter"
}), /*#__PURE__*/_react["default"].createElement(StyledPin, {
className: "popover-pin",
onClick: this.props.onClose
}, /*#__PURE__*/_react["default"].createElement(_icons.Pin, {
height: "16px"
}))) : null, Array.isArray(coordinate) && /*#__PURE__*/_react["default"].createElement(CoordinateInfo, {
coordinate: coordinate
}), layerHoverProp ? /*#__PURE__*/_react["default"].createElement(LayerHoverInfo, layerHoverProp) : null))
);
}
}]);
return MapPopover;
}(_react.PureComponent);
(0, _defineProperty2["default"])(MapPopover, "propTypes", {
layerHoverProp: _propTypes["default"].object,
coordinate: _propTypes["default"].oneOfType([_propTypes["default"].array, _propTypes["default"].bool]),
freezed: _propTypes["default"].bool,
x: _propTypes["default"].number,
y: _propTypes["default"].number,
mapW: _propTypes["default"].number.isRequired,
mapH: _propTypes["default"].number.isRequired,
onClose: _propTypes["default"].func.isRequired
});
return MapPopover;
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/map/map-popover.js"],"names":["MAX_WIDTH","MAX_HEIGHT","StyledMapPopover","styled","div","props","theme","scrollBar","panelBackground","textColor","textColorHl","StyledPin","primaryBtnBgd","linkBtnColor","MapPopoverFactory","deps","LayerHoverInfoFactory","CoordinateInfoFactory","LayerHoverInfo","CoordinateInfo","MapPopover","state","width","height","_setContainerSize","node","popover","current","Math","min","round","scrollWidth","scrollHeight","setState","x","y","topOffset","leftOffset","mapW","mapH","pos","right","left","bottom","top","freezed","coordinate","layerHoverProp","style","Number","isFinite","_getPosition","maxWidth","onClose","Array","isArray","PureComponent","PropTypes","object","oneOfType","array","bool","number","isRequired","func"],"mappings":"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","sourcesContent":["// Copyright (c) 2023 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, {PureComponent, createRef} from 'react';\nimport styled from 'styled-components';\nimport PropTypes from 'prop-types';\nimport LayerHoverInfoFactory from './layer-hover-info';\nimport CoordinateInfoFactory from './coordinate-info';\nimport {Pin} from 'components/common/icons';\nimport ErrorBoundary from 'components/common/error-boundary';\n\nconst MAX_WIDTH = 500;\nconst MAX_HEIGHT = 600;\n\nconst StyledMapPopover = styled.div`\n  ${props => props.theme.scrollBar};\n  font-size: 11px;\n  font-weight: 500;\n  background-color: ${props => props.theme.panelBackground};\n  color: ${props => props.theme.textColor};\n  z-index: 1001;\n  position: absolute;\n  overflow-x: auto;\n\n  .gutter {\n    height: 6px;\n  }\n\n  table {\n    margin: 2px 12px 12px 12px;\n    width: auto;\n\n    tbody {\n      border-top: transparent;\n      border-bottom: transparent;\n    }\n\n    td {\n      border-color: transparent;\n      padding: 4px;\n      color: ${props => props.theme.textColor};\n    }\n\n    td.row__value {\n      text-align: right;\n      font-weight: 500;\n      color: ${props => props.theme.textColorHl};\n    }\n  }\n`;\n\nconst StyledPin = styled.div`\n  position: absolute;\n  left: 50%;\n  transform: rotate(30deg);\n  top: 10px;\n  color: ${props => props.theme.primaryBtnBgd};\n\n  :hover {\n    cursor: pointer;\n    color: ${props => props.theme.linkBtnColor};\n  }\n`;\n\nMapPopoverFactory.deps = [LayerHoverInfoFactory, CoordinateInfoFactory];\n\nexport default function MapPopoverFactory(LayerHoverInfo, CoordinateInfo) {\n  class MapPopover extends PureComponent {\n    static propTypes = {\n      layerHoverProp: PropTypes.object,\n      coordinate: PropTypes.oneOfType([PropTypes.array, PropTypes.bool]),\n      freezed: PropTypes.bool,\n      x: PropTypes.number,\n      y: PropTypes.number,\n      mapW: PropTypes.number.isRequired,\n      mapH: PropTypes.number.isRequired,\n      onClose: PropTypes.func.isRequired\n    };\n\n    constructor(props) {\n      super(props);\n      this.state = {\n        width: 380,\n        height: 160\n      };\n    }\n\n    componentDidMount() {\n      this._setContainerSize();\n    }\n\n    componentDidUpdate() {\n      this._setContainerSize();\n    }\n\n    popover = createRef();\n\n    _setContainerSize() {\n      const node = this.popover.current;\n      if (!node) {\n        return;\n      }\n\n      const width = Math.min(Math.round(node.scrollWidth), MAX_WIDTH);\n      const height = Math.min(Math.round(node.scrollHeight), MAX_HEIGHT);\n\n      if (width !== this.state.width || height !== this.state.height) {\n        this.setState({width, height});\n      }\n    }\n\n    _getPosition(x, y) {\n      const topOffset = 20;\n      const leftOffset = 20;\n      const {mapW, mapH} = this.props;\n      const {width, height} = this.state;\n      const pos = {};\n      if (x + leftOffset + width > mapW) {\n        pos.right = mapW - x + leftOffset;\n      } else {\n        pos.left = x + leftOffset;\n      }\n\n      if (y + topOffset + height > mapH) {\n        pos.bottom = 10;\n      } else {\n        pos.top = y + topOffset;\n      }\n\n      return pos;\n    }\n    // the commented part is from previous commits ...... incase commit below the comment does not work\n    // return (\n    //   <StyledMapPopover\n    //     innerRef={comp => {\n    //       this.popover = comp;\n    //     }}\n    //     className={classnames('map-popover', {hidden})}\n    //     style={{\n    //       ...style,\n    //       maxWidth: width\n    //     }}\n    //     onMouseEnter={() => {\n    //       this.setState({isMouseOver: true});\n    //     }}\n    //     onMouseLeave={() => {\n    //       this.setState({isMouseOver: false});\n    //     }}\n    //   >\n    //     {freezed ? (\n    //       <div className=\"map-popover__top\">\n    //         <div className=\"gutter\" />\n    //         <StyledPin className=\"popover-pin\" onClick={this.props.onClose}>\n    //           <Pin height=\"16px\" />\n    //         </StyledPin>\n    //       </div>\n    //     ) : null}\n    //     <StyledLayerName className=\"map-popover__layer-name\">\n    //       <Layers height=\"12px\" />\n    //       {layer.config.label}\n    //     </StyledLayerName>\n    //     <table className=\"map-popover__table\">\n    //       {layer.isAggregated ? (\n    //         layer.type === 'boundary' || layer.type === 'pincode' ? (\n    //           <CellInfoBoundary {...infoProps} />\n    //         ) : (\n    //           <CellInfo {...infoProps} />\n    //         )\n    //       ) : (\n    //         <EntryInfo {...infoProps} />\n    render() {\n      const {x, y, freezed, coordinate, layerHoverProp} = this.props;\n\n      const style =\n        Number.isFinite(x) && Number.isFinite(y) ? this._getPosition(x, y) : {};\n\n      return (\n        <ErrorBoundary>\n          <StyledMapPopover\n            ref={this.popover}\n            className=\"map-popover\"\n            style={{\n              ...style,\n              maxWidth: MAX_WIDTH\n            }}\n          >\n            {freezed ? (\n              <div className=\"map-popover__top\">\n                <div className=\"gutter\" />\n                <StyledPin className=\"popover-pin\" onClick={this.props.onClose}>\n                  <Pin height=\"16px\" />\n                </StyledPin>\n              </div>\n            ) : null}\n            {Array.isArray(coordinate) && (\n              <CoordinateInfo coordinate={coordinate} />\n            )}\n            {layerHoverProp ? <LayerHoverInfo {...layerHoverProp} /> : null}\n          </StyledMapPopover>\n        </ErrorBoundary>\n      );\n    }\n  }\n\n  return MapPopover;\n}\n"]}