kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
234 lines (232 loc) • 42.9 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _typeof = require("@babel/runtime/helpers/typeof");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = exports.HISTOGRAM_MASK_MODE = void 0;
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
var _react = _interopRequireWildcard(require("react"));
var _d3Scale = require("d3-scale");
var _d3Color = require("d3-color");
var _d3Array = require("d3-array");
var _styledComponents = _interopRequireDefault(require("styled-components"));
var _templateObject, _templateObject2, _templateObject3; // 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; }
// clipping mask constants
var HISTOGRAM_MASK_MODE = exports.HISTOGRAM_MASK_MODE = {
NoMask: 0,
Mask: 1,
MaskWithOverlay: 2
};
var HISTOGRAM_MASK_BGCOLOR = '#FFFFFF';
var HISTOGRAM_MASK_FGCOLOR = '#000000';
var histogramStyle = {
highlightW: 0.7,
unHighlightedW: 0.4
};
var HistogramWrapper = _styledComponents["default"].svg(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n overflow: visible;\n"])));
var HistogramMaskRect = _styledComponents["default"].rect(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n fill: ", ";\n"])), function (props) {
return props.theme.panelBackground;
});
var HistogramBreakLine = _styledComponents["default"].g(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n stroke: ", ";\n stroke-width: 1px;\n transform: translate(0, 0);\n"])), function (props) {
return props.theme.histogramBreakLineColor;
});
var BarUnmemoized = _styledComponents["default"].rect(function (_ref) {
var theme = _ref.theme,
$inRange = _ref.$inRange,
$isOverlay = _ref.$isOverlay,
$color = _ref.$color;
return "\n ".concat($isOverlay ? "fill: ".concat($color !== null && $color !== void 0 ? $color : theme.histogramOverlayColor, ";") : $inRange ? "fill: ".concat($color !== null && $color !== void 0 ? $color : theme.histogramFillInRange, ";") : "fill: ".concat($color ? (0, _d3Color.hcl)($color).darker() : theme.histogramFillOutRange, ";"), "\n");
});
var Bar = /*#__PURE__*/_react["default"].memo(BarUnmemoized);
Bar.displayName = 'Bar';
var isBarInRange = function isBarInRange(bar, index, list, filterDomain, filterValue) {
// first
// if x0 <= domain[0] and current value[0] wasn't changed from the original domain
var x0Condition = index === 0 ? bar.x0 <= filterDomain[0] && filterDomain[0] === filterValue[0] : false;
// Last
// if x1 >= domain[1] and current value[1] wasn't changed from the original domain
var x1Condition = index === list.length - 1 ? bar.x1 >= filterDomain[1] && filterDomain[1] === filterValue[1] : false;
return (x0Condition || bar.x0 >= filterValue[0]) && (x1Condition || bar.x1 <= filterValue[1]);
};
function HistogramPlotFactory() {
var HistogramPlot = function HistogramPlot(_ref2) {
var width = _ref2.width,
height = _ref2.height,
histogramsByGroup = _ref2.histogramsByGroup,
colorsByGroup = _ref2.colorsByGroup,
_ref2$isMasked = _ref2.isMasked,
isMasked = _ref2$isMasked === void 0 ? HISTOGRAM_MASK_MODE.NoMask : _ref2$isMasked,
_ref2$countProp = _ref2.countProp,
countProp = _ref2$countProp === void 0 ? 'count' : _ref2$countProp,
margin = _ref2.margin,
isRanged = _ref2.isRanged,
range = _ref2.range,
value = _ref2.value,
brushComponent = _ref2.brushComponent,
breakLines = _ref2.breakLines;
var undefinedToZero = function undefinedToZero(x) {
return x ? x : 0;
};
var groupKeys = (0, _react.useMemo)(function () {
return Object.keys(histogramsByGroup)
// only keep non-empty groups
.filter(function (key) {
var _histogramsByGroup$ke;
return ((_histogramsByGroup$ke = histogramsByGroup[key]) === null || _histogramsByGroup$ke === void 0 ? void 0 : _histogramsByGroup$ke.length) > 0;
});
}, [histogramsByGroup]);
var domain = (0, _react.useMemo)(function () {
var _min, _max;
return range !== null && range !== void 0 ? range : [(_min = (0, _d3Array.min)(groupKeys, function (key) {
return histogramsByGroup[key][0].x0;
})) !== null && _min !== void 0 ? _min : 0, (_max = (0, _d3Array.max)(groupKeys, function (key) {
return histogramsByGroup[key][histogramsByGroup[key].length - 1].x1;
})) !== null && _max !== void 0 ? _max : 0];
}, [range, histogramsByGroup, groupKeys]);
var barWidth = (0, _react.useMemo)(function () {
if (groupKeys.length === 0) return 0;
// find histogramsByGroup with max number of bins
var maxGroup = groupKeys.reduce(function (accu, key, _idx) {
if (histogramsByGroup[key].length > accu.length) {
return histogramsByGroup[key];
}
return accu;
}, histogramsByGroup[groupKeys[0]]);
// find the bin for measuring step
var stdBinIdx = maxGroup.length > 1 ? 1 : 0;
var xStep = maxGroup[stdBinIdx].x1 - maxGroup[stdBinIdx].x0;
var maxBins = (domain[1] - domain[0]) / xStep;
if (!maxBins) return 0;
return width / maxBins / (isMasked ? 1 : groupKeys.length);
}, [histogramsByGroup, domain, groupKeys, width, isMasked]);
var x = (0, _react.useMemo)(function () {
return (0, _d3Scale.scaleLinear)().domain(domain).range([barWidth, width]);
}, [domain, width, barWidth]);
var y = (0, _react.useMemo)(function () {
return (0, _d3Scale.scaleLinear)().domain([0, Math.max(Number((0, _d3Array.max)(groupKeys, function (key) {
return (0, _d3Array.max)(histogramsByGroup[key], function (d) {
return d[countProp];
});
})), 1)]).range([0, height]);
}, [histogramsByGroup, groupKeys, height, countProp]);
if (groupKeys.length === 0) {
return null;
}
var maskedHistogram = function maskedHistogram() {
return /*#__PURE__*/_react["default"].createElement(HistogramWrapper, {
width: width,
height: height,
style: {
margin: "".concat(margin.top, "px ").concat(margin.right, "px ").concat(margin.bottom, "px ").concat(margin.left, "px")
}
}, /*#__PURE__*/_react["default"].createElement("defs", null, /*#__PURE__*/_react["default"].createElement("mask", {
id: "histogram-mask"
}, /*#__PURE__*/_react["default"].createElement("rect", {
x: "0",
y: "0",
width: width,
height: height + margin.bottom,
fill: HISTOGRAM_MASK_BGCOLOR
}), /*#__PURE__*/_react["default"].createElement("g", {
key: "filtered-bins",
className: "histogram-bars"
}, histogramsByGroup.filteredBins.map(function (bar, idx, list) {
var inRange = isBarInRange(bar, idx, list, domain, value);
var wRatio = inRange ? histogramStyle.highlightW : histogramStyle.unHighlightedW;
return /*#__PURE__*/_react["default"].createElement(Bar, {
$isOverlay: false,
$inRange: inRange,
$color: HISTOGRAM_MASK_FGCOLOR,
key: "mask-".concat(idx),
height: y(bar[countProp]),
width: barWidth * wRatio,
x: x(bar.x0) + barWidth * (1 - wRatio) / 2,
y: height - y(bar[countProp])
});
})))), /*#__PURE__*/_react["default"].createElement("g", {
transform: "translate(0,0)"
}, /*#__PURE__*/_react["default"].createElement(HistogramMaskRect, {
x: "0",
y: "0",
width: "100%",
height: height + margin.bottom,
mask: "url(#histogram-mask)"
})), isMasked === HISTOGRAM_MASK_MODE.MaskWithOverlay && /*#__PURE__*/_react["default"].createElement("g", {
key: "bins",
transform: "translate(0,0)",
className: "overlay-histogram-bars"
}, histogramsByGroup.bins.map(function (bar, idx, list) {
var filterBar = histogramsByGroup.filteredBins[idx];
var maskHeight = filterBar ? y(bar[countProp]) - y(filterBar[countProp]) : y(bar[countProp]);
var inRange = isBarInRange(bar, idx, list, domain, value);
var wRatio = inRange ? histogramStyle.highlightW : histogramStyle.unHighlightedW;
return /*#__PURE__*/_react["default"].createElement(Bar, {
$inRange: inRange,
$isOverlay: true,
key: "bar-".concat(idx),
height: maskHeight,
width: barWidth * wRatio,
x: x(bar.x0) + barWidth * (1 - wRatio) / 2,
y: height - y(bar[countProp])
});
})), /*#__PURE__*/_react["default"].createElement(HistogramBreakLine, null, (breakLines !== null && breakLines !== void 0 ? breakLines : []).map(function (pos, idx) {
return /*#__PURE__*/_react["default"].createElement("path", {
key: "mask-line-".concat(idx),
strokeDasharray: "4,4",
d: "M".concat(pos, ", 0 l0 100")
});
})), /*#__PURE__*/_react["default"].createElement("g", {
transform: "translate(".concat(isRanged ? 0 : barWidth / 2, ", 0)")
}, brushComponent));
};
return isMasked ? maskedHistogram() : /*#__PURE__*/_react["default"].createElement(HistogramWrapper, {
width: width,
height: height,
style: {
margin: "".concat(margin.top, "px ").concat(margin.right, "px ").concat(margin.bottom, "px ").concat(margin.left, "px")
}
}, /*#__PURE__*/_react["default"].createElement("g", null, groupKeys.map(function (key, i) {
return /*#__PURE__*/_react["default"].createElement("g", {
key: key,
className: "histogram-bars"
}, histogramsByGroup[key].map(function (bar, idx, list) {
var inRange = isBarInRange(bar, idx, list, domain, value);
var wRatio = inRange ? histogramStyle.highlightW : histogramStyle.unHighlightedW;
var startX = x(undefinedToZero(bar.x0)) + barWidth * i + barWidth * (1 - wRatio) / 2;
if (startX > 0 && startX + barWidth * histogramStyle.unHighlightedW <= width) {
return /*#__PURE__*/_react["default"].createElement(Bar, {
$isOverlay: false,
$inRange: inRange,
$color: colorsByGroup === null || colorsByGroup === void 0 ? void 0 : colorsByGroup[key],
key: "bar-".concat(idx),
height: y(bar[countProp]),
width: barWidth * wRatio,
x: startX,
rx: 1,
ry: 1,
y: height - y(bar[countProp])
});
}
return null;
}));
})), /*#__PURE__*/_react["default"].createElement("g", {
transform: "translate(".concat(isRanged ? 0 : barWidth / 2, ", 0)")
}, brushComponent));
};
var HistogramPlotWithGroups = function HistogramPlotWithGroups(props) {
var groups = (0, _react.useMemo)(function () {
return props.histogramsByGroup ? Object.keys(props.histogramsByGroup) : null;
}, [props.histogramsByGroup]);
if (!(groups !== null && groups !== void 0 && groups.length)) {
return null;
}
return /*#__PURE__*/_react["default"].createElement(HistogramPlot, props);
};
return HistogramPlotWithGroups;
}
var _default = exports["default"] = HistogramPlotFactory;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_d3Scale","_d3Color","_d3Array","_styledComponents","_interopRequireDefault","_templateObject","_templateObject2","_templateObject3","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","HISTOGRAM_MASK_MODE","exports","NoMask","Mask","MaskWithOverlay","HISTOGRAM_MASK_BGCOLOR","HISTOGRAM_MASK_FGCOLOR","histogramStyle","highlightW","unHighlightedW","HistogramWrapper","styled","svg","_taggedTemplateLiteral2","HistogramMaskRect","rect","props","theme","panelBackground","HistogramBreakLine","g","histogramBreakLineColor","BarUnmemoized","_ref","$inRange","$isOverlay","$color","concat","histogramOverlayColor","histogramFillInRange","hcl","darker","histogramFillOutRange","Bar","React","memo","displayName","isBarInRange","bar","index","list","filterDomain","filterValue","x0Condition","x0","x1Condition","length","x1","HistogramPlotFactory","HistogramPlot","_ref2","width","height","histogramsByGroup","colorsByGroup","_ref2$isMasked","isMasked","_ref2$countProp","countProp","margin","isRanged","range","value","brushComponent","breakLines","undefinedToZero","x","groupKeys","useMemo","keys","filter","key","_histogramsByGroup$ke","domain","_min","_max","min","max","barWidth","maxGroup","reduce","accu","_idx","stdBinIdx","xStep","maxBins","scaleLinear","y","Math","Number","d","maskedHistogram","createElement","style","top","right","bottom","left","id","fill","className","filteredBins","map","idx","inRange","wRatio","transform","mask","bins","filterBar","maskHeight","pos","strokeDasharray","startX","rx","ry","HistogramPlotWithGroups","groups","_default"],"sources":["../../src/common/histogram-plot.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React, {ReactElement, useMemo} from 'react';\nimport {scaleLinear} from 'd3-scale';\nimport {hcl} from 'd3-color';\nimport {min, max} from 'd3-array';\nimport styled from 'styled-components';\n\nimport {Bins} from '@kepler.gl/types';\n\n// clipping mask constants\nexport const HISTOGRAM_MASK_MODE = {\n  NoMask: 0,\n  Mask: 1,\n  MaskWithOverlay: 2\n};\nconst HISTOGRAM_MASK_BGCOLOR = '#FFFFFF';\nconst HISTOGRAM_MASK_FGCOLOR = '#000000';\n\nconst histogramStyle = {\n  highlightW: 0.7,\n  unHighlightedW: 0.4\n};\n\nconst HistogramWrapper = styled.svg`\n  overflow: visible;\n`;\n\nconst HistogramMaskRect = styled.rect`\n  fill: ${props => props.theme.panelBackground};\n`;\n\nconst HistogramBreakLine = styled.g`\n  stroke: ${props => props.theme.histogramBreakLineColor};\n  stroke-width: 1px;\n  transform: translate(0, 0);\n`;\n\ntype BarType = {\n  $inRange: boolean;\n  $isOverlay: boolean;\n  $color?: string;\n};\nconst BarUnmemoized = styled.rect<BarType>(\n  ({theme, $inRange, $isOverlay, $color}) => `\n  ${\n    $isOverlay\n      ? `fill: ${$color ?? theme.histogramOverlayColor};`\n      : $inRange\n      ? `fill: ${$color ?? theme.histogramFillInRange};`\n      : `fill: ${$color ? hcl($color).darker() : theme.histogramFillOutRange};`\n  }\n`\n);\nconst Bar = React.memo(BarUnmemoized);\nBar.displayName = 'Bar';\n\nconst isBarInRange = (\n  bar: {x0: number; x1: number},\n  index: number,\n  list: any[],\n  filterDomain: any[],\n  filterValue: any[]\n) => {\n  // first\n  // if x0 <= domain[0] and current value[0] wasn't changed from the original domain\n  const x0Condition =\n    index === 0 ? bar.x0 <= filterDomain[0] && filterDomain[0] === filterValue[0] : false;\n  // Last\n  // if x1 >= domain[1] and current value[1] wasn't changed from the original domain\n  const x1Condition =\n    index === list.length - 1\n      ? bar.x1 >= filterDomain[1] && filterDomain[1] === filterValue[1]\n      : false;\n  return (x0Condition || bar.x0 >= filterValue[0]) && (x1Condition || bar.x1 <= filterValue[1]);\n};\n\nexport type HistogramMaskModeType = {\n  NoMask: number;\n  Mask: number;\n  MaskWithOverlay: number;\n};\n\ninterface HistogramPlotProps {\n  width: number;\n  height: number;\n  margin: {top: number; bottom: number; left: number; right: number};\n  isRanged?: boolean;\n  value: number[];\n  isMasked?: number;\n  brushComponent?: ReactElement;\n  histogramsByGroup: Bins;\n  colorsByGroup?: null | {[dataId: string]: string};\n  countProp?: string;\n  range?: number[];\n  breakLines?: number[];\n}\n\nfunction HistogramPlotFactory() {\n  const HistogramPlot = ({\n    width,\n    height,\n    histogramsByGroup,\n    colorsByGroup,\n    isMasked = HISTOGRAM_MASK_MODE.NoMask,\n    countProp = 'count',\n    margin,\n    isRanged,\n    range,\n    value,\n    brushComponent,\n    breakLines\n  }: HistogramPlotProps) => {\n    const undefinedToZero = (x: number | undefined) => (x ? x : 0);\n    const groupKeys = useMemo(\n      () =>\n        Object.keys(histogramsByGroup)\n          // only keep non-empty groups\n          .filter(key => histogramsByGroup[key]?.length > 0),\n      [histogramsByGroup]\n    );\n\n    const domain = useMemo(\n      () =>\n        range ?? [\n          min(groupKeys, key => histogramsByGroup[key][0].x0) ?? 0,\n          max(groupKeys, key => histogramsByGroup[key][histogramsByGroup[key].length - 1].x1) ?? 0\n        ],\n      [range, histogramsByGroup, groupKeys]\n    );\n\n    const barWidth = useMemo(() => {\n      if (groupKeys.length === 0) return 0;\n      // find histogramsByGroup with max number of bins\n      const maxGroup = groupKeys.reduce((accu, key, _idx) => {\n        if (histogramsByGroup[key].length > accu.length) {\n          return histogramsByGroup[key];\n        }\n        return accu;\n      }, histogramsByGroup[groupKeys[0]]);\n\n      // find the bin for measuring step\n      const stdBinIdx = maxGroup.length > 1 ? 1 : 0;\n      const xStep = maxGroup[stdBinIdx].x1 - maxGroup[stdBinIdx].x0;\n      const maxBins = (domain[1] - domain[0]) / xStep;\n      if (!maxBins) return 0;\n      return width / maxBins / (isMasked ? 1 : groupKeys.length);\n    }, [histogramsByGroup, domain, groupKeys, width, isMasked]);\n\n    const x = useMemo(\n      () => scaleLinear().domain(domain).range([barWidth, width]),\n      [domain, width, barWidth]\n    );\n\n    const y = useMemo(\n      () =>\n        scaleLinear()\n          .domain([\n            0,\n            Math.max(\n              Number(max(groupKeys, key => max(histogramsByGroup[key], d => d[countProp]))),\n              1\n            )\n          ])\n          .range([0, height]),\n      [histogramsByGroup, groupKeys, height, countProp]\n    );\n\n    if (groupKeys.length === 0) {\n      return null;\n    }\n\n    const maskedHistogram = () => {\n      return (\n        <HistogramWrapper\n          width={width}\n          height={height}\n          style={{margin: `${margin.top}px ${margin.right}px ${margin.bottom}px ${margin.left}px`}}\n        >\n          <defs>\n            <mask id=\"histogram-mask\">\n              <rect\n                x=\"0\"\n                y=\"0\"\n                width={width}\n                height={height + margin.bottom}\n                fill={HISTOGRAM_MASK_BGCOLOR}\n              />\n              <g key=\"filtered-bins\" className=\"histogram-bars\">\n                {histogramsByGroup.filteredBins.map((bar, idx, list) => {\n                  const inRange = isBarInRange(bar, idx, list, domain, value);\n                  const wRatio = inRange\n                    ? histogramStyle.highlightW\n                    : histogramStyle.unHighlightedW;\n                  return (\n                    <Bar\n                      $isOverlay={false}\n                      $inRange={inRange}\n                      $color={HISTOGRAM_MASK_FGCOLOR}\n                      key={`mask-${idx}`}\n                      height={y(bar[countProp])}\n                      width={barWidth * wRatio}\n                      x={x(bar.x0) + (barWidth * (1 - wRatio)) / 2}\n                      y={height - y(bar[countProp])}\n                    />\n                  );\n                })}\n              </g>\n            </mask>\n          </defs>\n          <g transform=\"translate(0,0)\">\n            <HistogramMaskRect\n              x=\"0\"\n              y=\"0\"\n              width=\"100%\"\n              height={height + margin.bottom}\n              mask=\"url(#histogram-mask)\"\n            />\n          </g>\n          {isMasked === HISTOGRAM_MASK_MODE.MaskWithOverlay && (\n            <g key=\"bins\" transform=\"translate(0,0)\" className=\"overlay-histogram-bars\">\n              {histogramsByGroup.bins.map((bar, idx, list) => {\n                const filterBar = histogramsByGroup.filteredBins[idx];\n                const maskHeight = filterBar\n                  ? y(bar[countProp]) - y(filterBar[countProp])\n                  : y(bar[countProp]);\n                const inRange = isBarInRange(bar, idx, list, domain, value);\n                const wRatio = inRange ? histogramStyle.highlightW : histogramStyle.unHighlightedW;\n                return (\n                  <Bar\n                    $inRange={inRange}\n                    $isOverlay={true}\n                    key={`bar-${idx}`}\n                    height={maskHeight}\n                    width={barWidth * wRatio}\n                    x={x(bar.x0) + (barWidth * (1 - wRatio)) / 2}\n                    y={height - y(bar[countProp])}\n                  />\n                );\n              })}\n            </g>\n          )}\n          <HistogramBreakLine>\n            {(breakLines ?? []).map((pos, idx) => {\n              return (\n                <path key={`mask-line-${idx}`} strokeDasharray=\"4,4\" d={`M${pos}, 0 l0 100`} />\n              );\n            })}\n          </HistogramBreakLine>\n          <g transform={`translate(${isRanged ? 0 : barWidth / 2}, 0)`}>{brushComponent}</g>\n        </HistogramWrapper>\n      );\n    };\n\n    return isMasked ? (\n      maskedHistogram()\n    ) : (\n      <HistogramWrapper\n        width={width}\n        height={height}\n        style={{margin: `${margin.top}px ${margin.right}px ${margin.bottom}px ${margin.left}px`}}\n      >\n        <g>\n          {groupKeys.map((key, i) => (\n            <g key={key} className=\"histogram-bars\">\n              {histogramsByGroup[key].map((bar, idx, list) => {\n                const inRange = isBarInRange(bar, idx, list, domain, value);\n\n                const wRatio = inRange ? histogramStyle.highlightW : histogramStyle.unHighlightedW;\n                const startX =\n                  x(undefinedToZero(bar.x0)) + barWidth * i + (barWidth * (1 - wRatio)) / 2;\n                if (startX > 0 && startX + barWidth * histogramStyle.unHighlightedW <= width) {\n                  return (\n                    <Bar\n                      $isOverlay={false}\n                      $inRange={inRange}\n                      $color={colorsByGroup?.[key]}\n                      key={`bar-${idx}`}\n                      height={y(bar[countProp])}\n                      width={barWidth * wRatio}\n                      x={startX}\n                      rx={1}\n                      ry={1}\n                      y={height - y(bar[countProp])}\n                    />\n                  );\n                }\n                return null;\n              })}\n            </g>\n          ))}\n        </g>\n        <g transform={`translate(${isRanged ? 0 : barWidth / 2}, 0)`}>{brushComponent}</g>\n      </HistogramWrapper>\n    );\n  };\n\n  const HistogramPlotWithGroups = props => {\n    const groups = useMemo(\n      () => (props.histogramsByGroup ? Object.keys(props.histogramsByGroup) : null),\n      [props.histogramsByGroup]\n    );\n\n    if (!groups?.length) {\n      return null;\n    }\n\n    return <HistogramPlot {...props} />;\n  };\n\n  return HistogramPlotWithGroups;\n}\nexport default HistogramPlotFactory;\n"],"mappings":"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","ignoreList":[]}