@vizzly/dashboard 0.14.4-dev-88f2ae3ae61dabab126f4b0d884b40773d9cb20b → 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
|
@@ -1559,7 +1559,7 @@ var upcastFilterType = function upcastFilterType(type) {
|
|
|
1559
1559
|
if (type === 'dateTimeFilter') {
|
|
1560
1560
|
return DATE_FILTER;
|
|
1561
1561
|
}
|
|
1562
|
-
if (type === 'numericFilter'
|
|
1562
|
+
if (type === 'numericFilter') {
|
|
1563
1563
|
return ADVANCED_FILTER;
|
|
1564
1564
|
}
|
|
1565
1565
|
return type;
|
|
@@ -13772,8 +13772,7 @@ var ADMIN_FEATURE_TOGGLES = {
|
|
|
13772
13772
|
forceMobile: false,
|
|
13773
13773
|
unloadOffScreenViews: false,
|
|
13774
13774
|
showSavingIndicator: false,
|
|
13775
|
-
disablePersistingGlobalFiltersLocally: false
|
|
13776
|
-
simpleMultiSelectFilter: false
|
|
13775
|
+
disablePersistingGlobalFiltersLocally: false
|
|
13777
13776
|
};
|
|
13778
13777
|
var END_USER_DEFAULT_FEATURE_TOGGLES = {
|
|
13779
13778
|
parameters: true,
|
|
@@ -13810,8 +13809,7 @@ var END_USER_DEFAULT_FEATURE_TOGGLES = {
|
|
|
13810
13809
|
forceMobile: false,
|
|
13811
13810
|
unloadOffScreenViews: false,
|
|
13812
13811
|
showSavingIndicator: true,
|
|
13813
|
-
disablePersistingGlobalFiltersLocally: false
|
|
13814
|
-
simpleMultiSelectFilter: false
|
|
13812
|
+
disablePersistingGlobalFiltersLocally: false
|
|
13815
13813
|
};
|
|
13816
13814
|
var build$b = function build(partialFeatureToggles, queryEngineConfig, mode, scope) {
|
|
13817
13815
|
var featureToggles = {};
|
|
@@ -13868,7 +13866,7 @@ var build$b = function build(partialFeatureToggles, queryEngineConfig, mode, sco
|
|
|
13868
13866
|
return featureToggles;
|
|
13869
13867
|
};
|
|
13870
13868
|
var buildDefaults = function buildDefaults(partialFeatureToggles) {
|
|
13871
|
-
var _partialFeatureToggle, _partialFeatureToggle2
|
|
13869
|
+
var _partialFeatureToggle, _partialFeatureToggle2;
|
|
13872
13870
|
return {
|
|
13873
13871
|
showDateAndTimeFilter: partialFeatureToggles.showDateAndTimeFilter !== undefined ? partialFeatureToggles.showDateAndTimeFilter : true,
|
|
13874
13872
|
showDateFilter: partialFeatureToggles.showDateFilter !== undefined ? partialFeatureToggles.showDateFilter : true,
|
|
@@ -13879,8 +13877,7 @@ var buildDefaults = function buildDefaults(partialFeatureToggles) {
|
|
|
13879
13877
|
canDownloadViewAsPNG: partialFeatureToggles.canDownloadViewAsPNG !== undefined ? partialFeatureToggles.canDownloadViewAsPNG : true,
|
|
13880
13878
|
forceMobile: partialFeatureToggles.forceMobile !== undefined ? partialFeatureToggles.forceMobile : false,
|
|
13881
13879
|
unloadOffScreenViews: partialFeatureToggles.unloadOffScreenViews !== undefined ? partialFeatureToggles.unloadOffScreenViews : false,
|
|
13882
|
-
allowCalculatedField: (_partialFeatureToggle2 = partialFeatureToggles.allowCalculatedField) != null ? _partialFeatureToggle2 : false
|
|
13883
|
-
simpleMultiSelectFilter: (_partialFeatureToggle3 = partialFeatureToggles.simpleMultiSelectFilter) != null ? _partialFeatureToggle3 : false
|
|
13880
|
+
allowCalculatedField: (_partialFeatureToggle2 = partialFeatureToggles.allowCalculatedField) != null ? _partialFeatureToggle2 : false
|
|
13884
13881
|
};
|
|
13885
13882
|
};
|
|
13886
13883
|
|
|
@@ -28844,8 +28841,7 @@ var AdditionalFilter = function AdditionalFilter(props) {
|
|
|
28844
28841
|
onChange = props.onChange,
|
|
28845
28842
|
shouldAlwaysHaveValue = props.shouldAlwaysHaveValue;
|
|
28846
28843
|
var _useDashboardBehaviou = useDashboardBehaviourContext(),
|
|
28847
|
-
queryEngineConfig = _useDashboardBehaviou.queryEngineConfig
|
|
28848
|
-
featureToggles = _useDashboardBehaviou.featureToggles;
|
|
28844
|
+
queryEngineConfig = _useDashboardBehaviou.queryEngineConfig;
|
|
28849
28845
|
|
|
28850
28846
|
/** Validate the new filter before setting it */
|
|
28851
28847
|
var onChangeWithValidation = function onChangeWithValidation(newFilter) {
|
|
@@ -28896,7 +28892,7 @@ var AdditionalFilter = function AdditionalFilter(props) {
|
|
|
28896
28892
|
dataSets: props.dataSets
|
|
28897
28893
|
}, typeof props.filter.value === 'boolean' ? undefined : JSON.stringify(props.filter.value));
|
|
28898
28894
|
}
|
|
28899
|
-
if (filter.type == MULTI_SELECT_FILTER
|
|
28895
|
+
if (filter.type == MULTI_SELECT_FILTER) {
|
|
28900
28896
|
return jsxRuntime.jsx(MultiSelectFilter, {
|
|
28901
28897
|
showClearBtn: !shouldAlwaysHaveValue,
|
|
28902
28898
|
filter: filter,
|
|
@@ -38080,13 +38076,11 @@ var AddFilterForm = function AddFilterForm(props) {
|
|
|
38080
38076
|
value: SINGLE_SELECT_FILTER,
|
|
38081
38077
|
subText: textOverride('single_select_filter_description', 'Choose a single option from the list to filter. ')
|
|
38082
38078
|
}];
|
|
38083
|
-
|
|
38084
|
-
|
|
38085
|
-
|
|
38086
|
-
|
|
38087
|
-
|
|
38088
|
-
});
|
|
38089
|
-
}
|
|
38079
|
+
filterTypes.push({
|
|
38080
|
+
label: textOverride('multi_select', 'Multi select'),
|
|
38081
|
+
value: MULTI_SELECT_FILTER,
|
|
38082
|
+
subText: textOverride('multi_select_description', 'Allow multiple selections.')
|
|
38083
|
+
});
|
|
38090
38084
|
filterTypes.push({
|
|
38091
38085
|
label: textOverride('advanced_filter', 'Advanced filter'),
|
|
38092
38086
|
value: ADVANCED_FILTER,
|
|
@@ -42317,16 +42311,14 @@ var SCROLLBAR_WIDTH = 40;
|
|
|
42317
42311
|
var Tooltip$1 = function Tooltip(_ref) {
|
|
42318
42312
|
var _tooltipData$xKey$for;
|
|
42319
42313
|
var keys = _ref.keys,
|
|
42320
|
-
legendItems = _ref.legendItems,
|
|
42321
42314
|
showRoundedTotal = _ref.showRoundedTotal,
|
|
42322
42315
|
tooltipData = _ref.tooltipData,
|
|
42323
42316
|
tooltipLeft = _ref.tooltipLeft,
|
|
42324
42317
|
tooltipTop = _ref.tooltipTop,
|
|
42325
|
-
visibleYKeys = _ref.visibleYKeys,
|
|
42326
42318
|
xKey = _ref.xKey,
|
|
42327
42319
|
yKeys = _ref.yKeys,
|
|
42328
|
-
|
|
42329
|
-
|
|
42320
|
+
theme = _ref.theme,
|
|
42321
|
+
items = _ref.items;
|
|
42330
42322
|
var tooltipRef = React.useRef(null);
|
|
42331
42323
|
var _useState = React.useState({
|
|
42332
42324
|
left: tooltipLeft
|
|
@@ -42375,7 +42367,7 @@ var Tooltip$1 = function Tooltip(_ref) {
|
|
|
42375
42367
|
fontSize: '15px',
|
|
42376
42368
|
width: '100%',
|
|
42377
42369
|
minWidth: MIN_TOOLTIP_WIDTH
|
|
42378
|
-
}, ";label:Tooltip;", "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
42370
|
+
}, ";label:Tooltip;", "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlRvb2x0aXAudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTBGcUIiLCJmaWxlIjoiVG9vbHRpcC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgQ1NTUHJvcGVydGllcywgRnJhZ21lbnQsIHVzZUVmZmVjdCwgdXNlUmVmLCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IGNyZWF0ZVBvcnRhbCB9IGZyb20gJ3JlYWN0LWRvbSc7XG5cbmltcG9ydCB7IGdldENvbG9yIH0gZnJvbSAnLi4vLi4vdXRpbHMnO1xuaW1wb3J0IHsgTGVnZW5kSXRlbUJveCB9IGZyb20gJy4uL0xlZ2VuZC9MZWdlbmRJdGVtQm94JztcbmltcG9ydCB7IFNoYXBlRGVmaW5pdGlvbiwgQ29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZSwgRGF0YUl0ZW0sIEtleSB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQ2hhcnRzVjIvdHlwZXMnO1xuaW1wb3J0IHsgTGluZVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvTGluZUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQmFyU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9CYXJDaGFydFYyL3R5cGVzJztcbmltcG9ydCB7IEFyZWFTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0FyZWFDaGFydFYyL3R5cGVzJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5cbmNvbnN0IE1JTl9UT09MVElQX1dJRFRIID0gMTgwO1xuY29uc3QgVE9PTFRJUF9PRkZTRVQgPSAyMDtcbmNvbnN0IFNDUk9MTEJBUl9XSURUSCA9IDQwO1xuXG5pbnRlcmZhY2UgVG9vbHRpcFByb3BzPFQ+IHtcbiAga2V5czogeyBba2V5OiBzdHJpbmddOiBLZXkgfTtcbiAgc2hvd1JvdW5kZWRUb3RhbDogYm9vbGVhbjtcbiAgdG9vbHRpcERhdGE6IHtcbiAgICBba2V5SWQ6IHN0cmluZ106IERhdGFJdGVtO1xuICB9O1xuICB0b29sdGlwTGVmdDogbnVtYmVyO1xuICB0b29sdGlwVG9wOiBudW1iZXI7XG4gIHhLZXk6IHN0cmluZztcbiAgeUtleXM6IHN0cmluZ1tdO1xuICBpdGVtczoge1xuICAgIGxlZ2VuZEl0ZW1zOiBBcnJheTxTaGFwZURlZmluaXRpb248VD4+O1xuICAgIGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzOiBBcnJheTxDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlPjtcbiAgICB2aXNpYmxlWUtleXM6IHN0cmluZ1tdO1xuICB9W107XG4gIHRoZW1lOiBDU1NQcm9wZXJ0aWVzO1xufVxuXG5leHBvcnQgY29uc3QgVG9vbHRpcCA9ICh7XG4gIGtleXMsXG4gIHNob3dSb3VuZGVkVG90YWwsXG4gIHRvb2x0aXBEYXRhLFxuICB0b29sdGlwTGVmdCxcbiAgdG9vbHRpcFRvcCxcbiAgeEtleSxcbiAgeUtleXMsXG4gIHRoZW1lLFxuICBpdGVtcyxcbn06IFRvb2x0aXBQcm9wczxMaW5lU3R5bGVzIHwgQmFyU3R5bGVzIHwgQXJlYVN0eWxlcz4pID0+IHtcbiAgY29uc3QgdG9vbHRpcFJlZiA9IHVzZVJlZjxIVE1MRGl2RWxlbWVudD4obnVsbCk7XG4gIGNvbnN0IFtwb3NpdGlvbiwgc2V0UG9zaXRpb25dID0gdXNlU3RhdGU8eyBsZWZ0OiBudW1iZXIgfT4oe1xuICAgIGxlZnQ6IHRvb2x0aXBMZWZ0LFxuICB9KTtcblxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGNvbnN0IGFkanVzdFRvb2x0aXBQb3NpdGlvbiA9ICgpID0+IHtcbiAgICAgIGNvbnN0IHRvb2x0aXBFbGVtZW50ID0gdG9vbHRpcFJlZi5jdXJyZW50O1xuXG4gICAgICBpZiAodG9vbHRpcEVsZW1lbnQpIHtcbiAgICAgICAgY29uc3Qgc2NyZWVuV2lkdGggPSB3aW5kb3cuaW5uZXJXaWR0aDtcblxuICAgICAgICBjb25zdCByZWN0ID0gdG9vbHRpcEVsZW1lbnQuZ2V0Qm91bmRpbmdDbGllbnRSZWN0KCk7XG5cbiAgICAgICAgbGV0IHdpZHRoID0gcmVjdC53aWR0aDtcblxuICAgICAgICBpZiAod2lkdGggPCBNSU5fVE9PTFRJUF9XSURUSCkge1xuICAgICAgICAgIHdpZHRoID0gTUlOX1RPT0xUSVBfV0lEVEg7XG4gICAgICAgIH1cblxuICAgICAgICBsZXQgbGVmdCA9IHRvb2x0aXBMZWZ0ICsgVE9PTFRJUF9PRkZTRVQ7XG5cbiAgICAgICAgaWYgKHRvb2x0aXBMZWZ0ICsgd2lkdGggPiBzY3JlZW5XaWR0aCAtIFNDUk9MTEJBUl9XSURUSCkge1xuICAgICAgICAgIGxlZnQgPSB0b29sdGlwTGVmdCAtIHdpZHRoIC0gVE9PTFRJUF9PRkZTRVQ7XG4gICAgICAgIH1cblxuICAgICAgICBzZXRQb3NpdGlvbih7IGxlZnQgfSk7XG4gICAgICB9XG4gICAgfTtcblxuICAgIGFkanVzdFRvb2x0aXBQb3NpdGlvbigpO1xuICB9LCBbdG9vbHRpcExlZnRdKTtcblxuICByZXR1cm4gY3JlYXRlUG9ydGFsKFxuICAgIDxkaXZcbiAgICAgIHJlZj17dG9vbHRpcFJlZn1cbiAgICAgIHN0eWxlPXt7XG4gICAgICAgIHBvc2l0aW9uOiAnYWJzb2x1dGUnLFxuICAgICAgICBsZWZ0OiBwb3NpdGlvbi5sZWZ0LFxuICAgICAgICB0b3A6IHRvb2x0aXBUb3AsXG4gICAgICAgIHpJbmRleDogMjE0NzQ4MzY0NyAqIDEwLFxuICAgICAgICAuLi50aGVtZSxcbiAgICAgIH19XG4gICAgPlxuICAgICAgPGRpdiBzdHlsZT17eyB3b3JkQnJlYWs6ICdicmVhay1hbGwnIH19PlxuICAgICAgICA8ZGl2XG4gICAgICAgICAgY2xhc3NOYW1lPXtjc3Moe1xuICAgICAgICAgICAgZm9udEZhbWlseTogJ2luaGVyaXQnLFxuICAgICAgICAgICAgbGluZUhlaWdodDogJ2luaGVyaXQnLFxuICAgICAgICAgICAgbGV0dGVyU3BhY2luZzogJ2luaGVyaXQnLFxuICAgICAgICAgICAgZm9udFdlaWdodDogJ2JvbGQnLFxuICAgICAgICAgICAgZm9udFNpemU6ICcxNXB4JyxcbiAgICAgICAgICAgIHdpZHRoOiAnMTAwJScsXG4gICAgICAgICAgICBtaW5XaWR0aDogTUlOX1RPT0xUSVBfV0lEVEgsXG4gICAgICAgICAgfSl9XG4gICAgICAgID5cbiAgICAgICAgICB7dG9vbHRpcERhdGFbeEtleV0uZm9ybWF0dGVkVmFsdWUgPz8gdG9vbHRpcERhdGFbeEtleV0udmFsdWV9XG4gICAgICAgIDwvZGl2PlxuICAgICAgICA8dGFibGVcbiAgICAgICAgICBjZWxsUGFkZGluZz17MH1cbiAgICAgICAgICBjZWxsU3BhY2luZz17MH1cbiAgICAgICAgICBjbGFzc05hbWU9e2Nzcyh7XG4gICAgICAgICAgICBtYXJnaW46ICcwJyxcbiAgICAgICAgICAgIGJvcmRlclNwYWNpbmc6ICcwJyxcbiAgICAgICAgICAgIGJvcmRlckNvbGxhcHNlOiAnaW5oZXJpdCcsXG4gICAgICAgICAgICBib3JkZXI6ICdub25lJyxcbiAgICAgICAgICB9KX1cbiAgICAgICAgPlxuICAgICAgICAgIDx0Ym9keT5cbiAgICAgICAgICAgIHtpdGVtcy5tYXAoKGl0ZW0sIGluZGV4KSA9PiB7XG4gICAgICAgICAgICAgIHJldHVybiAoXG4gICAgICAgICAgICAgICAgPEZyYWdtZW50IGtleT17aW5kZXh9PlxuICAgICAgICAgICAgICAgICAge2l0ZW0ubGVnZW5kSXRlbXM/Lm1hcCgobGVnZW5kSXRlbSwgaW5kZXgpID0+IHtcbiAgICAgICAgICAgICAgICAgICAgaWYgKCF0b29sdGlwRGF0YVtsZWdlbmRJdGVtLnlLZXldIHx8IHRvb2x0aXBEYXRhW2xlZ2VuZEl0ZW0ueUtleV0udmFsdWUgPT09IG51bGwpIHtcbiAgICAgICAgICAgICAgICAgICAgICAvLyB5S2V5IGNvdWxkIG5vdCBiZSBmb3VuZCBpbiB0b29sdGlwRGF0YVxuICAgICAgICAgICAgICAgICAgICAgIHJldHVybiBudWxsO1xuICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICAgIHJldHVybiAoXG4gICAgICAgICAgICAgICAgICAgICAgaXRlbS52aXNpYmxlWUtleXM/LmluY2x1ZGVzKGxlZ2VuZEl0ZW0ueUtleSkgJiYgKFxuICAgICAgICAgICAgICAgICAgICAgICAgPHRyIGtleT17bGVnZW5kSXRlbS55S2V5fT5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgPHRkXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgc3R5bGU9e3tcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHZlcnRpY2FsQWxpZ246ICdtaWRkbGUnLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgcGFkZGluZzogaW5kZXggPT09IDAgPyAnMTJweCA4cHggMCAwJyA6ICc4cHggOHB4IDAgMCcsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICB3aWR0aDogJ2F1dG8nLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIH19XG4gICAgICAgICAgICAgICAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICA8TGVnZW5kSXRlbUJveFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgY29sb3I9e2dldENvbG9yKHtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgZGVmYXVsdENvbG9yOiBsZWdlbmRJdGVtLmNvbG9yLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB2YWx1ZTogdG9vbHRpcERhdGFbbGVnZW5kSXRlbS55S2V5XS52YWx1ZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgeUtleTogbGVnZW5kSXRlbS55S2V5LFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlczogaXRlbS5jb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlcyA/PyBbXSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIH0pfVxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgc3R5bGU9e2xlZ2VuZEl0ZW0uc3R5bGUgYXMgTGluZVN0eWxlc31cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHlLZXk9e2xlZ2VuZEl0ZW0ueUtleX1cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgICAgICAgICAgICAgICA8L3RkPlxuICAgICAgICAgICAgICAgICAgICAgICAgICA8dGQgc3R5bGU9e3sgcGFkZGluZzogJzhweCAwIDAgMCcgfX0+e2tleXNbbGVnZW5kSXRlbS55S2V5XS5rZXlGb3JtYXR0ZWR9PC90ZD5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgPHRkIHN0eWxlPXt7IGZvbnRXZWlnaHQ6ICdib2xkJywgcGFkZGluZzogJzhweCAwIDAgMTZweCcgfX0+XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAge3Rvb2x0aXBEYXRhW2xlZ2VuZEl0ZW0ueUtleV0uZm9ybWF0dGVkVmFsdWVcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgID8gdG9vbHRpcERhdGFbbGVnZW5kSXRlbS55S2V5XS5mb3JtYXR0ZWRWYWx1ZVxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgOiB0b29sdGlwRGF0YVtsZWdlbmRJdGVtLnlLZXldLnZhbHVlfVxuICAgICAgICAgICAgICAgICAgICAgICAgICA8L3RkPlxuICAgICAgICAgICAgICAgICAgICAgICAgPC90cj5cbiAgICAgICAgICAgICAgICAgICAgICApXG4gICAgICAgICAgICAgICAgICAgICk7XG4gICAgICAgICAgICAgICAgICB9KX1cbiAgICAgICAgICAgICAgICA8L0ZyYWdtZW50PlxuICAgICAgICAgICAgICApO1xuICAgICAgICAgICAgfSl9XG5cbiAgICAgICAgICAgIHtzaG93Um91bmRlZFRvdGFsICYmIChcbiAgICAgICAgICAgICAgPHRyPlxuICAgICAgICAgICAgICAgIDx0ZCBjb2xTcGFuPXsyfSBzdHlsZT17eyBwYWRkaW5nOiAnMTJweCAwIDAgMCcgfX0+XG4gICAgICAgICAgICAgICAgICBSb3VuZGVkIFRvdGFsXG4gICAgICAgICAgICAgICAgPC90ZD5cbiAgICAgICAgICAgICAgICA8dGQgc3R5bGU9e3sgZm9udFdlaWdodDogJ2JvbGQnLCBwYWRkaW5nOiAnMTJweCAwIDAgMTZweCcgfX0+XG4gICAgICAgICAgICAgICAgICB7eUtleXMucmVkdWNlKCh0b3RhbCwga2V5KSA9PiB7XG4gICAgICAgICAgICAgICAgICAgIHJldHVybiB0b3RhbCArIE1hdGgucm91bmQodG9vbHRpcERhdGFba2V5XS52YWx1ZSBhcyBudW1iZXIpO1xuICAgICAgICAgICAgICAgICAgfSwgMCl9XG4gICAgICAgICAgICAgICAgPC90ZD5cbiAgICAgICAgICAgICAgPC90cj5cbiAgICAgICAgICAgICl9XG4gICAgICAgICAgPC90Ym9keT5cbiAgICAgICAgPC90YWJsZT5cbiAgICAgIDwvZGl2PlxuICAgIDwvZGl2PixcbiAgICBkb2N1bWVudC5ib2R5XG4gICk7XG59O1xuIl19 */"),
|
|
42379
42371
|
children: (_tooltipData$xKey$for = tooltipData[xKey].formattedValue) != null ? _tooltipData$xKey$for : tooltipData[xKey].value
|
|
42380
42372
|
}), jsxRuntime.jsx("table", {
|
|
42381
42373
|
cellPadding: 0,
|
|
@@ -42383,45 +42375,51 @@ var Tooltip$1 = function Tooltip(_ref) {
|
|
|
42383
42375
|
className: /*#__PURE__*/css$1.css( {
|
|
42384
42376
|
name: "9a1sa-Tooltip",
|
|
42385
42377
|
styles: "margin:0;border-spacing:0;border-collapse:inherit;border:none;label:Tooltip;",
|
|
42386
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
42378
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlRvb2x0aXAudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXlHcUIiLCJmaWxlIjoiVG9vbHRpcC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgQ1NTUHJvcGVydGllcywgRnJhZ21lbnQsIHVzZUVmZmVjdCwgdXNlUmVmLCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IGNyZWF0ZVBvcnRhbCB9IGZyb20gJ3JlYWN0LWRvbSc7XG5cbmltcG9ydCB7IGdldENvbG9yIH0gZnJvbSAnLi4vLi4vdXRpbHMnO1xuaW1wb3J0IHsgTGVnZW5kSXRlbUJveCB9IGZyb20gJy4uL0xlZ2VuZC9MZWdlbmRJdGVtQm94JztcbmltcG9ydCB7IFNoYXBlRGVmaW5pdGlvbiwgQ29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZSwgRGF0YUl0ZW0sIEtleSB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQ2hhcnRzVjIvdHlwZXMnO1xuaW1wb3J0IHsgTGluZVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvTGluZUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQmFyU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9CYXJDaGFydFYyL3R5cGVzJztcbmltcG9ydCB7IEFyZWFTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0FyZWFDaGFydFYyL3R5cGVzJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5cbmNvbnN0IE1JTl9UT09MVElQX1dJRFRIID0gMTgwO1xuY29uc3QgVE9PTFRJUF9PRkZTRVQgPSAyMDtcbmNvbnN0IFNDUk9MTEJBUl9XSURUSCA9IDQwO1xuXG5pbnRlcmZhY2UgVG9vbHRpcFByb3BzPFQ+IHtcbiAga2V5czogeyBba2V5OiBzdHJpbmddOiBLZXkgfTtcbiAgc2hvd1JvdW5kZWRUb3RhbDogYm9vbGVhbjtcbiAgdG9vbHRpcERhdGE6IHtcbiAgICBba2V5SWQ6IHN0cmluZ106IERhdGFJdGVtO1xuICB9O1xuICB0b29sdGlwTGVmdDogbnVtYmVyO1xuICB0b29sdGlwVG9wOiBudW1iZXI7XG4gIHhLZXk6IHN0cmluZztcbiAgeUtleXM6IHN0cmluZ1tdO1xuICBpdGVtczoge1xuICAgIGxlZ2VuZEl0ZW1zOiBBcnJheTxTaGFwZURlZmluaXRpb248VD4+O1xuICAgIGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzOiBBcnJheTxDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlPjtcbiAgICB2aXNpYmxlWUtleXM6IHN0cmluZ1tdO1xuICB9W107XG4gIHRoZW1lOiBDU1NQcm9wZXJ0aWVzO1xufVxuXG5leHBvcnQgY29uc3QgVG9vbHRpcCA9ICh7XG4gIGtleXMsXG4gIHNob3dSb3VuZGVkVG90YWwsXG4gIHRvb2x0aXBEYXRhLFxuICB0b29sdGlwTGVmdCxcbiAgdG9vbHRpcFRvcCxcbiAgeEtleSxcbiAgeUtleXMsXG4gIHRoZW1lLFxuICBpdGVtcyxcbn06IFRvb2x0aXBQcm9wczxMaW5lU3R5bGVzIHwgQmFyU3R5bGVzIHwgQXJlYVN0eWxlcz4pID0+IHtcbiAgY29uc3QgdG9vbHRpcFJlZiA9IHVzZVJlZjxIVE1MRGl2RWxlbWVudD4obnVsbCk7XG4gIGNvbnN0IFtwb3NpdGlvbiwgc2V0UG9zaXRpb25dID0gdXNlU3RhdGU8eyBsZWZ0OiBudW1iZXIgfT4oe1xuICAgIGxlZnQ6IHRvb2x0aXBMZWZ0LFxuICB9KTtcblxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGNvbnN0IGFkanVzdFRvb2x0aXBQb3NpdGlvbiA9ICgpID0+IHtcbiAgICAgIGNvbnN0IHRvb2x0aXBFbGVtZW50ID0gdG9vbHRpcFJlZi5jdXJyZW50O1xuXG4gICAgICBpZiAodG9vbHRpcEVsZW1lbnQpIHtcbiAgICAgICAgY29uc3Qgc2NyZWVuV2lkdGggPSB3aW5kb3cuaW5uZXJXaWR0aDtcblxuICAgICAgICBjb25zdCByZWN0ID0gdG9vbHRpcEVsZW1lbnQuZ2V0Qm91bmRpbmdDbGllbnRSZWN0KCk7XG5cbiAgICAgICAgbGV0IHdpZHRoID0gcmVjdC53aWR0aDtcblxuICAgICAgICBpZiAod2lkdGggPCBNSU5fVE9PTFRJUF9XSURUSCkge1xuICAgICAgICAgIHdpZHRoID0gTUlOX1RPT0xUSVBfV0lEVEg7XG4gICAgICAgIH1cblxuICAgICAgICBsZXQgbGVmdCA9IHRvb2x0aXBMZWZ0ICsgVE9PTFRJUF9PRkZTRVQ7XG5cbiAgICAgICAgaWYgKHRvb2x0aXBMZWZ0ICsgd2lkdGggPiBzY3JlZW5XaWR0aCAtIFNDUk9MTEJBUl9XSURUSCkge1xuICAgICAgICAgIGxlZnQgPSB0b29sdGlwTGVmdCAtIHdpZHRoIC0gVE9PTFRJUF9PRkZTRVQ7XG4gICAgICAgIH1cblxuICAgICAgICBzZXRQb3NpdGlvbih7IGxlZnQgfSk7XG4gICAgICB9XG4gICAgfTtcblxuICAgIGFkanVzdFRvb2x0aXBQb3NpdGlvbigpO1xuICB9LCBbdG9vbHRpcExlZnRdKTtcblxuICByZXR1cm4gY3JlYXRlUG9ydGFsKFxuICAgIDxkaXZcbiAgICAgIHJlZj17dG9vbHRpcFJlZn1cbiAgICAgIHN0eWxlPXt7XG4gICAgICAgIHBvc2l0aW9uOiAnYWJzb2x1dGUnLFxuICAgICAgICBsZWZ0OiBwb3NpdGlvbi5sZWZ0LFxuICAgICAgICB0b3A6IHRvb2x0aXBUb3AsXG4gICAgICAgIHpJbmRleDogMjE0NzQ4MzY0NyAqIDEwLFxuICAgICAgICAuLi50aGVtZSxcbiAgICAgIH19XG4gICAgPlxuICAgICAgPGRpdiBzdHlsZT17eyB3b3JkQnJlYWs6ICdicmVhay1hbGwnIH19PlxuICAgICAgICA8ZGl2XG4gICAgICAgICAgY2xhc3NOYW1lPXtjc3Moe1xuICAgICAgICAgICAgZm9udEZhbWlseTogJ2luaGVyaXQnLFxuICAgICAgICAgICAgbGluZUhlaWdodDogJ2luaGVyaXQnLFxuICAgICAgICAgICAgbGV0dGVyU3BhY2luZzogJ2luaGVyaXQnLFxuICAgICAgICAgICAgZm9udFdlaWdodDogJ2JvbGQnLFxuICAgICAgICAgICAgZm9udFNpemU6ICcxNXB4JyxcbiAgICAgICAgICAgIHdpZHRoOiAnMTAwJScsXG4gICAgICAgICAgICBtaW5XaWR0aDogTUlOX1RPT0xUSVBfV0lEVEgsXG4gICAgICAgICAgfSl9XG4gICAgICAgID5cbiAgICAgICAgICB7dG9vbHRpcERhdGFbeEtleV0uZm9ybWF0dGVkVmFsdWUgPz8gdG9vbHRpcERhdGFbeEtleV0udmFsdWV9XG4gICAgICAgIDwvZGl2PlxuICAgICAgICA8dGFibGVcbiAgICAgICAgICBjZWxsUGFkZGluZz17MH1cbiAgICAgICAgICBjZWxsU3BhY2luZz17MH1cbiAgICAgICAgICBjbGFzc05hbWU9e2Nzcyh7XG4gICAgICAgICAgICBtYXJnaW46ICcwJyxcbiAgICAgICAgICAgIGJvcmRlclNwYWNpbmc6ICcwJyxcbiAgICAgICAgICAgIGJvcmRlckNvbGxhcHNlOiAnaW5oZXJpdCcsXG4gICAgICAgICAgICBib3JkZXI6ICdub25lJyxcbiAgICAgICAgICB9KX1cbiAgICAgICAgPlxuICAgICAgICAgIDx0Ym9keT5cbiAgICAgICAgICAgIHtpdGVtcy5tYXAoKGl0ZW0sIGluZGV4KSA9PiB7XG4gICAgICAgICAgICAgIHJldHVybiAoXG4gICAgICAgICAgICAgICAgPEZyYWdtZW50IGtleT17aW5kZXh9PlxuICAgICAgICAgICAgICAgICAge2l0ZW0ubGVnZW5kSXRlbXM/Lm1hcCgobGVnZW5kSXRlbSwgaW5kZXgpID0+IHtcbiAgICAgICAgICAgICAgICAgICAgaWYgKCF0b29sdGlwRGF0YVtsZWdlbmRJdGVtLnlLZXldIHx8IHRvb2x0aXBEYXRhW2xlZ2VuZEl0ZW0ueUtleV0udmFsdWUgPT09IG51bGwpIHtcbiAgICAgICAgICAgICAgICAgICAgICAvLyB5S2V5IGNvdWxkIG5vdCBiZSBmb3VuZCBpbiB0b29sdGlwRGF0YVxuICAgICAgICAgICAgICAgICAgICAgIHJldHVybiBudWxsO1xuICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICAgIHJldHVybiAoXG4gICAgICAgICAgICAgICAgICAgICAgaXRlbS52aXNpYmxlWUtleXM/LmluY2x1ZGVzKGxlZ2VuZEl0ZW0ueUtleSkgJiYgKFxuICAgICAgICAgICAgICAgICAgICAgICAgPHRyIGtleT17bGVnZW5kSXRlbS55S2V5fT5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgPHRkXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgc3R5bGU9e3tcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHZlcnRpY2FsQWxpZ246ICdtaWRkbGUnLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgcGFkZGluZzogaW5kZXggPT09IDAgPyAnMTJweCA4cHggMCAwJyA6ICc4cHggOHB4IDAgMCcsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICB3aWR0aDogJ2F1dG8nLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIH19XG4gICAgICAgICAgICAgICAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICA8TGVnZW5kSXRlbUJveFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgY29sb3I9e2dldENvbG9yKHtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgZGVmYXVsdENvbG9yOiBsZWdlbmRJdGVtLmNvbG9yLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB2YWx1ZTogdG9vbHRpcERhdGFbbGVnZW5kSXRlbS55S2V5XS52YWx1ZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgeUtleTogbGVnZW5kSXRlbS55S2V5LFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlczogaXRlbS5jb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlcyA/PyBbXSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIH0pfVxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgc3R5bGU9e2xlZ2VuZEl0ZW0uc3R5bGUgYXMgTGluZVN0eWxlc31cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHlLZXk9e2xlZ2VuZEl0ZW0ueUtleX1cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgICAgICAgICAgICAgICA8L3RkPlxuICAgICAgICAgICAgICAgICAgICAgICAgICA8dGQgc3R5bGU9e3sgcGFkZGluZzogJzhweCAwIDAgMCcgfX0+e2tleXNbbGVnZW5kSXRlbS55S2V5XS5rZXlGb3JtYXR0ZWR9PC90ZD5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgPHRkIHN0eWxlPXt7IGZvbnRXZWlnaHQ6ICdib2xkJywgcGFkZGluZzogJzhweCAwIDAgMTZweCcgfX0+XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAge3Rvb2x0aXBEYXRhW2xlZ2VuZEl0ZW0ueUtleV0uZm9ybWF0dGVkVmFsdWVcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgID8gdG9vbHRpcERhdGFbbGVnZW5kSXRlbS55S2V5XS5mb3JtYXR0ZWRWYWx1ZVxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgOiB0b29sdGlwRGF0YVtsZWdlbmRJdGVtLnlLZXldLnZhbHVlfVxuICAgICAgICAgICAgICAgICAgICAgICAgICA8L3RkPlxuICAgICAgICAgICAgICAgICAgICAgICAgPC90cj5cbiAgICAgICAgICAgICAgICAgICAgICApXG4gICAgICAgICAgICAgICAgICAgICk7XG4gICAgICAgICAgICAgICAgICB9KX1cbiAgICAgICAgICAgICAgICA8L0ZyYWdtZW50PlxuICAgICAgICAgICAgICApO1xuICAgICAgICAgICAgfSl9XG5cbiAgICAgICAgICAgIHtzaG93Um91bmRlZFRvdGFsICYmIChcbiAgICAgICAgICAgICAgPHRyPlxuICAgICAgICAgICAgICAgIDx0ZCBjb2xTcGFuPXsyfSBzdHlsZT17eyBwYWRkaW5nOiAnMTJweCAwIDAgMCcgfX0+XG4gICAgICAgICAgICAgICAgICBSb3VuZGVkIFRvdGFsXG4gICAgICAgICAgICAgICAgPC90ZD5cbiAgICAgICAgICAgICAgICA8dGQgc3R5bGU9e3sgZm9udFdlaWdodDogJ2JvbGQnLCBwYWRkaW5nOiAnMTJweCAwIDAgMTZweCcgfX0+XG4gICAgICAgICAgICAgICAgICB7eUtleXMucmVkdWNlKCh0b3RhbCwga2V5KSA9PiB7XG4gICAgICAgICAgICAgICAgICAgIHJldHVybiB0b3RhbCArIE1hdGgucm91bmQodG9vbHRpcERhdGFba2V5XS52YWx1ZSBhcyBudW1iZXIpO1xuICAgICAgICAgICAgICAgICAgfSwgMCl9XG4gICAgICAgICAgICAgICAgPC90ZD5cbiAgICAgICAgICAgICAgPC90cj5cbiAgICAgICAgICAgICl9XG4gICAgICAgICAgPC90Ym9keT5cbiAgICAgICAgPC90YWJsZT5cbiAgICAgIDwvZGl2PlxuICAgIDwvZGl2PixcbiAgICBkb2N1bWVudC5ib2R5XG4gICk7XG59O1xuIl19 */",
|
|
42387
42379
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$5
|
|
42388
42380
|
}),
|
|
42389
42381
|
children: jsxRuntime.jsxs("tbody", {
|
|
42390
|
-
children: [
|
|
42391
|
-
|
|
42392
|
-
|
|
42393
|
-
|
|
42394
|
-
|
|
42395
|
-
|
|
42396
|
-
|
|
42397
|
-
|
|
42398
|
-
|
|
42399
|
-
|
|
42400
|
-
|
|
42401
|
-
|
|
42402
|
-
|
|
42403
|
-
|
|
42404
|
-
|
|
42405
|
-
|
|
42406
|
-
|
|
42407
|
-
|
|
42408
|
-
|
|
42409
|
-
|
|
42410
|
-
|
|
42411
|
-
|
|
42412
|
-
|
|
42413
|
-
|
|
42414
|
-
|
|
42415
|
-
|
|
42416
|
-
|
|
42417
|
-
|
|
42418
|
-
|
|
42419
|
-
|
|
42420
|
-
|
|
42421
|
-
|
|
42422
|
-
|
|
42423
|
-
|
|
42424
|
-
|
|
42382
|
+
children: [items.map(function (item, index) {
|
|
42383
|
+
var _item$legendItems;
|
|
42384
|
+
return jsxRuntime.jsx(React.Fragment, {
|
|
42385
|
+
children: (_item$legendItems = item.legendItems) == null ? void 0 : _item$legendItems.map(function (legendItem, index) {
|
|
42386
|
+
var _item$visibleYKeys, _item$conditionalForm;
|
|
42387
|
+
if (!tooltipData[legendItem.yKey] || tooltipData[legendItem.yKey].value === null) {
|
|
42388
|
+
// yKey could not be found in tooltipData
|
|
42389
|
+
return null;
|
|
42390
|
+
}
|
|
42391
|
+
return ((_item$visibleYKeys = item.visibleYKeys) == null ? void 0 : _item$visibleYKeys.includes(legendItem.yKey)) && jsxRuntime.jsxs("tr", {
|
|
42392
|
+
children: [jsxRuntime.jsx("td", {
|
|
42393
|
+
style: {
|
|
42394
|
+
verticalAlign: 'middle',
|
|
42395
|
+
padding: index === 0 ? '12px 8px 0 0' : '8px 8px 0 0',
|
|
42396
|
+
width: 'auto'
|
|
42397
|
+
},
|
|
42398
|
+
children: jsxRuntime.jsx(LegendItemBox, {
|
|
42399
|
+
color: getColor({
|
|
42400
|
+
defaultColor: legendItem.color,
|
|
42401
|
+
value: tooltipData[legendItem.yKey].value,
|
|
42402
|
+
yKey: legendItem.yKey,
|
|
42403
|
+
conditionalFormattingRules: (_item$conditionalForm = item.conditionalFormattingRules) != null ? _item$conditionalForm : []
|
|
42404
|
+
}),
|
|
42405
|
+
style: legendItem.style,
|
|
42406
|
+
yKey: legendItem.yKey
|
|
42407
|
+
})
|
|
42408
|
+
}), jsxRuntime.jsx("td", {
|
|
42409
|
+
style: {
|
|
42410
|
+
padding: '8px 0 0 0'
|
|
42411
|
+
},
|
|
42412
|
+
children: keys[legendItem.yKey].keyFormatted
|
|
42413
|
+
}), jsxRuntime.jsx("td", {
|
|
42414
|
+
style: {
|
|
42415
|
+
fontWeight: 'bold',
|
|
42416
|
+
padding: '8px 0 0 16px'
|
|
42417
|
+
},
|
|
42418
|
+
children: tooltipData[legendItem.yKey].formattedValue ? tooltipData[legendItem.yKey].formattedValue : tooltipData[legendItem.yKey].value
|
|
42419
|
+
})]
|
|
42420
|
+
}, legendItem.yKey);
|
|
42421
|
+
})
|
|
42422
|
+
}, index);
|
|
42425
42423
|
}), showRoundedTotal && jsxRuntime.jsxs("tr", {
|
|
42426
42424
|
children: [jsxRuntime.jsx("td", {
|
|
42427
42425
|
colSpan: 2,
|
|
@@ -42535,16 +42533,14 @@ var LegendItem = function LegendItem(_ref) {
|
|
|
42535
42533
|
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)."; }
|
|
42536
42534
|
var Legend$1 = function Legend(_ref) {
|
|
42537
42535
|
var keys = _ref.keys,
|
|
42538
|
-
visibleYKeys = _ref.visibleYKeys,
|
|
42539
|
-
legendItems = _ref.legendItems,
|
|
42540
42536
|
setVisibleYKeys = _ref.setVisibleYKeys,
|
|
42541
|
-
|
|
42542
|
-
|
|
42537
|
+
marginLeft = _ref.marginLeft,
|
|
42538
|
+
items = _ref.items;
|
|
42543
42539
|
return jsxRuntime.jsx("div", {
|
|
42544
42540
|
className: /*#__PURE__*/css$1.css( {
|
|
42545
42541
|
name: "qz6h7j-Legend",
|
|
42546
42542
|
styles: "height:40px;padding-top:8px;label:Legend;",
|
|
42547
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
42543
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNEJvQiIsImZpbGUiOiJMZWdlbmQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0LCB7IEZyYWdtZW50IH0gZnJvbSAncmVhY3QnO1xuXG5pbXBvcnQgeyBMZWdlbmRJdGVtIH0gZnJvbSAnLi9MZWdlbmRJdGVtJztcbmltcG9ydCB7IFNoYXBlRGVmaW5pdGlvbiwgQ29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZSwgS2V5IH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9DaGFydHNWMi90eXBlcyc7XG5pbXBvcnQgeyBTY3JvbGxiYXIgfSBmcm9tICcuLi8uLi8uLi9TY3JvbGxiYXIvU2Nyb2xsYmFyJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBCYXJTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0JhckNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgTGluZVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvTGluZUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQXJlYVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQXJlYUNoYXJ0VjIvdHlwZXMnO1xuXG5pbnRlcmZhY2UgTGVnZW5kUHJvcHM8VD4ge1xuICBzZXRWaXNpYmxlWUtleXM/OiBSZWFjdC5EaXNwYXRjaDxSZWFjdC5TZXRTdGF0ZUFjdGlvbjxBcnJheTxzdHJpbmc+Pj47XG4gIGtleXM6IHsgW2tleTogc3RyaW5nXTogS2V5IH07XG4gIG1hcmdpbkxlZnQ6IG51bWJlcjtcbiAgaXRlbXM/OiB7XG4gICAgbGVnZW5kSXRlbXM6IEFycmF5PFNoYXBlRGVmaW5pdGlvbjxUPj47XG4gICAgdmlzaWJsZVlLZXlzOiBBcnJheTxzdHJpbmc+O1xuICAgIGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzOiBBcnJheTxDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlPjtcbiAgfVtdO1xufVxuXG5leHBvcnQgY29uc3QgTGVnZW5kID0gKHtcbiAga2V5cyxcbiAgc2V0VmlzaWJsZVlLZXlzLFxuICBtYXJnaW5MZWZ0LFxuICBpdGVtcyxcbn06IExlZ2VuZFByb3BzPEJhclN0eWxlcyB8IExpbmVTdHlsZXMgfCBBcmVhU3R5bGVzPikgPT4ge1xuICByZXR1cm4gKFxuICAgIDxkaXYgY2xhc3NOYW1lPXtjc3MoeyBoZWlnaHQ6IDQwLCBwYWRkaW5nVG9wOiA4IH0pfT5cbiAgICAgIDxTY3JvbGxiYXJcbiAgICAgICAgY2xhc3NOYW1lPXtjc3Moe1xuICAgICAgICAgIGRpc3BsYXk6ICdmbGV4JyxcbiAgICAgICAgICBmbGV4RGlyZWN0aW9uOiAncm93JyxcbiAgICAgICAgICBmbGV4V3JhcDogJ25vd3JhcCcsXG4gICAgICAgICAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG4gICAgICAgICAgbWFyZ2luTGVmdDogbWFyZ2luTGVmdCA/IGAke21hcmdpbkxlZnR9cHhgIDogdW5kZWZpbmVkLFxuICAgICAgICB9KX1cbiAgICAgICAgeD17dHJ1ZX1cbiAgICAgID5cbiAgICAgICAge2l0ZW1zPy5tYXAoKGl0ZW0sIGluZGV4KSA9PiAoXG4gICAgICAgICAgPEZyYWdtZW50IGtleT17aW5kZXh9PlxuICAgICAgICAgICAge2l0ZW0ubGVnZW5kSXRlbXM/Lm1hcChcbiAgICAgICAgICAgICAgbGVnZW5kSXRlbSA9PlxuICAgICAgICAgICAgICAgIGtleXNbbGVnZW5kSXRlbS55S2V5XSAmJiAoXG4gICAgICAgICAgICAgICAgICA8TGVnZW5kSXRlbVxuICAgICAgICAgICAgICAgICAgICB7Li4ubGVnZW5kSXRlbX1cbiAgICAgICAgICAgICAgICAgICAga2V5PXtgbGVnZW5kLSR7bGVnZW5kSXRlbS55S2V5fWB9XG4gICAgICAgICAgICAgICAgICAgIHlLZXlGb3JtYXR0ZWQ9e2tleXNbbGVnZW5kSXRlbS55S2V5XS5rZXlGb3JtYXR0ZWR9XG4gICAgICAgICAgICAgICAgICAgIG9uQ2xpY2s9eygpID0+XG4gICAgICAgICAgICAgICAgICAgICAgc2V0VmlzaWJsZVlLZXlzICYmXG4gICAgICAgICAgICAgICAgICAgICAgc2V0VmlzaWJsZVlLZXlzKHByZXYgPT4ge1xuICAgICAgICAgICAgICAgICAgICAgICAgbGV0IG5ld1Zpc2libGVMZWdlbmRJdGVtczogQXJyYXk8c3RyaW5nPiA9IFtdO1xuXG4gICAgICAgICAgICAgICAgICAgICAgICBpZiAocHJldi5sZW5ndGggPT09IGl0ZW0ubGVnZW5kSXRlbXMubGVuZ3RoKSB7XG4gICAgICAgICAgICAgICAgICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IFtsZWdlbmRJdGVtLnlLZXldO1xuICAgICAgICAgICAgICAgICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgaWYgKHByZXYuaW5jbHVkZXMobGVnZW5kSXRlbS55S2V5KSkge1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IHByZXYuZmlsdGVyKFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgcHJldkxlZ2VuZEl0ZW1JZCA9PiBwcmV2TGVnZW5kSXRlbUlkICE9PSBsZWdlbmRJdGVtLnlLZXlcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICApO1xuICAgICAgICAgICAgICAgICAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IFsuLi5wcmV2LCBsZWdlbmRJdGVtLnlLZXldO1xuICAgICAgICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICAgICAgICB9XG5cbiAgICAgICAgICAgICAgICAgICAgICAgIHJldHVybiBuZXdWaXNpYmxlTGVnZW5kSXRlbXMubGVuZ3RoID09PSAwXG4gICAgICAgICAgICAgICAgICAgICAgICAgID8gaXRlbS5sZWdlbmRJdGVtcy5tYXAobGVnZW5kSXRlbSA9PiBsZWdlbmRJdGVtLnlLZXkpXG4gICAgICAgICAgICAgICAgICAgICAgICAgIDogbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zO1xuICAgICAgICAgICAgICAgICAgICAgIH0pXG4gICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICAgICAgdmlzaWJsZT17c2V0VmlzaWJsZVlLZXlzID8gaXRlbS52aXNpYmxlWUtleXMuaW5jbHVkZXMobGVnZW5kSXRlbS55S2V5KSA6IHRydWV9XG4gICAgICAgICAgICAgICAgICAgIGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzPXtpdGVtLmNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzfVxuICAgICAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgICAgICApXG4gICAgICAgICAgICApfVxuICAgICAgICAgIDwvRnJhZ21lbnQ+XG4gICAgICAgICkpfVxuICAgICAgPC9TY3JvbGxiYXI+XG4gICAgPC9kaXY+XG4gICk7XG59O1xuIl19 */",
|
|
42548
42544
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$7
|
|
42549
42545
|
}),
|
|
42550
42546
|
children: jsxRuntime.jsx(Scrollbar, {
|
|
@@ -42554,34 +42550,39 @@ var Legend$1 = function Legend(_ref) {
|
|
|
42554
42550
|
flexWrap: 'nowrap',
|
|
42555
42551
|
alignItems: 'center',
|
|
42556
42552
|
marginLeft: marginLeft ? marginLeft + "px" : undefined
|
|
42557
|
-
}, ";label:Legend;", "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
42553
|
+
}, ";label:Legend;", "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBOEJtQiIsImZpbGUiOiJMZWdlbmQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0LCB7IEZyYWdtZW50IH0gZnJvbSAncmVhY3QnO1xuXG5pbXBvcnQgeyBMZWdlbmRJdGVtIH0gZnJvbSAnLi9MZWdlbmRJdGVtJztcbmltcG9ydCB7IFNoYXBlRGVmaW5pdGlvbiwgQ29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZSwgS2V5IH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9DaGFydHNWMi90eXBlcyc7XG5pbXBvcnQgeyBTY3JvbGxiYXIgfSBmcm9tICcuLi8uLi8uLi9TY3JvbGxiYXIvU2Nyb2xsYmFyJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBCYXJTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0JhckNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgTGluZVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvTGluZUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQXJlYVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQXJlYUNoYXJ0VjIvdHlwZXMnO1xuXG5pbnRlcmZhY2UgTGVnZW5kUHJvcHM8VD4ge1xuICBzZXRWaXNpYmxlWUtleXM/OiBSZWFjdC5EaXNwYXRjaDxSZWFjdC5TZXRTdGF0ZUFjdGlvbjxBcnJheTxzdHJpbmc+Pj47XG4gIGtleXM6IHsgW2tleTogc3RyaW5nXTogS2V5IH07XG4gIG1hcmdpbkxlZnQ6IG51bWJlcjtcbiAgaXRlbXM/OiB7XG4gICAgbGVnZW5kSXRlbXM6IEFycmF5PFNoYXBlRGVmaW5pdGlvbjxUPj47XG4gICAgdmlzaWJsZVlLZXlzOiBBcnJheTxzdHJpbmc+O1xuICAgIGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzOiBBcnJheTxDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlPjtcbiAgfVtdO1xufVxuXG5leHBvcnQgY29uc3QgTGVnZW5kID0gKHtcbiAga2V5cyxcbiAgc2V0VmlzaWJsZVlLZXlzLFxuICBtYXJnaW5MZWZ0LFxuICBpdGVtcyxcbn06IExlZ2VuZFByb3BzPEJhclN0eWxlcyB8IExpbmVTdHlsZXMgfCBBcmVhU3R5bGVzPikgPT4ge1xuICByZXR1cm4gKFxuICAgIDxkaXYgY2xhc3NOYW1lPXtjc3MoeyBoZWlnaHQ6IDQwLCBwYWRkaW5nVG9wOiA4IH0pfT5cbiAgICAgIDxTY3JvbGxiYXJcbiAgICAgICAgY2xhc3NOYW1lPXtjc3Moe1xuICAgICAgICAgIGRpc3BsYXk6ICdmbGV4JyxcbiAgICAgICAgICBmbGV4RGlyZWN0aW9uOiAncm93JyxcbiAgICAgICAgICBmbGV4V3JhcDogJ25vd3JhcCcsXG4gICAgICAgICAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG4gICAgICAgICAgbWFyZ2luTGVmdDogbWFyZ2luTGVmdCA/IGAke21hcmdpbkxlZnR9cHhgIDogdW5kZWZpbmVkLFxuICAgICAgICB9KX1cbiAgICAgICAgeD17dHJ1ZX1cbiAgICAgID5cbiAgICAgICAge2l0ZW1zPy5tYXAoKGl0ZW0sIGluZGV4KSA9PiAoXG4gICAgICAgICAgPEZyYWdtZW50IGtleT17aW5kZXh9PlxuICAgICAgICAgICAge2l0ZW0ubGVnZW5kSXRlbXM/Lm1hcChcbiAgICAgICAgICAgICAgbGVnZW5kSXRlbSA9PlxuICAgICAgICAgICAgICAgIGtleXNbbGVnZW5kSXRlbS55S2V5XSAmJiAoXG4gICAgICAgICAgICAgICAgICA8TGVnZW5kSXRlbVxuICAgICAgICAgICAgICAgICAgICB7Li4ubGVnZW5kSXRlbX1cbiAgICAgICAgICAgICAgICAgICAga2V5PXtgbGVnZW5kLSR7bGVnZW5kSXRlbS55S2V5fWB9XG4gICAgICAgICAgICAgICAgICAgIHlLZXlGb3JtYXR0ZWQ9e2tleXNbbGVnZW5kSXRlbS55S2V5XS5rZXlGb3JtYXR0ZWR9XG4gICAgICAgICAgICAgICAgICAgIG9uQ2xpY2s9eygpID0+XG4gICAgICAgICAgICAgICAgICAgICAgc2V0VmlzaWJsZVlLZXlzICYmXG4gICAgICAgICAgICAgICAgICAgICAgc2V0VmlzaWJsZVlLZXlzKHByZXYgPT4ge1xuICAgICAgICAgICAgICAgICAgICAgICAgbGV0IG5ld1Zpc2libGVMZWdlbmRJdGVtczogQXJyYXk8c3RyaW5nPiA9IFtdO1xuXG4gICAgICAgICAgICAgICAgICAgICAgICBpZiAocHJldi5sZW5ndGggPT09IGl0ZW0ubGVnZW5kSXRlbXMubGVuZ3RoKSB7XG4gICAgICAgICAgICAgICAgICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IFtsZWdlbmRJdGVtLnlLZXldO1xuICAgICAgICAgICAgICAgICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgaWYgKHByZXYuaW5jbHVkZXMobGVnZW5kSXRlbS55S2V5KSkge1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IHByZXYuZmlsdGVyKFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgcHJldkxlZ2VuZEl0ZW1JZCA9PiBwcmV2TGVnZW5kSXRlbUlkICE9PSBsZWdlbmRJdGVtLnlLZXlcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICApO1xuICAgICAgICAgICAgICAgICAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IFsuLi5wcmV2LCBsZWdlbmRJdGVtLnlLZXldO1xuICAgICAgICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICAgICAgICB9XG5cbiAgICAgICAgICAgICAgICAgICAgICAgIHJldHVybiBuZXdWaXNpYmxlTGVnZW5kSXRlbXMubGVuZ3RoID09PSAwXG4gICAgICAgICAgICAgICAgICAgICAgICAgID8gaXRlbS5sZWdlbmRJdGVtcy5tYXAobGVnZW5kSXRlbSA9PiBsZWdlbmRJdGVtLnlLZXkpXG4gICAgICAgICAgICAgICAgICAgICAgICAgIDogbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zO1xuICAgICAgICAgICAgICAgICAgICAgIH0pXG4gICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICAgICAgdmlzaWJsZT17c2V0VmlzaWJsZVlLZXlzID8gaXRlbS52aXNpYmxlWUtleXMuaW5jbHVkZXMobGVnZW5kSXRlbS55S2V5KSA6IHRydWV9XG4gICAgICAgICAgICAgICAgICAgIGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzPXtpdGVtLmNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzfVxuICAgICAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgICAgICApXG4gICAgICAgICAgICApfVxuICAgICAgICAgIDwvRnJhZ21lbnQ+XG4gICAgICAgICkpfVxuICAgICAgPC9TY3JvbGxiYXI+XG4gICAgPC9kaXY+XG4gICk7XG59O1xuIl19 */"),
|
|
42558
42554
|
x: true,
|
|
42559
|
-
children:
|
|
42560
|
-
|
|
42561
|
-
|
|
42562
|
-
|
|
42563
|
-
|
|
42564
|
-
|
|
42565
|
-
|
|
42566
|
-
|
|
42567
|
-
|
|
42568
|
-
|
|
42569
|
-
|
|
42570
|
-
|
|
42571
|
-
|
|
42572
|
-
|
|
42573
|
-
|
|
42574
|
-
|
|
42575
|
-
|
|
42576
|
-
|
|
42577
|
-
|
|
42578
|
-
|
|
42579
|
-
|
|
42580
|
-
|
|
42581
|
-
|
|
42582
|
-
|
|
42583
|
-
|
|
42584
|
-
|
|
42555
|
+
children: items == null ? void 0 : items.map(function (item, index) {
|
|
42556
|
+
var _item$legendItems;
|
|
42557
|
+
return jsxRuntime.jsx(React.Fragment, {
|
|
42558
|
+
children: (_item$legendItems = item.legendItems) == null ? void 0 : _item$legendItems.map(function (legendItem) {
|
|
42559
|
+
return keys[legendItem.yKey] && react.createElement(LegendItem, _extends({}, legendItem, {
|
|
42560
|
+
key: "legend-" + legendItem.yKey,
|
|
42561
|
+
yKeyFormatted: keys[legendItem.yKey].keyFormatted,
|
|
42562
|
+
onClick: function onClick() {
|
|
42563
|
+
return setVisibleYKeys && setVisibleYKeys(function (prev) {
|
|
42564
|
+
var newVisibleLegendItems = [];
|
|
42565
|
+
if (prev.length === item.legendItems.length) {
|
|
42566
|
+
newVisibleLegendItems = [legendItem.yKey];
|
|
42567
|
+
} else {
|
|
42568
|
+
if (prev.includes(legendItem.yKey)) {
|
|
42569
|
+
newVisibleLegendItems = prev.filter(function (prevLegendItemId) {
|
|
42570
|
+
return prevLegendItemId !== legendItem.yKey;
|
|
42571
|
+
});
|
|
42572
|
+
} else {
|
|
42573
|
+
newVisibleLegendItems = [].concat(prev, [legendItem.yKey]);
|
|
42574
|
+
}
|
|
42575
|
+
}
|
|
42576
|
+
return newVisibleLegendItems.length === 0 ? item.legendItems.map(function (legendItem) {
|
|
42577
|
+
return legendItem.yKey;
|
|
42578
|
+
}) : newVisibleLegendItems;
|
|
42579
|
+
});
|
|
42580
|
+
},
|
|
42581
|
+
visible: setVisibleYKeys ? item.visibleYKeys.includes(legendItem.yKey) : true,
|
|
42582
|
+
conditionalFormattingRules: item.conditionalFormattingRules
|
|
42583
|
+
}));
|
|
42584
|
+
})
|
|
42585
|
+
}, index);
|
|
42585
42586
|
})
|
|
42586
42587
|
})
|
|
42587
42588
|
});
|
|
@@ -42683,19 +42684,19 @@ var buildMargin = function buildMargin(yTicks, showYAxisLabels, hasYAxisTitle, h
|
|
|
42683
42684
|
};
|
|
42684
42685
|
};
|
|
42685
42686
|
|
|
42686
|
-
function useFlattenedData(xScaleKey, xScaleDataType,
|
|
42687
|
+
function useFlattenedData(xScaleKey, xScaleDataType, data, yKeys) {
|
|
42687
42688
|
return React.useMemo(function () {
|
|
42688
|
-
if (xScaleKey && xScaleDataType) {
|
|
42689
|
+
if (xScaleKey && xScaleDataType && yKeys.length > 0) {
|
|
42689
42690
|
return flattenData({
|
|
42690
|
-
data:
|
|
42691
|
+
data: data,
|
|
42691
42692
|
xScaleKey: xScaleKey,
|
|
42692
42693
|
xScaleDataType: xScaleDataType,
|
|
42693
|
-
yKeys:
|
|
42694
|
+
yKeys: yKeys
|
|
42694
42695
|
});
|
|
42695
42696
|
} else {
|
|
42696
42697
|
return [];
|
|
42697
42698
|
}
|
|
42698
|
-
}, [
|
|
42699
|
+
}, [data, xScaleKey, xScaleDataType, yKeys]);
|
|
42699
42700
|
}
|
|
42700
42701
|
|
|
42701
42702
|
var GoalLine = function GoalLine(_ref) {
|
|
@@ -43044,6 +43045,17 @@ function useTooltip$1(initialTooltipState) {
|
|
|
43044
43045
|
};
|
|
43045
43046
|
}
|
|
43046
43047
|
|
|
43048
|
+
function useYScale(innerHeight, scale$1) {
|
|
43049
|
+
return React.useMemo(function () {
|
|
43050
|
+
return scale.scaleLinear({
|
|
43051
|
+
range: [innerHeight, 0],
|
|
43052
|
+
domain: scale$1.ordering === 'asc' ? [scale$1.min, scale$1.max] : [scale$1.max, scale$1.min],
|
|
43053
|
+
nice: true,
|
|
43054
|
+
round: true
|
|
43055
|
+
});
|
|
43056
|
+
}, [innerHeight, scale$1]);
|
|
43057
|
+
}
|
|
43058
|
+
|
|
43047
43059
|
var LineChart$5 = function LineChart(_ref) {
|
|
43048
43060
|
var _theme$axis;
|
|
43049
43061
|
var chart = _ref.chart,
|
|
@@ -43109,14 +43121,8 @@ var LineChart$5 = function LineChart(_ref) {
|
|
|
43109
43121
|
}
|
|
43110
43122
|
return null;
|
|
43111
43123
|
}, [innerWidth, chart.x, chart.data]);
|
|
43112
|
-
var _yScale =
|
|
43113
|
-
|
|
43114
|
-
range: [innerHeight, 0],
|
|
43115
|
-
domain: chart.y.scale.ordering === 'asc' ? [chart.y.scale.min, chart.y.scale.max] : [chart.y.scale.max, chart.y.scale.min],
|
|
43116
|
-
nice: true
|
|
43117
|
-
});
|
|
43118
|
-
}, [innerHeight, chart.y]);
|
|
43119
|
-
var dataFlattened = useFlattenedData(xScaleKey, xScaleDataType, chart);
|
|
43124
|
+
var _yScale = useYScale(innerHeight, chart.y.scale);
|
|
43125
|
+
var dataFlattened = useFlattenedData(xScaleKey, xScaleDataType, chart.data, chart.y.keys);
|
|
43120
43126
|
var handleMouseMove = React.useCallback(function (event) {
|
|
43121
43127
|
if (!xKey || !xScaleKey || xScale === null) return;
|
|
43122
43128
|
var tooltipData = getTooltipData({
|
|
@@ -43143,6 +43149,11 @@ var LineChart$5 = function LineChart(_ref) {
|
|
|
43143
43149
|
var yTickValues = chart.y.ticks.map(function (tick) {
|
|
43144
43150
|
return Number(tick.value);
|
|
43145
43151
|
});
|
|
43152
|
+
var legendTooltipItems = [{
|
|
43153
|
+
legendItems: chart.lines,
|
|
43154
|
+
visibleYKeys: visibleYKeys,
|
|
43155
|
+
conditionalFormattingRules: chart.conditionalFormattingRules
|
|
43156
|
+
}];
|
|
43146
43157
|
return jsxRuntime.jsxs(React__default.Fragment, {
|
|
43147
43158
|
children: [jsxRuntime.jsxs(ChartWrapper$1, {
|
|
43148
43159
|
width: width,
|
|
@@ -43177,93 +43188,19 @@ var LineChart$5 = function LineChart(_ref) {
|
|
|
43177
43188
|
yScale: _yScale,
|
|
43178
43189
|
ticks: yTickValues,
|
|
43179
43190
|
stroke: theme == null || (_theme$axis = theme.axis) == null ? void 0 : _theme$axis.stroke
|
|
43180
|
-
}), jsxRuntime.
|
|
43181
|
-
children:
|
|
43182
|
-
|
|
43183
|
-
|
|
43184
|
-
|
|
43185
|
-
|
|
43186
|
-
|
|
43187
|
-
|
|
43188
|
-
|
|
43189
|
-
|
|
43190
|
-
|
|
43191
|
-
|
|
43192
|
-
|
|
43193
|
-
},
|
|
43194
|
-
y: function y(d) {
|
|
43195
|
-
return _yScale(Number(d[yKey]));
|
|
43196
|
-
},
|
|
43197
|
-
stroke: chart.lines.filter(function (legendItem) {
|
|
43198
|
-
return legendItem.yKey === yKey;
|
|
43199
|
-
})[0].color,
|
|
43200
|
-
strokeWidth: chart.lines.filter(function (legendItem) {
|
|
43201
|
-
return legendItem.yKey === yKey;
|
|
43202
|
-
})[0].style.strokeWidth,
|
|
43203
|
-
strokeLinecap: "round",
|
|
43204
|
-
strokeDasharray: (_chart$lines$filter$ = chart.lines.filter(function (legendItem) {
|
|
43205
|
-
return legendItem.yKey === yKey;
|
|
43206
|
-
})[0].style.strokeDasharray) != null ? _chart$lines$filter$ : undefined,
|
|
43207
|
-
shapeRendering: "smooth",
|
|
43208
|
-
defined: function defined(d) {
|
|
43209
|
-
return d[yKey] !== null;
|
|
43210
|
-
},
|
|
43211
|
-
curve: curve
|
|
43212
|
-
}, yKey);
|
|
43213
|
-
}), chart.conditionalFormattingRules.map(function (conditionalFormattingRule) {
|
|
43214
|
-
var _chart$lines$filter$2;
|
|
43215
|
-
if (conditionalFormattingRule.operator !== '<=' && conditionalFormattingRule.operator !== '>=') return null;
|
|
43216
|
-
var yKey = conditionalFormattingRule.yKey;
|
|
43217
|
-
var clipPathId = "clip-path-" + yKey + "-" + conditionalFormattingRule.value + "-" + conditionalFormattingRule.color + "-" + Math.random(); // Do not remove Math.random() - required to ensure unique clipPathId per view instance
|
|
43218
|
-
|
|
43219
|
-
var clipArea = getClipArea({
|
|
43220
|
-
conditionalFormattingRule: conditionalFormattingRule,
|
|
43221
|
-
chart: {
|
|
43222
|
-
width: innerWidth,
|
|
43223
|
-
height: innerHeight,
|
|
43224
|
-
yScale: _yScale
|
|
43225
|
-
}
|
|
43226
|
-
});
|
|
43227
|
-
|
|
43228
|
-
// return a new <LinePath /> for each conditional formatting rule with a matching <ReactClipPath /> to frame the part of the path that should be visible
|
|
43229
|
-
return jsxRuntime.jsxs(group.Group, {
|
|
43230
|
-
children: [jsxRuntime.jsx(shape.LinePath, {
|
|
43231
|
-
clipPath: "url(#" + clipPathId + ")",
|
|
43232
|
-
visibility: visibleYKeys.includes(yKey) ? 'visible' : 'hidden',
|
|
43233
|
-
data: dataFlattened,
|
|
43234
|
-
x: function x(d) {
|
|
43235
|
-
var _xScale2;
|
|
43236
|
-
// @ts-ignore
|
|
43237
|
-
var xValue = d[xScaleKey];
|
|
43238
|
-
var xValueAdjusted = xScaleDataType === 'date_time' ? new Date(xValue) : xScaleDataType === 'number' ? Number(xValue) : String(xValue);
|
|
43239
|
-
// @ts-ignore
|
|
43240
|
-
return (_xScale2 = xScale(xValueAdjusted)) != null ? _xScale2 : 0;
|
|
43241
|
-
},
|
|
43242
|
-
y: function y(d) {
|
|
43243
|
-
return _yScale(Number(d[yKey]));
|
|
43244
|
-
},
|
|
43245
|
-
stroke: conditionalFormattingRule.color,
|
|
43246
|
-
strokeWidth: chart.lines.filter(function (legendItem) {
|
|
43247
|
-
return legendItem.yKey === yKey;
|
|
43248
|
-
})[0].style.strokeWidth,
|
|
43249
|
-
strokeLinecap: "round",
|
|
43250
|
-
strokeDasharray: (_chart$lines$filter$2 = chart.lines.filter(function (legendItem) {
|
|
43251
|
-
return legendItem.yKey === yKey;
|
|
43252
|
-
})[0].style.strokeDasharray) != null ? _chart$lines$filter$2 : undefined,
|
|
43253
|
-
shapeRendering: "smooth",
|
|
43254
|
-
defined: function defined(d) {
|
|
43255
|
-
return d[yKey] !== null;
|
|
43256
|
-
},
|
|
43257
|
-
curve: curve
|
|
43258
|
-
}, yKey), jsxRuntime.jsx(clipPath.RectClipPath, {
|
|
43259
|
-
id: clipPathId,
|
|
43260
|
-
x: clipArea.x,
|
|
43261
|
-
y: clipArea.y,
|
|
43262
|
-
width: clipArea.width,
|
|
43263
|
-
height: clipArea.height
|
|
43264
|
-
})]
|
|
43265
|
-
}, clipPathId);
|
|
43266
|
-
})]
|
|
43191
|
+
}), jsxRuntime.jsx(group.Group, {
|
|
43192
|
+
children: xScaleKey !== null && jsxRuntime.jsx(Lines, {
|
|
43193
|
+
lines: chart.lines,
|
|
43194
|
+
conditionalFormattingRules: chart.conditionalFormattingRules,
|
|
43195
|
+
curve: curve,
|
|
43196
|
+
yKeys: chart.y.keys,
|
|
43197
|
+
visibleYKeys: visibleYKeys,
|
|
43198
|
+
data: dataFlattened,
|
|
43199
|
+
xScaleKey: xScaleKey,
|
|
43200
|
+
xScaleDataType: xScaleDataType,
|
|
43201
|
+
xScale: xScale,
|
|
43202
|
+
yScale: _yScale
|
|
43203
|
+
})
|
|
43267
43204
|
})]
|
|
43268
43205
|
}), tooltipData && jsxRuntime.jsxs("g", {
|
|
43269
43206
|
children: [jsxRuntime.jsx(Line, {
|
|
@@ -43295,27 +43232,117 @@ var LineChart$5 = function LineChart(_ref) {
|
|
|
43295
43232
|
width: innerWidth
|
|
43296
43233
|
})]
|
|
43297
43234
|
}), options.showLegend && jsxRuntime.jsx(Legend$1, {
|
|
43298
|
-
|
|
43299
|
-
visibleYKeys: visibleYKeys,
|
|
43235
|
+
items: legendTooltipItems,
|
|
43300
43236
|
setVisibleYKeys: setVisibleYKeys,
|
|
43301
43237
|
keys: chart.keys,
|
|
43302
|
-
conditionalFormattingRules: chart.conditionalFormattingRules,
|
|
43303
43238
|
marginLeft: margin.left - margin.leftTitleOffset
|
|
43304
43239
|
}), tooltipOpen && tooltipData && xKey && jsxRuntime.jsx(Tooltip$1, {
|
|
43240
|
+
items: legendTooltipItems,
|
|
43305
43241
|
tooltipData: tooltipData,
|
|
43306
43242
|
tooltipLeft: tooltipLeft,
|
|
43307
43243
|
tooltipTop: tooltipTop,
|
|
43308
43244
|
xKey: xKey,
|
|
43309
43245
|
keys: chart.keys,
|
|
43310
|
-
visibleYKeys: visibleYKeys,
|
|
43311
43246
|
yKeys: chart.y.keys,
|
|
43312
|
-
legendItems: chart.lines,
|
|
43313
43247
|
showRoundedTotal: options.showRoundedTotal,
|
|
43314
|
-
conditionalFormattingRules: chart.conditionalFormattingRules,
|
|
43315
43248
|
theme: themeCSS.popoverMenus
|
|
43316
43249
|
})]
|
|
43317
43250
|
});
|
|
43318
43251
|
};
|
|
43252
|
+
function Lines(_ref2) {
|
|
43253
|
+
var yKeys = _ref2.yKeys,
|
|
43254
|
+
visibleYKeys = _ref2.visibleYKeys,
|
|
43255
|
+
data = _ref2.data,
|
|
43256
|
+
xScaleKey = _ref2.xScaleKey,
|
|
43257
|
+
xScaleDataType = _ref2.xScaleDataType,
|
|
43258
|
+
xScale = _ref2.xScale,
|
|
43259
|
+
yScale = _ref2.yScale,
|
|
43260
|
+
lines = _ref2.lines,
|
|
43261
|
+
curve = _ref2.curve,
|
|
43262
|
+
conditionalFormattingRules = _ref2.conditionalFormattingRules;
|
|
43263
|
+
return jsxRuntime.jsxs(React.Fragment, {
|
|
43264
|
+
children: [yKeys.map(function (yKey) {
|
|
43265
|
+
var _lines$filter$0$style;
|
|
43266
|
+
return jsxRuntime.jsx(shape.LinePath, {
|
|
43267
|
+
visibility: visibleYKeys.includes(yKey) ? 'visible' : 'hidden',
|
|
43268
|
+
data: data,
|
|
43269
|
+
x: function x(d) {
|
|
43270
|
+
var _ref3;
|
|
43271
|
+
var xValue = d[xScaleKey];
|
|
43272
|
+
var xValueAdjusted = xScaleDataType === 'date_time' ? new Date(xValue) : xScaleDataType === 'number' ? Number(xValue) : String(xValue);
|
|
43273
|
+
return (_ref3 = xScale(xValueAdjusted)) != null ? _ref3 : 0;
|
|
43274
|
+
},
|
|
43275
|
+
y: function y(d) {
|
|
43276
|
+
return yScale(d[yKey]);
|
|
43277
|
+
},
|
|
43278
|
+
stroke: lines.filter(function (legendItem) {
|
|
43279
|
+
return legendItem.yKey === yKey;
|
|
43280
|
+
})[0].color,
|
|
43281
|
+
strokeWidth: lines.filter(function (legendItem) {
|
|
43282
|
+
return legendItem.yKey === yKey;
|
|
43283
|
+
})[0].style.strokeWidth,
|
|
43284
|
+
strokeLinecap: "round",
|
|
43285
|
+
strokeDasharray: (_lines$filter$0$style = lines.filter(function (legendItem) {
|
|
43286
|
+
return legendItem.yKey === yKey;
|
|
43287
|
+
})[0].style.strokeDasharray) != null ? _lines$filter$0$style : undefined,
|
|
43288
|
+
shapeRendering: "smooth",
|
|
43289
|
+
defined: function defined(d) {
|
|
43290
|
+
return d[yKey] !== null;
|
|
43291
|
+
},
|
|
43292
|
+
curve: curve
|
|
43293
|
+
}, yKey);
|
|
43294
|
+
}), conditionalFormattingRules.map(function (conditionalFormattingRule) {
|
|
43295
|
+
var _lines$filter$0$style2;
|
|
43296
|
+
if (conditionalFormattingRule.operator !== '<=' && conditionalFormattingRule.operator !== '>=') return null;
|
|
43297
|
+
var yKey = conditionalFormattingRule.yKey;
|
|
43298
|
+
var clipPathId = "clip-path-" + yKey + "-" + conditionalFormattingRule.value + "-" + conditionalFormattingRule.color + "-" + Math.random(); // Do not remove Math.random() - required to ensure unique clipPathId per view instance
|
|
43299
|
+
|
|
43300
|
+
var clipArea = getClipArea({
|
|
43301
|
+
conditionalFormattingRule: conditionalFormattingRule,
|
|
43302
|
+
chart: {
|
|
43303
|
+
width: innerWidth,
|
|
43304
|
+
height: innerHeight,
|
|
43305
|
+
yScale: yScale
|
|
43306
|
+
}
|
|
43307
|
+
});
|
|
43308
|
+
return jsxRuntime.jsxs(group.Group, {
|
|
43309
|
+
children: [jsxRuntime.jsx(shape.LinePath, {
|
|
43310
|
+
clipPath: "url(#" + clipPathId + ")",
|
|
43311
|
+
visibility: visibleYKeys.includes(yKey) ? 'visible' : 'hidden',
|
|
43312
|
+
data: data,
|
|
43313
|
+
x: function x(d) {
|
|
43314
|
+
var _ref4;
|
|
43315
|
+
var xValue = d[xScaleKey];
|
|
43316
|
+
var xValueAdjusted = xScaleDataType === 'date_time' ? new Date(xValue) : xScaleDataType === 'number' ? Number(xValue) : String(xValue);
|
|
43317
|
+
return (_ref4 = xScale(xValueAdjusted)) != null ? _ref4 : 0;
|
|
43318
|
+
},
|
|
43319
|
+
y: function y(d) {
|
|
43320
|
+
return yScale(d[yKey]);
|
|
43321
|
+
},
|
|
43322
|
+
stroke: conditionalFormattingRule.color,
|
|
43323
|
+
strokeWidth: lines.filter(function (legendItem) {
|
|
43324
|
+
return legendItem.yKey === yKey;
|
|
43325
|
+
})[0].style.strokeWidth,
|
|
43326
|
+
strokeLinecap: "round",
|
|
43327
|
+
strokeDasharray: (_lines$filter$0$style2 = lines.filter(function (legendItem) {
|
|
43328
|
+
return legendItem.yKey === yKey;
|
|
43329
|
+
})[0].style.strokeDasharray) != null ? _lines$filter$0$style2 : undefined,
|
|
43330
|
+
shapeRendering: "smooth",
|
|
43331
|
+
defined: function defined(d) {
|
|
43332
|
+
return d[yKey] !== null;
|
|
43333
|
+
},
|
|
43334
|
+
curve: curve
|
|
43335
|
+
}, yKey), jsxRuntime.jsx(clipPath.RectClipPath, {
|
|
43336
|
+
id: clipPathId,
|
|
43337
|
+
x: clipArea.x,
|
|
43338
|
+
y: clipArea.y,
|
|
43339
|
+
width: clipArea.width,
|
|
43340
|
+
height: clipArea.height
|
|
43341
|
+
})]
|
|
43342
|
+
}, clipPathId);
|
|
43343
|
+
})]
|
|
43344
|
+
});
|
|
43345
|
+
}
|
|
43319
43346
|
|
|
43320
43347
|
function getBarFill(bars, conditionalFormattingRules, barKey, barValues) {
|
|
43321
43348
|
var _bars$find;
|
|
@@ -43332,7 +43359,7 @@ function getBarFill(bars, conditionalFormattingRules, barKey, barValues) {
|
|
|
43332
43359
|
if (compare({
|
|
43333
43360
|
op: rule.operator,
|
|
43334
43361
|
value: rule.value
|
|
43335
|
-
}, value)) {
|
|
43362
|
+
}, value) && rule.yKey === barKey) {
|
|
43336
43363
|
fill = rule.color;
|
|
43337
43364
|
break;
|
|
43338
43365
|
}
|
|
@@ -43341,12 +43368,43 @@ function getBarFill(bars, conditionalFormattingRules, barKey, barValues) {
|
|
|
43341
43368
|
return fill;
|
|
43342
43369
|
}
|
|
43343
43370
|
|
|
43344
|
-
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)."; }
|
|
43345
|
-
var BAR_RADIUS = 2;
|
|
43346
43371
|
var PADDING = {
|
|
43347
43372
|
paddingOuter: 0.05,
|
|
43348
43373
|
paddingInner: 0.3
|
|
43349
43374
|
};
|
|
43375
|
+
|
|
43376
|
+
function useBarXScale(xScaleDataType, innerWidth, xScaleKey, data) {
|
|
43377
|
+
return React.useMemo(function () {
|
|
43378
|
+
if (xScaleDataType === 'string') {
|
|
43379
|
+
return scale.scaleBand(_extends({
|
|
43380
|
+
range: [0, innerWidth],
|
|
43381
|
+
domain: xScaleKey ? [].concat(data.map(function (d) {
|
|
43382
|
+
return d[xScaleKey] && d[xScaleKey].value !== null ? String(d[xScaleKey].value) : '';
|
|
43383
|
+
})) : []
|
|
43384
|
+
}, PADDING));
|
|
43385
|
+
}
|
|
43386
|
+
if (xScaleDataType === 'date_time' && xScaleKey) {
|
|
43387
|
+
return scale.scaleBand(_extends({
|
|
43388
|
+
range: [0, innerWidth],
|
|
43389
|
+
domain: data.map(function (d) {
|
|
43390
|
+
return new Date(d[xScaleKey].value);
|
|
43391
|
+
})
|
|
43392
|
+
}, PADDING));
|
|
43393
|
+
}
|
|
43394
|
+
if (xScaleDataType === 'number' && xScaleKey) {
|
|
43395
|
+
return scale.scaleBand(_extends({
|
|
43396
|
+
range: [0, innerWidth],
|
|
43397
|
+
domain: data.map(function (d) {
|
|
43398
|
+
return d[xScaleKey] && d[xScaleKey].value !== null ? Number(d[xScaleKey].value) : 0;
|
|
43399
|
+
})
|
|
43400
|
+
}, PADDING));
|
|
43401
|
+
}
|
|
43402
|
+
return null;
|
|
43403
|
+
}, [innerWidth, data]);
|
|
43404
|
+
}
|
|
43405
|
+
|
|
43406
|
+
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)."; }
|
|
43407
|
+
var BAR_RADIUS = 2;
|
|
43350
43408
|
var BarChart$5 = function BarChart(_ref) {
|
|
43351
43409
|
var _theme$axis;
|
|
43352
43410
|
var chart = _ref.chart,
|
|
@@ -43377,41 +43435,8 @@ var BarChart$5 = function BarChart(_ref) {
|
|
|
43377
43435
|
var xScaleKey = chart.x.scale.key;
|
|
43378
43436
|
var yScaleKeys = chart.y.keys;
|
|
43379
43437
|
var xScaleDataType = chart.x.scale.dataType;
|
|
43380
|
-
var xScale =
|
|
43381
|
-
|
|
43382
|
-
return scale.scaleBand(_extends({
|
|
43383
|
-
range: [0, innerWidth],
|
|
43384
|
-
domain: xScaleKey ? [].concat(chart.data.map(function (d) {
|
|
43385
|
-
return d[xScaleKey] && d[xScaleKey].value !== null ? String(d[xScaleKey].value) : '';
|
|
43386
|
-
})) : []
|
|
43387
|
-
}, PADDING));
|
|
43388
|
-
}
|
|
43389
|
-
if (xScaleDataType === 'date_time' && xScaleKey) {
|
|
43390
|
-
return scale.scaleBand(_extends({
|
|
43391
|
-
range: [0, innerWidth],
|
|
43392
|
-
domain: chart.data.map(function (d) {
|
|
43393
|
-
return new Date(d[xScaleKey].value);
|
|
43394
|
-
})
|
|
43395
|
-
}, PADDING));
|
|
43396
|
-
}
|
|
43397
|
-
if (xScaleDataType === 'number' && xScaleKey) {
|
|
43398
|
-
return scale.scaleBand(_extends({
|
|
43399
|
-
range: [0, innerWidth],
|
|
43400
|
-
domain: chart.data.map(function (d) {
|
|
43401
|
-
return d[xScaleKey] && d[xScaleKey].value !== null ? Number(d[xScaleKey].value) : 0;
|
|
43402
|
-
})
|
|
43403
|
-
}, PADDING));
|
|
43404
|
-
}
|
|
43405
|
-
return null;
|
|
43406
|
-
}, [innerWidth, chart.x, chart.data]);
|
|
43407
|
-
var yScale = React.useMemo(function () {
|
|
43408
|
-
return scale.scaleLinear({
|
|
43409
|
-
range: [innerHeight, 0],
|
|
43410
|
-
domain: chart.y.scale.ordering === 'asc' ? [chart.y.scale.min, chart.y.scale.max] : [chart.y.scale.max, chart.y.scale.min],
|
|
43411
|
-
nice: true,
|
|
43412
|
-
round: true
|
|
43413
|
-
});
|
|
43414
|
-
}, [innerHeight, chart.y]);
|
|
43438
|
+
var xScale = useBarXScale(xScaleDataType, innerWidth, xScaleKey, chart.data);
|
|
43439
|
+
var yScale = useYScale(innerHeight, chart.y.scale);
|
|
43415
43440
|
var innerXScale = React.useMemo(function () {
|
|
43416
43441
|
if (!options.stacked && xScale && 'bandwidth' in xScale) {
|
|
43417
43442
|
return scale.scaleBand({
|
|
@@ -43422,7 +43447,7 @@ var BarChart$5 = function BarChart(_ref) {
|
|
|
43422
43447
|
}
|
|
43423
43448
|
return undefined;
|
|
43424
43449
|
}, [xScale, yScaleKeys, options.stacked, xScaleDataType]);
|
|
43425
|
-
var dataFlattened = useFlattenedData(xScaleKey, xScaleDataType, chart);
|
|
43450
|
+
var dataFlattened = useFlattenedData(xScaleKey, xScaleDataType, chart.data, chart.y.keys);
|
|
43426
43451
|
var handleMouseMove = React.useCallback(function (event) {
|
|
43427
43452
|
if (!xKey || !xScaleKey || xScale === null) return;
|
|
43428
43453
|
var tooltipData = getTooltipData({
|
|
@@ -43468,6 +43493,13 @@ var BarChart$5 = function BarChart(_ref) {
|
|
|
43468
43493
|
var yTickValues = chart.y.ticks.map(function (tick) {
|
|
43469
43494
|
return Number(tick.value);
|
|
43470
43495
|
});
|
|
43496
|
+
var legendTooltipItems = [{
|
|
43497
|
+
visibleYKeys: chart.bars.map(function (legendItem) {
|
|
43498
|
+
return legendItem.yKey;
|
|
43499
|
+
}),
|
|
43500
|
+
legendItems: chart.bars,
|
|
43501
|
+
conditionalFormattingRules: chart.conditionalFormattingRules
|
|
43502
|
+
}];
|
|
43471
43503
|
return jsxRuntime.jsxs(React.Fragment, {
|
|
43472
43504
|
children: [jsxRuntime.jsxs(ChartWrapper$1, {
|
|
43473
43505
|
width: width,
|
|
@@ -43503,57 +43535,25 @@ var BarChart$5 = function BarChart(_ref) {
|
|
|
43503
43535
|
ticks: yTickValues,
|
|
43504
43536
|
stroke: theme == null || (_theme$axis = theme.axis) == null ? void 0 : _theme$axis.stroke
|
|
43505
43537
|
}), jsxRuntime.jsxs(group.Group, {
|
|
43506
|
-
children: [!options.stacked && jsxRuntime.jsx(
|
|
43538
|
+
children: [!options.stacked && jsxRuntime.jsx(BarGroup, {
|
|
43507
43539
|
data: dataFlattened,
|
|
43508
43540
|
keys: yScaleKeys,
|
|
43509
43541
|
height: innerHeight,
|
|
43510
|
-
|
|
43511
|
-
|
|
43512
|
-
|
|
43513
|
-
|
|
43514
|
-
var xValueAdjusted = xScaleDataType === 'date_time' ? new Date(xValue) : xScaleDataType === 'number' ? Number(xValue) : String(xValue);
|
|
43515
|
-
// @ts-ignore
|
|
43516
|
-
return xValueAdjusted;
|
|
43517
|
-
}
|
|
43518
|
-
// @ts-ignore
|
|
43519
|
-
,
|
|
43520
|
-
x0Scale: xScale
|
|
43521
|
-
// @ts-ignore
|
|
43522
|
-
,
|
|
43523
|
-
x1Scale: innerXScale,
|
|
43542
|
+
xKey: xKey,
|
|
43543
|
+
xScaleDataType: xScaleDataType,
|
|
43544
|
+
xScale: xScale,
|
|
43545
|
+
innerXScale: innerXScale,
|
|
43524
43546
|
yScale: yScale,
|
|
43525
|
-
|
|
43526
|
-
|
|
43527
|
-
|
|
43528
|
-
|
|
43529
|
-
return barGroups.map(function (barGroup) {
|
|
43530
|
-
return jsxRuntime.jsx(group.Group, {
|
|
43531
|
-
left: barGroup.x0,
|
|
43532
|
-
children: barGroup.bars.map(function (bar) {
|
|
43533
|
-
if (bar.value === null) return null;
|
|
43534
|
-
if (bar.height < 0 || bar.width < 0) return null;
|
|
43535
|
-
return jsxRuntime.jsx(Bar, {
|
|
43536
|
-
x: bar.x,
|
|
43537
|
-
y: bar.y,
|
|
43538
|
-
width: bar.width,
|
|
43539
|
-
height: bar.height,
|
|
43540
|
-
fill: getBarFill(chart.bars, chart.conditionalFormattingRules, bar.key, bar.value),
|
|
43541
|
-
onClick: function onClick(e) {
|
|
43542
|
-
return handleOnBarClick(e, barGroup, bar);
|
|
43543
|
-
},
|
|
43544
|
-
enableHover: enableHover
|
|
43545
|
-
}, "bar-group-bar-" + barGroup.index + "-" + bar.index + "-" + bar.value + "-" + bar.key);
|
|
43546
|
-
})
|
|
43547
|
-
}, "bar-group-" + barGroup.index + "-" + barGroup.x0);
|
|
43548
|
-
});
|
|
43549
|
-
}
|
|
43547
|
+
onClick: handleOnBarClick,
|
|
43548
|
+
conditionalFormattingRules: chart.conditionalFormattingRules,
|
|
43549
|
+
bars: chart.bars,
|
|
43550
|
+
enableHover: enableHover
|
|
43550
43551
|
}), options.stacked && jsxRuntime.jsx(shape.BarStack, {
|
|
43551
43552
|
x: function x(d) {
|
|
43552
43553
|
// @ts-ignore
|
|
43553
43554
|
var xValue = d[xScaleKey];
|
|
43554
43555
|
if (xScaleDataType === 'string') return xValue;
|
|
43555
43556
|
var xValueAdjusted = xScaleDataType === 'date_time' ? new Date(xValue) : xScaleDataType === 'number' ? Number(xValue) : String(xValue);
|
|
43556
|
-
// @ts-ignore
|
|
43557
43557
|
return xValueAdjusted;
|
|
43558
43558
|
}
|
|
43559
43559
|
// @ts-ignore
|
|
@@ -43601,31 +43601,79 @@ var BarChart$5 = function BarChart(_ref) {
|
|
|
43601
43601
|
width: innerWidth
|
|
43602
43602
|
})]
|
|
43603
43603
|
}), options.showLegend && jsxRuntime.jsx(Legend$1, {
|
|
43604
|
-
|
|
43605
|
-
visibleYKeys: chart.bars.map(function (legendItem) {
|
|
43606
|
-
return legendItem.yKey;
|
|
43607
|
-
}),
|
|
43604
|
+
items: legendTooltipItems,
|
|
43608
43605
|
setVisibleYKeys: function setVisibleYKeys() {},
|
|
43609
43606
|
keys: chart.keys,
|
|
43610
|
-
conditionalFormattingRules: chart.conditionalFormattingRules,
|
|
43611
43607
|
marginLeft: margin.left - margin.leftTitleOffset
|
|
43612
43608
|
}), tooltipOpen && tooltipData && xKey && jsxRuntime.jsx(Tooltip$1, {
|
|
43609
|
+
items: legendTooltipItems,
|
|
43613
43610
|
tooltipData: tooltipData,
|
|
43614
43611
|
tooltipLeft: tooltipLeft,
|
|
43615
43612
|
tooltipTop: tooltipTop,
|
|
43616
43613
|
xKey: xKey,
|
|
43617
43614
|
keys: chart.keys,
|
|
43618
|
-
visibleYKeys: chart.bars.map(function (legendItem) {
|
|
43619
|
-
return legendItem.yKey;
|
|
43620
|
-
}),
|
|
43621
43615
|
yKeys: chart.y.keys,
|
|
43622
|
-
legendItems: chart.bars,
|
|
43623
43616
|
showRoundedTotal: options.showRoundedTotal,
|
|
43624
|
-
conditionalFormattingRules: chart.conditionalFormattingRules,
|
|
43625
43617
|
theme: themeCSS.popoverMenus
|
|
43626
43618
|
})]
|
|
43627
43619
|
});
|
|
43628
43620
|
};
|
|
43621
|
+
function BarGroup(_ref2) {
|
|
43622
|
+
var data = _ref2.data,
|
|
43623
|
+
keys = _ref2.keys,
|
|
43624
|
+
height = _ref2.height,
|
|
43625
|
+
xKey = _ref2.xKey,
|
|
43626
|
+
xScaleDataType = _ref2.xScaleDataType,
|
|
43627
|
+
xScale = _ref2.xScale,
|
|
43628
|
+
innerXScale = _ref2.innerXScale,
|
|
43629
|
+
yScale = _ref2.yScale,
|
|
43630
|
+
_onClick = _ref2.onClick,
|
|
43631
|
+
conditionalFormattingRules = _ref2.conditionalFormattingRules,
|
|
43632
|
+
bars = _ref2.bars,
|
|
43633
|
+
enableHover = _ref2.enableHover;
|
|
43634
|
+
return jsxRuntime.jsx(shape.BarGroup, {
|
|
43635
|
+
data: data,
|
|
43636
|
+
keys: keys,
|
|
43637
|
+
height: height,
|
|
43638
|
+
x0: function x0(d) {
|
|
43639
|
+
var xValue = d[xKey];
|
|
43640
|
+
if (xScaleDataType === 'string') return String(xValue);
|
|
43641
|
+
var xValueAdjusted = xScaleDataType === 'date_time' ? new Date(String(xValue)) : xScaleDataType === 'number' ? Number(xValue) : String(xValue);
|
|
43642
|
+
return xValueAdjusted;
|
|
43643
|
+
}
|
|
43644
|
+
// @ts-ignore
|
|
43645
|
+
,
|
|
43646
|
+
x0Scale: xScale
|
|
43647
|
+
// @ts-ignore
|
|
43648
|
+
,
|
|
43649
|
+
x1Scale: innerXScale,
|
|
43650
|
+
yScale: yScale,
|
|
43651
|
+
color: function color() {
|
|
43652
|
+
return '';
|
|
43653
|
+
},
|
|
43654
|
+
children: function children(barGroups) {
|
|
43655
|
+
return barGroups.map(function (barGroup) {
|
|
43656
|
+
return jsxRuntime.jsx(group.Group, {
|
|
43657
|
+
left: barGroup.x0,
|
|
43658
|
+
children: barGroup.bars.map(function (bar) {
|
|
43659
|
+
if (bar.value === null || bar.height < 0 || bar.width < 0) return null;
|
|
43660
|
+
return jsxRuntime.jsx(Bar, {
|
|
43661
|
+
x: bar.x,
|
|
43662
|
+
y: bar.y,
|
|
43663
|
+
width: bar.width,
|
|
43664
|
+
height: bar.height,
|
|
43665
|
+
fill: getBarFill(bars, conditionalFormattingRules, String(bar.key), bar.value),
|
|
43666
|
+
onClick: function onClick(e) {
|
|
43667
|
+
return _onClick(e, barGroup, bar);
|
|
43668
|
+
},
|
|
43669
|
+
enableHover: enableHover
|
|
43670
|
+
}, "bar-group-bar-" + barGroup.index + "-" + bar.index + "-" + bar.value + "-" + String(bar.key));
|
|
43671
|
+
})
|
|
43672
|
+
}, "bar-group-" + barGroup.index + "-" + barGroup.x0);
|
|
43673
|
+
});
|
|
43674
|
+
}
|
|
43675
|
+
});
|
|
43676
|
+
}
|
|
43629
43677
|
var Bar = function Bar(props) {
|
|
43630
43678
|
var _useState = React.useState(props.fill),
|
|
43631
43679
|
fillColor = _useState[0],
|
|
@@ -43647,7 +43695,7 @@ var Bar = function Bar(props) {
|
|
|
43647
43695
|
className: props.enableHover ? /*#__PURE__*/css$1.css( {
|
|
43648
43696
|
name: "4nk3o1-Bar",
|
|
43649
43697
|
styles: "cursor:pointer;label:Bar;",
|
|
43650
|
-
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"]} */",
|
|
43698
|
+
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"]} */",
|
|
43651
43699
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$9
|
|
43652
43700
|
}) : ''
|
|
43653
43701
|
}, props.key);
|
|
@@ -43823,14 +43871,8 @@ var AreaChart$5 = function AreaChart(_ref) {
|
|
|
43823
43871
|
}
|
|
43824
43872
|
return null;
|
|
43825
43873
|
}, [innerWidth, chart.x, chart.data]);
|
|
43826
|
-
var _yScale =
|
|
43827
|
-
|
|
43828
|
-
range: [innerHeight, 0],
|
|
43829
|
-
domain: chart.y.scale.ordering === 'asc' ? [chart.y.scale.min, chart.y.scale.max] : [chart.y.scale.max, chart.y.scale.min],
|
|
43830
|
-
nice: true
|
|
43831
|
-
});
|
|
43832
|
-
}, [innerHeight, chart.y.scale]);
|
|
43833
|
-
var dataFlattened = useFlattenedData(xScaleKey, xScaleDataType, chart);
|
|
43874
|
+
var _yScale = useYScale(innerHeight, chart.y.scale);
|
|
43875
|
+
var dataFlattened = useFlattenedData(xScaleKey, xScaleDataType, chart.data, chart.y.keys);
|
|
43834
43876
|
var handleMouseMove = React.useCallback(function (event) {
|
|
43835
43877
|
if (!xKey || !xScaleKey || xScale === null) return;
|
|
43836
43878
|
var tooltipData = getTooltipData({
|
|
@@ -43860,12 +43902,17 @@ var AreaChart$5 = function AreaChart(_ref) {
|
|
|
43860
43902
|
step: Curves.curveStep,
|
|
43861
43903
|
straight: Curves.curveLinear
|
|
43862
43904
|
};
|
|
43863
|
-
return curveMap[(_options$curve = options.curve) != null ? _options$curve : '
|
|
43905
|
+
return curveMap[(_options$curve = options.curve) != null ? _options$curve : 'natural'];
|
|
43864
43906
|
}, [options.curve]);
|
|
43865
43907
|
if (width === 0 || height === 0 || xScale === null) return jsxRuntime.jsx(React__default.Fragment, {});
|
|
43866
43908
|
var yTickValues = chart.y.ticks.map(function (tick) {
|
|
43867
43909
|
return Number(tick.value);
|
|
43868
43910
|
});
|
|
43911
|
+
var legendTooltipItems = [{
|
|
43912
|
+
visibleYKeys: visibleYKeys,
|
|
43913
|
+
legendItems: chart.areas,
|
|
43914
|
+
conditionalFormattingRules: chart.conditionalFormattingRules
|
|
43915
|
+
}];
|
|
43869
43916
|
return jsxRuntime.jsxs(React__default.Fragment, {
|
|
43870
43917
|
children: [jsxRuntime.jsxs(ChartWrapper$1, {
|
|
43871
43918
|
width: width,
|
|
@@ -44021,23 +44068,19 @@ var AreaChart$5 = function AreaChart(_ref) {
|
|
|
44021
44068
|
width: innerWidth
|
|
44022
44069
|
})]
|
|
44023
44070
|
}), options.showLegend && jsxRuntime.jsx(Legend$1, {
|
|
44024
|
-
|
|
44025
|
-
visibleYKeys: visibleYKeys,
|
|
44071
|
+
items: legendTooltipItems,
|
|
44026
44072
|
setVisibleYKeys: setVisibleYKeys,
|
|
44027
44073
|
keys: chart.keys,
|
|
44028
|
-
conditionalFormattingRules: chart.conditionalFormattingRules,
|
|
44029
44074
|
marginLeft: margin.left - margin.leftTitleOffset
|
|
44030
44075
|
}), tooltipOpen && tooltipData && xKey && jsxRuntime.jsx(Tooltip$1, {
|
|
44076
|
+
items: legendTooltipItems,
|
|
44031
44077
|
tooltipData: tooltipData,
|
|
44032
44078
|
tooltipLeft: tooltipLeft,
|
|
44033
44079
|
tooltipTop: tooltipTop,
|
|
44034
44080
|
xKey: xKey,
|
|
44035
44081
|
keys: chart.keys,
|
|
44036
|
-
visibleYKeys: visibleYKeys,
|
|
44037
44082
|
yKeys: chart.y.keys,
|
|
44038
|
-
legendItems: chart.areas,
|
|
44039
44083
|
showRoundedTotal: options.showRoundedTotal,
|
|
44040
|
-
conditionalFormattingRules: chart.conditionalFormattingRules,
|
|
44041
44084
|
theme: themeCSS.popoverMenus
|
|
44042
44085
|
})]
|
|
44043
44086
|
});
|
|
@@ -44340,11 +44383,13 @@ var RadarChart$2 = function RadarChart(_ref) {
|
|
|
44340
44383
|
})]
|
|
44341
44384
|
})
|
|
44342
44385
|
}), options.showLegend && jsxRuntime.jsx(Legend$1, {
|
|
44343
|
-
|
|
44344
|
-
|
|
44386
|
+
items: [{
|
|
44387
|
+
legendItems: chart.lines,
|
|
44388
|
+
visibleYKeys: visibleYKeys,
|
|
44389
|
+
conditionalFormattingRules: []
|
|
44390
|
+
}],
|
|
44345
44391
|
setVisibleYKeys: setVisibleYKeys,
|
|
44346
44392
|
keys: chart.keys,
|
|
44347
|
-
conditionalFormattingRules: [],
|
|
44348
44393
|
marginLeft: margin.left - margin.leftTitleOffset
|
|
44349
44394
|
})]
|
|
44350
44395
|
});
|
|
@@ -49289,11 +49334,13 @@ var Legend$2 = function Legend(_ref) {
|
|
|
49289
49334
|
};
|
|
49290
49335
|
if (!showLegend) return null;
|
|
49291
49336
|
return jsxRuntime.jsx(Legend$1, {
|
|
49292
|
-
|
|
49293
|
-
|
|
49337
|
+
items: [{
|
|
49338
|
+
legendItems: items,
|
|
49339
|
+
visibleYKeys: ['increase', 'decrease'],
|
|
49340
|
+
conditionalFormattingRules: []
|
|
49341
|
+
}],
|
|
49294
49342
|
keys: keys,
|
|
49295
49343
|
marginLeft: margin.left - margin.leftTitleOffset,
|
|
49296
|
-
conditionalFormattingRules: [],
|
|
49297
49344
|
setVisibleYKeys: function setVisibleYKeys() {}
|
|
49298
49345
|
});
|
|
49299
49346
|
};
|