@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.
- package/dist/charts/src/v2/components/AreaChart/AreaChart.d.ts +22 -0
- package/dist/charts/src/v2/components/AreaChart/contants.d.ts +1 -0
- package/dist/charts/src/v2/components/AreaChart/index.d.ts +1 -0
- package/dist/charts/src/v2/components/BarChart/getBarFill.d.ts +2 -4
- package/dist/charts/src/v2/components/Legend/Legend.d.ts +2 -1
- package/dist/charts/src/v2/components/Legend/LegendItem/LegendItem.d.ts +2 -1
- package/dist/charts/src/v2/components/Legend/LegendItemBox/LegendItemBox.d.ts +3 -0
- package/dist/charts/src/v2/components/Threshold/ThresholdArea.d.ts +14 -0
- package/dist/charts/src/v2/components/Threshold/threshold.utils.d.ts +4 -0
- package/dist/charts/src/v2/components/Tooltip/CrosshairCircle.d.ts +20 -0
- package/dist/charts/src/v2/components/Tooltip/Line.d.ts +7 -0
- package/dist/charts/src/v2/components/Tooltip/Tooltip.d.ts +2 -1
- package/dist/charts/src/v2/components/hooks/useFlattenedData.d.ts +1 -3
- package/dist/charts/src/v2/components/hooks/useVisibleKey.d.ts +6 -0
- package/dist/charts/src/v2/utils/useableId.d.ts +1 -0
- package/dist/dashboard.cjs.development.js +401 -80
- package/dist/dashboard.cjs.production.min.js +1 -1
- package/dist/dashboard.esm.js +406 -82
- package/dist/shared-logic/src/AreaChartV2/types.d.ts +12 -0
- package/dist/shared-logic/src/BubbleChart/getAxisFormattingFunction.d.ts +1 -1
- package/dist/shared-logic/src/ChartsV2/getAxisFormattingFunction.d.ts +1 -1
- package/dist/shared-logic/src/ChartsV2/types.d.ts +3 -0
- package/package.json +1 -1
|
@@ -57,7 +57,6 @@ var windowSize = require('@react-hook/window-size');
|
|
|
57
57
|
var copy = _interopDefault(require('copy-to-clipboard'));
|
|
58
58
|
var html2canvas = _interopDefault(require('html2canvas'));
|
|
59
59
|
var jsPDF = _interopDefault(require('jspdf'));
|
|
60
|
-
var BubbleChart$3 = require('./charts/src/BubbleChart');
|
|
61
60
|
var clipPath = require('@visx/clip-path');
|
|
62
61
|
var event = require('@visx/event');
|
|
63
62
|
var d3Array = require('@visx/vendor/d3-array');
|
|
@@ -9340,7 +9339,7 @@ var BubbleChart = function BubbleChart(config) {
|
|
|
9340
9339
|
|
|
9341
9340
|
var attributesSchema$f = function attributesSchema(config) {
|
|
9342
9341
|
return Joi.object(_extends({}, baseAttributesSchema(config.attributesSchemaOptions), timeDimensionQuerySchema(config.queryEngineConfig, config.attributesSchemaOptions), {
|
|
9343
|
-
stacked: Joi.valid(true, false
|
|
9342
|
+
stacked: Joi.valid(true, false),
|
|
9344
9343
|
legend: Joi.valid(true, false),
|
|
9345
9344
|
type: Joi.valid('barChartV2').required(),
|
|
9346
9345
|
parameters: parametersSchema(config.queryEngineConfig, config.attributesSchemaOptions),
|
|
@@ -40747,6 +40746,259 @@ var IconText = function IconText(props) {
|
|
|
40747
40746
|
});
|
|
40748
40747
|
};
|
|
40749
40748
|
|
|
40749
|
+
var accessors$1 = function accessors(xAxisIsTime, xKey, yKey, horizontal) {
|
|
40750
|
+
return {
|
|
40751
|
+
xAccessor: function xAccessor(d) {
|
|
40752
|
+
return d ? horizontal ? d[yKey] : xAxisIsTime ? new Date(d[xKey]) : d[xKey] : undefined;
|
|
40753
|
+
},
|
|
40754
|
+
yAccessor: function yAccessor(d) {
|
|
40755
|
+
return d ? horizontal ? xAxisIsTime ? new Date(d[xKey]) : d[xKey] : d[yKey] : undefined;
|
|
40756
|
+
}
|
|
40757
|
+
};
|
|
40758
|
+
};
|
|
40759
|
+
var DEFAULT_Y_AXIS_LABEL_COUNT$1 = 5;
|
|
40760
|
+
var VizzlyBubbleChart = function VizzlyBubbleChart(props) {
|
|
40761
|
+
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;
|
|
40762
|
+
var height = adjustHeight((_props$height = props == null ? void 0 : props.height) != null ? _props$height : 300, props == null ? void 0 : props.legend);
|
|
40763
|
+
var _props$approxYAxisLab = props.approxYAxisLabelCount,
|
|
40764
|
+
approxYAxisLabelCount = _props$approxYAxisLab === void 0 ? 'auto' : _props$approxYAxisLab,
|
|
40765
|
+
_props$approxXAxisLab = props.approxXAxisLabelCount,
|
|
40766
|
+
approxXAxisLabelCount = _props$approxXAxisLab === void 0 ? 'auto' : _props$approxXAxisLab,
|
|
40767
|
+
_props$removeStroke = props.removeStroke,
|
|
40768
|
+
removeStroke = _props$removeStroke === void 0 ? false : _props$removeStroke,
|
|
40769
|
+
_props$horizontal = props.horizontal,
|
|
40770
|
+
horizontal = _props$horizontal === void 0 ? false : _props$horizontal,
|
|
40771
|
+
theme = props.theme,
|
|
40772
|
+
x = props.x;
|
|
40773
|
+
var xAxisIsTime = isXAxisTime(props.x, props.forceXAxisAsTime, props.bars, props.lines, props.areas);
|
|
40774
|
+
var axisLabelStyles = function axisLabelStyles(horizontal, labelTheme) {
|
|
40775
|
+
var _labelTheme$color, _labelTheme$fontSize, _labelTheme$fontWeigh, _labelTheme$fontFamil;
|
|
40776
|
+
return {
|
|
40777
|
+
fill: (_labelTheme$color = labelTheme == null ? void 0 : labelTheme.color) != null ? _labelTheme$color : 'rgba(0, 0, 0, 0.6)',
|
|
40778
|
+
fontSize: (_labelTheme$fontSize = labelTheme == null ? void 0 : labelTheme.fontSize) != null ? _labelTheme$fontSize : 9,
|
|
40779
|
+
fontWeight: (_labelTheme$fontWeigh = labelTheme == null ? void 0 : labelTheme.fontWeight) != null ? _labelTheme$fontWeigh : 700,
|
|
40780
|
+
fontFamily: (_labelTheme$fontFamil = labelTheme == null ? void 0 : labelTheme.fontFamily) != null ? _labelTheme$fontFamil : DEFAULT_CHART_FONT,
|
|
40781
|
+
textAnchor: horizontal ? 'end' : 'middle',
|
|
40782
|
+
scaleToFit: 'shrink-only'
|
|
40783
|
+
};
|
|
40784
|
+
};
|
|
40785
|
+
var _useXAxisLabelCount = useXAxisLabelCount(approxXAxisLabelCount, !(props != null && props.horizontal) && (props == null ? void 0 : props.forceXAxisAsTime)),
|
|
40786
|
+
widthRef = _useXAxisLabelCount[0],
|
|
40787
|
+
approximateXTickCount = _useXAxisLabelCount[1];
|
|
40788
|
+
var _useState = React.useState(undefined),
|
|
40789
|
+
nearestDatum = _useState[0];
|
|
40790
|
+
var _useState2 = React.useState(undefined),
|
|
40791
|
+
nearestTooltipDatums = _useState2[0];
|
|
40792
|
+
var colors = getConcatenatedProperties(props, 'colors');
|
|
40793
|
+
var customTheme = xychart.buildChartTheme(_extends({}, xychart.lightTheme, {
|
|
40794
|
+
colors: colors,
|
|
40795
|
+
tickLength: 0,
|
|
40796
|
+
gridColor: '',
|
|
40797
|
+
gridColorDark: ''
|
|
40798
|
+
}));
|
|
40799
|
+
var chartData = getConcatenatedProperties(props, 'data');
|
|
40800
|
+
var axisStrokeColor = (_theme$axis$stroke = theme == null || (_theme$axis = theme.axis) == null ? void 0 : _theme$axis.stroke) != null ? _theme$axis$stroke : '#eaeaea';
|
|
40801
|
+
var _getAxisType = getAxisType(approxXAxisLabelCount, approxYAxisLabelCount),
|
|
40802
|
+
xAxisType = _getAxisType.xAxisType,
|
|
40803
|
+
xAxisAttributes = _getAxisType.xAxisAttributes,
|
|
40804
|
+
yAxisType = _getAxisType.yAxisType;
|
|
40805
|
+
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;
|
|
40806
|
+
var _useMinMaxValue = useMinMaxValue(props),
|
|
40807
|
+
maxValue = _useMinMaxValue.maxValue,
|
|
40808
|
+
minValue = _useMinMaxValue.minValue;
|
|
40809
|
+
var leftWidth = getYAxisWidth(horizontal, (_props$forceXAxisAsTi = props.forceXAxisAsTime) != null ? _props$forceXAxisAsTi : false, props, theme, getConcatenatedProperties(props, 'data'), props.x);
|
|
40810
|
+
var margin = props.sparkline ? NO_MARGIN(props.yAxisOrientation !== 'right') : getDefaultMargins(horizontal, props.yAxisOrientation !== 'right', xAxisType, props == null ? void 0 : props.axisTitles, leftWidth);
|
|
40811
|
+
var getTrendLineStyle = function getTrendLineStyle(datumKey) {
|
|
40812
|
+
if (props.trends) {
|
|
40813
|
+
var _props$trends, _strokeDasharrayToBor, _indicatorProperties$, _indicatorProperties$2, _indicatorProperties$3, _indicatorProperties$4, _indicatorProperties$5, _indicatorProperties$6, _indicatorProperties$7, _indicatorProperties$8, _indicatorProperties$9;
|
|
40814
|
+
var indicatorKeyIndex = (_props$trends = props.trends) == null ? void 0 : _props$trends.keys.indexOf(datumKey);
|
|
40815
|
+
var indicatorProperties = props.trends;
|
|
40816
|
+
return {
|
|
40817
|
+
borderStyle: (_strokeDasharrayToBor = strokeDasharrayToBorderStyle((_indicatorProperties$ = indicatorProperties.strokeDasharray) == null ? void 0 : _indicatorProperties$[indicatorKeyIndex])) != null ? _strokeDasharrayToBor : 'dotted',
|
|
40818
|
+
borderWidth: 0,
|
|
40819
|
+
marginTop: (_indicatorProperties$2 = (_indicatorProperties$3 = indicatorProperties.strokeWidth) == null ? void 0 : _indicatorProperties$3[indicatorKeyIndex]) != null ? _indicatorProperties$2 : 2,
|
|
40820
|
+
borderTopWidth: (_indicatorProperties$4 = (_indicatorProperties$5 = indicatorProperties.strokeWidth) == null ? void 0 : _indicatorProperties$5[indicatorKeyIndex]) != null ? _indicatorProperties$4 : 2,
|
|
40821
|
+
borderColor: (_indicatorProperties$6 = (_indicatorProperties$7 = indicatorProperties.colors) == null ? void 0 : _indicatorProperties$7[indicatorKeyIndex]) != null ? _indicatorProperties$6 : '#1E1D2D',
|
|
40822
|
+
opacity: (_indicatorProperties$8 = (_indicatorProperties$9 = indicatorProperties.opacity) == null ? void 0 : _indicatorProperties$9[indicatorKeyIndex]) != null ? _indicatorProperties$8 : 1
|
|
40823
|
+
};
|
|
40824
|
+
}
|
|
40825
|
+
return undefined;
|
|
40826
|
+
};
|
|
40827
|
+
return jsxRuntime.jsxs("div", {
|
|
40828
|
+
ref: widthRef,
|
|
40829
|
+
style: {
|
|
40830
|
+
position: 'relative',
|
|
40831
|
+
height: height
|
|
40832
|
+
},
|
|
40833
|
+
className: "vizzly-xy-chart" + (props != null && (_props$bars2 = props.bars) != null && _props$bars2.funnelChart ? ' vizzly-xy-chart-funnel' : ''),
|
|
40834
|
+
"data-testid": "vizzly-" + (props == null ? void 0 : props.uniqueId) + "-chart",
|
|
40835
|
+
children: [jsxRuntime.jsxs(xychart.XYChart, {
|
|
40836
|
+
theme: customTheme,
|
|
40837
|
+
margin: margin,
|
|
40838
|
+
height: height,
|
|
40839
|
+
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)),
|
|
40840
|
+
yScale: getYScale(props == null ? void 0 : props.goalLine, maxValue, minValue, horizontal, xAxisIsTime),
|
|
40841
|
+
horizontal: horizontal,
|
|
40842
|
+
onPointerUp: function onPointerUp(params) {
|
|
40843
|
+
return props == null ? void 0 : props.onClick(nearestDatum, nearestTooltipDatums, params);
|
|
40844
|
+
},
|
|
40845
|
+
children: [jsxRuntime.jsx(xychart.Grid, {
|
|
40846
|
+
columns: horizontal,
|
|
40847
|
+
rows: !horizontal,
|
|
40848
|
+
stroke: "black",
|
|
40849
|
+
strokeDasharray: "0.5 5",
|
|
40850
|
+
strokeWidth: removeStroke ? 0 : 2,
|
|
40851
|
+
lineStyle: {
|
|
40852
|
+
strokeLinecap: 'round',
|
|
40853
|
+
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)'
|
|
40854
|
+
}
|
|
40855
|
+
}), !(props != null && props.sparkline) && jsxRuntime.jsxs(jsxRuntime.Fragment, {
|
|
40856
|
+
children: [xAxisType !== 'none' && jsxRuntime.jsx(xychart.Axis, _extends({}, xAxisAttributes, {
|
|
40857
|
+
tickLabelProps: function tickLabelProps() {
|
|
40858
|
+
var tickLabelProps = _extends({}, axisLabelStyles(horizontal, theme == null ? void 0 : theme.labels));
|
|
40859
|
+
if (!horizontal) {
|
|
40860
|
+
tickLabelProps['y'] = 15;
|
|
40861
|
+
}
|
|
40862
|
+
return tickLabelProps;
|
|
40863
|
+
},
|
|
40864
|
+
numTicks: xAxisType === 'end2end' ? numberOfXAxisPoints : approximateXTickCount,
|
|
40865
|
+
strokeWidth: removeStroke ? 0 : 1,
|
|
40866
|
+
tickStroke: "#eaeaea",
|
|
40867
|
+
stroke: horizontal ? 'transparent' : axisStrokeColor,
|
|
40868
|
+
orientation: horizontal ? 'left' : 'bottom',
|
|
40869
|
+
tickFormat: handleFormatXAxisLabel(props.formatXAxisLabel, props.forceXAxisAsTime || xAxisIsTime, chartData),
|
|
40870
|
+
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,
|
|
40871
|
+
children: function children(axisProps) {
|
|
40872
|
+
return jsxRuntime.jsx(XAxis, _extends({}, axisProps, {
|
|
40873
|
+
theme: theme,
|
|
40874
|
+
type: xAxisType,
|
|
40875
|
+
uniqueId: props == null ? void 0 : props.uniqueId,
|
|
40876
|
+
chartWidth: props == null ? void 0 : props.width,
|
|
40877
|
+
xAxisIsTime: !!props.forceXAxisAsTime,
|
|
40878
|
+
leftPanelWidth: leftWidth,
|
|
40879
|
+
axisHorizontal: props == null ? void 0 : props.horizontal
|
|
40880
|
+
}));
|
|
40881
|
+
}
|
|
40882
|
+
})), jsxRuntime.jsx(xychart.Axis, {
|
|
40883
|
+
labelOffset: 50,
|
|
40884
|
+
tickLabelProps: function tickLabelProps() {
|
|
40885
|
+
var tickLabelProps = _extends({}, axisLabelStyles(horizontal, theme == null ? void 0 : theme.labels));
|
|
40886
|
+
if (!horizontal && props.yAxisOrientation !== 'right') {
|
|
40887
|
+
tickLabelProps['width'] = LEFT_PANEL_WIDTH;
|
|
40888
|
+
tickLabelProps['textAnchor'] = 'middle';
|
|
40889
|
+
}
|
|
40890
|
+
return tickLabelProps;
|
|
40891
|
+
},
|
|
40892
|
+
hideAxisLine: true,
|
|
40893
|
+
numTicks: approxYAxisLabelCount === 'auto' ? DEFAULT_Y_AXIS_LABEL_COUNT$1 : approxYAxisLabelCount,
|
|
40894
|
+
strokeWidth: removeStroke ? 0 : 1,
|
|
40895
|
+
hideTicks: true,
|
|
40896
|
+
tickLength: !props.horizontal && props.yAxisOrientation !== 'right' ? LEFT_PANEL_WIDTH / 2 : 10,
|
|
40897
|
+
stroke: axisStrokeColor,
|
|
40898
|
+
orientation: horizontal ? 'bottom' : props.yAxisOrientation || 'left',
|
|
40899
|
+
tickFormat: formatYAxisLabel$1(props),
|
|
40900
|
+
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,
|
|
40901
|
+
children: function children(axisProps) {
|
|
40902
|
+
return jsxRuntime.jsx(YAxis, _extends({}, axisProps, {
|
|
40903
|
+
theme: theme,
|
|
40904
|
+
type: yAxisType,
|
|
40905
|
+
horizontal: horizontal,
|
|
40906
|
+
maxValueOfYAxis: props != null && props.formatYAxisLabel ? props == null ? void 0 : props.formatYAxisLabel(maxValue) : maxValue,
|
|
40907
|
+
uniqueId: props == null ? void 0 : props.uniqueId
|
|
40908
|
+
}));
|
|
40909
|
+
}
|
|
40910
|
+
})]
|
|
40911
|
+
}), jsxRuntime.jsx("style", {
|
|
40912
|
+
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 "
|
|
40913
|
+
}), props.lines && props.lines.keys.map(function (key, keyIndex) {
|
|
40914
|
+
var _props$lines3, _props$lines4;
|
|
40915
|
+
return jsxRuntime.jsx(xychart.GlyphSeries, _extends({
|
|
40916
|
+
size: function size(datum) {
|
|
40917
|
+
if (!datum || !datum.bubbleSize) return 5;
|
|
40918
|
+
return datum.bubbleSize;
|
|
40919
|
+
},
|
|
40920
|
+
dataKey: key,
|
|
40921
|
+
data: (_props$lines3 = props.lines) == null ? void 0 : _props$lines3.data
|
|
40922
|
+
}, accessors$1(xAxisIsTime, x, key, horizontal), {
|
|
40923
|
+
colorAccessor: (props == null || (_props$lines4 = props.lines) == null ? void 0 : _props$lines4.formatter) && getColorFromDatum(key, props == null ? void 0 : props.lines.formatter, colors, keyIndex)
|
|
40924
|
+
}), "scatter_chart_" + props.uniqueId + "_" + keyIndex);
|
|
40925
|
+
})]
|
|
40926
|
+
}), (props == null ? void 0 : props.legend) && jsxRuntime.jsx(Legend, {
|
|
40927
|
+
funnelChart: props == null || (_props$bars3 = props.bars) == null ? void 0 : _props$bars3.funnelChart
|
|
40928
|
+
// groupingCount={props}
|
|
40929
|
+
,
|
|
40930
|
+
keys: getConcatenatedProperties(props, 'keys'),
|
|
40931
|
+
colors: colors,
|
|
40932
|
+
typeIndex: getTypeIndex(props),
|
|
40933
|
+
formatSeriesName: props == null ? void 0 : props.formatSeriesName,
|
|
40934
|
+
formatter: props == null || (_props$bars4 = props.bars) == null ? void 0 : _props$bars4.formatter,
|
|
40935
|
+
data: (_props$bars5 = props.bars) == null ? void 0 : _props$bars5.data,
|
|
40936
|
+
conditionalFormattingPossibilities: props.conditionalFormattingPossibilities,
|
|
40937
|
+
getIndicatorStyles: getTrendLineStyle
|
|
40938
|
+
})]
|
|
40939
|
+
});
|
|
40940
|
+
};
|
|
40941
|
+
|
|
40942
|
+
var BubbleChart$2 = /*#__PURE__*/React.forwardRef(function (props, ref) {
|
|
40943
|
+
var zValues = props.z ? props.data.map(function (d) {
|
|
40944
|
+
return d[props.z];
|
|
40945
|
+
}) : [];
|
|
40946
|
+
var normaliseArray = function normaliseArray(array, min, max) {
|
|
40947
|
+
var arrayMin = Math.min.apply(Math, array);
|
|
40948
|
+
var arrayMax = Math.max.apply(Math, array);
|
|
40949
|
+
return array.map(function (value) {
|
|
40950
|
+
return (value - arrayMin) / (arrayMax - arrayMin) * (max - min) + min;
|
|
40951
|
+
});
|
|
40952
|
+
};
|
|
40953
|
+
var scaledSizeValues = normaliseArray(zValues, 1, 30);
|
|
40954
|
+
var data = props.data.map(function (d, i) {
|
|
40955
|
+
return _extends({}, d, {
|
|
40956
|
+
bubbleSize: scaledSizeValues[i]
|
|
40957
|
+
});
|
|
40958
|
+
});
|
|
40959
|
+
var forceRerender = useChartForceRerender(ref);
|
|
40960
|
+
if (forceRerender) return null;
|
|
40961
|
+
return jsxRuntime.jsx(responsive.ParentSize, {
|
|
40962
|
+
children: function children(parent) {
|
|
40963
|
+
var _props$height, _props$width;
|
|
40964
|
+
return jsxRuntime.jsx(VizzlyBubbleChart, {
|
|
40965
|
+
isBubble: true,
|
|
40966
|
+
approxXAxisLabelCount: props.approxXAxisLabelCount,
|
|
40967
|
+
approxYAxisLabelCount: props.approxYAxisLabelCount,
|
|
40968
|
+
uniqueId: props.uniqueId,
|
|
40969
|
+
formatSeriesName: props.formatSeriesName,
|
|
40970
|
+
forceXAxisAsTime: props.forceXAxisAsTime,
|
|
40971
|
+
sparkline: props.sparkline,
|
|
40972
|
+
lines: {
|
|
40973
|
+
annotate: props.annotate || [],
|
|
40974
|
+
data: data,
|
|
40975
|
+
keys: props.keys,
|
|
40976
|
+
colors: props.colors,
|
|
40977
|
+
scatter: true
|
|
40978
|
+
},
|
|
40979
|
+
x: props.x,
|
|
40980
|
+
z: props.z,
|
|
40981
|
+
sharedTooltip: true,
|
|
40982
|
+
legend: props.legend,
|
|
40983
|
+
removeStroke: props == null ? void 0 : props.removeStroke,
|
|
40984
|
+
formatXAxisLabel: props == null ? void 0 : props.formatXAxisLabel,
|
|
40985
|
+
formatYAxisLabel: props == null ? void 0 : props.formatYAxisLabel,
|
|
40986
|
+
horizontal: props == null ? void 0 : props.horizontal,
|
|
40987
|
+
height: (_props$height = props == null ? void 0 : props.height) != null ? _props$height : parent == null ? void 0 : parent.height,
|
|
40988
|
+
width: (_props$width = props == null ? void 0 : props.width) != null ? _props$width : parent == null ? void 0 : parent.width,
|
|
40989
|
+
theme: props == null ? void 0 : props.theme,
|
|
40990
|
+
onClick: function onClick(datum) {
|
|
40991
|
+
return (props == null ? void 0 : props.onClick) && (props == null ? void 0 : props.onClick(datum));
|
|
40992
|
+
},
|
|
40993
|
+
goalLine: props == null ? void 0 : props.goalLine,
|
|
40994
|
+
axisTitles: props == null ? void 0 : props.axisTitles,
|
|
40995
|
+
idPrefix: props == null ? void 0 : props.idPrefix,
|
|
40996
|
+
popOverMenuStyles: props.popOverMenuStyles
|
|
40997
|
+
});
|
|
40998
|
+
}
|
|
40999
|
+
});
|
|
41000
|
+
});
|
|
41001
|
+
|
|
40750
41002
|
var defaultProps$6 = {
|
|
40751
41003
|
type: 'bubbleChart',
|
|
40752
41004
|
xMeasure: null,
|
|
@@ -40834,7 +41086,7 @@ var BubbleChartView = function BubbleChartView(props) {
|
|
|
40834
41086
|
queriesAreChanging: props.queriesAreChanging,
|
|
40835
41087
|
children: [jsxRuntime.jsx(ViewHeader, _extends({}, headerProps)), jsxRuntime.jsx(ChartWrapper, {
|
|
40836
41088
|
disabledFeatures: (_props$library2 = props.library) != null ? _props$library2 : false,
|
|
40837
|
-
children: jsxRuntime.jsx(BubbleChart$
|
|
41089
|
+
children: jsxRuntime.jsx(BubbleChart$2, {
|
|
40838
41090
|
ref: ref,
|
|
40839
41091
|
approxXAxisLabelCount: props.approxXAxisLabelCount,
|
|
40840
41092
|
approxYAxisLabelCount: props.approxYAxisLabelCount,
|
|
@@ -40879,7 +41131,7 @@ var BubbleChartView = function BubbleChartView(props) {
|
|
|
40879
41131
|
BubbleChartView.defaultProps = defaultProps$6;
|
|
40880
41132
|
var memoized$4 = /*#__PURE__*/React.memo(BubbleChartView, shouldUpdate);
|
|
40881
41133
|
|
|
40882
|
-
var BubbleChart$
|
|
41134
|
+
var BubbleChart$3 = function BubbleChart(props) {
|
|
40883
41135
|
var _props$dashboardBehav;
|
|
40884
41136
|
var _props$component = props.component,
|
|
40885
41137
|
results = _props$component.results,
|
|
@@ -41330,6 +41582,21 @@ var LegendItemSquare = function LegendItemSquare(_ref2) {
|
|
|
41330
41582
|
})
|
|
41331
41583
|
});
|
|
41332
41584
|
};
|
|
41585
|
+
var LegendItemTriangle = function LegendItemTriangle(_ref3) {
|
|
41586
|
+
var color = _ref3.color;
|
|
41587
|
+
return jsxRuntime.jsx("svg", {
|
|
41588
|
+
width: 8,
|
|
41589
|
+
height: 8,
|
|
41590
|
+
style: {
|
|
41591
|
+
display: 'block',
|
|
41592
|
+
borderRadius: 1
|
|
41593
|
+
},
|
|
41594
|
+
children: jsxRuntime.jsx("polygon", {
|
|
41595
|
+
points: "0,0 10,10 0,10",
|
|
41596
|
+
fill: color
|
|
41597
|
+
})
|
|
41598
|
+
});
|
|
41599
|
+
};
|
|
41333
41600
|
|
|
41334
41601
|
var Tooltip$1 = function Tooltip(_ref) {
|
|
41335
41602
|
var keys = _ref.keys,
|
|
@@ -41462,7 +41729,7 @@ var LegendItem = function LegendItem(_ref) {
|
|
|
41462
41729
|
className: /*#__PURE__*/css$1.css( {
|
|
41463
41730
|
name: "mefz6m-LegendItem",
|
|
41464
41731
|
styles: "height:10px;display:flex;label:LegendItem;",
|
|
41465
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
41732
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZEl0ZW0udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQStDeUIiLCJmaWxlIjoiTGVnZW5kSXRlbS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgdXNlTWVtbyB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IExlZ2VuZEl0ZW1Cb3ggfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94JztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBMZWdlbmRJdGVtU3F1YXJlLCBMZWdlbmRJdGVtVHJpYW5nbGUgfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94L0xlZ2VuZEl0ZW1Cb3gnO1xuaW1wb3J0IHsgU2hhcGVEZWZpbml0aW9uLCBDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9DaGFydHNWMi90eXBlcyc7XG5pbXBvcnQgeyBMaW5lU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9MaW5lQ2hhcnRWMi90eXBlcyc7XG5pbXBvcnQgeyBCYXJTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0JhckNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQXJlYVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQXJlYUNoYXJ0VjIvdHlwZXMnO1xuXG5pbnRlcmZhY2UgTGVnZW5kSXRlbVByb3BzPFQ+IGV4dGVuZHMgU2hhcGVEZWZpbml0aW9uPFQ+IHtcbiAgb25DbGljazogKCkgPT4gdm9pZDtcbiAgdmlzaWJsZTogYm9vbGVhbjtcbiAgeUtleUZvcm1hdHRlZDogc3RyaW5nIHwgdW5kZWZpbmVkO1xuICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlczogQXJyYXk8Q29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZT47XG59XG5cbmV4cG9ydCBjb25zdCBMZWdlbmRJdGVtID0gKHtcbiAgeUtleSxcbiAgeUtleUZvcm1hdHRlZCxcbiAgY29sb3IsXG4gIHN0eWxlLFxuICBvbkNsaWNrLFxuICB2aXNpYmxlLFxuICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlcyxcbn06IExlZ2VuZEl0ZW1Qcm9wczxCYXJTdHlsZXMgfCBMaW5lU3R5bGVzIHwgQXJlYVN0eWxlcz4pID0+IHtcbiAgY29uc3QgcmVsZXZhbnRSdWxlcyA9IHVzZU1lbW8oKCkgPT4gY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXMuZmlsdGVyKHJ1bGUgPT4gcnVsZS55S2V5ID09PSB5S2V5KSwgW1xuICAgIGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzLFxuICBdKTtcblxuICByZXR1cm4gKFxuICAgIDxidXR0b25cbiAgICAgIGtleT17YGxlZ2VuZC0ke3lLZXl9YH1cbiAgICAgIHR5cGU9XCJidXR0b25cIlxuICAgICAgc3R5bGU9e3tcbiAgICAgICAgYWxsOiAndW5zZXQnLFxuICAgICAgICBkaXNwbGF5OiAnZmxleCcsXG4gICAgICAgIGZsZXhXcmFwOiAnbm93cmFwJyxcbiAgICAgICAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG4gICAgICAgIG91dGxpbmU6ICdyZXZlcnQnLFxuICAgICAgICBnYXA6ICc0cHgnLFxuICAgICAgICBwYWRkaW5nOiAnNHB4JyxcbiAgICAgICAgY3Vyc29yOiAncG9pbnRlcicsXG4gICAgICAgIG1hcmdpblJpZ2h0OiAnMTBweCcsXG4gICAgICB9fVxuICAgICAgb25DbGljaz17b25DbGlja31cbiAgICA+XG4gICAgICB7c3R5bGUudHlwZSA9PT0gJ2xpbmUnICYmIChcbiAgICAgICAgPHNwYW4gY2xhc3NOYW1lPXtjc3MoeyBoZWlnaHQ6IDEwLCBkaXNwbGF5OiAnZmxleCcgfSl9PlxuICAgICAgICAgIDxMZWdlbmRJdGVtQm94IGNvbG9yPXtjb2xvcn0gc3R5bGU9e3N0eWxlIGFzIExpbmVTdHlsZXN9IHlLZXk9e3lLZXl9IC8+XG4gICAgICAgICAge3JlbGV2YW50UnVsZXMubGVuZ3RoID4gMCAmJlxuICAgICAgICAgICAgcmVsZXZhbnRSdWxlcy5tYXAocnVsZSA9PiAoXG4gICAgICAgICAgICAgIDxMZWdlbmRJdGVtQm94XG4gICAgICAgICAgICAgICAgY29sb3I9e3J1bGUuY29sb3J9XG4gICAgICAgICAgICAgICAga2V5PXtgcnVsZS0ke0pTT04uc3RyaW5naWZ5KHJ1bGUpfWB9XG4gICAgICAgICAgICAgICAgc3R5bGU9e3N0eWxlIGFzIExpbmVTdHlsZXN9XG4gICAgICAgICAgICAgICAgeUtleT17eUtleX1cbiAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgICkpfVxuICAgICAgICA8L3NwYW4+XG4gICAgICApfVxuICAgICAge3N0eWxlLnR5cGUgPT09ICdiYXInICYmIChcbiAgICAgICAgPHNwYW4gY2xhc3NOYW1lPXtjc3MoeyBkaXNwbGF5OiAnZmxleCcsIGZsZXhEaXJlY3Rpb246ICdyb3cnLCBhbGlnbkl0ZW1zOiAnY2VudGVyJywgZ2FwOiAyIH0pfT5cbiAgICAgICAgICA8TGVnZW5kSXRlbVNxdWFyZSBjb2xvcj17Y29sb3J9IC8+XG4gICAgICAgICAge3JlbGV2YW50UnVsZXMubGVuZ3RoID4gMCAmJlxuICAgICAgICAgICAgcmVsZXZhbnRSdWxlcy5tYXAocnVsZSA9PiA8TGVnZW5kSXRlbVNxdWFyZSBjb2xvcj17cnVsZS5jb2xvcn0ga2V5PXtgcnVsZS0ke0pTT04uc3RyaW5naWZ5KHJ1bGUpfWB9IC8+KX1cbiAgICAgICAgPC9zcGFuPlxuICAgICAgKX1cbiAgICAgIHtzdHlsZS50eXBlID09PSAnYXJlYScgJiYgKFxuICAgICAgICA8c3BhbiBjbGFzc05hbWU9e2Nzcyh7IGRpc3BsYXk6ICdmbGV4JywgZmxleERpcmVjdGlvbjogJ3JvdycsIGFsaWduSXRlbXM6ICdjZW50ZXInLCBnYXA6IDIgfSl9PlxuICAgICAgICAgIDxMZWdlbmRJdGVtVHJpYW5nbGUgY29sb3I9e2NvbG9yfSAvPlxuICAgICAgICAgIHtyZWxldmFudFJ1bGVzLmxlbmd0aCA+IDAgJiZcbiAgICAgICAgICAgIHJlbGV2YW50UnVsZXMubWFwKHJ1bGUgPT4gPExlZ2VuZEl0ZW1UcmlhbmdsZSBjb2xvcj17cnVsZS5jb2xvcn0ga2V5PXtgcnVsZS0ke0pTT04uc3RyaW5naWZ5KHJ1bGUpfWB9IC8+KX1cbiAgICAgICAgPC9zcGFuPlxuICAgICAgKX1cbiAgICAgIDxzcGFuXG4gICAgICAgIHN0eWxlPXt7XG4gICAgICAgICAgZm9udFNpemU6ICcxMnB4JyxcbiAgICAgICAgICBsaW5lSGVpZ2h0OiAnMTZweCcsXG4gICAgICAgICAgZGlzcGxheTogJ2Jsb2NrJyxcbiAgICAgICAgICB0ZXh0RGVjb3JhdGlvbjogdmlzaWJsZSA/ICdub25lJyA6ICdsaW5lLXRocm91Z2gnLFxuICAgICAgICAgIHRleHRXcmFwOiAnbm93cmFwJyxcbiAgICAgICAgfX1cbiAgICAgID5cbiAgICAgICAge3lLZXlGb3JtYXR0ZWQgPyB5S2V5Rm9ybWF0dGVkIDogeUtleX1cbiAgICAgIDwvc3Bhbj5cbiAgICA8L2J1dHRvbj5cbiAgKTtcbn07XG4iXX0= */",
|
|
41466
41733
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$5
|
|
41467
41734
|
}),
|
|
41468
41735
|
children: [jsxRuntime.jsx(LegendItemBox, {
|
|
@@ -41480,7 +41747,7 @@ var LegendItem = function LegendItem(_ref) {
|
|
|
41480
41747
|
className: /*#__PURE__*/css$1.css( {
|
|
41481
41748
|
name: "pglbco-LegendItem",
|
|
41482
41749
|
styles: "display:flex;flex-direction:row;align-items:center;gap:2px;label:LegendItem;",
|
|
41483
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
41750
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZEl0ZW0udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTZEeUIiLCJmaWxlIjoiTGVnZW5kSXRlbS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgdXNlTWVtbyB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IExlZ2VuZEl0ZW1Cb3ggfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94JztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBMZWdlbmRJdGVtU3F1YXJlLCBMZWdlbmRJdGVtVHJpYW5nbGUgfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94L0xlZ2VuZEl0ZW1Cb3gnO1xuaW1wb3J0IHsgU2hhcGVEZWZpbml0aW9uLCBDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9DaGFydHNWMi90eXBlcyc7XG5pbXBvcnQgeyBMaW5lU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9MaW5lQ2hhcnRWMi90eXBlcyc7XG5pbXBvcnQgeyBCYXJTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0JhckNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQXJlYVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQXJlYUNoYXJ0VjIvdHlwZXMnO1xuXG5pbnRlcmZhY2UgTGVnZW5kSXRlbVByb3BzPFQ+IGV4dGVuZHMgU2hhcGVEZWZpbml0aW9uPFQ+IHtcbiAgb25DbGljazogKCkgPT4gdm9pZDtcbiAgdmlzaWJsZTogYm9vbGVhbjtcbiAgeUtleUZvcm1hdHRlZDogc3RyaW5nIHwgdW5kZWZpbmVkO1xuICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlczogQXJyYXk8Q29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZT47XG59XG5cbmV4cG9ydCBjb25zdCBMZWdlbmRJdGVtID0gKHtcbiAgeUtleSxcbiAgeUtleUZvcm1hdHRlZCxcbiAgY29sb3IsXG4gIHN0eWxlLFxuICBvbkNsaWNrLFxuICB2aXNpYmxlLFxuICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlcyxcbn06IExlZ2VuZEl0ZW1Qcm9wczxCYXJTdHlsZXMgfCBMaW5lU3R5bGVzIHwgQXJlYVN0eWxlcz4pID0+IHtcbiAgY29uc3QgcmVsZXZhbnRSdWxlcyA9IHVzZU1lbW8oKCkgPT4gY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXMuZmlsdGVyKHJ1bGUgPT4gcnVsZS55S2V5ID09PSB5S2V5KSwgW1xuICAgIGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzLFxuICBdKTtcblxuICByZXR1cm4gKFxuICAgIDxidXR0b25cbiAgICAgIGtleT17YGxlZ2VuZC0ke3lLZXl9YH1cbiAgICAgIHR5cGU9XCJidXR0b25cIlxuICAgICAgc3R5bGU9e3tcbiAgICAgICAgYWxsOiAndW5zZXQnLFxuICAgICAgICBkaXNwbGF5OiAnZmxleCcsXG4gICAgICAgIGZsZXhXcmFwOiAnbm93cmFwJyxcbiAgICAgICAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG4gICAgICAgIG91dGxpbmU6ICdyZXZlcnQnLFxuICAgICAgICBnYXA6ICc0cHgnLFxuICAgICAgICBwYWRkaW5nOiAnNHB4JyxcbiAgICAgICAgY3Vyc29yOiAncG9pbnRlcicsXG4gICAgICAgIG1hcmdpblJpZ2h0OiAnMTBweCcsXG4gICAgICB9fVxuICAgICAgb25DbGljaz17b25DbGlja31cbiAgICA+XG4gICAgICB7c3R5bGUudHlwZSA9PT0gJ2xpbmUnICYmIChcbiAgICAgICAgPHNwYW4gY2xhc3NOYW1lPXtjc3MoeyBoZWlnaHQ6IDEwLCBkaXNwbGF5OiAnZmxleCcgfSl9PlxuICAgICAgICAgIDxMZWdlbmRJdGVtQm94IGNvbG9yPXtjb2xvcn0gc3R5bGU9e3N0eWxlIGFzIExpbmVTdHlsZXN9IHlLZXk9e3lLZXl9IC8+XG4gICAgICAgICAge3JlbGV2YW50UnVsZXMubGVuZ3RoID4gMCAmJlxuICAgICAgICAgICAgcmVsZXZhbnRSdWxlcy5tYXAocnVsZSA9PiAoXG4gICAgICAgICAgICAgIDxMZWdlbmRJdGVtQm94XG4gICAgICAgICAgICAgICAgY29sb3I9e3J1bGUuY29sb3J9XG4gICAgICAgICAgICAgICAga2V5PXtgcnVsZS0ke0pTT04uc3RyaW5naWZ5KHJ1bGUpfWB9XG4gICAgICAgICAgICAgICAgc3R5bGU9e3N0eWxlIGFzIExpbmVTdHlsZXN9XG4gICAgICAgICAgICAgICAgeUtleT17eUtleX1cbiAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgICkpfVxuICAgICAgICA8L3NwYW4+XG4gICAgICApfVxuICAgICAge3N0eWxlLnR5cGUgPT09ICdiYXInICYmIChcbiAgICAgICAgPHNwYW4gY2xhc3NOYW1lPXtjc3MoeyBkaXNwbGF5OiAnZmxleCcsIGZsZXhEaXJlY3Rpb246ICdyb3cnLCBhbGlnbkl0ZW1zOiAnY2VudGVyJywgZ2FwOiAyIH0pfT5cbiAgICAgICAgICA8TGVnZW5kSXRlbVNxdWFyZSBjb2xvcj17Y29sb3J9IC8+XG4gICAgICAgICAge3JlbGV2YW50UnVsZXMubGVuZ3RoID4gMCAmJlxuICAgICAgICAgICAgcmVsZXZhbnRSdWxlcy5tYXAocnVsZSA9PiA8TGVnZW5kSXRlbVNxdWFyZSBjb2xvcj17cnVsZS5jb2xvcn0ga2V5PXtgcnVsZS0ke0pTT04uc3RyaW5naWZ5KHJ1bGUpfWB9IC8+KX1cbiAgICAgICAgPC9zcGFuPlxuICAgICAgKX1cbiAgICAgIHtzdHlsZS50eXBlID09PSAnYXJlYScgJiYgKFxuICAgICAgICA8c3BhbiBjbGFzc05hbWU9e2Nzcyh7IGRpc3BsYXk6ICdmbGV4JywgZmxleERpcmVjdGlvbjogJ3JvdycsIGFsaWduSXRlbXM6ICdjZW50ZXInLCBnYXA6IDIgfSl9PlxuICAgICAgICAgIDxMZWdlbmRJdGVtVHJpYW5nbGUgY29sb3I9e2NvbG9yfSAvPlxuICAgICAgICAgIHtyZWxldmFudFJ1bGVzLmxlbmd0aCA+IDAgJiZcbiAgICAgICAgICAgIHJlbGV2YW50UnVsZXMubWFwKHJ1bGUgPT4gPExlZ2VuZEl0ZW1UcmlhbmdsZSBjb2xvcj17cnVsZS5jb2xvcn0ga2V5PXtgcnVsZS0ke0pTT04uc3RyaW5naWZ5KHJ1bGUpfWB9IC8+KX1cbiAgICAgICAgPC9zcGFuPlxuICAgICAgKX1cbiAgICAgIDxzcGFuXG4gICAgICAgIHN0eWxlPXt7XG4gICAgICAgICAgZm9udFNpemU6ICcxMnB4JyxcbiAgICAgICAgICBsaW5lSGVpZ2h0OiAnMTZweCcsXG4gICAgICAgICAgZGlzcGxheTogJ2Jsb2NrJyxcbiAgICAgICAgICB0ZXh0RGVjb3JhdGlvbjogdmlzaWJsZSA/ICdub25lJyA6ICdsaW5lLXRocm91Z2gnLFxuICAgICAgICAgIHRleHRXcmFwOiAnbm93cmFwJyxcbiAgICAgICAgfX1cbiAgICAgID5cbiAgICAgICAge3lLZXlGb3JtYXR0ZWQgPyB5S2V5Rm9ybWF0dGVkIDogeUtleX1cbiAgICAgIDwvc3Bhbj5cbiAgICA8L2J1dHRvbj5cbiAgKTtcbn07XG4iXX0= */",
|
|
41484
41751
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$5
|
|
41485
41752
|
}),
|
|
41486
41753
|
children: [jsxRuntime.jsx(LegendItemSquare, {
|
|
@@ -41490,6 +41757,20 @@ var LegendItem = function LegendItem(_ref) {
|
|
|
41490
41757
|
color: rule.color
|
|
41491
41758
|
}, "rule-" + JSON.stringify(rule));
|
|
41492
41759
|
})]
|
|
41760
|
+
}), style.type === 'area' && jsxRuntime.jsxs("span", {
|
|
41761
|
+
className: /*#__PURE__*/css$1.css( {
|
|
41762
|
+
name: "pglbco-LegendItem",
|
|
41763
|
+
styles: "display:flex;flex-direction:row;align-items:center;gap:2px;label:LegendItem;",
|
|
41764
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZEl0ZW0udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW9FeUIiLCJmaWxlIjoiTGVnZW5kSXRlbS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgdXNlTWVtbyB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IExlZ2VuZEl0ZW1Cb3ggfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94JztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBMZWdlbmRJdGVtU3F1YXJlLCBMZWdlbmRJdGVtVHJpYW5nbGUgfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94L0xlZ2VuZEl0ZW1Cb3gnO1xuaW1wb3J0IHsgU2hhcGVEZWZpbml0aW9uLCBDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9DaGFydHNWMi90eXBlcyc7XG5pbXBvcnQgeyBMaW5lU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9MaW5lQ2hhcnRWMi90eXBlcyc7XG5pbXBvcnQgeyBCYXJTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0JhckNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQXJlYVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQXJlYUNoYXJ0VjIvdHlwZXMnO1xuXG5pbnRlcmZhY2UgTGVnZW5kSXRlbVByb3BzPFQ+IGV4dGVuZHMgU2hhcGVEZWZpbml0aW9uPFQ+IHtcbiAgb25DbGljazogKCkgPT4gdm9pZDtcbiAgdmlzaWJsZTogYm9vbGVhbjtcbiAgeUtleUZvcm1hdHRlZDogc3RyaW5nIHwgdW5kZWZpbmVkO1xuICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlczogQXJyYXk8Q29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZT47XG59XG5cbmV4cG9ydCBjb25zdCBMZWdlbmRJdGVtID0gKHtcbiAgeUtleSxcbiAgeUtleUZvcm1hdHRlZCxcbiAgY29sb3IsXG4gIHN0eWxlLFxuICBvbkNsaWNrLFxuICB2aXNpYmxlLFxuICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlcyxcbn06IExlZ2VuZEl0ZW1Qcm9wczxCYXJTdHlsZXMgfCBMaW5lU3R5bGVzIHwgQXJlYVN0eWxlcz4pID0+IHtcbiAgY29uc3QgcmVsZXZhbnRSdWxlcyA9IHVzZU1lbW8oKCkgPT4gY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXMuZmlsdGVyKHJ1bGUgPT4gcnVsZS55S2V5ID09PSB5S2V5KSwgW1xuICAgIGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzLFxuICBdKTtcblxuICByZXR1cm4gKFxuICAgIDxidXR0b25cbiAgICAgIGtleT17YGxlZ2VuZC0ke3lLZXl9YH1cbiAgICAgIHR5cGU9XCJidXR0b25cIlxuICAgICAgc3R5bGU9e3tcbiAgICAgICAgYWxsOiAndW5zZXQnLFxuICAgICAgICBkaXNwbGF5OiAnZmxleCcsXG4gICAgICAgIGZsZXhXcmFwOiAnbm93cmFwJyxcbiAgICAgICAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG4gICAgICAgIG91dGxpbmU6ICdyZXZlcnQnLFxuICAgICAgICBnYXA6ICc0cHgnLFxuICAgICAgICBwYWRkaW5nOiAnNHB4JyxcbiAgICAgICAgY3Vyc29yOiAncG9pbnRlcicsXG4gICAgICAgIG1hcmdpblJpZ2h0OiAnMTBweCcsXG4gICAgICB9fVxuICAgICAgb25DbGljaz17b25DbGlja31cbiAgICA+XG4gICAgICB7c3R5bGUudHlwZSA9PT0gJ2xpbmUnICYmIChcbiAgICAgICAgPHNwYW4gY2xhc3NOYW1lPXtjc3MoeyBoZWlnaHQ6IDEwLCBkaXNwbGF5OiAnZmxleCcgfSl9PlxuICAgICAgICAgIDxMZWdlbmRJdGVtQm94IGNvbG9yPXtjb2xvcn0gc3R5bGU9e3N0eWxlIGFzIExpbmVTdHlsZXN9IHlLZXk9e3lLZXl9IC8+XG4gICAgICAgICAge3JlbGV2YW50UnVsZXMubGVuZ3RoID4gMCAmJlxuICAgICAgICAgICAgcmVsZXZhbnRSdWxlcy5tYXAocnVsZSA9PiAoXG4gICAgICAgICAgICAgIDxMZWdlbmRJdGVtQm94XG4gICAgICAgICAgICAgICAgY29sb3I9e3J1bGUuY29sb3J9XG4gICAgICAgICAgICAgICAga2V5PXtgcnVsZS0ke0pTT04uc3RyaW5naWZ5KHJ1bGUpfWB9XG4gICAgICAgICAgICAgICAgc3R5bGU9e3N0eWxlIGFzIExpbmVTdHlsZXN9XG4gICAgICAgICAgICAgICAgeUtleT17eUtleX1cbiAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgICkpfVxuICAgICAgICA8L3NwYW4+XG4gICAgICApfVxuICAgICAge3N0eWxlLnR5cGUgPT09ICdiYXInICYmIChcbiAgICAgICAgPHNwYW4gY2xhc3NOYW1lPXtjc3MoeyBkaXNwbGF5OiAnZmxleCcsIGZsZXhEaXJlY3Rpb246ICdyb3cnLCBhbGlnbkl0ZW1zOiAnY2VudGVyJywgZ2FwOiAyIH0pfT5cbiAgICAgICAgICA8TGVnZW5kSXRlbVNxdWFyZSBjb2xvcj17Y29sb3J9IC8+XG4gICAgICAgICAge3JlbGV2YW50UnVsZXMubGVuZ3RoID4gMCAmJlxuICAgICAgICAgICAgcmVsZXZhbnRSdWxlcy5tYXAocnVsZSA9PiA8TGVnZW5kSXRlbVNxdWFyZSBjb2xvcj17cnVsZS5jb2xvcn0ga2V5PXtgcnVsZS0ke0pTT04uc3RyaW5naWZ5KHJ1bGUpfWB9IC8+KX1cbiAgICAgICAgPC9zcGFuPlxuICAgICAgKX1cbiAgICAgIHtzdHlsZS50eXBlID09PSAnYXJlYScgJiYgKFxuICAgICAgICA8c3BhbiBjbGFzc05hbWU9e2Nzcyh7IGRpc3BsYXk6ICdmbGV4JywgZmxleERpcmVjdGlvbjogJ3JvdycsIGFsaWduSXRlbXM6ICdjZW50ZXInLCBnYXA6IDIgfSl9PlxuICAgICAgICAgIDxMZWdlbmRJdGVtVHJpYW5nbGUgY29sb3I9e2NvbG9yfSAvPlxuICAgICAgICAgIHtyZWxldmFudFJ1bGVzLmxlbmd0aCA+IDAgJiZcbiAgICAgICAgICAgIHJlbGV2YW50UnVsZXMubWFwKHJ1bGUgPT4gPExlZ2VuZEl0ZW1UcmlhbmdsZSBjb2xvcj17cnVsZS5jb2xvcn0ga2V5PXtgcnVsZS0ke0pTT04uc3RyaW5naWZ5KHJ1bGUpfWB9IC8+KX1cbiAgICAgICAgPC9zcGFuPlxuICAgICAgKX1cbiAgICAgIDxzcGFuXG4gICAgICAgIHN0eWxlPXt7XG4gICAgICAgICAgZm9udFNpemU6ICcxMnB4JyxcbiAgICAgICAgICBsaW5lSGVpZ2h0OiAnMTZweCcsXG4gICAgICAgICAgZGlzcGxheTogJ2Jsb2NrJyxcbiAgICAgICAgICB0ZXh0RGVjb3JhdGlvbjogdmlzaWJsZSA/ICdub25lJyA6ICdsaW5lLXRocm91Z2gnLFxuICAgICAgICAgIHRleHRXcmFwOiAnbm93cmFwJyxcbiAgICAgICAgfX1cbiAgICAgID5cbiAgICAgICAge3lLZXlGb3JtYXR0ZWQgPyB5S2V5Rm9ybWF0dGVkIDogeUtleX1cbiAgICAgIDwvc3Bhbj5cbiAgICA8L2J1dHRvbj5cbiAgKTtcbn07XG4iXX0= */",
|
|
41765
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$5
|
|
41766
|
+
}),
|
|
41767
|
+
children: [jsxRuntime.jsx(LegendItemTriangle, {
|
|
41768
|
+
color: color
|
|
41769
|
+
}), relevantRules.length > 0 && relevantRules.map(function (rule) {
|
|
41770
|
+
return jsxRuntime.jsx(LegendItemTriangle, {
|
|
41771
|
+
color: rule.color
|
|
41772
|
+
}, "rule-" + JSON.stringify(rule));
|
|
41773
|
+
})]
|
|
41493
41774
|
}), jsxRuntime.jsx("span", {
|
|
41494
41775
|
style: {
|
|
41495
41776
|
fontSize: '12px',
|
|
@@ -41515,7 +41796,7 @@ var Legend$1 = function Legend(_ref) {
|
|
|
41515
41796
|
className: /*#__PURE__*/css$1.css( {
|
|
41516
41797
|
name: "qz6h7j-Legend",
|
|
41517
41798
|
styles: "height:40px;padding-top:8px;label:Legend;",
|
|
41518
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
41799
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNEJvQiIsImZpbGUiOiJMZWdlbmQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcblxuaW1wb3J0IHsgTGVnZW5kSXRlbSB9IGZyb20gJy4vTGVnZW5kSXRlbSc7XG5pbXBvcnQgeyBTaGFwZURlZmluaXRpb24sIENvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGUsIEtleSB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQ2hhcnRzVjIvdHlwZXMnO1xuaW1wb3J0IHsgU2Nyb2xsYmFyIH0gZnJvbSAnLi4vLi4vLi4vU2Nyb2xsYmFyL1Njcm9sbGJhcic7XG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9jc3MnO1xuaW1wb3J0IHsgQmFyU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9CYXJDaGFydFYyL3R5cGVzJztcbmltcG9ydCB7IExpbmVTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0xpbmVDaGFydFYyL3R5cGVzJztcbmltcG9ydCB7IEFyZWFTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0FyZWFDaGFydFYyL3R5cGVzJztcblxuaW50ZXJmYWNlIExlZ2VuZFByb3BzPFQ+IHtcbiAgc2V0VmlzaWJsZVlLZXlzOiBSZWFjdC5EaXNwYXRjaDxSZWFjdC5TZXRTdGF0ZUFjdGlvbjxBcnJheTxzdHJpbmc+Pj47XG4gIHZpc2libGVZS2V5czogQXJyYXk8c3RyaW5nPjtcbiAga2V5czogeyBba2V5OiBzdHJpbmddOiBLZXkgfTtcbiAgbGVnZW5kSXRlbXM6IEFycmF5PFNoYXBlRGVmaW5pdGlvbjxUPj47XG4gIGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzOiBBcnJheTxDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlPjtcbiAgbWFyZ2luTGVmdDogbnVtYmVyO1xufVxuXG5leHBvcnQgY29uc3QgTGVnZW5kID0gKHtcbiAga2V5cyxcbiAgdmlzaWJsZVlLZXlzLFxuICBsZWdlbmRJdGVtcyxcbiAgc2V0VmlzaWJsZVlLZXlzLFxuICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlcyxcbiAgbWFyZ2luTGVmdCxcbn06IExlZ2VuZFByb3BzPEJhclN0eWxlcyB8IExpbmVTdHlsZXMgfCBBcmVhU3R5bGVzPikgPT4ge1xuICByZXR1cm4gKFxuICAgIDxkaXYgY2xhc3NOYW1lPXtjc3MoeyBoZWlnaHQ6IDQwLCBwYWRkaW5nVG9wOiA4IH0pfT5cbiAgICAgIDxTY3JvbGxiYXJcbiAgICAgICAgY2xhc3NOYW1lPXtjc3Moe1xuICAgICAgICAgIGRpc3BsYXk6ICdmbGV4JyxcbiAgICAgICAgICBmbGV4RGlyZWN0aW9uOiAncm93JyxcbiAgICAgICAgICBmbGV4V3JhcDogJ25vd3JhcCcsXG4gICAgICAgICAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG4gICAgICAgICAgbWFyZ2luTGVmdDogbWFyZ2luTGVmdCA/IGAke21hcmdpbkxlZnR9cHhgIDogdW5kZWZpbmVkLFxuICAgICAgICB9KX1cbiAgICAgICAgeD17dHJ1ZX1cbiAgICAgID5cbiAgICAgICAge2xlZ2VuZEl0ZW1zLm1hcChcbiAgICAgICAgICBsZWdlbmRJdGVtID0+XG4gICAgICAgICAgICBrZXlzW2xlZ2VuZEl0ZW0ueUtleV0gJiYgKFxuICAgICAgICAgICAgICA8TGVnZW5kSXRlbVxuICAgICAgICAgICAgICAgIHsuLi5sZWdlbmRJdGVtfVxuICAgICAgICAgICAgICAgIGtleT17YGxlZ2VuZC0ke2xlZ2VuZEl0ZW0ueUtleX1gfVxuICAgICAgICAgICAgICAgIHlLZXlGb3JtYXR0ZWQ9e2tleXNbbGVnZW5kSXRlbS55S2V5XS5rZXlGb3JtYXR0ZWR9XG4gICAgICAgICAgICAgICAgb25DbGljaz17KCkgPT5cbiAgICAgICAgICAgICAgICAgIHNldFZpc2libGVZS2V5cyhwcmV2ID0+IHtcbiAgICAgICAgICAgICAgICAgICAgbGV0IG5ld1Zpc2libGVMZWdlbmRJdGVtczogQXJyYXk8c3RyaW5nPiA9IFtdO1xuXG4gICAgICAgICAgICAgICAgICAgIGlmIChwcmV2Lmxlbmd0aCA9PT0gbGVnZW5kSXRlbXMubGVuZ3RoKSB7XG4gICAgICAgICAgICAgICAgICAgICAgbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zID0gW2xlZ2VuZEl0ZW0ueUtleV07XG4gICAgICAgICAgICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICAgICAgICAgICAgaWYgKHByZXYuaW5jbHVkZXMobGVnZW5kSXRlbS55S2V5KSkge1xuICAgICAgICAgICAgICAgICAgICAgICAgbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zID0gcHJldi5maWx0ZXIocHJldkxlZ2VuZEl0ZW1JZCA9PiBwcmV2TGVnZW5kSXRlbUlkICE9PSBsZWdlbmRJdGVtLnlLZXkpO1xuICAgICAgICAgICAgICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICAgICAgICAgICAgICBuZXdWaXNpYmxlTGVnZW5kSXRlbXMgPSBbLi4ucHJldiwgbGVnZW5kSXRlbS55S2V5XTtcbiAgICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgICAgICAgICByZXR1cm4gbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zLmxlbmd0aCA9PT0gMFxuICAgICAgICAgICAgICAgICAgICAgID8gbGVnZW5kSXRlbXMubWFwKGxlZ2VuZEl0ZW0gPT4gbGVnZW5kSXRlbS55S2V5KVxuICAgICAgICAgICAgICAgICAgICAgIDogbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zO1xuICAgICAgICAgICAgICAgICAgfSlcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgdmlzaWJsZT17dmlzaWJsZVlLZXlzLmluY2x1ZGVzKGxlZ2VuZEl0ZW0ueUtleSl9XG4gICAgICAgICAgICAgICAgY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXM9e2NvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzfVxuICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgKVxuICAgICAgICApfVxuICAgICAgPC9TY3JvbGxiYXI+XG4gICAgPC9kaXY+XG4gICk7XG59O1xuIl19 */",
|
|
41519
41800
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$6
|
|
41520
41801
|
}),
|
|
41521
41802
|
children: jsxRuntime.jsx(Scrollbar, {
|
|
@@ -41525,7 +41806,7 @@ var Legend$1 = function Legend(_ref) {
|
|
|
41525
41806
|
flexWrap: 'nowrap',
|
|
41526
41807
|
alignItems: 'center',
|
|
41527
41808
|
marginLeft: marginLeft ? marginLeft + "px" : undefined
|
|
41528
|
-
}, ";label:Legend;", "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
41809
|
+
}, ";label:Legend;", "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBOEJtQiIsImZpbGUiOiJMZWdlbmQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcblxuaW1wb3J0IHsgTGVnZW5kSXRlbSB9IGZyb20gJy4vTGVnZW5kSXRlbSc7XG5pbXBvcnQgeyBTaGFwZURlZmluaXRpb24sIENvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGUsIEtleSB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQ2hhcnRzVjIvdHlwZXMnO1xuaW1wb3J0IHsgU2Nyb2xsYmFyIH0gZnJvbSAnLi4vLi4vLi4vU2Nyb2xsYmFyL1Njcm9sbGJhcic7XG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9jc3MnO1xuaW1wb3J0IHsgQmFyU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9CYXJDaGFydFYyL3R5cGVzJztcbmltcG9ydCB7IExpbmVTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0xpbmVDaGFydFYyL3R5cGVzJztcbmltcG9ydCB7IEFyZWFTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0FyZWFDaGFydFYyL3R5cGVzJztcblxuaW50ZXJmYWNlIExlZ2VuZFByb3BzPFQ+IHtcbiAgc2V0VmlzaWJsZVlLZXlzOiBSZWFjdC5EaXNwYXRjaDxSZWFjdC5TZXRTdGF0ZUFjdGlvbjxBcnJheTxzdHJpbmc+Pj47XG4gIHZpc2libGVZS2V5czogQXJyYXk8c3RyaW5nPjtcbiAga2V5czogeyBba2V5OiBzdHJpbmddOiBLZXkgfTtcbiAgbGVnZW5kSXRlbXM6IEFycmF5PFNoYXBlRGVmaW5pdGlvbjxUPj47XG4gIGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzOiBBcnJheTxDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlPjtcbiAgbWFyZ2luTGVmdDogbnVtYmVyO1xufVxuXG5leHBvcnQgY29uc3QgTGVnZW5kID0gKHtcbiAga2V5cyxcbiAgdmlzaWJsZVlLZXlzLFxuICBsZWdlbmRJdGVtcyxcbiAgc2V0VmlzaWJsZVlLZXlzLFxuICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlcyxcbiAgbWFyZ2luTGVmdCxcbn06IExlZ2VuZFByb3BzPEJhclN0eWxlcyB8IExpbmVTdHlsZXMgfCBBcmVhU3R5bGVzPikgPT4ge1xuICByZXR1cm4gKFxuICAgIDxkaXYgY2xhc3NOYW1lPXtjc3MoeyBoZWlnaHQ6IDQwLCBwYWRkaW5nVG9wOiA4IH0pfT5cbiAgICAgIDxTY3JvbGxiYXJcbiAgICAgICAgY2xhc3NOYW1lPXtjc3Moe1xuICAgICAgICAgIGRpc3BsYXk6ICdmbGV4JyxcbiAgICAgICAgICBmbGV4RGlyZWN0aW9uOiAncm93JyxcbiAgICAgICAgICBmbGV4V3JhcDogJ25vd3JhcCcsXG4gICAgICAgICAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG4gICAgICAgICAgbWFyZ2luTGVmdDogbWFyZ2luTGVmdCA/IGAke21hcmdpbkxlZnR9cHhgIDogdW5kZWZpbmVkLFxuICAgICAgICB9KX1cbiAgICAgICAgeD17dHJ1ZX1cbiAgICAgID5cbiAgICAgICAge2xlZ2VuZEl0ZW1zLm1hcChcbiAgICAgICAgICBsZWdlbmRJdGVtID0+XG4gICAgICAgICAgICBrZXlzW2xlZ2VuZEl0ZW0ueUtleV0gJiYgKFxuICAgICAgICAgICAgICA8TGVnZW5kSXRlbVxuICAgICAgICAgICAgICAgIHsuLi5sZWdlbmRJdGVtfVxuICAgICAgICAgICAgICAgIGtleT17YGxlZ2VuZC0ke2xlZ2VuZEl0ZW0ueUtleX1gfVxuICAgICAgICAgICAgICAgIHlLZXlGb3JtYXR0ZWQ9e2tleXNbbGVnZW5kSXRlbS55S2V5XS5rZXlGb3JtYXR0ZWR9XG4gICAgICAgICAgICAgICAgb25DbGljaz17KCkgPT5cbiAgICAgICAgICAgICAgICAgIHNldFZpc2libGVZS2V5cyhwcmV2ID0+IHtcbiAgICAgICAgICAgICAgICAgICAgbGV0IG5ld1Zpc2libGVMZWdlbmRJdGVtczogQXJyYXk8c3RyaW5nPiA9IFtdO1xuXG4gICAgICAgICAgICAgICAgICAgIGlmIChwcmV2Lmxlbmd0aCA9PT0gbGVnZW5kSXRlbXMubGVuZ3RoKSB7XG4gICAgICAgICAgICAgICAgICAgICAgbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zID0gW2xlZ2VuZEl0ZW0ueUtleV07XG4gICAgICAgICAgICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICAgICAgICAgICAgaWYgKHByZXYuaW5jbHVkZXMobGVnZW5kSXRlbS55S2V5KSkge1xuICAgICAgICAgICAgICAgICAgICAgICAgbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zID0gcHJldi5maWx0ZXIocHJldkxlZ2VuZEl0ZW1JZCA9PiBwcmV2TGVnZW5kSXRlbUlkICE9PSBsZWdlbmRJdGVtLnlLZXkpO1xuICAgICAgICAgICAgICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICAgICAgICAgICAgICBuZXdWaXNpYmxlTGVnZW5kSXRlbXMgPSBbLi4ucHJldiwgbGVnZW5kSXRlbS55S2V5XTtcbiAgICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgICAgICAgICByZXR1cm4gbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zLmxlbmd0aCA9PT0gMFxuICAgICAgICAgICAgICAgICAgICAgID8gbGVnZW5kSXRlbXMubWFwKGxlZ2VuZEl0ZW0gPT4gbGVnZW5kSXRlbS55S2V5KVxuICAgICAgICAgICAgICAgICAgICAgIDogbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zO1xuICAgICAgICAgICAgICAgICAgfSlcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgdmlzaWJsZT17dmlzaWJsZVlLZXlzLmluY2x1ZGVzKGxlZ2VuZEl0ZW0ueUtleSl9XG4gICAgICAgICAgICAgICAgY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXM9e2NvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzfVxuICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgKVxuICAgICAgICApfVxuICAgICAgPC9TY3JvbGxiYXI+XG4gICAgPC9kaXY+XG4gICk7XG59O1xuIl19 */"),
|
|
41529
41810
|
x: true,
|
|
41530
41811
|
children: legendItems.map(function (legendItem) {
|
|
41531
41812
|
return keys[legendItem.yKey] && react.createElement(LegendItem, _extends({}, legendItem, {
|
|
@@ -41755,12 +42036,12 @@ var AxisBottom = function AxisBottom(_ref) {
|
|
|
41755
42036
|
var tick = null;
|
|
41756
42037
|
if (xScaleDataType === 'date_time' && value instanceof Date) {
|
|
41757
42038
|
var matchingTickValue = x.ticks.find(function (tickValue) {
|
|
41758
|
-
return tickValue.scaleValue && new Date(tickValue.scaleValue).valueOf() === value.valueOf();
|
|
42039
|
+
return tickValue.scaleValue && new Date(tickValue == null ? void 0 : tickValue.scaleValue).valueOf() === value.valueOf();
|
|
41759
42040
|
});
|
|
41760
42041
|
tick = matchingTickValue || null;
|
|
41761
42042
|
} else {
|
|
41762
42043
|
var _matchingTickValue = x.ticks.find(function (tickValue) {
|
|
41763
|
-
return tickValue.scaleValue === value;
|
|
42044
|
+
return (tickValue == null ? void 0 : tickValue.scaleValue) === value;
|
|
41764
42045
|
});
|
|
41765
42046
|
tick = _matchingTickValue || null;
|
|
41766
42047
|
}
|
|
@@ -41890,6 +42171,68 @@ var ChartWrapper$1 = function ChartWrapper(props) {
|
|
|
41890
42171
|
});
|
|
41891
42172
|
};
|
|
41892
42173
|
|
|
42174
|
+
var CrosshairCircle = function CrosshairCircle(_ref) {
|
|
42175
|
+
var dataType = _ref.dataType,
|
|
42176
|
+
yKeys = _ref.yKeys,
|
|
42177
|
+
tooltipData = _ref.tooltipData,
|
|
42178
|
+
xKey = _ref.xKey,
|
|
42179
|
+
margin = _ref.margin,
|
|
42180
|
+
conditionalFormattingRules = _ref.conditionalFormattingRules,
|
|
42181
|
+
legendItems = _ref.legendItems,
|
|
42182
|
+
visibleYKeys = _ref.visibleYKeys,
|
|
42183
|
+
yScale = _ref.yScale,
|
|
42184
|
+
xScale = _ref.xScale;
|
|
42185
|
+
return jsxRuntime.jsx(React.Fragment, {
|
|
42186
|
+
children: yKeys.map(function (yKey) {
|
|
42187
|
+
if (!xKey || !tooltipData[yKey] || tooltipData[yKey].value === null) return null;
|
|
42188
|
+
if (tooltipData[xKey] && tooltipData[xKey].value && dataType && visibleYKeys.includes(yKey)) {
|
|
42189
|
+
var xValue = tooltipData[xKey].value;
|
|
42190
|
+
var xValueAdjusted = dataType === 'date_time' ? new Date(xValue) : dataType === 'number' ? Number(xValue) : String(xValue);
|
|
42191
|
+
return jsxRuntime.jsx("circle", {
|
|
42192
|
+
cx:
|
|
42193
|
+
// @ts-ignore
|
|
42194
|
+
xScale(xValueAdjusted) + margin.left,
|
|
42195
|
+
cy: yScale(yKey) + margin.top,
|
|
42196
|
+
r: 4,
|
|
42197
|
+
fill: getColor({
|
|
42198
|
+
defaultColor: legendItems.filter(function (legendItem) {
|
|
42199
|
+
return legendItem.yKey === yKey;
|
|
42200
|
+
})[0].color,
|
|
42201
|
+
yKey: yKey,
|
|
42202
|
+
value: tooltipData[yKey].value,
|
|
42203
|
+
conditionalFormattingRules: conditionalFormattingRules
|
|
42204
|
+
}),
|
|
42205
|
+
strokeWidth: 2,
|
|
42206
|
+
stroke: "#fff",
|
|
42207
|
+
pointerEvents: "none"
|
|
42208
|
+
}, yKey);
|
|
42209
|
+
} else {
|
|
42210
|
+
return null;
|
|
42211
|
+
}
|
|
42212
|
+
})
|
|
42213
|
+
});
|
|
42214
|
+
};
|
|
42215
|
+
|
|
42216
|
+
var Line = function Line(_ref) {
|
|
42217
|
+
var margin = _ref.margin,
|
|
42218
|
+
x = _ref.x,
|
|
42219
|
+
height = _ref.height;
|
|
42220
|
+
return jsxRuntime.jsx(shape.Line, {
|
|
42221
|
+
from: {
|
|
42222
|
+
x: x,
|
|
42223
|
+
y: margin.top
|
|
42224
|
+
},
|
|
42225
|
+
to: {
|
|
42226
|
+
x: x,
|
|
42227
|
+
y: height + margin.top
|
|
42228
|
+
},
|
|
42229
|
+
stroke: '#aaa',
|
|
42230
|
+
strokeWidth: 2,
|
|
42231
|
+
pointerEvents: "none",
|
|
42232
|
+
opacity: 0.8
|
|
42233
|
+
});
|
|
42234
|
+
};
|
|
42235
|
+
|
|
41893
42236
|
var LineChart$5 = function LineChart(_ref) {
|
|
41894
42237
|
var _theme$axis;
|
|
41895
42238
|
var chart = _ref.chart,
|
|
@@ -41953,7 +42296,7 @@ var LineChart$5 = function LineChart(_ref) {
|
|
|
41953
42296
|
}
|
|
41954
42297
|
return null;
|
|
41955
42298
|
}, [innerWidth, chart.x, chart.data]);
|
|
41956
|
-
var
|
|
42299
|
+
var _yScale = React.useMemo(function () {
|
|
41957
42300
|
return scale.scaleLinear({
|
|
41958
42301
|
range: [innerHeight, 0],
|
|
41959
42302
|
domain: chart.y.scale.ordering === 'asc' ? [chart.y.scale.min, chart.y.scale.max] : [chart.y.scale.max, chart.y.scale.min],
|
|
@@ -41998,7 +42341,7 @@ var LineChart$5 = function LineChart(_ref) {
|
|
|
41998
42341
|
top: margin.top,
|
|
41999
42342
|
children: [jsxRuntime.jsx(GridRows, {
|
|
42000
42343
|
ticks: yTickValues,
|
|
42001
|
-
yScale:
|
|
42344
|
+
yScale: _yScale,
|
|
42002
42345
|
width: innerWidth,
|
|
42003
42346
|
height: innerHeight,
|
|
42004
42347
|
removeStroke: options.removeStroke,
|
|
@@ -42017,7 +42360,7 @@ var LineChart$5 = function LineChart(_ref) {
|
|
|
42017
42360
|
y: chart.y,
|
|
42018
42361
|
margin: margin,
|
|
42019
42362
|
themeCSS: themeCSS,
|
|
42020
|
-
yScale:
|
|
42363
|
+
yScale: _yScale,
|
|
42021
42364
|
ticks: yTickValues,
|
|
42022
42365
|
stroke: theme == null || (_theme$axis = theme.axis) == null ? void 0 : _theme$axis.stroke
|
|
42023
42366
|
}), jsxRuntime.jsxs(group.Group, {
|
|
@@ -42035,7 +42378,7 @@ var LineChart$5 = function LineChart(_ref) {
|
|
|
42035
42378
|
return (_xScale = xScale(xValueAdjusted)) != null ? _xScale : 0;
|
|
42036
42379
|
},
|
|
42037
42380
|
y: function y(d) {
|
|
42038
|
-
return
|
|
42381
|
+
return _yScale(Number(d[yKey]));
|
|
42039
42382
|
},
|
|
42040
42383
|
stroke: chart.lines.filter(function (legendItem) {
|
|
42041
42384
|
return legendItem.yKey === yKey;
|
|
@@ -42064,7 +42407,7 @@ var LineChart$5 = function LineChart(_ref) {
|
|
|
42064
42407
|
chart: {
|
|
42065
42408
|
width: innerWidth,
|
|
42066
42409
|
height: innerHeight,
|
|
42067
|
-
yScale:
|
|
42410
|
+
yScale: _yScale
|
|
42068
42411
|
}
|
|
42069
42412
|
});
|
|
42070
42413
|
|
|
@@ -42083,7 +42426,7 @@ var LineChart$5 = function LineChart(_ref) {
|
|
|
42083
42426
|
return (_xScale2 = xScale(xValueAdjusted)) != null ? _xScale2 : 0;
|
|
42084
42427
|
},
|
|
42085
42428
|
y: function y(d) {
|
|
42086
|
-
return
|
|
42429
|
+
return _yScale(Number(d[yKey]));
|
|
42087
42430
|
},
|
|
42088
42431
|
stroke: conditionalFormattingRule.color,
|
|
42089
42432
|
strokeWidth: chart.lines.filter(function (legendItem) {
|
|
@@ -42109,50 +42452,30 @@ var LineChart$5 = function LineChart(_ref) {
|
|
|
42109
42452
|
})]
|
|
42110
42453
|
})]
|
|
42111
42454
|
}), tooltipData && jsxRuntime.jsxs("g", {
|
|
42112
|
-
children: [jsxRuntime.jsx(
|
|
42113
|
-
|
|
42114
|
-
|
|
42115
|
-
|
|
42116
|
-
|
|
42117
|
-
|
|
42118
|
-
|
|
42119
|
-
|
|
42120
|
-
|
|
42121
|
-
|
|
42122
|
-
|
|
42123
|
-
pointerEvents: "none",
|
|
42124
|
-
opacity: 0.8
|
|
42125
|
-
}), chart.y.keys.map(function (yKey) {
|
|
42126
|
-
if (!xScaleKey || !tooltipData[yKey] || tooltipData[yKey].value === null) return null;
|
|
42127
|
-
if (tooltipData[xScaleKey] && tooltipData[xScaleKey].value && xScaleDataType && visibleYKeys.includes(yKey)) {
|
|
42128
|
-
var xValue = tooltipData[xScaleKey].value;
|
|
42129
|
-
var xValueAdjusted = xScaleDataType === 'date_time' ? new Date(xValue) : xScaleDataType === 'number' ? Number(xValue) : String(xValue);
|
|
42130
|
-
return jsxRuntime.jsx("circle", {
|
|
42131
|
-
cx:
|
|
42132
|
-
// @ts-ignore
|
|
42133
|
-
xScale(xValueAdjusted) + margin.left,
|
|
42134
|
-
cy: yScale(tooltipData[yKey].value !== null ? tooltipData[yKey].value : 0) + margin.top,
|
|
42135
|
-
r: 4,
|
|
42136
|
-
fill: getColor({
|
|
42137
|
-
defaultColor: chart.lines.filter(function (legendItem) {
|
|
42138
|
-
return legendItem.yKey === yKey;
|
|
42139
|
-
})[0].color,
|
|
42140
|
-
yKey: yKey,
|
|
42141
|
-
value: tooltipData[yKey].value,
|
|
42142
|
-
conditionalFormattingRules: chart.conditionalFormattingRules
|
|
42143
|
-
}),
|
|
42144
|
-
strokeWidth: 2,
|
|
42145
|
-
stroke: "#fff",
|
|
42146
|
-
pointerEvents: "none"
|
|
42147
|
-
}, yKey);
|
|
42148
|
-
} else {
|
|
42149
|
-
return null;
|
|
42455
|
+
children: [jsxRuntime.jsx(Line, {
|
|
42456
|
+
x: tooltipLeft,
|
|
42457
|
+
margin: margin,
|
|
42458
|
+
height: innerHeight
|
|
42459
|
+
}), jsxRuntime.jsx(CrosshairCircle, {
|
|
42460
|
+
yKeys: chart.y.keys,
|
|
42461
|
+
xKey: xScaleKey,
|
|
42462
|
+
dataType: xScaleDataType,
|
|
42463
|
+
legendItems: chart.lines,
|
|
42464
|
+
yScale: function yScale(yKey) {
|
|
42465
|
+
return _yScale(tooltipData[yKey].value !== null ? tooltipData[yKey].value : 0);
|
|
42150
42466
|
}
|
|
42467
|
+
// @ts-ignore
|
|
42468
|
+
,
|
|
42469
|
+
xScale: xScale,
|
|
42470
|
+
margin: margin,
|
|
42471
|
+
tooltipData: tooltipData,
|
|
42472
|
+
conditionalFormattingRules: chart.conditionalFormattingRules,
|
|
42473
|
+
visibleYKeys: visibleYKeys
|
|
42151
42474
|
})]
|
|
42152
42475
|
}), jsxRuntime.jsx(GoalLines$1, {
|
|
42153
42476
|
goalLines: chart.goalLines,
|
|
42154
42477
|
y: function y(d) {
|
|
42155
|
-
return
|
|
42478
|
+
return _yScale(d);
|
|
42156
42479
|
},
|
|
42157
42480
|
margin: margin,
|
|
42158
42481
|
width: innerWidth
|
|
@@ -42447,19 +42770,10 @@ var BarChart$5 = function BarChart(_ref) {
|
|
|
42447
42770
|
})]
|
|
42448
42771
|
})]
|
|
42449
42772
|
}), tooltipData && jsxRuntime.jsx("g", {
|
|
42450
|
-
children: jsxRuntime.jsx(
|
|
42451
|
-
|
|
42452
|
-
|
|
42453
|
-
|
|
42454
|
-
},
|
|
42455
|
-
to: {
|
|
42456
|
-
x: tooltipLeft,
|
|
42457
|
-
y: innerHeight + margin.top
|
|
42458
|
-
},
|
|
42459
|
-
stroke: '#aaa',
|
|
42460
|
-
strokeWidth: 2,
|
|
42461
|
-
pointerEvents: "none",
|
|
42462
|
-
opacity: 0.8
|
|
42773
|
+
children: jsxRuntime.jsx(Line, {
|
|
42774
|
+
x: tooltipLeft,
|
|
42775
|
+
margin: margin,
|
|
42776
|
+
height: innerHeight
|
|
42463
42777
|
})
|
|
42464
42778
|
}), jsxRuntime.jsx(GoalLines$1, {
|
|
42465
42779
|
goalLines: chart.goalLines,
|
|
@@ -42516,7 +42830,7 @@ var Bar = function Bar(props) {
|
|
|
42516
42830
|
className: props.enableHover ? /*#__PURE__*/css$1.css( {
|
|
42517
42831
|
name: "4nk3o1-Bar",
|
|
42518
42832
|
styles: "cursor:pointer;label:Bar;",
|
|
42519
|
-
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"]} */",
|
|
42833
|
+
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"]} */",
|
|
42520
42834
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$8
|
|
42521
42835
|
}) : ''
|
|
42522
42836
|
}, props.key);
|
|
@@ -48466,7 +48780,7 @@ var Component = function Component(props) {
|
|
|
48466
48780
|
});
|
|
48467
48781
|
},
|
|
48468
48782
|
onError: dashboardBehaviour.onError,
|
|
48469
|
-
children: jsxRuntime.jsx(BubbleChart$
|
|
48783
|
+
children: jsxRuntime.jsx(BubbleChart$3, {
|
|
48470
48784
|
id: props.id,
|
|
48471
48785
|
setLocalFilters: props.setLocalFilters,
|
|
48472
48786
|
dataSet: dataSet,
|
|
@@ -56929,6 +57243,22 @@ var ChartSettingsSection = function ChartSettingsSection(_ref) {
|
|
|
56929
57243
|
}
|
|
56930
57244
|
return options;
|
|
56931
57245
|
}();
|
|
57246
|
+
var layoutOptions = function () {
|
|
57247
|
+
var options = [{
|
|
57248
|
+
label: textOverride('grouped', 'Grouped'),
|
|
57249
|
+
value: false
|
|
57250
|
+
}, {
|
|
57251
|
+
label: textOverride('stacked', 'Stacked'),
|
|
57252
|
+
value: true
|
|
57253
|
+
}];
|
|
57254
|
+
if (attributes.type === 'barChart' || attributes.type === 'areaChart') {
|
|
57255
|
+
options.push({
|
|
57256
|
+
label: textOverride('stacked_100prc', 'Stacked (100%)'),
|
|
57257
|
+
value: '100%'
|
|
57258
|
+
});
|
|
57259
|
+
}
|
|
57260
|
+
return options;
|
|
57261
|
+
}();
|
|
56932
57262
|
return jsxRuntime.jsx(Section, {
|
|
56933
57263
|
title: section.title,
|
|
56934
57264
|
tooltip: section == null ? void 0 : section.description,
|
|
@@ -56948,16 +57278,7 @@ var ChartSettingsSection = function ChartSettingsSection(_ref) {
|
|
|
56948
57278
|
stacked: stacked
|
|
56949
57279
|
});
|
|
56950
57280
|
},
|
|
56951
|
-
options:
|
|
56952
|
-
label: textOverride('grouped', 'Grouped'),
|
|
56953
|
-
value: false
|
|
56954
|
-
}, {
|
|
56955
|
-
label: textOverride('stacked', 'Stacked'),
|
|
56956
|
-
value: true
|
|
56957
|
-
}, {
|
|
56958
|
-
label: textOverride('stacked_100prc', 'Stacked (100%)'),
|
|
56959
|
-
value: '100%'
|
|
56960
|
-
}]
|
|
57281
|
+
options: layoutOptions
|
|
56961
57282
|
}), section.type === 'curve' && jsxRuntime.jsx(FormatSelectInput, {
|
|
56962
57283
|
label: section.title,
|
|
56963
57284
|
id: "format-layout-curve",
|