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