UNPKG

kepler.gl.geoiq

Version:

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

286 lines (239 loc) 28 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 _rangeBrush = _interopRequireDefault(require("./range-brush")); var _filterUtils = require("../../utils/filter-utils"); var _base = require("../../styles/base"); function _templateObject2() { 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"]); _templateObject2 = function _templateObject2() { 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 _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: 18, bottom: 0, left: 0, right: 0 }; var chartH = 52; var containerH = 78; var histogramStyle = { highlightW: 0.7, unHighlightedW: 0.4, highlightedColor: _base.theme.activeColor, unHighlightedColor: _base.theme.sliderBarColor }; 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("svg", { 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 fill = inRange ? histogramStyle.highlightedColor : histogramStyle.unHighlightedColor; var wRatio = inRange ? histogramStyle.highlightW : histogramStyle.unHighlightedW; return _react["default"].createElement("rect", { key: bar.x0, fill: fill, 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 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(_templateObject2(), 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","highlightedColor","theme","activeColor","unHighlightedColor","sliderBarColor","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","fill","wRatio","LineChartWrapper","styled","div","LineChart","hintFormat","color","data","children","brushData","customComponent","val","moment","utc","format","StyledHint","textColorLT","HintContent"],"mappings":"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","sourcesContent":["// Copyright (c) 2019 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 RangeBrush from './range-brush';\nimport {getTimeWidgetHintFormatter} from 'utils/filter-utils';\nimport {theme} from 'styles/base';\n\nconst chartMargin = {top: 18, bottom: 0, left: 0, right: 0};\nconst chartH = 52;\nconst containerH = 78;\nconst histogramStyle = {\n  highlightW: 0.7,\n  unHighlightedW: 0.4,\n  highlightedColor: theme.activeColor,\n  unHighlightedColor: theme.sliderBarColor\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 =>\n    getTimeWidgetHintFormatter(domain)\n  );\n\n  onMouseMove = hoveredDP => {\n    this.setState({hoveredDP});\n  };\n\n  render() {\n    const {\n      onBrush,\n      range,\n      value,\n      width,\n      plotType,\n      lineChart,\n      histogram\n    } = this.props;\n    const domain = [histogram[0].x0, histogram[histogram.length - 1].x1];\n\n    const brushComponent = (\n      <RangeBrush\n        domain={domain}\n        onBrush={onBrush}\n        range={range}\n        value={value}\n        width={width}\n      />\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 = ({\n  width,\n  height,\n  margin,\n  histogram,\n  value,\n  brushComponent\n}) => {\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    <svg 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 fill = inRange ? histogramStyle.highlightedColor : histogramStyle.unHighlightedColor;\n          const wRatio = inRange ? histogramStyle.highlightW : histogramStyle.unHighlightedW;\n\n          return (\n            <rect\n              key={bar.x0}\n              fill={fill}\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    </svg>\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 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 = [\n    {x: data[0].x, y: yDomain[1], customComponent: () => children}\n  ];\n\n  return (\n    <LineChartWrapper>\n      <XYPlot width={width} height={height} margin={{...margin, bottom: 12}}>\n        <LineSeries\n          strokeWidth={2}\n          color={color}\n          data={data}\n          onNearestX={onMouseMove}\n        />\n        <MarkSeries\n          data={hoveredDP ? [hoveredDP] : []}\n          color={color}\n          size={3}\n        />\n        <CustomSVGSeries data={brushData} />\n        {hoveredDP ? (\n          <Hint value={hoveredDP}>\n            <HintContent\n              {...hoveredDP}\n              format={val => moment.utc(val).format(hintFormat)}\n            />\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"]}