UNPKG

kepler.gl.geoiq

Version:

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

383 lines (323 loc) 39.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.MapPopover = void 0; 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 _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 _classnames = _interopRequireDefault(require("classnames")); var _styledComponents2 = require("../common/styled-components"); var _icons = require("../common/icons"); var _defaultSettings = require("../../constants/default-settings"); 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; } function _templateObject3() { var data = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n font-size: 12px;\n letter-spacing: 0.43px;\n text-transform: capitalize;\n padding-left: 14px;\n margin-top: 12px;\n\n svg {\n margin-right: 4px;\n }\n"]); _templateObject3 = function _templateObject3() { return data; }; return data; } function _templateObject2() { var data = (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"]); _templateObject2 = function _templateObject2() { return data; }; return data; } function _templateObject() { var data = (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"]); _templateObject = function _templateObject() { return data; }; return data; } var MAX_WIDTH = 400; var MAX_HEIGHT = 600; var StyledMapPopover = _styledComponents["default"].div(_templateObject(), 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(), function (props) { return props.theme.primaryBtnBgd; }, function (props) { return props.theme.linkBtnColor; }); var StyledLayerName = _styledComponents2.CenterFlexbox.extend(_templateObject3(), function (props) { return props.theme.textColorHl; }); var MapPopover = /*#__PURE__*/ function (_Component) { (0, _inherits2["default"])(MapPopover, _Component); function MapPopover(props) { var _this; (0, _classCallCheck2["default"])(this, MapPopover); _this = (0, _possibleConstructorReturn2["default"])(this, (0, _getPrototypeOf2["default"])(MapPopover).call(this, props)); _this.state = { isMouseOver: false, 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; if (!node) { return; } var width = Math.min(node.scrollWidth, MAX_WIDTH); var height = Math.min(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 = 30; var leftOffset = 30; var mapState = this.props.mapState; var _this$state = this.state, width = _this$state.width, height = _this$state.height; var pos = {}; if (x + leftOffset + width > mapState.width) { pos.right = mapState.width - x + leftOffset; } else { pos.left = x + leftOffset; } if (y + topOffset + height > mapState.height) { pos.bottom = 10; } else { pos.top = y + topOffset; } return pos; } }, { key: "render", value: function render() { var _this2 = this; var _this$props = this.props, x = _this$props.x, y = _this$props.y, isVisible = _this$props.isVisible, data = _this$props.data, layer = _this$props.layer, freezed = _this$props.freezed, fields = _this$props.fields, _this$props$fieldsToS = _this$props.fieldsToShow, fieldsToShow = _this$props$fieldsToS === void 0 ? [] : _this$props$fieldsToS; var hidden = !isVisible && !this.state.isMouseOver; var width = this.state.width; if (!data || !layer || !fieldsToShow.length) { return null; } var infoProps = { data: data, layer: layer, fieldsToShow: fieldsToShow, fields: fields }; var style = Number.isFinite(x) && Number.isFinite(y) ? this._getPosition(x, y) : {}; return _react["default"].createElement(StyledMapPopover, { innerRef: function innerRef(comp) { _this2.popover = comp; }, className: (0, _classnames["default"])('map-popover', { hidden: hidden }), style: _objectSpread({}, style, { maxWidth: width }), onMouseEnter: function onMouseEnter() { _this2.setState({ isMouseOver: true }); }, onMouseLeave: function onMouseLeave() { _this2.setState({ isMouseOver: false }); } }, freezed ? _react["default"].createElement("div", { className: "map-popover__top" }, _react["default"].createElement("div", { className: "gutter" }), _react["default"].createElement(StyledPin, { className: "popover-pin", onClick: this.props.onClose }, _react["default"].createElement(_icons.Pin, { height: "16px" }))) : null, _react["default"].createElement(StyledLayerName, { className: "map-popover__layer-name" }, _react["default"].createElement(_icons.Layers, { height: "12px" }), layer.config.label), _react["default"].createElement("table", { className: "map-popover__table" }, layer.isAggregated ? layer.type === 'boundary' || layer.type === 'pincode' ? _react["default"].createElement(CellInfoBoundary, infoProps) : _react["default"].createElement(CellInfo, infoProps) : _react["default"].createElement(EntryInfo, infoProps))); } }]); return MapPopover; }(_react.Component); exports.MapPopover = MapPopover; (0, _defineProperty2["default"])(MapPopover, "propTypes", { fields: _propTypes["default"].arrayOf(_propTypes["default"].any), fieldsToShow: _propTypes["default"].arrayOf(_propTypes["default"].any), isVisible: _propTypes["default"].bool, layer: _propTypes["default"].object, data: _propTypes["default"].oneOfType([_propTypes["default"].arrayOf(_propTypes["default"].any), _propTypes["default"].object]), freezed: _propTypes["default"].bool, x: _propTypes["default"].number, y: _propTypes["default"].number, onClose: _propTypes["default"].func, mapState: _propTypes["default"].object.isRequired }); var Row = function Row(_ref) { var name = _ref.name, value = _ref.value, url = _ref.url; // Set 'url' to 'value' if it looks like a url if (!url && value && typeof value === 'string' && value.match(/^http/)) { url = value; } var asImg = /<img>/.test(name); return _react["default"].createElement("tr", { className: "row", key: name }, _react["default"].createElement("td", { className: "row__name" }, name), _react["default"].createElement("td", { className: "row__value" }, asImg ? _react["default"].createElement("img", { src: value }) : url ? _react["default"].createElement("a", { target: "_blank", rel: "noopener noreferrer", href: url }, value) : value)); }; var EntryInfo = function EntryInfo(_ref2) { var fieldsToShow = _ref2.fieldsToShow, fields = _ref2.fields, data = _ref2.data; return _react["default"].createElement("tbody", null, fieldsToShow.map(function (name) { return _react["default"].createElement(EntryInfoRow, { key: name, name: name, fields: fields, data: data }); })); }; var EntryInfoRow = function EntryInfoRow(_ref3) { var name = _ref3.name, fields = _ref3.fields, data = _ref3.data; var field = fields.find(function (f) { return f.name === name; }); if (!field) { return null; } var valueIdx = field.tableFieldIndex - 1; var format = _getCellFormat(field.type); return _react["default"].createElement(Row, { name: name, value: format ? format(data[valueIdx]) : data[valueIdx] }); }; var CellInfo = function CellInfo(_ref4) { var data = _ref4.data, layer = _ref4.layer; var _layer$config = layer.config, colorField = _layer$config.colorField, sizeField = _layer$config.sizeField; return _react["default"].createElement("tbody", null, _react["default"].createElement(Row, { name: 'total points', key: "count", value: data.points && data.points.length }), colorField && layer.visualChannels.color ? _react["default"].createElement(Row, { name: layer.getVisualChannelDescription('color').measure, key: "color", value: data.colorValue || 'N/A' }) : null, sizeField && layer.visualChannels.size ? _react["default"].createElement(Row, { name: layer.getVisualChannelDescription('size').measure, key: "size", value: data.elevationValue || 'N/A' }) : null); }; var CellInfoBoundary = function CellInfoBoundary(_ref5) { var data = _ref5.data, layer = _ref5.layer; var _layer$config2 = layer.config, colorField = _layer$config2.colorField, heightField = _layer$config2.heightField; var enable3d = layer.config.visConfig.enable3d; var dataKeys = Object.keys(data.properties); dataKeys = dataKeys.filter(function (d) { if (d !== 'aggregatedData' && d !== 'count' && d !== 'values' && d != 'heightAggregatedData') { return d; } }); return _react["default"].createElement("tbody", null, _react["default"].createElement(Row, { name: 'total points', key: "count", value: data.properties.count }), colorField && layer.visualChannels.color ? _react["default"].createElement(Row, { name: layer.getVisualChannelDescription('color').measure, key: "color", value: data.properties.aggregatedData || 'N/A' }) : null, heightField && enable3d && layer.visualChannels.height ? _react["default"].createElement(Row, { name: layer.getVisualChannelDescription('height').measure, key: "height", value: data.properties.heightAggregatedData || 'N/A' }) : null, dataKeys.map(function (d) { return _react["default"].createElement(Row, { name: d, key: d, value: data.properties[d] }); })); }; function _getCellFormat(type) { return _defaultSettings.FIELD_DISPLAY_FORMAT[type]; } var MapPopoverFactory = function MapPopoverFactory() { return MapPopover; }; var _default = MapPopoverFactory; exports["default"] = _default; //# 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","StyledLayerName","CenterFlexbox","extend","MapPopover","state","isMouseOver","width","height","_setContainerSize","node","popover","Math","min","scrollWidth","scrollHeight","setState","x","y","topOffset","leftOffset","mapState","pos","right","left","bottom","top","isVisible","data","layer","freezed","fields","fieldsToShow","hidden","length","infoProps","style","Number","isFinite","_getPosition","comp","maxWidth","onClose","config","label","isAggregated","type","Component","PropTypes","arrayOf","any","bool","object","oneOfType","number","func","isRequired","Row","name","value","url","match","asImg","test","EntryInfo","map","EntryInfoRow","field","find","f","valueIdx","tableFieldIndex","format","_getCellFormat","CellInfo","colorField","sizeField","points","visualChannels","color","getVisualChannelDescription","measure","colorValue","size","elevationValue","CellInfoBoundary","heightField","enable3d","visConfig","dataKeys","Object","keys","properties","filter","d","count","aggregatedData","heightAggregatedData","FIELD_DISPLAY_FORMAT","MapPopoverFactory"],"mappings":"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","sourcesContent":["// Copyright (c) 2019 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} from 'react';\nimport styled from 'styled-components';\nimport PropTypes from 'prop-types';\nimport classnames from 'classnames';\nimport {CenterFlexbox} from 'components/common/styled-components';\nimport {Pin, Layers} from 'components/common/icons';\nimport {FIELD_DISPLAY_FORMAT} from 'constants/default-settings';\n\nconst MAX_WIDTH = 400;\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\nconst StyledLayerName = CenterFlexbox.extend`\n  color: ${props => props.theme.textColorHl};\n  font-size: 12px;\n  letter-spacing: 0.43px;\n  text-transform: capitalize;\n  padding-left: 14px;\n  margin-top: 12px;\n\n  svg {\n    margin-right: 4px;\n  }\n`;\n\nexport class MapPopover extends Component {\n  static propTypes = {\n    fields: PropTypes.arrayOf(PropTypes.any),\n    fieldsToShow: PropTypes.arrayOf(PropTypes.any),\n    isVisible: PropTypes.bool,\n    layer: PropTypes.object,\n    data: PropTypes.oneOfType([\n      PropTypes.arrayOf(PropTypes.any),\n      PropTypes.object\n    ]),\n    freezed: PropTypes.bool,\n    x: PropTypes.number,\n    y: PropTypes.number,\n    onClose: PropTypes.func,\n    mapState: PropTypes.object.isRequired\n  };\n\n  constructor(props) {\n    super(props);\n    this.state = {\n      isMouseOver: false,\n      width: 380,\n      height: 160\n    };\n  }\n\n  componentDidMount() {\n    this._setContainerSize();\n  }\n\n  componentDidUpdate() {\n    this._setContainerSize();\n  }\n\n  _setContainerSize() {\n    const node = this.popover;\n    if (!node) {\n      return;\n    }\n\n    const width = Math.min(node.scrollWidth, MAX_WIDTH);\n    const height = Math.min(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 = 30;\n    const leftOffset = 30;\n    const {mapState} = this.props;\n    const {width, height} = this.state;\n    const pos = {};\n    if (x + leftOffset + width > mapState.width) {\n      pos.right = mapState.width - x + leftOffset;\n    } else {\n      pos.left = x + leftOffset;\n    }\n\n    if (y + topOffset + height > mapState.height) {\n      pos.bottom = 10;\n    } else {\n      pos.top = y + topOffset;\n    }\n\n    return pos;\n  }\n\n  render() {\n    const {\n      x,\n      y,\n      isVisible,\n      data,\n      layer,\n      freezed,\n      fields,\n      fieldsToShow = []\n    } = this.props;\n    const hidden = !isVisible && !this.state.isMouseOver;\n    const {width} = this.state;\n\n    if (!data || !layer || !fieldsToShow.length) {\n      return null;\n    }\n\n    const infoProps = {data, layer, fieldsToShow, fields};\n\n    const style =\n      Number.isFinite(x) && Number.isFinite(y) ? this._getPosition(x, y) : {};\n\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          )}\n        </table>\n      </StyledMapPopover>\n    );\n  }\n}\n\nconst Row = ({name, value, url}) => {\n  // Set 'url' to 'value' if it looks like a url\n  if (!url && value && typeof value === 'string' && value.match(/^http/)) {\n    url = value;\n  }\n\n  const asImg = /<img>/.test(name);\n  return (\n    <tr className=\"row\" key={name}>\n      <td className=\"row__name\">{name}</td>\n      <td className=\"row__value\">\n        {asImg ? (\n          <img src={value} />\n        ) : url ? (\n          <a target=\"_blank\" rel=\"noopener noreferrer\" href={url}>\n            {value}\n          </a>\n        ) : (\n          value\n        )}\n      </td>\n    </tr>\n  );\n};\n\nconst EntryInfo = ({fieldsToShow, fields, data}) => (\n  <tbody>\n    {fieldsToShow.map(name => (\n      <EntryInfoRow key={name} name={name} fields={fields} data={data} />\n    ))}\n  </tbody>\n);\n\nconst EntryInfoRow = ({name, fields, data}) => {\n  const field = fields.find(f => f.name === name);\n  if (!field) {\n    return null;\n  }\n\n  const valueIdx = field.tableFieldIndex - 1;\n  const format = _getCellFormat(field.type);\n\n  return (\n    <Row name={name} value={format ? format(data[valueIdx]) : data[valueIdx]} />\n  );\n};\n\nconst CellInfo = ({data, layer}) => {\n  const {colorField, sizeField} = layer.config;\n\n  return (\n    <tbody>\n      <Row\n        name={'total points'}\n        key=\"count\"\n        value={data.points && data.points.length}\n      />\n      {colorField && layer.visualChannels.color ? (\n        <Row\n          name={layer.getVisualChannelDescription('color').measure}\n          key=\"color\"\n          value={data.colorValue || 'N/A'}\n        />\n      ) : null}\n      {sizeField && layer.visualChannels.size ? (\n        <Row\n          name={layer.getVisualChannelDescription('size').measure}\n          key=\"size\"\n          value={data.elevationValue || 'N/A'}\n        />\n      ) : null}\n    </tbody>\n  );\n};\n\nconst CellInfoBoundary = ({data, layer}) => {\n  const {colorField, heightField} = layer.config;\n  const {enable3d} = layer.config.visConfig;\n  var dataKeys = Object.keys(data.properties);\n  dataKeys = dataKeys.filter(d => {\n    if (\n      d !== 'aggregatedData' &&\n      d !== 'count' &&\n      d !== 'values' &&\n      d != 'heightAggregatedData'\n    ) {\n      return d;\n    }\n  });\n  return (\n    <tbody>\n      <Row name={'total points'} key=\"count\" value={data.properties.count} />\n      {/* <Row\n        name={'total points'}\n        key=\"count\"\n        value={data.properties.locality_name}\n      /> */}\n      {colorField && layer.visualChannels.color ? (\n        <Row\n          name={layer.getVisualChannelDescription('color').measure}\n          key=\"color\"\n          value={data.properties.aggregatedData || 'N/A'}\n        />\n      ) : null}\n      {heightField && enable3d && layer.visualChannels.height ? (\n        <Row\n          name={layer.getVisualChannelDescription('height').measure}\n          key=\"height\"\n          value={data.properties.heightAggregatedData || 'N/A'}\n        />\n      ) : null}\n      {dataKeys.map(d => (\n        <Row name={d} key={d} value={data.properties[d]} />\n      ))}\n    </tbody>\n  );\n};\n\nfunction _getCellFormat(type) {\n  return FIELD_DISPLAY_FORMAT[type];\n}\n\nconst MapPopoverFactory = () => MapPopover;\nexport default MapPopoverFactory;\n"]}