@vizzly/dashboard 0.14.4-dev-97acb8d43347ac757049612930b3f8e69e913e55 → 0.14.4-dev-3455fe16fbb312a7c23a46cc2f4bcf62b52bb944
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/Axis/AxisLeft.d.ts +2 -1
- package/dist/charts/src/v2/components/BarChart/BarChart.d.ts +18 -2
- package/dist/charts/src/v2/components/BarChart/useBarXScale.d.ts +2 -0
- package/dist/charts/src/v2/components/ComboChart/ComboChart.d.ts +22 -0
- package/dist/charts/src/v2/components/Legend/Legend.d.ts +7 -5
- package/dist/charts/src/v2/components/LineChart/LineChart.d.ts +16 -1
- package/dist/charts/src/v2/components/Tooltip/Tooltip.d.ts +6 -4
- package/dist/charts/src/v2/components/hooks/useFlattenedData.d.ts +3 -8
- package/dist/charts/src/v2/components/hooks/useYScale.d.ts +2 -0
- package/dist/charts/src/v2/constants/PADDING.d.ts +4 -0
- package/dist/charts/src/v2/{components/BarChart → utils}/getBarFill.d.ts +2 -2
- package/dist/dashboard.cjs.development.js +356 -309
- package/dist/dashboard.cjs.production.min.js +1 -1
- package/dist/dashboard.esm.js +361 -314
- package/dist/shared-logic/src/ChartsV2/types.d.ts +8 -7
- package/dist/shared-logic/src/ComboChartV2/types.d.ts +15 -0
- package/dist/shared-logic/src/FeatureToggle/types.d.ts +0 -3
- package/package.json +1 -1
package/dist/dashboard.esm.js
CHANGED
|
@@ -28,13 +28,13 @@ import { preserveOffsetOnSource } from '@atlaskit/pragmatic-drag-and-drop/elemen
|
|
|
28
28
|
import { dropTargetForExternal } from '@atlaskit/pragmatic-drag-and-drop/external/adapter';
|
|
29
29
|
import { DropIndicator } from '@atlaskit/pragmatic-drag-and-drop-react-drop-indicator/box';
|
|
30
30
|
import { ParentSize } from '@visx/responsive';
|
|
31
|
-
import { Annotation, AnnotationConnector, AnnotationLabel, DataContext, buildChartTheme, lightTheme, XYChart, Grid as Grid$2, Axis, AreaSeries, AreaStack, BarGroup, BarSeries, BarStack, GlyphSeries, LineSeries, Tooltip as Tooltip$3 } from '@visx/xychart';
|
|
31
|
+
import { Annotation, AnnotationConnector, AnnotationLabel, DataContext, buildChartTheme, lightTheme, XYChart, Grid as Grid$2, Axis, AreaSeries, AreaStack, BarGroup as BarGroup$1, BarSeries, BarStack, GlyphSeries, LineSeries, Tooltip as Tooltip$3 } from '@visx/xychart';
|
|
32
32
|
import { LinearGradient } from '@visx/gradient';
|
|
33
33
|
import { LegendItem as LegendItem$1, LegendLabel } from '@visx/legend';
|
|
34
|
-
import { scaleOrdinal, scaleQuantize, scalePoint, scaleTime,
|
|
34
|
+
import { scaleOrdinal, scaleQuantize, scaleLinear, scalePoint, scaleTime, 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 as Line$1, LinePath,
|
|
37
|
+
import { Line as Line$1, LinePath, BarStack as BarStack$1, BarGroup as BarGroup$2, AreaStack as AreaStack$1, AreaClosed, LineRadial } 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';
|
|
@@ -1550,7 +1550,7 @@ var upcastFilterType = function upcastFilterType(type) {
|
|
|
1550
1550
|
if (type === 'dateTimeFilter') {
|
|
1551
1551
|
return DATE_FILTER;
|
|
1552
1552
|
}
|
|
1553
|
-
if (type === 'numericFilter'
|
|
1553
|
+
if (type === 'numericFilter') {
|
|
1554
1554
|
return ADVANCED_FILTER;
|
|
1555
1555
|
}
|
|
1556
1556
|
return type;
|
|
@@ -13767,8 +13767,7 @@ var ADMIN_FEATURE_TOGGLES = {
|
|
|
13767
13767
|
forceMobile: false,
|
|
13768
13768
|
unloadOffScreenViews: false,
|
|
13769
13769
|
showSavingIndicator: false,
|
|
13770
|
-
disablePersistingGlobalFiltersLocally: false
|
|
13771
|
-
simpleMultiSelectFilter: false
|
|
13770
|
+
disablePersistingGlobalFiltersLocally: false
|
|
13772
13771
|
};
|
|
13773
13772
|
var END_USER_DEFAULT_FEATURE_TOGGLES = {
|
|
13774
13773
|
parameters: true,
|
|
@@ -13805,8 +13804,7 @@ var END_USER_DEFAULT_FEATURE_TOGGLES = {
|
|
|
13805
13804
|
forceMobile: false,
|
|
13806
13805
|
unloadOffScreenViews: false,
|
|
13807
13806
|
showSavingIndicator: true,
|
|
13808
|
-
disablePersistingGlobalFiltersLocally: false
|
|
13809
|
-
simpleMultiSelectFilter: false
|
|
13807
|
+
disablePersistingGlobalFiltersLocally: false
|
|
13810
13808
|
};
|
|
13811
13809
|
var build$b = function build(partialFeatureToggles, queryEngineConfig, mode, scope) {
|
|
13812
13810
|
var featureToggles = {};
|
|
@@ -13863,7 +13861,7 @@ var build$b = function build(partialFeatureToggles, queryEngineConfig, mode, sco
|
|
|
13863
13861
|
return featureToggles;
|
|
13864
13862
|
};
|
|
13865
13863
|
var buildDefaults = function buildDefaults(partialFeatureToggles) {
|
|
13866
|
-
var _partialFeatureToggle, _partialFeatureToggle2
|
|
13864
|
+
var _partialFeatureToggle, _partialFeatureToggle2;
|
|
13867
13865
|
return {
|
|
13868
13866
|
showDateAndTimeFilter: partialFeatureToggles.showDateAndTimeFilter !== undefined ? partialFeatureToggles.showDateAndTimeFilter : true,
|
|
13869
13867
|
showDateFilter: partialFeatureToggles.showDateFilter !== undefined ? partialFeatureToggles.showDateFilter : true,
|
|
@@ -13874,8 +13872,7 @@ var buildDefaults = function buildDefaults(partialFeatureToggles) {
|
|
|
13874
13872
|
canDownloadViewAsPNG: partialFeatureToggles.canDownloadViewAsPNG !== undefined ? partialFeatureToggles.canDownloadViewAsPNG : true,
|
|
13875
13873
|
forceMobile: partialFeatureToggles.forceMobile !== undefined ? partialFeatureToggles.forceMobile : false,
|
|
13876
13874
|
unloadOffScreenViews: partialFeatureToggles.unloadOffScreenViews !== undefined ? partialFeatureToggles.unloadOffScreenViews : false,
|
|
13877
|
-
allowCalculatedField: (_partialFeatureToggle2 = partialFeatureToggles.allowCalculatedField) != null ? _partialFeatureToggle2 : false
|
|
13878
|
-
simpleMultiSelectFilter: (_partialFeatureToggle3 = partialFeatureToggles.simpleMultiSelectFilter) != null ? _partialFeatureToggle3 : false
|
|
13875
|
+
allowCalculatedField: (_partialFeatureToggle2 = partialFeatureToggles.allowCalculatedField) != null ? _partialFeatureToggle2 : false
|
|
13879
13876
|
};
|
|
13880
13877
|
};
|
|
13881
13878
|
|
|
@@ -28875,8 +28872,7 @@ var AdditionalFilter = function AdditionalFilter(props) {
|
|
|
28875
28872
|
onChange = props.onChange,
|
|
28876
28873
|
shouldAlwaysHaveValue = props.shouldAlwaysHaveValue;
|
|
28877
28874
|
var _useDashboardBehaviou = useDashboardBehaviourContext(),
|
|
28878
|
-
queryEngineConfig = _useDashboardBehaviou.queryEngineConfig
|
|
28879
|
-
featureToggles = _useDashboardBehaviou.featureToggles;
|
|
28875
|
+
queryEngineConfig = _useDashboardBehaviou.queryEngineConfig;
|
|
28880
28876
|
|
|
28881
28877
|
/** Validate the new filter before setting it */
|
|
28882
28878
|
var onChangeWithValidation = function onChangeWithValidation(newFilter) {
|
|
@@ -28927,7 +28923,7 @@ var AdditionalFilter = function AdditionalFilter(props) {
|
|
|
28927
28923
|
dataSets: props.dataSets
|
|
28928
28924
|
}, typeof props.filter.value === 'boolean' ? undefined : JSON.stringify(props.filter.value));
|
|
28929
28925
|
}
|
|
28930
|
-
if (filter.type == MULTI_SELECT_FILTER
|
|
28926
|
+
if (filter.type == MULTI_SELECT_FILTER) {
|
|
28931
28927
|
return jsx(MultiSelectFilter, {
|
|
28932
28928
|
showClearBtn: !shouldAlwaysHaveValue,
|
|
28933
28929
|
filter: filter,
|
|
@@ -33157,7 +33153,7 @@ var VizzlyXYChart = function VizzlyXYChart(props) {
|
|
|
33157
33153
|
}), (props == null ? void 0 : props.bars) && !props.bars.stacked && !(props != null && (_props$bars3 = props.bars) != null && _props$bars3.funnelChart) && jsxs(Fragment, {
|
|
33158
33154
|
children: [props.enableHover && jsx("style", {
|
|
33159
33155
|
children: "\n /* We need to find a more accurate way to target the rect element. */\n .vizzly-xy-chart > div > svg > rect {\n cursor: pointer;\n }"
|
|
33160
|
-
}), jsx(BarGroup, {
|
|
33156
|
+
}), jsx(BarGroup$1, {
|
|
33161
33157
|
children: props.bars.keys.map(function (key, keyIndex) {
|
|
33162
33158
|
var _props$bars$styles$co, _props$bars4, _props$bars5;
|
|
33163
33159
|
return jsx(BarSeries, _extends({
|
|
@@ -38117,13 +38113,11 @@ var AddFilterForm = function AddFilterForm(props) {
|
|
|
38117
38113
|
value: SINGLE_SELECT_FILTER,
|
|
38118
38114
|
subText: textOverride('single_select_filter_description', 'Choose a single option from the list to filter. ')
|
|
38119
38115
|
}];
|
|
38120
|
-
|
|
38121
|
-
|
|
38122
|
-
|
|
38123
|
-
|
|
38124
|
-
|
|
38125
|
-
});
|
|
38126
|
-
}
|
|
38116
|
+
filterTypes.push({
|
|
38117
|
+
label: textOverride('multi_select', 'Multi select'),
|
|
38118
|
+
value: MULTI_SELECT_FILTER,
|
|
38119
|
+
subText: textOverride('multi_select_description', 'Allow multiple selections.')
|
|
38120
|
+
});
|
|
38127
38121
|
filterTypes.push({
|
|
38128
38122
|
label: textOverride('advanced_filter', 'Advanced filter'),
|
|
38129
38123
|
value: ADVANCED_FILTER,
|
|
@@ -42354,16 +42348,14 @@ var SCROLLBAR_WIDTH = 40;
|
|
|
42354
42348
|
var Tooltip$1 = function Tooltip(_ref) {
|
|
42355
42349
|
var _tooltipData$xKey$for;
|
|
42356
42350
|
var keys = _ref.keys,
|
|
42357
|
-
legendItems = _ref.legendItems,
|
|
42358
42351
|
showRoundedTotal = _ref.showRoundedTotal,
|
|
42359
42352
|
tooltipData = _ref.tooltipData,
|
|
42360
42353
|
tooltipLeft = _ref.tooltipLeft,
|
|
42361
42354
|
tooltipTop = _ref.tooltipTop,
|
|
42362
|
-
visibleYKeys = _ref.visibleYKeys,
|
|
42363
42355
|
xKey = _ref.xKey,
|
|
42364
42356
|
yKeys = _ref.yKeys,
|
|
42365
|
-
|
|
42366
|
-
|
|
42357
|
+
theme = _ref.theme,
|
|
42358
|
+
items = _ref.items;
|
|
42367
42359
|
var tooltipRef = useRef(null);
|
|
42368
42360
|
var _useState = useState({
|
|
42369
42361
|
left: tooltipLeft
|
|
@@ -42412,7 +42404,7 @@ var Tooltip$1 = function Tooltip(_ref) {
|
|
|
42412
42404
|
fontSize: '15px',
|
|
42413
42405
|
width: '100%',
|
|
42414
42406
|
minWidth: MIN_TOOLTIP_WIDTH
|
|
42415
|
-
}, process.env.NODE_ENV === "production" ? "" : ";label:Tooltip;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
42407
|
+
}, process.env.NODE_ENV === "production" ? "" : ";label:Tooltip;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlRvb2x0aXAudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTBGcUIiLCJmaWxlIjoiVG9vbHRpcC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgQ1NTUHJvcGVydGllcywgRnJhZ21lbnQsIHVzZUVmZmVjdCwgdXNlUmVmLCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IGNyZWF0ZVBvcnRhbCB9IGZyb20gJ3JlYWN0LWRvbSc7XG5cbmltcG9ydCB7IGdldENvbG9yIH0gZnJvbSAnLi4vLi4vdXRpbHMnO1xuaW1wb3J0IHsgTGVnZW5kSXRlbUJveCB9IGZyb20gJy4uL0xlZ2VuZC9MZWdlbmRJdGVtQm94JztcbmltcG9ydCB7IFNoYXBlRGVmaW5pdGlvbiwgQ29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZSwgRGF0YUl0ZW0sIEtleSB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQ2hhcnRzVjIvdHlwZXMnO1xuaW1wb3J0IHsgTGluZVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvTGluZUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQmFyU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9CYXJDaGFydFYyL3R5cGVzJztcbmltcG9ydCB7IEFyZWFTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0FyZWFDaGFydFYyL3R5cGVzJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5cbmNvbnN0IE1JTl9UT09MVElQX1dJRFRIID0gMTgwO1xuY29uc3QgVE9PTFRJUF9PRkZTRVQgPSAyMDtcbmNvbnN0IFNDUk9MTEJBUl9XSURUSCA9IDQwO1xuXG5pbnRlcmZhY2UgVG9vbHRpcFByb3BzPFQ+IHtcbiAga2V5czogeyBba2V5OiBzdHJpbmddOiBLZXkgfTtcbiAgc2hvd1JvdW5kZWRUb3RhbDogYm9vbGVhbjtcbiAgdG9vbHRpcERhdGE6IHtcbiAgICBba2V5SWQ6IHN0cmluZ106IERhdGFJdGVtO1xuICB9O1xuICB0b29sdGlwTGVmdDogbnVtYmVyO1xuICB0b29sdGlwVG9wOiBudW1iZXI7XG4gIHhLZXk6IHN0cmluZztcbiAgeUtleXM6IHN0cmluZ1tdO1xuICBpdGVtczoge1xuICAgIGxlZ2VuZEl0ZW1zOiBBcnJheTxTaGFwZURlZmluaXRpb248VD4+O1xuICAgIGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzOiBBcnJheTxDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlPjtcbiAgICB2aXNpYmxlWUtleXM6IHN0cmluZ1tdO1xuICB9W107XG4gIHRoZW1lOiBDU1NQcm9wZXJ0aWVzO1xufVxuXG5leHBvcnQgY29uc3QgVG9vbHRpcCA9ICh7XG4gIGtleXMsXG4gIHNob3dSb3VuZGVkVG90YWwsXG4gIHRvb2x0aXBEYXRhLFxuICB0b29sdGlwTGVmdCxcbiAgdG9vbHRpcFRvcCxcbiAgeEtleSxcbiAgeUtleXMsXG4gIHRoZW1lLFxuICBpdGVtcyxcbn06IFRvb2x0aXBQcm9wczxMaW5lU3R5bGVzIHwgQmFyU3R5bGVzIHwgQXJlYVN0eWxlcz4pID0+IHtcbiAgY29uc3QgdG9vbHRpcFJlZiA9IHVzZVJlZjxIVE1MRGl2RWxlbWVudD4obnVsbCk7XG4gIGNvbnN0IFtwb3NpdGlvbiwgc2V0UG9zaXRpb25dID0gdXNlU3RhdGU8eyBsZWZ0OiBudW1iZXIgfT4oe1xuICAgIGxlZnQ6IHRvb2x0aXBMZWZ0LFxuICB9KTtcblxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGNvbnN0IGFkanVzdFRvb2x0aXBQb3NpdGlvbiA9ICgpID0+IHtcbiAgICAgIGNvbnN0IHRvb2x0aXBFbGVtZW50ID0gdG9vbHRpcFJlZi5jdXJyZW50O1xuXG4gICAgICBpZiAodG9vbHRpcEVsZW1lbnQpIHtcbiAgICAgICAgY29uc3Qgc2NyZWVuV2lkdGggPSB3aW5kb3cuaW5uZXJXaWR0aDtcblxuICAgICAgICBjb25zdCByZWN0ID0gdG9vbHRpcEVsZW1lbnQuZ2V0Qm91bmRpbmdDbGllbnRSZWN0KCk7XG5cbiAgICAgICAgbGV0IHdpZHRoID0gcmVjdC53aWR0aDtcblxuICAgICAgICBpZiAod2lkdGggPCBNSU5fVE9PTFRJUF9XSURUSCkge1xuICAgICAgICAgIHdpZHRoID0gTUlOX1RPT0xUSVBfV0lEVEg7XG4gICAgICAgIH1cblxuICAgICAgICBsZXQgbGVmdCA9IHRvb2x0aXBMZWZ0ICsgVE9PTFRJUF9PRkZTRVQ7XG5cbiAgICAgICAgaWYgKHRvb2x0aXBMZWZ0ICsgd2lkdGggPiBzY3JlZW5XaWR0aCAtIFNDUk9MTEJBUl9XSURUSCkge1xuICAgICAgICAgIGxlZnQgPSB0b29sdGlwTGVmdCAtIHdpZHRoIC0gVE9PTFRJUF9PRkZTRVQ7XG4gICAgICAgIH1cblxuICAgICAgICBzZXRQb3NpdGlvbih7IGxlZnQgfSk7XG4gICAgICB9XG4gICAgfTtcblxuICAgIGFkanVzdFRvb2x0aXBQb3NpdGlvbigpO1xuICB9LCBbdG9vbHRpcExlZnRdKTtcblxuICByZXR1cm4gY3JlYXRlUG9ydGFsKFxuICAgIDxkaXZcbiAgICAgIHJlZj17dG9vbHRpcFJlZn1cbiAgICAgIHN0eWxlPXt7XG4gICAgICAgIHBvc2l0aW9uOiAnYWJzb2x1dGUnLFxuICAgICAgICBsZWZ0OiBwb3NpdGlvbi5sZWZ0LFxuICAgICAgICB0b3A6IHRvb2x0aXBUb3AsXG4gICAgICAgIHpJbmRleDogMjE0NzQ4MzY0NyAqIDEwLFxuICAgICAgICAuLi50aGVtZSxcbiAgICAgIH19XG4gICAgPlxuICAgICAgPGRpdiBzdHlsZT17eyB3b3JkQnJlYWs6ICdicmVhay1hbGwnIH19PlxuICAgICAgICA8ZGl2XG4gICAgICAgICAgY2xhc3NOYW1lPXtjc3Moe1xuICAgICAgICAgICAgZm9udEZhbWlseTogJ2luaGVyaXQnLFxuICAgICAgICAgICAgbGluZUhlaWdodDogJ2luaGVyaXQnLFxuICAgICAgICAgICAgbGV0dGVyU3BhY2luZzogJ2luaGVyaXQnLFxuICAgICAgICAgICAgZm9udFdlaWdodDogJ2JvbGQnLFxuICAgICAgICAgICAgZm9udFNpemU6ICcxNXB4JyxcbiAgICAgICAgICAgIHdpZHRoOiAnMTAwJScsXG4gICAgICAgICAgICBtaW5XaWR0aDogTUlOX1RPT0xUSVBfV0lEVEgsXG4gICAgICAgICAgfSl9XG4gICAgICAgID5cbiAgICAgICAgICB7dG9vbHRpcERhdGFbeEtleV0uZm9ybWF0dGVkVmFsdWUgPz8gdG9vbHRpcERhdGFbeEtleV0udmFsdWV9XG4gICAgICAgIDwvZGl2PlxuICAgICAgICA8dGFibGVcbiAgICAgICAgICBjZWxsUGFkZGluZz17MH1cbiAgICAgICAgICBjZWxsU3BhY2luZz17MH1cbiAgICAgICAgICBjbGFzc05hbWU9e2Nzcyh7XG4gICAgICAgICAgICBtYXJnaW46ICcwJyxcbiAgICAgICAgICAgIGJvcmRlclNwYWNpbmc6ICcwJyxcbiAgICAgICAgICAgIGJvcmRlckNvbGxhcHNlOiAnaW5oZXJpdCcsXG4gICAgICAgICAgICBib3JkZXI6ICdub25lJyxcbiAgICAgICAgICB9KX1cbiAgICAgICAgPlxuICAgICAgICAgIDx0Ym9keT5cbiAgICAgICAgICAgIHtpdGVtcy5tYXAoKGl0ZW0sIGluZGV4KSA9PiB7XG4gICAgICAgICAgICAgIHJldHVybiAoXG4gICAgICAgICAgICAgICAgPEZyYWdtZW50IGtleT17aW5kZXh9PlxuICAgICAgICAgICAgICAgICAge2l0ZW0ubGVnZW5kSXRlbXM/Lm1hcCgobGVnZW5kSXRlbSwgaW5kZXgpID0+IHtcbiAgICAgICAgICAgICAgICAgICAgaWYgKCF0b29sdGlwRGF0YVtsZWdlbmRJdGVtLnlLZXldIHx8IHRvb2x0aXBEYXRhW2xlZ2VuZEl0ZW0ueUtleV0udmFsdWUgPT09IG51bGwpIHtcbiAgICAgICAgICAgICAgICAgICAgICAvLyB5S2V5IGNvdWxkIG5vdCBiZSBmb3VuZCBpbiB0b29sdGlwRGF0YVxuICAgICAgICAgICAgICAgICAgICAgIHJldHVybiBudWxsO1xuICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICAgIHJldHVybiAoXG4gICAgICAgICAgICAgICAgICAgICAgaXRlbS52aXNpYmxlWUtleXM/LmluY2x1ZGVzKGxlZ2VuZEl0ZW0ueUtleSkgJiYgKFxuICAgICAgICAgICAgICAgICAgICAgICAgPHRyIGtleT17bGVnZW5kSXRlbS55S2V5fT5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgPHRkXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgc3R5bGU9e3tcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHZlcnRpY2FsQWxpZ246ICdtaWRkbGUnLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgcGFkZGluZzogaW5kZXggPT09IDAgPyAnMTJweCA4cHggMCAwJyA6ICc4cHggOHB4IDAgMCcsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICB3aWR0aDogJ2F1dG8nLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIH19XG4gICAgICAgICAgICAgICAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICA8TGVnZW5kSXRlbUJveFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgY29sb3I9e2dldENvbG9yKHtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgZGVmYXVsdENvbG9yOiBsZWdlbmRJdGVtLmNvbG9yLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB2YWx1ZTogdG9vbHRpcERhdGFbbGVnZW5kSXRlbS55S2V5XS52YWx1ZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgeUtleTogbGVnZW5kSXRlbS55S2V5LFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlczogaXRlbS5jb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlcyA/PyBbXSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIH0pfVxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgc3R5bGU9e2xlZ2VuZEl0ZW0uc3R5bGUgYXMgTGluZVN0eWxlc31cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHlLZXk9e2xlZ2VuZEl0ZW0ueUtleX1cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgICAgICAgICAgICAgICA8L3RkPlxuICAgICAgICAgICAgICAgICAgICAgICAgICA8dGQgc3R5bGU9e3sgcGFkZGluZzogJzhweCAwIDAgMCcgfX0+e2tleXNbbGVnZW5kSXRlbS55S2V5XS5rZXlGb3JtYXR0ZWR9PC90ZD5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgPHRkIHN0eWxlPXt7IGZvbnRXZWlnaHQ6ICdib2xkJywgcGFkZGluZzogJzhweCAwIDAgMTZweCcgfX0+XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAge3Rvb2x0aXBEYXRhW2xlZ2VuZEl0ZW0ueUtleV0uZm9ybWF0dGVkVmFsdWVcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgID8gdG9vbHRpcERhdGFbbGVnZW5kSXRlbS55S2V5XS5mb3JtYXR0ZWRWYWx1ZVxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgOiB0b29sdGlwRGF0YVtsZWdlbmRJdGVtLnlLZXldLnZhbHVlfVxuICAgICAgICAgICAgICAgICAgICAgICAgICA8L3RkPlxuICAgICAgICAgICAgICAgICAgICAgICAgPC90cj5cbiAgICAgICAgICAgICAgICAgICAgICApXG4gICAgICAgICAgICAgICAgICAgICk7XG4gICAgICAgICAgICAgICAgICB9KX1cbiAgICAgICAgICAgICAgICA8L0ZyYWdtZW50PlxuICAgICAgICAgICAgICApO1xuICAgICAgICAgICAgfSl9XG5cbiAgICAgICAgICAgIHtzaG93Um91bmRlZFRvdGFsICYmIChcbiAgICAgICAgICAgICAgPHRyPlxuICAgICAgICAgICAgICAgIDx0ZCBjb2xTcGFuPXsyfSBzdHlsZT17eyBwYWRkaW5nOiAnMTJweCAwIDAgMCcgfX0+XG4gICAgICAgICAgICAgICAgICBSb3VuZGVkIFRvdGFsXG4gICAgICAgICAgICAgICAgPC90ZD5cbiAgICAgICAgICAgICAgICA8dGQgc3R5bGU9e3sgZm9udFdlaWdodDogJ2JvbGQnLCBwYWRkaW5nOiAnMTJweCAwIDAgMTZweCcgfX0+XG4gICAgICAgICAgICAgICAgICB7eUtleXMucmVkdWNlKCh0b3RhbCwga2V5KSA9PiB7XG4gICAgICAgICAgICAgICAgICAgIHJldHVybiB0b3RhbCArIE1hdGgucm91bmQodG9vbHRpcERhdGFba2V5XS52YWx1ZSBhcyBudW1iZXIpO1xuICAgICAgICAgICAgICAgICAgfSwgMCl9XG4gICAgICAgICAgICAgICAgPC90ZD5cbiAgICAgICAgICAgICAgPC90cj5cbiAgICAgICAgICAgICl9XG4gICAgICAgICAgPC90Ym9keT5cbiAgICAgICAgPC90YWJsZT5cbiAgICAgIDwvZGl2PlxuICAgIDwvZGl2PixcbiAgICBkb2N1bWVudC5ib2R5XG4gICk7XG59O1xuIl19 */"),
|
|
42416
42408
|
children: (_tooltipData$xKey$for = tooltipData[xKey].formattedValue) != null ? _tooltipData$xKey$for : tooltipData[xKey].value
|
|
42417
42409
|
}), jsx("table", {
|
|
42418
42410
|
cellPadding: 0,
|
|
@@ -42423,45 +42415,51 @@ var Tooltip$1 = function Tooltip(_ref) {
|
|
|
42423
42415
|
} : {
|
|
42424
42416
|
name: "9a1sa-Tooltip",
|
|
42425
42417
|
styles: "margin:0;border-spacing:0;border-collapse:inherit;border:none;label:Tooltip;",
|
|
42426
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
42418
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlRvb2x0aXAudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXlHcUIiLCJmaWxlIjoiVG9vbHRpcC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgQ1NTUHJvcGVydGllcywgRnJhZ21lbnQsIHVzZUVmZmVjdCwgdXNlUmVmLCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IGNyZWF0ZVBvcnRhbCB9IGZyb20gJ3JlYWN0LWRvbSc7XG5cbmltcG9ydCB7IGdldENvbG9yIH0gZnJvbSAnLi4vLi4vdXRpbHMnO1xuaW1wb3J0IHsgTGVnZW5kSXRlbUJveCB9IGZyb20gJy4uL0xlZ2VuZC9MZWdlbmRJdGVtQm94JztcbmltcG9ydCB7IFNoYXBlRGVmaW5pdGlvbiwgQ29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZSwgRGF0YUl0ZW0sIEtleSB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQ2hhcnRzVjIvdHlwZXMnO1xuaW1wb3J0IHsgTGluZVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvTGluZUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQmFyU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9CYXJDaGFydFYyL3R5cGVzJztcbmltcG9ydCB7IEFyZWFTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0FyZWFDaGFydFYyL3R5cGVzJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5cbmNvbnN0IE1JTl9UT09MVElQX1dJRFRIID0gMTgwO1xuY29uc3QgVE9PTFRJUF9PRkZTRVQgPSAyMDtcbmNvbnN0IFNDUk9MTEJBUl9XSURUSCA9IDQwO1xuXG5pbnRlcmZhY2UgVG9vbHRpcFByb3BzPFQ+IHtcbiAga2V5czogeyBba2V5OiBzdHJpbmddOiBLZXkgfTtcbiAgc2hvd1JvdW5kZWRUb3RhbDogYm9vbGVhbjtcbiAgdG9vbHRpcERhdGE6IHtcbiAgICBba2V5SWQ6IHN0cmluZ106IERhdGFJdGVtO1xuICB9O1xuICB0b29sdGlwTGVmdDogbnVtYmVyO1xuICB0b29sdGlwVG9wOiBudW1iZXI7XG4gIHhLZXk6IHN0cmluZztcbiAgeUtleXM6IHN0cmluZ1tdO1xuICBpdGVtczoge1xuICAgIGxlZ2VuZEl0ZW1zOiBBcnJheTxTaGFwZURlZmluaXRpb248VD4+O1xuICAgIGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzOiBBcnJheTxDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlPjtcbiAgICB2aXNpYmxlWUtleXM6IHN0cmluZ1tdO1xuICB9W107XG4gIHRoZW1lOiBDU1NQcm9wZXJ0aWVzO1xufVxuXG5leHBvcnQgY29uc3QgVG9vbHRpcCA9ICh7XG4gIGtleXMsXG4gIHNob3dSb3VuZGVkVG90YWwsXG4gIHRvb2x0aXBEYXRhLFxuICB0b29sdGlwTGVmdCxcbiAgdG9vbHRpcFRvcCxcbiAgeEtleSxcbiAgeUtleXMsXG4gIHRoZW1lLFxuICBpdGVtcyxcbn06IFRvb2x0aXBQcm9wczxMaW5lU3R5bGVzIHwgQmFyU3R5bGVzIHwgQXJlYVN0eWxlcz4pID0+IHtcbiAgY29uc3QgdG9vbHRpcFJlZiA9IHVzZVJlZjxIVE1MRGl2RWxlbWVudD4obnVsbCk7XG4gIGNvbnN0IFtwb3NpdGlvbiwgc2V0UG9zaXRpb25dID0gdXNlU3RhdGU8eyBsZWZ0OiBudW1iZXIgfT4oe1xuICAgIGxlZnQ6IHRvb2x0aXBMZWZ0LFxuICB9KTtcblxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGNvbnN0IGFkanVzdFRvb2x0aXBQb3NpdGlvbiA9ICgpID0+IHtcbiAgICAgIGNvbnN0IHRvb2x0aXBFbGVtZW50ID0gdG9vbHRpcFJlZi5jdXJyZW50O1xuXG4gICAgICBpZiAodG9vbHRpcEVsZW1lbnQpIHtcbiAgICAgICAgY29uc3Qgc2NyZWVuV2lkdGggPSB3aW5kb3cuaW5uZXJXaWR0aDtcblxuICAgICAgICBjb25zdCByZWN0ID0gdG9vbHRpcEVsZW1lbnQuZ2V0Qm91bmRpbmdDbGllbnRSZWN0KCk7XG5cbiAgICAgICAgbGV0IHdpZHRoID0gcmVjdC53aWR0aDtcblxuICAgICAgICBpZiAod2lkdGggPCBNSU5fVE9PTFRJUF9XSURUSCkge1xuICAgICAgICAgIHdpZHRoID0gTUlOX1RPT0xUSVBfV0lEVEg7XG4gICAgICAgIH1cblxuICAgICAgICBsZXQgbGVmdCA9IHRvb2x0aXBMZWZ0ICsgVE9PTFRJUF9PRkZTRVQ7XG5cbiAgICAgICAgaWYgKHRvb2x0aXBMZWZ0ICsgd2lkdGggPiBzY3JlZW5XaWR0aCAtIFNDUk9MTEJBUl9XSURUSCkge1xuICAgICAgICAgIGxlZnQgPSB0b29sdGlwTGVmdCAtIHdpZHRoIC0gVE9PTFRJUF9PRkZTRVQ7XG4gICAgICAgIH1cblxuICAgICAgICBzZXRQb3NpdGlvbih7IGxlZnQgfSk7XG4gICAgICB9XG4gICAgfTtcblxuICAgIGFkanVzdFRvb2x0aXBQb3NpdGlvbigpO1xuICB9LCBbdG9vbHRpcExlZnRdKTtcblxuICByZXR1cm4gY3JlYXRlUG9ydGFsKFxuICAgIDxkaXZcbiAgICAgIHJlZj17dG9vbHRpcFJlZn1cbiAgICAgIHN0eWxlPXt7XG4gICAgICAgIHBvc2l0aW9uOiAnYWJzb2x1dGUnLFxuICAgICAgICBsZWZ0OiBwb3NpdGlvbi5sZWZ0LFxuICAgICAgICB0b3A6IHRvb2x0aXBUb3AsXG4gICAgICAgIHpJbmRleDogMjE0NzQ4MzY0NyAqIDEwLFxuICAgICAgICAuLi50aGVtZSxcbiAgICAgIH19XG4gICAgPlxuICAgICAgPGRpdiBzdHlsZT17eyB3b3JkQnJlYWs6ICdicmVhay1hbGwnIH19PlxuICAgICAgICA8ZGl2XG4gICAgICAgICAgY2xhc3NOYW1lPXtjc3Moe1xuICAgICAgICAgICAgZm9udEZhbWlseTogJ2luaGVyaXQnLFxuICAgICAgICAgICAgbGluZUhlaWdodDogJ2luaGVyaXQnLFxuICAgICAgICAgICAgbGV0dGVyU3BhY2luZzogJ2luaGVyaXQnLFxuICAgICAgICAgICAgZm9udFdlaWdodDogJ2JvbGQnLFxuICAgICAgICAgICAgZm9udFNpemU6ICcxNXB4JyxcbiAgICAgICAgICAgIHdpZHRoOiAnMTAwJScsXG4gICAgICAgICAgICBtaW5XaWR0aDogTUlOX1RPT0xUSVBfV0lEVEgsXG4gICAgICAgICAgfSl9XG4gICAgICAgID5cbiAgICAgICAgICB7dG9vbHRpcERhdGFbeEtleV0uZm9ybWF0dGVkVmFsdWUgPz8gdG9vbHRpcERhdGFbeEtleV0udmFsdWV9XG4gICAgICAgIDwvZGl2PlxuICAgICAgICA8dGFibGVcbiAgICAgICAgICBjZWxsUGFkZGluZz17MH1cbiAgICAgICAgICBjZWxsU3BhY2luZz17MH1cbiAgICAgICAgICBjbGFzc05hbWU9e2Nzcyh7XG4gICAgICAgICAgICBtYXJnaW46ICcwJyxcbiAgICAgICAgICAgIGJvcmRlclNwYWNpbmc6ICcwJyxcbiAgICAgICAgICAgIGJvcmRlckNvbGxhcHNlOiAnaW5oZXJpdCcsXG4gICAgICAgICAgICBib3JkZXI6ICdub25lJyxcbiAgICAgICAgICB9KX1cbiAgICAgICAgPlxuICAgICAgICAgIDx0Ym9keT5cbiAgICAgICAgICAgIHtpdGVtcy5tYXAoKGl0ZW0sIGluZGV4KSA9PiB7XG4gICAgICAgICAgICAgIHJldHVybiAoXG4gICAgICAgICAgICAgICAgPEZyYWdtZW50IGtleT17aW5kZXh9PlxuICAgICAgICAgICAgICAgICAge2l0ZW0ubGVnZW5kSXRlbXM/Lm1hcCgobGVnZW5kSXRlbSwgaW5kZXgpID0+IHtcbiAgICAgICAgICAgICAgICAgICAgaWYgKCF0b29sdGlwRGF0YVtsZWdlbmRJdGVtLnlLZXldIHx8IHRvb2x0aXBEYXRhW2xlZ2VuZEl0ZW0ueUtleV0udmFsdWUgPT09IG51bGwpIHtcbiAgICAgICAgICAgICAgICAgICAgICAvLyB5S2V5IGNvdWxkIG5vdCBiZSBmb3VuZCBpbiB0b29sdGlwRGF0YVxuICAgICAgICAgICAgICAgICAgICAgIHJldHVybiBudWxsO1xuICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICAgIHJldHVybiAoXG4gICAgICAgICAgICAgICAgICAgICAgaXRlbS52aXNpYmxlWUtleXM/LmluY2x1ZGVzKGxlZ2VuZEl0ZW0ueUtleSkgJiYgKFxuICAgICAgICAgICAgICAgICAgICAgICAgPHRyIGtleT17bGVnZW5kSXRlbS55S2V5fT5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgPHRkXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgc3R5bGU9e3tcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHZlcnRpY2FsQWxpZ246ICdtaWRkbGUnLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgcGFkZGluZzogaW5kZXggPT09IDAgPyAnMTJweCA4cHggMCAwJyA6ICc4cHggOHB4IDAgMCcsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICB3aWR0aDogJ2F1dG8nLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIH19XG4gICAgICAgICAgICAgICAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICA8TGVnZW5kSXRlbUJveFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgY29sb3I9e2dldENvbG9yKHtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgZGVmYXVsdENvbG9yOiBsZWdlbmRJdGVtLmNvbG9yLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB2YWx1ZTogdG9vbHRpcERhdGFbbGVnZW5kSXRlbS55S2V5XS52YWx1ZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgeUtleTogbGVnZW5kSXRlbS55S2V5LFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlczogaXRlbS5jb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlcyA/PyBbXSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIH0pfVxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgc3R5bGU9e2xlZ2VuZEl0ZW0uc3R5bGUgYXMgTGluZVN0eWxlc31cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHlLZXk9e2xlZ2VuZEl0ZW0ueUtleX1cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgICAgICAgICAgICAgICA8L3RkPlxuICAgICAgICAgICAgICAgICAgICAgICAgICA8dGQgc3R5bGU9e3sgcGFkZGluZzogJzhweCAwIDAgMCcgfX0+e2tleXNbbGVnZW5kSXRlbS55S2V5XS5rZXlGb3JtYXR0ZWR9PC90ZD5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgPHRkIHN0eWxlPXt7IGZvbnRXZWlnaHQ6ICdib2xkJywgcGFkZGluZzogJzhweCAwIDAgMTZweCcgfX0+XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAge3Rvb2x0aXBEYXRhW2xlZ2VuZEl0ZW0ueUtleV0uZm9ybWF0dGVkVmFsdWVcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgID8gdG9vbHRpcERhdGFbbGVnZW5kSXRlbS55S2V5XS5mb3JtYXR0ZWRWYWx1ZVxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgOiB0b29sdGlwRGF0YVtsZWdlbmRJdGVtLnlLZXldLnZhbHVlfVxuICAgICAgICAgICAgICAgICAgICAgICAgICA8L3RkPlxuICAgICAgICAgICAgICAgICAgICAgICAgPC90cj5cbiAgICAgICAgICAgICAgICAgICAgICApXG4gICAgICAgICAgICAgICAgICAgICk7XG4gICAgICAgICAgICAgICAgICB9KX1cbiAgICAgICAgICAgICAgICA8L0ZyYWdtZW50PlxuICAgICAgICAgICAgICApO1xuICAgICAgICAgICAgfSl9XG5cbiAgICAgICAgICAgIHtzaG93Um91bmRlZFRvdGFsICYmIChcbiAgICAgICAgICAgICAgPHRyPlxuICAgICAgICAgICAgICAgIDx0ZCBjb2xTcGFuPXsyfSBzdHlsZT17eyBwYWRkaW5nOiAnMTJweCAwIDAgMCcgfX0+XG4gICAgICAgICAgICAgICAgICBSb3VuZGVkIFRvdGFsXG4gICAgICAgICAgICAgICAgPC90ZD5cbiAgICAgICAgICAgICAgICA8dGQgc3R5bGU9e3sgZm9udFdlaWdodDogJ2JvbGQnLCBwYWRkaW5nOiAnMTJweCAwIDAgMTZweCcgfX0+XG4gICAgICAgICAgICAgICAgICB7eUtleXMucmVkdWNlKCh0b3RhbCwga2V5KSA9PiB7XG4gICAgICAgICAgICAgICAgICAgIHJldHVybiB0b3RhbCArIE1hdGgucm91bmQodG9vbHRpcERhdGFba2V5XS52YWx1ZSBhcyBudW1iZXIpO1xuICAgICAgICAgICAgICAgICAgfSwgMCl9XG4gICAgICAgICAgICAgICAgPC90ZD5cbiAgICAgICAgICAgICAgPC90cj5cbiAgICAgICAgICAgICl9XG4gICAgICAgICAgPC90Ym9keT5cbiAgICAgICAgPC90YWJsZT5cbiAgICAgIDwvZGl2PlxuICAgIDwvZGl2PixcbiAgICBkb2N1bWVudC5ib2R5XG4gICk7XG59O1xuIl19 */",
|
|
42427
42419
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$5
|
|
42428
42420
|
}),
|
|
42429
42421
|
children: jsxs("tbody", {
|
|
42430
|
-
children: [
|
|
42431
|
-
|
|
42432
|
-
|
|
42433
|
-
|
|
42434
|
-
|
|
42435
|
-
|
|
42436
|
-
|
|
42437
|
-
|
|
42438
|
-
|
|
42439
|
-
|
|
42440
|
-
|
|
42441
|
-
|
|
42442
|
-
|
|
42443
|
-
|
|
42444
|
-
|
|
42445
|
-
|
|
42446
|
-
|
|
42447
|
-
|
|
42448
|
-
|
|
42449
|
-
|
|
42450
|
-
|
|
42451
|
-
|
|
42452
|
-
|
|
42453
|
-
|
|
42454
|
-
|
|
42455
|
-
|
|
42456
|
-
|
|
42457
|
-
|
|
42458
|
-
|
|
42459
|
-
|
|
42460
|
-
|
|
42461
|
-
|
|
42462
|
-
|
|
42463
|
-
|
|
42464
|
-
|
|
42422
|
+
children: [items.map(function (item, index) {
|
|
42423
|
+
var _item$legendItems;
|
|
42424
|
+
return jsx(Fragment, {
|
|
42425
|
+
children: (_item$legendItems = item.legendItems) == null ? void 0 : _item$legendItems.map(function (legendItem, index) {
|
|
42426
|
+
var _item$visibleYKeys, _item$conditionalForm;
|
|
42427
|
+
if (!tooltipData[legendItem.yKey] || tooltipData[legendItem.yKey].value === null) {
|
|
42428
|
+
// yKey could not be found in tooltipData
|
|
42429
|
+
return null;
|
|
42430
|
+
}
|
|
42431
|
+
return ((_item$visibleYKeys = item.visibleYKeys) == null ? void 0 : _item$visibleYKeys.includes(legendItem.yKey)) && jsxs("tr", {
|
|
42432
|
+
children: [jsx("td", {
|
|
42433
|
+
style: {
|
|
42434
|
+
verticalAlign: 'middle',
|
|
42435
|
+
padding: index === 0 ? '12px 8px 0 0' : '8px 8px 0 0',
|
|
42436
|
+
width: 'auto'
|
|
42437
|
+
},
|
|
42438
|
+
children: jsx(LegendItemBox, {
|
|
42439
|
+
color: getColor({
|
|
42440
|
+
defaultColor: legendItem.color,
|
|
42441
|
+
value: tooltipData[legendItem.yKey].value,
|
|
42442
|
+
yKey: legendItem.yKey,
|
|
42443
|
+
conditionalFormattingRules: (_item$conditionalForm = item.conditionalFormattingRules) != null ? _item$conditionalForm : []
|
|
42444
|
+
}),
|
|
42445
|
+
style: legendItem.style,
|
|
42446
|
+
yKey: legendItem.yKey
|
|
42447
|
+
})
|
|
42448
|
+
}), jsx("td", {
|
|
42449
|
+
style: {
|
|
42450
|
+
padding: '8px 0 0 0'
|
|
42451
|
+
},
|
|
42452
|
+
children: keys[legendItem.yKey].keyFormatted
|
|
42453
|
+
}), jsx("td", {
|
|
42454
|
+
style: {
|
|
42455
|
+
fontWeight: 'bold',
|
|
42456
|
+
padding: '8px 0 0 16px'
|
|
42457
|
+
},
|
|
42458
|
+
children: tooltipData[legendItem.yKey].formattedValue ? tooltipData[legendItem.yKey].formattedValue : tooltipData[legendItem.yKey].value
|
|
42459
|
+
})]
|
|
42460
|
+
}, legendItem.yKey);
|
|
42461
|
+
})
|
|
42462
|
+
}, index);
|
|
42465
42463
|
}), showRoundedTotal && jsxs("tr", {
|
|
42466
42464
|
children: [jsx("td", {
|
|
42467
42465
|
colSpan: 2,
|
|
@@ -42584,11 +42582,9 @@ var LegendItem = function LegendItem(_ref) {
|
|
|
42584
42582
|
function _EMOTION_STRINGIFIED_CSS_ERROR__$7() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
|
|
42585
42583
|
var Legend$1 = function Legend(_ref) {
|
|
42586
42584
|
var keys = _ref.keys,
|
|
42587
|
-
visibleYKeys = _ref.visibleYKeys,
|
|
42588
|
-
legendItems = _ref.legendItems,
|
|
42589
42585
|
setVisibleYKeys = _ref.setVisibleYKeys,
|
|
42590
|
-
|
|
42591
|
-
|
|
42586
|
+
marginLeft = _ref.marginLeft,
|
|
42587
|
+
items = _ref.items;
|
|
42592
42588
|
return jsx("div", {
|
|
42593
42589
|
className: /*#__PURE__*/css$1(process.env.NODE_ENV === "production" ? {
|
|
42594
42590
|
name: "1nbollx",
|
|
@@ -42596,7 +42592,7 @@ var Legend$1 = function Legend(_ref) {
|
|
|
42596
42592
|
} : {
|
|
42597
42593
|
name: "qz6h7j-Legend",
|
|
42598
42594
|
styles: "height:40px;padding-top:8px;label:Legend;",
|
|
42599
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
42595
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNEJvQiIsImZpbGUiOiJMZWdlbmQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0LCB7IEZyYWdtZW50IH0gZnJvbSAncmVhY3QnO1xuXG5pbXBvcnQgeyBMZWdlbmRJdGVtIH0gZnJvbSAnLi9MZWdlbmRJdGVtJztcbmltcG9ydCB7IFNoYXBlRGVmaW5pdGlvbiwgQ29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZSwgS2V5IH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9DaGFydHNWMi90eXBlcyc7XG5pbXBvcnQgeyBTY3JvbGxiYXIgfSBmcm9tICcuLi8uLi8uLi9TY3JvbGxiYXIvU2Nyb2xsYmFyJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBCYXJTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0JhckNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgTGluZVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvTGluZUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQXJlYVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQXJlYUNoYXJ0VjIvdHlwZXMnO1xuXG5pbnRlcmZhY2UgTGVnZW5kUHJvcHM8VD4ge1xuICBzZXRWaXNpYmxlWUtleXM/OiBSZWFjdC5EaXNwYXRjaDxSZWFjdC5TZXRTdGF0ZUFjdGlvbjxBcnJheTxzdHJpbmc+Pj47XG4gIGtleXM6IHsgW2tleTogc3RyaW5nXTogS2V5IH07XG4gIG1hcmdpbkxlZnQ6IG51bWJlcjtcbiAgaXRlbXM/OiB7XG4gICAgbGVnZW5kSXRlbXM6IEFycmF5PFNoYXBlRGVmaW5pdGlvbjxUPj47XG4gICAgdmlzaWJsZVlLZXlzOiBBcnJheTxzdHJpbmc+O1xuICAgIGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzOiBBcnJheTxDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlPjtcbiAgfVtdO1xufVxuXG5leHBvcnQgY29uc3QgTGVnZW5kID0gKHtcbiAga2V5cyxcbiAgc2V0VmlzaWJsZVlLZXlzLFxuICBtYXJnaW5MZWZ0LFxuICBpdGVtcyxcbn06IExlZ2VuZFByb3BzPEJhclN0eWxlcyB8IExpbmVTdHlsZXMgfCBBcmVhU3R5bGVzPikgPT4ge1xuICByZXR1cm4gKFxuICAgIDxkaXYgY2xhc3NOYW1lPXtjc3MoeyBoZWlnaHQ6IDQwLCBwYWRkaW5nVG9wOiA4IH0pfT5cbiAgICAgIDxTY3JvbGxiYXJcbiAgICAgICAgY2xhc3NOYW1lPXtjc3Moe1xuICAgICAgICAgIGRpc3BsYXk6ICdmbGV4JyxcbiAgICAgICAgICBmbGV4RGlyZWN0aW9uOiAncm93JyxcbiAgICAgICAgICBmbGV4V3JhcDogJ25vd3JhcCcsXG4gICAgICAgICAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG4gICAgICAgICAgbWFyZ2luTGVmdDogbWFyZ2luTGVmdCA/IGAke21hcmdpbkxlZnR9cHhgIDogdW5kZWZpbmVkLFxuICAgICAgICB9KX1cbiAgICAgICAgeD17dHJ1ZX1cbiAgICAgID5cbiAgICAgICAge2l0ZW1zPy5tYXAoKGl0ZW0sIGluZGV4KSA9PiAoXG4gICAgICAgICAgPEZyYWdtZW50IGtleT17aW5kZXh9PlxuICAgICAgICAgICAge2l0ZW0ubGVnZW5kSXRlbXM/Lm1hcChcbiAgICAgICAgICAgICAgbGVnZW5kSXRlbSA9PlxuICAgICAgICAgICAgICAgIGtleXNbbGVnZW5kSXRlbS55S2V5XSAmJiAoXG4gICAgICAgICAgICAgICAgICA8TGVnZW5kSXRlbVxuICAgICAgICAgICAgICAgICAgICB7Li4ubGVnZW5kSXRlbX1cbiAgICAgICAgICAgICAgICAgICAga2V5PXtgbGVnZW5kLSR7bGVnZW5kSXRlbS55S2V5fWB9XG4gICAgICAgICAgICAgICAgICAgIHlLZXlGb3JtYXR0ZWQ9e2tleXNbbGVnZW5kSXRlbS55S2V5XS5rZXlGb3JtYXR0ZWR9XG4gICAgICAgICAgICAgICAgICAgIG9uQ2xpY2s9eygpID0+XG4gICAgICAgICAgICAgICAgICAgICAgc2V0VmlzaWJsZVlLZXlzICYmXG4gICAgICAgICAgICAgICAgICAgICAgc2V0VmlzaWJsZVlLZXlzKHByZXYgPT4ge1xuICAgICAgICAgICAgICAgICAgICAgICAgbGV0IG5ld1Zpc2libGVMZWdlbmRJdGVtczogQXJyYXk8c3RyaW5nPiA9IFtdO1xuXG4gICAgICAgICAgICAgICAgICAgICAgICBpZiAocHJldi5sZW5ndGggPT09IGl0ZW0ubGVnZW5kSXRlbXMubGVuZ3RoKSB7XG4gICAgICAgICAgICAgICAgICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IFtsZWdlbmRJdGVtLnlLZXldO1xuICAgICAgICAgICAgICAgICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgaWYgKHByZXYuaW5jbHVkZXMobGVnZW5kSXRlbS55S2V5KSkge1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IHByZXYuZmlsdGVyKFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgcHJldkxlZ2VuZEl0ZW1JZCA9PiBwcmV2TGVnZW5kSXRlbUlkICE9PSBsZWdlbmRJdGVtLnlLZXlcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICApO1xuICAgICAgICAgICAgICAgICAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IFsuLi5wcmV2LCBsZWdlbmRJdGVtLnlLZXldO1xuICAgICAgICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICAgICAgICB9XG5cbiAgICAgICAgICAgICAgICAgICAgICAgIHJldHVybiBuZXdWaXNpYmxlTGVnZW5kSXRlbXMubGVuZ3RoID09PSAwXG4gICAgICAgICAgICAgICAgICAgICAgICAgID8gaXRlbS5sZWdlbmRJdGVtcy5tYXAobGVnZW5kSXRlbSA9PiBsZWdlbmRJdGVtLnlLZXkpXG4gICAgICAgICAgICAgICAgICAgICAgICAgIDogbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zO1xuICAgICAgICAgICAgICAgICAgICAgIH0pXG4gICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICAgICAgdmlzaWJsZT17c2V0VmlzaWJsZVlLZXlzID8gaXRlbS52aXNpYmxlWUtleXMuaW5jbHVkZXMobGVnZW5kSXRlbS55S2V5KSA6IHRydWV9XG4gICAgICAgICAgICAgICAgICAgIGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzPXtpdGVtLmNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzfVxuICAgICAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgICAgICApXG4gICAgICAgICAgICApfVxuICAgICAgICAgIDwvRnJhZ21lbnQ+XG4gICAgICAgICkpfVxuICAgICAgPC9TY3JvbGxiYXI+XG4gICAgPC9kaXY+XG4gICk7XG59O1xuIl19 */",
|
|
42600
42596
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$7
|
|
42601
42597
|
}),
|
|
42602
42598
|
children: jsx(Scrollbar, {
|
|
@@ -42606,34 +42602,39 @@ var Legend$1 = function Legend(_ref) {
|
|
|
42606
42602
|
flexWrap: 'nowrap',
|
|
42607
42603
|
alignItems: 'center',
|
|
42608
42604
|
marginLeft: marginLeft ? marginLeft + "px" : undefined
|
|
42609
|
-
}, process.env.NODE_ENV === "production" ? "" : ";label:Legend;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
42605
|
+
}, process.env.NODE_ENV === "production" ? "" : ";label:Legend;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBOEJtQiIsImZpbGUiOiJMZWdlbmQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0LCB7IEZyYWdtZW50IH0gZnJvbSAncmVhY3QnO1xuXG5pbXBvcnQgeyBMZWdlbmRJdGVtIH0gZnJvbSAnLi9MZWdlbmRJdGVtJztcbmltcG9ydCB7IFNoYXBlRGVmaW5pdGlvbiwgQ29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZSwgS2V5IH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9DaGFydHNWMi90eXBlcyc7XG5pbXBvcnQgeyBTY3JvbGxiYXIgfSBmcm9tICcuLi8uLi8uLi9TY3JvbGxiYXIvU2Nyb2xsYmFyJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBCYXJTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0JhckNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgTGluZVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvTGluZUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQXJlYVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQXJlYUNoYXJ0VjIvdHlwZXMnO1xuXG5pbnRlcmZhY2UgTGVnZW5kUHJvcHM8VD4ge1xuICBzZXRWaXNpYmxlWUtleXM/OiBSZWFjdC5EaXNwYXRjaDxSZWFjdC5TZXRTdGF0ZUFjdGlvbjxBcnJheTxzdHJpbmc+Pj47XG4gIGtleXM6IHsgW2tleTogc3RyaW5nXTogS2V5IH07XG4gIG1hcmdpbkxlZnQ6IG51bWJlcjtcbiAgaXRlbXM/OiB7XG4gICAgbGVnZW5kSXRlbXM6IEFycmF5PFNoYXBlRGVmaW5pdGlvbjxUPj47XG4gICAgdmlzaWJsZVlLZXlzOiBBcnJheTxzdHJpbmc+O1xuICAgIGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzOiBBcnJheTxDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlPjtcbiAgfVtdO1xufVxuXG5leHBvcnQgY29uc3QgTGVnZW5kID0gKHtcbiAga2V5cyxcbiAgc2V0VmlzaWJsZVlLZXlzLFxuICBtYXJnaW5MZWZ0LFxuICBpdGVtcyxcbn06IExlZ2VuZFByb3BzPEJhclN0eWxlcyB8IExpbmVTdHlsZXMgfCBBcmVhU3R5bGVzPikgPT4ge1xuICByZXR1cm4gKFxuICAgIDxkaXYgY2xhc3NOYW1lPXtjc3MoeyBoZWlnaHQ6IDQwLCBwYWRkaW5nVG9wOiA4IH0pfT5cbiAgICAgIDxTY3JvbGxiYXJcbiAgICAgICAgY2xhc3NOYW1lPXtjc3Moe1xuICAgICAgICAgIGRpc3BsYXk6ICdmbGV4JyxcbiAgICAgICAgICBmbGV4RGlyZWN0aW9uOiAncm93JyxcbiAgICAgICAgICBmbGV4V3JhcDogJ25vd3JhcCcsXG4gICAgICAgICAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG4gICAgICAgICAgbWFyZ2luTGVmdDogbWFyZ2luTGVmdCA/IGAke21hcmdpbkxlZnR9cHhgIDogdW5kZWZpbmVkLFxuICAgICAgICB9KX1cbiAgICAgICAgeD17dHJ1ZX1cbiAgICAgID5cbiAgICAgICAge2l0ZW1zPy5tYXAoKGl0ZW0sIGluZGV4KSA9PiAoXG4gICAgICAgICAgPEZyYWdtZW50IGtleT17aW5kZXh9PlxuICAgICAgICAgICAge2l0ZW0ubGVnZW5kSXRlbXM/Lm1hcChcbiAgICAgICAgICAgICAgbGVnZW5kSXRlbSA9PlxuICAgICAgICAgICAgICAgIGtleXNbbGVnZW5kSXRlbS55S2V5XSAmJiAoXG4gICAgICAgICAgICAgICAgICA8TGVnZW5kSXRlbVxuICAgICAgICAgICAgICAgICAgICB7Li4ubGVnZW5kSXRlbX1cbiAgICAgICAgICAgICAgICAgICAga2V5PXtgbGVnZW5kLSR7bGVnZW5kSXRlbS55S2V5fWB9XG4gICAgICAgICAgICAgICAgICAgIHlLZXlGb3JtYXR0ZWQ9e2tleXNbbGVnZW5kSXRlbS55S2V5XS5rZXlGb3JtYXR0ZWR9XG4gICAgICAgICAgICAgICAgICAgIG9uQ2xpY2s9eygpID0+XG4gICAgICAgICAgICAgICAgICAgICAgc2V0VmlzaWJsZVlLZXlzICYmXG4gICAgICAgICAgICAgICAgICAgICAgc2V0VmlzaWJsZVlLZXlzKHByZXYgPT4ge1xuICAgICAgICAgICAgICAgICAgICAgICAgbGV0IG5ld1Zpc2libGVMZWdlbmRJdGVtczogQXJyYXk8c3RyaW5nPiA9IFtdO1xuXG4gICAgICAgICAgICAgICAgICAgICAgICBpZiAocHJldi5sZW5ndGggPT09IGl0ZW0ubGVnZW5kSXRlbXMubGVuZ3RoKSB7XG4gICAgICAgICAgICAgICAgICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IFtsZWdlbmRJdGVtLnlLZXldO1xuICAgICAgICAgICAgICAgICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgaWYgKHByZXYuaW5jbHVkZXMobGVnZW5kSXRlbS55S2V5KSkge1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IHByZXYuZmlsdGVyKFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgcHJldkxlZ2VuZEl0ZW1JZCA9PiBwcmV2TGVnZW5kSXRlbUlkICE9PSBsZWdlbmRJdGVtLnlLZXlcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICApO1xuICAgICAgICAgICAgICAgICAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IFsuLi5wcmV2LCBsZWdlbmRJdGVtLnlLZXldO1xuICAgICAgICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICAgICAgICB9XG5cbiAgICAgICAgICAgICAgICAgICAgICAgIHJldHVybiBuZXdWaXNpYmxlTGVnZW5kSXRlbXMubGVuZ3RoID09PSAwXG4gICAgICAgICAgICAgICAgICAgICAgICAgID8gaXRlbS5sZWdlbmRJdGVtcy5tYXAobGVnZW5kSXRlbSA9PiBsZWdlbmRJdGVtLnlLZXkpXG4gICAgICAgICAgICAgICAgICAgICAgICAgIDogbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zO1xuICAgICAgICAgICAgICAgICAgICAgIH0pXG4gICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICAgICAgdmlzaWJsZT17c2V0VmlzaWJsZVlLZXlzID8gaXRlbS52aXNpYmxlWUtleXMuaW5jbHVkZXMobGVnZW5kSXRlbS55S2V5KSA6IHRydWV9XG4gICAgICAgICAgICAgICAgICAgIGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzPXtpdGVtLmNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzfVxuICAgICAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgICAgICApXG4gICAgICAgICAgICApfVxuICAgICAgICAgIDwvRnJhZ21lbnQ+XG4gICAgICAgICkpfVxuICAgICAgPC9TY3JvbGxiYXI+XG4gICAgPC9kaXY+XG4gICk7XG59O1xuIl19 */"),
|
|
42610
42606
|
x: true,
|
|
42611
|
-
children:
|
|
42612
|
-
|
|
42613
|
-
|
|
42614
|
-
|
|
42615
|
-
|
|
42616
|
-
|
|
42617
|
-
|
|
42618
|
-
|
|
42619
|
-
|
|
42620
|
-
|
|
42621
|
-
|
|
42622
|
-
|
|
42623
|
-
|
|
42624
|
-
|
|
42625
|
-
|
|
42626
|
-
|
|
42627
|
-
|
|
42628
|
-
|
|
42629
|
-
|
|
42630
|
-
|
|
42631
|
-
|
|
42632
|
-
|
|
42633
|
-
|
|
42634
|
-
|
|
42635
|
-
|
|
42636
|
-
|
|
42607
|
+
children: items == null ? void 0 : items.map(function (item, index) {
|
|
42608
|
+
var _item$legendItems;
|
|
42609
|
+
return jsx(Fragment, {
|
|
42610
|
+
children: (_item$legendItems = item.legendItems) == null ? void 0 : _item$legendItems.map(function (legendItem) {
|
|
42611
|
+
return keys[legendItem.yKey] && createElement$1(LegendItem, _extends({}, legendItem, {
|
|
42612
|
+
key: "legend-" + legendItem.yKey,
|
|
42613
|
+
yKeyFormatted: keys[legendItem.yKey].keyFormatted,
|
|
42614
|
+
onClick: function onClick() {
|
|
42615
|
+
return setVisibleYKeys && setVisibleYKeys(function (prev) {
|
|
42616
|
+
var newVisibleLegendItems = [];
|
|
42617
|
+
if (prev.length === item.legendItems.length) {
|
|
42618
|
+
newVisibleLegendItems = [legendItem.yKey];
|
|
42619
|
+
} else {
|
|
42620
|
+
if (prev.includes(legendItem.yKey)) {
|
|
42621
|
+
newVisibleLegendItems = prev.filter(function (prevLegendItemId) {
|
|
42622
|
+
return prevLegendItemId !== legendItem.yKey;
|
|
42623
|
+
});
|
|
42624
|
+
} else {
|
|
42625
|
+
newVisibleLegendItems = [].concat(prev, [legendItem.yKey]);
|
|
42626
|
+
}
|
|
42627
|
+
}
|
|
42628
|
+
return newVisibleLegendItems.length === 0 ? item.legendItems.map(function (legendItem) {
|
|
42629
|
+
return legendItem.yKey;
|
|
42630
|
+
}) : newVisibleLegendItems;
|
|
42631
|
+
});
|
|
42632
|
+
},
|
|
42633
|
+
visible: setVisibleYKeys ? item.visibleYKeys.includes(legendItem.yKey) : true,
|
|
42634
|
+
conditionalFormattingRules: item.conditionalFormattingRules
|
|
42635
|
+
}));
|
|
42636
|
+
})
|
|
42637
|
+
}, index);
|
|
42637
42638
|
})
|
|
42638
42639
|
})
|
|
42639
42640
|
});
|
|
@@ -42735,19 +42736,19 @@ var buildMargin = function buildMargin(yTicks, showYAxisLabels, hasYAxisTitle, h
|
|
|
42735
42736
|
};
|
|
42736
42737
|
};
|
|
42737
42738
|
|
|
42738
|
-
function useFlattenedData(xScaleKey, xScaleDataType,
|
|
42739
|
+
function useFlattenedData(xScaleKey, xScaleDataType, data, yKeys) {
|
|
42739
42740
|
return useMemo(function () {
|
|
42740
|
-
if (xScaleKey && xScaleDataType) {
|
|
42741
|
+
if (xScaleKey && xScaleDataType && yKeys.length > 0) {
|
|
42741
42742
|
return flattenData({
|
|
42742
|
-
data:
|
|
42743
|
+
data: data,
|
|
42743
42744
|
xScaleKey: xScaleKey,
|
|
42744
42745
|
xScaleDataType: xScaleDataType,
|
|
42745
|
-
yKeys:
|
|
42746
|
+
yKeys: yKeys
|
|
42746
42747
|
});
|
|
42747
42748
|
} else {
|
|
42748
42749
|
return [];
|
|
42749
42750
|
}
|
|
42750
|
-
}, [
|
|
42751
|
+
}, [data, xScaleKey, xScaleDataType, yKeys]);
|
|
42751
42752
|
}
|
|
42752
42753
|
|
|
42753
42754
|
var GoalLine = function GoalLine(_ref) {
|
|
@@ -43099,6 +43100,17 @@ function useTooltip$1(initialTooltipState) {
|
|
|
43099
43100
|
};
|
|
43100
43101
|
}
|
|
43101
43102
|
|
|
43103
|
+
function useYScale(innerHeight, scale) {
|
|
43104
|
+
return useMemo(function () {
|
|
43105
|
+
return scaleLinear({
|
|
43106
|
+
range: [innerHeight, 0],
|
|
43107
|
+
domain: scale.ordering === 'asc' ? [scale.min, scale.max] : [scale.max, scale.min],
|
|
43108
|
+
nice: true,
|
|
43109
|
+
round: true
|
|
43110
|
+
});
|
|
43111
|
+
}, [innerHeight, scale]);
|
|
43112
|
+
}
|
|
43113
|
+
|
|
43102
43114
|
var LineChart$5 = function LineChart(_ref) {
|
|
43103
43115
|
var _theme$axis;
|
|
43104
43116
|
var chart = _ref.chart,
|
|
@@ -43164,14 +43176,8 @@ var LineChart$5 = function LineChart(_ref) {
|
|
|
43164
43176
|
}
|
|
43165
43177
|
return null;
|
|
43166
43178
|
}, [innerWidth, chart.x, chart.data]);
|
|
43167
|
-
var _yScale =
|
|
43168
|
-
|
|
43169
|
-
range: [innerHeight, 0],
|
|
43170
|
-
domain: chart.y.scale.ordering === 'asc' ? [chart.y.scale.min, chart.y.scale.max] : [chart.y.scale.max, chart.y.scale.min],
|
|
43171
|
-
nice: true
|
|
43172
|
-
});
|
|
43173
|
-
}, [innerHeight, chart.y]);
|
|
43174
|
-
var dataFlattened = useFlattenedData(xScaleKey, xScaleDataType, chart);
|
|
43179
|
+
var _yScale = useYScale(innerHeight, chart.y.scale);
|
|
43180
|
+
var dataFlattened = useFlattenedData(xScaleKey, xScaleDataType, chart.data, chart.y.keys);
|
|
43175
43181
|
var handleMouseMove = useCallback(function (event) {
|
|
43176
43182
|
if (!xKey || !xScaleKey || xScale === null) return;
|
|
43177
43183
|
var tooltipData = getTooltipData({
|
|
@@ -43198,6 +43204,11 @@ var LineChart$5 = function LineChart(_ref) {
|
|
|
43198
43204
|
var yTickValues = chart.y.ticks.map(function (tick) {
|
|
43199
43205
|
return Number(tick.value);
|
|
43200
43206
|
});
|
|
43207
|
+
var legendTooltipItems = [{
|
|
43208
|
+
legendItems: chart.lines,
|
|
43209
|
+
visibleYKeys: visibleYKeys,
|
|
43210
|
+
conditionalFormattingRules: chart.conditionalFormattingRules
|
|
43211
|
+
}];
|
|
43201
43212
|
return jsxs(React__default.Fragment, {
|
|
43202
43213
|
children: [jsxs(ChartWrapper$1, {
|
|
43203
43214
|
width: width,
|
|
@@ -43232,93 +43243,19 @@ var LineChart$5 = function LineChart(_ref) {
|
|
|
43232
43243
|
yScale: _yScale,
|
|
43233
43244
|
ticks: yTickValues,
|
|
43234
43245
|
stroke: theme == null || (_theme$axis = theme.axis) == null ? void 0 : _theme$axis.stroke
|
|
43235
|
-
}),
|
|
43236
|
-
children:
|
|
43237
|
-
|
|
43238
|
-
|
|
43239
|
-
|
|
43240
|
-
|
|
43241
|
-
|
|
43242
|
-
|
|
43243
|
-
|
|
43244
|
-
|
|
43245
|
-
|
|
43246
|
-
|
|
43247
|
-
|
|
43248
|
-
},
|
|
43249
|
-
y: function y(d) {
|
|
43250
|
-
return _yScale(Number(d[yKey]));
|
|
43251
|
-
},
|
|
43252
|
-
stroke: chart.lines.filter(function (legendItem) {
|
|
43253
|
-
return legendItem.yKey === yKey;
|
|
43254
|
-
})[0].color,
|
|
43255
|
-
strokeWidth: chart.lines.filter(function (legendItem) {
|
|
43256
|
-
return legendItem.yKey === yKey;
|
|
43257
|
-
})[0].style.strokeWidth,
|
|
43258
|
-
strokeLinecap: "round",
|
|
43259
|
-
strokeDasharray: (_chart$lines$filter$ = chart.lines.filter(function (legendItem) {
|
|
43260
|
-
return legendItem.yKey === yKey;
|
|
43261
|
-
})[0].style.strokeDasharray) != null ? _chart$lines$filter$ : undefined,
|
|
43262
|
-
shapeRendering: "smooth",
|
|
43263
|
-
defined: function defined(d) {
|
|
43264
|
-
return d[yKey] !== null;
|
|
43265
|
-
},
|
|
43266
|
-
curve: curve
|
|
43267
|
-
}, yKey);
|
|
43268
|
-
}), chart.conditionalFormattingRules.map(function (conditionalFormattingRule) {
|
|
43269
|
-
var _chart$lines$filter$2;
|
|
43270
|
-
if (conditionalFormattingRule.operator !== '<=' && conditionalFormattingRule.operator !== '>=') return null;
|
|
43271
|
-
var yKey = conditionalFormattingRule.yKey;
|
|
43272
|
-
var clipPathId = "clip-path-" + yKey + "-" + conditionalFormattingRule.value + "-" + conditionalFormattingRule.color + "-" + Math.random(); // Do not remove Math.random() - required to ensure unique clipPathId per view instance
|
|
43273
|
-
|
|
43274
|
-
var clipArea = getClipArea({
|
|
43275
|
-
conditionalFormattingRule: conditionalFormattingRule,
|
|
43276
|
-
chart: {
|
|
43277
|
-
width: innerWidth,
|
|
43278
|
-
height: innerHeight,
|
|
43279
|
-
yScale: _yScale
|
|
43280
|
-
}
|
|
43281
|
-
});
|
|
43282
|
-
|
|
43283
|
-
// return a new <LinePath /> for each conditional formatting rule with a matching <ReactClipPath /> to frame the part of the path that should be visible
|
|
43284
|
-
return jsxs(Group$2, {
|
|
43285
|
-
children: [jsx(LinePath, {
|
|
43286
|
-
clipPath: "url(#" + clipPathId + ")",
|
|
43287
|
-
visibility: visibleYKeys.includes(yKey) ? 'visible' : 'hidden',
|
|
43288
|
-
data: dataFlattened,
|
|
43289
|
-
x: function x(d) {
|
|
43290
|
-
var _xScale2;
|
|
43291
|
-
// @ts-ignore
|
|
43292
|
-
var xValue = d[xScaleKey];
|
|
43293
|
-
var xValueAdjusted = xScaleDataType === 'date_time' ? new Date(xValue) : xScaleDataType === 'number' ? Number(xValue) : String(xValue);
|
|
43294
|
-
// @ts-ignore
|
|
43295
|
-
return (_xScale2 = xScale(xValueAdjusted)) != null ? _xScale2 : 0;
|
|
43296
|
-
},
|
|
43297
|
-
y: function y(d) {
|
|
43298
|
-
return _yScale(Number(d[yKey]));
|
|
43299
|
-
},
|
|
43300
|
-
stroke: conditionalFormattingRule.color,
|
|
43301
|
-
strokeWidth: chart.lines.filter(function (legendItem) {
|
|
43302
|
-
return legendItem.yKey === yKey;
|
|
43303
|
-
})[0].style.strokeWidth,
|
|
43304
|
-
strokeLinecap: "round",
|
|
43305
|
-
strokeDasharray: (_chart$lines$filter$2 = chart.lines.filter(function (legendItem) {
|
|
43306
|
-
return legendItem.yKey === yKey;
|
|
43307
|
-
})[0].style.strokeDasharray) != null ? _chart$lines$filter$2 : undefined,
|
|
43308
|
-
shapeRendering: "smooth",
|
|
43309
|
-
defined: function defined(d) {
|
|
43310
|
-
return d[yKey] !== null;
|
|
43311
|
-
},
|
|
43312
|
-
curve: curve
|
|
43313
|
-
}, yKey), jsx(RectClipPath, {
|
|
43314
|
-
id: clipPathId,
|
|
43315
|
-
x: clipArea.x,
|
|
43316
|
-
y: clipArea.y,
|
|
43317
|
-
width: clipArea.width,
|
|
43318
|
-
height: clipArea.height
|
|
43319
|
-
})]
|
|
43320
|
-
}, clipPathId);
|
|
43321
|
-
})]
|
|
43246
|
+
}), jsx(Group$2, {
|
|
43247
|
+
children: xScaleKey !== null && jsx(Lines, {
|
|
43248
|
+
lines: chart.lines,
|
|
43249
|
+
conditionalFormattingRules: chart.conditionalFormattingRules,
|
|
43250
|
+
curve: curve,
|
|
43251
|
+
yKeys: chart.y.keys,
|
|
43252
|
+
visibleYKeys: visibleYKeys,
|
|
43253
|
+
data: dataFlattened,
|
|
43254
|
+
xScaleKey: xScaleKey,
|
|
43255
|
+
xScaleDataType: xScaleDataType,
|
|
43256
|
+
xScale: xScale,
|
|
43257
|
+
yScale: _yScale
|
|
43258
|
+
})
|
|
43322
43259
|
})]
|
|
43323
43260
|
}), tooltipData && jsxs("g", {
|
|
43324
43261
|
children: [jsx(Line, {
|
|
@@ -43350,27 +43287,117 @@ var LineChart$5 = function LineChart(_ref) {
|
|
|
43350
43287
|
width: innerWidth
|
|
43351
43288
|
})]
|
|
43352
43289
|
}), options.showLegend && jsx(Legend$1, {
|
|
43353
|
-
|
|
43354
|
-
visibleYKeys: visibleYKeys,
|
|
43290
|
+
items: legendTooltipItems,
|
|
43355
43291
|
setVisibleYKeys: setVisibleYKeys,
|
|
43356
43292
|
keys: chart.keys,
|
|
43357
|
-
conditionalFormattingRules: chart.conditionalFormattingRules,
|
|
43358
43293
|
marginLeft: margin.left - margin.leftTitleOffset
|
|
43359
43294
|
}), tooltipOpen && tooltipData && xKey && jsx(Tooltip$1, {
|
|
43295
|
+
items: legendTooltipItems,
|
|
43360
43296
|
tooltipData: tooltipData,
|
|
43361
43297
|
tooltipLeft: tooltipLeft,
|
|
43362
43298
|
tooltipTop: tooltipTop,
|
|
43363
43299
|
xKey: xKey,
|
|
43364
43300
|
keys: chart.keys,
|
|
43365
|
-
visibleYKeys: visibleYKeys,
|
|
43366
43301
|
yKeys: chart.y.keys,
|
|
43367
|
-
legendItems: chart.lines,
|
|
43368
43302
|
showRoundedTotal: options.showRoundedTotal,
|
|
43369
|
-
conditionalFormattingRules: chart.conditionalFormattingRules,
|
|
43370
43303
|
theme: themeCSS.popoverMenus
|
|
43371
43304
|
})]
|
|
43372
43305
|
});
|
|
43373
43306
|
};
|
|
43307
|
+
function Lines(_ref2) {
|
|
43308
|
+
var yKeys = _ref2.yKeys,
|
|
43309
|
+
visibleYKeys = _ref2.visibleYKeys,
|
|
43310
|
+
data = _ref2.data,
|
|
43311
|
+
xScaleKey = _ref2.xScaleKey,
|
|
43312
|
+
xScaleDataType = _ref2.xScaleDataType,
|
|
43313
|
+
xScale = _ref2.xScale,
|
|
43314
|
+
yScale = _ref2.yScale,
|
|
43315
|
+
lines = _ref2.lines,
|
|
43316
|
+
curve = _ref2.curve,
|
|
43317
|
+
conditionalFormattingRules = _ref2.conditionalFormattingRules;
|
|
43318
|
+
return jsxs(Fragment, {
|
|
43319
|
+
children: [yKeys.map(function (yKey) {
|
|
43320
|
+
var _lines$filter$0$style;
|
|
43321
|
+
return jsx(LinePath, {
|
|
43322
|
+
visibility: visibleYKeys.includes(yKey) ? 'visible' : 'hidden',
|
|
43323
|
+
data: data,
|
|
43324
|
+
x: function x(d) {
|
|
43325
|
+
var _ref3;
|
|
43326
|
+
var xValue = d[xScaleKey];
|
|
43327
|
+
var xValueAdjusted = xScaleDataType === 'date_time' ? new Date(xValue) : xScaleDataType === 'number' ? Number(xValue) : String(xValue);
|
|
43328
|
+
return (_ref3 = xScale(xValueAdjusted)) != null ? _ref3 : 0;
|
|
43329
|
+
},
|
|
43330
|
+
y: function y(d) {
|
|
43331
|
+
return yScale(d[yKey]);
|
|
43332
|
+
},
|
|
43333
|
+
stroke: lines.filter(function (legendItem) {
|
|
43334
|
+
return legendItem.yKey === yKey;
|
|
43335
|
+
})[0].color,
|
|
43336
|
+
strokeWidth: lines.filter(function (legendItem) {
|
|
43337
|
+
return legendItem.yKey === yKey;
|
|
43338
|
+
})[0].style.strokeWidth,
|
|
43339
|
+
strokeLinecap: "round",
|
|
43340
|
+
strokeDasharray: (_lines$filter$0$style = lines.filter(function (legendItem) {
|
|
43341
|
+
return legendItem.yKey === yKey;
|
|
43342
|
+
})[0].style.strokeDasharray) != null ? _lines$filter$0$style : undefined,
|
|
43343
|
+
shapeRendering: "smooth",
|
|
43344
|
+
defined: function defined(d) {
|
|
43345
|
+
return d[yKey] !== null;
|
|
43346
|
+
},
|
|
43347
|
+
curve: curve
|
|
43348
|
+
}, yKey);
|
|
43349
|
+
}), conditionalFormattingRules.map(function (conditionalFormattingRule) {
|
|
43350
|
+
var _lines$filter$0$style2;
|
|
43351
|
+
if (conditionalFormattingRule.operator !== '<=' && conditionalFormattingRule.operator !== '>=') return null;
|
|
43352
|
+
var yKey = conditionalFormattingRule.yKey;
|
|
43353
|
+
var clipPathId = "clip-path-" + yKey + "-" + conditionalFormattingRule.value + "-" + conditionalFormattingRule.color + "-" + Math.random(); // Do not remove Math.random() - required to ensure unique clipPathId per view instance
|
|
43354
|
+
|
|
43355
|
+
var clipArea = getClipArea({
|
|
43356
|
+
conditionalFormattingRule: conditionalFormattingRule,
|
|
43357
|
+
chart: {
|
|
43358
|
+
width: innerWidth,
|
|
43359
|
+
height: innerHeight,
|
|
43360
|
+
yScale: yScale
|
|
43361
|
+
}
|
|
43362
|
+
});
|
|
43363
|
+
return jsxs(Group$2, {
|
|
43364
|
+
children: [jsx(LinePath, {
|
|
43365
|
+
clipPath: "url(#" + clipPathId + ")",
|
|
43366
|
+
visibility: visibleYKeys.includes(yKey) ? 'visible' : 'hidden',
|
|
43367
|
+
data: data,
|
|
43368
|
+
x: function x(d) {
|
|
43369
|
+
var _ref4;
|
|
43370
|
+
var xValue = d[xScaleKey];
|
|
43371
|
+
var xValueAdjusted = xScaleDataType === 'date_time' ? new Date(xValue) : xScaleDataType === 'number' ? Number(xValue) : String(xValue);
|
|
43372
|
+
return (_ref4 = xScale(xValueAdjusted)) != null ? _ref4 : 0;
|
|
43373
|
+
},
|
|
43374
|
+
y: function y(d) {
|
|
43375
|
+
return yScale(d[yKey]);
|
|
43376
|
+
},
|
|
43377
|
+
stroke: conditionalFormattingRule.color,
|
|
43378
|
+
strokeWidth: lines.filter(function (legendItem) {
|
|
43379
|
+
return legendItem.yKey === yKey;
|
|
43380
|
+
})[0].style.strokeWidth,
|
|
43381
|
+
strokeLinecap: "round",
|
|
43382
|
+
strokeDasharray: (_lines$filter$0$style2 = lines.filter(function (legendItem) {
|
|
43383
|
+
return legendItem.yKey === yKey;
|
|
43384
|
+
})[0].style.strokeDasharray) != null ? _lines$filter$0$style2 : undefined,
|
|
43385
|
+
shapeRendering: "smooth",
|
|
43386
|
+
defined: function defined(d) {
|
|
43387
|
+
return d[yKey] !== null;
|
|
43388
|
+
},
|
|
43389
|
+
curve: curve
|
|
43390
|
+
}, yKey), jsx(RectClipPath, {
|
|
43391
|
+
id: clipPathId,
|
|
43392
|
+
x: clipArea.x,
|
|
43393
|
+
y: clipArea.y,
|
|
43394
|
+
width: clipArea.width,
|
|
43395
|
+
height: clipArea.height
|
|
43396
|
+
})]
|
|
43397
|
+
}, clipPathId);
|
|
43398
|
+
})]
|
|
43399
|
+
});
|
|
43400
|
+
}
|
|
43374
43401
|
|
|
43375
43402
|
function getBarFill(bars, conditionalFormattingRules, barKey, barValues) {
|
|
43376
43403
|
var _bars$find;
|
|
@@ -43387,7 +43414,7 @@ function getBarFill(bars, conditionalFormattingRules, barKey, barValues) {
|
|
|
43387
43414
|
if (compare({
|
|
43388
43415
|
op: rule.operator,
|
|
43389
43416
|
value: rule.value
|
|
43390
|
-
}, value)) {
|
|
43417
|
+
}, value) && rule.yKey === barKey) {
|
|
43391
43418
|
fill = rule.color;
|
|
43392
43419
|
break;
|
|
43393
43420
|
}
|
|
@@ -43396,12 +43423,43 @@ function getBarFill(bars, conditionalFormattingRules, barKey, barValues) {
|
|
|
43396
43423
|
return fill;
|
|
43397
43424
|
}
|
|
43398
43425
|
|
|
43399
|
-
function _EMOTION_STRINGIFIED_CSS_ERROR__$9() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
|
|
43400
|
-
var BAR_RADIUS = 2;
|
|
43401
43426
|
var PADDING = {
|
|
43402
43427
|
paddingOuter: 0.05,
|
|
43403
43428
|
paddingInner: 0.3
|
|
43404
43429
|
};
|
|
43430
|
+
|
|
43431
|
+
function useBarXScale(xScaleDataType, innerWidth, xScaleKey, data) {
|
|
43432
|
+
return useMemo(function () {
|
|
43433
|
+
if (xScaleDataType === 'string') {
|
|
43434
|
+
return scaleBand(_extends({
|
|
43435
|
+
range: [0, innerWidth],
|
|
43436
|
+
domain: xScaleKey ? [].concat(data.map(function (d) {
|
|
43437
|
+
return d[xScaleKey] && d[xScaleKey].value !== null ? String(d[xScaleKey].value) : '';
|
|
43438
|
+
})) : []
|
|
43439
|
+
}, PADDING));
|
|
43440
|
+
}
|
|
43441
|
+
if (xScaleDataType === 'date_time' && xScaleKey) {
|
|
43442
|
+
return scaleBand(_extends({
|
|
43443
|
+
range: [0, innerWidth],
|
|
43444
|
+
domain: data.map(function (d) {
|
|
43445
|
+
return new Date(d[xScaleKey].value);
|
|
43446
|
+
})
|
|
43447
|
+
}, PADDING));
|
|
43448
|
+
}
|
|
43449
|
+
if (xScaleDataType === 'number' && xScaleKey) {
|
|
43450
|
+
return scaleBand(_extends({
|
|
43451
|
+
range: [0, innerWidth],
|
|
43452
|
+
domain: data.map(function (d) {
|
|
43453
|
+
return d[xScaleKey] && d[xScaleKey].value !== null ? Number(d[xScaleKey].value) : 0;
|
|
43454
|
+
})
|
|
43455
|
+
}, PADDING));
|
|
43456
|
+
}
|
|
43457
|
+
return null;
|
|
43458
|
+
}, [innerWidth, data]);
|
|
43459
|
+
}
|
|
43460
|
+
|
|
43461
|
+
function _EMOTION_STRINGIFIED_CSS_ERROR__$9() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
|
|
43462
|
+
var BAR_RADIUS = 2;
|
|
43405
43463
|
var BarChart$5 = function BarChart(_ref) {
|
|
43406
43464
|
var _theme$axis;
|
|
43407
43465
|
var chart = _ref.chart,
|
|
@@ -43432,41 +43490,8 @@ var BarChart$5 = function BarChart(_ref) {
|
|
|
43432
43490
|
var xScaleKey = chart.x.scale.key;
|
|
43433
43491
|
var yScaleKeys = chart.y.keys;
|
|
43434
43492
|
var xScaleDataType = chart.x.scale.dataType;
|
|
43435
|
-
var xScale =
|
|
43436
|
-
|
|
43437
|
-
return scaleBand(_extends({
|
|
43438
|
-
range: [0, innerWidth],
|
|
43439
|
-
domain: xScaleKey ? [].concat(chart.data.map(function (d) {
|
|
43440
|
-
return d[xScaleKey] && d[xScaleKey].value !== null ? String(d[xScaleKey].value) : '';
|
|
43441
|
-
})) : []
|
|
43442
|
-
}, PADDING));
|
|
43443
|
-
}
|
|
43444
|
-
if (xScaleDataType === 'date_time' && xScaleKey) {
|
|
43445
|
-
return scaleBand(_extends({
|
|
43446
|
-
range: [0, innerWidth],
|
|
43447
|
-
domain: chart.data.map(function (d) {
|
|
43448
|
-
return new Date(d[xScaleKey].value);
|
|
43449
|
-
})
|
|
43450
|
-
}, PADDING));
|
|
43451
|
-
}
|
|
43452
|
-
if (xScaleDataType === 'number' && xScaleKey) {
|
|
43453
|
-
return scaleBand(_extends({
|
|
43454
|
-
range: [0, innerWidth],
|
|
43455
|
-
domain: chart.data.map(function (d) {
|
|
43456
|
-
return d[xScaleKey] && d[xScaleKey].value !== null ? Number(d[xScaleKey].value) : 0;
|
|
43457
|
-
})
|
|
43458
|
-
}, PADDING));
|
|
43459
|
-
}
|
|
43460
|
-
return null;
|
|
43461
|
-
}, [innerWidth, chart.x, chart.data]);
|
|
43462
|
-
var yScale = useMemo(function () {
|
|
43463
|
-
return scaleLinear({
|
|
43464
|
-
range: [innerHeight, 0],
|
|
43465
|
-
domain: chart.y.scale.ordering === 'asc' ? [chart.y.scale.min, chart.y.scale.max] : [chart.y.scale.max, chart.y.scale.min],
|
|
43466
|
-
nice: true,
|
|
43467
|
-
round: true
|
|
43468
|
-
});
|
|
43469
|
-
}, [innerHeight, chart.y]);
|
|
43493
|
+
var xScale = useBarXScale(xScaleDataType, innerWidth, xScaleKey, chart.data);
|
|
43494
|
+
var yScale = useYScale(innerHeight, chart.y.scale);
|
|
43470
43495
|
var innerXScale = useMemo(function () {
|
|
43471
43496
|
if (!options.stacked && xScale && 'bandwidth' in xScale) {
|
|
43472
43497
|
return scaleBand({
|
|
@@ -43477,7 +43502,7 @@ var BarChart$5 = function BarChart(_ref) {
|
|
|
43477
43502
|
}
|
|
43478
43503
|
return undefined;
|
|
43479
43504
|
}, [xScale, yScaleKeys, options.stacked, xScaleDataType]);
|
|
43480
|
-
var dataFlattened = useFlattenedData(xScaleKey, xScaleDataType, chart);
|
|
43505
|
+
var dataFlattened = useFlattenedData(xScaleKey, xScaleDataType, chart.data, chart.y.keys);
|
|
43481
43506
|
var handleMouseMove = useCallback(function (event) {
|
|
43482
43507
|
if (!xKey || !xScaleKey || xScale === null) return;
|
|
43483
43508
|
var tooltipData = getTooltipData({
|
|
@@ -43523,6 +43548,13 @@ var BarChart$5 = function BarChart(_ref) {
|
|
|
43523
43548
|
var yTickValues = chart.y.ticks.map(function (tick) {
|
|
43524
43549
|
return Number(tick.value);
|
|
43525
43550
|
});
|
|
43551
|
+
var legendTooltipItems = [{
|
|
43552
|
+
visibleYKeys: chart.bars.map(function (legendItem) {
|
|
43553
|
+
return legendItem.yKey;
|
|
43554
|
+
}),
|
|
43555
|
+
legendItems: chart.bars,
|
|
43556
|
+
conditionalFormattingRules: chart.conditionalFormattingRules
|
|
43557
|
+
}];
|
|
43526
43558
|
return jsxs(Fragment, {
|
|
43527
43559
|
children: [jsxs(ChartWrapper$1, {
|
|
43528
43560
|
width: width,
|
|
@@ -43558,57 +43590,25 @@ var BarChart$5 = function BarChart(_ref) {
|
|
|
43558
43590
|
ticks: yTickValues,
|
|
43559
43591
|
stroke: theme == null || (_theme$axis = theme.axis) == null ? void 0 : _theme$axis.stroke
|
|
43560
43592
|
}), jsxs(Group$2, {
|
|
43561
|
-
children: [!options.stacked && jsx(BarGroup
|
|
43593
|
+
children: [!options.stacked && jsx(BarGroup, {
|
|
43562
43594
|
data: dataFlattened,
|
|
43563
43595
|
keys: yScaleKeys,
|
|
43564
43596
|
height: innerHeight,
|
|
43565
|
-
|
|
43566
|
-
|
|
43567
|
-
|
|
43568
|
-
|
|
43569
|
-
var xValueAdjusted = xScaleDataType === 'date_time' ? new Date(xValue) : xScaleDataType === 'number' ? Number(xValue) : String(xValue);
|
|
43570
|
-
// @ts-ignore
|
|
43571
|
-
return xValueAdjusted;
|
|
43572
|
-
}
|
|
43573
|
-
// @ts-ignore
|
|
43574
|
-
,
|
|
43575
|
-
x0Scale: xScale
|
|
43576
|
-
// @ts-ignore
|
|
43577
|
-
,
|
|
43578
|
-
x1Scale: innerXScale,
|
|
43597
|
+
xKey: xKey,
|
|
43598
|
+
xScaleDataType: xScaleDataType,
|
|
43599
|
+
xScale: xScale,
|
|
43600
|
+
innerXScale: innerXScale,
|
|
43579
43601
|
yScale: yScale,
|
|
43580
|
-
|
|
43581
|
-
|
|
43582
|
-
|
|
43583
|
-
|
|
43584
|
-
return barGroups.map(function (barGroup) {
|
|
43585
|
-
return jsx(Group$2, {
|
|
43586
|
-
left: barGroup.x0,
|
|
43587
|
-
children: barGroup.bars.map(function (bar) {
|
|
43588
|
-
if (bar.value === null) return null;
|
|
43589
|
-
if (bar.height < 0 || bar.width < 0) return null;
|
|
43590
|
-
return jsx(Bar, {
|
|
43591
|
-
x: bar.x,
|
|
43592
|
-
y: bar.y,
|
|
43593
|
-
width: bar.width,
|
|
43594
|
-
height: bar.height,
|
|
43595
|
-
fill: getBarFill(chart.bars, chart.conditionalFormattingRules, bar.key, bar.value),
|
|
43596
|
-
onClick: function onClick(e) {
|
|
43597
|
-
return handleOnBarClick(e, barGroup, bar);
|
|
43598
|
-
},
|
|
43599
|
-
enableHover: enableHover
|
|
43600
|
-
}, "bar-group-bar-" + barGroup.index + "-" + bar.index + "-" + bar.value + "-" + bar.key);
|
|
43601
|
-
})
|
|
43602
|
-
}, "bar-group-" + barGroup.index + "-" + barGroup.x0);
|
|
43603
|
-
});
|
|
43604
|
-
}
|
|
43602
|
+
onClick: handleOnBarClick,
|
|
43603
|
+
conditionalFormattingRules: chart.conditionalFormattingRules,
|
|
43604
|
+
bars: chart.bars,
|
|
43605
|
+
enableHover: enableHover
|
|
43605
43606
|
}), options.stacked && jsx(BarStack$1, {
|
|
43606
43607
|
x: function x(d) {
|
|
43607
43608
|
// @ts-ignore
|
|
43608
43609
|
var xValue = d[xScaleKey];
|
|
43609
43610
|
if (xScaleDataType === 'string') return xValue;
|
|
43610
43611
|
var xValueAdjusted = xScaleDataType === 'date_time' ? new Date(xValue) : xScaleDataType === 'number' ? Number(xValue) : String(xValue);
|
|
43611
|
-
// @ts-ignore
|
|
43612
43612
|
return xValueAdjusted;
|
|
43613
43613
|
}
|
|
43614
43614
|
// @ts-ignore
|
|
@@ -43656,31 +43656,79 @@ var BarChart$5 = function BarChart(_ref) {
|
|
|
43656
43656
|
width: innerWidth
|
|
43657
43657
|
})]
|
|
43658
43658
|
}), options.showLegend && jsx(Legend$1, {
|
|
43659
|
-
|
|
43660
|
-
visibleYKeys: chart.bars.map(function (legendItem) {
|
|
43661
|
-
return legendItem.yKey;
|
|
43662
|
-
}),
|
|
43659
|
+
items: legendTooltipItems,
|
|
43663
43660
|
setVisibleYKeys: function setVisibleYKeys() {},
|
|
43664
43661
|
keys: chart.keys,
|
|
43665
|
-
conditionalFormattingRules: chart.conditionalFormattingRules,
|
|
43666
43662
|
marginLeft: margin.left - margin.leftTitleOffset
|
|
43667
43663
|
}), tooltipOpen && tooltipData && xKey && jsx(Tooltip$1, {
|
|
43664
|
+
items: legendTooltipItems,
|
|
43668
43665
|
tooltipData: tooltipData,
|
|
43669
43666
|
tooltipLeft: tooltipLeft,
|
|
43670
43667
|
tooltipTop: tooltipTop,
|
|
43671
43668
|
xKey: xKey,
|
|
43672
43669
|
keys: chart.keys,
|
|
43673
|
-
visibleYKeys: chart.bars.map(function (legendItem) {
|
|
43674
|
-
return legendItem.yKey;
|
|
43675
|
-
}),
|
|
43676
43670
|
yKeys: chart.y.keys,
|
|
43677
|
-
legendItems: chart.bars,
|
|
43678
43671
|
showRoundedTotal: options.showRoundedTotal,
|
|
43679
|
-
conditionalFormattingRules: chart.conditionalFormattingRules,
|
|
43680
43672
|
theme: themeCSS.popoverMenus
|
|
43681
43673
|
})]
|
|
43682
43674
|
});
|
|
43683
43675
|
};
|
|
43676
|
+
function BarGroup(_ref2) {
|
|
43677
|
+
var data = _ref2.data,
|
|
43678
|
+
keys = _ref2.keys,
|
|
43679
|
+
height = _ref2.height,
|
|
43680
|
+
xKey = _ref2.xKey,
|
|
43681
|
+
xScaleDataType = _ref2.xScaleDataType,
|
|
43682
|
+
xScale = _ref2.xScale,
|
|
43683
|
+
innerXScale = _ref2.innerXScale,
|
|
43684
|
+
yScale = _ref2.yScale,
|
|
43685
|
+
_onClick = _ref2.onClick,
|
|
43686
|
+
conditionalFormattingRules = _ref2.conditionalFormattingRules,
|
|
43687
|
+
bars = _ref2.bars,
|
|
43688
|
+
enableHover = _ref2.enableHover;
|
|
43689
|
+
return jsx(BarGroup$2, {
|
|
43690
|
+
data: data,
|
|
43691
|
+
keys: keys,
|
|
43692
|
+
height: height,
|
|
43693
|
+
x0: function x0(d) {
|
|
43694
|
+
var xValue = d[xKey];
|
|
43695
|
+
if (xScaleDataType === 'string') return String(xValue);
|
|
43696
|
+
var xValueAdjusted = xScaleDataType === 'date_time' ? new Date(String(xValue)) : xScaleDataType === 'number' ? Number(xValue) : String(xValue);
|
|
43697
|
+
return xValueAdjusted;
|
|
43698
|
+
}
|
|
43699
|
+
// @ts-ignore
|
|
43700
|
+
,
|
|
43701
|
+
x0Scale: xScale
|
|
43702
|
+
// @ts-ignore
|
|
43703
|
+
,
|
|
43704
|
+
x1Scale: innerXScale,
|
|
43705
|
+
yScale: yScale,
|
|
43706
|
+
color: function color() {
|
|
43707
|
+
return '';
|
|
43708
|
+
},
|
|
43709
|
+
children: function children(barGroups) {
|
|
43710
|
+
return barGroups.map(function (barGroup) {
|
|
43711
|
+
return jsx(Group$2, {
|
|
43712
|
+
left: barGroup.x0,
|
|
43713
|
+
children: barGroup.bars.map(function (bar) {
|
|
43714
|
+
if (bar.value === null || bar.height < 0 || bar.width < 0) return null;
|
|
43715
|
+
return jsx(Bar, {
|
|
43716
|
+
x: bar.x,
|
|
43717
|
+
y: bar.y,
|
|
43718
|
+
width: bar.width,
|
|
43719
|
+
height: bar.height,
|
|
43720
|
+
fill: getBarFill(bars, conditionalFormattingRules, String(bar.key), bar.value),
|
|
43721
|
+
onClick: function onClick(e) {
|
|
43722
|
+
return _onClick(e, barGroup, bar);
|
|
43723
|
+
},
|
|
43724
|
+
enableHover: enableHover
|
|
43725
|
+
}, "bar-group-bar-" + barGroup.index + "-" + bar.index + "-" + bar.value + "-" + String(bar.key));
|
|
43726
|
+
})
|
|
43727
|
+
}, "bar-group-" + barGroup.index + "-" + barGroup.x0);
|
|
43728
|
+
});
|
|
43729
|
+
}
|
|
43730
|
+
});
|
|
43731
|
+
}
|
|
43684
43732
|
var Bar = function Bar(props) {
|
|
43685
43733
|
var _useState = useState(props.fill),
|
|
43686
43734
|
fillColor = _useState[0],
|
|
@@ -43705,7 +43753,7 @@ var Bar = function Bar(props) {
|
|
|
43705
43753
|
} : {
|
|
43706
43754
|
name: "4nk3o1-Bar",
|
|
43707
43755
|
styles: "cursor:pointer;label:Bar;",
|
|
43708
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["BarChart.tsx"],"names":[],"mappings":"AA0YqC","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 { 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';\nimport useTooltip from '../hooks/useTooltip';\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 {\n    tooltipOpen,\n    tooltipLeft = 0,\n    tooltipTop = 0,\n    lineLeft = 0,\n    tooltipData,\n    hideTooltip,\n    showTooltip,\n  } = 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        lineLeft: tooltipData?.lineLeft,\n        tooltipLeft: event.pageX,\n        tooltipTop: event.pageY,\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={lineLeft} 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"]} */",
|
|
43756
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["BarChart.tsx"],"names":[],"mappings":"AA8YqC","file":"BarChart.tsx","sourcesContent":["import { BarChartRepresentation, BarStyles } 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 { Legend } from '../Legend';\nimport { BarGroup as VisxBarGroup, BarStack } from '@visx/shape';\nimport { DataType } from 'shared-logic/src/Field/types';\nimport { scaleBand } from '@visx/scale';\nimport { getBarFill } from '../../utils/getBarFill';\nimport { buildMargin } from '../../utils/buildMargin';\nimport {\n  ChartDataDefinition,\n  ChartOnViewClick,\n  ConditionalFormattingRule,\n  DataItem,\n  ShapeDefinition,\n} from 'shared-logic/src/ChartsV2/types';\nimport { lightenColor } from '../../../styles/color.functions';\nimport { css } from '@emotion/css';\nimport { BarGroupBar, BarGroup as BarGroupType, DatumObject } 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 { ScaleLinear, ScaleBand } from '@visx/vendor/d3-scale';\nimport { Line } from '../Tooltip/Line';\nimport useTooltip from '../hooks/useTooltip';\nimport { useBarXScale } from './useBarXScale';\nimport { useYScale } from '../hooks/useYScale';\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\nexport const BarChart = ({ chart, width, height, options, theme, onClick, enableHover }: BarChartProps) => {\n  const {\n    tooltipOpen,\n    tooltipLeft = 0,\n    tooltipTop = 0,\n    lineLeft = 0,\n    tooltipData,\n    hideTooltip,\n    showTooltip,\n  } = 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 = useBarXScale(xScaleDataType, innerWidth, xScaleKey, chart.data);\n\n  const yScale = useYScale(innerHeight, chart.y.scale);\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<ChartDataDefinition>(xScaleKey, xScaleDataType, chart.data, chart.y.keys);\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        lineLeft: tooltipData?.lineLeft,\n        tooltipLeft: event.pageX,\n        tooltipTop: event.pageY,\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  const legendTooltipItems = [\n    {\n      visibleYKeys: chart.bars.map(legendItem => legendItem.yKey),\n      legendItems: chart.bars,\n      conditionalFormattingRules: chart.conditionalFormattingRules,\n    },\n  ];\n  return (\n    <Fragment>\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                xKey={xKey}\n                xScaleDataType={xScaleDataType}\n                xScale={xScale}\n                innerXScale={innerXScale}\n                yScale={yScale}\n                onClick={handleOnBarClick}\n                conditionalFormattingRules={chart.conditionalFormattingRules}\n                bars={chart.bars}\n                enableHover={enableHover}\n              />\n            )}\n\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                  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={lineLeft} 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          items={legendTooltipItems}\n          setVisibleYKeys={() => {}}\n          keys={chart.keys}\n          marginLeft={margin.left - margin.leftTitleOffset}\n        />\n      )}\n      {/* ----- TOOLTIP ----- */}\n      {tooltipOpen && tooltipData && xKey && (\n        <Tooltip\n          items={legendTooltipItems}\n          tooltipData={tooltipData}\n          tooltipLeft={tooltipLeft}\n          tooltipTop={tooltipTop}\n          xKey={xKey}\n          keys={chart.keys}\n          yKeys={chart.y.keys}\n          showRoundedTotal={options.showRoundedTotal}\n          theme={themeCSS.popoverMenus}\n        />\n      )}\n    </Fragment>\n  );\n};\n\nexport function BarGroup({\n  data,\n  keys,\n  height,\n  xKey,\n  xScaleDataType,\n  xScale,\n  innerXScale,\n  yScale,\n  onClick,\n  conditionalFormattingRules,\n  bars,\n  enableHover,\n}: {\n  data: ChartDataDefinition[];\n  keys: string[];\n  height: number;\n  xKey: string;\n  xScaleDataType: DataType;\n  xScale: ScaleBand<string> | ScaleBand<Date> | ScaleBand<number> | null;\n  innerXScale: ScaleBand<string> | undefined;\n  yScale: ScaleLinear<number, number, never>;\n  onClick: (e: React.MouseEvent<SVGRectElement, MouseEvent>, barGroup: any, bar: any) => void;\n  conditionalFormattingRules: ConditionalFormattingRule[];\n  bars: ShapeDefinition<BarStyles>[];\n  enableHover?: boolean;\n}) {\n  return (\n    <VisxBarGroup<DatumObject>\n      data={data as DatumObject[]}\n      keys={keys}\n      height={height}\n      x0={d => {\n        const xValue = d[xKey as keyof typeof d];\n        if (xScaleDataType === 'string') return String(xValue);\n        const xValueAdjusted =\n          xScaleDataType === 'date_time'\n            ? new Date(String(xValue))\n            : xScaleDataType === 'number'\n            ? Number(xValue)\n            : String(xValue);\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 || bar.height < 0 || bar.width < 0) return null;\n              return (\n                <Bar\n                  key={`bar-group-bar-${barGroup.index}-${bar.index}-${bar.value}-${String(bar.key)}`}\n                  x={bar.x}\n                  y={bar.y}\n                  width={bar.width}\n                  height={bar.height}\n                  fill={getBarFill(bars, conditionalFormattingRules, String(bar.key), bar.value)}\n                  onClick={e => onClick(e, barGroup, bar)}\n                  enableHover={enableHover}\n                />\n              );\n            })}\n          </Group>\n        ));\n      }}\n    </VisxBarGroup>\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"]} */",
|
|
43709
43757
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$9
|
|
43710
43758
|
}) : ''
|
|
43711
43759
|
}, props.key);
|
|
@@ -43881,14 +43929,8 @@ var AreaChart$5 = function AreaChart(_ref) {
|
|
|
43881
43929
|
}
|
|
43882
43930
|
return null;
|
|
43883
43931
|
}, [innerWidth, chart.x, chart.data]);
|
|
43884
|
-
var _yScale =
|
|
43885
|
-
|
|
43886
|
-
range: [innerHeight, 0],
|
|
43887
|
-
domain: chart.y.scale.ordering === 'asc' ? [chart.y.scale.min, chart.y.scale.max] : [chart.y.scale.max, chart.y.scale.min],
|
|
43888
|
-
nice: true
|
|
43889
|
-
});
|
|
43890
|
-
}, [innerHeight, chart.y.scale]);
|
|
43891
|
-
var dataFlattened = useFlattenedData(xScaleKey, xScaleDataType, chart);
|
|
43932
|
+
var _yScale = useYScale(innerHeight, chart.y.scale);
|
|
43933
|
+
var dataFlattened = useFlattenedData(xScaleKey, xScaleDataType, chart.data, chart.y.keys);
|
|
43892
43934
|
var handleMouseMove = useCallback(function (event) {
|
|
43893
43935
|
if (!xKey || !xScaleKey || xScale === null) return;
|
|
43894
43936
|
var tooltipData = getTooltipData({
|
|
@@ -43918,12 +43960,17 @@ var AreaChart$5 = function AreaChart(_ref) {
|
|
|
43918
43960
|
step: curveStep,
|
|
43919
43961
|
straight: curveLinear
|
|
43920
43962
|
};
|
|
43921
|
-
return curveMap[(_options$curve = options.curve) != null ? _options$curve : '
|
|
43963
|
+
return curveMap[(_options$curve = options.curve) != null ? _options$curve : 'natural'];
|
|
43922
43964
|
}, [options.curve]);
|
|
43923
43965
|
if (width === 0 || height === 0 || xScale === null) return jsx(React__default.Fragment, {});
|
|
43924
43966
|
var yTickValues = chart.y.ticks.map(function (tick) {
|
|
43925
43967
|
return Number(tick.value);
|
|
43926
43968
|
});
|
|
43969
|
+
var legendTooltipItems = [{
|
|
43970
|
+
visibleYKeys: visibleYKeys,
|
|
43971
|
+
legendItems: chart.areas,
|
|
43972
|
+
conditionalFormattingRules: chart.conditionalFormattingRules
|
|
43973
|
+
}];
|
|
43927
43974
|
return jsxs(React__default.Fragment, {
|
|
43928
43975
|
children: [jsxs(ChartWrapper$1, {
|
|
43929
43976
|
width: width,
|
|
@@ -44079,23 +44126,19 @@ var AreaChart$5 = function AreaChart(_ref) {
|
|
|
44079
44126
|
width: innerWidth
|
|
44080
44127
|
})]
|
|
44081
44128
|
}), options.showLegend && jsx(Legend$1, {
|
|
44082
|
-
|
|
44083
|
-
visibleYKeys: visibleYKeys,
|
|
44129
|
+
items: legendTooltipItems,
|
|
44084
44130
|
setVisibleYKeys: setVisibleYKeys,
|
|
44085
44131
|
keys: chart.keys,
|
|
44086
|
-
conditionalFormattingRules: chart.conditionalFormattingRules,
|
|
44087
44132
|
marginLeft: margin.left - margin.leftTitleOffset
|
|
44088
44133
|
}), tooltipOpen && tooltipData && xKey && jsx(Tooltip$1, {
|
|
44134
|
+
items: legendTooltipItems,
|
|
44089
44135
|
tooltipData: tooltipData,
|
|
44090
44136
|
tooltipLeft: tooltipLeft,
|
|
44091
44137
|
tooltipTop: tooltipTop,
|
|
44092
44138
|
xKey: xKey,
|
|
44093
44139
|
keys: chart.keys,
|
|
44094
|
-
visibleYKeys: visibleYKeys,
|
|
44095
44140
|
yKeys: chart.y.keys,
|
|
44096
|
-
legendItems: chart.areas,
|
|
44097
44141
|
showRoundedTotal: options.showRoundedTotal,
|
|
44098
|
-
conditionalFormattingRules: chart.conditionalFormattingRules,
|
|
44099
44142
|
theme: themeCSS.popoverMenus
|
|
44100
44143
|
})]
|
|
44101
44144
|
});
|
|
@@ -44398,11 +44441,13 @@ var RadarChart$2 = function RadarChart(_ref) {
|
|
|
44398
44441
|
})]
|
|
44399
44442
|
})
|
|
44400
44443
|
}), options.showLegend && jsx(Legend$1, {
|
|
44401
|
-
|
|
44402
|
-
|
|
44444
|
+
items: [{
|
|
44445
|
+
legendItems: chart.lines,
|
|
44446
|
+
visibleYKeys: visibleYKeys,
|
|
44447
|
+
conditionalFormattingRules: []
|
|
44448
|
+
}],
|
|
44403
44449
|
setVisibleYKeys: setVisibleYKeys,
|
|
44404
44450
|
keys: chart.keys,
|
|
44405
|
-
conditionalFormattingRules: [],
|
|
44406
44451
|
marginLeft: margin.left - margin.leftTitleOffset
|
|
44407
44452
|
})]
|
|
44408
44453
|
});
|
|
@@ -49347,11 +49392,13 @@ var Legend$2 = function Legend(_ref) {
|
|
|
49347
49392
|
};
|
|
49348
49393
|
if (!showLegend) return null;
|
|
49349
49394
|
return jsx(Legend$1, {
|
|
49350
|
-
|
|
49351
|
-
|
|
49395
|
+
items: [{
|
|
49396
|
+
legendItems: items,
|
|
49397
|
+
visibleYKeys: ['increase', 'decrease'],
|
|
49398
|
+
conditionalFormattingRules: []
|
|
49399
|
+
}],
|
|
49352
49400
|
keys: keys,
|
|
49353
49401
|
marginLeft: margin.left - margin.leftTitleOffset,
|
|
49354
|
-
conditionalFormattingRules: [],
|
|
49355
49402
|
setVisibleYKeys: function setVisibleYKeys() {}
|
|
49356
49403
|
});
|
|
49357
49404
|
};
|
|
@@ -49597,7 +49644,7 @@ var WaterfallChart$2 = function WaterfallChart(_ref) {
|
|
|
49597
49644
|
},
|
|
49598
49645
|
stroke: (_theme$axis$stroke = theme == null || (_theme$axis = theme.axis) == null ? void 0 : _theme$axis.stroke) != null ? _theme$axis$stroke : 'transparent'
|
|
49599
49646
|
}), jsx(Group$2, {
|
|
49600
|
-
children: jsx(BarGroup$
|
|
49647
|
+
children: jsx(BarGroup$2, {
|
|
49601
49648
|
data: dataFlattened,
|
|
49602
49649
|
keys: yScaleKeys,
|
|
49603
49650
|
height: innerHeight,
|