UNPKG

kepler.gl

Version:

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

176 lines (148 loc) 20.8 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports["default"] = exports.StyledLayerName = void 0; var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral")); var _react = _interopRequireDefault(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 _interactionUtils = require("../../utils/interaction-utils"); var _templateObject, _templateObject2; var 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; }); exports.StyledLayerName = StyledLayerName; var StyledTable = _styledComponents["default"].table(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n & .row__delta-value {\n text-align: right;\n\n &.positive {\n color: ", ";\n }\n\n &.negative {\n color: ", ";\n }\n }\n"])), function (props) { return props.theme.primaryBtnBgd; }, function (props) { return props.theme.negativeBtnActBgd; }); /** @type {import('./layer-hover-info').RowComponent} */ 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: "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), (0, _dataUtils.notNullorUndefined)(deltaValue) && /*#__PURE__*/_react["default"].createElement("td", { className: "row__delta-value ".concat(deltaValue.toString().charAt(0) === '+' ? 'positive' : 'negative') }, deltaValue)); }; var EntryInfo = function EntryInfo(_ref2) { var fieldsToShow = _ref2.fieldsToShow, fields = _ref2.fields, data = _ref2.data, primaryData = _ref2.primaryData, compareType = _ref2.compareType; return /*#__PURE__*/_react["default"].createElement("tbody", null, fieldsToShow.map(function (item) { return /*#__PURE__*/_react["default"].createElement(EntryInfoRow, { key: item.name, item: item, fields: fields, data: data, primaryData: primaryData, compareType: compareType }); })); }; var EntryInfoRow = function EntryInfoRow(_ref3) { var item = _ref3.item, fields = _ref3.fields, data = _ref3.data, primaryData = _ref3.primaryData, compareType = _ref3.compareType; var fieldIdx = fields.findIndex(function (f) { return f.name === item.name; }); if (fieldIdx < 0) { return null; } var field = fields[fieldIdx]; var displayValue = (0, _interactionUtils.getTooltipDisplayValue)({ item: item, field: field, data: data, fieldIdx: fieldIdx }); var displayDeltaValue = (0, _interactionUtils.getTooltipDisplayDeltaValue)({ item: item, field: field, data: data, fieldIdx: fieldIdx, primaryData: primaryData, compareType: compareType }); 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 data = _ref4.data, layer = _ref4.layer; var _layer$config = layer.config, colorField = _layer$config.colorField, sizeField = _layer$config.sizeField; return /*#__PURE__*/_react["default"].createElement("tbody", null, /*#__PURE__*/_react["default"].createElement(Row, { name: 'total points', key: "count", value: data.points && data.points.length }), colorField && layer.visualChannels.color ? /*#__PURE__*/_react["default"].createElement(Row, { name: layer.getVisualChannelDescription('color').measure, key: "color", value: data.colorValue || 'N/A' }) : null, sizeField && layer.visualChannels.size ? /*#__PURE__*/_react["default"].createElement(Row, { name: layer.getVisualChannelDescription('size').measure, key: "size", value: data.elevationValue || 'N/A' }) : null); }; var LayerHoverInfoFactory = function LayerHoverInfoFactory() { var LayerHoverInfo = function LayerHoverInfo(props) { var data = props.data, layer = props.layer; if (!data || !layer) { return null; } 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), /*#__PURE__*/_react["default"].createElement(StyledTable, null, 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; }; var _default = LayerHoverInfoFactory; exports["default"] = _default; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/map/layer-hover-info.js"],"names":["StyledLayerName","CenterFlexbox","props","theme","textColorHl","StyledTable","styled","table","primaryBtnBgd","negativeBtnActBgd","Row","name","value","deltaValue","url","match","asImg","test","toString","charAt","EntryInfo","fieldsToShow","fields","data","primaryData","compareType","map","item","EntryInfoRow","fieldIdx","findIndex","f","field","displayValue","displayDeltaValue","displayName","CellInfo","layer","config","colorField","sizeField","points","length","visualChannels","color","getVisualChannelDescription","measure","colorValue","size","elevationValue","LayerHoverInfoFactory","LayerHoverInfo","label","isAggregated","propTypes","PropTypes","arrayOf","any","object","oneOfType"],"mappings":";;;;;;;;;;;AAoBA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;;;AAEO,IAAMA,eAAe,GAAG,kCAAOC,gCAAP,CAAH,+NACjB,UAAAC,KAAK;AAAA,SAAIA,KAAK,CAACC,KAAN,CAAYC,WAAhB;AAAA,CADY,CAArB;;;AAWP,IAAMC,WAAW,GAAGC,6BAAOC,KAAV,+OAKF,UAAAL,KAAK;AAAA,SAAIA,KAAK,CAACC,KAAN,CAAYK,aAAhB;AAAA,CALH,EASF,UAAAN,KAAK;AAAA,SAAIA,KAAK,CAACC,KAAN,CAAYM,iBAAhB;AAAA,CATH,CAAjB;AAcA;;;AACA,IAAMC,GAAG,GAAG,SAANA,GAAM,OAAoC;AAAA,MAAlCC,IAAkC,QAAlCA,IAAkC;AAAA,MAA5BC,KAA4B,QAA5BA,KAA4B;AAAA,MAArBC,UAAqB,QAArBA,UAAqB;AAAA,MAATC,GAAS,QAATA,GAAS;;AAC9C;AACA,MAAI,CAACA,GAAD,IAAQF,KAAR,IAAiB,OAAOA,KAAP,KAAiB,QAAlC,IAA8CA,KAAK,CAACG,KAAN,CAAY,OAAZ,CAAlD,EAAwE;AACtED,IAAAA,GAAG,GAAGF,KAAN;AACD;;AAED,MAAMI,KAAK,GAAG,QAAQC,IAAR,CAAaN,IAAb,CAAd;AACA,sBACE;AAAI,IAAA,SAAS,EAAC,KAAd;AAAoB,IAAA,GAAG,EAAEA;AAAzB,kBACE;AAAI,IAAA,SAAS,EAAC;AAAd,KAA2BA,IAA3B,CADF,eAEE;AAAI,IAAA,SAAS,EAAC;AAAd,KACGK,KAAK,gBACJ;AAAK,IAAA,GAAG,EAAEJ;AAAV,IADI,GAEFE,GAAG,gBACL;AAAG,IAAA,MAAM,EAAC,QAAV;AAAmB,IAAA,GAAG,EAAC,qBAAvB;AAA6C,IAAA,IAAI,EAAEA;AAAnD,KACGF,KADH,CADK,GAKLA,KARJ,CAFF,EAaG,mCAAmBC,UAAnB,kBACC;AACE,IAAA,SAAS,6BACPA,UAAU,CAACK,QAAX,GAAsBC,MAAtB,CAA6B,CAA7B,MAAoC,GAApC,GAA0C,UAA1C,GAAuD,UADhD;AADX,KAKGN,UALH,CAdJ,CADF;AAyBD,CAhCD;;AAkCA,IAAMO,SAAS,GAAG,SAAZA,SAAY;AAAA,MAAEC,YAAF,SAAEA,YAAF;AAAA,MAAgBC,MAAhB,SAAgBA,MAAhB;AAAA,MAAwBC,IAAxB,SAAwBA,IAAxB;AAAA,MAA8BC,WAA9B,SAA8BA,WAA9B;AAAA,MAA2CC,WAA3C,SAA2CA,WAA3C;AAAA,sBAChB,+CACGJ,YAAY,CAACK,GAAb,CAAiB,UAAAC,IAAI;AAAA,wBACpB,gCAAC,YAAD;AACE,MAAA,GAAG,EAAEA,IAAI,CAAChB,IADZ;AAEE,MAAA,IAAI,EAAEgB,IAFR;AAGE,MAAA,MAAM,EAAEL,MAHV;AAIE,MAAA,IAAI,EAAEC,IAJR;AAKE,MAAA,WAAW,EAAEC,WALf;AAME,MAAA,WAAW,EAAEC;AANf,MADoB;AAAA,GAArB,CADH,CADgB;AAAA,CAAlB;;AAeA,IAAMG,YAAY,GAAG,SAAfA,YAAe,QAAoD;AAAA,MAAlDD,IAAkD,SAAlDA,IAAkD;AAAA,MAA5CL,MAA4C,SAA5CA,MAA4C;AAAA,MAApCC,IAAoC,SAApCA,IAAoC;AAAA,MAA9BC,WAA8B,SAA9BA,WAA8B;AAAA,MAAjBC,WAAiB,SAAjBA,WAAiB;AACvE,MAAMI,QAAQ,GAAGP,MAAM,CAACQ,SAAP,CAAiB,UAAAC,CAAC;AAAA,WAAIA,CAAC,CAACpB,IAAF,KAAWgB,IAAI,CAAChB,IAApB;AAAA,GAAlB,CAAjB;;AACA,MAAIkB,QAAQ,GAAG,CAAf,EAAkB;AAChB,WAAO,IAAP;AACD;;AACD,MAAMG,KAAK,GAAGV,MAAM,CAACO,QAAD,CAApB;AACA,MAAMI,YAAY,GAAG,8CAAuB;AAACN,IAAAA,IAAI,EAAJA,IAAD;AAAOK,IAAAA,KAAK,EAALA,KAAP;AAAcT,IAAAA,IAAI,EAAJA,IAAd;AAAoBM,IAAAA,QAAQ,EAARA;AAApB,GAAvB,CAArB;AAEA,MAAMK,iBAAiB,GAAG,mDAA4B;AACpDP,IAAAA,IAAI,EAAJA,IADoD;AAEpDK,IAAAA,KAAK,EAALA,KAFoD;AAGpDT,IAAAA,IAAI,EAAJA,IAHoD;AAIpDM,IAAAA,QAAQ,EAARA,QAJoD;AAKpDL,IAAAA,WAAW,EAAXA,WALoD;AAMpDC,IAAAA,WAAW,EAAXA;AANoD,GAA5B,CAA1B;AASA,sBACE,gCAAC,GAAD;AACE,IAAA,IAAI,EAAEO,KAAK,CAACG,WAAN,IAAqBH,KAAK,CAACrB,IADnC;AAEE,IAAA,KAAK,EAAEsB,YAFT;AAGE,IAAA,UAAU,EAAEC;AAHd,IADF;AAOD,CAxBD,C,CA0BA;;;AACA,IAAME,QAAQ,GAAG,SAAXA,QAAW,QAAmB;AAAA,MAAjBb,IAAiB,SAAjBA,IAAiB;AAAA,MAAXc,KAAW,SAAXA,KAAW;AAAA,sBACFA,KAAK,CAACC,MADJ;AAAA,MAC3BC,UAD2B,iBAC3BA,UAD2B;AAAA,MACfC,SADe,iBACfA,SADe;AAGlC,sBACE,4DACE,gCAAC,GAAD;AAAK,IAAA,IAAI,EAAE,cAAX;AAA2B,IAAA,GAAG,EAAC,OAA/B;AAAuC,IAAA,KAAK,EAAEjB,IAAI,CAACkB,MAAL,IAAelB,IAAI,CAACkB,MAAL,CAAYC;AAAzE,IADF,EAEGH,UAAU,IAAIF,KAAK,CAACM,cAAN,CAAqBC,KAAnC,gBACC,gCAAC,GAAD;AACE,IAAA,IAAI,EAAEP,KAAK,CAACQ,2BAAN,CAAkC,OAAlC,EAA2CC,OADnD;AAEE,IAAA,GAAG,EAAC,OAFN;AAGE,IAAA,KAAK,EAAEvB,IAAI,CAACwB,UAAL,IAAmB;AAH5B,IADD,GAMG,IARN,EASGP,SAAS,IAAIH,KAAK,CAACM,cAAN,CAAqBK,IAAlC,gBACC,gCAAC,GAAD;AACE,IAAA,IAAI,EAAEX,KAAK,CAACQ,2BAAN,CAAkC,MAAlC,EAA0CC,OADlD;AAEE,IAAA,GAAG,EAAC,MAFN;AAGE,IAAA,KAAK,EAAEvB,IAAI,CAAC0B,cAAL,IAAuB;AAHhC,IADD,GAMG,IAfN,CADF;AAmBD,CAtBD;;AAwBA,IAAMC,qBAAqB,GAAG,SAAxBA,qBAAwB,GAAM;AAClC,MAAMC,cAAc,GAAG,SAAjBA,cAAiB,CAAAjD,KAAK,EAAI;AAAA,QACvBqB,IADuB,GACRrB,KADQ,CACvBqB,IADuB;AAAA,QACjBc,KADiB,GACRnC,KADQ,CACjBmC,KADiB;;AAG9B,QAAI,CAACd,IAAD,IAAS,CAACc,KAAd,EAAqB;AACnB,aAAO,IAAP;AACD;;AAED,wBACE;AAAK,MAAA,SAAS,EAAC;AAAf,oBACE,gCAAC,eAAD;AAAiB,MAAA,SAAS,EAAC;AAA3B,oBACE,gCAAC,aAAD;AAAQ,MAAA,MAAM,EAAC;AAAf,MADF,EAEGnC,KAAK,CAACmC,KAAN,CAAYC,MAAZ,CAAmBc,KAFtB,CADF,eAKE,gCAAC,WAAD,QACGlD,KAAK,CAACmC,KAAN,CAAYgB,YAAZ,gBAA2B,gCAAC,QAAD,EAAcnD,KAAd,CAA3B,gBAAqD,gCAAC,SAAD,EAAeA,KAAf,CADxD,CALF,CADF;AAWD,GAlBD;;AAoBAiD,EAAAA,cAAc,CAACG,SAAf,GAA2B;AACzBhC,IAAAA,MAAM,EAAEiC,sBAAUC,OAAV,CAAkBD,sBAAUE,GAA5B,CADiB;AAEzBpC,IAAAA,YAAY,EAAEkC,sBAAUC,OAAV,CAAkBD,sBAAUE,GAA5B,CAFW;AAGzBpB,IAAAA,KAAK,EAAEkB,sBAAUG,MAHQ;AAIzBnC,IAAAA,IAAI,EAAEgC,sBAAUI,SAAV,CAAoB,CAACJ,sBAAUC,OAAV,CAAkBD,sBAAUE,GAA5B,CAAD,EAAmCF,sBAAUG,MAA7C,CAApB;AAJmB,GAA3B;AAMA,SAAOP,cAAP;AACD,CA5BD;;eA8BeD,qB","sourcesContent":["// Copyright (c) 2021 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 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 {notNullorUndefined} from 'utils/data-utils';\nimport {getTooltipDisplayValue, getTooltipDisplayDeltaValue} from 'utils/interaction-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\n    &.positive {\n      color: ${props => props.theme.primaryBtnBgd};\n    }\n\n    &.negative {\n      color: ${props => props.theme.negativeBtnActBgd};\n    }\n  }\n`;\n\n/** @type {import('./layer-hover-info').RowComponent} */\nconst Row = ({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=\"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      {notNullorUndefined(deltaValue) && (\n        <td\n          className={`row__delta-value ${\n            deltaValue.toString().charAt(0) === '+' ? 'positive' : 'negative'\n          }`}\n        >\n          {deltaValue}\n        </td>\n      )}\n    </tr>\n  );\n};\n\nconst EntryInfo = ({fieldsToShow, fields, data, primaryData, compareType}) => (\n  <tbody>\n    {fieldsToShow.map(item => (\n      <EntryInfoRow\n        key={item.name}\n        item={item}\n        fields={fields}\n        data={data}\n        primaryData={primaryData}\n        compareType={compareType}\n      />\n    ))}\n  </tbody>\n);\n\nconst EntryInfoRow = ({item, fields, data, primaryData, compareType}) => {\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 displayValue = getTooltipDisplayValue({item, field, data, fieldIdx});\n\n  const displayDeltaValue = getTooltipDisplayDeltaValue({\n    item,\n    field,\n    data,\n    fieldIdx,\n    primaryData,\n    compareType\n  });\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 = ({data, layer}) => {\n  const {colorField, sizeField} = layer.config;\n\n  return (\n    <tbody>\n      <Row name={'total points'} key=\"count\" value={data.points && data.points.length} />\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 LayerHoverInfoFactory = () => {\n  const LayerHoverInfo = props => {\n    const {data, layer} = props;\n\n    if (!data || !layer) {\n      return null;\n    }\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        <StyledTable>\n          {props.layer.isAggregated ? <CellInfo {...props} /> : <EntryInfo {...props} />}\n        </StyledTable>\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"]}