UNPKG

kepler.gl

Version:

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

301 lines (250 loc) 28.4 kB
"use strict"; var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard"); var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); 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 _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck")); var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass")); var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn")); var _getPrototypeOf3 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf")); var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized")); var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits")); var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _react = _interopRequireWildcard(require("react")); var _propTypes = _interopRequireDefault(require("prop-types")); var _d3Scale = require("d3-scale"); var _moment = _interopRequireDefault(require("moment")); var _d3Array = require("d3-array"); var _reselect = require("reselect"); var _reactVis = require("react-vis"); var _styledComponents = _interopRequireDefault(require("styled-components")); var _classnames = _interopRequireDefault(require("classnames")); var _rangeBrush = _interopRequireDefault(require("./range-brush")); var _filterUtils = require("../../utils/filter-utils"); function _templateObject3() { var data = (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"]); _templateObject3 = function _templateObject3() { return data; }; return data; } function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2["default"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } function _templateObject2() { var data = (0, _taggedTemplateLiteral2["default"])(["\n .histogram-bars {\n rect {\n fill: ", ";\n }\n rect.in-range {\n fill: ", ";\n }\n }\n"]); _templateObject2 = function _templateObject2() { return data; }; return data; } function _templateObject() { var data = (0, _taggedTemplateLiteral2["default"])(["\n .rv-xy-plot__inner path {\n fill: none;\n stroke-width: 1.5;\n }\n"]); _templateObject = function _templateObject() { return data; }; return data; } var chartMargin = { top: 8, bottom: 0, left: 0, right: 0 }; var chartH = 52; var containerH = 68; var histogramStyle = { highlightW: 0.7, unHighlightedW: 0.4 }; var RangePlot = /*#__PURE__*/ function (_Component) { (0, _inherits2["default"])(RangePlot, _Component); function RangePlot() { var _getPrototypeOf2; var _this; (0, _classCallCheck2["default"])(this, RangePlot); for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { args[_key] = arguments[_key]; } _this = (0, _possibleConstructorReturn2["default"])(this, (_getPrototypeOf2 = (0, _getPrototypeOf3["default"])(RangePlot)).call.apply(_getPrototypeOf2, [this].concat(args))); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "state", { hoveredDP: null }); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "domainSelector", function (props) { return props.lineChart && props.lineChart.xDomain; }); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "hintFormatter", (0, _reselect.createSelector)(_this.domainSelector, function (domain) { return (0, _filterUtils.getTimeWidgetHintFormatter)(domain); })); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "onMouseMove", function (hoveredDP) { _this.setState({ hoveredDP: hoveredDP }); }); return _this; } (0, _createClass2["default"])(RangePlot, [{ key: "render", value: function render() { var _this$props = this.props, onBrush = _this$props.onBrush, range = _this$props.range, value = _this$props.value, width = _this$props.width, plotType = _this$props.plotType, lineChart = _this$props.lineChart, histogram = _this$props.histogram; var domain = [histogram[0].x0, histogram[histogram.length - 1].x1]; var brushComponent = _react["default"].createElement(_rangeBrush["default"], { domain: domain, onBrush: onBrush, range: range, value: value, width: width }); return _react["default"].createElement("div", { style: { height: "".concat(containerH, "px"), position: 'relative' } }, plotType === 'lineChart' ? _react["default"].createElement(LineChart, { hoveredDP: this.state.hoveredDP, width: width, height: containerH, margin: chartMargin, children: brushComponent, onMouseMove: this.onMouseMove, yDomain: lineChart.yDomain, hintFormat: this.hintFormatter(this.props), data: lineChart.series }) : _react["default"].createElement(Histogram, { width: width, height: chartH, value: value, margin: chartMargin, histogram: histogram, brushComponent: brushComponent })); } }]); return RangePlot; }(_react.Component); exports["default"] = RangePlot; (0, _defineProperty2["default"])(RangePlot, "propTypes", { value: _propTypes["default"].arrayOf(_propTypes["default"].number).isRequired, histogram: _propTypes["default"].arrayOf(_propTypes["default"].shape({ x0: _propTypes["default"].number, x1: _propTypes["default"].number })), lineChart: _propTypes["default"].object, plotType: _propTypes["default"].string, isEnlarged: _propTypes["default"].bool, onBlur: _propTypes["default"].func, width: _propTypes["default"].number.isRequired }); var Histogram = function Histogram(_ref) { var width = _ref.width, height = _ref.height, margin = _ref.margin, histogram = _ref.histogram, value = _ref.value, brushComponent = _ref.brushComponent; var domain = [histogram[0].x0, histogram[histogram.length - 1].x1]; var barWidth = width / histogram.length; var x = (0, _d3Scale.scaleLinear)().domain(domain).range([0, width]); var y = (0, _d3Scale.scaleLinear)().domain([0, (0, _d3Array.max)(histogram, function (d) { return d.count; })]).range([0, height]); return _react["default"].createElement(HistogramWrapper, { width: width, height: height, style: { marginTop: "".concat(margin.top, "px") } }, _react["default"].createElement("g", { className: "histogram-bars" }, histogram.map(function (bar) { var inRange = bar.x0 >= value[0] && bar.x1 <= value[1]; var wRatio = inRange ? histogramStyle.highlightW : histogramStyle.unHighlightedW; return _react["default"].createElement("rect", { className: (0, _classnames["default"])({ 'in-range': inRange }), key: bar.x0, height: y(bar.count), width: barWidth * wRatio, x: x(bar.x0) + barWidth * (1 - wRatio) / 2, rx: 1, ry: 1, y: height - y(bar.count) }); })), brushComponent); }; var LineChartWrapper = _styledComponents["default"].div(_templateObject()); var HistogramWrapper = _styledComponents["default"].svg(_templateObject2(), function (props) { return props.theme.histogramFillOutRange; }, function (props) { return props.theme.histogramFillInRange; }); var LineChart = function LineChart(_ref2) { var width = _ref2.width, height = _ref2.height, yDomain = _ref2.yDomain, hintFormat = _ref2.hintFormat, hoveredDP = _ref2.hoveredDP, margin = _ref2.margin, color = _ref2.color, data = _ref2.data, onMouseMove = _ref2.onMouseMove, children = _ref2.children; var brushData = [{ x: data[0].x, y: yDomain[1], customComponent: function customComponent() { return children; } }]; return _react["default"].createElement(LineChartWrapper, null, _react["default"].createElement(_reactVis.XYPlot, { width: width, height: height, margin: _objectSpread({}, margin, { bottom: 12 }) }, _react["default"].createElement(_reactVis.LineSeries, { strokeWidth: 2, color: color, data: data, onNearestX: onMouseMove }), _react["default"].createElement(_reactVis.MarkSeries, { data: hoveredDP ? [hoveredDP] : [], color: color, size: 3 }), _react["default"].createElement(_reactVis.CustomSVGSeries, { data: brushData }), hoveredDP ? _react["default"].createElement(_reactVis.Hint, { value: hoveredDP }, _react["default"].createElement(HintContent, (0, _extends2["default"])({}, hoveredDP, { format: function format(val) { return _moment["default"].utc(val).format(hintFormat); } }))) : null)); }; var StyledHint = _styledComponents["default"].div(_templateObject3(), function (props) { return props.theme.textColorLT; }); var HintContent = function HintContent(_ref3) { var x = _ref3.x, y = _ref3.y, format = _ref3.format; return _react["default"].createElement(StyledHint, null, _react["default"].createElement("div", { className: "hint--x" }, format(x)), _react["default"].createElement("div", { className: "row" }, y)); }; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/common/range-plot.js"],"names":["chartMargin","top","bottom","left","right","chartH","containerH","histogramStyle","highlightW","unHighlightedW","RangePlot","hoveredDP","props","lineChart","xDomain","domainSelector","domain","setState","onBrush","range","value","width","plotType","histogram","x0","length","x1","brushComponent","height","position","state","onMouseMove","yDomain","hintFormatter","series","Component","PropTypes","arrayOf","number","isRequired","shape","object","string","isEnlarged","bool","onBlur","func","Histogram","margin","barWidth","x","y","d","count","marginTop","map","bar","inRange","wRatio","LineChartWrapper","styled","div","HistogramWrapper","svg","theme","histogramFillOutRange","histogramFillInRange","LineChart","hintFormat","color","data","children","brushData","customComponent","val","moment","utc","format","StyledHint","textColorLT","HintContent"],"mappings":"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","sourcesContent":["// Copyright (c) 2020 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, {Component} from 'react';\nimport PropTypes from 'prop-types';\nimport {scaleLinear} from 'd3-scale';\nimport moment from 'moment';\nimport {max} from 'd3-array';\nimport {createSelector} from 'reselect';\nimport {LineSeries, XYPlot, CustomSVGSeries, Hint, MarkSeries} from 'react-vis';\nimport styled from 'styled-components';\nimport classnames from 'classnames';\n\nimport RangeBrush from './range-brush';\nimport {getTimeWidgetHintFormatter} from 'utils/filter-utils';\n\nconst chartMargin = {top: 8, bottom: 0, left: 0, right: 0};\nconst chartH = 52;\nconst containerH = 68;\nconst histogramStyle = {\n  highlightW: 0.7,\n  unHighlightedW: 0.4\n};\n\nexport default class RangePlot extends Component {\n  static propTypes = {\n    value: PropTypes.arrayOf(PropTypes.number).isRequired,\n    histogram: PropTypes.arrayOf(\n      PropTypes.shape({\n        x0: PropTypes.number,\n        x1: PropTypes.number\n      })\n    ),\n    lineChart: PropTypes.object,\n    plotType: PropTypes.string,\n    isEnlarged: PropTypes.bool,\n    onBlur: PropTypes.func,\n    width: PropTypes.number.isRequired\n  };\n\n  state = {\n    hoveredDP: null\n  };\n\n  domainSelector = props => props.lineChart && props.lineChart.xDomain;\n  hintFormatter = createSelector(this.domainSelector, domain => getTimeWidgetHintFormatter(domain));\n\n  onMouseMove = hoveredDP => {\n    this.setState({hoveredDP});\n  };\n\n  render() {\n    const {onBrush, range, value, width, plotType, lineChart, histogram} = this.props;\n    const domain = [histogram[0].x0, histogram[histogram.length - 1].x1];\n\n    const brushComponent = (\n      <RangeBrush domain={domain} onBrush={onBrush} range={range} value={value} width={width} />\n    );\n\n    return (\n      <div\n        style={{\n          height: `${containerH}px`,\n          position: 'relative'\n        }}\n      >\n        {plotType === 'lineChart' ? (\n          <LineChart\n            hoveredDP={this.state.hoveredDP}\n            width={width}\n            height={containerH}\n            margin={chartMargin}\n            children={brushComponent}\n            onMouseMove={this.onMouseMove}\n            yDomain={lineChart.yDomain}\n            hintFormat={this.hintFormatter(this.props)}\n            data={lineChart.series}\n          />\n        ) : (\n          <Histogram\n            width={width}\n            height={chartH}\n            value={value}\n            margin={chartMargin}\n            histogram={histogram}\n            brushComponent={brushComponent}\n          />\n        )}\n      </div>\n    );\n  }\n}\n\nconst Histogram = ({width, height, margin, histogram, value, brushComponent}) => {\n  const domain = [histogram[0].x0, histogram[histogram.length - 1].x1];\n  const barWidth = width / histogram.length;\n\n  const x = scaleLinear()\n    .domain(domain)\n    .range([0, width]);\n\n  const y = scaleLinear()\n    .domain([0, max(histogram, d => d.count)])\n    .range([0, height]);\n\n  return (\n    <HistogramWrapper width={width} height={height} style={{marginTop: `${margin.top}px`}}>\n      <g className=\"histogram-bars\">\n        {histogram.map(bar => {\n          const inRange = bar.x0 >= value[0] && bar.x1 <= value[1];\n          const wRatio = inRange ? histogramStyle.highlightW : histogramStyle.unHighlightedW;\n\n          return (\n            <rect\n              className={classnames({'in-range': inRange})}\n              key={bar.x0}\n              height={y(bar.count)}\n              width={barWidth * wRatio}\n              x={x(bar.x0) + (barWidth * (1 - wRatio)) / 2}\n              rx={1}\n              ry={1}\n              y={height - y(bar.count)}\n            />\n          );\n        })}\n      </g>\n      {brushComponent}\n    </HistogramWrapper>\n  );\n};\n\nconst LineChartWrapper = styled.div`\n  .rv-xy-plot__inner path {\n    fill: none;\n    stroke-width: 1.5;\n  }\n`;\n\nconst HistogramWrapper = styled.svg`\n  .histogram-bars {\n    rect {\n      fill: ${props => props.theme.histogramFillOutRange};\n    }\n    rect.in-range {\n      fill: ${props => props.theme.histogramFillInRange};\n    }\n  }\n`;\nconst LineChart = ({\n  width,\n  height,\n  yDomain,\n  hintFormat,\n  hoveredDP,\n  margin,\n  color,\n  data,\n  onMouseMove,\n  children\n}) => {\n  const brushData = [{x: data[0].x, y: yDomain[1], customComponent: () => children}];\n\n  return (\n    <LineChartWrapper>\n      <XYPlot width={width} height={height} margin={{...margin, bottom: 12}}>\n        <LineSeries strokeWidth={2} color={color} data={data} onNearestX={onMouseMove} />\n        <MarkSeries data={hoveredDP ? [hoveredDP] : []} color={color} size={3} />\n        <CustomSVGSeries data={brushData} />\n        {hoveredDP ? (\n          <Hint value={hoveredDP}>\n            <HintContent {...hoveredDP} format={val => moment.utc(val).format(hintFormat)} />\n          </Hint>\n        ) : null}\n      </XYPlot>\n    </LineChartWrapper>\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`;\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"]}