UNPKG

kepler.gl

Version:

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

120 lines (119 loc) 20.3 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); var _typeof = require("@babel/runtime/helpers/typeof"); 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 _utils = require("@kepler.gl/utils"); var _templateObject, _templateObject2; // 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" != _typeof(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 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 LineChartComponent = function LineChartComponent(_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 _ref3 = lineChart || {}, yDomain = _ref3.yDomain, xDomain = _ref3.xDomain; // @ts-expect-error seems lineChart.series has ambiguous types. Requires refactoring. var series = lineChart === null || lineChart === void 0 ? void 0 : lineChart.series; var paddedYDomain = (0, _react.useMemo)(function () { return yDomain && yDomain[0] && yDomain[1] ? [yDomain[0], yDomain[1] + (yDomain[1] - yDomain[0]) * 0.2] : []; }, [yDomain]); var brushData = (0, _react.useMemo)(function () { return xDomain && paddedYDomain ? [{ x: xDomain[0], y: paddedYDomain[1], customComponent: function customComponent() { return brushComponent; } }] : []; }, [xDomain, paddedYDomain, brushComponent]); var hintFormatter = (0, _react.useMemo)(function () { return (0, _utils.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); }, yDomain: paddedYDomain, xDomain: xDomain }, /*#__PURE__*/_react["default"].createElement(_reactVis.HorizontalGridLines, { tickTotal: 3 }), series.lines.map(function (d, i) { return /*#__PURE__*/_react["default"].createElement(_reactVis.LineSeries, { key: i, style: { fill: 'none' }, color: color, data: d, onNearestX: series.markers.length || !enableChartHover ? undefined : onMouseMove }); }), /*#__PURE__*/_react["default"].createElement(_reactVis.MarkSeries, { data: hoveredDP ? [hoveredDP] : [], color: color }), /*#__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 LineChartComponent; } var _default = exports["default"] = LineChartFactory; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_reactVis","_styledComponents","_interopRequireDefault","_utils","_templateObject","_templateObject2","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","LineChartWrapper","styled","div","_taggedTemplateLiteral2","props","theme","histogramFillOutRange","textColor","StyledHint","textColorLT","HintContent","_ref","x","y","format","createElement","className","MARGIN","top","bottom","left","right","LineChartFactory","LineChartComponent","_ref2","brushComponent","brushing","color","enableChartHover","height","hoveredDP","isEnlarged","lineChart","margin","onMouseMove","width","timezone","timeFormat","_ref3","yDomain","xDomain","series","paddedYDomain","useMemo","brushData","customComponent","hintFormatter","datetimeFormatter","style","marginTop","concat","XYPlot","xType","onMouseLeave","HorizontalGridLines","tickTotal","lines","map","d","LineSeries","key","fill","data","onNearestX","markers","length","undefined","MarkSeries","CustomSVGSeries","YAxis","Hint","value","_extends2","_default","exports"],"sources":["../../src/common/line-chart.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React, {useMemo} from 'react';\nimport {\n  HorizontalGridLines,\n  LineSeries,\n  XYPlot,\n  CustomSVGSeries,\n  Hint,\n  YAxis,\n  MarkSeries,\n  LineSeriesPoint,\n  RVNearestXData\n} from 'react-vis';\nimport {LineChart} from '@kepler.gl/types';\nimport styled from 'styled-components';\nimport {datetimeFormatter} from '@kepler.gl/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\ninterface HintContentProps {\n  x: number;\n  y: number;\n  format: (ts: number) => string;\n}\n\nconst HintContent = ({x, y, format}: HintContentProps) => (\n  <StyledHint>\n    <div className=\"hint--x\">{format(x)}</div>\n    <div className=\"row\">{y}</div>\n  </StyledHint>\n);\n\nexport interface HoverDP {\n  x: number;\n  y: number;\n  color?: string | number;\n  opacity?: string | number;\n  stroke?: string | number;\n  fill?: string | number;\n  size?: string | number;\n}\n\ninterface LineChartProps {\n  brushComponent?: any;\n  brushing?: boolean;\n  color?: string;\n  enableChartHover?: boolean;\n  height: number;\n  hoveredDP?: HoverDP | null;\n  isEnlarged?: boolean;\n  lineChart?: LineChart;\n  margin: {top?: number; bottom?: number; left?: number; right?: number};\n  onMouseMove: (datapoint: LineSeriesPoint | null, data?: RVNearestXData<LineSeriesPoint>) => void;\n  width: number;\n  timezone?: string | null;\n  timeFormat?: string;\n}\n\nconst MARGIN = {top: 0, bottom: 0, left: 0, right: 0};\nfunction LineChartFactory() {\n  const LineChartComponent = ({\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  }: LineChartProps) => {\n    const {yDomain, xDomain} = lineChart || {};\n    // @ts-expect-error seems lineChart.series has ambiguous types. Requires refactoring.\n    const series: {lines: any[]; markers: any[]} = lineChart?.series;\n\n    const paddedYDomain = useMemo(\n      () =>\n        yDomain && yDomain[0] && yDomain[1]\n          ? [yDomain[0], yDomain[1] + (yDomain[1] - yDomain[0]) * 0.2]\n          : [],\n      [yDomain]\n    );\n    const brushData = useMemo(() => {\n      return xDomain && paddedYDomain\n        ? [\n            {\n              x: xDomain[0],\n              y: paddedYDomain[1],\n              customComponent: () => brushComponent\n            }\n          ]\n        : [];\n    }, [xDomain, paddedYDomain, brushComponent]);\n\n    const hintFormatter = useMemo(\n      () => datetimeFormatter(timezone)(timeFormat),\n      [timezone, 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          yDomain={paddedYDomain}\n          xDomain={xDomain}\n        >\n          <HorizontalGridLines tickTotal={3} />\n          {series.lines.map((d, i) => (\n            <LineSeries\n              key={i}\n              style={{fill: 'none'}}\n              color={color}\n              data={d}\n              onNearestX={series.markers.length || !enableChartHover ? undefined : onMouseMove}\n            />\n          ))}\n          <MarkSeries data={hoveredDP ? [hoveredDP] : []} color={color} />\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 LineChartComponent;\n}\n\nexport default LineChartFactory;\n"],"mappings":"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","ignoreList":[]}