kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
216 lines (213 loc) • 34.5 kB
JavaScript
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _typeof = require("@babel/runtime/helpers/typeof");
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 _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("@kepler.gl/utils");
var _constants = require("@kepler.gl/constants");
var _loadingSpinner = _interopRequireDefault(require("./loading-spinner"));
var _styles = require("@kepler.gl/styles");
var _excluded = ["bins", "onBrush", "range", "value", "width", "plotType", "lineChart", "isEnlarged", "isRanged", "theme"],
_excluded2 = ["lineChart", "plotType", "bins", "setFilterPlot", "isEnlarged", "theme"];
var _templateObject; // SPDX-License-Identifier: MIT
// Copyright contributors to the kepler.gl project
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; }
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty2["default"])(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
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"]];
var isHistogramPlot = function isHistogramPlot(plotType) {
return (plotType === null || plotType === void 0 ? void 0 : plotType.type) === _constants.PLOT_TYPES.histogram;
};
var isLineChart = function isLineChart(plotType) {
return (plotType === null || plotType === void 0 ? void 0 : plotType.type) === _constants.PLOT_TYPES.lineChart;
};
var hasHistogram = function hasHistogram(plotType, bins) {
return isHistogramPlot(plotType) && bins;
};
var hasLineChart = function hasLineChart(plotType, lineChart) {
return isLineChart(plotType) && lineChart;
};
var LOADING_SPINNER_CONTAINER_STYLE = {
display: 'flex',
alignItems: 'center',
justifyContent: 'center',
width: '100%'
};
function RangePlotFactory(RangeBrush, HistogramPlot, LineChartPlot) {
var RangePlot = function RangePlot(_ref) {
var bins = _ref.bins,
onBrush = _ref.onBrush,
range = _ref.range,
value = _ref.value,
width = _ref.width,
plotType = _ref.plotType,
lineChart = _ref.lineChart,
isEnlarged = _ref.isEnlarged,
isRanged = _ref.isRanged,
theme = _ref.theme,
chartProps = (0, _objectWithoutProperties2["default"])(_ref, _excluded);
var groupColors = (0, _react.useMemo)(function () {
var dataIds = bins ? Object.keys(bins) : [];
return plotType.colorsByDataId ? dataIds.reduce(function (acc, dataId) {
acc[dataId] = plotType.colorsByDataId[dataId];
return acc;
}, {}) : null;
}, [bins, plotType.colorsByDataId]);
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 ? (0, _utils.hasMobileWidth)(_styles.breakPointValues) ? theme.rangePlotHLargePalm : 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,
onBrush: onBrush
}, chartProps);
return isLineChart(plotType) && lineChart ? /*#__PURE__*/_react["default"].createElement(LineChartPlot, (0, _extends2["default"])({
lineChart: lineChart
}, commonProps)) : /*#__PURE__*/_react["default"].createElement(HistogramPlot, (0, _extends2["default"])({
histogramsByGroup: bins,
colorsByGroup: groupColors,
range: range
}, commonProps));
};
var RangePlotWithTheme = (0, _styledComponents.withTheme)(RangePlot);
// a container to render spinner or message when the data is too big
// to generate a plot
var WithPlotLoading = function WithPlotLoading(_ref2) {
var lineChart = _ref2.lineChart,
plotType = _ref2.plotType,
bins = _ref2.bins,
setFilterPlot = _ref2.setFilterPlot,
isEnlarged = _ref2.isEnlarged,
theme = _ref2.theme,
otherProps = (0, _objectWithoutProperties2["default"])(_ref2, _excluded2);
var _useState7 = (0, _react.useState)(false),
_useState8 = (0, _slicedToArray2["default"])(_useState7, 2),
isLoading = _useState8[0],
setIsLoading = _useState8[1];
var isChangingRef = (0, _react.useRef)(false);
(0, _react.useEffect)(function () {
if (isChangingRef.current) {
if (hasHistogram(plotType, bins)) {
// Bins are loaded
isChangingRef.current = false;
}
} else {
if (!plotType || isHistogramPlot(plotType) && !bins) {
// load histogram
setIsLoading(true);
setFilterPlot({
plotType: {
type: _constants.PLOT_TYPES.histogram
}
});
isChangingRef.current = true;
}
}
}, [bins, plotType, setFilterPlot]);
(0, _react.useEffect)(function () {
if (isChangingRef.current) {
if (hasLineChart(plotType, lineChart)) {
// Line chart is loaded
isChangingRef.current = false;
}
} else {
if (isLineChart(plotType) && !lineChart) {
// load line chart
setIsLoading(true);
setFilterPlot({
plotType: {
type: _constants.PLOT_TYPES.lineChart
}
});
isChangingRef.current = true;
}
}
}, [lineChart, plotType, setFilterPlot]);
var rangePlotStyle = (0, _react.useMemo)(function () {
return {
height: "".concat(isEnlarged ? (0, _utils.hasMobileWidth)(_styles.breakPointValues) ? theme.rangePlotContainerHLargePalm : theme.rangePlotContainerHLarge : theme.rangePlotContainerH, "px")
};
}, [isEnlarged, theme]);
return /*#__PURE__*/_react["default"].createElement(StyledRangePlot, {
style: rangePlotStyle,
className: "kg-range-slider__plot"
}, isLoading ? /*#__PURE__*/_react["default"].createElement("div", {
style: LOADING_SPINNER_CONTAINER_STYLE
}, /*#__PURE__*/_react["default"].createElement(_loadingSpinner["default"], {
borderColor: "transparent",
size: 40
})) : /*#__PURE__*/_react["default"].createElement(RangePlotWithTheme, (0, _extends2["default"])({
lineChart: lineChart,
bins: bins,
plotType: plotType,
isEnlarged: isEnlarged,
theme: theme
}, otherProps)));
};
return (0, _styledComponents.withTheme)(WithPlotLoading);
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_styledComponents","_rangeBrush","_interopRequireDefault","_histogramPlot","_lineChart","_utils","_constants","_loadingSpinner","_styles","_excluded","_excluded2","_templateObject","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","ownKeys","keys","getOwnPropertySymbols","o","filter","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","StyledRangePlot","styled","div","_taggedTemplateLiteral2","props","theme","sliderBarHeight","RangePlotFactory","deps","RangeBrushFactory","HistogramPlotFactory","LineChartFactory","isHistogramPlot","plotType","type","PLOT_TYPES","histogram","isLineChart","lineChart","hasHistogram","bins","hasLineChart","LOADING_SPINNER_CONTAINER_STYLE","display","alignItems","justifyContent","width","RangeBrush","HistogramPlot","LineChartPlot","RangePlot","_ref","onBrush","range","value","isEnlarged","isRanged","chartProps","_objectWithoutProperties2","groupColors","useMemo","dataIds","colorsByDataId","reduce","acc","dataId","_useState","useState","_useState2","_slicedToArray2","brushing","setBrushing","_useState3","_useState4","hoveredDP","onMouseMove","_useState5","_useState6","enableChartHover","setEnableChartHover","height","hasMobileWidth","breakPointValues","rangePlotHLargePalm","rangePlotHLarge","rangePlotH","onBrushStart","useCallback","onBrushEnd","onMouseoverHandle","onMouseoutHandle","brushComponent","isTest","createElement","_extends2","commonProps","margin","rangePlotMarginLarge","rangePlotMargin","histogramsByGroup","colorsByGroup","RangePlotWithTheme","withTheme","WithPlotLoading","_ref2","setFilterPlot","otherProps","_useState7","_useState8","isLoading","setIsLoading","isChangingRef","useRef","useEffect","current","rangePlotStyle","concat","rangePlotContainerHLargePalm","rangePlotContainerHLarge","rangePlotContainerH","style","className","borderColor","size"],"sources":["../../src/common/range-plot.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React, {useCallback, useEffect, useMemo, useRef, useState, CSSProperties} from 'react';\nimport styled, {withTheme} from 'styled-components';\nimport RangeBrushFactory, {OnBrush, RangeBrushProps} from './range-brush';\nimport HistogramPlotFactory from './histogram-plot';\nimport LineChartFactory, {HoverDP} from './line-chart';\nimport {hasMobileWidth, isTest} from '@kepler.gl/utils';\nimport {PLOT_TYPES} from '@kepler.gl/constants';\nimport LoadingSpinner from './loading-spinner';\nimport {breakPointValues} from '@kepler.gl/styles';\nimport {LineChart as LineChartType, Filter, Bins} from '@kepler.gl/types';\nimport {Datasets} from '@kepler.gl/table';\n\nconst StyledRangePlot = styled.div`\n  margin-bottom: ${props => props.theme.sliderBarHeight}px;\n  display: flex;\n  position: relative;\n`;\n\ninterface RangePlotProps {\n  onBrush: OnBrush;\n  range: number[];\n  value: number[];\n  width: number;\n  plotType: {\n    [key: string]: any;\n  };\n  lineChart?: LineChartType;\n  bins?: Bins;\n\n  isEnlarged?: boolean;\n  isRanged?: boolean;\n  theme: any;\n  timeFormat?: string;\n  timezone?: string | null;\n  playbackControlWidth?: number;\n\n  animationWindow?: string;\n  filter?: Filter;\n  datasets?: Datasets;\n\n  invertTrendColor?: boolean;\n\n  style: CSSProperties;\n}\n\ntype WithPlotLoadingProps = RangePlotProps &\n  Partial<RangeBrushProps> & {\n    setFilterPlot: any;\n  };\n\nRangePlotFactory.deps = [RangeBrushFactory, HistogramPlotFactory, LineChartFactory];\n\nconst isHistogramPlot = plotType => plotType?.type === PLOT_TYPES.histogram;\nconst isLineChart = plotType => plotType?.type === PLOT_TYPES.lineChart;\nconst hasHistogram = (plotType, bins) => isHistogramPlot(plotType) && bins;\nconst hasLineChart = (plotType, lineChart) => isLineChart(plotType) && lineChart;\n\nconst LOADING_SPINNER_CONTAINER_STYLE = {\n  display: 'flex',\n  alignItems: 'center',\n  justifyContent: 'center',\n  width: '100%'\n};\n\nexport default function RangePlotFactory(\n  RangeBrush: ReturnType<typeof RangeBrushFactory>,\n  HistogramPlot: ReturnType<typeof HistogramPlotFactory>,\n  LineChartPlot: ReturnType<typeof LineChartFactory>\n) {\n  const RangePlot = ({\n    bins,\n    onBrush,\n    range,\n    value,\n    width,\n    plotType,\n    lineChart,\n    isEnlarged,\n    isRanged,\n    theme,\n    ...chartProps\n  }: RangePlotProps & Partial<RangeBrushProps>) => {\n    const groupColors = useMemo(() => {\n      const dataIds = bins ? Object.keys(bins) : [];\n      return plotType.colorsByDataId\n        ? dataIds.reduce((acc, dataId) => {\n            acc[dataId] = plotType.colorsByDataId[dataId];\n            return acc;\n          }, {})\n        : null;\n    }, [bins, plotType.colorsByDataId]);\n\n    const [brushing, setBrushing] = useState(false);\n    const [hoveredDP, onMouseMove] = useState<HoverDP | null>(null);\n    const [enableChartHover, setEnableChartHover] = useState(false);\n    const height = isEnlarged\n      ? hasMobileWidth(breakPointValues)\n        ? theme.rangePlotHLargePalm\n        : theme.rangePlotHLarge\n      : 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      onBrush,\n      ...chartProps\n    };\n\n    return isLineChart(plotType) && lineChart ? (\n      <LineChartPlot lineChart={lineChart} {...commonProps} />\n    ) : (\n      <HistogramPlot\n        histogramsByGroup={bins}\n        colorsByGroup={groupColors}\n        range={range}\n        {...commonProps}\n      />\n    );\n  };\n\n  const RangePlotWithTheme = withTheme(RangePlot) as React.FC<\n    RangePlotProps & Partial<RangeBrushProps>\n  >;\n\n  // a container to render spinner or message when the data is too big\n  // to generate a plot\n  const WithPlotLoading = ({\n    lineChart,\n    plotType,\n    bins,\n    setFilterPlot,\n    isEnlarged,\n    theme,\n    ...otherProps\n  }: WithPlotLoadingProps) => {\n    const [isLoading, setIsLoading] = useState(false);\n    const isChangingRef = useRef(false);\n\n    useEffect(() => {\n      if (isChangingRef.current) {\n        if (hasHistogram(plotType, bins)) {\n          // Bins are loaded\n          isChangingRef.current = false;\n        }\n      } else {\n        if (!plotType || (isHistogramPlot(plotType) && !bins)) {\n          // load histogram\n          setIsLoading(true);\n          setFilterPlot({plotType: {type: PLOT_TYPES.histogram}});\n          isChangingRef.current = true;\n        }\n      }\n    }, [bins, plotType, setFilterPlot]);\n\n    useEffect(() => {\n      if (isChangingRef.current) {\n        if (hasLineChart(plotType, lineChart)) {\n          // Line chart is loaded\n          isChangingRef.current = false;\n        }\n      } else {\n        if (isLineChart(plotType) && !lineChart) {\n          // load line chart\n          setIsLoading(true);\n          setFilterPlot({plotType: {type: PLOT_TYPES.lineChart}});\n          isChangingRef.current = true;\n        }\n      }\n    }, [lineChart, plotType, setFilterPlot]);\n\n    const rangePlotStyle = useMemo(\n      () => ({\n        height: `${\n          isEnlarged\n            ? hasMobileWidth(breakPointValues)\n              ? theme.rangePlotContainerHLargePalm\n              : theme.rangePlotContainerHLarge\n            : theme.rangePlotContainerH\n        }px`\n      }),\n      [isEnlarged, theme]\n    );\n\n    return (\n      <StyledRangePlot style={rangePlotStyle} className=\"kg-range-slider__plot\">\n        {isLoading ? (\n          <div style={LOADING_SPINNER_CONTAINER_STYLE}>\n            <LoadingSpinner borderColor=\"transparent\" size={40} />\n          </div>\n        ) : (\n          <RangePlotWithTheme\n            lineChart={lineChart}\n            bins={bins}\n            plotType={plotType}\n            isEnlarged={isEnlarged}\n            theme={theme}\n            {...otherProps}\n          />\n        )}\n      </StyledRangePlot>\n    );\n  };\n\n  return withTheme(WithPlotLoading) as React.FC<Omit<WithPlotLoadingProps, 'theme'>>;\n}\n"],"mappings":"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","ignoreList":[]}
;