UNPKG

kepler.gl

Version:

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

250 lines (247 loc) 42.1 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); var _typeof3 = require("@babel/runtime/helpers/typeof"); Object.defineProperty(exports, "__esModule", { value: true }); exports["default"] = exports.StyledLayerName = void 0; var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof")); var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties")); var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral")); var _react = _interopRequireWildcard(require("react")); var _styledComponents = _interopRequireDefault(require("styled-components")); var _truncate = _interopRequireDefault(require("lodash/truncate")); var _styledComponents2 = require("../common/styled-components"); var _icons = require("../common/icons"); var _propTypes = _interopRequireDefault(require("prop-types")); var _commonUtils = require("@kepler.gl/common-utils"); var _utils = require("@kepler.gl/utils"); var _reducers = require("@kepler.gl/reducers"); var _reactIntl = require("react-intl"); var _excluded = ["fieldsToShow"]; var _templateObject, _templateObject2, _templateObject3; // SPDX-License-Identifier: MIT // Copyright contributors to the kepler.gl project 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" != _typeof3(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; } 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\n svg {\n margin-right: 4px;\n }\n"])), function (props) { return props.theme.textColorHl; }); var StyledTable = _styledComponents["default"].table(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n & .row__delta-value {\n text-align: right;\n margin-left: 6px;\n\n &.positive {\n color: ", ";\n }\n\n &.negative {\n color: ", ";\n }\n }\n & .row__name {\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n }\n & .row__value {\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: pre-line;\n max-width: 250px;\n }\n"])), function (props) { return props.theme.notificationColors.success; }, function (props) { return props.theme.negativeBtnActBgd; }); var StyledDivider = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n // offset divider to reach popover edge\n margin-left: -14px;\n margin-right: -14px;\n border-bottom: 1px solid ", ";\n"])), function (props) { return props.theme.panelBorderColor; }); var TOOLTIP_VALUE_MAX_LENGTH = 256; var Row = function Row(_ref) { var name = _ref.name, value = _ref.value, deltaValue = _ref.deltaValue, 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 displayValue = typeof value === 'string' && value.length > TOOLTIP_VALUE_MAX_LENGTH ? (0, _truncate["default"])(value, { length: TOOLTIP_VALUE_MAX_LENGTH }) : value; var asImg = /<img>/.test(name); return /*#__PURE__*/_react["default"].createElement("tr", { className: "layer-hover-info__row", key: name }, /*#__PURE__*/_react["default"].createElement("td", { className: "row__name" }, asImg ? name.replace('<img>', '') : 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 }, displayValue) : /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, /*#__PURE__*/_react["default"].createElement("span", null, displayValue), (0, _commonUtils.notNullorUndefined)(deltaValue) ? /*#__PURE__*/_react["default"].createElement("span", { className: "row__delta-value ".concat((deltaValue === null || deltaValue === void 0 ? void 0 : deltaValue.toString().charAt(0)) === '+' ? 'positive' : 'negative') }, deltaValue) : null))); }; var EntryInfo = function EntryInfo(_ref2) { var fieldsToShow = _ref2.fieldsToShow, props = (0, _objectWithoutProperties2["default"])(_ref2, _excluded); return /*#__PURE__*/_react["default"].createElement("tbody", null, fieldsToShow.map(function (item) { return /*#__PURE__*/_react["default"].createElement(EntryInfoRow, (0, _extends2["default"])({ key: item.name, item: item }, props)); })); }; var EntryInfoRow = function EntryInfoRow(_ref3) { var layer = _ref3.layer, item = _ref3.item, fields = _ref3.fields, data = _ref3.data, primaryData = _ref3.primaryData, compareType = _ref3.compareType, currentTime = _ref3.currentTime; var fieldIdx = fields.findIndex(function (f) { return f.name === item.name; }); if (fieldIdx < 0) { return null; } var field = fields[fieldIdx]; var fieldValueAccessor = layer.accessVSFieldValue(field, currentTime); var value = fieldValueAccessor(field, data instanceof _utils.DataRow ? { index: data._rowIndex } : data); // Handle WMS layer data in comparison mode - WMS layers don't have comparable field data var primaryValue = null; var displayDeltaValue = null; if (primaryData) { try { // Only calculate primary value if primaryData has a compatible structure if (primaryData instanceof _utils.DataRow || primaryData && (0, _typeof2["default"])(primaryData) === 'object' && 'index' in primaryData) { primaryValue = fieldValueAccessor(field, primaryData instanceof _utils.DataRow ? { index: primaryData._rowIndex } : primaryData); displayDeltaValue = (0, _reducers.getTooltipDisplayDeltaValue)({ field: field, value: value, primaryValue: primaryValue, compareType: compareType }); } } catch (error) { // If there's an error accessing primaryData (e.g., WMS layer data), skip comparison primaryValue = null; } } var displayValue = (0, _reducers.getTooltipDisplayValue)({ item: item, field: field, value: value }); return /*#__PURE__*/_react["default"].createElement(Row, { name: field.displayName || field.name, value: displayValue, deltaValue: displayDeltaValue }); }; // TODO: supporting comparative value for aggregated cells as well var CellInfo = function CellInfo(_ref4) { var fieldsToShow = _ref4.fieldsToShow, data = _ref4.data, layer = _ref4.layer; var _ref5 = layer.config, colorField = _ref5.colorField, sizeField = _ref5.sizeField; var colorValue = (0, _react.useMemo)(function () { if (colorField && layer.visualChannels.color) { var item = fieldsToShow.find(function (field) { return field.name === colorField.name; }); return (0, _reducers.getTooltipDisplayValue)({ item: item, field: colorField, value: data.colorValue }); } return null; }, [fieldsToShow, colorField, layer, data.colorValue]); var elevationValue = (0, _react.useMemo)(function () { if (sizeField && layer.visualChannels.size) { var item = fieldsToShow.find(function (field) { return field.name === sizeField.name; }); return (0, _reducers.getTooltipDisplayValue)({ item: item, field: sizeField, value: data.elevationValue }); } return null; }, [fieldsToShow, sizeField, layer, data.elevationValue]); var aggregatedData = (0, _react.useMemo)(function () { if (data.aggregatedData && fieldsToShow) { return fieldsToShow.reduce(function (acc, field) { var _data$aggregatedData; var dataForField = (_data$aggregatedData = data.aggregatedData) === null || _data$aggregatedData === void 0 ? void 0 : _data$aggregatedData[field.name]; if (dataForField !== null && dataForField !== void 0 && dataForField.measure && field.name !== (colorField === null || colorField === void 0 ? void 0 : colorField.name)) { acc.push({ name: "".concat((0, _utils.capitalizeFirstLetter)(dataForField.measure), " of ").concat(field.name), value: dataForField.value }); } return acc; }, []); } return []; }, [data.aggregatedData, fieldsToShow, colorField === null || colorField === void 0 ? void 0 : colorField.name]); var colorMeasure = layer.getVisualChannelDescription('color').measure; var sizeMeasure = layer.getVisualChannelDescription('size').measure; return /*#__PURE__*/_react["default"].createElement("tbody", null, /*#__PURE__*/_react["default"].createElement(Row, { name: 'total points', key: "count", value: String(data.points && data.points.length) }), colorField && layer.visualChannels.color && colorMeasure ? /*#__PURE__*/_react["default"].createElement(Row, { name: colorMeasure, key: "color", value: colorValue || 'N/A' }) : null, sizeField && layer.visualChannels.size && sizeMeasure ? /*#__PURE__*/_react["default"].createElement(Row, { name: sizeMeasure, key: "size", value: elevationValue || 'N/A' }) : null, aggregatedData.map(function (dataForField, idx) { return /*#__PURE__*/_react["default"].createElement(Row, { name: dataForField.name, key: "data_".concat(idx), value: dataForField.value || 'N/A' }); })); }; var LayerHoverInfoFactory = function LayerHoverInfoFactory() { var LayerHoverInfo = function LayerHoverInfo(props) { var data = props.data, layer = props.layer; var intl = (0, _reactIntl.useIntl)(); if (!data || !layer) { return null; } var hasFieldsToShow = data.fieldValues && Object.keys(data.fieldValues).length > 0 || data.wmsFeatureData && data.wmsFeatureData.length > 0 || props.fieldsToShow && props.fieldsToShow.length > 0; return /*#__PURE__*/_react["default"].createElement("div", { className: "map-popover__layer-info" }, /*#__PURE__*/_react["default"].createElement(StyledLayerName, { className: "map-popover__layer-name" }, /*#__PURE__*/_react["default"].createElement(_icons.Layers, { height: "12px" }), props.layer.config.label), hasFieldsToShow && /*#__PURE__*/_react["default"].createElement(StyledDivider, null), /*#__PURE__*/_react["default"].createElement(StyledTable, null, data.wmsFeatureData ? /*#__PURE__*/_react["default"].createElement("tbody", null, data.wmsFeatureData.map(function (_ref6, i) { var name = _ref6.name, value = _ref6.value; return /*#__PURE__*/_react["default"].createElement(Row, { key: i, name: name, value: value }); })) : data.fieldValues ? /*#__PURE__*/_react["default"].createElement("tbody", null, data.fieldValues.map(function (_ref7, i) { var labelMessage = _ref7.labelMessage, value = _ref7.value; return /*#__PURE__*/_react["default"].createElement(Row, { key: i, name: intl.formatMessage({ id: labelMessage }), value: value }); })) : props.layer.isAggregated ? /*#__PURE__*/_react["default"].createElement(CellInfo, props) : /*#__PURE__*/_react["default"].createElement(EntryInfo, props)), hasFieldsToShow && /*#__PURE__*/_react["default"].createElement(StyledDivider, null)); }; 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 _default = exports["default"] = LayerHoverInfoFactory; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_styledComponents","_interopRequireDefault","_truncate","_styledComponents2","_icons","_propTypes","_commonUtils","_utils","_reducers","_reactIntl","_excluded","_templateObject","_templateObject2","_templateObject3","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof3","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","StyledLayerName","exports","styled","CenterFlexbox","_taggedTemplateLiteral2","props","theme","textColorHl","StyledTable","table","notificationColors","success","negativeBtnActBgd","StyledDivider","div","panelBorderColor","TOOLTIP_VALUE_MAX_LENGTH","Row","_ref","name","value","deltaValue","url","match","displayValue","length","truncate","asImg","test","createElement","className","key","replace","src","target","rel","href","Fragment","notNullorUndefined","concat","toString","charAt","EntryInfo","_ref2","fieldsToShow","_objectWithoutProperties2","map","item","EntryInfoRow","_extends2","_ref3","layer","fields","data","primaryData","compareType","currentTime","fieldIdx","findIndex","f","field","fieldValueAccessor","accessVSFieldValue","DataRow","index","_rowIndex","primaryValue","displayDeltaValue","_typeof2","getTooltipDisplayDeltaValue","error","getTooltipDisplayValue","displayName","CellInfo","_ref4","_ref5","config","colorField","sizeField","colorValue","useMemo","visualChannels","color","find","elevationValue","size","aggregatedData","reduce","acc","_data$aggregatedData","dataForField","measure","push","capitalizeFirstLetter","colorMeasure","getVisualChannelDescription","sizeMeasure","String","points","idx","LayerHoverInfoFactory","LayerHoverInfo","intl","useIntl","hasFieldsToShow","fieldValues","keys","wmsFeatureData","Layers","height","label","_ref6","_ref7","labelMessage","formatMessage","id","isAggregated","propTypes","PropTypes","arrayOf","any","object","oneOfType","_default"],"sources":["../../src/map/layer-hover-info.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React, {useMemo} from 'react';\nimport styled from 'styled-components';\nimport truncate from 'lodash/truncate';\nimport {CompareType, Field, Merge, TooltipField} from '@kepler.gl/types';\nimport {CenterFlexbox} from '../common/styled-components';\nimport {Layers} from '../common/icons';\nimport PropTypes from 'prop-types';\nimport {notNullorUndefined} from '@kepler.gl/common-utils';\nimport {DataRow} from '@kepler.gl/utils';\nimport {Layer} from '@kepler.gl/layers';\nimport {\n  AggregationLayerHoverData,\n  LayerHoverProp,\n  getTooltipDisplayDeltaValue,\n  getTooltipDisplayValue\n} from '@kepler.gl/reducers';\nimport {useIntl} from 'react-intl';\nimport {VisState} from '@kepler.gl/schemas';\nimport {capitalizeFirstLetter} from '@kepler.gl/utils';\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\n  svg {\n    margin-right: 4px;\n  }\n`;\n\nconst StyledTable = styled.table`\n  & .row__delta-value {\n    text-align: right;\n    margin-left: 6px;\n\n    &.positive {\n      color: ${props => props.theme.notificationColors.success};\n    }\n\n    &.negative {\n      color: ${props => props.theme.negativeBtnActBgd};\n    }\n  }\n  & .row__name {\n    overflow: hidden;\n    text-overflow: ellipsis;\n    white-space: nowrap;\n  }\n  & .row__value {\n    overflow: hidden;\n    text-overflow: ellipsis;\n    white-space: pre-line;\n    max-width: 250px;\n  }\n`;\n\nconst StyledDivider = styled.div`\n  // offset divider to reach popover edge\n  margin-left: -14px;\n  margin-right: -14px;\n  border-bottom: 1px solid ${props => props.theme.panelBorderColor};\n`;\n\ninterface RowProps {\n  name: string;\n  value: string;\n  deltaValue?: string | null;\n  url?: string;\n}\n\nconst TOOLTIP_VALUE_MAX_LENGTH = 256;\n\nconst Row: React.FC<RowProps> = ({name, value, deltaValue, 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 displayValue =\n    typeof value === 'string' && value.length > TOOLTIP_VALUE_MAX_LENGTH\n      ? truncate(value, {length: TOOLTIP_VALUE_MAX_LENGTH})\n      : value;\n\n  const asImg = /<img>/.test(name);\n  return (\n    <tr className=\"layer-hover-info__row\" key={name}>\n      <td className=\"row__name\">{asImg ? name.replace('<img>', '') : 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            {displayValue}\n          </a>\n        ) : (\n          <>\n            <span>{displayValue}</span>\n            {notNullorUndefined(deltaValue) ? (\n              <span\n                className={`row__delta-value ${\n                  deltaValue?.toString().charAt(0) === '+' ? 'positive' : 'negative'\n                }`}\n              >\n                {deltaValue}\n              </span>\n            ) : null}\n          </>\n        )}\n      </td>\n    </tr>\n  );\n};\n\nexport type EntryInfoProps = Merge<LayerHoverProp, {fieldsToShow: TooltipField[]}>;\n\nconst EntryInfo: React.FC<EntryInfoProps> = ({fieldsToShow, ...props}) => (\n  <tbody>\n    {fieldsToShow.map(item => (\n      <EntryInfoRow key={item.name} item={item} {...props} />\n    ))}\n  </tbody>\n);\n\nexport type EntryInfoRowProps = {\n  data: LayerHoverProp['data'];\n  fields: Field[];\n  layer: Layer;\n  primaryData?: LayerHoverProp['primaryData'];\n  compareType?: CompareType;\n  currentTime?: VisState['animationConfig']['currentTime'];\n  item: TooltipField;\n};\n\nconst EntryInfoRow: React.FC<EntryInfoRowProps> = ({\n  layer,\n  item,\n  fields,\n  data,\n  primaryData,\n  compareType,\n  currentTime\n}) => {\n  const fieldIdx = fields.findIndex(f => f.name === item.name);\n  if (fieldIdx < 0) {\n    return null;\n  }\n  const field = fields[fieldIdx];\n  const fieldValueAccessor = layer.accessVSFieldValue(field, currentTime);\n  const value = fieldValueAccessor(field, data instanceof DataRow ? {index: data._rowIndex} : data);\n\n  // Handle WMS layer data in comparison mode - WMS layers don't have comparable field data\n  let primaryValue = null;\n  let displayDeltaValue: string | null = null;\n\n  if (primaryData) {\n    try {\n      // Only calculate primary value if primaryData has a compatible structure\n      if (\n        primaryData instanceof DataRow ||\n        (primaryData && typeof primaryData === 'object' && 'index' in primaryData)\n      ) {\n        primaryValue = fieldValueAccessor(\n          field,\n          primaryData instanceof DataRow ? {index: primaryData._rowIndex} : primaryData\n        );\n\n        displayDeltaValue = getTooltipDisplayDeltaValue({\n          field,\n          value,\n          primaryValue,\n          compareType\n        });\n      }\n    } catch (error) {\n      // If there's an error accessing primaryData (e.g., WMS layer data), skip comparison\n      primaryValue = null;\n    }\n  }\n\n  const displayValue = getTooltipDisplayValue({item, field, value});\n\n  return (\n    <Row\n      name={field.displayName || field.name}\n      value={displayValue}\n      deltaValue={displayDeltaValue}\n    />\n  );\n};\n\n// TODO: supporting comparative value for aggregated cells as well\nconst CellInfo = ({\n  fieldsToShow,\n  data,\n  layer\n}: {\n  data: AggregationLayerHoverData;\n  fieldsToShow: TooltipField[];\n  layer: Layer;\n}) => {\n  const {colorField, sizeField} = layer.config as any;\n\n  const colorValue = useMemo(() => {\n    if (colorField && layer.visualChannels.color) {\n      const item = fieldsToShow.find(field => field.name === colorField.name);\n      return getTooltipDisplayValue({item, field: colorField, value: data.colorValue});\n    }\n    return null;\n  }, [fieldsToShow, colorField, layer, data.colorValue]);\n\n  const elevationValue = useMemo(() => {\n    if (sizeField && layer.visualChannels.size) {\n      const item = fieldsToShow.find(field => field.name === sizeField.name);\n      return getTooltipDisplayValue({item, field: sizeField, value: data.elevationValue});\n    }\n    return null;\n  }, [fieldsToShow, sizeField, layer, data.elevationValue]);\n\n  const aggregatedData = useMemo(() => {\n    if (data.aggregatedData && fieldsToShow) {\n      return fieldsToShow.reduce((acc, field) => {\n        const dataForField = data.aggregatedData?.[field.name];\n        if (dataForField?.measure && field.name !== colorField?.name) {\n          acc.push({\n            name: `${capitalizeFirstLetter(dataForField.measure)} of ${field.name}`,\n            value: dataForField.value\n          });\n        }\n        return acc;\n      }, [] as {name: string; value?: string}[]);\n    }\n    return [];\n  }, [data.aggregatedData, fieldsToShow, colorField?.name]);\n\n  const colorMeasure = layer.getVisualChannelDescription('color').measure;\n  const sizeMeasure = layer.getVisualChannelDescription('size').measure;\n  return (\n    <tbody>\n      <Row name={'total points'} key=\"count\" value={String(data.points && data.points.length)} />\n      {colorField && layer.visualChannels.color && colorMeasure ? (\n        <Row name={colorMeasure} key=\"color\" value={colorValue || 'N/A'} />\n      ) : null}\n      {sizeField && layer.visualChannels.size && sizeMeasure ? (\n        <Row name={sizeMeasure} key=\"size\" value={elevationValue || 'N/A'} />\n      ) : null}\n      {aggregatedData.map((dataForField, idx) => (\n        <Row name={dataForField.name} key={`data_${idx}`} value={dataForField.value || 'N/A'} />\n      ))}\n    </tbody>\n  );\n};\n\nconst LayerHoverInfoFactory = () => {\n  const LayerHoverInfo = props => {\n    const {data, layer} = props;\n    const intl = useIntl();\n    if (!data || !layer) {\n      return null;\n    }\n\n    const hasFieldsToShow =\n      (data.fieldValues && Object.keys(data.fieldValues).length > 0) ||\n      (data.wmsFeatureData && data.wmsFeatureData.length > 0) ||\n      (props.fieldsToShow && props.fieldsToShow.length > 0);\n\n    return (\n      <div className=\"map-popover__layer-info\">\n        <StyledLayerName className=\"map-popover__layer-name\">\n          <Layers height=\"12px\" />\n          {props.layer.config.label}\n        </StyledLayerName>\n        {hasFieldsToShow && <StyledDivider />}\n        <StyledTable>\n          {data.wmsFeatureData ? (\n            <tbody>\n              {data.wmsFeatureData.map(({name, value}, i) => (\n                <Row key={i} name={name} value={value} />\n              ))}\n            </tbody>\n          ) : data.fieldValues ? (\n            <tbody>\n              {data.fieldValues.map(({labelMessage, value}, i) => (\n                <Row key={i} name={intl.formatMessage({id: labelMessage})} value={value} />\n              ))}\n            </tbody>\n          ) : props.layer.isAggregated ? (\n            <CellInfo {...props} />\n          ) : (\n            <EntryInfo {...props} />\n          )}\n        </StyledTable>\n        {hasFieldsToShow && <StyledDivider />}\n      </div>\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([PropTypes.arrayOf(PropTypes.any), PropTypes.object])\n  };\n  return LayerHoverInfo;\n};\n\nexport default LayerHoverInfoFactory;\n"],"mappings":"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","ignoreList":[]}