@vizzly/dashboard 0.14.4-dev-470d6f9c95d1b6422dbe1be22378ce12cdf6580a → 0.14.4-dev-8beb4cd0b38350abdd05b93b66f2523ced40aa15

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (23) hide show
  1. package/dist/charts/src/v2/components/AreaChart/AreaChart.d.ts +22 -0
  2. package/dist/charts/src/v2/components/AreaChart/contants.d.ts +1 -0
  3. package/dist/charts/src/v2/components/AreaChart/index.d.ts +1 -0
  4. package/dist/charts/src/v2/components/BarChart/getBarFill.d.ts +2 -4
  5. package/dist/charts/src/v2/components/Legend/Legend.d.ts +2 -1
  6. package/dist/charts/src/v2/components/Legend/LegendItem/LegendItem.d.ts +2 -1
  7. package/dist/charts/src/v2/components/Legend/LegendItemBox/LegendItemBox.d.ts +3 -0
  8. package/dist/charts/src/v2/components/Threshold/ThresholdArea.d.ts +14 -0
  9. package/dist/charts/src/v2/components/Threshold/threshold.utils.d.ts +4 -0
  10. package/dist/charts/src/v2/components/Tooltip/CrosshairCircle.d.ts +20 -0
  11. package/dist/charts/src/v2/components/Tooltip/Line.d.ts +7 -0
  12. package/dist/charts/src/v2/components/Tooltip/Tooltip.d.ts +2 -1
  13. package/dist/charts/src/v2/components/hooks/useFlattenedData.d.ts +1 -3
  14. package/dist/charts/src/v2/components/hooks/useVisibleKey.d.ts +6 -0
  15. package/dist/charts/src/v2/utils/useableId.d.ts +1 -0
  16. package/dist/dashboard.cjs.development.js +401 -80
  17. package/dist/dashboard.cjs.production.min.js +1 -1
  18. package/dist/dashboard.esm.js +406 -82
  19. package/dist/shared-logic/src/AreaChartV2/types.d.ts +12 -0
  20. package/dist/shared-logic/src/BubbleChart/getAxisFormattingFunction.d.ts +1 -1
  21. package/dist/shared-logic/src/ChartsV2/getAxisFormattingFunction.d.ts +1 -1
  22. package/dist/shared-logic/src/ChartsV2/types.d.ts +3 -0
  23. package/package.json +1 -1
@@ -34,7 +34,7 @@ import { LegendItem as LegendItem$1, LegendLabel } from '@visx/legend';
34
34
  import { scaleOrdinal, scaleQuantize, scalePoint, scaleTime, scaleLinear, scaleBand } from '@visx/scale';
35
35
  import Ordinal from '@visx/legend/lib/legends/Ordinal';
36
36
  import { curveNatural, curveMonotoneX, curveMonotoneY, curveLinear, curveStep, curveStepBefore, curveStepAfter } from '@visx/curve';
37
- import { Line, LinePath, BarGroup as BarGroup$1, BarStack as BarStack$1 } from '@visx/shape';
37
+ import { Line as Line$1, LinePath, BarGroup as BarGroup$1, BarStack as BarStack$1 } from '@visx/shape';
38
38
  import { Mercator, Graticule } from '@visx/geo';
39
39
  import { feature } from 'topojson-client';
40
40
  import ParentSize$1 from '@visx/responsive/lib/components/ParentSize';
@@ -48,7 +48,6 @@ import { useWindowWidth } from '@react-hook/window-size';
48
48
  import copy from 'copy-to-clipboard';
49
49
  import html2canvas from 'html2canvas';
50
50
  import jsPDF from 'jspdf';
51
- import { BubbleChart as BubbleChart$3 } from './charts/src/BubbleChart';
52
51
  import { RectClipPath } from '@visx/clip-path';
53
52
  import { localPoint } from '@visx/event';
54
53
  import { bisector } from '@visx/vendor/d3-array';
@@ -9331,7 +9330,7 @@ var BubbleChart = function BubbleChart(config) {
9331
9330
 
9332
9331
  var attributesSchema$f = function attributesSchema(config) {
9333
9332
  return Joi.object(_extends({}, baseAttributesSchema(config.attributesSchemaOptions), timeDimensionQuerySchema(config.queryEngineConfig, config.attributesSchemaOptions), {
9334
- stacked: Joi.valid(true, false, '100%'),
9333
+ stacked: Joi.valid(true, false),
9335
9334
  legend: Joi.valid(true, false),
9336
9335
  type: Joi.valid('barChartV2').required(),
9337
9336
  parameters: parametersSchema(config.queryEngineConfig, config.attributesSchemaOptions),
@@ -32026,7 +32025,7 @@ var ChartGoalLine = /*#__PURE__*/memo(function (props) {
32026
32025
  var height = 16;
32027
32026
  var triangleWidth = 8;
32028
32027
  return jsxs("g", {
32029
- children: [jsx(Line, {
32028
+ children: [jsx(Line$1, {
32030
32029
  from: {
32031
32030
  x: 0,
32032
32031
  y: y
@@ -40784,6 +40783,259 @@ var IconText = function IconText(props) {
40784
40783
  });
40785
40784
  };
40786
40785
 
40786
+ var accessors$1 = function accessors(xAxisIsTime, xKey, yKey, horizontal) {
40787
+ return {
40788
+ xAccessor: function xAccessor(d) {
40789
+ return d ? horizontal ? d[yKey] : xAxisIsTime ? new Date(d[xKey]) : d[xKey] : undefined;
40790
+ },
40791
+ yAccessor: function yAccessor(d) {
40792
+ return d ? horizontal ? xAxisIsTime ? new Date(d[xKey]) : d[xKey] : d[yKey] : undefined;
40793
+ }
40794
+ };
40795
+ };
40796
+ var DEFAULT_Y_AXIS_LABEL_COUNT$1 = 5;
40797
+ var VizzlyBubbleChart = function VizzlyBubbleChart(props) {
40798
+ var _props$height, _theme$axis$stroke, _theme$axis, _ref, _props$lines$data$len, _props$lines, _props$areas, _props$bars, _props$forceXAxisAsTi, _props$bars2, _props$lines2, _theme$grid$stroke, _theme$grid, _props$axisTitles, _props$axisTitles2, _props$axisTitles3, _props$axisTitles4, _props$bars3, _props$bars4, _props$bars5;
40799
+ var height = adjustHeight((_props$height = props == null ? void 0 : props.height) != null ? _props$height : 300, props == null ? void 0 : props.legend);
40800
+ var _props$approxYAxisLab = props.approxYAxisLabelCount,
40801
+ approxYAxisLabelCount = _props$approxYAxisLab === void 0 ? 'auto' : _props$approxYAxisLab,
40802
+ _props$approxXAxisLab = props.approxXAxisLabelCount,
40803
+ approxXAxisLabelCount = _props$approxXAxisLab === void 0 ? 'auto' : _props$approxXAxisLab,
40804
+ _props$removeStroke = props.removeStroke,
40805
+ removeStroke = _props$removeStroke === void 0 ? false : _props$removeStroke,
40806
+ _props$horizontal = props.horizontal,
40807
+ horizontal = _props$horizontal === void 0 ? false : _props$horizontal,
40808
+ theme = props.theme,
40809
+ x = props.x;
40810
+ var xAxisIsTime = isXAxisTime(props.x, props.forceXAxisAsTime, props.bars, props.lines, props.areas);
40811
+ var axisLabelStyles = function axisLabelStyles(horizontal, labelTheme) {
40812
+ var _labelTheme$color, _labelTheme$fontSize, _labelTheme$fontWeigh, _labelTheme$fontFamil;
40813
+ return {
40814
+ fill: (_labelTheme$color = labelTheme == null ? void 0 : labelTheme.color) != null ? _labelTheme$color : 'rgba(0, 0, 0, 0.6)',
40815
+ fontSize: (_labelTheme$fontSize = labelTheme == null ? void 0 : labelTheme.fontSize) != null ? _labelTheme$fontSize : 9,
40816
+ fontWeight: (_labelTheme$fontWeigh = labelTheme == null ? void 0 : labelTheme.fontWeight) != null ? _labelTheme$fontWeigh : 700,
40817
+ fontFamily: (_labelTheme$fontFamil = labelTheme == null ? void 0 : labelTheme.fontFamily) != null ? _labelTheme$fontFamil : DEFAULT_CHART_FONT,
40818
+ textAnchor: horizontal ? 'end' : 'middle',
40819
+ scaleToFit: 'shrink-only'
40820
+ };
40821
+ };
40822
+ var _useXAxisLabelCount = useXAxisLabelCount(approxXAxisLabelCount, !(props != null && props.horizontal) && (props == null ? void 0 : props.forceXAxisAsTime)),
40823
+ widthRef = _useXAxisLabelCount[0],
40824
+ approximateXTickCount = _useXAxisLabelCount[1];
40825
+ var _useState = useState(undefined),
40826
+ nearestDatum = _useState[0];
40827
+ var _useState2 = useState(undefined),
40828
+ nearestTooltipDatums = _useState2[0];
40829
+ var colors = getConcatenatedProperties(props, 'colors');
40830
+ var customTheme = buildChartTheme(_extends({}, lightTheme, {
40831
+ colors: colors,
40832
+ tickLength: 0,
40833
+ gridColor: '',
40834
+ gridColorDark: ''
40835
+ }));
40836
+ var chartData = getConcatenatedProperties(props, 'data');
40837
+ var axisStrokeColor = (_theme$axis$stroke = theme == null || (_theme$axis = theme.axis) == null ? void 0 : _theme$axis.stroke) != null ? _theme$axis$stroke : '#eaeaea';
40838
+ var _getAxisType = getAxisType(approxXAxisLabelCount, approxYAxisLabelCount),
40839
+ xAxisType = _getAxisType.xAxisType,
40840
+ xAxisAttributes = _getAxisType.xAxisAttributes,
40841
+ yAxisType = _getAxisType.yAxisType;
40842
+ var numberOfXAxisPoints = (_ref = (_props$lines$data$len = props == null || (_props$lines = props.lines) == null ? void 0 : _props$lines.data.length) != null ? _props$lines$data$len : props == null || (_props$areas = props.areas) == null || (_props$areas = _props$areas.data) == null ? void 0 : _props$areas.length) != null ? _ref : (_props$bars = props.bars) == null ? void 0 : _props$bars.data.length;
40843
+ var _useMinMaxValue = useMinMaxValue(props),
40844
+ maxValue = _useMinMaxValue.maxValue,
40845
+ minValue = _useMinMaxValue.minValue;
40846
+ var leftWidth = getYAxisWidth(horizontal, (_props$forceXAxisAsTi = props.forceXAxisAsTime) != null ? _props$forceXAxisAsTi : false, props, theme, getConcatenatedProperties(props, 'data'), props.x);
40847
+ var margin = props.sparkline ? NO_MARGIN(props.yAxisOrientation !== 'right') : getDefaultMargins(horizontal, props.yAxisOrientation !== 'right', xAxisType, props == null ? void 0 : props.axisTitles, leftWidth);
40848
+ var getTrendLineStyle = function getTrendLineStyle(datumKey) {
40849
+ if (props.trends) {
40850
+ var _props$trends, _strokeDasharrayToBor, _indicatorProperties$, _indicatorProperties$2, _indicatorProperties$3, _indicatorProperties$4, _indicatorProperties$5, _indicatorProperties$6, _indicatorProperties$7, _indicatorProperties$8, _indicatorProperties$9;
40851
+ var indicatorKeyIndex = (_props$trends = props.trends) == null ? void 0 : _props$trends.keys.indexOf(datumKey);
40852
+ var indicatorProperties = props.trends;
40853
+ return {
40854
+ borderStyle: (_strokeDasharrayToBor = strokeDasharrayToBorderStyle((_indicatorProperties$ = indicatorProperties.strokeDasharray) == null ? void 0 : _indicatorProperties$[indicatorKeyIndex])) != null ? _strokeDasharrayToBor : 'dotted',
40855
+ borderWidth: 0,
40856
+ marginTop: (_indicatorProperties$2 = (_indicatorProperties$3 = indicatorProperties.strokeWidth) == null ? void 0 : _indicatorProperties$3[indicatorKeyIndex]) != null ? _indicatorProperties$2 : 2,
40857
+ borderTopWidth: (_indicatorProperties$4 = (_indicatorProperties$5 = indicatorProperties.strokeWidth) == null ? void 0 : _indicatorProperties$5[indicatorKeyIndex]) != null ? _indicatorProperties$4 : 2,
40858
+ borderColor: (_indicatorProperties$6 = (_indicatorProperties$7 = indicatorProperties.colors) == null ? void 0 : _indicatorProperties$7[indicatorKeyIndex]) != null ? _indicatorProperties$6 : '#1E1D2D',
40859
+ opacity: (_indicatorProperties$8 = (_indicatorProperties$9 = indicatorProperties.opacity) == null ? void 0 : _indicatorProperties$9[indicatorKeyIndex]) != null ? _indicatorProperties$8 : 1
40860
+ };
40861
+ }
40862
+ return undefined;
40863
+ };
40864
+ return jsxs("div", {
40865
+ ref: widthRef,
40866
+ style: {
40867
+ position: 'relative',
40868
+ height: height
40869
+ },
40870
+ className: "vizzly-xy-chart" + (props != null && (_props$bars2 = props.bars) != null && _props$bars2.funnelChart ? ' vizzly-xy-chart-funnel' : ''),
40871
+ "data-testid": "vizzly-" + (props == null ? void 0 : props.uniqueId) + "-chart",
40872
+ children: [jsxs(XYChart, {
40873
+ theme: customTheme,
40874
+ margin: margin,
40875
+ height: height,
40876
+ xScale: getScale('x', horizontal, xAxisIsTime, props == null || (_props$lines2 = props.lines) == null ? void 0 : _props$lines2.scatter, !!(props != null && props.lines) || !!(props != null && props.areas)),
40877
+ yScale: getYScale(props == null ? void 0 : props.goalLine, maxValue, minValue, horizontal, xAxisIsTime),
40878
+ horizontal: horizontal,
40879
+ onPointerUp: function onPointerUp(params) {
40880
+ return props == null ? void 0 : props.onClick(nearestDatum, nearestTooltipDatums, params);
40881
+ },
40882
+ children: [jsx(Grid$1, {
40883
+ columns: horizontal,
40884
+ rows: !horizontal,
40885
+ stroke: "black",
40886
+ strokeDasharray: "0.5 5",
40887
+ strokeWidth: removeStroke ? 0 : 2,
40888
+ lineStyle: {
40889
+ strokeLinecap: 'round',
40890
+ stroke: (_theme$grid$stroke = theme == null || (_theme$grid = theme.grid) == null ? void 0 : _theme$grid.stroke) != null ? _theme$grid$stroke : 'rgba(200, 200, 200, 0.2)'
40891
+ }
40892
+ }), !(props != null && props.sparkline) && jsxs(Fragment$1, {
40893
+ children: [xAxisType !== 'none' && jsx(Axis, _extends({}, xAxisAttributes, {
40894
+ tickLabelProps: function tickLabelProps() {
40895
+ var tickLabelProps = _extends({}, axisLabelStyles(horizontal, theme == null ? void 0 : theme.labels));
40896
+ if (!horizontal) {
40897
+ tickLabelProps['y'] = 15;
40898
+ }
40899
+ return tickLabelProps;
40900
+ },
40901
+ numTicks: xAxisType === 'end2end' ? numberOfXAxisPoints : approximateXTickCount,
40902
+ strokeWidth: removeStroke ? 0 : 1,
40903
+ tickStroke: "#eaeaea",
40904
+ stroke: horizontal ? 'transparent' : axisStrokeColor,
40905
+ orientation: horizontal ? 'left' : 'bottom',
40906
+ tickFormat: handleFormatXAxisLabel(props.formatXAxisLabel, props.forceXAxisAsTime || xAxisIsTime, chartData),
40907
+ label: horizontal ? props == null || (_props$axisTitles = props.axisTitles) == null ? void 0 : _props$axisTitles.y : props == null || (_props$axisTitles2 = props.axisTitles) == null ? void 0 : _props$axisTitles2.x,
40908
+ children: function children(axisProps) {
40909
+ return jsx(XAxis, _extends({}, axisProps, {
40910
+ theme: theme,
40911
+ type: xAxisType,
40912
+ uniqueId: props == null ? void 0 : props.uniqueId,
40913
+ chartWidth: props == null ? void 0 : props.width,
40914
+ xAxisIsTime: !!props.forceXAxisAsTime,
40915
+ leftPanelWidth: leftWidth,
40916
+ axisHorizontal: props == null ? void 0 : props.horizontal
40917
+ }));
40918
+ }
40919
+ })), jsx(Axis, {
40920
+ labelOffset: 50,
40921
+ tickLabelProps: function tickLabelProps() {
40922
+ var tickLabelProps = _extends({}, axisLabelStyles(horizontal, theme == null ? void 0 : theme.labels));
40923
+ if (!horizontal && props.yAxisOrientation !== 'right') {
40924
+ tickLabelProps['width'] = LEFT_PANEL_WIDTH;
40925
+ tickLabelProps['textAnchor'] = 'middle';
40926
+ }
40927
+ return tickLabelProps;
40928
+ },
40929
+ hideAxisLine: true,
40930
+ numTicks: approxYAxisLabelCount === 'auto' ? DEFAULT_Y_AXIS_LABEL_COUNT$1 : approxYAxisLabelCount,
40931
+ strokeWidth: removeStroke ? 0 : 1,
40932
+ hideTicks: true,
40933
+ tickLength: !props.horizontal && props.yAxisOrientation !== 'right' ? LEFT_PANEL_WIDTH / 2 : 10,
40934
+ stroke: axisStrokeColor,
40935
+ orientation: horizontal ? 'bottom' : props.yAxisOrientation || 'left',
40936
+ tickFormat: formatYAxisLabel$1(props),
40937
+ label: horizontal ? props == null || (_props$axisTitles3 = props.axisTitles) == null ? void 0 : _props$axisTitles3.x : props == null || (_props$axisTitles4 = props.axisTitles) == null ? void 0 : _props$axisTitles4.y,
40938
+ children: function children(axisProps) {
40939
+ return jsx(YAxis, _extends({}, axisProps, {
40940
+ theme: theme,
40941
+ type: yAxisType,
40942
+ horizontal: horizontal,
40943
+ maxValueOfYAxis: props != null && props.formatYAxisLabel ? props == null ? void 0 : props.formatYAxisLabel(maxValue) : maxValue,
40944
+ uniqueId: props == null ? void 0 : props.uniqueId
40945
+ }));
40946
+ }
40947
+ })]
40948
+ }), jsx("style", {
40949
+ children: "\n .visx-bar-stack .visx-bar {\n stroke: #fff;\n stroke-width: 2px;\n }\n .vizzly-xy-chart-funnel .visx-bar-stack .visx-bar {\n stroke-width: 0;\n }\n .visx-tooltip-glyph svg {\n max-width: 10px\n height: 10px;\n }\n " + TOOLTIP_ZINDEX + "\n "
40950
+ }), props.lines && props.lines.keys.map(function (key, keyIndex) {
40951
+ var _props$lines3, _props$lines4;
40952
+ return jsx(GlyphSeries, _extends({
40953
+ size: function size(datum) {
40954
+ if (!datum || !datum.bubbleSize) return 5;
40955
+ return datum.bubbleSize;
40956
+ },
40957
+ dataKey: key,
40958
+ data: (_props$lines3 = props.lines) == null ? void 0 : _props$lines3.data
40959
+ }, accessors$1(xAxisIsTime, x, key, horizontal), {
40960
+ colorAccessor: (props == null || (_props$lines4 = props.lines) == null ? void 0 : _props$lines4.formatter) && getColorFromDatum(key, props == null ? void 0 : props.lines.formatter, colors, keyIndex)
40961
+ }), "scatter_chart_" + props.uniqueId + "_" + keyIndex);
40962
+ })]
40963
+ }), (props == null ? void 0 : props.legend) && jsx(Legend, {
40964
+ funnelChart: props == null || (_props$bars3 = props.bars) == null ? void 0 : _props$bars3.funnelChart
40965
+ // groupingCount={props}
40966
+ ,
40967
+ keys: getConcatenatedProperties(props, 'keys'),
40968
+ colors: colors,
40969
+ typeIndex: getTypeIndex(props),
40970
+ formatSeriesName: props == null ? void 0 : props.formatSeriesName,
40971
+ formatter: props == null || (_props$bars4 = props.bars) == null ? void 0 : _props$bars4.formatter,
40972
+ data: (_props$bars5 = props.bars) == null ? void 0 : _props$bars5.data,
40973
+ conditionalFormattingPossibilities: props.conditionalFormattingPossibilities,
40974
+ getIndicatorStyles: getTrendLineStyle
40975
+ })]
40976
+ });
40977
+ };
40978
+
40979
+ var BubbleChart$2 = /*#__PURE__*/forwardRef(function (props, ref) {
40980
+ var zValues = props.z ? props.data.map(function (d) {
40981
+ return d[props.z];
40982
+ }) : [];
40983
+ var normaliseArray = function normaliseArray(array, min, max) {
40984
+ var arrayMin = Math.min.apply(Math, array);
40985
+ var arrayMax = Math.max.apply(Math, array);
40986
+ return array.map(function (value) {
40987
+ return (value - arrayMin) / (arrayMax - arrayMin) * (max - min) + min;
40988
+ });
40989
+ };
40990
+ var scaledSizeValues = normaliseArray(zValues, 1, 30);
40991
+ var data = props.data.map(function (d, i) {
40992
+ return _extends({}, d, {
40993
+ bubbleSize: scaledSizeValues[i]
40994
+ });
40995
+ });
40996
+ var forceRerender = useChartForceRerender(ref);
40997
+ if (forceRerender) return null;
40998
+ return jsx(ParentSize, {
40999
+ children: function children(parent) {
41000
+ var _props$height, _props$width;
41001
+ return jsx(VizzlyBubbleChart, {
41002
+ isBubble: true,
41003
+ approxXAxisLabelCount: props.approxXAxisLabelCount,
41004
+ approxYAxisLabelCount: props.approxYAxisLabelCount,
41005
+ uniqueId: props.uniqueId,
41006
+ formatSeriesName: props.formatSeriesName,
41007
+ forceXAxisAsTime: props.forceXAxisAsTime,
41008
+ sparkline: props.sparkline,
41009
+ lines: {
41010
+ annotate: props.annotate || [],
41011
+ data: data,
41012
+ keys: props.keys,
41013
+ colors: props.colors,
41014
+ scatter: true
41015
+ },
41016
+ x: props.x,
41017
+ z: props.z,
41018
+ sharedTooltip: true,
41019
+ legend: props.legend,
41020
+ removeStroke: props == null ? void 0 : props.removeStroke,
41021
+ formatXAxisLabel: props == null ? void 0 : props.formatXAxisLabel,
41022
+ formatYAxisLabel: props == null ? void 0 : props.formatYAxisLabel,
41023
+ horizontal: props == null ? void 0 : props.horizontal,
41024
+ height: (_props$height = props == null ? void 0 : props.height) != null ? _props$height : parent == null ? void 0 : parent.height,
41025
+ width: (_props$width = props == null ? void 0 : props.width) != null ? _props$width : parent == null ? void 0 : parent.width,
41026
+ theme: props == null ? void 0 : props.theme,
41027
+ onClick: function onClick(datum) {
41028
+ return (props == null ? void 0 : props.onClick) && (props == null ? void 0 : props.onClick(datum));
41029
+ },
41030
+ goalLine: props == null ? void 0 : props.goalLine,
41031
+ axisTitles: props == null ? void 0 : props.axisTitles,
41032
+ idPrefix: props == null ? void 0 : props.idPrefix,
41033
+ popOverMenuStyles: props.popOverMenuStyles
41034
+ });
41035
+ }
41036
+ });
41037
+ });
41038
+
40787
41039
  var defaultProps$6 = {
40788
41040
  type: 'bubbleChart',
40789
41041
  xMeasure: null,
@@ -40871,7 +41123,7 @@ var BubbleChartView = function BubbleChartView(props) {
40871
41123
  queriesAreChanging: props.queriesAreChanging,
40872
41124
  children: [jsx(ViewHeader, _extends({}, headerProps)), jsx(ChartWrapper, {
40873
41125
  disabledFeatures: (_props$library2 = props.library) != null ? _props$library2 : false,
40874
- children: jsx(BubbleChart$3, {
41126
+ children: jsx(BubbleChart$2, {
40875
41127
  ref: ref,
40876
41128
  approxXAxisLabelCount: props.approxXAxisLabelCount,
40877
41129
  approxYAxisLabelCount: props.approxYAxisLabelCount,
@@ -40916,7 +41168,7 @@ var BubbleChartView = function BubbleChartView(props) {
40916
41168
  BubbleChartView.defaultProps = defaultProps$6;
40917
41169
  var memoized$4 = /*#__PURE__*/memo(BubbleChartView, shouldUpdate);
40918
41170
 
40919
- var BubbleChart$2 = function BubbleChart(props) {
41171
+ var BubbleChart$3 = function BubbleChart(props) {
40920
41172
  var _props$dashboardBehav;
40921
41173
  var _props$component = props.component,
40922
41174
  results = _props$component.results,
@@ -41367,6 +41619,21 @@ var LegendItemSquare = function LegendItemSquare(_ref2) {
41367
41619
  })
41368
41620
  });
41369
41621
  };
41622
+ var LegendItemTriangle = function LegendItemTriangle(_ref3) {
41623
+ var color = _ref3.color;
41624
+ return jsx("svg", {
41625
+ width: 8,
41626
+ height: 8,
41627
+ style: {
41628
+ display: 'block',
41629
+ borderRadius: 1
41630
+ },
41631
+ children: jsx("polygon", {
41632
+ points: "0,0 10,10 0,10",
41633
+ fill: color
41634
+ })
41635
+ });
41636
+ };
41370
41637
 
41371
41638
  var Tooltip$1 = function Tooltip(_ref) {
41372
41639
  var keys = _ref.keys,
@@ -41502,7 +41769,7 @@ var LegendItem = function LegendItem(_ref) {
41502
41769
  } : {
41503
41770
  name: "mefz6m-LegendItem",
41504
41771
  styles: "height:10px;display:flex;label:LegendItem;",
41505
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZEl0ZW0udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQStDeUIiLCJmaWxlIjoiTGVnZW5kSXRlbS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgdXNlTWVtbyB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IExlZ2VuZEl0ZW1Cb3ggfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94JztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBMZWdlbmRJdGVtU3F1YXJlIH0gZnJvbSAnLi4vTGVnZW5kSXRlbUJveC9MZWdlbmRJdGVtQm94JztcbmltcG9ydCB7IFNoYXBlRGVmaW5pdGlvbiwgQ29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZSB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQ2hhcnRzVjIvdHlwZXMnO1xuaW1wb3J0IHsgTGluZVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvTGluZUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQmFyU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9CYXJDaGFydFYyL3R5cGVzJztcblxuaW50ZXJmYWNlIExlZ2VuZEl0ZW1Qcm9wczxUPiBleHRlbmRzIFNoYXBlRGVmaW5pdGlvbjxUPiB7XG4gIG9uQ2xpY2s6ICgpID0+IHZvaWQ7XG4gIHZpc2libGU6IGJvb2xlYW47XG4gIHlLZXlGb3JtYXR0ZWQ6IHN0cmluZyB8IHVuZGVmaW5lZDtcbiAgY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXM6IEFycmF5PENvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGU+O1xufVxuXG5leHBvcnQgY29uc3QgTGVnZW5kSXRlbSA9ICh7XG4gIHlLZXksXG4gIHlLZXlGb3JtYXR0ZWQsXG4gIGNvbG9yLFxuICBzdHlsZSxcbiAgb25DbGljayxcbiAgdmlzaWJsZSxcbiAgY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXMsXG59OiBMZWdlbmRJdGVtUHJvcHM8QmFyU3R5bGVzIHwgTGluZVN0eWxlcz4pID0+IHtcbiAgY29uc3QgcmVsZXZhbnRSdWxlcyA9IHVzZU1lbW8oXG4gICAgKCkgPT4gY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXMuZmlsdGVyKChydWxlKSA9PiBydWxlLnlLZXkgPT09IHlLZXkpLFxuICAgIFtjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlc11cbiAgKTtcblxuICByZXR1cm4gKFxuICAgIDxidXR0b25cbiAgICAgIGtleT17YGxlZ2VuZC0ke3lLZXl9YH1cbiAgICAgIHR5cGU9XCJidXR0b25cIlxuICAgICAgc3R5bGU9e3tcbiAgICAgICAgYWxsOiAndW5zZXQnLFxuICAgICAgICBkaXNwbGF5OiAnZmxleCcsXG4gICAgICAgIGZsZXhXcmFwOiAnbm93cmFwJyxcbiAgICAgICAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG4gICAgICAgIG91dGxpbmU6ICdyZXZlcnQnLFxuICAgICAgICBnYXA6ICc0cHgnLFxuICAgICAgICBwYWRkaW5nOiAnNHB4JyxcbiAgICAgICAgY3Vyc29yOiAncG9pbnRlcicsXG4gICAgICAgIG1hcmdpblJpZ2h0OiAnMTBweCcsXG4gICAgICB9fVxuICAgICAgb25DbGljaz17b25DbGlja31cbiAgICA+XG4gICAgICB7c3R5bGUudHlwZSA9PT0gJ2xpbmUnICYmIChcbiAgICAgICAgPHNwYW4gY2xhc3NOYW1lPXtjc3MoeyBoZWlnaHQ6IDEwLCBkaXNwbGF5OiAnZmxleCcgfSl9PlxuICAgICAgICAgIDxMZWdlbmRJdGVtQm94IGNvbG9yPXtjb2xvcn0gc3R5bGU9e3N0eWxlIGFzIExpbmVTdHlsZXN9IHlLZXk9e3lLZXl9IC8+XG4gICAgICAgICAge3JlbGV2YW50UnVsZXMubGVuZ3RoID4gMCAmJlxuICAgICAgICAgICAgcmVsZXZhbnRSdWxlcy5tYXAoKHJ1bGUpID0+IChcbiAgICAgICAgICAgICAgPExlZ2VuZEl0ZW1Cb3hcbiAgICAgICAgICAgICAgICBjb2xvcj17cnVsZS5jb2xvcn1cbiAgICAgICAgICAgICAgICBrZXk9e2BydWxlLSR7SlNPTi5zdHJpbmdpZnkocnVsZSl9YH1cbiAgICAgICAgICAgICAgICBzdHlsZT17c3R5bGUgYXMgTGluZVN0eWxlc31cbiAgICAgICAgICAgICAgICB5S2V5PXt5S2V5fVxuICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgKSl9XG4gICAgICAgIDwvc3Bhbj5cbiAgICAgICl9XG4gICAgICB7c3R5bGUudHlwZSA9PT0gJ2JhcicgJiYgKFxuICAgICAgICA8c3BhbiBjbGFzc05hbWU9e2Nzcyh7IGRpc3BsYXk6ICdmbGV4JywgZmxleERpcmVjdGlvbjogJ3JvdycsIGFsaWduSXRlbXM6ICdjZW50ZXInLCBnYXA6IDIgfSl9PlxuICAgICAgICAgIDxMZWdlbmRJdGVtU3F1YXJlIGNvbG9yPXtjb2xvcn0gLz5cbiAgICAgICAgICB7cmVsZXZhbnRSdWxlcy5sZW5ndGggPiAwICYmXG4gICAgICAgICAgICByZWxldmFudFJ1bGVzLm1hcCgocnVsZSkgPT4gPExlZ2VuZEl0ZW1TcXVhcmUgY29sb3I9e3J1bGUuY29sb3J9IGtleT17YHJ1bGUtJHtKU09OLnN0cmluZ2lmeShydWxlKX1gfSAvPil9XG4gICAgICAgIDwvc3Bhbj5cbiAgICAgICl9XG4gICAgICA8c3BhblxuICAgICAgICBzdHlsZT17e1xuICAgICAgICAgIGZvbnRTaXplOiAnMTJweCcsXG4gICAgICAgICAgbGluZUhlaWdodDogJzE2cHgnLFxuICAgICAgICAgIGRpc3BsYXk6ICdibG9jaycsXG4gICAgICAgICAgdGV4dERlY29yYXRpb246IHZpc2libGUgPyAnbm9uZScgOiAnbGluZS10aHJvdWdoJyxcbiAgICAgICAgICB0ZXh0V3JhcDogJ25vd3JhcCcsXG4gICAgICAgIH19XG4gICAgICA+XG4gICAgICAgIHt5S2V5Rm9ybWF0dGVkID8geUtleUZvcm1hdHRlZCA6IHlLZXl9XG4gICAgICA8L3NwYW4+XG4gICAgPC9idXR0b24+XG4gICk7XG59O1xuIl19 */",
41772
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZEl0ZW0udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQStDeUIiLCJmaWxlIjoiTGVnZW5kSXRlbS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgdXNlTWVtbyB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IExlZ2VuZEl0ZW1Cb3ggfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94JztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBMZWdlbmRJdGVtU3F1YXJlLCBMZWdlbmRJdGVtVHJpYW5nbGUgfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94L0xlZ2VuZEl0ZW1Cb3gnO1xuaW1wb3J0IHsgU2hhcGVEZWZpbml0aW9uLCBDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9DaGFydHNWMi90eXBlcyc7XG5pbXBvcnQgeyBMaW5lU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9MaW5lQ2hhcnRWMi90eXBlcyc7XG5pbXBvcnQgeyBCYXJTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0JhckNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQXJlYVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQXJlYUNoYXJ0VjIvdHlwZXMnO1xuXG5pbnRlcmZhY2UgTGVnZW5kSXRlbVByb3BzPFQ+IGV4dGVuZHMgU2hhcGVEZWZpbml0aW9uPFQ+IHtcbiAgb25DbGljazogKCkgPT4gdm9pZDtcbiAgdmlzaWJsZTogYm9vbGVhbjtcbiAgeUtleUZvcm1hdHRlZDogc3RyaW5nIHwgdW5kZWZpbmVkO1xuICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlczogQXJyYXk8Q29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZT47XG59XG5cbmV4cG9ydCBjb25zdCBMZWdlbmRJdGVtID0gKHtcbiAgeUtleSxcbiAgeUtleUZvcm1hdHRlZCxcbiAgY29sb3IsXG4gIHN0eWxlLFxuICBvbkNsaWNrLFxuICB2aXNpYmxlLFxuICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlcyxcbn06IExlZ2VuZEl0ZW1Qcm9wczxCYXJTdHlsZXMgfCBMaW5lU3R5bGVzIHwgQXJlYVN0eWxlcz4pID0+IHtcbiAgY29uc3QgcmVsZXZhbnRSdWxlcyA9IHVzZU1lbW8oKCkgPT4gY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXMuZmlsdGVyKHJ1bGUgPT4gcnVsZS55S2V5ID09PSB5S2V5KSwgW1xuICAgIGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzLFxuICBdKTtcblxuICByZXR1cm4gKFxuICAgIDxidXR0b25cbiAgICAgIGtleT17YGxlZ2VuZC0ke3lLZXl9YH1cbiAgICAgIHR5cGU9XCJidXR0b25cIlxuICAgICAgc3R5bGU9e3tcbiAgICAgICAgYWxsOiAndW5zZXQnLFxuICAgICAgICBkaXNwbGF5OiAnZmxleCcsXG4gICAgICAgIGZsZXhXcmFwOiAnbm93cmFwJyxcbiAgICAgICAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG4gICAgICAgIG91dGxpbmU6ICdyZXZlcnQnLFxuICAgICAgICBnYXA6ICc0cHgnLFxuICAgICAgICBwYWRkaW5nOiAnNHB4JyxcbiAgICAgICAgY3Vyc29yOiAncG9pbnRlcicsXG4gICAgICAgIG1hcmdpblJpZ2h0OiAnMTBweCcsXG4gICAgICB9fVxuICAgICAgb25DbGljaz17b25DbGlja31cbiAgICA+XG4gICAgICB7c3R5bGUudHlwZSA9PT0gJ2xpbmUnICYmIChcbiAgICAgICAgPHNwYW4gY2xhc3NOYW1lPXtjc3MoeyBoZWlnaHQ6IDEwLCBkaXNwbGF5OiAnZmxleCcgfSl9PlxuICAgICAgICAgIDxMZWdlbmRJdGVtQm94IGNvbG9yPXtjb2xvcn0gc3R5bGU9e3N0eWxlIGFzIExpbmVTdHlsZXN9IHlLZXk9e3lLZXl9IC8+XG4gICAgICAgICAge3JlbGV2YW50UnVsZXMubGVuZ3RoID4gMCAmJlxuICAgICAgICAgICAgcmVsZXZhbnRSdWxlcy5tYXAocnVsZSA9PiAoXG4gICAgICAgICAgICAgIDxMZWdlbmRJdGVtQm94XG4gICAgICAgICAgICAgICAgY29sb3I9e3J1bGUuY29sb3J9XG4gICAgICAgICAgICAgICAga2V5PXtgcnVsZS0ke0pTT04uc3RyaW5naWZ5KHJ1bGUpfWB9XG4gICAgICAgICAgICAgICAgc3R5bGU9e3N0eWxlIGFzIExpbmVTdHlsZXN9XG4gICAgICAgICAgICAgICAgeUtleT17eUtleX1cbiAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgICkpfVxuICAgICAgICA8L3NwYW4+XG4gICAgICApfVxuICAgICAge3N0eWxlLnR5cGUgPT09ICdiYXInICYmIChcbiAgICAgICAgPHNwYW4gY2xhc3NOYW1lPXtjc3MoeyBkaXNwbGF5OiAnZmxleCcsIGZsZXhEaXJlY3Rpb246ICdyb3cnLCBhbGlnbkl0ZW1zOiAnY2VudGVyJywgZ2FwOiAyIH0pfT5cbiAgICAgICAgICA8TGVnZW5kSXRlbVNxdWFyZSBjb2xvcj17Y29sb3J9IC8+XG4gICAgICAgICAge3JlbGV2YW50UnVsZXMubGVuZ3RoID4gMCAmJlxuICAgICAgICAgICAgcmVsZXZhbnRSdWxlcy5tYXAocnVsZSA9PiA8TGVnZW5kSXRlbVNxdWFyZSBjb2xvcj17cnVsZS5jb2xvcn0ga2V5PXtgcnVsZS0ke0pTT04uc3RyaW5naWZ5KHJ1bGUpfWB9IC8+KX1cbiAgICAgICAgPC9zcGFuPlxuICAgICAgKX1cbiAgICAgIHtzdHlsZS50eXBlID09PSAnYXJlYScgJiYgKFxuICAgICAgICA8c3BhbiBjbGFzc05hbWU9e2Nzcyh7IGRpc3BsYXk6ICdmbGV4JywgZmxleERpcmVjdGlvbjogJ3JvdycsIGFsaWduSXRlbXM6ICdjZW50ZXInLCBnYXA6IDIgfSl9PlxuICAgICAgICAgIDxMZWdlbmRJdGVtVHJpYW5nbGUgY29sb3I9e2NvbG9yfSAvPlxuICAgICAgICAgIHtyZWxldmFudFJ1bGVzLmxlbmd0aCA+IDAgJiZcbiAgICAgICAgICAgIHJlbGV2YW50UnVsZXMubWFwKHJ1bGUgPT4gPExlZ2VuZEl0ZW1UcmlhbmdsZSBjb2xvcj17cnVsZS5jb2xvcn0ga2V5PXtgcnVsZS0ke0pTT04uc3RyaW5naWZ5KHJ1bGUpfWB9IC8+KX1cbiAgICAgICAgPC9zcGFuPlxuICAgICAgKX1cbiAgICAgIDxzcGFuXG4gICAgICAgIHN0eWxlPXt7XG4gICAgICAgICAgZm9udFNpemU6ICcxMnB4JyxcbiAgICAgICAgICBsaW5lSGVpZ2h0OiAnMTZweCcsXG4gICAgICAgICAgZGlzcGxheTogJ2Jsb2NrJyxcbiAgICAgICAgICB0ZXh0RGVjb3JhdGlvbjogdmlzaWJsZSA/ICdub25lJyA6ICdsaW5lLXRocm91Z2gnLFxuICAgICAgICAgIHRleHRXcmFwOiAnbm93cmFwJyxcbiAgICAgICAgfX1cbiAgICAgID5cbiAgICAgICAge3lLZXlGb3JtYXR0ZWQgPyB5S2V5Rm9ybWF0dGVkIDogeUtleX1cbiAgICAgIDwvc3Bhbj5cbiAgICA8L2J1dHRvbj5cbiAgKTtcbn07XG4iXX0= */",
41506
41773
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$5
41507
41774
  }),
41508
41775
  children: [jsx(LegendItemBox, {
@@ -41523,7 +41790,7 @@ var LegendItem = function LegendItem(_ref) {
41523
41790
  } : {
41524
41791
  name: "pglbco-LegendItem",
41525
41792
  styles: "display:flex;flex-direction:row;align-items:center;gap:2px;label:LegendItem;",
41526
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZEl0ZW0udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTZEeUIiLCJmaWxlIjoiTGVnZW5kSXRlbS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgdXNlTWVtbyB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IExlZ2VuZEl0ZW1Cb3ggfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94JztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBMZWdlbmRJdGVtU3F1YXJlIH0gZnJvbSAnLi4vTGVnZW5kSXRlbUJveC9MZWdlbmRJdGVtQm94JztcbmltcG9ydCB7IFNoYXBlRGVmaW5pdGlvbiwgQ29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZSB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQ2hhcnRzVjIvdHlwZXMnO1xuaW1wb3J0IHsgTGluZVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvTGluZUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQmFyU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9CYXJDaGFydFYyL3R5cGVzJztcblxuaW50ZXJmYWNlIExlZ2VuZEl0ZW1Qcm9wczxUPiBleHRlbmRzIFNoYXBlRGVmaW5pdGlvbjxUPiB7XG4gIG9uQ2xpY2s6ICgpID0+IHZvaWQ7XG4gIHZpc2libGU6IGJvb2xlYW47XG4gIHlLZXlGb3JtYXR0ZWQ6IHN0cmluZyB8IHVuZGVmaW5lZDtcbiAgY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXM6IEFycmF5PENvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGU+O1xufVxuXG5leHBvcnQgY29uc3QgTGVnZW5kSXRlbSA9ICh7XG4gIHlLZXksXG4gIHlLZXlGb3JtYXR0ZWQsXG4gIGNvbG9yLFxuICBzdHlsZSxcbiAgb25DbGljayxcbiAgdmlzaWJsZSxcbiAgY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXMsXG59OiBMZWdlbmRJdGVtUHJvcHM8QmFyU3R5bGVzIHwgTGluZVN0eWxlcz4pID0+IHtcbiAgY29uc3QgcmVsZXZhbnRSdWxlcyA9IHVzZU1lbW8oXG4gICAgKCkgPT4gY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXMuZmlsdGVyKChydWxlKSA9PiBydWxlLnlLZXkgPT09IHlLZXkpLFxuICAgIFtjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlc11cbiAgKTtcblxuICByZXR1cm4gKFxuICAgIDxidXR0b25cbiAgICAgIGtleT17YGxlZ2VuZC0ke3lLZXl9YH1cbiAgICAgIHR5cGU9XCJidXR0b25cIlxuICAgICAgc3R5bGU9e3tcbiAgICAgICAgYWxsOiAndW5zZXQnLFxuICAgICAgICBkaXNwbGF5OiAnZmxleCcsXG4gICAgICAgIGZsZXhXcmFwOiAnbm93cmFwJyxcbiAgICAgICAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG4gICAgICAgIG91dGxpbmU6ICdyZXZlcnQnLFxuICAgICAgICBnYXA6ICc0cHgnLFxuICAgICAgICBwYWRkaW5nOiAnNHB4JyxcbiAgICAgICAgY3Vyc29yOiAncG9pbnRlcicsXG4gICAgICAgIG1hcmdpblJpZ2h0OiAnMTBweCcsXG4gICAgICB9fVxuICAgICAgb25DbGljaz17b25DbGlja31cbiAgICA+XG4gICAgICB7c3R5bGUudHlwZSA9PT0gJ2xpbmUnICYmIChcbiAgICAgICAgPHNwYW4gY2xhc3NOYW1lPXtjc3MoeyBoZWlnaHQ6IDEwLCBkaXNwbGF5OiAnZmxleCcgfSl9PlxuICAgICAgICAgIDxMZWdlbmRJdGVtQm94IGNvbG9yPXtjb2xvcn0gc3R5bGU9e3N0eWxlIGFzIExpbmVTdHlsZXN9IHlLZXk9e3lLZXl9IC8+XG4gICAgICAgICAge3JlbGV2YW50UnVsZXMubGVuZ3RoID4gMCAmJlxuICAgICAgICAgICAgcmVsZXZhbnRSdWxlcy5tYXAoKHJ1bGUpID0+IChcbiAgICAgICAgICAgICAgPExlZ2VuZEl0ZW1Cb3hcbiAgICAgICAgICAgICAgICBjb2xvcj17cnVsZS5jb2xvcn1cbiAgICAgICAgICAgICAgICBrZXk9e2BydWxlLSR7SlNPTi5zdHJpbmdpZnkocnVsZSl9YH1cbiAgICAgICAgICAgICAgICBzdHlsZT17c3R5bGUgYXMgTGluZVN0eWxlc31cbiAgICAgICAgICAgICAgICB5S2V5PXt5S2V5fVxuICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgKSl9XG4gICAgICAgIDwvc3Bhbj5cbiAgICAgICl9XG4gICAgICB7c3R5bGUudHlwZSA9PT0gJ2JhcicgJiYgKFxuICAgICAgICA8c3BhbiBjbGFzc05hbWU9e2Nzcyh7IGRpc3BsYXk6ICdmbGV4JywgZmxleERpcmVjdGlvbjogJ3JvdycsIGFsaWduSXRlbXM6ICdjZW50ZXInLCBnYXA6IDIgfSl9PlxuICAgICAgICAgIDxMZWdlbmRJdGVtU3F1YXJlIGNvbG9yPXtjb2xvcn0gLz5cbiAgICAgICAgICB7cmVsZXZhbnRSdWxlcy5sZW5ndGggPiAwICYmXG4gICAgICAgICAgICByZWxldmFudFJ1bGVzLm1hcCgocnVsZSkgPT4gPExlZ2VuZEl0ZW1TcXVhcmUgY29sb3I9e3J1bGUuY29sb3J9IGtleT17YHJ1bGUtJHtKU09OLnN0cmluZ2lmeShydWxlKX1gfSAvPil9XG4gICAgICAgIDwvc3Bhbj5cbiAgICAgICl9XG4gICAgICA8c3BhblxuICAgICAgICBzdHlsZT17e1xuICAgICAgICAgIGZvbnRTaXplOiAnMTJweCcsXG4gICAgICAgICAgbGluZUhlaWdodDogJzE2cHgnLFxuICAgICAgICAgIGRpc3BsYXk6ICdibG9jaycsXG4gICAgICAgICAgdGV4dERlY29yYXRpb246IHZpc2libGUgPyAnbm9uZScgOiAnbGluZS10aHJvdWdoJyxcbiAgICAgICAgICB0ZXh0V3JhcDogJ25vd3JhcCcsXG4gICAgICAgIH19XG4gICAgICA+XG4gICAgICAgIHt5S2V5Rm9ybWF0dGVkID8geUtleUZvcm1hdHRlZCA6IHlLZXl9XG4gICAgICA8L3NwYW4+XG4gICAgPC9idXR0b24+XG4gICk7XG59O1xuIl19 */",
41793
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZEl0ZW0udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTZEeUIiLCJmaWxlIjoiTGVnZW5kSXRlbS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgdXNlTWVtbyB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IExlZ2VuZEl0ZW1Cb3ggfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94JztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBMZWdlbmRJdGVtU3F1YXJlLCBMZWdlbmRJdGVtVHJpYW5nbGUgfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94L0xlZ2VuZEl0ZW1Cb3gnO1xuaW1wb3J0IHsgU2hhcGVEZWZpbml0aW9uLCBDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9DaGFydHNWMi90eXBlcyc7XG5pbXBvcnQgeyBMaW5lU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9MaW5lQ2hhcnRWMi90eXBlcyc7XG5pbXBvcnQgeyBCYXJTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0JhckNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQXJlYVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQXJlYUNoYXJ0VjIvdHlwZXMnO1xuXG5pbnRlcmZhY2UgTGVnZW5kSXRlbVByb3BzPFQ+IGV4dGVuZHMgU2hhcGVEZWZpbml0aW9uPFQ+IHtcbiAgb25DbGljazogKCkgPT4gdm9pZDtcbiAgdmlzaWJsZTogYm9vbGVhbjtcbiAgeUtleUZvcm1hdHRlZDogc3RyaW5nIHwgdW5kZWZpbmVkO1xuICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlczogQXJyYXk8Q29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZT47XG59XG5cbmV4cG9ydCBjb25zdCBMZWdlbmRJdGVtID0gKHtcbiAgeUtleSxcbiAgeUtleUZvcm1hdHRlZCxcbiAgY29sb3IsXG4gIHN0eWxlLFxuICBvbkNsaWNrLFxuICB2aXNpYmxlLFxuICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlcyxcbn06IExlZ2VuZEl0ZW1Qcm9wczxCYXJTdHlsZXMgfCBMaW5lU3R5bGVzIHwgQXJlYVN0eWxlcz4pID0+IHtcbiAgY29uc3QgcmVsZXZhbnRSdWxlcyA9IHVzZU1lbW8oKCkgPT4gY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXMuZmlsdGVyKHJ1bGUgPT4gcnVsZS55S2V5ID09PSB5S2V5KSwgW1xuICAgIGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzLFxuICBdKTtcblxuICByZXR1cm4gKFxuICAgIDxidXR0b25cbiAgICAgIGtleT17YGxlZ2VuZC0ke3lLZXl9YH1cbiAgICAgIHR5cGU9XCJidXR0b25cIlxuICAgICAgc3R5bGU9e3tcbiAgICAgICAgYWxsOiAndW5zZXQnLFxuICAgICAgICBkaXNwbGF5OiAnZmxleCcsXG4gICAgICAgIGZsZXhXcmFwOiAnbm93cmFwJyxcbiAgICAgICAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG4gICAgICAgIG91dGxpbmU6ICdyZXZlcnQnLFxuICAgICAgICBnYXA6ICc0cHgnLFxuICAgICAgICBwYWRkaW5nOiAnNHB4JyxcbiAgICAgICAgY3Vyc29yOiAncG9pbnRlcicsXG4gICAgICAgIG1hcmdpblJpZ2h0OiAnMTBweCcsXG4gICAgICB9fVxuICAgICAgb25DbGljaz17b25DbGlja31cbiAgICA+XG4gICAgICB7c3R5bGUudHlwZSA9PT0gJ2xpbmUnICYmIChcbiAgICAgICAgPHNwYW4gY2xhc3NOYW1lPXtjc3MoeyBoZWlnaHQ6IDEwLCBkaXNwbGF5OiAnZmxleCcgfSl9PlxuICAgICAgICAgIDxMZWdlbmRJdGVtQm94IGNvbG9yPXtjb2xvcn0gc3R5bGU9e3N0eWxlIGFzIExpbmVTdHlsZXN9IHlLZXk9e3lLZXl9IC8+XG4gICAgICAgICAge3JlbGV2YW50UnVsZXMubGVuZ3RoID4gMCAmJlxuICAgICAgICAgICAgcmVsZXZhbnRSdWxlcy5tYXAocnVsZSA9PiAoXG4gICAgICAgICAgICAgIDxMZWdlbmRJdGVtQm94XG4gICAgICAgICAgICAgICAgY29sb3I9e3J1bGUuY29sb3J9XG4gICAgICAgICAgICAgICAga2V5PXtgcnVsZS0ke0pTT04uc3RyaW5naWZ5KHJ1bGUpfWB9XG4gICAgICAgICAgICAgICAgc3R5bGU9e3N0eWxlIGFzIExpbmVTdHlsZXN9XG4gICAgICAgICAgICAgICAgeUtleT17eUtleX1cbiAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgICkpfVxuICAgICAgICA8L3NwYW4+XG4gICAgICApfVxuICAgICAge3N0eWxlLnR5cGUgPT09ICdiYXInICYmIChcbiAgICAgICAgPHNwYW4gY2xhc3NOYW1lPXtjc3MoeyBkaXNwbGF5OiAnZmxleCcsIGZsZXhEaXJlY3Rpb246ICdyb3cnLCBhbGlnbkl0ZW1zOiAnY2VudGVyJywgZ2FwOiAyIH0pfT5cbiAgICAgICAgICA8TGVnZW5kSXRlbVNxdWFyZSBjb2xvcj17Y29sb3J9IC8+XG4gICAgICAgICAge3JlbGV2YW50UnVsZXMubGVuZ3RoID4gMCAmJlxuICAgICAgICAgICAgcmVsZXZhbnRSdWxlcy5tYXAocnVsZSA9PiA8TGVnZW5kSXRlbVNxdWFyZSBjb2xvcj17cnVsZS5jb2xvcn0ga2V5PXtgcnVsZS0ke0pTT04uc3RyaW5naWZ5KHJ1bGUpfWB9IC8+KX1cbiAgICAgICAgPC9zcGFuPlxuICAgICAgKX1cbiAgICAgIHtzdHlsZS50eXBlID09PSAnYXJlYScgJiYgKFxuICAgICAgICA8c3BhbiBjbGFzc05hbWU9e2Nzcyh7IGRpc3BsYXk6ICdmbGV4JywgZmxleERpcmVjdGlvbjogJ3JvdycsIGFsaWduSXRlbXM6ICdjZW50ZXInLCBnYXA6IDIgfSl9PlxuICAgICAgICAgIDxMZWdlbmRJdGVtVHJpYW5nbGUgY29sb3I9e2NvbG9yfSAvPlxuICAgICAgICAgIHtyZWxldmFudFJ1bGVzLmxlbmd0aCA+IDAgJiZcbiAgICAgICAgICAgIHJlbGV2YW50UnVsZXMubWFwKHJ1bGUgPT4gPExlZ2VuZEl0ZW1UcmlhbmdsZSBjb2xvcj17cnVsZS5jb2xvcn0ga2V5PXtgcnVsZS0ke0pTT04uc3RyaW5naWZ5KHJ1bGUpfWB9IC8+KX1cbiAgICAgICAgPC9zcGFuPlxuICAgICAgKX1cbiAgICAgIDxzcGFuXG4gICAgICAgIHN0eWxlPXt7XG4gICAgICAgICAgZm9udFNpemU6ICcxMnB4JyxcbiAgICAgICAgICBsaW5lSGVpZ2h0OiAnMTZweCcsXG4gICAgICAgICAgZGlzcGxheTogJ2Jsb2NrJyxcbiAgICAgICAgICB0ZXh0RGVjb3JhdGlvbjogdmlzaWJsZSA/ICdub25lJyA6ICdsaW5lLXRocm91Z2gnLFxuICAgICAgICAgIHRleHRXcmFwOiAnbm93cmFwJyxcbiAgICAgICAgfX1cbiAgICAgID5cbiAgICAgICAge3lLZXlGb3JtYXR0ZWQgPyB5S2V5Rm9ybWF0dGVkIDogeUtleX1cbiAgICAgIDwvc3Bhbj5cbiAgICA8L2J1dHRvbj5cbiAgKTtcbn07XG4iXX0= */",
41527
41794
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$5
41528
41795
  }),
41529
41796
  children: [jsx(LegendItemSquare, {
@@ -41533,6 +41800,23 @@ var LegendItem = function LegendItem(_ref) {
41533
41800
  color: rule.color
41534
41801
  }, "rule-" + JSON.stringify(rule));
41535
41802
  })]
41803
+ }), style.type === 'area' && jsxs("span", {
41804
+ className: /*#__PURE__*/css$1(process.env.NODE_ENV === "production" ? {
41805
+ name: "6b52m3",
41806
+ styles: "display:flex;flex-direction:row;align-items:center;gap:2px"
41807
+ } : {
41808
+ name: "pglbco-LegendItem",
41809
+ styles: "display:flex;flex-direction:row;align-items:center;gap:2px;label:LegendItem;",
41810
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZEl0ZW0udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW9FeUIiLCJmaWxlIjoiTGVnZW5kSXRlbS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgdXNlTWVtbyB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IExlZ2VuZEl0ZW1Cb3ggfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94JztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBMZWdlbmRJdGVtU3F1YXJlLCBMZWdlbmRJdGVtVHJpYW5nbGUgfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94L0xlZ2VuZEl0ZW1Cb3gnO1xuaW1wb3J0IHsgU2hhcGVEZWZpbml0aW9uLCBDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9DaGFydHNWMi90eXBlcyc7XG5pbXBvcnQgeyBMaW5lU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9MaW5lQ2hhcnRWMi90eXBlcyc7XG5pbXBvcnQgeyBCYXJTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0JhckNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQXJlYVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQXJlYUNoYXJ0VjIvdHlwZXMnO1xuXG5pbnRlcmZhY2UgTGVnZW5kSXRlbVByb3BzPFQ+IGV4dGVuZHMgU2hhcGVEZWZpbml0aW9uPFQ+IHtcbiAgb25DbGljazogKCkgPT4gdm9pZDtcbiAgdmlzaWJsZTogYm9vbGVhbjtcbiAgeUtleUZvcm1hdHRlZDogc3RyaW5nIHwgdW5kZWZpbmVkO1xuICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlczogQXJyYXk8Q29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZT47XG59XG5cbmV4cG9ydCBjb25zdCBMZWdlbmRJdGVtID0gKHtcbiAgeUtleSxcbiAgeUtleUZvcm1hdHRlZCxcbiAgY29sb3IsXG4gIHN0eWxlLFxuICBvbkNsaWNrLFxuICB2aXNpYmxlLFxuICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlcyxcbn06IExlZ2VuZEl0ZW1Qcm9wczxCYXJTdHlsZXMgfCBMaW5lU3R5bGVzIHwgQXJlYVN0eWxlcz4pID0+IHtcbiAgY29uc3QgcmVsZXZhbnRSdWxlcyA9IHVzZU1lbW8oKCkgPT4gY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXMuZmlsdGVyKHJ1bGUgPT4gcnVsZS55S2V5ID09PSB5S2V5KSwgW1xuICAgIGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzLFxuICBdKTtcblxuICByZXR1cm4gKFxuICAgIDxidXR0b25cbiAgICAgIGtleT17YGxlZ2VuZC0ke3lLZXl9YH1cbiAgICAgIHR5cGU9XCJidXR0b25cIlxuICAgICAgc3R5bGU9e3tcbiAgICAgICAgYWxsOiAndW5zZXQnLFxuICAgICAgICBkaXNwbGF5OiAnZmxleCcsXG4gICAgICAgIGZsZXhXcmFwOiAnbm93cmFwJyxcbiAgICAgICAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG4gICAgICAgIG91dGxpbmU6ICdyZXZlcnQnLFxuICAgICAgICBnYXA6ICc0cHgnLFxuICAgICAgICBwYWRkaW5nOiAnNHB4JyxcbiAgICAgICAgY3Vyc29yOiAncG9pbnRlcicsXG4gICAgICAgIG1hcmdpblJpZ2h0OiAnMTBweCcsXG4gICAgICB9fVxuICAgICAgb25DbGljaz17b25DbGlja31cbiAgICA+XG4gICAgICB7c3R5bGUudHlwZSA9PT0gJ2xpbmUnICYmIChcbiAgICAgICAgPHNwYW4gY2xhc3NOYW1lPXtjc3MoeyBoZWlnaHQ6IDEwLCBkaXNwbGF5OiAnZmxleCcgfSl9PlxuICAgICAgICAgIDxMZWdlbmRJdGVtQm94IGNvbG9yPXtjb2xvcn0gc3R5bGU9e3N0eWxlIGFzIExpbmVTdHlsZXN9IHlLZXk9e3lLZXl9IC8+XG4gICAgICAgICAge3JlbGV2YW50UnVsZXMubGVuZ3RoID4gMCAmJlxuICAgICAgICAgICAgcmVsZXZhbnRSdWxlcy5tYXAocnVsZSA9PiAoXG4gICAgICAgICAgICAgIDxMZWdlbmRJdGVtQm94XG4gICAgICAgICAgICAgICAgY29sb3I9e3J1bGUuY29sb3J9XG4gICAgICAgICAgICAgICAga2V5PXtgcnVsZS0ke0pTT04uc3RyaW5naWZ5KHJ1bGUpfWB9XG4gICAgICAgICAgICAgICAgc3R5bGU9e3N0eWxlIGFzIExpbmVTdHlsZXN9XG4gICAgICAgICAgICAgICAgeUtleT17eUtleX1cbiAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgICkpfVxuICAgICAgICA8L3NwYW4+XG4gICAgICApfVxuICAgICAge3N0eWxlLnR5cGUgPT09ICdiYXInICYmIChcbiAgICAgICAgPHNwYW4gY2xhc3NOYW1lPXtjc3MoeyBkaXNwbGF5OiAnZmxleCcsIGZsZXhEaXJlY3Rpb246ICdyb3cnLCBhbGlnbkl0ZW1zOiAnY2VudGVyJywgZ2FwOiAyIH0pfT5cbiAgICAgICAgICA8TGVnZW5kSXRlbVNxdWFyZSBjb2xvcj17Y29sb3J9IC8+XG4gICAgICAgICAge3JlbGV2YW50UnVsZXMubGVuZ3RoID4gMCAmJlxuICAgICAgICAgICAgcmVsZXZhbnRSdWxlcy5tYXAocnVsZSA9PiA8TGVnZW5kSXRlbVNxdWFyZSBjb2xvcj17cnVsZS5jb2xvcn0ga2V5PXtgcnVsZS0ke0pTT04uc3RyaW5naWZ5KHJ1bGUpfWB9IC8+KX1cbiAgICAgICAgPC9zcGFuPlxuICAgICAgKX1cbiAgICAgIHtzdHlsZS50eXBlID09PSAnYXJlYScgJiYgKFxuICAgICAgICA8c3BhbiBjbGFzc05hbWU9e2Nzcyh7IGRpc3BsYXk6ICdmbGV4JywgZmxleERpcmVjdGlvbjogJ3JvdycsIGFsaWduSXRlbXM6ICdjZW50ZXInLCBnYXA6IDIgfSl9PlxuICAgICAgICAgIDxMZWdlbmRJdGVtVHJpYW5nbGUgY29sb3I9e2NvbG9yfSAvPlxuICAgICAgICAgIHtyZWxldmFudFJ1bGVzLmxlbmd0aCA+IDAgJiZcbiAgICAgICAgICAgIHJlbGV2YW50UnVsZXMubWFwKHJ1bGUgPT4gPExlZ2VuZEl0ZW1UcmlhbmdsZSBjb2xvcj17cnVsZS5jb2xvcn0ga2V5PXtgcnVsZS0ke0pTT04uc3RyaW5naWZ5KHJ1bGUpfWB9IC8+KX1cbiAgICAgICAgPC9zcGFuPlxuICAgICAgKX1cbiAgICAgIDxzcGFuXG4gICAgICAgIHN0eWxlPXt7XG4gICAgICAgICAgZm9udFNpemU6ICcxMnB4JyxcbiAgICAgICAgICBsaW5lSGVpZ2h0OiAnMTZweCcsXG4gICAgICAgICAgZGlzcGxheTogJ2Jsb2NrJyxcbiAgICAgICAgICB0ZXh0RGVjb3JhdGlvbjogdmlzaWJsZSA/ICdub25lJyA6ICdsaW5lLXRocm91Z2gnLFxuICAgICAgICAgIHRleHRXcmFwOiAnbm93cmFwJyxcbiAgICAgICAgfX1cbiAgICAgID5cbiAgICAgICAge3lLZXlGb3JtYXR0ZWQgPyB5S2V5Rm9ybWF0dGVkIDogeUtleX1cbiAgICAgIDwvc3Bhbj5cbiAgICA8L2J1dHRvbj5cbiAgKTtcbn07XG4iXX0= */",
41811
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__$5
41812
+ }),
41813
+ children: [jsx(LegendItemTriangle, {
41814
+ color: color
41815
+ }), relevantRules.length > 0 && relevantRules.map(function (rule) {
41816
+ return jsx(LegendItemTriangle, {
41817
+ color: rule.color
41818
+ }, "rule-" + JSON.stringify(rule));
41819
+ })]
41536
41820
  }), jsx("span", {
41537
41821
  style: {
41538
41822
  fontSize: '12px',
@@ -41561,7 +41845,7 @@ var Legend$1 = function Legend(_ref) {
41561
41845
  } : {
41562
41846
  name: "qz6h7j-Legend",
41563
41847
  styles: "height:40px;padding-top:8px;label:Legend;",
41564
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMkJvQiIsImZpbGUiOiJMZWdlbmQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcblxuaW1wb3J0IHsgTGVnZW5kSXRlbSB9IGZyb20gJy4vTGVnZW5kSXRlbSc7XG5pbXBvcnQgeyBTaGFwZURlZmluaXRpb24sIENvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGUsIEtleSB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQ2hhcnRzVjIvdHlwZXMnO1xuaW1wb3J0IHsgU2Nyb2xsYmFyIH0gZnJvbSAnLi4vLi4vLi4vU2Nyb2xsYmFyL1Njcm9sbGJhcic7XG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9jc3MnO1xuaW1wb3J0IHsgQmFyU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9CYXJDaGFydFYyL3R5cGVzJztcbmltcG9ydCB7IExpbmVTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0xpbmVDaGFydFYyL3R5cGVzJztcblxuaW50ZXJmYWNlIExlZ2VuZFByb3BzPFQ+IHtcbiAgc2V0VmlzaWJsZVlLZXlzOiBSZWFjdC5EaXNwYXRjaDxSZWFjdC5TZXRTdGF0ZUFjdGlvbjxBcnJheTxzdHJpbmc+Pj47XG4gIHZpc2libGVZS2V5czogQXJyYXk8c3RyaW5nPjtcbiAga2V5czogeyBba2V5OiBzdHJpbmddOiBLZXkgfTtcbiAgbGVnZW5kSXRlbXM6IEFycmF5PFNoYXBlRGVmaW5pdGlvbjxUPj47XG4gIGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzOiBBcnJheTxDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlPjtcbiAgbWFyZ2luTGVmdDogbnVtYmVyO1xufVxuXG5leHBvcnQgY29uc3QgTGVnZW5kID0gKHtcbiAga2V5cyxcbiAgdmlzaWJsZVlLZXlzLFxuICBsZWdlbmRJdGVtcyxcbiAgc2V0VmlzaWJsZVlLZXlzLFxuICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlcyxcbiAgbWFyZ2luTGVmdCxcbn06IExlZ2VuZFByb3BzPEJhclN0eWxlcyB8IExpbmVTdHlsZXM+KSA9PiB7XG4gIHJldHVybiAoXG4gICAgPGRpdiBjbGFzc05hbWU9e2Nzcyh7IGhlaWdodDogNDAsIHBhZGRpbmdUb3A6IDggfSl9PlxuICAgICAgPFNjcm9sbGJhclxuICAgICAgICBjbGFzc05hbWU9e2Nzcyh7XG4gICAgICAgICAgZGlzcGxheTogJ2ZsZXgnLFxuICAgICAgICAgIGZsZXhEaXJlY3Rpb246ICdyb3cnLFxuICAgICAgICAgIGZsZXhXcmFwOiAnbm93cmFwJyxcbiAgICAgICAgICBhbGlnbkl0ZW1zOiAnY2VudGVyJyxcbiAgICAgICAgICBtYXJnaW5MZWZ0OiBtYXJnaW5MZWZ0ID8gYCR7bWFyZ2luTGVmdH1weGAgOiB1bmRlZmluZWQsXG4gICAgICAgIH0pfVxuICAgICAgICB4PXt0cnVlfVxuICAgICAgPlxuICAgICAgICB7bGVnZW5kSXRlbXMubWFwKFxuICAgICAgICAgIChsZWdlbmRJdGVtKSA9PlxuICAgICAgICAgICAga2V5c1tsZWdlbmRJdGVtLnlLZXldICYmIChcbiAgICAgICAgICAgICAgPExlZ2VuZEl0ZW1cbiAgICAgICAgICAgICAgICB7Li4ubGVnZW5kSXRlbX1cbiAgICAgICAgICAgICAgICBrZXk9e2BsZWdlbmQtJHtsZWdlbmRJdGVtLnlLZXl9YH1cbiAgICAgICAgICAgICAgICB5S2V5Rm9ybWF0dGVkPXtrZXlzW2xlZ2VuZEl0ZW0ueUtleV0ua2V5Rm9ybWF0dGVkfVxuICAgICAgICAgICAgICAgIG9uQ2xpY2s9eygpID0+XG4gICAgICAgICAgICAgICAgICBzZXRWaXNpYmxlWUtleXMoKHByZXYpID0+IHtcbiAgICAgICAgICAgICAgICAgICAgbGV0IG5ld1Zpc2libGVMZWdlbmRJdGVtczogQXJyYXk8c3RyaW5nPiA9IFtdO1xuXG4gICAgICAgICAgICAgICAgICAgIGlmIChwcmV2Lmxlbmd0aCA9PT0gbGVnZW5kSXRlbXMubGVuZ3RoKSB7XG4gICAgICAgICAgICAgICAgICAgICAgbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zID0gW2xlZ2VuZEl0ZW0ueUtleV07XG4gICAgICAgICAgICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICAgICAgICAgICAgaWYgKHByZXYuaW5jbHVkZXMobGVnZW5kSXRlbS55S2V5KSkge1xuICAgICAgICAgICAgICAgICAgICAgICAgbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zID0gcHJldi5maWx0ZXIoKHByZXZMZWdlbmRJdGVtSWQpID0+IHByZXZMZWdlbmRJdGVtSWQgIT09IGxlZ2VuZEl0ZW0ueUtleSk7XG4gICAgICAgICAgICAgICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgICAgICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IFsuLi5wcmV2LCBsZWdlbmRJdGVtLnlLZXldO1xuICAgICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICAgICAgfVxuXG4gICAgICAgICAgICAgICAgICAgIHJldHVybiBuZXdWaXNpYmxlTGVnZW5kSXRlbXMubGVuZ3RoID09PSAwXG4gICAgICAgICAgICAgICAgICAgICAgPyBsZWdlbmRJdGVtcy5tYXAoKGxlZ2VuZEl0ZW0pID0+IGxlZ2VuZEl0ZW0ueUtleSlcbiAgICAgICAgICAgICAgICAgICAgICA6IG5ld1Zpc2libGVMZWdlbmRJdGVtcztcbiAgICAgICAgICAgICAgICAgIH0pXG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgIHZpc2libGU9e3Zpc2libGVZS2V5cy5pbmNsdWRlcyhsZWdlbmRJdGVtLnlLZXkpfVxuICAgICAgICAgICAgICAgIGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzPXtjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlc31cbiAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgIClcbiAgICAgICAgKX1cbiAgICAgIDwvU2Nyb2xsYmFyPlxuICAgIDwvZGl2PlxuICApO1xufTtcbiJdfQ== */",
41848
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNEJvQiIsImZpbGUiOiJMZWdlbmQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcblxuaW1wb3J0IHsgTGVnZW5kSXRlbSB9IGZyb20gJy4vTGVnZW5kSXRlbSc7XG5pbXBvcnQgeyBTaGFwZURlZmluaXRpb24sIENvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGUsIEtleSB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQ2hhcnRzVjIvdHlwZXMnO1xuaW1wb3J0IHsgU2Nyb2xsYmFyIH0gZnJvbSAnLi4vLi4vLi4vU2Nyb2xsYmFyL1Njcm9sbGJhcic7XG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9jc3MnO1xuaW1wb3J0IHsgQmFyU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9CYXJDaGFydFYyL3R5cGVzJztcbmltcG9ydCB7IExpbmVTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0xpbmVDaGFydFYyL3R5cGVzJztcbmltcG9ydCB7IEFyZWFTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0FyZWFDaGFydFYyL3R5cGVzJztcblxuaW50ZXJmYWNlIExlZ2VuZFByb3BzPFQ+IHtcbiAgc2V0VmlzaWJsZVlLZXlzOiBSZWFjdC5EaXNwYXRjaDxSZWFjdC5TZXRTdGF0ZUFjdGlvbjxBcnJheTxzdHJpbmc+Pj47XG4gIHZpc2libGVZS2V5czogQXJyYXk8c3RyaW5nPjtcbiAga2V5czogeyBba2V5OiBzdHJpbmddOiBLZXkgfTtcbiAgbGVnZW5kSXRlbXM6IEFycmF5PFNoYXBlRGVmaW5pdGlvbjxUPj47XG4gIGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzOiBBcnJheTxDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlPjtcbiAgbWFyZ2luTGVmdDogbnVtYmVyO1xufVxuXG5leHBvcnQgY29uc3QgTGVnZW5kID0gKHtcbiAga2V5cyxcbiAgdmlzaWJsZVlLZXlzLFxuICBsZWdlbmRJdGVtcyxcbiAgc2V0VmlzaWJsZVlLZXlzLFxuICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlcyxcbiAgbWFyZ2luTGVmdCxcbn06IExlZ2VuZFByb3BzPEJhclN0eWxlcyB8IExpbmVTdHlsZXMgfCBBcmVhU3R5bGVzPikgPT4ge1xuICByZXR1cm4gKFxuICAgIDxkaXYgY2xhc3NOYW1lPXtjc3MoeyBoZWlnaHQ6IDQwLCBwYWRkaW5nVG9wOiA4IH0pfT5cbiAgICAgIDxTY3JvbGxiYXJcbiAgICAgICAgY2xhc3NOYW1lPXtjc3Moe1xuICAgICAgICAgIGRpc3BsYXk6ICdmbGV4JyxcbiAgICAgICAgICBmbGV4RGlyZWN0aW9uOiAncm93JyxcbiAgICAgICAgICBmbGV4V3JhcDogJ25vd3JhcCcsXG4gICAgICAgICAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG4gICAgICAgICAgbWFyZ2luTGVmdDogbWFyZ2luTGVmdCA/IGAke21hcmdpbkxlZnR9cHhgIDogdW5kZWZpbmVkLFxuICAgICAgICB9KX1cbiAgICAgICAgeD17dHJ1ZX1cbiAgICAgID5cbiAgICAgICAge2xlZ2VuZEl0ZW1zLm1hcChcbiAgICAgICAgICBsZWdlbmRJdGVtID0+XG4gICAgICAgICAgICBrZXlzW2xlZ2VuZEl0ZW0ueUtleV0gJiYgKFxuICAgICAgICAgICAgICA8TGVnZW5kSXRlbVxuICAgICAgICAgICAgICAgIHsuLi5sZWdlbmRJdGVtfVxuICAgICAgICAgICAgICAgIGtleT17YGxlZ2VuZC0ke2xlZ2VuZEl0ZW0ueUtleX1gfVxuICAgICAgICAgICAgICAgIHlLZXlGb3JtYXR0ZWQ9e2tleXNbbGVnZW5kSXRlbS55S2V5XS5rZXlGb3JtYXR0ZWR9XG4gICAgICAgICAgICAgICAgb25DbGljaz17KCkgPT5cbiAgICAgICAgICAgICAgICAgIHNldFZpc2libGVZS2V5cyhwcmV2ID0+IHtcbiAgICAgICAgICAgICAgICAgICAgbGV0IG5ld1Zpc2libGVMZWdlbmRJdGVtczogQXJyYXk8c3RyaW5nPiA9IFtdO1xuXG4gICAgICAgICAgICAgICAgICAgIGlmIChwcmV2Lmxlbmd0aCA9PT0gbGVnZW5kSXRlbXMubGVuZ3RoKSB7XG4gICAgICAgICAgICAgICAgICAgICAgbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zID0gW2xlZ2VuZEl0ZW0ueUtleV07XG4gICAgICAgICAgICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICAgICAgICAgICAgaWYgKHByZXYuaW5jbHVkZXMobGVnZW5kSXRlbS55S2V5KSkge1xuICAgICAgICAgICAgICAgICAgICAgICAgbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zID0gcHJldi5maWx0ZXIocHJldkxlZ2VuZEl0ZW1JZCA9PiBwcmV2TGVnZW5kSXRlbUlkICE9PSBsZWdlbmRJdGVtLnlLZXkpO1xuICAgICAgICAgICAgICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICAgICAgICAgICAgICBuZXdWaXNpYmxlTGVnZW5kSXRlbXMgPSBbLi4ucHJldiwgbGVnZW5kSXRlbS55S2V5XTtcbiAgICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgICAgICAgICByZXR1cm4gbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zLmxlbmd0aCA9PT0gMFxuICAgICAgICAgICAgICAgICAgICAgID8gbGVnZW5kSXRlbXMubWFwKGxlZ2VuZEl0ZW0gPT4gbGVnZW5kSXRlbS55S2V5KVxuICAgICAgICAgICAgICAgICAgICAgIDogbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zO1xuICAgICAgICAgICAgICAgICAgfSlcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgdmlzaWJsZT17dmlzaWJsZVlLZXlzLmluY2x1ZGVzKGxlZ2VuZEl0ZW0ueUtleSl9XG4gICAgICAgICAgICAgICAgY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXM9e2NvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzfVxuICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgKVxuICAgICAgICApfVxuICAgICAgPC9TY3JvbGxiYXI+XG4gICAgPC9kaXY+XG4gICk7XG59O1xuIl19 */",
41565
41849
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$6
41566
41850
  }),
41567
41851
  children: jsx(Scrollbar, {
@@ -41571,7 +41855,7 @@ var Legend$1 = function Legend(_ref) {
41571
41855
  flexWrap: 'nowrap',
41572
41856
  alignItems: 'center',
41573
41857
  marginLeft: marginLeft ? marginLeft + "px" : undefined
41574
- }, process.env.NODE_ENV === "production" ? "" : ";label:Legend;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNkJtQiIsImZpbGUiOiJMZWdlbmQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcblxuaW1wb3J0IHsgTGVnZW5kSXRlbSB9IGZyb20gJy4vTGVnZW5kSXRlbSc7XG5pbXBvcnQgeyBTaGFwZURlZmluaXRpb24sIENvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGUsIEtleSB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQ2hhcnRzVjIvdHlwZXMnO1xuaW1wb3J0IHsgU2Nyb2xsYmFyIH0gZnJvbSAnLi4vLi4vLi4vU2Nyb2xsYmFyL1Njcm9sbGJhcic7XG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9jc3MnO1xuaW1wb3J0IHsgQmFyU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9CYXJDaGFydFYyL3R5cGVzJztcbmltcG9ydCB7IExpbmVTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0xpbmVDaGFydFYyL3R5cGVzJztcblxuaW50ZXJmYWNlIExlZ2VuZFByb3BzPFQ+IHtcbiAgc2V0VmlzaWJsZVlLZXlzOiBSZWFjdC5EaXNwYXRjaDxSZWFjdC5TZXRTdGF0ZUFjdGlvbjxBcnJheTxzdHJpbmc+Pj47XG4gIHZpc2libGVZS2V5czogQXJyYXk8c3RyaW5nPjtcbiAga2V5czogeyBba2V5OiBzdHJpbmddOiBLZXkgfTtcbiAgbGVnZW5kSXRlbXM6IEFycmF5PFNoYXBlRGVmaW5pdGlvbjxUPj47XG4gIGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzOiBBcnJheTxDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlPjtcbiAgbWFyZ2luTGVmdDogbnVtYmVyO1xufVxuXG5leHBvcnQgY29uc3QgTGVnZW5kID0gKHtcbiAga2V5cyxcbiAgdmlzaWJsZVlLZXlzLFxuICBsZWdlbmRJdGVtcyxcbiAgc2V0VmlzaWJsZVlLZXlzLFxuICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlcyxcbiAgbWFyZ2luTGVmdCxcbn06IExlZ2VuZFByb3BzPEJhclN0eWxlcyB8IExpbmVTdHlsZXM+KSA9PiB7XG4gIHJldHVybiAoXG4gICAgPGRpdiBjbGFzc05hbWU9e2Nzcyh7IGhlaWdodDogNDAsIHBhZGRpbmdUb3A6IDggfSl9PlxuICAgICAgPFNjcm9sbGJhclxuICAgICAgICBjbGFzc05hbWU9e2Nzcyh7XG4gICAgICAgICAgZGlzcGxheTogJ2ZsZXgnLFxuICAgICAgICAgIGZsZXhEaXJlY3Rpb246ICdyb3cnLFxuICAgICAgICAgIGZsZXhXcmFwOiAnbm93cmFwJyxcbiAgICAgICAgICBhbGlnbkl0ZW1zOiAnY2VudGVyJyxcbiAgICAgICAgICBtYXJnaW5MZWZ0OiBtYXJnaW5MZWZ0ID8gYCR7bWFyZ2luTGVmdH1weGAgOiB1bmRlZmluZWQsXG4gICAgICAgIH0pfVxuICAgICAgICB4PXt0cnVlfVxuICAgICAgPlxuICAgICAgICB7bGVnZW5kSXRlbXMubWFwKFxuICAgICAgICAgIChsZWdlbmRJdGVtKSA9PlxuICAgICAgICAgICAga2V5c1tsZWdlbmRJdGVtLnlLZXldICYmIChcbiAgICAgICAgICAgICAgPExlZ2VuZEl0ZW1cbiAgICAgICAgICAgICAgICB7Li4ubGVnZW5kSXRlbX1cbiAgICAgICAgICAgICAgICBrZXk9e2BsZWdlbmQtJHtsZWdlbmRJdGVtLnlLZXl9YH1cbiAgICAgICAgICAgICAgICB5S2V5Rm9ybWF0dGVkPXtrZXlzW2xlZ2VuZEl0ZW0ueUtleV0ua2V5Rm9ybWF0dGVkfVxuICAgICAgICAgICAgICAgIG9uQ2xpY2s9eygpID0+XG4gICAgICAgICAgICAgICAgICBzZXRWaXNpYmxlWUtleXMoKHByZXYpID0+IHtcbiAgICAgICAgICAgICAgICAgICAgbGV0IG5ld1Zpc2libGVMZWdlbmRJdGVtczogQXJyYXk8c3RyaW5nPiA9IFtdO1xuXG4gICAgICAgICAgICAgICAgICAgIGlmIChwcmV2Lmxlbmd0aCA9PT0gbGVnZW5kSXRlbXMubGVuZ3RoKSB7XG4gICAgICAgICAgICAgICAgICAgICAgbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zID0gW2xlZ2VuZEl0ZW0ueUtleV07XG4gICAgICAgICAgICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICAgICAgICAgICAgaWYgKHByZXYuaW5jbHVkZXMobGVnZW5kSXRlbS55S2V5KSkge1xuICAgICAgICAgICAgICAgICAgICAgICAgbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zID0gcHJldi5maWx0ZXIoKHByZXZMZWdlbmRJdGVtSWQpID0+IHByZXZMZWdlbmRJdGVtSWQgIT09IGxlZ2VuZEl0ZW0ueUtleSk7XG4gICAgICAgICAgICAgICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgICAgICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IFsuLi5wcmV2LCBsZWdlbmRJdGVtLnlLZXldO1xuICAgICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICAgICAgfVxuXG4gICAgICAgICAgICAgICAgICAgIHJldHVybiBuZXdWaXNpYmxlTGVnZW5kSXRlbXMubGVuZ3RoID09PSAwXG4gICAgICAgICAgICAgICAgICAgICAgPyBsZWdlbmRJdGVtcy5tYXAoKGxlZ2VuZEl0ZW0pID0+IGxlZ2VuZEl0ZW0ueUtleSlcbiAgICAgICAgICAgICAgICAgICAgICA6IG5ld1Zpc2libGVMZWdlbmRJdGVtcztcbiAgICAgICAgICAgICAgICAgIH0pXG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgIHZpc2libGU9e3Zpc2libGVZS2V5cy5pbmNsdWRlcyhsZWdlbmRJdGVtLnlLZXkpfVxuICAgICAgICAgICAgICAgIGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzPXtjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlc31cbiAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgIClcbiAgICAgICAgKX1cbiAgICAgIDwvU2Nyb2xsYmFyPlxuICAgIDwvZGl2PlxuICApO1xufTtcbiJdfQ== */"),
41858
+ }, process.env.NODE_ENV === "production" ? "" : ";label:Legend;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBOEJtQiIsImZpbGUiOiJMZWdlbmQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcblxuaW1wb3J0IHsgTGVnZW5kSXRlbSB9IGZyb20gJy4vTGVnZW5kSXRlbSc7XG5pbXBvcnQgeyBTaGFwZURlZmluaXRpb24sIENvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGUsIEtleSB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQ2hhcnRzVjIvdHlwZXMnO1xuaW1wb3J0IHsgU2Nyb2xsYmFyIH0gZnJvbSAnLi4vLi4vLi4vU2Nyb2xsYmFyL1Njcm9sbGJhcic7XG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9jc3MnO1xuaW1wb3J0IHsgQmFyU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9CYXJDaGFydFYyL3R5cGVzJztcbmltcG9ydCB7IExpbmVTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0xpbmVDaGFydFYyL3R5cGVzJztcbmltcG9ydCB7IEFyZWFTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0FyZWFDaGFydFYyL3R5cGVzJztcblxuaW50ZXJmYWNlIExlZ2VuZFByb3BzPFQ+IHtcbiAgc2V0VmlzaWJsZVlLZXlzOiBSZWFjdC5EaXNwYXRjaDxSZWFjdC5TZXRTdGF0ZUFjdGlvbjxBcnJheTxzdHJpbmc+Pj47XG4gIHZpc2libGVZS2V5czogQXJyYXk8c3RyaW5nPjtcbiAga2V5czogeyBba2V5OiBzdHJpbmddOiBLZXkgfTtcbiAgbGVnZW5kSXRlbXM6IEFycmF5PFNoYXBlRGVmaW5pdGlvbjxUPj47XG4gIGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzOiBBcnJheTxDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlPjtcbiAgbWFyZ2luTGVmdDogbnVtYmVyO1xufVxuXG5leHBvcnQgY29uc3QgTGVnZW5kID0gKHtcbiAga2V5cyxcbiAgdmlzaWJsZVlLZXlzLFxuICBsZWdlbmRJdGVtcyxcbiAgc2V0VmlzaWJsZVlLZXlzLFxuICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlcyxcbiAgbWFyZ2luTGVmdCxcbn06IExlZ2VuZFByb3BzPEJhclN0eWxlcyB8IExpbmVTdHlsZXMgfCBBcmVhU3R5bGVzPikgPT4ge1xuICByZXR1cm4gKFxuICAgIDxkaXYgY2xhc3NOYW1lPXtjc3MoeyBoZWlnaHQ6IDQwLCBwYWRkaW5nVG9wOiA4IH0pfT5cbiAgICAgIDxTY3JvbGxiYXJcbiAgICAgICAgY2xhc3NOYW1lPXtjc3Moe1xuICAgICAgICAgIGRpc3BsYXk6ICdmbGV4JyxcbiAgICAgICAgICBmbGV4RGlyZWN0aW9uOiAncm93JyxcbiAgICAgICAgICBmbGV4V3JhcDogJ25vd3JhcCcsXG4gICAgICAgICAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG4gICAgICAgICAgbWFyZ2luTGVmdDogbWFyZ2luTGVmdCA/IGAke21hcmdpbkxlZnR9cHhgIDogdW5kZWZpbmVkLFxuICAgICAgICB9KX1cbiAgICAgICAgeD17dHJ1ZX1cbiAgICAgID5cbiAgICAgICAge2xlZ2VuZEl0ZW1zLm1hcChcbiAgICAgICAgICBsZWdlbmRJdGVtID0+XG4gICAgICAgICAgICBrZXlzW2xlZ2VuZEl0ZW0ueUtleV0gJiYgKFxuICAgICAgICAgICAgICA8TGVnZW5kSXRlbVxuICAgICAgICAgICAgICAgIHsuLi5sZWdlbmRJdGVtfVxuICAgICAgICAgICAgICAgIGtleT17YGxlZ2VuZC0ke2xlZ2VuZEl0ZW0ueUtleX1gfVxuICAgICAgICAgICAgICAgIHlLZXlGb3JtYXR0ZWQ9e2tleXNbbGVnZW5kSXRlbS55S2V5XS5rZXlGb3JtYXR0ZWR9XG4gICAgICAgICAgICAgICAgb25DbGljaz17KCkgPT5cbiAgICAgICAgICAgICAgICAgIHNldFZpc2libGVZS2V5cyhwcmV2ID0+IHtcbiAgICAgICAgICAgICAgICAgICAgbGV0IG5ld1Zpc2libGVMZWdlbmRJdGVtczogQXJyYXk8c3RyaW5nPiA9IFtdO1xuXG4gICAgICAgICAgICAgICAgICAgIGlmIChwcmV2Lmxlbmd0aCA9PT0gbGVnZW5kSXRlbXMubGVuZ3RoKSB7XG4gICAgICAgICAgICAgICAgICAgICAgbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zID0gW2xlZ2VuZEl0ZW0ueUtleV07XG4gICAgICAgICAgICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICAgICAgICAgICAgaWYgKHByZXYuaW5jbHVkZXMobGVnZW5kSXRlbS55S2V5KSkge1xuICAgICAgICAgICAgICAgICAgICAgICAgbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zID0gcHJldi5maWx0ZXIocHJldkxlZ2VuZEl0ZW1JZCA9PiBwcmV2TGVnZW5kSXRlbUlkICE9PSBsZWdlbmRJdGVtLnlLZXkpO1xuICAgICAgICAgICAgICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICAgICAgICAgICAgICBuZXdWaXNpYmxlTGVnZW5kSXRlbXMgPSBbLi4ucHJldiwgbGVnZW5kSXRlbS55S2V5XTtcbiAgICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgICAgICAgICByZXR1cm4gbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zLmxlbmd0aCA9PT0gMFxuICAgICAgICAgICAgICAgICAgICAgID8gbGVnZW5kSXRlbXMubWFwKGxlZ2VuZEl0ZW0gPT4gbGVnZW5kSXRlbS55S2V5KVxuICAgICAgICAgICAgICAgICAgICAgIDogbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zO1xuICAgICAgICAgICAgICAgICAgfSlcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgdmlzaWJsZT17dmlzaWJsZVlLZXlzLmluY2x1ZGVzKGxlZ2VuZEl0ZW0ueUtleSl9XG4gICAgICAgICAgICAgICAgY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXM9e2NvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzfVxuICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgKVxuICAgICAgICApfVxuICAgICAgPC9TY3JvbGxiYXI+XG4gICAgPC9kaXY+XG4gICk7XG59O1xuIl19 */"),
41575
41859
  x: true,
41576
41860
  children: legendItems.map(function (legendItem) {
41577
41861
  return keys[legendItem.yKey] && createElement$1(LegendItem, _extends({}, legendItem, {
@@ -41715,7 +41999,7 @@ var GoalLine = function GoalLine(_ref) {
41715
41999
  style: {
41716
42000
  position: 'relative'
41717
42001
  },
41718
- children: [jsx(Line, {
42002
+ children: [jsx(Line$1, {
41719
42003
  from: {
41720
42004
  x: margin.left,
41721
42005
  y: margin.top + y
@@ -41801,12 +42085,12 @@ var AxisBottom = function AxisBottom(_ref) {
41801
42085
  var tick = null;
41802
42086
  if (xScaleDataType === 'date_time' && value instanceof Date) {
41803
42087
  var matchingTickValue = x.ticks.find(function (tickValue) {
41804
- return tickValue.scaleValue && new Date(tickValue.scaleValue).valueOf() === value.valueOf();
42088
+ return tickValue.scaleValue && new Date(tickValue == null ? void 0 : tickValue.scaleValue).valueOf() === value.valueOf();
41805
42089
  });
41806
42090
  tick = matchingTickValue || null;
41807
42091
  } else {
41808
42092
  var _matchingTickValue = x.ticks.find(function (tickValue) {
41809
- return tickValue.scaleValue === value;
42093
+ return (tickValue == null ? void 0 : tickValue.scaleValue) === value;
41810
42094
  });
41811
42095
  tick = _matchingTickValue || null;
41812
42096
  }
@@ -41939,6 +42223,68 @@ var ChartWrapper$1 = function ChartWrapper(props) {
41939
42223
  });
41940
42224
  };
41941
42225
 
42226
+ var CrosshairCircle = function CrosshairCircle(_ref) {
42227
+ var dataType = _ref.dataType,
42228
+ yKeys = _ref.yKeys,
42229
+ tooltipData = _ref.tooltipData,
42230
+ xKey = _ref.xKey,
42231
+ margin = _ref.margin,
42232
+ conditionalFormattingRules = _ref.conditionalFormattingRules,
42233
+ legendItems = _ref.legendItems,
42234
+ visibleYKeys = _ref.visibleYKeys,
42235
+ yScale = _ref.yScale,
42236
+ xScale = _ref.xScale;
42237
+ return jsx(Fragment, {
42238
+ children: yKeys.map(function (yKey) {
42239
+ if (!xKey || !tooltipData[yKey] || tooltipData[yKey].value === null) return null;
42240
+ if (tooltipData[xKey] && tooltipData[xKey].value && dataType && visibleYKeys.includes(yKey)) {
42241
+ var xValue = tooltipData[xKey].value;
42242
+ var xValueAdjusted = dataType === 'date_time' ? new Date(xValue) : dataType === 'number' ? Number(xValue) : String(xValue);
42243
+ return jsx("circle", {
42244
+ cx:
42245
+ // @ts-ignore
42246
+ xScale(xValueAdjusted) + margin.left,
42247
+ cy: yScale(yKey) + margin.top,
42248
+ r: 4,
42249
+ fill: getColor({
42250
+ defaultColor: legendItems.filter(function (legendItem) {
42251
+ return legendItem.yKey === yKey;
42252
+ })[0].color,
42253
+ yKey: yKey,
42254
+ value: tooltipData[yKey].value,
42255
+ conditionalFormattingRules: conditionalFormattingRules
42256
+ }),
42257
+ strokeWidth: 2,
42258
+ stroke: "#fff",
42259
+ pointerEvents: "none"
42260
+ }, yKey);
42261
+ } else {
42262
+ return null;
42263
+ }
42264
+ })
42265
+ });
42266
+ };
42267
+
42268
+ var Line = function Line(_ref) {
42269
+ var margin = _ref.margin,
42270
+ x = _ref.x,
42271
+ height = _ref.height;
42272
+ return jsx(Line$1, {
42273
+ from: {
42274
+ x: x,
42275
+ y: margin.top
42276
+ },
42277
+ to: {
42278
+ x: x,
42279
+ y: height + margin.top
42280
+ },
42281
+ stroke: '#aaa',
42282
+ strokeWidth: 2,
42283
+ pointerEvents: "none",
42284
+ opacity: 0.8
42285
+ });
42286
+ };
42287
+
41942
42288
  var LineChart$5 = function LineChart(_ref) {
41943
42289
  var _theme$axis;
41944
42290
  var chart = _ref.chart,
@@ -42002,7 +42348,7 @@ var LineChart$5 = function LineChart(_ref) {
42002
42348
  }
42003
42349
  return null;
42004
42350
  }, [innerWidth, chart.x, chart.data]);
42005
- var yScale = useMemo(function () {
42351
+ var _yScale = useMemo(function () {
42006
42352
  return scaleLinear({
42007
42353
  range: [innerHeight, 0],
42008
42354
  domain: chart.y.scale.ordering === 'asc' ? [chart.y.scale.min, chart.y.scale.max] : [chart.y.scale.max, chart.y.scale.min],
@@ -42047,7 +42393,7 @@ var LineChart$5 = function LineChart(_ref) {
42047
42393
  top: margin.top,
42048
42394
  children: [jsx(GridRows, {
42049
42395
  ticks: yTickValues,
42050
- yScale: yScale,
42396
+ yScale: _yScale,
42051
42397
  width: innerWidth,
42052
42398
  height: innerHeight,
42053
42399
  removeStroke: options.removeStroke,
@@ -42066,7 +42412,7 @@ var LineChart$5 = function LineChart(_ref) {
42066
42412
  y: chart.y,
42067
42413
  margin: margin,
42068
42414
  themeCSS: themeCSS,
42069
- yScale: yScale,
42415
+ yScale: _yScale,
42070
42416
  ticks: yTickValues,
42071
42417
  stroke: theme == null || (_theme$axis = theme.axis) == null ? void 0 : _theme$axis.stroke
42072
42418
  }), jsxs(Group$2, {
@@ -42084,7 +42430,7 @@ var LineChart$5 = function LineChart(_ref) {
42084
42430
  return (_xScale = xScale(xValueAdjusted)) != null ? _xScale : 0;
42085
42431
  },
42086
42432
  y: function y(d) {
42087
- return yScale(d[yKey]);
42433
+ return _yScale(Number(d[yKey]));
42088
42434
  },
42089
42435
  stroke: chart.lines.filter(function (legendItem) {
42090
42436
  return legendItem.yKey === yKey;
@@ -42113,7 +42459,7 @@ var LineChart$5 = function LineChart(_ref) {
42113
42459
  chart: {
42114
42460
  width: innerWidth,
42115
42461
  height: innerHeight,
42116
- yScale: yScale
42462
+ yScale: _yScale
42117
42463
  }
42118
42464
  });
42119
42465
 
@@ -42132,7 +42478,7 @@ var LineChart$5 = function LineChart(_ref) {
42132
42478
  return (_xScale2 = xScale(xValueAdjusted)) != null ? _xScale2 : 0;
42133
42479
  },
42134
42480
  y: function y(d) {
42135
- return yScale(d[yKey]);
42481
+ return _yScale(Number(d[yKey]));
42136
42482
  },
42137
42483
  stroke: conditionalFormattingRule.color,
42138
42484
  strokeWidth: chart.lines.filter(function (legendItem) {
@@ -42159,49 +42505,29 @@ var LineChart$5 = function LineChart(_ref) {
42159
42505
  })]
42160
42506
  }), tooltipData && jsxs("g", {
42161
42507
  children: [jsx(Line, {
42162
- from: {
42163
- x: tooltipLeft,
42164
- y: margin.top
42165
- },
42166
- to: {
42167
- x: tooltipLeft,
42168
- y: innerHeight + margin.top
42169
- },
42170
- stroke: '#aaa',
42171
- strokeWidth: 2,
42172
- pointerEvents: "none",
42173
- opacity: 0.8
42174
- }), chart.y.keys.map(function (yKey) {
42175
- if (!xScaleKey || !tooltipData[yKey] || tooltipData[yKey].value === null) return null;
42176
- if (tooltipData[xScaleKey] && tooltipData[xScaleKey].value && xScaleDataType && visibleYKeys.includes(yKey)) {
42177
- var xValue = tooltipData[xScaleKey].value;
42178
- var xValueAdjusted = xScaleDataType === 'date_time' ? new Date(xValue) : xScaleDataType === 'number' ? Number(xValue) : String(xValue);
42179
- return jsx("circle", {
42180
- cx:
42181
- // @ts-ignore
42182
- xScale(xValueAdjusted) + margin.left,
42183
- cy: yScale(tooltipData[yKey].value !== null ? tooltipData[yKey].value : 0) + margin.top,
42184
- r: 4,
42185
- fill: getColor({
42186
- defaultColor: chart.lines.filter(function (legendItem) {
42187
- return legendItem.yKey === yKey;
42188
- })[0].color,
42189
- yKey: yKey,
42190
- value: tooltipData[yKey].value,
42191
- conditionalFormattingRules: chart.conditionalFormattingRules
42192
- }),
42193
- strokeWidth: 2,
42194
- stroke: "#fff",
42195
- pointerEvents: "none"
42196
- }, yKey);
42197
- } else {
42198
- return null;
42508
+ x: tooltipLeft,
42509
+ margin: margin,
42510
+ height: innerHeight
42511
+ }), jsx(CrosshairCircle, {
42512
+ yKeys: chart.y.keys,
42513
+ xKey: xScaleKey,
42514
+ dataType: xScaleDataType,
42515
+ legendItems: chart.lines,
42516
+ yScale: function yScale(yKey) {
42517
+ return _yScale(tooltipData[yKey].value !== null ? tooltipData[yKey].value : 0);
42199
42518
  }
42519
+ // @ts-ignore
42520
+ ,
42521
+ xScale: xScale,
42522
+ margin: margin,
42523
+ tooltipData: tooltipData,
42524
+ conditionalFormattingRules: chart.conditionalFormattingRules,
42525
+ visibleYKeys: visibleYKeys
42200
42526
  })]
42201
42527
  }), jsx(GoalLines$1, {
42202
42528
  goalLines: chart.goalLines,
42203
42529
  y: function y(d) {
42204
- return yScale(d);
42530
+ return _yScale(d);
42205
42531
  },
42206
42532
  margin: margin,
42207
42533
  width: innerWidth
@@ -42497,18 +42823,9 @@ var BarChart$5 = function BarChart(_ref) {
42497
42823
  })]
42498
42824
  }), tooltipData && jsx("g", {
42499
42825
  children: jsx(Line, {
42500
- from: {
42501
- x: tooltipLeft,
42502
- y: margin.top
42503
- },
42504
- to: {
42505
- x: tooltipLeft,
42506
- y: innerHeight + margin.top
42507
- },
42508
- stroke: '#aaa',
42509
- strokeWidth: 2,
42510
- pointerEvents: "none",
42511
- opacity: 0.8
42826
+ x: tooltipLeft,
42827
+ margin: margin,
42828
+ height: innerHeight
42512
42829
  })
42513
42830
  }), jsx(GoalLines$1, {
42514
42831
  goalLines: chart.goalLines,
@@ -42568,7 +42885,7 @@ var Bar = function Bar(props) {
42568
42885
  } : {
42569
42886
  name: "4nk3o1-Bar",
42570
42887
  styles: "cursor:pointer;label:Bar;",
42571
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["BarChart.tsx"],"names":[],"mappings":"AAuYqC","file":"BarChart.tsx","sourcesContent":["import { BarChartRepresentation } from 'shared-logic/src/BarChartV2/types';\nimport { ChartTheme } from '../../../types';\nimport { Group } from '@visx/group';\nimport { getChartThemeCSS, getTooltipData } from '../../utils';\nimport { Fragment, useCallback, useMemo, useState } from 'react';\nimport { Tooltip } from '../Tooltip';\nimport { useTooltip } from '@visx/tooltip';\nimport { Legend } from '../Legend';\nimport { BarGroup, BarStack, Line } from '@visx/shape';\nimport { DataType } from 'shared-logic/src/Field/types';\nimport { scaleLinear, scaleBand } from '@visx/scale';\nimport { getBarFill } from './getBarFill';\nimport { buildMargin } from '../../utils/buildMargin';\nimport { ChartOnViewClick, DataItem, Tick } from 'shared-logic/src/ChartsV2/types';\nimport { lightenColor } from '../../../styles/color.functions';\nimport { css } from '@emotion/css';\nimport { BarGroupBar, BarGroup as BarGroupType } from '@visx/shape/lib/types';\nimport { useFlattenedData } from '../hooks/useFlattenedData';\nimport GoalLines from '../GoalLine/GoalLines';\nimport { AxisBottom } from '../Axis/AxisBottom';\nimport { AxisLeft } from '../Axis/AxisLeft';\nimport { GridRows } from '../GridRows/GridRows';\nimport { ChartWrapper } from '../ChartWrapper/ChartWrapper';\n\n// Need to look at updating BarChart to use this type method of rendering - https://codesandbox.io/p/sandbox/visx-bar-chart-j9smpj?file=%2FExample.tsx\n// Currently it's using Stacked Chart which isn't technically correct\n\nexport type BarChartProps = {\n  width: number;\n  height: number;\n  theme?: ChartTheme;\n  chart: BarChartRepresentation;\n  options: {\n    stacked: boolean;\n    showRoundedTotal: boolean;\n    showLegend: boolean;\n    removeStroke: boolean;\n    axis: {\n      showXAxisLabels: boolean;\n      showYAxisLabels: boolean;\n    };\n  };\n  onClick: (params: ChartOnViewClick) => void;\n  enableHover?: boolean;\n};\n\nconst BAR_RADIUS = 2;\n\nconst PADDING = {\n  paddingOuter: 0.05,\n  paddingInner: 0.3,\n};\n\nexport const BarChart = ({ chart, width, height, options, theme, onClick, enableHover }: BarChartProps) => {\n  const { tooltipOpen, tooltipLeft = 0, tooltipTop = 0, tooltipData, hideTooltip, showTooltip } = useTooltip<{\n    [keyId: string]: DataItem;\n  } | null>();\n\n  const margin = buildMargin(chart.y.ticks, options.axis.showYAxisLabels, chart.y.title != null, chart.x.title != null);\n\n  // const [visibleYKeys, setVisibleYKeys] = useState(chart.bars.map((legendItem) => legendItem.yKey));\n\n  const innerWidth = width - margin.left - margin.right;\n  const innerHeight = height - margin.top - margin.bottom - (options.showLegend ? 40 : 0);\n  const xKey = chart.x.key;\n  const xScaleKey = chart.x.scale.key;\n  const yScaleKeys = chart.y.keys;\n  const xScaleDataType: DataType = chart.x.scale.dataType;\n\n  const xScale = useMemo(() => {\n    if (xScaleDataType === 'string') {\n      return scaleBand<string>({\n        range: [0, innerWidth],\n        domain: xScaleKey\n          ? [...chart.data.map(d => (d[xScaleKey] && d[xScaleKey].value !== null ? String(d[xScaleKey].value) : ''))]\n          : [],\n        ...PADDING,\n      });\n    }\n\n    if (xScaleDataType === 'date_time' && xScaleKey) {\n      return scaleBand<Date>({\n        range: [0, innerWidth],\n        domain: chart.data.map(d => new Date(d[xScaleKey].value as string)),\n        ...PADDING,\n      });\n    }\n\n    if (xScaleDataType === 'number' && xScaleKey) {\n      return scaleBand<number>({\n        range: [0, innerWidth],\n        domain: chart.data.map(d => (d[xScaleKey] && d[xScaleKey].value !== null ? Number(d[xScaleKey].value) : 0)),\n        ...PADDING,\n      });\n    }\n\n    return null;\n  }, [innerWidth, chart.x, chart.data]);\n\n  const yScale = useMemo(\n    () =>\n      scaleLinear<number>({\n        range: [innerHeight, 0],\n        domain:\n          chart.y.scale.ordering === 'asc'\n            ? [chart.y.scale.min as number, chart.y.scale.max as number]\n            : [chart.y.scale.max as number, chart.y.scale.min as number],\n        nice: true,\n        round: true,\n      }),\n    [innerHeight, chart.y]\n  );\n\n  const innerXScale = useMemo(() => {\n    if (!options.stacked && xScale && 'bandwidth' in xScale) {\n      return scaleBand<string>({\n        range: [0, xScale?.bandwidth()],\n        domain: yScaleKeys,\n        padding: 0.1,\n      });\n    }\n\n    return undefined;\n  }, [xScale, yScaleKeys, options.stacked, xScaleDataType]);\n\n  const dataFlattened = useFlattenedData<BarChartRepresentation>(xScaleKey, xScaleDataType, chart);\n\n  const handleMouseMove = useCallback(\n    (event: React.MouseEvent<SVGElement>) => {\n      if (!xKey || !xScaleKey || xScale === null) return;\n\n      const tooltipData = getTooltipData({\n        data: chart.data,\n        event,\n        margin,\n        xScaleKey,\n        xScaleDataType,\n        xOrdering: chart.x.scale.ordering,\n        xScale,\n        chartType: 'bar',\n      });\n\n      showTooltip({\n        tooltipLeft: tooltipData?.tooltipLeft,\n        tooltipTop: tooltipData?.tooltipTop,\n        tooltipData: tooltipData?.tooltipData,\n      });\n    },\n    [showTooltip, xScale, margin, xKey, xScaleKey, xScaleDataType, chart.x.scale.ordering, chart.data]\n  );\n\n  const handleMouseLeave = useCallback(() => {\n    hideTooltip();\n  }, [hideTooltip]);\n\n  const handleOnBarClick = useCallback(\n    (event: React.MouseEvent<SVGRectElement, MouseEvent>, barGroup: BarGroupType<string>, bar: BarGroupBar<string>) => {\n      onClick({\n        clickedValue: {\n          index: barGroup.index,\n          y: {\n            key: bar.key,\n            value: bar.value,\n          },\n          x: {\n            ...chart.x.ticks[barGroup.index],\n            value: chart.data[barGroup.index][xKey].value ?? '',\n            key: xKey,\n          },\n        },\n        clickEvent: event,\n      });\n    },\n    [onClick, chart.data, xKey]\n  );\n\n  const themeCSS = useMemo(() => getChartThemeCSS(theme), [theme]);\n\n  const yTickValues = chart.y.ticks.map(tick => Number(tick.value));\n\n  return (\n    <Fragment>\n      {/* width/height 100% required or useParentSize() continuously scales as parent element has no specified height */}\n      <ChartWrapper\n        width={width}\n        height={height}\n        onMouseMove={handleMouseMove}\n        onMouseLeave={handleMouseLeave}\n        showLegend={options.showLegend}\n      >\n        <Group left={margin.left} top={margin.top}>\n          <GridRows\n            ticks={yTickValues}\n            yScale={yScale}\n            width={innerWidth}\n            height={innerHeight}\n            removeStroke={options.removeStroke}\n            themeCSS={themeCSS}\n          />\n          <AxisBottom\n            x={chart.x}\n            margin={margin}\n            themeCSS={themeCSS}\n            show={options.axis.showXAxisLabels}\n            removeStroke={options.removeStroke}\n            xScaleDataType={xScaleDataType}\n            xScale={xScale}\n            height={innerHeight}\n          />\n          <AxisLeft\n            show={options.axis.showYAxisLabels}\n            y={chart.y}\n            margin={margin}\n            themeCSS={themeCSS}\n            yScale={yScale}\n            ticks={yTickValues}\n            stroke={theme?.axis?.stroke}\n          />\n          <Group>\n            {!options.stacked && (\n              <BarGroup\n                data={dataFlattened}\n                keys={yScaleKeys}\n                height={innerHeight}\n                x0={d => {\n                  // @ts-ignore\n                  const xValue = d[xScaleKey];\n\n                  if (xScaleDataType === 'string') return xValue;\n\n                  const xValueAdjusted =\n                    xScaleDataType === 'date_time'\n                      ? new Date(xValue)\n                      : xScaleDataType === 'number'\n                      ? Number(xValue)\n                      : String(xValue);\n                  // @ts-ignore\n                  return xValueAdjusted;\n                }}\n                // @ts-ignore\n                x0Scale={xScale}\n                // @ts-ignore\n                x1Scale={innerXScale}\n                yScale={yScale}\n                color={() => ''}\n              >\n                {barGroups => {\n                  return barGroups.map(barGroup => (\n                    <Group key={`bar-group-${barGroup.index}-${barGroup.x0}`} left={barGroup.x0}>\n                      {barGroup.bars.map(bar => {\n                        if (bar.value === null) return null;\n                        if (bar.height < 0 || bar.width < 0) return null;\n                        return (\n                          <Bar\n                            key={`bar-group-bar-${barGroup.index}-${bar.index}-${bar.value}-${bar.key}`}\n                            x={bar.x}\n                            y={bar.y}\n                            width={bar.width}\n                            height={bar.height}\n                            fill={getBarFill(chart.bars, chart.conditionalFormattingRules, bar.key, bar.value)}\n                            onClick={e => handleOnBarClick(e, barGroup, bar)}\n                            enableHover={enableHover}\n                          />\n                        );\n                      })}\n                    </Group>\n                  ));\n                }}\n              </BarGroup>\n            )}\n\n            {/* How to we get 'scaleValue' here? Will we need to start storing scaleKey as well as xKey? */}\n            {options.stacked && (\n              <BarStack\n                x={d => {\n                  // @ts-ignore\n                  const xValue = d[xScaleKey];\n                  if (xScaleDataType === 'string') return xValue;\n\n                  const xValueAdjusted =\n                    xScaleDataType === 'date_time'\n                      ? new Date(xValue)\n                      : xScaleDataType === 'number'\n                      ? Number(xValue)\n                      : String(xValue);\n                  // @ts-ignore\n                  return xValueAdjusted;\n                }}\n                // @ts-ignore\n                xScale={xScale}\n                yScale={yScale}\n                data={dataFlattened}\n                keys={chart.y.keys}\n                color={() => ''}\n                height={innerHeight}\n                width={innerWidth}\n                offset=\"none\"\n              >\n                {barStacks =>\n                  barStacks.map(barStack =>\n                    barStack.bars.map(bar => {\n                      if (bar.height < 3) return null;\n                      const BAR_PADDING = 1.5;\n                      return (\n                        <rect\n                          key={`bar-stack-${barStack.index}-${bar.index}`}\n                          x={bar.x}\n                          y={bar.y}\n                          width={bar.width}\n                          height={bar.height - BAR_PADDING}\n                          fill={getBarFill(chart.bars, chart.conditionalFormattingRules, bar.key, bar.bar.data)}\n                          rx={BAR_RADIUS}\n                        />\n                      );\n                    })\n                  )\n                }\n              </BarStack>\n            )}\n          </Group>\n        </Group>\n        {/* ----- TOOLTIP CROSSHAIR ----- */}\n        {tooltipData && (\n          <g>\n            <Line\n              from={{ x: tooltipLeft, y: margin.top }}\n              to={{ x: tooltipLeft, y: innerHeight + margin.top }}\n              stroke={'#aaa'}\n              strokeWidth={2}\n              pointerEvents=\"none\"\n              opacity={0.8}\n            />\n          </g>\n        )}\n        {/* ----- GOAL LINES ------ */}\n        <GoalLines goalLines={chart.goalLines} y={d => yScale(d)} margin={margin} width={innerWidth} />\n      </ChartWrapper>\n      {/* ----- LEGEND ----- */}\n      {options.showLegend && (\n        <Legend\n          legendItems={chart.bars}\n          visibleYKeys={chart.bars.map(legendItem => legendItem.yKey)}\n          setVisibleYKeys={() => {}}\n          keys={chart.keys}\n          conditionalFormattingRules={chart.conditionalFormattingRules}\n          marginLeft={margin.left - margin.leftTitleOffset}\n        />\n      )}\n      {/* ----- TOOLTIP ----- */}\n      {tooltipOpen && tooltipData && xKey && (\n        <Tooltip\n          tooltipData={tooltipData}\n          tooltipLeft={tooltipLeft}\n          tooltipTop={tooltipTop}\n          xKey={xKey}\n          keys={chart.keys}\n          visibleYKeys={chart.bars.map(legendItem => legendItem.yKey)}\n          yKeys={chart.y.keys}\n          legendItems={chart.bars}\n          showRoundedTotal={options.showRoundedTotal}\n          conditionalFormattingRules={chart.conditionalFormattingRules}\n          theme={themeCSS.popoverMenus}\n        />\n      )}\n    </Fragment>\n  );\n};\n\nconst Bar = (props: {\n  onClick: (e: React.MouseEvent<SVGRectElement, MouseEvent>) => void;\n  fill?: string;\n  x: number;\n  y: number;\n  width: number;\n  height: number;\n  key: string;\n  enableHover?: boolean;\n}) => {\n  const [fillColor, setFillColor] = useState(props.fill);\n  return (\n    <rect\n      key={props.key}\n      x={props.x}\n      y={props.y}\n      width={props.width}\n      height={props.height}\n      fill={fillColor}\n      rx={BAR_RADIUS}\n      onClick={props.onClick}\n      onMouseEnter={() => props.enableHover && setFillColor(lightenColor(props.fill, 0.8))}\n      onMouseLeave={() => props.enableHover && setFillColor(props.fill)}\n      className={props.enableHover ? css({ cursor: 'pointer' }) : ''}\n    />\n  );\n};\n"]} */",
42888
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["BarChart.tsx"],"names":[],"mappings":"AAiYqC","file":"BarChart.tsx","sourcesContent":["import { BarChartRepresentation } from 'shared-logic/src/BarChartV2/types';\nimport { ChartTheme } from '../../../types';\nimport { Group } from '@visx/group';\nimport { getChartThemeCSS, getTooltipData } from '../../utils';\nimport { Fragment, useCallback, useMemo, useState } from 'react';\nimport { Tooltip } from '../Tooltip';\nimport { useTooltip } from '@visx/tooltip';\nimport { Legend } from '../Legend';\nimport { BarGroup, BarStack } from '@visx/shape';\nimport { DataType } from 'shared-logic/src/Field/types';\nimport { scaleLinear, scaleBand } from '@visx/scale';\nimport { getBarFill } from './getBarFill';\nimport { buildMargin } from '../../utils/buildMargin';\nimport { ChartOnViewClick, ChartDataDefinition, DataItem } from 'shared-logic/src/ChartsV2/types';\nimport { lightenColor } from '../../../styles/color.functions';\nimport { css } from '@emotion/css';\nimport { BarGroupBar, BarGroup as BarGroupType } from '@visx/shape/lib/types';\nimport { useFlattenedData } from '../hooks/useFlattenedData';\nimport GoalLines from '../GoalLine/GoalLines';\nimport { AxisBottom } from '../Axis/AxisBottom';\nimport { AxisLeft } from '../Axis/AxisLeft';\nimport { GridRows } from '../GridRows/GridRows';\nimport { ChartWrapper } from '../ChartWrapper/ChartWrapper';\nimport { Line } from '../Tooltip/Line';\n\n// Need to look at updating BarChart to use this type method of rendering - https://codesandbox.io/p/sandbox/visx-bar-chart-j9smpj?file=%2FExample.tsx\n// Currently it's using Stacked Chart which isn't technically correct\n\nexport type BarChartProps = {\n  width: number;\n  height: number;\n  theme?: ChartTheme;\n  chart: BarChartRepresentation;\n  options: {\n    stacked: boolean;\n    showRoundedTotal: boolean;\n    showLegend: boolean;\n    removeStroke: boolean;\n    axis: {\n      showXAxisLabels: boolean;\n      showYAxisLabels: boolean;\n    };\n  };\n  onClick: (params: ChartOnViewClick) => void;\n  enableHover?: boolean;\n};\n\nconst BAR_RADIUS = 2;\n\nconst PADDING = {\n  paddingOuter: 0.05,\n  paddingInner: 0.3,\n};\n\nexport const BarChart = ({ chart, width, height, options, theme, onClick, enableHover }: BarChartProps) => {\n  const { tooltipOpen, tooltipLeft = 0, tooltipTop = 0, tooltipData, hideTooltip, showTooltip } = useTooltip<{\n    [keyId: string]: DataItem;\n  } | null>();\n\n  const margin = buildMargin(chart.y.ticks, options.axis.showYAxisLabels, chart.y.title != null, chart.x.title != null);\n\n  // const [visibleYKeys, setVisibleYKeys] = useState(chart.bars.map((legendItem) => legendItem.yKey));\n\n  const innerWidth = width - margin.left - margin.right;\n  const innerHeight = height - margin.top - margin.bottom - (options.showLegend ? 40 : 0);\n  const xKey = chart.x.key;\n  const xScaleKey = chart.x.scale.key;\n  const yScaleKeys = chart.y.keys;\n  const xScaleDataType: DataType = chart.x.scale.dataType;\n\n  const xScale = useMemo(() => {\n    if (xScaleDataType === 'string') {\n      return scaleBand<string>({\n        range: [0, innerWidth],\n        domain: xScaleKey\n          ? [...chart.data.map(d => (d[xScaleKey] && d[xScaleKey].value !== null ? String(d[xScaleKey].value) : ''))]\n          : [],\n        ...PADDING,\n      });\n    }\n\n    if (xScaleDataType === 'date_time' && xScaleKey) {\n      return scaleBand<Date>({\n        range: [0, innerWidth],\n        domain: chart.data.map(d => new Date(d[xScaleKey].value as string)),\n        ...PADDING,\n      });\n    }\n\n    if (xScaleDataType === 'number' && xScaleKey) {\n      return scaleBand<number>({\n        range: [0, innerWidth],\n        domain: chart.data.map(d => (d[xScaleKey] && d[xScaleKey].value !== null ? Number(d[xScaleKey].value) : 0)),\n        ...PADDING,\n      });\n    }\n\n    return null;\n  }, [innerWidth, chart.x, chart.data]);\n\n  const yScale = useMemo(\n    () =>\n      scaleLinear<number>({\n        range: [innerHeight, 0],\n        domain:\n          chart.y.scale.ordering === 'asc'\n            ? [chart.y.scale.min as number, chart.y.scale.max as number]\n            : [chart.y.scale.max as number, chart.y.scale.min as number],\n        nice: true,\n        round: true,\n      }),\n    [innerHeight, chart.y]\n  );\n\n  const innerXScale = useMemo(() => {\n    if (!options.stacked && xScale && 'bandwidth' in xScale) {\n      return scaleBand<string>({\n        range: [0, xScale?.bandwidth()],\n        domain: yScaleKeys,\n        padding: 0.1,\n      });\n    }\n\n    return undefined;\n  }, [xScale, yScaleKeys, options.stacked, xScaleDataType]);\n\n  const dataFlattened = useFlattenedData<BarChartRepresentation, ChartDataDefinition>(xScaleKey, xScaleDataType, chart);\n\n  const handleMouseMove = useCallback(\n    (event: React.MouseEvent<SVGElement>) => {\n      if (!xKey || !xScaleKey || xScale === null) return;\n\n      const tooltipData = getTooltipData({\n        data: chart.data,\n        event,\n        margin,\n        xScaleKey,\n        xScaleDataType,\n        xOrdering: chart.x.scale.ordering,\n        xScale,\n        chartType: 'bar',\n      });\n\n      showTooltip({\n        tooltipLeft: tooltipData?.tooltipLeft,\n        tooltipTop: tooltipData?.tooltipTop,\n        tooltipData: tooltipData?.tooltipData,\n      });\n    },\n    [showTooltip, xScale, margin, xKey, xScaleKey, xScaleDataType, chart.x.scale.ordering, chart.data]\n  );\n\n  const handleMouseLeave = useCallback(() => {\n    hideTooltip();\n  }, [hideTooltip]);\n\n  const handleOnBarClick = useCallback(\n    (event: React.MouseEvent<SVGRectElement, MouseEvent>, barGroup: BarGroupType<string>, bar: BarGroupBar<string>) => {\n      onClick({\n        clickedValue: {\n          index: barGroup.index,\n          y: {\n            key: bar.key,\n            value: bar.value,\n          },\n          x: {\n            ...chart.x.ticks[barGroup.index],\n            value: chart.data[barGroup.index][xKey].value ?? '',\n            key: xKey,\n          },\n        },\n        clickEvent: event,\n      });\n    },\n    [onClick, chart.data, xKey]\n  );\n\n  const themeCSS = useMemo(() => getChartThemeCSS(theme), [theme]);\n\n  const yTickValues = chart.y.ticks.map(tick => Number(tick.value));\n\n  return (\n    <Fragment>\n      {/* width/height 100% required or useParentSize() continuously scales as parent element has no specified height */}\n      <ChartWrapper\n        width={width}\n        height={height}\n        onMouseMove={handleMouseMove}\n        onMouseLeave={handleMouseLeave}\n        showLegend={options.showLegend}\n      >\n        <Group left={margin.left} top={margin.top}>\n          <GridRows\n            ticks={yTickValues}\n            yScale={yScale}\n            width={innerWidth}\n            height={innerHeight}\n            removeStroke={options.removeStroke}\n            themeCSS={themeCSS}\n          />\n          <AxisBottom\n            x={chart.x}\n            margin={margin}\n            themeCSS={themeCSS}\n            show={options.axis.showXAxisLabels}\n            removeStroke={options.removeStroke}\n            xScaleDataType={xScaleDataType}\n            xScale={xScale}\n            height={innerHeight}\n          />\n          <AxisLeft\n            show={options.axis.showYAxisLabels}\n            y={chart.y}\n            margin={margin}\n            themeCSS={themeCSS}\n            yScale={yScale}\n            ticks={yTickValues}\n            stroke={theme?.axis?.stroke}\n          />\n          <Group>\n            {!options.stacked && (\n              <BarGroup\n                data={dataFlattened}\n                keys={yScaleKeys}\n                height={innerHeight}\n                x0={d => {\n                  // @ts-ignore\n                  const xValue = d[xScaleKey];\n\n                  if (xScaleDataType === 'string') return xValue;\n\n                  const xValueAdjusted =\n                    xScaleDataType === 'date_time'\n                      ? new Date(xValue)\n                      : xScaleDataType === 'number'\n                      ? Number(xValue)\n                      : String(xValue);\n                  // @ts-ignore\n                  return xValueAdjusted;\n                }}\n                // @ts-ignore\n                x0Scale={xScale}\n                // @ts-ignore\n                x1Scale={innerXScale}\n                yScale={yScale}\n                color={() => ''}\n              >\n                {barGroups => {\n                  return barGroups.map(barGroup => (\n                    <Group key={`bar-group-${barGroup.index}-${barGroup.x0}`} left={barGroup.x0}>\n                      {barGroup.bars.map(bar => {\n                        if (bar.value === null) return null;\n                        if (bar.height < 0 || bar.width < 0) return null;\n                        return (\n                          <Bar\n                            key={`bar-group-bar-${barGroup.index}-${bar.index}-${bar.value}-${bar.key}`}\n                            x={bar.x}\n                            y={bar.y}\n                            width={bar.width}\n                            height={bar.height}\n                            fill={getBarFill(chart.bars, chart.conditionalFormattingRules, bar.key, bar.value)}\n                            onClick={e => handleOnBarClick(e, barGroup, bar)}\n                            enableHover={enableHover}\n                          />\n                        );\n                      })}\n                    </Group>\n                  ));\n                }}\n              </BarGroup>\n            )}\n\n            {/* How to we get 'scaleValue' here? Will we need to start storing scaleKey as well as xKey? */}\n            {options.stacked && (\n              <BarStack\n                x={d => {\n                  // @ts-ignore\n                  const xValue = d[xScaleKey];\n                  if (xScaleDataType === 'string') return xValue;\n\n                  const xValueAdjusted =\n                    xScaleDataType === 'date_time'\n                      ? new Date(xValue)\n                      : xScaleDataType === 'number'\n                      ? Number(xValue)\n                      : String(xValue);\n                  // @ts-ignore\n                  return xValueAdjusted;\n                }}\n                // @ts-ignore\n                xScale={xScale}\n                yScale={yScale}\n                data={dataFlattened}\n                keys={chart.y.keys}\n                color={() => ''}\n                height={innerHeight}\n                width={innerWidth}\n                offset=\"none\"\n              >\n                {barStacks =>\n                  barStacks.map(barStack =>\n                    barStack.bars.map(bar => {\n                      if (bar.height < 3) return null;\n                      const BAR_PADDING = 1.5;\n                      return (\n                        <rect\n                          key={`bar-stack-${barStack.index}-${bar.index}`}\n                          x={bar.x}\n                          y={bar.y}\n                          width={bar.width}\n                          height={bar.height - BAR_PADDING}\n                          fill={getBarFill(chart.bars, chart.conditionalFormattingRules, bar.key, bar.bar.data)}\n                          rx={BAR_RADIUS}\n                        />\n                      );\n                    })\n                  )\n                }\n              </BarStack>\n            )}\n          </Group>\n        </Group>\n        {/* ----- TOOLTIP CROSSHAIR ----- */}\n        {tooltipData && (\n          <g>\n            <Line x={tooltipLeft} margin={margin} height={innerHeight} />\n          </g>\n        )}\n        {/* ----- GOAL LINES ------ */}\n        <GoalLines goalLines={chart.goalLines} y={d => yScale(d)} margin={margin} width={innerWidth} />\n      </ChartWrapper>\n      {/* ----- LEGEND ----- */}\n      {options.showLegend && (\n        <Legend\n          legendItems={chart.bars}\n          visibleYKeys={chart.bars.map(legendItem => legendItem.yKey)}\n          setVisibleYKeys={() => {}}\n          keys={chart.keys}\n          conditionalFormattingRules={chart.conditionalFormattingRules}\n          marginLeft={margin.left - margin.leftTitleOffset}\n        />\n      )}\n      {/* ----- TOOLTIP ----- */}\n      {tooltipOpen && tooltipData && xKey && (\n        <Tooltip\n          tooltipData={tooltipData}\n          tooltipLeft={tooltipLeft}\n          tooltipTop={tooltipTop}\n          xKey={xKey}\n          keys={chart.keys}\n          visibleYKeys={chart.bars.map(legendItem => legendItem.yKey)}\n          yKeys={chart.y.keys}\n          legendItems={chart.bars}\n          showRoundedTotal={options.showRoundedTotal}\n          conditionalFormattingRules={chart.conditionalFormattingRules}\n          theme={themeCSS.popoverMenus}\n        />\n      )}\n    </Fragment>\n  );\n};\n\nconst Bar = (props: {\n  onClick: (e: React.MouseEvent<SVGRectElement, MouseEvent>) => void;\n  fill?: string;\n  x: number;\n  y: number;\n  width: number;\n  height: number;\n  key: string;\n  enableHover?: boolean;\n}) => {\n  const [fillColor, setFillColor] = useState(props.fill);\n  return (\n    <rect\n      key={props.key}\n      x={props.x}\n      y={props.y}\n      width={props.width}\n      height={props.height}\n      fill={fillColor}\n      rx={BAR_RADIUS}\n      onClick={props.onClick}\n      onMouseEnter={() => props.enableHover && setFillColor(lightenColor(props.fill, 0.8))}\n      onMouseLeave={() => props.enableHover && setFillColor(props.fill)}\n      className={props.enableHover ? css({ cursor: 'pointer' }) : ''}\n    />\n  );\n};\n"]} */",
42572
42889
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$8
42573
42890
  }) : ''
42574
42891
  }, props.key);
@@ -48023,7 +48340,7 @@ var WaterfallChart$2 = function WaterfallChart(_ref) {
48023
48340
  })
48024
48341
  })]
48025
48342
  }), tooltipData && jsx("g", {
48026
- children: jsx(Line, {
48343
+ children: jsx(Line$1, {
48027
48344
  from: {
48028
48345
  x: tooltipLeft,
48029
48346
  y: margin.top
@@ -48518,7 +48835,7 @@ var Component = function Component(props) {
48518
48835
  });
48519
48836
  },
48520
48837
  onError: dashboardBehaviour.onError,
48521
- children: jsx(BubbleChart$2, {
48838
+ children: jsx(BubbleChart$3, {
48522
48839
  id: props.id,
48523
48840
  setLocalFilters: props.setLocalFilters,
48524
48841
  dataSet: dataSet,
@@ -56981,6 +57298,22 @@ var ChartSettingsSection = function ChartSettingsSection(_ref) {
56981
57298
  }
56982
57299
  return options;
56983
57300
  }();
57301
+ var layoutOptions = function () {
57302
+ var options = [{
57303
+ label: textOverride('grouped', 'Grouped'),
57304
+ value: false
57305
+ }, {
57306
+ label: textOverride('stacked', 'Stacked'),
57307
+ value: true
57308
+ }];
57309
+ if (attributes.type === 'barChart' || attributes.type === 'areaChart') {
57310
+ options.push({
57311
+ label: textOverride('stacked_100prc', 'Stacked (100%)'),
57312
+ value: '100%'
57313
+ });
57314
+ }
57315
+ return options;
57316
+ }();
56984
57317
  return jsx(Section, {
56985
57318
  title: section.title,
56986
57319
  tooltip: section == null ? void 0 : section.description,
@@ -57000,16 +57333,7 @@ var ChartSettingsSection = function ChartSettingsSection(_ref) {
57000
57333
  stacked: stacked
57001
57334
  });
57002
57335
  },
57003
- options: [{
57004
- label: textOverride('grouped', 'Grouped'),
57005
- value: false
57006
- }, {
57007
- label: textOverride('stacked', 'Stacked'),
57008
- value: true
57009
- }, {
57010
- label: textOverride('stacked_100prc', 'Stacked (100%)'),
57011
- value: '100%'
57012
- }]
57336
+ options: layoutOptions
57013
57337
  }), section.type === 'curve' && jsx(FormatSelectInput, {
57014
57338
  label: section.title,
57015
57339
  id: "format-layout-curve",