kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
125 lines (108 loc) • 14.4 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = void 0;
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
var _react = _interopRequireWildcard(require("react"));
var _reactVis = require("react-vis");
var _styledComponents = _interopRequireDefault(require("styled-components"));
var _dataUtils = require("../../utils/data-utils");
var _templateObject, _templateObject2;
var LineChartWrapper = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n .rv-xy-plot {\n /* important for rendering hint */\n position: relative;\n }\n .rv-xy-plot__inner {\n /* important to show axis */\n overflow: visible;\n }\n\n .rv-xy-plot__grid-lines__line {\n stroke: ", ";\n stroke-dasharray: 1px 4px;\n }\n\n .rv-xy-plot__axis__tick__text {\n font-size: 9px;\n fill: ", ";\n }\n"])), function (props) {
return props.theme.histogramFillOutRange;
}, function (props) {
return props.theme.textColor;
});
var StyledHint = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n background-color: #d3d8e0;\n border-radius: 2px;\n color: ", ";\n font-size: 9px;\n margin: 4px;\n padding: 3px 6px;\n pointer-events: none;\n user-select: none;\n"])), function (props) {
return props.theme.textColorLT;
});
var HintContent = function HintContent(_ref) {
var x = _ref.x,
y = _ref.y,
format = _ref.format;
return /*#__PURE__*/_react["default"].createElement(StyledHint, null, /*#__PURE__*/_react["default"].createElement("div", {
className: "hint--x"
}, format(x)), /*#__PURE__*/_react["default"].createElement("div", {
className: "row"
}, y));
};
var MARGIN = {
top: 0,
bottom: 0,
left: 0,
right: 0
};
function LineChartFactory() {
var LineChart = function LineChart(_ref2) {
var brushComponent = _ref2.brushComponent,
brushing = _ref2.brushing,
color = _ref2.color,
enableChartHover = _ref2.enableChartHover,
height = _ref2.height,
hoveredDP = _ref2.hoveredDP,
isEnlarged = _ref2.isEnlarged,
lineChart = _ref2.lineChart,
margin = _ref2.margin,
onMouseMove = _ref2.onMouseMove,
width = _ref2.width,
timezone = _ref2.timezone,
timeFormat = _ref2.timeFormat;
var series = lineChart.series,
yDomain = lineChart.yDomain;
var brushData = (0, _react.useMemo)(function () {
return [{
x: series[0].x,
y: yDomain[1],
customComponent: function customComponent() {
return brushComponent;
}
}];
}, [series, yDomain, brushComponent]);
var hintFormatter = (0, _react.useMemo)(function () {
return (0, _dataUtils.datetimeFormatter)(timezone)(timeFormat);
}, [timezone, timeFormat]);
return /*#__PURE__*/_react["default"].createElement(LineChartWrapper, {
style: {
marginTop: "".concat(margin.top, "px")
}
}, /*#__PURE__*/_react["default"].createElement(_reactVis.XYPlot, {
xType: "time",
width: width,
height: height,
margin: MARGIN,
onMouseLeave: function onMouseLeave() {
onMouseMove(null);
}
}, /*#__PURE__*/_react["default"].createElement(_reactVis.HorizontalGridLines, {
tickTotal: 3
}), /*#__PURE__*/_react["default"].createElement(_reactVis.LineSeries, {
style: {
fill: 'none'
},
strokeWidth: 2,
color: color,
data: series,
onNearestX: enableChartHover ? onMouseMove : null
}), /*#__PURE__*/_react["default"].createElement(_reactVis.MarkSeries, {
data: hoveredDP ? [hoveredDP] : [],
color: color,
size: 3
}), /*#__PURE__*/_react["default"].createElement(_reactVis.CustomSVGSeries, {
data: brushData
}), isEnlarged && /*#__PURE__*/_react["default"].createElement(_reactVis.YAxis, {
tickTotal: 3
}), hoveredDP && enableChartHover && !brushing ? /*#__PURE__*/_react["default"].createElement(_reactVis.Hint, {
value: hoveredDP
}, /*#__PURE__*/_react["default"].createElement(HintContent, (0, _extends2["default"])({}, hoveredDP, {
format: hintFormatter
}))) : null));
};
return LineChart;
}
var _default = LineChartFactory;
exports["default"] = _default;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/common/line-chart.js"],"names":["LineChartWrapper","styled","div","props","theme","histogramFillOutRange","textColor","StyledHint","textColorLT","HintContent","x","y","format","MARGIN","top","bottom","left","right","LineChartFactory","LineChart","brushComponent","brushing","color","enableChartHover","height","hoveredDP","isEnlarged","lineChart","margin","onMouseMove","width","timezone","timeFormat","series","yDomain","brushData","customComponent","hintFormatter","marginTop","fill"],"mappings":";;;;;;;;;;;;;;;AAoBA;;AACA;;AASA;;AACA;;;;AAEA,IAAMA,gBAAgB,GAAGC,6BAAOC,GAAV,obAWR,UAAAC,KAAK;AAAA,SAAIA,KAAK,CAACC,KAAN,CAAYC,qBAAhB;AAAA,CAXG,EAiBV,UAAAF,KAAK;AAAA,SAAIA,KAAK,CAACC,KAAN,CAAYE,SAAhB;AAAA,CAjBK,CAAtB;;AAqBA,IAAMC,UAAU,GAAGN,6BAAOC,GAAV,uQAGL,UAAAC,KAAK;AAAA,SAAIA,KAAK,CAACC,KAAN,CAAYI,WAAhB;AAAA,CAHA,CAAhB;;AAWA,IAAMC,WAAW,GAAG,SAAdA,WAAc;AAAA,MAAEC,CAAF,QAAEA,CAAF;AAAA,MAAKC,CAAL,QAAKA,CAAL;AAAA,MAAQC,MAAR,QAAQA,MAAR;AAAA,sBAClB,gCAAC,UAAD,qBACE;AAAK,IAAA,SAAS,EAAC;AAAf,KAA0BA,MAAM,CAACF,CAAD,CAAhC,CADF,eAEE;AAAK,IAAA,SAAS,EAAC;AAAf,KAAsBC,CAAtB,CAFF,CADkB;AAAA,CAApB;;AAOA,IAAME,MAAM,GAAG;AAACC,EAAAA,GAAG,EAAE,CAAN;AAASC,EAAAA,MAAM,EAAE,CAAjB;AAAoBC,EAAAA,IAAI,EAAE,CAA1B;AAA6BC,EAAAA,KAAK,EAAE;AAApC,CAAf;;AACA,SAASC,gBAAT,GAA4B;AAC1B,MAAMC,SAAS,GAAG,SAAZA,SAAY,QAcZ;AAAA,QAbJC,cAaI,SAbJA,cAaI;AAAA,QAZJC,QAYI,SAZJA,QAYI;AAAA,QAXJC,KAWI,SAXJA,KAWI;AAAA,QAVJC,gBAUI,SAVJA,gBAUI;AAAA,QATJC,MASI,SATJA,MASI;AAAA,QARJC,SAQI,SARJA,SAQI;AAAA,QAPJC,UAOI,SAPJA,UAOI;AAAA,QANJC,SAMI,SANJA,SAMI;AAAA,QALJC,MAKI,SALJA,MAKI;AAAA,QAJJC,WAII,SAJJA,WAII;AAAA,QAHJC,KAGI,SAHJA,KAGI;AAAA,QAFJC,QAEI,SAFJA,QAEI;AAAA,QADJC,UACI,SADJA,UACI;AAAA,QACGC,MADH,GACsBN,SADtB,CACGM,MADH;AAAA,QACWC,OADX,GACsBP,SADtB,CACWO,OADX;AAGJ,QAAMC,SAAS,GAAG,oBAAQ,YAAM;AAC9B,aAAO,CAAC;AAACzB,QAAAA,CAAC,EAAEuB,MAAM,CAAC,CAAD,CAAN,CAAUvB,CAAd;AAAiBC,QAAAA,CAAC,EAAEuB,OAAO,CAAC,CAAD,CAA3B;AAAgCE,QAAAA,eAAe,EAAE;AAAA,iBAAMhB,cAAN;AAAA;AAAjD,OAAD,CAAP;AACD,KAFiB,EAEf,CAACa,MAAD,EAASC,OAAT,EAAkBd,cAAlB,CAFe,CAAlB;AAGA,QAAMiB,aAAa,GAAG,oBAAQ;AAAA,aAAM,kCAAkBN,QAAlB,EAA4BC,UAA5B,CAAN;AAAA,KAAR,EAAuD,CAC3ED,QAD2E,EAE3EC,UAF2E,CAAvD,CAAtB;AAKA,wBACE,gCAAC,gBAAD;AAAkB,MAAA,KAAK,EAAE;AAACM,QAAAA,SAAS,YAAKV,MAAM,CAACd,GAAZ;AAAV;AAAzB,oBACE,gCAAC,gBAAD;AACE,MAAA,KAAK,EAAC,MADR;AAEE,MAAA,KAAK,EAAEgB,KAFT;AAGE,MAAA,MAAM,EAAEN,MAHV;AAIE,MAAA,MAAM,EAAEX,MAJV;AAKE,MAAA,YAAY,EAAE,wBAAM;AAClBgB,QAAAA,WAAW,CAAC,IAAD,CAAX;AACD;AAPH,oBASE,gCAAC,6BAAD;AAAqB,MAAA,SAAS,EAAE;AAAhC,MATF,eAUE,gCAAC,oBAAD;AACE,MAAA,KAAK,EAAE;AAACU,QAAAA,IAAI,EAAE;AAAP,OADT;AAEE,MAAA,WAAW,EAAE,CAFf;AAGE,MAAA,KAAK,EAAEjB,KAHT;AAIE,MAAA,IAAI,EAAEW,MAJR;AAKE,MAAA,UAAU,EAAEV,gBAAgB,GAAGM,WAAH,GAAiB;AAL/C,MAVF,eAiBE,gCAAC,oBAAD;AAAY,MAAA,IAAI,EAAEJ,SAAS,GAAG,CAACA,SAAD,CAAH,GAAiB,EAA5C;AAAgD,MAAA,KAAK,EAAEH,KAAvD;AAA8D,MAAA,IAAI,EAAE;AAApE,MAjBF,eAkBE,gCAAC,yBAAD;AAAiB,MAAA,IAAI,EAAEa;AAAvB,MAlBF,EAmBGT,UAAU,iBAAI,gCAAC,eAAD;AAAO,MAAA,SAAS,EAAE;AAAlB,MAnBjB,EAoBGD,SAAS,IAAIF,gBAAb,IAAiC,CAACF,QAAlC,gBACC,gCAAC,cAAD;AAAM,MAAA,KAAK,EAAEI;AAAb,oBACE,gCAAC,WAAD,gCAAiBA,SAAjB;AAA4B,MAAA,MAAM,EAAEY;AAApC,OADF,CADD,GAIG,IAxBN,CADF,CADF;AA8BD,GAvDD;;AAwDA,SAAOlB,SAAP;AACD;;eAEcD,gB","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, {useMemo} from 'react';\nimport {\n  HorizontalGridLines,\n  LineSeries,\n  XYPlot,\n  CustomSVGSeries,\n  Hint,\n  YAxis,\n  MarkSeries\n} from 'react-vis';\nimport styled from 'styled-components';\nimport {datetimeFormatter} from 'utils/data-utils';\n\nconst LineChartWrapper = styled.div`\n  .rv-xy-plot {\n    /* important for rendering hint */\n    position: relative;\n  }\n  .rv-xy-plot__inner {\n    /* important to show axis */\n    overflow: visible;\n  }\n\n  .rv-xy-plot__grid-lines__line {\n    stroke: ${props => props.theme.histogramFillOutRange};\n    stroke-dasharray: 1px 4px;\n  }\n\n  .rv-xy-plot__axis__tick__text {\n    font-size: 9px;\n    fill: ${props => props.theme.textColor};\n  }\n`;\n\nconst StyledHint = styled.div`\n  background-color: #d3d8e0;\n  border-radius: 2px;\n  color: ${props => props.theme.textColorLT};\n  font-size: 9px;\n  margin: 4px;\n  padding: 3px 6px;\n  pointer-events: none;\n  user-select: none;\n`;\n\nconst HintContent = ({x, y, format}) => (\n  <StyledHint>\n    <div className=\"hint--x\">{format(x)}</div>\n    <div className=\"row\">{y}</div>\n  </StyledHint>\n);\n\nconst MARGIN = {top: 0, bottom: 0, left: 0, right: 0};\nfunction LineChartFactory() {\n  const LineChart = ({\n    brushComponent,\n    brushing,\n    color,\n    enableChartHover,\n    height,\n    hoveredDP,\n    isEnlarged,\n    lineChart,\n    margin,\n    onMouseMove,\n    width,\n    timezone,\n    timeFormat\n  }) => {\n    const {series, yDomain} = lineChart;\n\n    const brushData = useMemo(() => {\n      return [{x: series[0].x, y: yDomain[1], customComponent: () => brushComponent}];\n    }, [series, yDomain, brushComponent]);\n    const hintFormatter = useMemo(() => datetimeFormatter(timezone)(timeFormat), [\n      timezone,\n      timeFormat\n    ]);\n\n    return (\n      <LineChartWrapper style={{marginTop: `${margin.top}px`}}>\n        <XYPlot\n          xType=\"time\"\n          width={width}\n          height={height}\n          margin={MARGIN}\n          onMouseLeave={() => {\n            onMouseMove(null);\n          }}\n        >\n          <HorizontalGridLines tickTotal={3} />\n          <LineSeries\n            style={{fill: 'none'}}\n            strokeWidth={2}\n            color={color}\n            data={series}\n            onNearestX={enableChartHover ? onMouseMove : null}\n          />\n          <MarkSeries data={hoveredDP ? [hoveredDP] : []} color={color} size={3} />\n          <CustomSVGSeries data={brushData} />\n          {isEnlarged && <YAxis tickTotal={3} />}\n          {hoveredDP && enableChartHover && !brushing ? (\n            <Hint value={hoveredDP}>\n              <HintContent {...hoveredDP} format={hintFormatter} />\n            </Hint>\n          ) : null}\n        </XYPlot>\n      </LineChartWrapper>\n    );\n  };\n  return LineChart;\n}\n\nexport default LineChartFactory;\n"]}