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
JavaScript
"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"]}