UNPKG

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