kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
148 lines (119 loc) • 18 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = RangePlotFactory;
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
var _react = _interopRequireWildcard(require("react"));
var _propTypes = _interopRequireDefault(require("prop-types"));
var _styledComponents = _interopRequireWildcard(require("styled-components"));
var _rangeBrush = _interopRequireDefault(require("./range-brush"));
var _histogramPlot = _interopRequireDefault(require("./histogram-plot"));
var _lineChart = _interopRequireDefault(require("./line-chart"));
var _utils = require("../../utils/utils");
var _templateObject;
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; }
var StyledRangePlot = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n margin-bottom: ", "px;\n display: flex;\n position: 'relative';\n"])), function (props) {
return props.theme.sliderBarHeight;
});
RangePlotFactory.deps = [_rangeBrush["default"], _histogramPlot["default"], _lineChart["default"]];
function RangePlotFactory(RangeBrush, HistogramPlot, LineChart) {
var RangePlot = function RangePlot(_ref) {
var onBrush = _ref.onBrush,
range = _ref.range,
value = _ref.value,
width = _ref.width,
plotType = _ref.plotType,
lineChart = _ref.lineChart,
histogram = _ref.histogram,
isEnlarged = _ref.isEnlarged,
isRanged = _ref.isRanged,
theme = _ref.theme,
chartProps = (0, _objectWithoutProperties2["default"])(_ref, ["onBrush", "range", "value", "width", "plotType", "lineChart", "histogram", "isEnlarged", "isRanged", "theme"]);
var _useState = (0, _react.useState)(false),
_useState2 = (0, _slicedToArray2["default"])(_useState, 2),
brushing = _useState2[0],
setBrushing = _useState2[1];
var _useState3 = (0, _react.useState)(null),
_useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
hoveredDP = _useState4[0],
onMouseMove = _useState4[1];
var _useState5 = (0, _react.useState)(false),
_useState6 = (0, _slicedToArray2["default"])(_useState5, 2),
enableChartHover = _useState6[0],
setEnableChartHover = _useState6[1];
var height = isEnlarged ? theme.rangePlotHLarge : theme.rangePlotH;
var onBrushStart = (0, _react.useCallback)(function () {
setBrushing(true);
onMouseMove(null);
setEnableChartHover(false);
}, [setBrushing, onMouseMove, setEnableChartHover]);
var onBrushEnd = (0, _react.useCallback)(function () {
setBrushing(false);
setEnableChartHover(true);
}, [setBrushing, setEnableChartHover]);
var onMouseoverHandle = (0, _react.useCallback)(function () {
onMouseMove(null);
setEnableChartHover(false);
}, [onMouseMove, setEnableChartHover]);
var onMouseoutHandle = (0, _react.useCallback)(function () {
setEnableChartHover(true);
}, [setEnableChartHover]); // JsDom have limited support for SVG, d3 will fail
var brushComponent = (0, _utils.isTest)() ? null : /*#__PURE__*/_react["default"].createElement(RangeBrush, (0, _extends2["default"])({
onBrush: onBrush,
onBrushStart: onBrushStart,
onBrushEnd: onBrushEnd,
range: range,
value: value,
width: width,
height: height,
isRanged: isRanged,
onMouseoverHandle: onMouseoverHandle,
onMouseoutHandle: onMouseoutHandle
}, chartProps));
var commonProps = _objectSpread({
width: width,
value: value,
height: height,
margin: isEnlarged ? theme.rangePlotMarginLarge : theme.rangePlotMargin,
brushComponent: brushComponent,
brushing: brushing,
isEnlarged: isEnlarged,
enableChartHover: enableChartHover,
onMouseMove: onMouseMove,
hoveredDP: hoveredDP,
isRanged: isRanged
}, chartProps);
return /*#__PURE__*/_react["default"].createElement(StyledRangePlot, {
style: {
height: "".concat(isEnlarged ? theme.rangePlotContainerHLarge : theme.rangePlotContainerH, "px")
},
className: "kg-range-slider__plot"
}, plotType === 'lineChart' && lineChart ? /*#__PURE__*/_react["default"].createElement(LineChart, (0, _extends2["default"])({
lineChart: lineChart
}, commonProps)) : /*#__PURE__*/_react["default"].createElement(HistogramPlot, (0, _extends2["default"])({
histogram: histogram
}, commonProps)));
};
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
};
return (0, _styledComponents.withTheme)(RangePlot);
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/common/range-plot.js"],"names":["StyledRangePlot","styled","div","props","theme","sliderBarHeight","RangePlotFactory","deps","RangeBrushFactory","HistogramPlotFactory","LineChartFactory","RangeBrush","HistogramPlot","LineChart","RangePlot","onBrush","range","value","width","plotType","lineChart","histogram","isEnlarged","isRanged","chartProps","brushing","setBrushing","hoveredDP","onMouseMove","enableChartHover","setEnableChartHover","height","rangePlotHLarge","rangePlotH","onBrushStart","onBrushEnd","onMouseoverHandle","onMouseoutHandle","brushComponent","commonProps","margin","rangePlotMarginLarge","rangePlotMargin","rangePlotContainerHLarge","rangePlotContainerH","propTypes","PropTypes","arrayOf","number","isRequired","shape","x0","x1","object","string","bool","onBlur","func"],"mappings":"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","sourcesContent":["// Copyright (c) 2021 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, {useState, useCallback} from 'react';\nimport PropTypes from 'prop-types';\nimport styled, {withTheme} from 'styled-components';\nimport RangeBrushFactory from './range-brush';\nimport HistogramPlotFactory from './histogram-plot';\nimport LineChartFactory from './line-chart';\nimport {isTest} from 'utils/utils';\n\nconst StyledRangePlot = styled.div`\n  margin-bottom: ${props => props.theme.sliderBarHeight}px;\n  display: flex;\n  position: 'relative';\n`;\n\nRangePlotFactory.deps = [RangeBrushFactory, HistogramPlotFactory, LineChartFactory];\n\nexport default function RangePlotFactory(RangeBrush, HistogramPlot, LineChart) {\n  const RangePlot = ({\n    onBrush,\n    range,\n    value,\n    width,\n    plotType,\n    lineChart,\n    histogram,\n    isEnlarged,\n    isRanged,\n    theme,\n    ...chartProps\n  }) => {\n    const [brushing, setBrushing] = useState(false);\n    const [hoveredDP, onMouseMove] = useState(null);\n    const [enableChartHover, setEnableChartHover] = useState(false);\n    const height = isEnlarged ? theme.rangePlotHLarge : theme.rangePlotH;\n\n    const onBrushStart = useCallback(() => {\n      setBrushing(true);\n      onMouseMove(null);\n      setEnableChartHover(false);\n    }, [setBrushing, onMouseMove, setEnableChartHover]);\n\n    const onBrushEnd = useCallback(() => {\n      setBrushing(false);\n      setEnableChartHover(true);\n    }, [setBrushing, setEnableChartHover]);\n\n    const onMouseoverHandle = useCallback(() => {\n      onMouseMove(null);\n      setEnableChartHover(false);\n    }, [onMouseMove, setEnableChartHover]);\n\n    const onMouseoutHandle = useCallback(() => {\n      setEnableChartHover(true);\n    }, [setEnableChartHover]);\n\n    // JsDom have limited support for SVG, d3 will fail\n    const brushComponent = isTest() ? null : (\n      <RangeBrush\n        onBrush={onBrush}\n        onBrushStart={onBrushStart}\n        onBrushEnd={onBrushEnd}\n        range={range}\n        value={value}\n        width={width}\n        height={height}\n        isRanged={isRanged}\n        onMouseoverHandle={onMouseoverHandle}\n        onMouseoutHandle={onMouseoutHandle}\n        {...chartProps}\n      />\n    );\n\n    const commonProps = {\n      width,\n      value,\n      height,\n      margin: isEnlarged ? theme.rangePlotMarginLarge : theme.rangePlotMargin,\n      brushComponent,\n      brushing,\n      isEnlarged,\n      enableChartHover,\n      onMouseMove,\n      hoveredDP,\n      isRanged,\n      ...chartProps\n    };\n\n    return (\n      <StyledRangePlot\n        style={{\n          height: `${isEnlarged ? theme.rangePlotContainerHLarge : theme.rangePlotContainerH}px`\n        }}\n        className=\"kg-range-slider__plot\"\n      >\n        {plotType === 'lineChart' && lineChart ? (\n          <LineChart lineChart={lineChart} {...commonProps} />\n        ) : (\n          <HistogramPlot histogram={histogram} {...commonProps} />\n        )}\n      </StyledRangePlot>\n    );\n  };\n\n  RangePlot.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  return withTheme(RangePlot);\n}\n"]}