UNPKG

kepler.gl

Version:

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

245 lines (242 loc) 40.8 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 _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__value,\n & .row__name {\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: no-wrap;\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 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 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 }, value) : /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, /*#__PURE__*/_react["default"].createElement("span", null, value), (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","_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","Row","_ref","name","value","deltaValue","url","match","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","displayValue","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","length","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 {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__value,\n  & .row__name {\n    overflow: hidden;\n    text-overflow: ellipsis;\n    white-space: no-wrap;\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 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 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            {value}\n          </a>\n        ) : (\n          <>\n            <span>{value}</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":[]}