kepler.gl.geoiq
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
366 lines (310 loc) • 41.7 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _typeof = require("@babel/runtime/helpers/typeof");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.StyledLayerName = void 0;
exports["default"] = LayerHoverInfoFactory;
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
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 _styledComponents2 = require("../common/styled-components");
var _icons = require("../common/icons");
var _propTypes = _interopRequireDefault(require("prop-types"));
var _dataUtils = require("../../utils/data-utils");
var _axios = _interopRequireDefault(require("axios"));
var _defaultSettings = require("../../constants/default-settings");
var _templateObject;
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 StyledLayerName = exports.StyledLayerName = (0, _styledComponents["default"])(_styledComponents2.CenterFlexbox)(_templateObject || (_templateObject = (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"])), function (props) {
return props.theme.textColorHl;
});
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 (/*#__PURE__*/_react["default"].createElement("tr", {
className: "row",
key: name
}, /*#__PURE__*/_react["default"].createElement("td", {
className: "row__name"
}, name), /*#__PURE__*/_react["default"].createElement("td", {
className: "row__value"
}, asImg ? /*#__PURE__*/_react["default"].createElement("img", {
src: value
}) : url ? /*#__PURE__*/_react["default"].createElement("a", {
target: "_blank",
rel: "noopener noreferrer",
href: url
}, value) : value))
);
};
var EntryInfo = function EntryInfo(_ref2) {
var _ref2$fieldsToShow = _ref2.fieldsToShow,
fieldsToShow = _ref2$fieldsToShow === void 0 ? [] : _ref2$fieldsToShow,
fields = _ref2.fields,
data = _ref2.data;
// const {properties} = data;
// console.log(
// 'properties,fieldsTOshow , fields and data inside EntryInfo ',
// properties,
// fieldsToShow,
// fields,
// data
// );
return (/*#__PURE__*/_react["default"].createElement("tbody", null, fieldsToShow.map(function (name) {
return (/*#__PURE__*/_react["default"].createElement(EntryInfoRow, {
key: name,
name: name,
fields: fields,
data: Array.isArray(data) ? data : data.properties[name]
})
);
}))
);
};
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;
}
if (Array.isArray(data)) {
var valueIdx = field.tableFieldIndex - 1;
var displayValue = (0, _dataUtils.parseFieldValue)(data[valueIdx], field.type);
return (/*#__PURE__*/_react["default"].createElement(Row, {
name: name,
value: displayValue
})
);
} else {
var _displayValue = data;
return (/*#__PURE__*/_react["default"].createElement(Row, {
name: name,
value: _displayValue
})
);
}
};
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,
heightField = _layer$config.heightField,
visConfig = _layer$config.visConfig;
var properties = data.properties;
var colorAggregation = visConfig.colorAggregation; // console.log(
// 'properties, data, colorField and sizeField inside cellInfo',
// data,
// properties,
// colorField,
// sizeField
// );
return (/*#__PURE__*/_react["default"].createElement("tbody", null, properties && properties.name ? /*#__PURE__*/_react["default"].createElement(Row, {
name: 'name',
key: "name",
value: properties.name
}) : null, /*#__PURE__*/_react["default"].createElement(Row, {
name: 'total points',
key: "count",
value: properties ? properties.totalCount : data.points && data.points.length
}), colorField && layer.visualChannels.color ? /*#__PURE__*/_react["default"].createElement(Row, {
name: layer.getVisualChannelDescription('color').measure,
key: "color",
value: properties ? properties.aggregatedData : data.colorValue || 'N/A'
}) : null, sizeField && layer.visualChannels.size ? /*#__PURE__*/_react["default"].createElement(Row, {
name: layer.getVisualChannelDescription('size').measure,
key: "size",
value: properties ? properties.heightAggregatedData : data.elevationValue || 'N/A'
}) : null, heightField && layer.visualChannels.height ? /*#__PURE__*/_react["default"].createElement(Row, {
name: layer.getVisualChannelDescription('height').measure,
key: "size",
value: properties ? properties.heightAggregatedData : data.elevationValue || 'N/A'
}) : null)
);
};
function LayerHoverInfoFactory() {
var LayerHoverInfo = /*#__PURE__*/function (_Component) {
(0, _inherits2["default"])(LayerHoverInfo, _Component);
var _super = _createSuper(LayerHoverInfo);
function LayerHoverInfo(props) {
var _this;
(0, _classCallCheck2["default"])(this, LayerHoverInfo);
_this = _super.call(this, props);
_this.state = {
fieldsToShow: [],
fields: {},
data: {}
};
return _this;
} // state = {
// fieldsToShow: [],
// fields: {},
// data: {}
// };
(0, _createClass2["default"])(LayerHoverInfo, [{
key: "componentWillReceiveProps",
value: function componentWillReceiveProps(nextProps) {
var _this2 = this;
var _this$props = this.props,
data = _this$props.data,
layer = _this$props.layer,
fields = _this$props.fields,
fieldsToShow = _this$props.fieldsToShow,
datasets = _this$props.datasets,
auth = _this$props.auth;
if (layer.type === 'backendPoint' || layer.type === 'backendGeojson' || layer.type === 'geojson') {
if (nextProps.data.docId !== data.docId) {
var uid = auth.uid;
var _datasets$layer$confi2 = datasets[layer.config.dataId],
indexName = _datasets$layer$confi2.indexName,
_fields = _datasets$layer$confi2.fields;
var layerHoverApiData = {
docId: nextProps.data.docId,
fieldsToShow: JSON.stringify(fieldsToShow),
userId: uid,
indexName: indexName
};
var config = {
headers: {
'Content-Type': 'application/json'
}
};
_axios["default"].post("".concat(_defaultSettings.ON_PREMESIS_URL, "/geoiqutilities/hover/v1.0/fetch"), layerHoverApiData, config).then(function (response) {
return _this2.setState({
fieldsToShow: fieldsToShow,
fields: _fields,
data: response.data.data
});
})["catch"](function (e) {
return console.log('error in hoverAPI', e);
});
}
}
}
}, {
key: "componentDidMount",
value: function componentDidMount() {
var _this3 = this;
var _this$props2 = this.props,
data = _this$props2.data,
layer = _this$props2.layer,
fields = _this$props2.fields,
fieldsToShow = _this$props2.fieldsToShow,
datasets = _this$props2.datasets,
auth = _this$props2.auth;
if (layer.type === 'backendPoint' || layer.type === 'backendGeojson' || layer.type === 'geojson') {
var uid = auth.uid;
var _datasets$layer$confi4 = datasets[layer.config.dataId],
indexName = _datasets$layer$confi4.indexName,
_fields2 = _datasets$layer$confi4.fields;
var layerHoverApiData = {
docId: data.docId,
fieldsToShow: JSON.stringify(fieldsToShow),
userId: uid,
indexName: indexName
};
var config = {
headers: {
'Content-Type': 'application/json'
}
};
_axios["default"].post("".concat(_defaultSettings.ON_PREMESIS_URL, "/geoiqutilities/hover/v1.0/fetch"), layerHoverApiData, config).then(function (response) {
return _this3.setState({
fieldsToShow: fieldsToShow,
fields: _fields2,
data: response.data.data
});
})["catch"](function (e) {
return console.log('error inside componentDidMount', e);
});
}
} // componentDidMount() {
// this.setState({...this.state, ...this.props});
// }
}, {
key: "render",
value: function render() {
var _this$props3 = this.props,
data = _this$props3.data,
layer = _this$props3.layer,
fields = _this$props3.fields,
fieldsToShow = _this$props3.fieldsToShow,
datasets = _this$props3.datasets,
auth = _this$props3.auth;
if (!data || !layer || !fieldsToShow.length) {
return null;
}
var prop = _objectSpread(_objectSpread({}, this.state), this.props);
return (/*#__PURE__*/_react["default"].createElement("div", null, /*#__PURE__*/_react["default"].createElement(StyledLayerName, {
className: "map-popover__layer-name"
}, /*#__PURE__*/_react["default"].createElement(_icons.Layers, {
height: "12px"
}), layer.config.label), /*#__PURE__*/_react["default"].createElement("table", {
className: "map-popover__table"
}, layer.isAggregated && !data.docId ? /*#__PURE__*/_react["default"].createElement(CellInfo, this.props) : /*#__PURE__*/_react["default"].createElement(EntryInfo, prop)))
);
}
}]);
return LayerHoverInfo;
}(_react.Component);
(0, _defineProperty2["default"])(LayerHoverInfo, "propTypes", {
fields: _propTypes["default"].arrayOf(_propTypes["default"].any),
fieldsToShow: _propTypes["default"].arrayOf(_propTypes["default"].any),
layer: _propTypes["default"].object,
data: _propTypes["default"].oneOfType([_propTypes["default"].arrayOf(_propTypes["default"].any), _propTypes["default"].object])
});
return LayerHoverInfo;
}
var LayerHoverInfoFactorys = function LayerHoverInfoFactorys() {
var LayerHoverInfo = function LayerHoverInfo(props) {
var data = props.data,
layer = props.layer,
fields = props.fields,
fieldsToShow = props.fieldsToShow,
datasets = props.datasets,
auth = props.auth;
if (!data || !layer || !fieldsToShow.length) {
return null;
}
return (/*#__PURE__*/_react["default"].createElement("div", null, /*#__PURE__*/_react["default"].createElement(StyledLayerName, {
className: "map-popover__layer-name"
}, /*#__PURE__*/_react["default"].createElement(_icons.Layers, {
height: "12px"
}), props.layer.config.label), /*#__PURE__*/_react["default"].createElement("table", {
className: "map-popover__table"
}, props.layer.isAggregated ? /*#__PURE__*/_react["default"].createElement(CellInfo, props) : /*#__PURE__*/_react["default"].createElement(EntryInfo, props)))
); // }
};
LayerHoverInfo.propTypes = {
fields: _propTypes["default"].arrayOf(_propTypes["default"].any),
fieldsToShow: _propTypes["default"].arrayOf(_propTypes["default"].any),
layer: _propTypes["default"].object,
data: _propTypes["default"].oneOfType([_propTypes["default"].arrayOf(_propTypes["default"].any), _propTypes["default"].object])
};
return LayerHoverInfo;
}; // export default LayerHoverInfoFactory;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/map/layer-hover-info.js"],"names":["StyledLayerName","CenterFlexbox","props","theme","textColorHl","Row","name","value","url","match","asImg","test","EntryInfo","fieldsToShow","fields","data","map","Array","isArray","properties","EntryInfoRow","field","find","f","valueIdx","tableFieldIndex","displayValue","type","CellInfo","layer","config","colorField","sizeField","heightField","visConfig","colorAggregation","totalCount","points","length","visualChannels","color","getVisualChannelDescription","measure","aggregatedData","colorValue","size","heightAggregatedData","elevationValue","height","LayerHoverInfoFactory","LayerHoverInfo","state","nextProps","datasets","auth","docId","uid","dataId","indexName","layerHoverApiData","JSON","stringify","userId","headers","axios","post","ON_PREMESIS_URL","then","response","setState","e","console","log","prop","label","isAggregated","Component","PropTypes","arrayOf","any","object","oneOfType","LayerHoverInfoFactorys","propTypes"],"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, {Component} from 'react';\nimport styled from 'styled-components';\nimport {CenterFlexbox} from 'components/common/styled-components';\nimport {Layers} from 'components/common/icons';\nimport PropTypes from 'prop-types';\nimport {parseFieldValue} from 'utils/data-utils';\nimport axios from 'axios';\nimport {ON_PREMESIS_URL} from 'constants/default-settings';\n\nexport const StyledLayerName = styled(CenterFlexbox)`\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\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  // const {properties} = data;\n  // console.log(\n  //   'properties,fieldsTOshow , fields and data inside EntryInfo ',\n  //   properties,\n  //   fieldsToShow,\n  //   fields,\n  //   data\n  // );\n  return (\n    <tbody>\n      {fieldsToShow.map(name => (\n        <EntryInfoRow\n          key={name}\n          name={name}\n          fields={fields}\n          data={Array.isArray(data) ? data : data.properties[name]}\n        />\n      ))}\n    </tbody>\n  );\n};\n\nconst EntryInfoRow = ({name, fields, data}) => {\n  const field = fields.find(f => f.name === name);\n  if (!field) {\n    return null;\n  }\n  if (Array.isArray(data)) {\n    const valueIdx = field.tableFieldIndex - 1;\n    const displayValue = parseFieldValue(data[valueIdx], field.type);\n    return <Row name={name} value={displayValue} />;\n  } else {\n    const displayValue = data;\n\n    return <Row name={name} value={displayValue} />;\n  }\n};\n\nconst CellInfo = ({data, layer}) => {\n  const {colorField, sizeField, heightField, visConfig} = layer.config;\n  const {properties} = data;\n  const {colorAggregation} = visConfig;\n  // console.log(\n  //   'properties, data, colorField and sizeField inside cellInfo',\n  //   data,\n  //   properties,\n  //   colorField,\n  //   sizeField\n  // );\n\n  return (\n    <tbody>\n      {properties && properties.name ? (\n        <Row name={'name'} key=\"name\" value={properties.name} />\n      ) : null}\n      <Row\n        name={'total points'}\n        key=\"count\"\n        value={\n          properties ? properties.totalCount : data.points && data.points.length\n        }\n      />\n      {colorField && layer.visualChannels.color ? (\n        <Row\n          name={layer.getVisualChannelDescription('color').measure}\n          key=\"color\"\n          value={\n            properties ? properties.aggregatedData : data.colorValue || 'N/A'\n          }\n        />\n      ) : null}\n      {sizeField && layer.visualChannels.size ? (\n        <Row\n          name={layer.getVisualChannelDescription('size').measure}\n          key=\"size\"\n          value={\n            properties\n              ? properties.heightAggregatedData\n              : data.elevationValue || 'N/A'\n          }\n        />\n      ) : null}\n      {heightField && layer.visualChannels.height ? (\n        <Row\n          name={layer.getVisualChannelDescription('height').measure}\n          key=\"size\"\n          value={\n            properties\n              ? properties.heightAggregatedData\n              : data.elevationValue || 'N/A'\n          }\n        />\n      ) : null}\n    </tbody>\n  );\n};\n\nexport default function LayerHoverInfoFactory() {\n  class LayerHoverInfo extends Component {\n    static propTypes = {\n      fields: PropTypes.arrayOf(PropTypes.any),\n      fieldsToShow: PropTypes.arrayOf(PropTypes.any),\n      layer: PropTypes.object,\n      data: PropTypes.oneOfType([\n        PropTypes.arrayOf(PropTypes.any),\n        PropTypes.object\n      ])\n    };\n    constructor(props) {\n      super(props);\n      this.state = {\n        fieldsToShow: [],\n        fields: {},\n        data: {}\n      };\n    }\n\n    // state = {\n    //   fieldsToShow: [],\n    //   fields: {},\n    //   data: {}\n    // };\n\n    componentWillReceiveProps(nextProps) {\n      const {data, layer, fields, fieldsToShow, datasets, auth} = this.props;\n\n      if (\n        layer.type === 'backendPoint' ||\n        layer.type === 'backendGeojson' ||\n        layer.type === 'geojson'\n      ) {\n        if (nextProps.data.docId !== data.docId) {\n          const {uid} = auth;\n          const {indexName, fields} = datasets[layer.config.dataId];\n          const layerHoverApiData = {\n            docId: nextProps.data.docId,\n            fieldsToShow: JSON.stringify(fieldsToShow),\n            userId: uid,\n            indexName\n          };\n          const config = {\n            headers: {\n              'Content-Type': 'application/json'\n            }\n          };\n          axios\n            .post(\n              `${ON_PREMESIS_URL}/geoiqutilities/hover/v1.0/fetch`,\n              layerHoverApiData,\n              config\n            )\n            .then(response =>\n              this.setState({\n                fieldsToShow,\n                fields,\n                data: response.data.data\n              })\n            )\n            .catch(e => console.log('error in hoverAPI', e));\n        }\n      }\n    }\n\n    componentDidMount() {\n      const {data, layer, fields, fieldsToShow, datasets, auth} = this.props;\n\n      if (\n        layer.type === 'backendPoint' ||\n        layer.type === 'backendGeojson' ||\n        layer.type === 'geojson'\n      ) {\n        const {uid} = auth;\n        const {indexName, fields} = datasets[layer.config.dataId];\n        const layerHoverApiData = {\n          docId: data.docId,\n          fieldsToShow: JSON.stringify(fieldsToShow),\n          userId: uid,\n          indexName\n        };\n        const config = {\n          headers: {\n            'Content-Type': 'application/json'\n          }\n        };\n        axios\n          .post(\n            `${ON_PREMESIS_URL}/geoiqutilities/hover/v1.0/fetch`,\n            layerHoverApiData,\n            config\n          )\n          .then(response =>\n            this.setState({\n              fieldsToShow,\n              fields,\n              data: response.data.data\n            })\n          )\n          .catch(e => console.log('error inside componentDidMount', e));\n      }\n    }\n\n    // componentDidMount() {\n    //   this.setState({...this.state, ...this.props});\n    // }\n    render() {\n      const {data, layer, fields, fieldsToShow, datasets, auth} = this.props;\n      if (!data || !layer || !fieldsToShow.length) {\n        return null;\n      }\n      let prop = {\n        ...this.state,\n        ...this.props\n      };\n      return (\n        <div>\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 && !data.docId ? (\n              <CellInfo {...this.props} />\n            ) : (\n              <EntryInfo {...prop} />\n            )}\n          </table>\n        </div>\n      );\n    }\n  }\n  return LayerHoverInfo;\n}\n\nconst LayerHoverInfoFactorys = () => {\n  const LayerHoverInfo = props => {\n    const {data, layer, fields, fieldsToShow, datasets, auth} = props;\n\n    if (!data || !layer || !fieldsToShow.length) {\n      return null;\n    }\n\n    return (\n      <div>\n        <StyledLayerName className=\"map-popover__layer-name\">\n          <Layers height=\"12px\" />\n          {props.layer.config.label}\n        </StyledLayerName>\n        <table className=\"map-popover__table\">\n          {props.layer.isAggregated ? (\n            <CellInfo {...props} />\n          ) : (\n            <EntryInfo {...props} />\n          )}\n        </table>\n      </div>\n    );\n    // }\n  };\n\n  LayerHoverInfo.propTypes = {\n    fields: PropTypes.arrayOf(PropTypes.any),\n    fieldsToShow: PropTypes.arrayOf(PropTypes.any),\n    layer: PropTypes.object,\n    data: PropTypes.oneOfType([\n      PropTypes.arrayOf(PropTypes.any),\n      PropTypes.object\n    ])\n  };\n  return LayerHoverInfo;\n};\n\n// export default LayerHoverInfoFactory;\n"]}