@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
package/dist/dashboard.esm.js
CHANGED
|
@@ -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
|
|
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$
|
|
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$
|
|
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,
|
|
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,
|
|
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,
|
|
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,
|
|
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
|
|
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:
|
|
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:
|
|
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
|
|
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:
|
|
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
|
|
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
|
-
|
|
42163
|
-
|
|
42164
|
-
|
|
42165
|
-
|
|
42166
|
-
|
|
42167
|
-
|
|
42168
|
-
|
|
42169
|
-
|
|
42170
|
-
|
|
42171
|
-
|
|
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
|
|
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
|
-
|
|
42501
|
-
|
|
42502
|
-
|
|
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$
|
|
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",
|