@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.
@@ -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' || type === 'multiSelectFilter') {
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, _partialFeatureToggle3;
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 && featureToggles.simpleMultiSelectFilter) {
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
- if (featureToggles.simpleMultiSelectFilter) {
38084
- filterTypes.push({
38085
- label: textOverride('multi_select', 'Multi select'),
38086
- value: MULTI_SELECT_FILTER,
38087
- subText: textOverride('multi_select_description', 'Allow multiple selections.')
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
- conditionalFormattingRules = _ref.conditionalFormattingRules,
42329
- theme = _ref.theme;
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,{"version":3,"sources":["Tooltip.tsx"],"names":[],"mappings":"AAyF+B","file":"Tooltip.tsx","sourcesContent":["import React, { CSSProperties, useEffect, useRef, useState } from 'react';\nimport { createPortal } from 'react-dom';\n\nimport { getColor } from '../../utils';\nimport { LegendItemBox } from '../Legend/LegendItemBox';\nimport { ShapeDefinition, ConditionalFormattingRule, DataItem, Key } from 'shared-logic/src/ChartsV2/types';\nimport { LineStyles } from 'shared-logic/src/LineChartV2/types';\nimport { BarStyles } from 'shared-logic/src/BarChartV2/types';\nimport { AreaStyles } from 'shared-logic/src/AreaChartV2/types';\nimport { css } from '@emotion/css';\n\nconst MIN_TOOLTIP_WIDTH = 180;\nconst TOOLTIP_OFFSET = 20;\nconst SCROLLBAR_WIDTH = 40;\ninterface TooltipProps<T> {\n    keys: { [key: string]: Key };\n    legendItems: Array<ShapeDefinition<T>>;\n    showRoundedTotal: boolean;\n    tooltipData: {\n        [keyId: string]: DataItem;\n    };\n    tooltipLeft: number;\n    tooltipTop: number;\n    visibleYKeys: string[];\n    xKey: string;\n    yKeys: string[];\n    conditionalFormattingRules: Array<ConditionalFormattingRule>;\n    theme: CSSProperties;\n}\n\nexport const Tooltip = ({\n    keys,\n    legendItems,\n    showRoundedTotal,\n    tooltipData,\n    tooltipLeft,\n    tooltipTop,\n    visibleYKeys,\n    xKey,\n    yKeys,\n    conditionalFormattingRules,\n    theme,\n}: TooltipProps<LineStyles | BarStyles | AreaStyles>) => {\n    const tooltipRef = useRef<HTMLDivElement>(null);\n    const [position, setPosition] = useState<{ left: number }>({\n        left: tooltipLeft,\n    });\n\n    useEffect(() => {\n        const adjustTooltipPosition = () => {\n            const tooltipElement = tooltipRef.current;\n\n            if (tooltipElement) {\n                const screenWidth = window.innerWidth;\n\n                const rect = tooltipElement.getBoundingClientRect();\n\n                let width = rect.width;\n\n                if (width < MIN_TOOLTIP_WIDTH) {\n                    width = MIN_TOOLTIP_WIDTH;\n                }\n\n                let left = tooltipLeft + TOOLTIP_OFFSET;\n\n                if (tooltipLeft + width > screenWidth - SCROLLBAR_WIDTH) {\n                    left = tooltipLeft - width - TOOLTIP_OFFSET;\n                }\n\n                setPosition({ left });\n            }\n        };\n\n        adjustTooltipPosition();\n    }, [tooltipLeft]);\n\n    return createPortal(\n        <div\n            ref={tooltipRef}\n            style={{\n                position: 'absolute',\n                left: position.left,\n                top: tooltipTop,\n                zIndex: 2147483647 * 10,\n                ...theme,\n            }}\n        >\n            <div style={{ wordBreak: 'break-all' }}>\n                <div\n                    className={css({\n                        fontFamily: 'inherit',\n                        lineHeight: 'inherit',\n                        letterSpacing: 'inherit',\n                        fontWeight: 'bold',\n                        fontSize: '15px',\n                        width: '100%',\n                        minWidth: MIN_TOOLTIP_WIDTH,\n                    })}\n                >\n                    {tooltipData[xKey].formattedValue ?? tooltipData[xKey].value}\n                </div>\n                <table\n                    cellPadding={0}\n                    cellSpacing={0}\n                    className={css({\n                        margin: '0',\n                        borderSpacing: '0',\n                        borderCollapse: 'inherit',\n                        border: 'none',\n                    })}\n                >\n                    <tbody>\n                        {legendItems.map((legendItem, index) => {\n                            if (!tooltipData[legendItem.yKey] || tooltipData[legendItem.yKey].value === null) {\n                                // yKey could not be found in tooltipData\n                                return null;\n                            }\n                            return (\n                                visibleYKeys.includes(legendItem.yKey) && (\n                                    <tr key={legendItem.yKey}>\n                                        <td\n                                            style={{\n                                                verticalAlign: 'middle',\n                                                padding: index === 0 ? '12px 8px 0 0' : '8px 8px 0 0',\n                                                width: 'auto',\n                                            }}\n                                        >\n                                            <LegendItemBox\n                                                color={getColor({\n                                                    defaultColor: legendItem.color,\n                                                    value: tooltipData[legendItem.yKey].value,\n                                                    yKey: legendItem.yKey,\n                                                    conditionalFormattingRules,\n                                                })}\n                                                style={legendItem.style as LineStyles}\n                                                yKey={legendItem.yKey}\n                                            />\n                                        </td>\n                                        <td style={{ padding: '8px 0 0 0' }}>{keys[legendItem.yKey].keyFormatted}</td>\n                                        <td style={{ fontWeight: 'bold', padding: '8px 0 0 16px' }}>\n                                            {tooltipData[legendItem.yKey].formattedValue\n                                                ? tooltipData[legendItem.yKey].formattedValue\n                                                : tooltipData[legendItem.yKey].value}\n                                        </td>\n                                    </tr>\n                                )\n                            );\n                        }\n                        )}\n                        {showRoundedTotal && (\n                            <tr>\n                                <td colSpan={2} style={{ padding: '12px 0 0 0' }}>\n                                    Rounded Total\n                                </td>\n                                <td style={{ fontWeight: 'bold', padding: '12px 0 0 16px' }}>\n                                    {yKeys.reduce((total, key) => {\n                                        return total + Math.round(tooltipData[key].value as number);\n                                    }, 0)}\n                                </td>\n                            </tr>\n                        )}\n                    </tbody>\n                </table>\n            </div>\n        </div>,\n        document.body\n    );\n};\n"]} */"),
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,{"version":3,"sources":["Tooltip.tsx"],"names":[],"mappings":"AAwG+B","file":"Tooltip.tsx","sourcesContent":["import React, { CSSProperties, useEffect, useRef, useState } from 'react';\nimport { createPortal } from 'react-dom';\n\nimport { getColor } from '../../utils';\nimport { LegendItemBox } from '../Legend/LegendItemBox';\nimport { ShapeDefinition, ConditionalFormattingRule, DataItem, Key } from 'shared-logic/src/ChartsV2/types';\nimport { LineStyles } from 'shared-logic/src/LineChartV2/types';\nimport { BarStyles } from 'shared-logic/src/BarChartV2/types';\nimport { AreaStyles } from 'shared-logic/src/AreaChartV2/types';\nimport { css } from '@emotion/css';\n\nconst MIN_TOOLTIP_WIDTH = 180;\nconst TOOLTIP_OFFSET = 20;\nconst SCROLLBAR_WIDTH = 40;\ninterface TooltipProps<T> {\n    keys: { [key: string]: Key };\n    legendItems: Array<ShapeDefinition<T>>;\n    showRoundedTotal: boolean;\n    tooltipData: {\n        [keyId: string]: DataItem;\n    };\n    tooltipLeft: number;\n    tooltipTop: number;\n    visibleYKeys: string[];\n    xKey: string;\n    yKeys: string[];\n    conditionalFormattingRules: Array<ConditionalFormattingRule>;\n    theme: CSSProperties;\n}\n\nexport const Tooltip = ({\n    keys,\n    legendItems,\n    showRoundedTotal,\n    tooltipData,\n    tooltipLeft,\n    tooltipTop,\n    visibleYKeys,\n    xKey,\n    yKeys,\n    conditionalFormattingRules,\n    theme,\n}: TooltipProps<LineStyles | BarStyles | AreaStyles>) => {\n    const tooltipRef = useRef<HTMLDivElement>(null);\n    const [position, setPosition] = useState<{ left: number }>({\n        left: tooltipLeft,\n    });\n\n    useEffect(() => {\n        const adjustTooltipPosition = () => {\n            const tooltipElement = tooltipRef.current;\n\n            if (tooltipElement) {\n                const screenWidth = window.innerWidth;\n\n                const rect = tooltipElement.getBoundingClientRect();\n\n                let width = rect.width;\n\n                if (width < MIN_TOOLTIP_WIDTH) {\n                    width = MIN_TOOLTIP_WIDTH;\n                }\n\n                let left = tooltipLeft + TOOLTIP_OFFSET;\n\n                if (tooltipLeft + width > screenWidth - SCROLLBAR_WIDTH) {\n                    left = tooltipLeft - width - TOOLTIP_OFFSET;\n                }\n\n                setPosition({ left });\n            }\n        };\n\n        adjustTooltipPosition();\n    }, [tooltipLeft]);\n\n    return createPortal(\n        <div\n            ref={tooltipRef}\n            style={{\n                position: 'absolute',\n                left: position.left,\n                top: tooltipTop,\n                zIndex: 2147483647 * 10,\n                ...theme,\n            }}\n        >\n            <div style={{ wordBreak: 'break-all' }}>\n                <div\n                    className={css({\n                        fontFamily: 'inherit',\n                        lineHeight: 'inherit',\n                        letterSpacing: 'inherit',\n                        fontWeight: 'bold',\n                        fontSize: '15px',\n                        width: '100%',\n                        minWidth: MIN_TOOLTIP_WIDTH,\n                    })}\n                >\n                    {tooltipData[xKey].formattedValue ?? tooltipData[xKey].value}\n                </div>\n                <table\n                    cellPadding={0}\n                    cellSpacing={0}\n                    className={css({\n                        margin: '0',\n                        borderSpacing: '0',\n                        borderCollapse: 'inherit',\n                        border: 'none',\n                    })}\n                >\n                    <tbody>\n                        {legendItems.map((legendItem, index) => {\n                            if (!tooltipData[legendItem.yKey] || tooltipData[legendItem.yKey].value === null) {\n                                // yKey could not be found in tooltipData\n                                return null;\n                            }\n                            return (\n                                visibleYKeys.includes(legendItem.yKey) && (\n                                    <tr key={legendItem.yKey}>\n                                        <td\n                                            style={{\n                                                verticalAlign: 'middle',\n                                                padding: index === 0 ? '12px 8px 0 0' : '8px 8px 0 0',\n                                                width: 'auto',\n                                            }}\n                                        >\n                                            <LegendItemBox\n                                                color={getColor({\n                                                    defaultColor: legendItem.color,\n                                                    value: tooltipData[legendItem.yKey].value,\n                                                    yKey: legendItem.yKey,\n                                                    conditionalFormattingRules,\n                                                })}\n                                                style={legendItem.style as LineStyles}\n                                                yKey={legendItem.yKey}\n                                            />\n                                        </td>\n                                        <td style={{ padding: '8px 0 0 0' }}>{keys[legendItem.yKey].keyFormatted}</td>\n                                        <td style={{ fontWeight: 'bold', padding: '8px 0 0 16px' }}>\n                                            {tooltipData[legendItem.yKey].formattedValue\n                                                ? tooltipData[legendItem.yKey].formattedValue\n                                                : tooltipData[legendItem.yKey].value}\n                                        </td>\n                                    </tr>\n                                )\n                            );\n                        }\n                        )}\n                        {showRoundedTotal && (\n                            <tr>\n                                <td colSpan={2} style={{ padding: '12px 0 0 0' }}>\n                                    Rounded Total\n                                </td>\n                                <td style={{ fontWeight: 'bold', padding: '12px 0 0 16px' }}>\n                                    {yKeys.reduce((total, key) => {\n                                        return total + Math.round(tooltipData[key].value as number);\n                                    }, 0)}\n                                </td>\n                            </tr>\n                        )}\n                    </tbody>\n                </table>\n            </div>\n        </div>,\n        document.body\n    );\n};\n"]} */",
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: [legendItems.map(function (legendItem, index) {
42391
- if (!tooltipData[legendItem.yKey] || tooltipData[legendItem.yKey].value === null) {
42392
- // yKey could not be found in tooltipData
42393
- return null;
42394
- }
42395
- return visibleYKeys.includes(legendItem.yKey) && jsxRuntime.jsxs("tr", {
42396
- children: [jsxRuntime.jsx("td", {
42397
- style: {
42398
- verticalAlign: 'middle',
42399
- padding: index === 0 ? '12px 8px 0 0' : '8px 8px 0 0',
42400
- width: 'auto'
42401
- },
42402
- children: jsxRuntime.jsx(LegendItemBox, {
42403
- color: getColor({
42404
- defaultColor: legendItem.color,
42405
- value: tooltipData[legendItem.yKey].value,
42406
- yKey: legendItem.yKey,
42407
- conditionalFormattingRules: conditionalFormattingRules
42408
- }),
42409
- style: legendItem.style,
42410
- yKey: legendItem.yKey
42411
- })
42412
- }), jsxRuntime.jsx("td", {
42413
- style: {
42414
- padding: '8px 0 0 0'
42415
- },
42416
- children: keys[legendItem.yKey].keyFormatted
42417
- }), jsxRuntime.jsx("td", {
42418
- style: {
42419
- fontWeight: 'bold',
42420
- padding: '8px 0 0 16px'
42421
- },
42422
- children: tooltipData[legendItem.yKey].formattedValue ? tooltipData[legendItem.yKey].formattedValue : tooltipData[legendItem.yKey].value
42423
- })]
42424
- }, legendItem.yKey);
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
- conditionalFormattingRules = _ref.conditionalFormattingRules,
42542
- marginLeft = _ref.marginLeft;
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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNEJvQiIsImZpbGUiOiJMZWdlbmQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcblxuaW1wb3J0IHsgTGVnZW5kSXRlbSB9IGZyb20gJy4vTGVnZW5kSXRlbSc7XG5pbXBvcnQgeyBTaGFwZURlZmluaXRpb24sIENvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGUsIEtleSB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQ2hhcnRzVjIvdHlwZXMnO1xuaW1wb3J0IHsgU2Nyb2xsYmFyIH0gZnJvbSAnLi4vLi4vLi4vU2Nyb2xsYmFyL1Njcm9sbGJhcic7XG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9jc3MnO1xuaW1wb3J0IHsgQmFyU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9CYXJDaGFydFYyL3R5cGVzJztcbmltcG9ydCB7IExpbmVTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0xpbmVDaGFydFYyL3R5cGVzJztcbmltcG9ydCB7IEFyZWFTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0FyZWFDaGFydFYyL3R5cGVzJztcblxuaW50ZXJmYWNlIExlZ2VuZFByb3BzPFQ+IHtcbiAgc2V0VmlzaWJsZVlLZXlzOiBSZWFjdC5EaXNwYXRjaDxSZWFjdC5TZXRTdGF0ZUFjdGlvbjxBcnJheTxzdHJpbmc+Pj47XG4gIHZpc2libGVZS2V5czogQXJyYXk8c3RyaW5nPjtcbiAga2V5czogeyBba2V5OiBzdHJpbmddOiBLZXkgfTtcbiAgbGVnZW5kSXRlbXM6IEFycmF5PFNoYXBlRGVmaW5pdGlvbjxUPj47XG4gIGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzOiBBcnJheTxDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlPjtcbiAgbWFyZ2luTGVmdDogbnVtYmVyO1xufVxuXG5leHBvcnQgY29uc3QgTGVnZW5kID0gKHtcbiAga2V5cyxcbiAgdmlzaWJsZVlLZXlzLFxuICBsZWdlbmRJdGVtcyxcbiAgc2V0VmlzaWJsZVlLZXlzLFxuICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlcyxcbiAgbWFyZ2luTGVmdCxcbn06IExlZ2VuZFByb3BzPEJhclN0eWxlcyB8IExpbmVTdHlsZXMgfCBBcmVhU3R5bGVzPikgPT4ge1xuICByZXR1cm4gKFxuICAgIDxkaXYgY2xhc3NOYW1lPXtjc3MoeyBoZWlnaHQ6IDQwLCBwYWRkaW5nVG9wOiA4IH0pfT5cbiAgICAgIDxTY3JvbGxiYXJcbiAgICAgICAgY2xhc3NOYW1lPXtjc3Moe1xuICAgICAgICAgIGRpc3BsYXk6ICdmbGV4JyxcbiAgICAgICAgICBmbGV4RGlyZWN0aW9uOiAncm93JyxcbiAgICAgICAgICBmbGV4V3JhcDogJ25vd3JhcCcsXG4gICAgICAgICAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG4gICAgICAgICAgbWFyZ2luTGVmdDogbWFyZ2luTGVmdCA/IGAke21hcmdpbkxlZnR9cHhgIDogdW5kZWZpbmVkLFxuICAgICAgICB9KX1cbiAgICAgICAgeD17dHJ1ZX1cbiAgICAgID5cbiAgICAgICAge2xlZ2VuZEl0ZW1zLm1hcChcbiAgICAgICAgICBsZWdlbmRJdGVtID0+XG4gICAgICAgICAgICBrZXlzW2xlZ2VuZEl0ZW0ueUtleV0gJiYgKFxuICAgICAgICAgICAgICA8TGVnZW5kSXRlbVxuICAgICAgICAgICAgICAgIHsuLi5sZWdlbmRJdGVtfVxuICAgICAgICAgICAgICAgIGtleT17YGxlZ2VuZC0ke2xlZ2VuZEl0ZW0ueUtleX1gfVxuICAgICAgICAgICAgICAgIHlLZXlGb3JtYXR0ZWQ9e2tleXNbbGVnZW5kSXRlbS55S2V5XS5rZXlGb3JtYXR0ZWR9XG4gICAgICAgICAgICAgICAgb25DbGljaz17KCkgPT5cbiAgICAgICAgICAgICAgICAgIHNldFZpc2libGVZS2V5cyhwcmV2ID0+IHtcbiAgICAgICAgICAgICAgICAgICAgbGV0IG5ld1Zpc2libGVMZWdlbmRJdGVtczogQXJyYXk8c3RyaW5nPiA9IFtdO1xuXG4gICAgICAgICAgICAgICAgICAgIGlmIChwcmV2Lmxlbmd0aCA9PT0gbGVnZW5kSXRlbXMubGVuZ3RoKSB7XG4gICAgICAgICAgICAgICAgICAgICAgbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zID0gW2xlZ2VuZEl0ZW0ueUtleV07XG4gICAgICAgICAgICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICAgICAgICAgICAgaWYgKHByZXYuaW5jbHVkZXMobGVnZW5kSXRlbS55S2V5KSkge1xuICAgICAgICAgICAgICAgICAgICAgICAgbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zID0gcHJldi5maWx0ZXIocHJldkxlZ2VuZEl0ZW1JZCA9PiBwcmV2TGVnZW5kSXRlbUlkICE9PSBsZWdlbmRJdGVtLnlLZXkpO1xuICAgICAgICAgICAgICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICAgICAgICAgICAgICBuZXdWaXNpYmxlTGVnZW5kSXRlbXMgPSBbLi4ucHJldiwgbGVnZW5kSXRlbS55S2V5XTtcbiAgICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgICAgICAgICByZXR1cm4gbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zLmxlbmd0aCA9PT0gMFxuICAgICAgICAgICAgICAgICAgICAgID8gbGVnZW5kSXRlbXMubWFwKGxlZ2VuZEl0ZW0gPT4gbGVnZW5kSXRlbS55S2V5KVxuICAgICAgICAgICAgICAgICAgICAgIDogbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zO1xuICAgICAgICAgICAgICAgICAgfSlcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgdmlzaWJsZT17dmlzaWJsZVlLZXlzLmluY2x1ZGVzKGxlZ2VuZEl0ZW0ueUtleSl9XG4gICAgICAgICAgICAgICAgY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXM9e2NvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzfVxuICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgKVxuICAgICAgICApfVxuICAgICAgPC9TY3JvbGxiYXI+XG4gICAgPC9kaXY+XG4gICk7XG59O1xuIl19 */",
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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBOEJtQiIsImZpbGUiOiJMZWdlbmQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcblxuaW1wb3J0IHsgTGVnZW5kSXRlbSB9IGZyb20gJy4vTGVnZW5kSXRlbSc7XG5pbXBvcnQgeyBTaGFwZURlZmluaXRpb24sIENvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGUsIEtleSB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQ2hhcnRzVjIvdHlwZXMnO1xuaW1wb3J0IHsgU2Nyb2xsYmFyIH0gZnJvbSAnLi4vLi4vLi4vU2Nyb2xsYmFyL1Njcm9sbGJhcic7XG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9jc3MnO1xuaW1wb3J0IHsgQmFyU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9CYXJDaGFydFYyL3R5cGVzJztcbmltcG9ydCB7IExpbmVTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0xpbmVDaGFydFYyL3R5cGVzJztcbmltcG9ydCB7IEFyZWFTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0FyZWFDaGFydFYyL3R5cGVzJztcblxuaW50ZXJmYWNlIExlZ2VuZFByb3BzPFQ+IHtcbiAgc2V0VmlzaWJsZVlLZXlzOiBSZWFjdC5EaXNwYXRjaDxSZWFjdC5TZXRTdGF0ZUFjdGlvbjxBcnJheTxzdHJpbmc+Pj47XG4gIHZpc2libGVZS2V5czogQXJyYXk8c3RyaW5nPjtcbiAga2V5czogeyBba2V5OiBzdHJpbmddOiBLZXkgfTtcbiAgbGVnZW5kSXRlbXM6IEFycmF5PFNoYXBlRGVmaW5pdGlvbjxUPj47XG4gIGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzOiBBcnJheTxDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlPjtcbiAgbWFyZ2luTGVmdDogbnVtYmVyO1xufVxuXG5leHBvcnQgY29uc3QgTGVnZW5kID0gKHtcbiAga2V5cyxcbiAgdmlzaWJsZVlLZXlzLFxuICBsZWdlbmRJdGVtcyxcbiAgc2V0VmlzaWJsZVlLZXlzLFxuICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlcyxcbiAgbWFyZ2luTGVmdCxcbn06IExlZ2VuZFByb3BzPEJhclN0eWxlcyB8IExpbmVTdHlsZXMgfCBBcmVhU3R5bGVzPikgPT4ge1xuICByZXR1cm4gKFxuICAgIDxkaXYgY2xhc3NOYW1lPXtjc3MoeyBoZWlnaHQ6IDQwLCBwYWRkaW5nVG9wOiA4IH0pfT5cbiAgICAgIDxTY3JvbGxiYXJcbiAgICAgICAgY2xhc3NOYW1lPXtjc3Moe1xuICAgICAgICAgIGRpc3BsYXk6ICdmbGV4JyxcbiAgICAgICAgICBmbGV4RGlyZWN0aW9uOiAncm93JyxcbiAgICAgICAgICBmbGV4V3JhcDogJ25vd3JhcCcsXG4gICAgICAgICAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG4gICAgICAgICAgbWFyZ2luTGVmdDogbWFyZ2luTGVmdCA/IGAke21hcmdpbkxlZnR9cHhgIDogdW5kZWZpbmVkLFxuICAgICAgICB9KX1cbiAgICAgICAgeD17dHJ1ZX1cbiAgICAgID5cbiAgICAgICAge2xlZ2VuZEl0ZW1zLm1hcChcbiAgICAgICAgICBsZWdlbmRJdGVtID0+XG4gICAgICAgICAgICBrZXlzW2xlZ2VuZEl0ZW0ueUtleV0gJiYgKFxuICAgICAgICAgICAgICA8TGVnZW5kSXRlbVxuICAgICAgICAgICAgICAgIHsuLi5sZWdlbmRJdGVtfVxuICAgICAgICAgICAgICAgIGtleT17YGxlZ2VuZC0ke2xlZ2VuZEl0ZW0ueUtleX1gfVxuICAgICAgICAgICAgICAgIHlLZXlGb3JtYXR0ZWQ9e2tleXNbbGVnZW5kSXRlbS55S2V5XS5rZXlGb3JtYXR0ZWR9XG4gICAgICAgICAgICAgICAgb25DbGljaz17KCkgPT5cbiAgICAgICAgICAgICAgICAgIHNldFZpc2libGVZS2V5cyhwcmV2ID0+IHtcbiAgICAgICAgICAgICAgICAgICAgbGV0IG5ld1Zpc2libGVMZWdlbmRJdGVtczogQXJyYXk8c3RyaW5nPiA9IFtdO1xuXG4gICAgICAgICAgICAgICAgICAgIGlmIChwcmV2Lmxlbmd0aCA9PT0gbGVnZW5kSXRlbXMubGVuZ3RoKSB7XG4gICAgICAgICAgICAgICAgICAgICAgbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zID0gW2xlZ2VuZEl0ZW0ueUtleV07XG4gICAgICAgICAgICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICAgICAgICAgICAgaWYgKHByZXYuaW5jbHVkZXMobGVnZW5kSXRlbS55S2V5KSkge1xuICAgICAgICAgICAgICAgICAgICAgICAgbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zID0gcHJldi5maWx0ZXIocHJldkxlZ2VuZEl0ZW1JZCA9PiBwcmV2TGVnZW5kSXRlbUlkICE9PSBsZWdlbmRJdGVtLnlLZXkpO1xuICAgICAgICAgICAgICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICAgICAgICAgICAgICBuZXdWaXNpYmxlTGVnZW5kSXRlbXMgPSBbLi4ucHJldiwgbGVnZW5kSXRlbS55S2V5XTtcbiAgICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgICAgICAgICByZXR1cm4gbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zLmxlbmd0aCA9PT0gMFxuICAgICAgICAgICAgICAgICAgICAgID8gbGVnZW5kSXRlbXMubWFwKGxlZ2VuZEl0ZW0gPT4gbGVnZW5kSXRlbS55S2V5KVxuICAgICAgICAgICAgICAgICAgICAgIDogbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zO1xuICAgICAgICAgICAgICAgICAgfSlcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgdmlzaWJsZT17dmlzaWJsZVlLZXlzLmluY2x1ZGVzKGxlZ2VuZEl0ZW0ueUtleSl9XG4gICAgICAgICAgICAgICAgY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXM9e2NvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzfVxuICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgKVxuICAgICAgICApfVxuICAgICAgPC9TY3JvbGxiYXI+XG4gICAgPC9kaXY+XG4gICk7XG59O1xuIl19 */"),
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: legendItems.map(function (legendItem) {
42560
- return keys[legendItem.yKey] && react.createElement(LegendItem, _extends({}, legendItem, {
42561
- key: "legend-" + legendItem.yKey,
42562
- yKeyFormatted: keys[legendItem.yKey].keyFormatted,
42563
- onClick: function onClick() {
42564
- return setVisibleYKeys(function (prev) {
42565
- var newVisibleLegendItems = [];
42566
- if (prev.length === legendItems.length) {
42567
- newVisibleLegendItems = [legendItem.yKey];
42568
- } else {
42569
- if (prev.includes(legendItem.yKey)) {
42570
- newVisibleLegendItems = prev.filter(function (prevLegendItemId) {
42571
- return prevLegendItemId !== legendItem.yKey;
42572
- });
42573
- } else {
42574
- newVisibleLegendItems = [].concat(prev, [legendItem.yKey]);
42575
- }
42576
- }
42577
- return newVisibleLegendItems.length === 0 ? legendItems.map(function (legendItem) {
42578
- return legendItem.yKey;
42579
- }) : newVisibleLegendItems;
42580
- });
42581
- },
42582
- visible: visibleYKeys.includes(legendItem.yKey),
42583
- conditionalFormattingRules: conditionalFormattingRules
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, chart) {
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: chart.data,
42691
+ data: data,
42691
42692
  xScaleKey: xScaleKey,
42692
42693
  xScaleDataType: xScaleDataType,
42693
- yKeys: chart.y.keys
42694
+ yKeys: yKeys
42694
42695
  });
42695
42696
  } else {
42696
42697
  return [];
42697
42698
  }
42698
- }, [chart.data, xScaleKey, xScaleDataType, chart.y.keys]);
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 = React.useMemo(function () {
43113
- return scale.scaleLinear({
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.jsxs(group.Group, {
43181
- children: [chart.y.keys.map(function (yKey) {
43182
- var _chart$lines$filter$;
43183
- return jsxRuntime.jsx(shape.LinePath, {
43184
- visibility: visibleYKeys.includes(yKey) ? 'visible' : 'hidden',
43185
- data: dataFlattened,
43186
- x: function x(d) {
43187
- var _xScale;
43188
- // @ts-ignore
43189
- var xValue = d[xScaleKey];
43190
- var xValueAdjusted = xScaleDataType === 'date_time' ? new Date(xValue) : xScaleDataType === 'number' ? Number(xValue) : String(xValue);
43191
- // @ts-ignore
43192
- return (_xScale = xScale(xValueAdjusted)) != null ? _xScale : 0;
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
- legendItems: chart.lines,
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 = React.useMemo(function () {
43381
- if (xScaleDataType === 'string') {
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(shape.BarGroup, {
43538
+ children: [!options.stacked && jsxRuntime.jsx(BarGroup, {
43507
43539
  data: dataFlattened,
43508
43540
  keys: yScaleKeys,
43509
43541
  height: innerHeight,
43510
- x0: function x0(d) {
43511
- // @ts-ignore
43512
- var xValue = d[xScaleKey];
43513
- if (xScaleDataType === 'string') return xValue;
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
- color: function color() {
43526
- return '';
43527
- },
43528
- children: function children(barGroups) {
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
- legendItems: chart.bars,
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 = React.useMemo(function () {
43827
- return scale.scaleLinear({
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 : 'monotoneX'];
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
- legendItems: chart.areas,
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
- legendItems: chart.lines,
44344
- visibleYKeys: visibleYKeys,
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
- legendItems: items,
49293
- visibleYKeys: ['increase', 'decrease'],
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
  };