@vizzly/dashboard 0.14.4-dev-97acb8d43347ac757049612930b3f8e69e913e55 → 0.14.4-dev-452014891c726bda8e71210563e32bb225b30c86

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.
Files changed (26) hide show
  1. package/dist/charts/src/v2/components/Axis/AxisLeft.d.ts +2 -1
  2. package/dist/charts/src/v2/components/BarChart/BarChart.d.ts +18 -2
  3. package/dist/charts/src/v2/components/BarChart/useBarXScale.d.ts +2 -0
  4. package/dist/charts/src/v2/components/ComboChart/ComboChart.d.ts +22 -0
  5. package/dist/charts/src/v2/components/Legend/Legend.d.ts +7 -5
  6. package/dist/charts/src/v2/components/LineChart/LineChart.d.ts +16 -1
  7. package/dist/charts/src/v2/components/Tooltip/Tooltip.d.ts +6 -4
  8. package/dist/charts/src/v2/components/WaterfallChart/Legend.d.ts +3 -1
  9. package/dist/charts/src/v2/components/WaterfallChart/WaterfallChart.d.ts +3 -1
  10. package/dist/charts/src/v2/components/hooks/useFlattenedData.d.ts +3 -8
  11. package/dist/charts/src/v2/components/hooks/useYScale.d.ts +2 -0
  12. package/dist/charts/src/v2/constants/PADDING.d.ts +4 -0
  13. package/dist/charts/src/v2/{components/BarChart → utils}/getBarFill.d.ts +2 -2
  14. package/dist/dashboard/src/contexts/GlobalProvider/useGlobalProvider.d.ts +12 -12
  15. package/dist/dashboard.cjs.development.js +435 -344
  16. package/dist/dashboard.cjs.production.min.js +1 -1
  17. package/dist/dashboard.esm.js +440 -349
  18. package/dist/shared-logic/src/ChartsV2/types.d.ts +8 -7
  19. package/dist/shared-logic/src/ComboChartV2/types.d.ts +15 -0
  20. package/dist/shared-logic/src/Component/types.d.ts +2 -0
  21. package/dist/shared-logic/src/ComponentInterface/types/namespaces.types.d.ts +1 -0
  22. package/dist/shared-logic/src/FeatureToggle/types.d.ts +0 -3
  23. package/dist/shared-logic/src/FormatPanelConfig/types.d.ts +2 -1
  24. package/dist/shared-ui/src/library/StylePanel/WaterfallColorsSection.d.ts +7 -0
  25. package/package.json +1 -1
  26. package/dist/charts/src/v2/components/WaterfallChart/getBarFill.d.ts +0 -5
@@ -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;
@@ -10018,7 +10018,9 @@ var attributesSchema$h = function attributesSchema(config) {
10018
10018
  parameters: parametersSchema(config.queryEngineConfig, config.attributesSchemaOptions),
10019
10019
  axisTitles: axisTitleSchema(),
10020
10020
  headline: headlineSchema(),
10021
- tags: tagsSchema()
10021
+ tags: tagsSchema(),
10022
+ increaseColor: Joi.string().required(),
10023
+ decreaseColor: Joi.string().required()
10022
10024
  }));
10023
10025
  };
10024
10026
 
@@ -10182,6 +10184,11 @@ var CONSTANTS$j = {
10182
10184
  type: 'headline',
10183
10185
  title: 'Headline',
10184
10186
  description: ''
10187
+ },
10188
+ waterfall_colors: {
10189
+ type: 'waterfallColors',
10190
+ title: 'Color selector',
10191
+ description: ''
10185
10192
  }
10186
10193
  }
10187
10194
  };
@@ -10221,6 +10228,8 @@ var WaterfallChart = function WaterfallChart(config) {
10221
10228
  axisTitles: dumped.axisTitles,
10222
10229
  displaySubject: dumped.displaySubject,
10223
10230
  displayTitle: dumped.displayTitle,
10231
+ increaseColor: dumped.increaseColor,
10232
+ decreaseColor: dumped.decreaseColor,
10224
10233
  protectedByOrganisation: dumped.protectedByOrganisation,
10225
10234
  type: dumped.type,
10226
10235
  offset: dumped.offset
@@ -10255,6 +10264,8 @@ var WaterfallChart = function WaterfallChart(config) {
10255
10264
  parameters: {},
10256
10265
  axisTitles: undefined,
10257
10266
  headline: undefined,
10267
+ increaseColor: '#00FF00',
10268
+ decreaseColor: '#FF0000',
10258
10269
  tags: [],
10259
10270
  approxXAxisLabelCount: 'auto',
10260
10271
  approxYAxisLabelCount: 'auto'
@@ -10309,7 +10320,7 @@ var WaterfallChart = function WaterfallChart(config) {
10309
10320
  }), namespace(CONSTANTS$j, 'sort'), namespace(CONSTANTS$j, 'filter'), namespace(CONSTANTS$j, 'custom_metrics'), namespace(CONSTANTS$j, 'limit')];
10310
10321
  },
10311
10322
  formatPanelConfig: function formatPanelConfig() {
10312
- return [headingConstant(CONSTANTS$j), chartStylesConstant(CONSTANTS$j, false, false), axisLabelsConstants(CONSTANTS$j)];
10323
+ return [headingConstant(CONSTANTS$j), namespace(CONSTANTS$j, 'waterfall_colors'), chartStylesConstant(CONSTANTS$j, false, false), axisLabelsConstants(CONSTANTS$j)];
10313
10324
  },
10314
10325
  supportedCustomFields: {
10315
10326
  percentages: true,
@@ -13772,8 +13783,7 @@ var ADMIN_FEATURE_TOGGLES = {
13772
13783
  forceMobile: false,
13773
13784
  unloadOffScreenViews: false,
13774
13785
  showSavingIndicator: false,
13775
- disablePersistingGlobalFiltersLocally: false,
13776
- simpleMultiSelectFilter: false
13786
+ disablePersistingGlobalFiltersLocally: false
13777
13787
  };
13778
13788
  var END_USER_DEFAULT_FEATURE_TOGGLES = {
13779
13789
  parameters: true,
@@ -13810,8 +13820,7 @@ var END_USER_DEFAULT_FEATURE_TOGGLES = {
13810
13820
  forceMobile: false,
13811
13821
  unloadOffScreenViews: false,
13812
13822
  showSavingIndicator: true,
13813
- disablePersistingGlobalFiltersLocally: false,
13814
- simpleMultiSelectFilter: false
13823
+ disablePersistingGlobalFiltersLocally: false
13815
13824
  };
13816
13825
  var build$b = function build(partialFeatureToggles, queryEngineConfig, mode, scope) {
13817
13826
  var featureToggles = {};
@@ -13868,7 +13877,7 @@ var build$b = function build(partialFeatureToggles, queryEngineConfig, mode, sco
13868
13877
  return featureToggles;
13869
13878
  };
13870
13879
  var buildDefaults = function buildDefaults(partialFeatureToggles) {
13871
- var _partialFeatureToggle, _partialFeatureToggle2, _partialFeatureToggle3;
13880
+ var _partialFeatureToggle, _partialFeatureToggle2;
13872
13881
  return {
13873
13882
  showDateAndTimeFilter: partialFeatureToggles.showDateAndTimeFilter !== undefined ? partialFeatureToggles.showDateAndTimeFilter : true,
13874
13883
  showDateFilter: partialFeatureToggles.showDateFilter !== undefined ? partialFeatureToggles.showDateFilter : true,
@@ -13879,8 +13888,7 @@ var buildDefaults = function buildDefaults(partialFeatureToggles) {
13879
13888
  canDownloadViewAsPNG: partialFeatureToggles.canDownloadViewAsPNG !== undefined ? partialFeatureToggles.canDownloadViewAsPNG : true,
13880
13889
  forceMobile: partialFeatureToggles.forceMobile !== undefined ? partialFeatureToggles.forceMobile : false,
13881
13890
  unloadOffScreenViews: partialFeatureToggles.unloadOffScreenViews !== undefined ? partialFeatureToggles.unloadOffScreenViews : false,
13882
- allowCalculatedField: (_partialFeatureToggle2 = partialFeatureToggles.allowCalculatedField) != null ? _partialFeatureToggle2 : false,
13883
- simpleMultiSelectFilter: (_partialFeatureToggle3 = partialFeatureToggles.simpleMultiSelectFilter) != null ? _partialFeatureToggle3 : false
13891
+ allowCalculatedField: (_partialFeatureToggle2 = partialFeatureToggles.allowCalculatedField) != null ? _partialFeatureToggle2 : false
13884
13892
  };
13885
13893
  };
13886
13894
 
@@ -28844,8 +28852,7 @@ var AdditionalFilter = function AdditionalFilter(props) {
28844
28852
  onChange = props.onChange,
28845
28853
  shouldAlwaysHaveValue = props.shouldAlwaysHaveValue;
28846
28854
  var _useDashboardBehaviou = useDashboardBehaviourContext(),
28847
- queryEngineConfig = _useDashboardBehaviou.queryEngineConfig,
28848
- featureToggles = _useDashboardBehaviou.featureToggles;
28855
+ queryEngineConfig = _useDashboardBehaviou.queryEngineConfig;
28849
28856
 
28850
28857
  /** Validate the new filter before setting it */
28851
28858
  var onChangeWithValidation = function onChangeWithValidation(newFilter) {
@@ -28896,7 +28903,7 @@ var AdditionalFilter = function AdditionalFilter(props) {
28896
28903
  dataSets: props.dataSets
28897
28904
  }, typeof props.filter.value === 'boolean' ? undefined : JSON.stringify(props.filter.value));
28898
28905
  }
28899
- if (filter.type == MULTI_SELECT_FILTER && featureToggles.simpleMultiSelectFilter) {
28906
+ if (filter.type == MULTI_SELECT_FILTER) {
28900
28907
  return jsxRuntime.jsx(MultiSelectFilter, {
28901
28908
  showClearBtn: !shouldAlwaysHaveValue,
28902
28909
  filter: filter,
@@ -38080,13 +38087,11 @@ var AddFilterForm = function AddFilterForm(props) {
38080
38087
  value: SINGLE_SELECT_FILTER,
38081
38088
  subText: textOverride('single_select_filter_description', 'Choose a single option from the list to filter. ')
38082
38089
  }];
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
- }
38090
+ filterTypes.push({
38091
+ label: textOverride('multi_select', 'Multi select'),
38092
+ value: MULTI_SELECT_FILTER,
38093
+ subText: textOverride('multi_select_description', 'Allow multiple selections.')
38094
+ });
38090
38095
  filterTypes.push({
38091
38096
  label: textOverride('advanced_filter', 'Advanced filter'),
38092
38097
  value: ADVANCED_FILTER,
@@ -42317,16 +42322,14 @@ var SCROLLBAR_WIDTH = 40;
42317
42322
  var Tooltip$1 = function Tooltip(_ref) {
42318
42323
  var _tooltipData$xKey$for;
42319
42324
  var keys = _ref.keys,
42320
- legendItems = _ref.legendItems,
42321
42325
  showRoundedTotal = _ref.showRoundedTotal,
42322
42326
  tooltipData = _ref.tooltipData,
42323
42327
  tooltipLeft = _ref.tooltipLeft,
42324
42328
  tooltipTop = _ref.tooltipTop,
42325
- visibleYKeys = _ref.visibleYKeys,
42326
42329
  xKey = _ref.xKey,
42327
42330
  yKeys = _ref.yKeys,
42328
- conditionalFormattingRules = _ref.conditionalFormattingRules,
42329
- theme = _ref.theme;
42331
+ theme = _ref.theme,
42332
+ items = _ref.items;
42330
42333
  var tooltipRef = React.useRef(null);
42331
42334
  var _useState = React.useState({
42332
42335
  left: tooltipLeft
@@ -42375,7 +42378,7 @@ var Tooltip$1 = function Tooltip(_ref) {
42375
42378
  fontSize: '15px',
42376
42379
  width: '100%',
42377
42380
  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"]} */"),
42381
+ }, ";label:Tooltip;", "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlRvb2x0aXAudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTBGcUIiLCJmaWxlIjoiVG9vbHRpcC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgQ1NTUHJvcGVydGllcywgRnJhZ21lbnQsIHVzZUVmZmVjdCwgdXNlUmVmLCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IGNyZWF0ZVBvcnRhbCB9IGZyb20gJ3JlYWN0LWRvbSc7XG5cbmltcG9ydCB7IGdldENvbG9yIH0gZnJvbSAnLi4vLi4vdXRpbHMnO1xuaW1wb3J0IHsgTGVnZW5kSXRlbUJveCB9IGZyb20gJy4uL0xlZ2VuZC9MZWdlbmRJdGVtQm94JztcbmltcG9ydCB7IFNoYXBlRGVmaW5pdGlvbiwgQ29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZSwgRGF0YUl0ZW0sIEtleSB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQ2hhcnRzVjIvdHlwZXMnO1xuaW1wb3J0IHsgTGluZVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvTGluZUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQmFyU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9CYXJDaGFydFYyL3R5cGVzJztcbmltcG9ydCB7IEFyZWFTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0FyZWFDaGFydFYyL3R5cGVzJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5cbmNvbnN0IE1JTl9UT09MVElQX1dJRFRIID0gMTgwO1xuY29uc3QgVE9PTFRJUF9PRkZTRVQgPSAyMDtcbmNvbnN0IFNDUk9MTEJBUl9XSURUSCA9IDQwO1xuXG5pbnRlcmZhY2UgVG9vbHRpcFByb3BzPFQ+IHtcbiAga2V5czogeyBba2V5OiBzdHJpbmddOiBLZXkgfTtcbiAgc2hvd1JvdW5kZWRUb3RhbDogYm9vbGVhbjtcbiAgdG9vbHRpcERhdGE6IHtcbiAgICBba2V5SWQ6IHN0cmluZ106IERhdGFJdGVtO1xuICB9O1xuICB0b29sdGlwTGVmdDogbnVtYmVyO1xuICB0b29sdGlwVG9wOiBudW1iZXI7XG4gIHhLZXk6IHN0cmluZztcbiAgeUtleXM6IHN0cmluZ1tdO1xuICBpdGVtczoge1xuICAgIGxlZ2VuZEl0ZW1zOiBBcnJheTxTaGFwZURlZmluaXRpb248VD4+O1xuICAgIGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzOiBBcnJheTxDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlPjtcbiAgICB2aXNpYmxlWUtleXM6IHN0cmluZ1tdO1xuICB9W107XG4gIHRoZW1lOiBDU1NQcm9wZXJ0aWVzO1xufVxuXG5leHBvcnQgY29uc3QgVG9vbHRpcCA9ICh7XG4gIGtleXMsXG4gIHNob3dSb3VuZGVkVG90YWwsXG4gIHRvb2x0aXBEYXRhLFxuICB0b29sdGlwTGVmdCxcbiAgdG9vbHRpcFRvcCxcbiAgeEtleSxcbiAgeUtleXMsXG4gIHRoZW1lLFxuICBpdGVtcyxcbn06IFRvb2x0aXBQcm9wczxMaW5lU3R5bGVzIHwgQmFyU3R5bGVzIHwgQXJlYVN0eWxlcz4pID0+IHtcbiAgY29uc3QgdG9vbHRpcFJlZiA9IHVzZVJlZjxIVE1MRGl2RWxlbWVudD4obnVsbCk7XG4gIGNvbnN0IFtwb3NpdGlvbiwgc2V0UG9zaXRpb25dID0gdXNlU3RhdGU8eyBsZWZ0OiBudW1iZXIgfT4oe1xuICAgIGxlZnQ6IHRvb2x0aXBMZWZ0LFxuICB9KTtcblxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGNvbnN0IGFkanVzdFRvb2x0aXBQb3NpdGlvbiA9ICgpID0+IHtcbiAgICAgIGNvbnN0IHRvb2x0aXBFbGVtZW50ID0gdG9vbHRpcFJlZi5jdXJyZW50O1xuXG4gICAgICBpZiAodG9vbHRpcEVsZW1lbnQpIHtcbiAgICAgICAgY29uc3Qgc2NyZWVuV2lkdGggPSB3aW5kb3cuaW5uZXJXaWR0aDtcblxuICAgICAgICBjb25zdCByZWN0ID0gdG9vbHRpcEVsZW1lbnQuZ2V0Qm91bmRpbmdDbGllbnRSZWN0KCk7XG5cbiAgICAgICAgbGV0IHdpZHRoID0gcmVjdC53aWR0aDtcblxuICAgICAgICBpZiAod2lkdGggPCBNSU5fVE9PTFRJUF9XSURUSCkge1xuICAgICAgICAgIHdpZHRoID0gTUlOX1RPT0xUSVBfV0lEVEg7XG4gICAgICAgIH1cblxuICAgICAgICBsZXQgbGVmdCA9IHRvb2x0aXBMZWZ0ICsgVE9PTFRJUF9PRkZTRVQ7XG5cbiAgICAgICAgaWYgKHRvb2x0aXBMZWZ0ICsgd2lkdGggPiBzY3JlZW5XaWR0aCAtIFNDUk9MTEJBUl9XSURUSCkge1xuICAgICAgICAgIGxlZnQgPSB0b29sdGlwTGVmdCAtIHdpZHRoIC0gVE9PTFRJUF9PRkZTRVQ7XG4gICAgICAgIH1cblxuICAgICAgICBzZXRQb3NpdGlvbih7IGxlZnQgfSk7XG4gICAgICB9XG4gICAgfTtcblxuICAgIGFkanVzdFRvb2x0aXBQb3NpdGlvbigpO1xuICB9LCBbdG9vbHRpcExlZnRdKTtcblxuICByZXR1cm4gY3JlYXRlUG9ydGFsKFxuICAgIDxkaXZcbiAgICAgIHJlZj17dG9vbHRpcFJlZn1cbiAgICAgIHN0eWxlPXt7XG4gICAgICAgIHBvc2l0aW9uOiAnYWJzb2x1dGUnLFxuICAgICAgICBsZWZ0OiBwb3NpdGlvbi5sZWZ0LFxuICAgICAgICB0b3A6IHRvb2x0aXBUb3AsXG4gICAgICAgIHpJbmRleDogMjE0NzQ4MzY0NyAqIDEwLFxuICAgICAgICAuLi50aGVtZSxcbiAgICAgIH19XG4gICAgPlxuICAgICAgPGRpdiBzdHlsZT17eyB3b3JkQnJlYWs6ICdicmVhay1hbGwnIH19PlxuICAgICAgICA8ZGl2XG4gICAgICAgICAgY2xhc3NOYW1lPXtjc3Moe1xuICAgICAgICAgICAgZm9udEZhbWlseTogJ2luaGVyaXQnLFxuICAgICAgICAgICAgbGluZUhlaWdodDogJ2luaGVyaXQnLFxuICAgICAgICAgICAgbGV0dGVyU3BhY2luZzogJ2luaGVyaXQnLFxuICAgICAgICAgICAgZm9udFdlaWdodDogJ2JvbGQnLFxuICAgICAgICAgICAgZm9udFNpemU6ICcxNXB4JyxcbiAgICAgICAgICAgIHdpZHRoOiAnMTAwJScsXG4gICAgICAgICAgICBtaW5XaWR0aDogTUlOX1RPT0xUSVBfV0lEVEgsXG4gICAgICAgICAgfSl9XG4gICAgICAgID5cbiAgICAgICAgICB7dG9vbHRpcERhdGFbeEtleV0uZm9ybWF0dGVkVmFsdWUgPz8gdG9vbHRpcERhdGFbeEtleV0udmFsdWV9XG4gICAgICAgIDwvZGl2PlxuICAgICAgICA8dGFibGVcbiAgICAgICAgICBjZWxsUGFkZGluZz17MH1cbiAgICAgICAgICBjZWxsU3BhY2luZz17MH1cbiAgICAgICAgICBjbGFzc05hbWU9e2Nzcyh7XG4gICAgICAgICAgICBtYXJnaW46ICcwJyxcbiAgICAgICAgICAgIGJvcmRlclNwYWNpbmc6ICcwJyxcbiAgICAgICAgICAgIGJvcmRlckNvbGxhcHNlOiAnaW5oZXJpdCcsXG4gICAgICAgICAgICBib3JkZXI6ICdub25lJyxcbiAgICAgICAgICB9KX1cbiAgICAgICAgPlxuICAgICAgICAgIDx0Ym9keT5cbiAgICAgICAgICAgIHtpdGVtcy5tYXAoKGl0ZW0sIGluZGV4KSA9PiB7XG4gICAgICAgICAgICAgIHJldHVybiAoXG4gICAgICAgICAgICAgICAgPEZyYWdtZW50IGtleT17aW5kZXh9PlxuICAgICAgICAgICAgICAgICAge2l0ZW0ubGVnZW5kSXRlbXM/Lm1hcCgobGVnZW5kSXRlbSwgaW5kZXgpID0+IHtcbiAgICAgICAgICAgICAgICAgICAgaWYgKCF0b29sdGlwRGF0YVtsZWdlbmRJdGVtLnlLZXldIHx8IHRvb2x0aXBEYXRhW2xlZ2VuZEl0ZW0ueUtleV0udmFsdWUgPT09IG51bGwpIHtcbiAgICAgICAgICAgICAgICAgICAgICAvLyB5S2V5IGNvdWxkIG5vdCBiZSBmb3VuZCBpbiB0b29sdGlwRGF0YVxuICAgICAgICAgICAgICAgICAgICAgIHJldHVybiBudWxsO1xuICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICAgIHJldHVybiAoXG4gICAgICAgICAgICAgICAgICAgICAgaXRlbS52aXNpYmxlWUtleXM/LmluY2x1ZGVzKGxlZ2VuZEl0ZW0ueUtleSkgJiYgKFxuICAgICAgICAgICAgICAgICAgICAgICAgPHRyIGtleT17bGVnZW5kSXRlbS55S2V5fT5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgPHRkXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgc3R5bGU9e3tcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHZlcnRpY2FsQWxpZ246ICdtaWRkbGUnLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgcGFkZGluZzogaW5kZXggPT09IDAgPyAnMTJweCA4cHggMCAwJyA6ICc4cHggOHB4IDAgMCcsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICB3aWR0aDogJ2F1dG8nLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIH19XG4gICAgICAgICAgICAgICAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICA8TGVnZW5kSXRlbUJveFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgY29sb3I9e2dldENvbG9yKHtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgZGVmYXVsdENvbG9yOiBsZWdlbmRJdGVtLmNvbG9yLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB2YWx1ZTogdG9vbHRpcERhdGFbbGVnZW5kSXRlbS55S2V5XS52YWx1ZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgeUtleTogbGVnZW5kSXRlbS55S2V5LFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlczogaXRlbS5jb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlcyA/PyBbXSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIH0pfVxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgc3R5bGU9e2xlZ2VuZEl0ZW0uc3R5bGUgYXMgTGluZVN0eWxlc31cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHlLZXk9e2xlZ2VuZEl0ZW0ueUtleX1cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgICAgICAgICAgICAgICA8L3RkPlxuICAgICAgICAgICAgICAgICAgICAgICAgICA8dGQgc3R5bGU9e3sgcGFkZGluZzogJzhweCAwIDAgMCcgfX0+e2tleXNbbGVnZW5kSXRlbS55S2V5XS5rZXlGb3JtYXR0ZWR9PC90ZD5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgPHRkIHN0eWxlPXt7IGZvbnRXZWlnaHQ6ICdib2xkJywgcGFkZGluZzogJzhweCAwIDAgMTZweCcgfX0+XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAge3Rvb2x0aXBEYXRhW2xlZ2VuZEl0ZW0ueUtleV0uZm9ybWF0dGVkVmFsdWVcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgID8gdG9vbHRpcERhdGFbbGVnZW5kSXRlbS55S2V5XS5mb3JtYXR0ZWRWYWx1ZVxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgOiB0b29sdGlwRGF0YVtsZWdlbmRJdGVtLnlLZXldLnZhbHVlfVxuICAgICAgICAgICAgICAgICAgICAgICAgICA8L3RkPlxuICAgICAgICAgICAgICAgICAgICAgICAgPC90cj5cbiAgICAgICAgICAgICAgICAgICAgICApXG4gICAgICAgICAgICAgICAgICAgICk7XG4gICAgICAgICAgICAgICAgICB9KX1cbiAgICAgICAgICAgICAgICA8L0ZyYWdtZW50PlxuICAgICAgICAgICAgICApO1xuICAgICAgICAgICAgfSl9XG5cbiAgICAgICAgICAgIHtzaG93Um91bmRlZFRvdGFsICYmIChcbiAgICAgICAgICAgICAgPHRyPlxuICAgICAgICAgICAgICAgIDx0ZCBjb2xTcGFuPXsyfSBzdHlsZT17eyBwYWRkaW5nOiAnMTJweCAwIDAgMCcgfX0+XG4gICAgICAgICAgICAgICAgICBSb3VuZGVkIFRvdGFsXG4gICAgICAgICAgICAgICAgPC90ZD5cbiAgICAgICAgICAgICAgICA8dGQgc3R5bGU9e3sgZm9udFdlaWdodDogJ2JvbGQnLCBwYWRkaW5nOiAnMTJweCAwIDAgMTZweCcgfX0+XG4gICAgICAgICAgICAgICAgICB7eUtleXMucmVkdWNlKCh0b3RhbCwga2V5KSA9PiB7XG4gICAgICAgICAgICAgICAgICAgIHJldHVybiB0b3RhbCArIE1hdGgucm91bmQodG9vbHRpcERhdGFba2V5XS52YWx1ZSBhcyBudW1iZXIpO1xuICAgICAgICAgICAgICAgICAgfSwgMCl9XG4gICAgICAgICAgICAgICAgPC90ZD5cbiAgICAgICAgICAgICAgPC90cj5cbiAgICAgICAgICAgICl9XG4gICAgICAgICAgPC90Ym9keT5cbiAgICAgICAgPC90YWJsZT5cbiAgICAgIDwvZGl2PlxuICAgIDwvZGl2PixcbiAgICBkb2N1bWVudC5ib2R5XG4gICk7XG59O1xuIl19 */"),
42379
42382
  children: (_tooltipData$xKey$for = tooltipData[xKey].formattedValue) != null ? _tooltipData$xKey$for : tooltipData[xKey].value
42380
42383
  }), jsxRuntime.jsx("table", {
42381
42384
  cellPadding: 0,
@@ -42383,45 +42386,51 @@ var Tooltip$1 = function Tooltip(_ref) {
42383
42386
  className: /*#__PURE__*/css$1.css( {
42384
42387
  name: "9a1sa-Tooltip",
42385
42388
  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"]} */",
42389
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlRvb2x0aXAudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXlHcUIiLCJmaWxlIjoiVG9vbHRpcC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgQ1NTUHJvcGVydGllcywgRnJhZ21lbnQsIHVzZUVmZmVjdCwgdXNlUmVmLCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IGNyZWF0ZVBvcnRhbCB9IGZyb20gJ3JlYWN0LWRvbSc7XG5cbmltcG9ydCB7IGdldENvbG9yIH0gZnJvbSAnLi4vLi4vdXRpbHMnO1xuaW1wb3J0IHsgTGVnZW5kSXRlbUJveCB9IGZyb20gJy4uL0xlZ2VuZC9MZWdlbmRJdGVtQm94JztcbmltcG9ydCB7IFNoYXBlRGVmaW5pdGlvbiwgQ29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZSwgRGF0YUl0ZW0sIEtleSB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQ2hhcnRzVjIvdHlwZXMnO1xuaW1wb3J0IHsgTGluZVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvTGluZUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQmFyU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9CYXJDaGFydFYyL3R5cGVzJztcbmltcG9ydCB7IEFyZWFTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0FyZWFDaGFydFYyL3R5cGVzJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5cbmNvbnN0IE1JTl9UT09MVElQX1dJRFRIID0gMTgwO1xuY29uc3QgVE9PTFRJUF9PRkZTRVQgPSAyMDtcbmNvbnN0IFNDUk9MTEJBUl9XSURUSCA9IDQwO1xuXG5pbnRlcmZhY2UgVG9vbHRpcFByb3BzPFQ+IHtcbiAga2V5czogeyBba2V5OiBzdHJpbmddOiBLZXkgfTtcbiAgc2hvd1JvdW5kZWRUb3RhbDogYm9vbGVhbjtcbiAgdG9vbHRpcERhdGE6IHtcbiAgICBba2V5SWQ6IHN0cmluZ106IERhdGFJdGVtO1xuICB9O1xuICB0b29sdGlwTGVmdDogbnVtYmVyO1xuICB0b29sdGlwVG9wOiBudW1iZXI7XG4gIHhLZXk6IHN0cmluZztcbiAgeUtleXM6IHN0cmluZ1tdO1xuICBpdGVtczoge1xuICAgIGxlZ2VuZEl0ZW1zOiBBcnJheTxTaGFwZURlZmluaXRpb248VD4+O1xuICAgIGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzOiBBcnJheTxDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlPjtcbiAgICB2aXNpYmxlWUtleXM6IHN0cmluZ1tdO1xuICB9W107XG4gIHRoZW1lOiBDU1NQcm9wZXJ0aWVzO1xufVxuXG5leHBvcnQgY29uc3QgVG9vbHRpcCA9ICh7XG4gIGtleXMsXG4gIHNob3dSb3VuZGVkVG90YWwsXG4gIHRvb2x0aXBEYXRhLFxuICB0b29sdGlwTGVmdCxcbiAgdG9vbHRpcFRvcCxcbiAgeEtleSxcbiAgeUtleXMsXG4gIHRoZW1lLFxuICBpdGVtcyxcbn06IFRvb2x0aXBQcm9wczxMaW5lU3R5bGVzIHwgQmFyU3R5bGVzIHwgQXJlYVN0eWxlcz4pID0+IHtcbiAgY29uc3QgdG9vbHRpcFJlZiA9IHVzZVJlZjxIVE1MRGl2RWxlbWVudD4obnVsbCk7XG4gIGNvbnN0IFtwb3NpdGlvbiwgc2V0UG9zaXRpb25dID0gdXNlU3RhdGU8eyBsZWZ0OiBudW1iZXIgfT4oe1xuICAgIGxlZnQ6IHRvb2x0aXBMZWZ0LFxuICB9KTtcblxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGNvbnN0IGFkanVzdFRvb2x0aXBQb3NpdGlvbiA9ICgpID0+IHtcbiAgICAgIGNvbnN0IHRvb2x0aXBFbGVtZW50ID0gdG9vbHRpcFJlZi5jdXJyZW50O1xuXG4gICAgICBpZiAodG9vbHRpcEVsZW1lbnQpIHtcbiAgICAgICAgY29uc3Qgc2NyZWVuV2lkdGggPSB3aW5kb3cuaW5uZXJXaWR0aDtcblxuICAgICAgICBjb25zdCByZWN0ID0gdG9vbHRpcEVsZW1lbnQuZ2V0Qm91bmRpbmdDbGllbnRSZWN0KCk7XG5cbiAgICAgICAgbGV0IHdpZHRoID0gcmVjdC53aWR0aDtcblxuICAgICAgICBpZiAod2lkdGggPCBNSU5fVE9PTFRJUF9XSURUSCkge1xuICAgICAgICAgIHdpZHRoID0gTUlOX1RPT0xUSVBfV0lEVEg7XG4gICAgICAgIH1cblxuICAgICAgICBsZXQgbGVmdCA9IHRvb2x0aXBMZWZ0ICsgVE9PTFRJUF9PRkZTRVQ7XG5cbiAgICAgICAgaWYgKHRvb2x0aXBMZWZ0ICsgd2lkdGggPiBzY3JlZW5XaWR0aCAtIFNDUk9MTEJBUl9XSURUSCkge1xuICAgICAgICAgIGxlZnQgPSB0b29sdGlwTGVmdCAtIHdpZHRoIC0gVE9PTFRJUF9PRkZTRVQ7XG4gICAgICAgIH1cblxuICAgICAgICBzZXRQb3NpdGlvbih7IGxlZnQgfSk7XG4gICAgICB9XG4gICAgfTtcblxuICAgIGFkanVzdFRvb2x0aXBQb3NpdGlvbigpO1xuICB9LCBbdG9vbHRpcExlZnRdKTtcblxuICByZXR1cm4gY3JlYXRlUG9ydGFsKFxuICAgIDxkaXZcbiAgICAgIHJlZj17dG9vbHRpcFJlZn1cbiAgICAgIHN0eWxlPXt7XG4gICAgICAgIHBvc2l0aW9uOiAnYWJzb2x1dGUnLFxuICAgICAgICBsZWZ0OiBwb3NpdGlvbi5sZWZ0LFxuICAgICAgICB0b3A6IHRvb2x0aXBUb3AsXG4gICAgICAgIHpJbmRleDogMjE0NzQ4MzY0NyAqIDEwLFxuICAgICAgICAuLi50aGVtZSxcbiAgICAgIH19XG4gICAgPlxuICAgICAgPGRpdiBzdHlsZT17eyB3b3JkQnJlYWs6ICdicmVhay1hbGwnIH19PlxuICAgICAgICA8ZGl2XG4gICAgICAgICAgY2xhc3NOYW1lPXtjc3Moe1xuICAgICAgICAgICAgZm9udEZhbWlseTogJ2luaGVyaXQnLFxuICAgICAgICAgICAgbGluZUhlaWdodDogJ2luaGVyaXQnLFxuICAgICAgICAgICAgbGV0dGVyU3BhY2luZzogJ2luaGVyaXQnLFxuICAgICAgICAgICAgZm9udFdlaWdodDogJ2JvbGQnLFxuICAgICAgICAgICAgZm9udFNpemU6ICcxNXB4JyxcbiAgICAgICAgICAgIHdpZHRoOiAnMTAwJScsXG4gICAgICAgICAgICBtaW5XaWR0aDogTUlOX1RPT0xUSVBfV0lEVEgsXG4gICAgICAgICAgfSl9XG4gICAgICAgID5cbiAgICAgICAgICB7dG9vbHRpcERhdGFbeEtleV0uZm9ybWF0dGVkVmFsdWUgPz8gdG9vbHRpcERhdGFbeEtleV0udmFsdWV9XG4gICAgICAgIDwvZGl2PlxuICAgICAgICA8dGFibGVcbiAgICAgICAgICBjZWxsUGFkZGluZz17MH1cbiAgICAgICAgICBjZWxsU3BhY2luZz17MH1cbiAgICAgICAgICBjbGFzc05hbWU9e2Nzcyh7XG4gICAgICAgICAgICBtYXJnaW46ICcwJyxcbiAgICAgICAgICAgIGJvcmRlclNwYWNpbmc6ICcwJyxcbiAgICAgICAgICAgIGJvcmRlckNvbGxhcHNlOiAnaW5oZXJpdCcsXG4gICAgICAgICAgICBib3JkZXI6ICdub25lJyxcbiAgICAgICAgICB9KX1cbiAgICAgICAgPlxuICAgICAgICAgIDx0Ym9keT5cbiAgICAgICAgICAgIHtpdGVtcy5tYXAoKGl0ZW0sIGluZGV4KSA9PiB7XG4gICAgICAgICAgICAgIHJldHVybiAoXG4gICAgICAgICAgICAgICAgPEZyYWdtZW50IGtleT17aW5kZXh9PlxuICAgICAgICAgICAgICAgICAge2l0ZW0ubGVnZW5kSXRlbXM/Lm1hcCgobGVnZW5kSXRlbSwgaW5kZXgpID0+IHtcbiAgICAgICAgICAgICAgICAgICAgaWYgKCF0b29sdGlwRGF0YVtsZWdlbmRJdGVtLnlLZXldIHx8IHRvb2x0aXBEYXRhW2xlZ2VuZEl0ZW0ueUtleV0udmFsdWUgPT09IG51bGwpIHtcbiAgICAgICAgICAgICAgICAgICAgICAvLyB5S2V5IGNvdWxkIG5vdCBiZSBmb3VuZCBpbiB0b29sdGlwRGF0YVxuICAgICAgICAgICAgICAgICAgICAgIHJldHVybiBudWxsO1xuICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICAgIHJldHVybiAoXG4gICAgICAgICAgICAgICAgICAgICAgaXRlbS52aXNpYmxlWUtleXM/LmluY2x1ZGVzKGxlZ2VuZEl0ZW0ueUtleSkgJiYgKFxuICAgICAgICAgICAgICAgICAgICAgICAgPHRyIGtleT17bGVnZW5kSXRlbS55S2V5fT5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgPHRkXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgc3R5bGU9e3tcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHZlcnRpY2FsQWxpZ246ICdtaWRkbGUnLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgcGFkZGluZzogaW5kZXggPT09IDAgPyAnMTJweCA4cHggMCAwJyA6ICc4cHggOHB4IDAgMCcsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICB3aWR0aDogJ2F1dG8nLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIH19XG4gICAgICAgICAgICAgICAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICA8TGVnZW5kSXRlbUJveFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgY29sb3I9e2dldENvbG9yKHtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgZGVmYXVsdENvbG9yOiBsZWdlbmRJdGVtLmNvbG9yLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB2YWx1ZTogdG9vbHRpcERhdGFbbGVnZW5kSXRlbS55S2V5XS52YWx1ZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgeUtleTogbGVnZW5kSXRlbS55S2V5LFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlczogaXRlbS5jb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlcyA/PyBbXSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIH0pfVxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgc3R5bGU9e2xlZ2VuZEl0ZW0uc3R5bGUgYXMgTGluZVN0eWxlc31cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHlLZXk9e2xlZ2VuZEl0ZW0ueUtleX1cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgICAgICAgICAgICAgICA8L3RkPlxuICAgICAgICAgICAgICAgICAgICAgICAgICA8dGQgc3R5bGU9e3sgcGFkZGluZzogJzhweCAwIDAgMCcgfX0+e2tleXNbbGVnZW5kSXRlbS55S2V5XS5rZXlGb3JtYXR0ZWR9PC90ZD5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgPHRkIHN0eWxlPXt7IGZvbnRXZWlnaHQ6ICdib2xkJywgcGFkZGluZzogJzhweCAwIDAgMTZweCcgfX0+XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAge3Rvb2x0aXBEYXRhW2xlZ2VuZEl0ZW0ueUtleV0uZm9ybWF0dGVkVmFsdWVcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgID8gdG9vbHRpcERhdGFbbGVnZW5kSXRlbS55S2V5XS5mb3JtYXR0ZWRWYWx1ZVxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgOiB0b29sdGlwRGF0YVtsZWdlbmRJdGVtLnlLZXldLnZhbHVlfVxuICAgICAgICAgICAgICAgICAgICAgICAgICA8L3RkPlxuICAgICAgICAgICAgICAgICAgICAgICAgPC90cj5cbiAgICAgICAgICAgICAgICAgICAgICApXG4gICAgICAgICAgICAgICAgICAgICk7XG4gICAgICAgICAgICAgICAgICB9KX1cbiAgICAgICAgICAgICAgICA8L0ZyYWdtZW50PlxuICAgICAgICAgICAgICApO1xuICAgICAgICAgICAgfSl9XG5cbiAgICAgICAgICAgIHtzaG93Um91bmRlZFRvdGFsICYmIChcbiAgICAgICAgICAgICAgPHRyPlxuICAgICAgICAgICAgICAgIDx0ZCBjb2xTcGFuPXsyfSBzdHlsZT17eyBwYWRkaW5nOiAnMTJweCAwIDAgMCcgfX0+XG4gICAgICAgICAgICAgICAgICBSb3VuZGVkIFRvdGFsXG4gICAgICAgICAgICAgICAgPC90ZD5cbiAgICAgICAgICAgICAgICA8dGQgc3R5bGU9e3sgZm9udFdlaWdodDogJ2JvbGQnLCBwYWRkaW5nOiAnMTJweCAwIDAgMTZweCcgfX0+XG4gICAgICAgICAgICAgICAgICB7eUtleXMucmVkdWNlKCh0b3RhbCwga2V5KSA9PiB7XG4gICAgICAgICAgICAgICAgICAgIHJldHVybiB0b3RhbCArIE1hdGgucm91bmQodG9vbHRpcERhdGFba2V5XS52YWx1ZSBhcyBudW1iZXIpO1xuICAgICAgICAgICAgICAgICAgfSwgMCl9XG4gICAgICAgICAgICAgICAgPC90ZD5cbiAgICAgICAgICAgICAgPC90cj5cbiAgICAgICAgICAgICl9XG4gICAgICAgICAgPC90Ym9keT5cbiAgICAgICAgPC90YWJsZT5cbiAgICAgIDwvZGl2PlxuICAgIDwvZGl2PixcbiAgICBkb2N1bWVudC5ib2R5XG4gICk7XG59O1xuIl19 */",
42387
42390
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$5
42388
42391
  }),
42389
42392
  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);
42393
+ children: [items.map(function (item, index) {
42394
+ var _item$legendItems;
42395
+ return jsxRuntime.jsx(React.Fragment, {
42396
+ children: (_item$legendItems = item.legendItems) == null ? void 0 : _item$legendItems.map(function (legendItem, index) {
42397
+ var _item$visibleYKeys, _item$conditionalForm;
42398
+ if (!tooltipData[legendItem.yKey] || tooltipData[legendItem.yKey].value === null) {
42399
+ // yKey could not be found in tooltipData
42400
+ return null;
42401
+ }
42402
+ return ((_item$visibleYKeys = item.visibleYKeys) == null ? void 0 : _item$visibleYKeys.includes(legendItem.yKey)) && jsxRuntime.jsxs("tr", {
42403
+ children: [jsxRuntime.jsx("td", {
42404
+ style: {
42405
+ verticalAlign: 'middle',
42406
+ padding: index === 0 ? '12px 8px 0 0' : '8px 8px 0 0',
42407
+ width: 'auto'
42408
+ },
42409
+ children: jsxRuntime.jsx(LegendItemBox, {
42410
+ color: getColor({
42411
+ defaultColor: legendItem.color,
42412
+ value: tooltipData[legendItem.yKey].value,
42413
+ yKey: legendItem.yKey,
42414
+ conditionalFormattingRules: (_item$conditionalForm = item.conditionalFormattingRules) != null ? _item$conditionalForm : []
42415
+ }),
42416
+ style: legendItem.style,
42417
+ yKey: legendItem.yKey
42418
+ })
42419
+ }), jsxRuntime.jsx("td", {
42420
+ style: {
42421
+ padding: '8px 0 0 0'
42422
+ },
42423
+ children: keys[legendItem.yKey].keyFormatted
42424
+ }), jsxRuntime.jsx("td", {
42425
+ style: {
42426
+ fontWeight: 'bold',
42427
+ padding: '8px 0 0 16px'
42428
+ },
42429
+ children: tooltipData[legendItem.yKey].formattedValue ? tooltipData[legendItem.yKey].formattedValue : tooltipData[legendItem.yKey].value
42430
+ })]
42431
+ }, legendItem.yKey);
42432
+ })
42433
+ }, index);
42425
42434
  }), showRoundedTotal && jsxRuntime.jsxs("tr", {
42426
42435
  children: [jsxRuntime.jsx("td", {
42427
42436
  colSpan: 2,
@@ -42535,16 +42544,14 @@ var LegendItem = function LegendItem(_ref) {
42535
42544
  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
42545
  var Legend$1 = function Legend(_ref) {
42537
42546
  var keys = _ref.keys,
42538
- visibleYKeys = _ref.visibleYKeys,
42539
- legendItems = _ref.legendItems,
42540
42547
  setVisibleYKeys = _ref.setVisibleYKeys,
42541
- conditionalFormattingRules = _ref.conditionalFormattingRules,
42542
- marginLeft = _ref.marginLeft;
42548
+ marginLeft = _ref.marginLeft,
42549
+ items = _ref.items;
42543
42550
  return jsxRuntime.jsx("div", {
42544
42551
  className: /*#__PURE__*/css$1.css( {
42545
42552
  name: "qz6h7j-Legend",
42546
42553
  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 */",
42554
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNEJvQiIsImZpbGUiOiJMZWdlbmQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0LCB7IEZyYWdtZW50IH0gZnJvbSAncmVhY3QnO1xuXG5pbXBvcnQgeyBMZWdlbmRJdGVtIH0gZnJvbSAnLi9MZWdlbmRJdGVtJztcbmltcG9ydCB7IFNoYXBlRGVmaW5pdGlvbiwgQ29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZSwgS2V5IH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9DaGFydHNWMi90eXBlcyc7XG5pbXBvcnQgeyBTY3JvbGxiYXIgfSBmcm9tICcuLi8uLi8uLi9TY3JvbGxiYXIvU2Nyb2xsYmFyJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBCYXJTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0JhckNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgTGluZVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvTGluZUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQXJlYVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQXJlYUNoYXJ0VjIvdHlwZXMnO1xuXG5pbnRlcmZhY2UgTGVnZW5kUHJvcHM8VD4ge1xuICBzZXRWaXNpYmxlWUtleXM/OiBSZWFjdC5EaXNwYXRjaDxSZWFjdC5TZXRTdGF0ZUFjdGlvbjxBcnJheTxzdHJpbmc+Pj47XG4gIGtleXM6IHsgW2tleTogc3RyaW5nXTogS2V5IH07XG4gIG1hcmdpbkxlZnQ6IG51bWJlcjtcbiAgaXRlbXM/OiB7XG4gICAgbGVnZW5kSXRlbXM6IEFycmF5PFNoYXBlRGVmaW5pdGlvbjxUPj47XG4gICAgdmlzaWJsZVlLZXlzOiBBcnJheTxzdHJpbmc+O1xuICAgIGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzOiBBcnJheTxDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlPjtcbiAgfVtdO1xufVxuXG5leHBvcnQgY29uc3QgTGVnZW5kID0gKHtcbiAga2V5cyxcbiAgc2V0VmlzaWJsZVlLZXlzLFxuICBtYXJnaW5MZWZ0LFxuICBpdGVtcyxcbn06IExlZ2VuZFByb3BzPEJhclN0eWxlcyB8IExpbmVTdHlsZXMgfCBBcmVhU3R5bGVzPikgPT4ge1xuICByZXR1cm4gKFxuICAgIDxkaXYgY2xhc3NOYW1lPXtjc3MoeyBoZWlnaHQ6IDQwLCBwYWRkaW5nVG9wOiA4IH0pfT5cbiAgICAgIDxTY3JvbGxiYXJcbiAgICAgICAgY2xhc3NOYW1lPXtjc3Moe1xuICAgICAgICAgIGRpc3BsYXk6ICdmbGV4JyxcbiAgICAgICAgICBmbGV4RGlyZWN0aW9uOiAncm93JyxcbiAgICAgICAgICBmbGV4V3JhcDogJ25vd3JhcCcsXG4gICAgICAgICAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG4gICAgICAgICAgbWFyZ2luTGVmdDogbWFyZ2luTGVmdCA/IGAke21hcmdpbkxlZnR9cHhgIDogdW5kZWZpbmVkLFxuICAgICAgICB9KX1cbiAgICAgICAgeD17dHJ1ZX1cbiAgICAgID5cbiAgICAgICAge2l0ZW1zPy5tYXAoKGl0ZW0sIGluZGV4KSA9PiAoXG4gICAgICAgICAgPEZyYWdtZW50IGtleT17aW5kZXh9PlxuICAgICAgICAgICAge2l0ZW0ubGVnZW5kSXRlbXM/Lm1hcChcbiAgICAgICAgICAgICAgbGVnZW5kSXRlbSA9PlxuICAgICAgICAgICAgICAgIGtleXNbbGVnZW5kSXRlbS55S2V5XSAmJiAoXG4gICAgICAgICAgICAgICAgICA8TGVnZW5kSXRlbVxuICAgICAgICAgICAgICAgICAgICB7Li4ubGVnZW5kSXRlbX1cbiAgICAgICAgICAgICAgICAgICAga2V5PXtgbGVnZW5kLSR7bGVnZW5kSXRlbS55S2V5fWB9XG4gICAgICAgICAgICAgICAgICAgIHlLZXlGb3JtYXR0ZWQ9e2tleXNbbGVnZW5kSXRlbS55S2V5XS5rZXlGb3JtYXR0ZWR9XG4gICAgICAgICAgICAgICAgICAgIG9uQ2xpY2s9eygpID0+XG4gICAgICAgICAgICAgICAgICAgICAgc2V0VmlzaWJsZVlLZXlzICYmXG4gICAgICAgICAgICAgICAgICAgICAgc2V0VmlzaWJsZVlLZXlzKHByZXYgPT4ge1xuICAgICAgICAgICAgICAgICAgICAgICAgbGV0IG5ld1Zpc2libGVMZWdlbmRJdGVtczogQXJyYXk8c3RyaW5nPiA9IFtdO1xuXG4gICAgICAgICAgICAgICAgICAgICAgICBpZiAocHJldi5sZW5ndGggPT09IGl0ZW0ubGVnZW5kSXRlbXMubGVuZ3RoKSB7XG4gICAgICAgICAgICAgICAgICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IFtsZWdlbmRJdGVtLnlLZXldO1xuICAgICAgICAgICAgICAgICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgaWYgKHByZXYuaW5jbHVkZXMobGVnZW5kSXRlbS55S2V5KSkge1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IHByZXYuZmlsdGVyKFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgcHJldkxlZ2VuZEl0ZW1JZCA9PiBwcmV2TGVnZW5kSXRlbUlkICE9PSBsZWdlbmRJdGVtLnlLZXlcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICApO1xuICAgICAgICAgICAgICAgICAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IFsuLi5wcmV2LCBsZWdlbmRJdGVtLnlLZXldO1xuICAgICAgICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICAgICAgICB9XG5cbiAgICAgICAgICAgICAgICAgICAgICAgIHJldHVybiBuZXdWaXNpYmxlTGVnZW5kSXRlbXMubGVuZ3RoID09PSAwXG4gICAgICAgICAgICAgICAgICAgICAgICAgID8gaXRlbS5sZWdlbmRJdGVtcy5tYXAobGVnZW5kSXRlbSA9PiBsZWdlbmRJdGVtLnlLZXkpXG4gICAgICAgICAgICAgICAgICAgICAgICAgIDogbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zO1xuICAgICAgICAgICAgICAgICAgICAgIH0pXG4gICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICAgICAgdmlzaWJsZT17c2V0VmlzaWJsZVlLZXlzID8gaXRlbS52aXNpYmxlWUtleXMuaW5jbHVkZXMobGVnZW5kSXRlbS55S2V5KSA6IHRydWV9XG4gICAgICAgICAgICAgICAgICAgIGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzPXtpdGVtLmNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzfVxuICAgICAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgICAgICApXG4gICAgICAgICAgICApfVxuICAgICAgICAgIDwvRnJhZ21lbnQ+XG4gICAgICAgICkpfVxuICAgICAgPC9TY3JvbGxiYXI+XG4gICAgPC9kaXY+XG4gICk7XG59O1xuIl19 */",
42548
42555
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$7
42549
42556
  }),
42550
42557
  children: jsxRuntime.jsx(Scrollbar, {
@@ -42554,34 +42561,39 @@ var Legend$1 = function Legend(_ref) {
42554
42561
  flexWrap: 'nowrap',
42555
42562
  alignItems: 'center',
42556
42563
  marginLeft: marginLeft ? marginLeft + "px" : undefined
42557
- }, ";label:Legend;", "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBOEJtQiIsImZpbGUiOiJMZWdlbmQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcblxuaW1wb3J0IHsgTGVnZW5kSXRlbSB9IGZyb20gJy4vTGVnZW5kSXRlbSc7XG5pbXBvcnQgeyBTaGFwZURlZmluaXRpb24sIENvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGUsIEtleSB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQ2hhcnRzVjIvdHlwZXMnO1xuaW1wb3J0IHsgU2Nyb2xsYmFyIH0gZnJvbSAnLi4vLi4vLi4vU2Nyb2xsYmFyL1Njcm9sbGJhcic7XG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9jc3MnO1xuaW1wb3J0IHsgQmFyU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9CYXJDaGFydFYyL3R5cGVzJztcbmltcG9ydCB7IExpbmVTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0xpbmVDaGFydFYyL3R5cGVzJztcbmltcG9ydCB7IEFyZWFTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0FyZWFDaGFydFYyL3R5cGVzJztcblxuaW50ZXJmYWNlIExlZ2VuZFByb3BzPFQ+IHtcbiAgc2V0VmlzaWJsZVlLZXlzOiBSZWFjdC5EaXNwYXRjaDxSZWFjdC5TZXRTdGF0ZUFjdGlvbjxBcnJheTxzdHJpbmc+Pj47XG4gIHZpc2libGVZS2V5czogQXJyYXk8c3RyaW5nPjtcbiAga2V5czogeyBba2V5OiBzdHJpbmddOiBLZXkgfTtcbiAgbGVnZW5kSXRlbXM6IEFycmF5PFNoYXBlRGVmaW5pdGlvbjxUPj47XG4gIGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzOiBBcnJheTxDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlPjtcbiAgbWFyZ2luTGVmdDogbnVtYmVyO1xufVxuXG5leHBvcnQgY29uc3QgTGVnZW5kID0gKHtcbiAga2V5cyxcbiAgdmlzaWJsZVlLZXlzLFxuICBsZWdlbmRJdGVtcyxcbiAgc2V0VmlzaWJsZVlLZXlzLFxuICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlcyxcbiAgbWFyZ2luTGVmdCxcbn06IExlZ2VuZFByb3BzPEJhclN0eWxlcyB8IExpbmVTdHlsZXMgfCBBcmVhU3R5bGVzPikgPT4ge1xuICByZXR1cm4gKFxuICAgIDxkaXYgY2xhc3NOYW1lPXtjc3MoeyBoZWlnaHQ6IDQwLCBwYWRkaW5nVG9wOiA4IH0pfT5cbiAgICAgIDxTY3JvbGxiYXJcbiAgICAgICAgY2xhc3NOYW1lPXtjc3Moe1xuICAgICAgICAgIGRpc3BsYXk6ICdmbGV4JyxcbiAgICAgICAgICBmbGV4RGlyZWN0aW9uOiAncm93JyxcbiAgICAgICAgICBmbGV4V3JhcDogJ25vd3JhcCcsXG4gICAgICAgICAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG4gICAgICAgICAgbWFyZ2luTGVmdDogbWFyZ2luTGVmdCA/IGAke21hcmdpbkxlZnR9cHhgIDogdW5kZWZpbmVkLFxuICAgICAgICB9KX1cbiAgICAgICAgeD17dHJ1ZX1cbiAgICAgID5cbiAgICAgICAge2xlZ2VuZEl0ZW1zLm1hcChcbiAgICAgICAgICBsZWdlbmRJdGVtID0+XG4gICAgICAgICAgICBrZXlzW2xlZ2VuZEl0ZW0ueUtleV0gJiYgKFxuICAgICAgICAgICAgICA8TGVnZW5kSXRlbVxuICAgICAgICAgICAgICAgIHsuLi5sZWdlbmRJdGVtfVxuICAgICAgICAgICAgICAgIGtleT17YGxlZ2VuZC0ke2xlZ2VuZEl0ZW0ueUtleX1gfVxuICAgICAgICAgICAgICAgIHlLZXlGb3JtYXR0ZWQ9e2tleXNbbGVnZW5kSXRlbS55S2V5XS5rZXlGb3JtYXR0ZWR9XG4gICAgICAgICAgICAgICAgb25DbGljaz17KCkgPT5cbiAgICAgICAgICAgICAgICAgIHNldFZpc2libGVZS2V5cyhwcmV2ID0+IHtcbiAgICAgICAgICAgICAgICAgICAgbGV0IG5ld1Zpc2libGVMZWdlbmRJdGVtczogQXJyYXk8c3RyaW5nPiA9IFtdO1xuXG4gICAgICAgICAgICAgICAgICAgIGlmIChwcmV2Lmxlbmd0aCA9PT0gbGVnZW5kSXRlbXMubGVuZ3RoKSB7XG4gICAgICAgICAgICAgICAgICAgICAgbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zID0gW2xlZ2VuZEl0ZW0ueUtleV07XG4gICAgICAgICAgICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICAgICAgICAgICAgaWYgKHByZXYuaW5jbHVkZXMobGVnZW5kSXRlbS55S2V5KSkge1xuICAgICAgICAgICAgICAgICAgICAgICAgbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zID0gcHJldi5maWx0ZXIocHJldkxlZ2VuZEl0ZW1JZCA9PiBwcmV2TGVnZW5kSXRlbUlkICE9PSBsZWdlbmRJdGVtLnlLZXkpO1xuICAgICAgICAgICAgICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICAgICAgICAgICAgICBuZXdWaXNpYmxlTGVnZW5kSXRlbXMgPSBbLi4ucHJldiwgbGVnZW5kSXRlbS55S2V5XTtcbiAgICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgICAgICAgICByZXR1cm4gbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zLmxlbmd0aCA9PT0gMFxuICAgICAgICAgICAgICAgICAgICAgID8gbGVnZW5kSXRlbXMubWFwKGxlZ2VuZEl0ZW0gPT4gbGVnZW5kSXRlbS55S2V5KVxuICAgICAgICAgICAgICAgICAgICAgIDogbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zO1xuICAgICAgICAgICAgICAgICAgfSlcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgdmlzaWJsZT17dmlzaWJsZVlLZXlzLmluY2x1ZGVzKGxlZ2VuZEl0ZW0ueUtleSl9XG4gICAgICAgICAgICAgICAgY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXM9e2NvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzfVxuICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgKVxuICAgICAgICApfVxuICAgICAgPC9TY3JvbGxiYXI+XG4gICAgPC9kaXY+XG4gICk7XG59O1xuIl19 */"),
42564
+ }, ";label:Legend;", "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBOEJtQiIsImZpbGUiOiJMZWdlbmQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0LCB7IEZyYWdtZW50IH0gZnJvbSAncmVhY3QnO1xuXG5pbXBvcnQgeyBMZWdlbmRJdGVtIH0gZnJvbSAnLi9MZWdlbmRJdGVtJztcbmltcG9ydCB7IFNoYXBlRGVmaW5pdGlvbiwgQ29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZSwgS2V5IH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9DaGFydHNWMi90eXBlcyc7XG5pbXBvcnQgeyBTY3JvbGxiYXIgfSBmcm9tICcuLi8uLi8uLi9TY3JvbGxiYXIvU2Nyb2xsYmFyJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBCYXJTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0JhckNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgTGluZVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvTGluZUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQXJlYVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQXJlYUNoYXJ0VjIvdHlwZXMnO1xuXG5pbnRlcmZhY2UgTGVnZW5kUHJvcHM8VD4ge1xuICBzZXRWaXNpYmxlWUtleXM/OiBSZWFjdC5EaXNwYXRjaDxSZWFjdC5TZXRTdGF0ZUFjdGlvbjxBcnJheTxzdHJpbmc+Pj47XG4gIGtleXM6IHsgW2tleTogc3RyaW5nXTogS2V5IH07XG4gIG1hcmdpbkxlZnQ6IG51bWJlcjtcbiAgaXRlbXM/OiB7XG4gICAgbGVnZW5kSXRlbXM6IEFycmF5PFNoYXBlRGVmaW5pdGlvbjxUPj47XG4gICAgdmlzaWJsZVlLZXlzOiBBcnJheTxzdHJpbmc+O1xuICAgIGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzOiBBcnJheTxDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlPjtcbiAgfVtdO1xufVxuXG5leHBvcnQgY29uc3QgTGVnZW5kID0gKHtcbiAga2V5cyxcbiAgc2V0VmlzaWJsZVlLZXlzLFxuICBtYXJnaW5MZWZ0LFxuICBpdGVtcyxcbn06IExlZ2VuZFByb3BzPEJhclN0eWxlcyB8IExpbmVTdHlsZXMgfCBBcmVhU3R5bGVzPikgPT4ge1xuICByZXR1cm4gKFxuICAgIDxkaXYgY2xhc3NOYW1lPXtjc3MoeyBoZWlnaHQ6IDQwLCBwYWRkaW5nVG9wOiA4IH0pfT5cbiAgICAgIDxTY3JvbGxiYXJcbiAgICAgICAgY2xhc3NOYW1lPXtjc3Moe1xuICAgICAgICAgIGRpc3BsYXk6ICdmbGV4JyxcbiAgICAgICAgICBmbGV4RGlyZWN0aW9uOiAncm93JyxcbiAgICAgICAgICBmbGV4V3JhcDogJ25vd3JhcCcsXG4gICAgICAgICAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG4gICAgICAgICAgbWFyZ2luTGVmdDogbWFyZ2luTGVmdCA/IGAke21hcmdpbkxlZnR9cHhgIDogdW5kZWZpbmVkLFxuICAgICAgICB9KX1cbiAgICAgICAgeD17dHJ1ZX1cbiAgICAgID5cbiAgICAgICAge2l0ZW1zPy5tYXAoKGl0ZW0sIGluZGV4KSA9PiAoXG4gICAgICAgICAgPEZyYWdtZW50IGtleT17aW5kZXh9PlxuICAgICAgICAgICAge2l0ZW0ubGVnZW5kSXRlbXM/Lm1hcChcbiAgICAgICAgICAgICAgbGVnZW5kSXRlbSA9PlxuICAgICAgICAgICAgICAgIGtleXNbbGVnZW5kSXRlbS55S2V5XSAmJiAoXG4gICAgICAgICAgICAgICAgICA8TGVnZW5kSXRlbVxuICAgICAgICAgICAgICAgICAgICB7Li4ubGVnZW5kSXRlbX1cbiAgICAgICAgICAgICAgICAgICAga2V5PXtgbGVnZW5kLSR7bGVnZW5kSXRlbS55S2V5fWB9XG4gICAgICAgICAgICAgICAgICAgIHlLZXlGb3JtYXR0ZWQ9e2tleXNbbGVnZW5kSXRlbS55S2V5XS5rZXlGb3JtYXR0ZWR9XG4gICAgICAgICAgICAgICAgICAgIG9uQ2xpY2s9eygpID0+XG4gICAgICAgICAgICAgICAgICAgICAgc2V0VmlzaWJsZVlLZXlzICYmXG4gICAgICAgICAgICAgICAgICAgICAgc2V0VmlzaWJsZVlLZXlzKHByZXYgPT4ge1xuICAgICAgICAgICAgICAgICAgICAgICAgbGV0IG5ld1Zpc2libGVMZWdlbmRJdGVtczogQXJyYXk8c3RyaW5nPiA9IFtdO1xuXG4gICAgICAgICAgICAgICAgICAgICAgICBpZiAocHJldi5sZW5ndGggPT09IGl0ZW0ubGVnZW5kSXRlbXMubGVuZ3RoKSB7XG4gICAgICAgICAgICAgICAgICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IFtsZWdlbmRJdGVtLnlLZXldO1xuICAgICAgICAgICAgICAgICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgaWYgKHByZXYuaW5jbHVkZXMobGVnZW5kSXRlbS55S2V5KSkge1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IHByZXYuZmlsdGVyKFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgcHJldkxlZ2VuZEl0ZW1JZCA9PiBwcmV2TGVnZW5kSXRlbUlkICE9PSBsZWdlbmRJdGVtLnlLZXlcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICApO1xuICAgICAgICAgICAgICAgICAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IFsuLi5wcmV2LCBsZWdlbmRJdGVtLnlLZXldO1xuICAgICAgICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICAgICAgICB9XG5cbiAgICAgICAgICAgICAgICAgICAgICAgIHJldHVybiBuZXdWaXNpYmxlTGVnZW5kSXRlbXMubGVuZ3RoID09PSAwXG4gICAgICAgICAgICAgICAgICAgICAgICAgID8gaXRlbS5sZWdlbmRJdGVtcy5tYXAobGVnZW5kSXRlbSA9PiBsZWdlbmRJdGVtLnlLZXkpXG4gICAgICAgICAgICAgICAgICAgICAgICAgIDogbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zO1xuICAgICAgICAgICAgICAgICAgICAgIH0pXG4gICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICAgICAgdmlzaWJsZT17c2V0VmlzaWJsZVlLZXlzID8gaXRlbS52aXNpYmxlWUtleXMuaW5jbHVkZXMobGVnZW5kSXRlbS55S2V5KSA6IHRydWV9XG4gICAgICAgICAgICAgICAgICAgIGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzPXtpdGVtLmNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzfVxuICAgICAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgICAgICApXG4gICAgICAgICAgICApfVxuICAgICAgICAgIDwvRnJhZ21lbnQ+XG4gICAgICAgICkpfVxuICAgICAgPC9TY3JvbGxiYXI+XG4gICAgPC9kaXY+XG4gICk7XG59O1xuIl19 */"),
42558
42565
  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
- }));
42566
+ children: items == null ? void 0 : items.map(function (item, index) {
42567
+ var _item$legendItems;
42568
+ return jsxRuntime.jsx(React.Fragment, {
42569
+ children: (_item$legendItems = item.legendItems) == null ? void 0 : _item$legendItems.map(function (legendItem) {
42570
+ return keys[legendItem.yKey] && react.createElement(LegendItem, _extends({}, legendItem, {
42571
+ key: "legend-" + legendItem.yKey,
42572
+ yKeyFormatted: keys[legendItem.yKey].keyFormatted,
42573
+ onClick: function onClick() {
42574
+ return setVisibleYKeys && setVisibleYKeys(function (prev) {
42575
+ var newVisibleLegendItems = [];
42576
+ if (prev.length === item.legendItems.length) {
42577
+ newVisibleLegendItems = [legendItem.yKey];
42578
+ } else {
42579
+ if (prev.includes(legendItem.yKey)) {
42580
+ newVisibleLegendItems = prev.filter(function (prevLegendItemId) {
42581
+ return prevLegendItemId !== legendItem.yKey;
42582
+ });
42583
+ } else {
42584
+ newVisibleLegendItems = [].concat(prev, [legendItem.yKey]);
42585
+ }
42586
+ }
42587
+ return newVisibleLegendItems.length === 0 ? item.legendItems.map(function (legendItem) {
42588
+ return legendItem.yKey;
42589
+ }) : newVisibleLegendItems;
42590
+ });
42591
+ },
42592
+ visible: setVisibleYKeys ? item.visibleYKeys.includes(legendItem.yKey) : true,
42593
+ conditionalFormattingRules: item.conditionalFormattingRules
42594
+ }));
42595
+ })
42596
+ }, index);
42585
42597
  })
42586
42598
  })
42587
42599
  });
@@ -42683,19 +42695,19 @@ var buildMargin = function buildMargin(yTicks, showYAxisLabels, hasYAxisTitle, h
42683
42695
  };
42684
42696
  };
42685
42697
 
42686
- function useFlattenedData(xScaleKey, xScaleDataType, chart) {
42698
+ function useFlattenedData(xScaleKey, xScaleDataType, data, yKeys) {
42687
42699
  return React.useMemo(function () {
42688
- if (xScaleKey && xScaleDataType) {
42700
+ if (xScaleKey && xScaleDataType && yKeys.length > 0) {
42689
42701
  return flattenData({
42690
- data: chart.data,
42702
+ data: data,
42691
42703
  xScaleKey: xScaleKey,
42692
42704
  xScaleDataType: xScaleDataType,
42693
- yKeys: chart.y.keys
42705
+ yKeys: yKeys
42694
42706
  });
42695
42707
  } else {
42696
42708
  return [];
42697
42709
  }
42698
- }, [chart.data, xScaleKey, xScaleDataType, chart.y.keys]);
42710
+ }, [data, xScaleKey, xScaleDataType, yKeys]);
42699
42711
  }
42700
42712
 
42701
42713
  var GoalLine = function GoalLine(_ref) {
@@ -43044,6 +43056,17 @@ function useTooltip$1(initialTooltipState) {
43044
43056
  };
43045
43057
  }
43046
43058
 
43059
+ function useYScale(innerHeight, scale$1) {
43060
+ return React.useMemo(function () {
43061
+ return scale.scaleLinear({
43062
+ range: [innerHeight, 0],
43063
+ domain: scale$1.ordering === 'asc' ? [scale$1.min, scale$1.max] : [scale$1.max, scale$1.min],
43064
+ nice: true,
43065
+ round: true
43066
+ });
43067
+ }, [innerHeight, scale$1]);
43068
+ }
43069
+
43047
43070
  var LineChart$5 = function LineChart(_ref) {
43048
43071
  var _theme$axis;
43049
43072
  var chart = _ref.chart,
@@ -43109,14 +43132,8 @@ var LineChart$5 = function LineChart(_ref) {
43109
43132
  }
43110
43133
  return null;
43111
43134
  }, [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);
43135
+ var _yScale = useYScale(innerHeight, chart.y.scale);
43136
+ var dataFlattened = useFlattenedData(xScaleKey, xScaleDataType, chart.data, chart.y.keys);
43120
43137
  var handleMouseMove = React.useCallback(function (event) {
43121
43138
  if (!xKey || !xScaleKey || xScale === null) return;
43122
43139
  var tooltipData = getTooltipData({
@@ -43143,6 +43160,11 @@ var LineChart$5 = function LineChart(_ref) {
43143
43160
  var yTickValues = chart.y.ticks.map(function (tick) {
43144
43161
  return Number(tick.value);
43145
43162
  });
43163
+ var legendTooltipItems = [{
43164
+ legendItems: chart.lines,
43165
+ visibleYKeys: visibleYKeys,
43166
+ conditionalFormattingRules: chart.conditionalFormattingRules
43167
+ }];
43146
43168
  return jsxRuntime.jsxs(React__default.Fragment, {
43147
43169
  children: [jsxRuntime.jsxs(ChartWrapper$1, {
43148
43170
  width: width,
@@ -43177,93 +43199,19 @@ var LineChart$5 = function LineChart(_ref) {
43177
43199
  yScale: _yScale,
43178
43200
  ticks: yTickValues,
43179
43201
  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
- })]
43202
+ }), jsxRuntime.jsx(group.Group, {
43203
+ children: xScaleKey !== null && jsxRuntime.jsx(Lines, {
43204
+ lines: chart.lines,
43205
+ conditionalFormattingRules: chart.conditionalFormattingRules,
43206
+ curve: curve,
43207
+ yKeys: chart.y.keys,
43208
+ visibleYKeys: visibleYKeys,
43209
+ data: dataFlattened,
43210
+ xScaleKey: xScaleKey,
43211
+ xScaleDataType: xScaleDataType,
43212
+ xScale: xScale,
43213
+ yScale: _yScale
43214
+ })
43267
43215
  })]
43268
43216
  }), tooltipData && jsxRuntime.jsxs("g", {
43269
43217
  children: [jsxRuntime.jsx(Line, {
@@ -43295,27 +43243,117 @@ var LineChart$5 = function LineChart(_ref) {
43295
43243
  width: innerWidth
43296
43244
  })]
43297
43245
  }), options.showLegend && jsxRuntime.jsx(Legend$1, {
43298
- legendItems: chart.lines,
43299
- visibleYKeys: visibleYKeys,
43246
+ items: legendTooltipItems,
43300
43247
  setVisibleYKeys: setVisibleYKeys,
43301
43248
  keys: chart.keys,
43302
- conditionalFormattingRules: chart.conditionalFormattingRules,
43303
43249
  marginLeft: margin.left - margin.leftTitleOffset
43304
43250
  }), tooltipOpen && tooltipData && xKey && jsxRuntime.jsx(Tooltip$1, {
43251
+ items: legendTooltipItems,
43305
43252
  tooltipData: tooltipData,
43306
43253
  tooltipLeft: tooltipLeft,
43307
43254
  tooltipTop: tooltipTop,
43308
43255
  xKey: xKey,
43309
43256
  keys: chart.keys,
43310
- visibleYKeys: visibleYKeys,
43311
43257
  yKeys: chart.y.keys,
43312
- legendItems: chart.lines,
43313
43258
  showRoundedTotal: options.showRoundedTotal,
43314
- conditionalFormattingRules: chart.conditionalFormattingRules,
43315
43259
  theme: themeCSS.popoverMenus
43316
43260
  })]
43317
43261
  });
43318
43262
  };
43263
+ function Lines(_ref2) {
43264
+ var yKeys = _ref2.yKeys,
43265
+ visibleYKeys = _ref2.visibleYKeys,
43266
+ data = _ref2.data,
43267
+ xScaleKey = _ref2.xScaleKey,
43268
+ xScaleDataType = _ref2.xScaleDataType,
43269
+ xScale = _ref2.xScale,
43270
+ yScale = _ref2.yScale,
43271
+ lines = _ref2.lines,
43272
+ curve = _ref2.curve,
43273
+ conditionalFormattingRules = _ref2.conditionalFormattingRules;
43274
+ return jsxRuntime.jsxs(React.Fragment, {
43275
+ children: [yKeys.map(function (yKey) {
43276
+ var _lines$filter$0$style;
43277
+ return jsxRuntime.jsx(shape.LinePath, {
43278
+ visibility: visibleYKeys.includes(yKey) ? 'visible' : 'hidden',
43279
+ data: data,
43280
+ x: function x(d) {
43281
+ var _ref3;
43282
+ var xValue = d[xScaleKey];
43283
+ var xValueAdjusted = xScaleDataType === 'date_time' ? new Date(xValue) : xScaleDataType === 'number' ? Number(xValue) : String(xValue);
43284
+ return (_ref3 = xScale(xValueAdjusted)) != null ? _ref3 : 0;
43285
+ },
43286
+ y: function y(d) {
43287
+ return yScale(d[yKey]);
43288
+ },
43289
+ stroke: lines.filter(function (legendItem) {
43290
+ return legendItem.yKey === yKey;
43291
+ })[0].color,
43292
+ strokeWidth: lines.filter(function (legendItem) {
43293
+ return legendItem.yKey === yKey;
43294
+ })[0].style.strokeWidth,
43295
+ strokeLinecap: "round",
43296
+ strokeDasharray: (_lines$filter$0$style = lines.filter(function (legendItem) {
43297
+ return legendItem.yKey === yKey;
43298
+ })[0].style.strokeDasharray) != null ? _lines$filter$0$style : undefined,
43299
+ shapeRendering: "smooth",
43300
+ defined: function defined(d) {
43301
+ return d[yKey] !== null;
43302
+ },
43303
+ curve: curve
43304
+ }, yKey);
43305
+ }), conditionalFormattingRules.map(function (conditionalFormattingRule) {
43306
+ var _lines$filter$0$style2;
43307
+ if (conditionalFormattingRule.operator !== '<=' && conditionalFormattingRule.operator !== '>=') return null;
43308
+ var yKey = conditionalFormattingRule.yKey;
43309
+ var clipPathId = "clip-path-" + yKey + "-" + conditionalFormattingRule.value + "-" + conditionalFormattingRule.color + "-" + Math.random(); // Do not remove Math.random() - required to ensure unique clipPathId per view instance
43310
+
43311
+ var clipArea = getClipArea({
43312
+ conditionalFormattingRule: conditionalFormattingRule,
43313
+ chart: {
43314
+ width: innerWidth,
43315
+ height: innerHeight,
43316
+ yScale: yScale
43317
+ }
43318
+ });
43319
+ return jsxRuntime.jsxs(group.Group, {
43320
+ children: [jsxRuntime.jsx(shape.LinePath, {
43321
+ clipPath: "url(#" + clipPathId + ")",
43322
+ visibility: visibleYKeys.includes(yKey) ? 'visible' : 'hidden',
43323
+ data: data,
43324
+ x: function x(d) {
43325
+ var _ref4;
43326
+ var xValue = d[xScaleKey];
43327
+ var xValueAdjusted = xScaleDataType === 'date_time' ? new Date(xValue) : xScaleDataType === 'number' ? Number(xValue) : String(xValue);
43328
+ return (_ref4 = xScale(xValueAdjusted)) != null ? _ref4 : 0;
43329
+ },
43330
+ y: function y(d) {
43331
+ return yScale(d[yKey]);
43332
+ },
43333
+ stroke: conditionalFormattingRule.color,
43334
+ strokeWidth: lines.filter(function (legendItem) {
43335
+ return legendItem.yKey === yKey;
43336
+ })[0].style.strokeWidth,
43337
+ strokeLinecap: "round",
43338
+ strokeDasharray: (_lines$filter$0$style2 = lines.filter(function (legendItem) {
43339
+ return legendItem.yKey === yKey;
43340
+ })[0].style.strokeDasharray) != null ? _lines$filter$0$style2 : undefined,
43341
+ shapeRendering: "smooth",
43342
+ defined: function defined(d) {
43343
+ return d[yKey] !== null;
43344
+ },
43345
+ curve: curve
43346
+ }, yKey), jsxRuntime.jsx(clipPath.RectClipPath, {
43347
+ id: clipPathId,
43348
+ x: clipArea.x,
43349
+ y: clipArea.y,
43350
+ width: clipArea.width,
43351
+ height: clipArea.height
43352
+ })]
43353
+ }, clipPathId);
43354
+ })]
43355
+ });
43356
+ }
43319
43357
 
43320
43358
  function getBarFill(bars, conditionalFormattingRules, barKey, barValues) {
43321
43359
  var _bars$find;
@@ -43332,7 +43370,7 @@ function getBarFill(bars, conditionalFormattingRules, barKey, barValues) {
43332
43370
  if (compare({
43333
43371
  op: rule.operator,
43334
43372
  value: rule.value
43335
- }, value)) {
43373
+ }, value) && rule.yKey === barKey) {
43336
43374
  fill = rule.color;
43337
43375
  break;
43338
43376
  }
@@ -43341,12 +43379,43 @@ function getBarFill(bars, conditionalFormattingRules, barKey, barValues) {
43341
43379
  return fill;
43342
43380
  }
43343
43381
 
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
43382
  var PADDING = {
43347
43383
  paddingOuter: 0.05,
43348
43384
  paddingInner: 0.3
43349
43385
  };
43386
+
43387
+ function useBarXScale(xScaleDataType, innerWidth, xScaleKey, data) {
43388
+ return React.useMemo(function () {
43389
+ if (xScaleDataType === 'string') {
43390
+ return scale.scaleBand(_extends({
43391
+ range: [0, innerWidth],
43392
+ domain: xScaleKey ? [].concat(data.map(function (d) {
43393
+ return d[xScaleKey] && d[xScaleKey].value !== null ? String(d[xScaleKey].value) : '';
43394
+ })) : []
43395
+ }, PADDING));
43396
+ }
43397
+ if (xScaleDataType === 'date_time' && xScaleKey) {
43398
+ return scale.scaleBand(_extends({
43399
+ range: [0, innerWidth],
43400
+ domain: data.map(function (d) {
43401
+ return new Date(d[xScaleKey].value);
43402
+ })
43403
+ }, PADDING));
43404
+ }
43405
+ if (xScaleDataType === 'number' && xScaleKey) {
43406
+ return scale.scaleBand(_extends({
43407
+ range: [0, innerWidth],
43408
+ domain: data.map(function (d) {
43409
+ return d[xScaleKey] && d[xScaleKey].value !== null ? Number(d[xScaleKey].value) : 0;
43410
+ })
43411
+ }, PADDING));
43412
+ }
43413
+ return null;
43414
+ }, [innerWidth, data]);
43415
+ }
43416
+
43417
+ 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)."; }
43418
+ var BAR_RADIUS = 2;
43350
43419
  var BarChart$5 = function BarChart(_ref) {
43351
43420
  var _theme$axis;
43352
43421
  var chart = _ref.chart,
@@ -43377,41 +43446,8 @@ var BarChart$5 = function BarChart(_ref) {
43377
43446
  var xScaleKey = chart.x.scale.key;
43378
43447
  var yScaleKeys = chart.y.keys;
43379
43448
  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]);
43449
+ var xScale = useBarXScale(xScaleDataType, innerWidth, xScaleKey, chart.data);
43450
+ var yScale = useYScale(innerHeight, chart.y.scale);
43415
43451
  var innerXScale = React.useMemo(function () {
43416
43452
  if (!options.stacked && xScale && 'bandwidth' in xScale) {
43417
43453
  return scale.scaleBand({
@@ -43422,7 +43458,7 @@ var BarChart$5 = function BarChart(_ref) {
43422
43458
  }
43423
43459
  return undefined;
43424
43460
  }, [xScale, yScaleKeys, options.stacked, xScaleDataType]);
43425
- var dataFlattened = useFlattenedData(xScaleKey, xScaleDataType, chart);
43461
+ var dataFlattened = useFlattenedData(xScaleKey, xScaleDataType, chart.data, chart.y.keys);
43426
43462
  var handleMouseMove = React.useCallback(function (event) {
43427
43463
  if (!xKey || !xScaleKey || xScale === null) return;
43428
43464
  var tooltipData = getTooltipData({
@@ -43468,6 +43504,13 @@ var BarChart$5 = function BarChart(_ref) {
43468
43504
  var yTickValues = chart.y.ticks.map(function (tick) {
43469
43505
  return Number(tick.value);
43470
43506
  });
43507
+ var legendTooltipItems = [{
43508
+ visibleYKeys: chart.bars.map(function (legendItem) {
43509
+ return legendItem.yKey;
43510
+ }),
43511
+ legendItems: chart.bars,
43512
+ conditionalFormattingRules: chart.conditionalFormattingRules
43513
+ }];
43471
43514
  return jsxRuntime.jsxs(React.Fragment, {
43472
43515
  children: [jsxRuntime.jsxs(ChartWrapper$1, {
43473
43516
  width: width,
@@ -43503,57 +43546,25 @@ var BarChart$5 = function BarChart(_ref) {
43503
43546
  ticks: yTickValues,
43504
43547
  stroke: theme == null || (_theme$axis = theme.axis) == null ? void 0 : _theme$axis.stroke
43505
43548
  }), jsxRuntime.jsxs(group.Group, {
43506
- children: [!options.stacked && jsxRuntime.jsx(shape.BarGroup, {
43549
+ children: [!options.stacked && jsxRuntime.jsx(BarGroup, {
43507
43550
  data: dataFlattened,
43508
43551
  keys: yScaleKeys,
43509
43552
  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,
43553
+ xKey: xKey,
43554
+ xScaleDataType: xScaleDataType,
43555
+ xScale: xScale,
43556
+ innerXScale: innerXScale,
43524
43557
  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
- }
43558
+ onClick: handleOnBarClick,
43559
+ conditionalFormattingRules: chart.conditionalFormattingRules,
43560
+ bars: chart.bars,
43561
+ enableHover: enableHover
43550
43562
  }), options.stacked && jsxRuntime.jsx(shape.BarStack, {
43551
43563
  x: function x(d) {
43552
43564
  // @ts-ignore
43553
43565
  var xValue = d[xScaleKey];
43554
43566
  if (xScaleDataType === 'string') return xValue;
43555
43567
  var xValueAdjusted = xScaleDataType === 'date_time' ? new Date(xValue) : xScaleDataType === 'number' ? Number(xValue) : String(xValue);
43556
- // @ts-ignore
43557
43568
  return xValueAdjusted;
43558
43569
  }
43559
43570
  // @ts-ignore
@@ -43601,31 +43612,79 @@ var BarChart$5 = function BarChart(_ref) {
43601
43612
  width: innerWidth
43602
43613
  })]
43603
43614
  }), options.showLegend && jsxRuntime.jsx(Legend$1, {
43604
- legendItems: chart.bars,
43605
- visibleYKeys: chart.bars.map(function (legendItem) {
43606
- return legendItem.yKey;
43607
- }),
43615
+ items: legendTooltipItems,
43608
43616
  setVisibleYKeys: function setVisibleYKeys() {},
43609
43617
  keys: chart.keys,
43610
- conditionalFormattingRules: chart.conditionalFormattingRules,
43611
43618
  marginLeft: margin.left - margin.leftTitleOffset
43612
43619
  }), tooltipOpen && tooltipData && xKey && jsxRuntime.jsx(Tooltip$1, {
43620
+ items: legendTooltipItems,
43613
43621
  tooltipData: tooltipData,
43614
43622
  tooltipLeft: tooltipLeft,
43615
43623
  tooltipTop: tooltipTop,
43616
43624
  xKey: xKey,
43617
43625
  keys: chart.keys,
43618
- visibleYKeys: chart.bars.map(function (legendItem) {
43619
- return legendItem.yKey;
43620
- }),
43621
43626
  yKeys: chart.y.keys,
43622
- legendItems: chart.bars,
43623
43627
  showRoundedTotal: options.showRoundedTotal,
43624
- conditionalFormattingRules: chart.conditionalFormattingRules,
43625
43628
  theme: themeCSS.popoverMenus
43626
43629
  })]
43627
43630
  });
43628
43631
  };
43632
+ function BarGroup(_ref2) {
43633
+ var data = _ref2.data,
43634
+ keys = _ref2.keys,
43635
+ height = _ref2.height,
43636
+ xKey = _ref2.xKey,
43637
+ xScaleDataType = _ref2.xScaleDataType,
43638
+ xScale = _ref2.xScale,
43639
+ innerXScale = _ref2.innerXScale,
43640
+ yScale = _ref2.yScale,
43641
+ _onClick = _ref2.onClick,
43642
+ conditionalFormattingRules = _ref2.conditionalFormattingRules,
43643
+ bars = _ref2.bars,
43644
+ enableHover = _ref2.enableHover;
43645
+ return jsxRuntime.jsx(shape.BarGroup, {
43646
+ data: data,
43647
+ keys: keys,
43648
+ height: height,
43649
+ x0: function x0(d) {
43650
+ var xValue = d[xKey];
43651
+ if (xScaleDataType === 'string') return String(xValue);
43652
+ var xValueAdjusted = xScaleDataType === 'date_time' ? new Date(String(xValue)) : xScaleDataType === 'number' ? Number(xValue) : String(xValue);
43653
+ return xValueAdjusted;
43654
+ }
43655
+ // @ts-ignore
43656
+ ,
43657
+ x0Scale: xScale
43658
+ // @ts-ignore
43659
+ ,
43660
+ x1Scale: innerXScale,
43661
+ yScale: yScale,
43662
+ color: function color() {
43663
+ return '';
43664
+ },
43665
+ children: function children(barGroups) {
43666
+ return barGroups.map(function (barGroup) {
43667
+ return jsxRuntime.jsx(group.Group, {
43668
+ left: barGroup.x0,
43669
+ children: barGroup.bars.map(function (bar) {
43670
+ if (bar.value === null || bar.height < 0 || bar.width < 0) return null;
43671
+ return jsxRuntime.jsx(Bar, {
43672
+ x: bar.x,
43673
+ y: bar.y,
43674
+ width: bar.width,
43675
+ height: bar.height,
43676
+ fill: getBarFill(bars, conditionalFormattingRules, String(bar.key), bar.value),
43677
+ onClick: function onClick(e) {
43678
+ return _onClick(e, barGroup, bar);
43679
+ },
43680
+ enableHover: enableHover
43681
+ }, "bar-group-bar-" + barGroup.index + "-" + bar.index + "-" + bar.value + "-" + String(bar.key));
43682
+ })
43683
+ }, "bar-group-" + barGroup.index + "-" + barGroup.x0);
43684
+ });
43685
+ }
43686
+ });
43687
+ }
43629
43688
  var Bar = function Bar(props) {
43630
43689
  var _useState = React.useState(props.fill),
43631
43690
  fillColor = _useState[0],
@@ -43647,7 +43706,7 @@ var Bar = function Bar(props) {
43647
43706
  className: props.enableHover ? /*#__PURE__*/css$1.css( {
43648
43707
  name: "4nk3o1-Bar",
43649
43708
  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"]} */",
43709
+ 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
43710
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$9
43652
43711
  }) : ''
43653
43712
  }, props.key);
@@ -43823,14 +43882,8 @@ var AreaChart$5 = function AreaChart(_ref) {
43823
43882
  }
43824
43883
  return null;
43825
43884
  }, [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);
43885
+ var _yScale = useYScale(innerHeight, chart.y.scale);
43886
+ var dataFlattened = useFlattenedData(xScaleKey, xScaleDataType, chart.data, chart.y.keys);
43834
43887
  var handleMouseMove = React.useCallback(function (event) {
43835
43888
  if (!xKey || !xScaleKey || xScale === null) return;
43836
43889
  var tooltipData = getTooltipData({
@@ -43860,12 +43913,17 @@ var AreaChart$5 = function AreaChart(_ref) {
43860
43913
  step: Curves.curveStep,
43861
43914
  straight: Curves.curveLinear
43862
43915
  };
43863
- return curveMap[(_options$curve = options.curve) != null ? _options$curve : 'monotoneX'];
43916
+ return curveMap[(_options$curve = options.curve) != null ? _options$curve : 'natural'];
43864
43917
  }, [options.curve]);
43865
43918
  if (width === 0 || height === 0 || xScale === null) return jsxRuntime.jsx(React__default.Fragment, {});
43866
43919
  var yTickValues = chart.y.ticks.map(function (tick) {
43867
43920
  return Number(tick.value);
43868
43921
  });
43922
+ var legendTooltipItems = [{
43923
+ visibleYKeys: visibleYKeys,
43924
+ legendItems: chart.areas,
43925
+ conditionalFormattingRules: chart.conditionalFormattingRules
43926
+ }];
43869
43927
  return jsxRuntime.jsxs(React__default.Fragment, {
43870
43928
  children: [jsxRuntime.jsxs(ChartWrapper$1, {
43871
43929
  width: width,
@@ -44021,23 +44079,19 @@ var AreaChart$5 = function AreaChart(_ref) {
44021
44079
  width: innerWidth
44022
44080
  })]
44023
44081
  }), options.showLegend && jsxRuntime.jsx(Legend$1, {
44024
- legendItems: chart.areas,
44025
- visibleYKeys: visibleYKeys,
44082
+ items: legendTooltipItems,
44026
44083
  setVisibleYKeys: setVisibleYKeys,
44027
44084
  keys: chart.keys,
44028
- conditionalFormattingRules: chart.conditionalFormattingRules,
44029
44085
  marginLeft: margin.left - margin.leftTitleOffset
44030
44086
  }), tooltipOpen && tooltipData && xKey && jsxRuntime.jsx(Tooltip$1, {
44087
+ items: legendTooltipItems,
44031
44088
  tooltipData: tooltipData,
44032
44089
  tooltipLeft: tooltipLeft,
44033
44090
  tooltipTop: tooltipTop,
44034
44091
  xKey: xKey,
44035
44092
  keys: chart.keys,
44036
- visibleYKeys: visibleYKeys,
44037
44093
  yKeys: chart.y.keys,
44038
- legendItems: chart.areas,
44039
44094
  showRoundedTotal: options.showRoundedTotal,
44040
- conditionalFormattingRules: chart.conditionalFormattingRules,
44041
44095
  theme: themeCSS.popoverMenus
44042
44096
  })]
44043
44097
  });
@@ -44340,11 +44394,13 @@ var RadarChart$2 = function RadarChart(_ref) {
44340
44394
  })]
44341
44395
  })
44342
44396
  }), options.showLegend && jsxRuntime.jsx(Legend$1, {
44343
- legendItems: chart.lines,
44344
- visibleYKeys: visibleYKeys,
44397
+ items: [{
44398
+ legendItems: chart.lines,
44399
+ visibleYKeys: visibleYKeys,
44400
+ conditionalFormattingRules: []
44401
+ }],
44345
44402
  setVisibleYKeys: setVisibleYKeys,
44346
44403
  keys: chart.keys,
44347
- conditionalFormattingRules: [],
44348
44404
  marginLeft: margin.left - margin.leftTitleOffset
44349
44405
  })]
44350
44406
  });
@@ -49056,30 +49112,6 @@ var BarChartV2 = function BarChartV2(props) {
49056
49112
  });
49057
49113
  };
49058
49114
 
49059
- function getBarFill$1(bars, conditionalFormattingRules, barKey, barValues) {
49060
- var _bars$find;
49061
- // Default fill color from the corresponding bar
49062
- var fill = (_bars$find = bars.find(function (chartBar) {
49063
- return chartBar.yKey === barKey;
49064
- })) == null ? void 0 : _bars$find.color;
49065
-
49066
- // Determine the value based on barValues type
49067
- var value = typeof barValues === 'number' ? barValues : barValues == null ? void 0 : barValues[barKey];
49068
- if (typeof value === 'number') {
49069
- for (var _iterator = _createForOfIteratorHelperLoose(conditionalFormattingRules), _step; !(_step = _iterator()).done;) {
49070
- var rule = _step.value;
49071
- if (compare({
49072
- op: rule.operator,
49073
- value: rule.value
49074
- }, value)) {
49075
- fill = rule.color;
49076
- break;
49077
- }
49078
- }
49079
- }
49080
- return fill;
49081
- }
49082
-
49083
49115
  var ASSUMED_AVERAGE_CHAR_WIDTH$1 = 8.8;
49084
49116
  function calculateWordWidth$1(word, avgCharWidth) {
49085
49117
  if (avgCharWidth === void 0) {
@@ -49261,15 +49293,17 @@ var IconTrendingDown$1 = function IconTrendingDown() {
49261
49293
 
49262
49294
  var Legend$2 = function Legend(_ref) {
49263
49295
  var showLegend = _ref.showLegend,
49264
- margin = _ref.margin;
49296
+ margin = _ref.margin,
49297
+ increaseColor = _ref.increaseColor,
49298
+ decreaseColor = _ref.decreaseColor;
49265
49299
  var items = [{
49266
- color: 'green',
49300
+ color: increaseColor,
49267
49301
  yKey: 'increase',
49268
49302
  style: {
49269
49303
  type: 'bar'
49270
49304
  }
49271
49305
  }, {
49272
- color: 'red',
49306
+ color: decreaseColor,
49273
49307
  yKey: 'decrease',
49274
49308
  style: {
49275
49309
  type: 'bar'
@@ -49289,11 +49323,13 @@ var Legend$2 = function Legend(_ref) {
49289
49323
  };
49290
49324
  if (!showLegend) return null;
49291
49325
  return jsxRuntime.jsx(Legend$1, {
49292
- legendItems: items,
49293
- visibleYKeys: ['increase', 'decrease'],
49326
+ items: [{
49327
+ legendItems: items,
49328
+ visibleYKeys: ['increase', 'decrease'],
49329
+ conditionalFormattingRules: []
49330
+ }],
49294
49331
  keys: keys,
49295
49332
  marginLeft: margin.left - margin.leftTitleOffset,
49296
- conditionalFormattingRules: [],
49297
49333
  setVisibleYKeys: function setVisibleYKeys() {}
49298
49334
  });
49299
49335
  };
@@ -49311,7 +49347,9 @@ var WaterfallChart$2 = function WaterfallChart(_ref) {
49311
49347
  options = _ref.options,
49312
49348
  chart = _ref.chart,
49313
49349
  steps = _ref.steps,
49314
- theme = _ref.theme;
49350
+ theme = _ref.theme,
49351
+ increaseColor = _ref.increaseColor,
49352
+ decreaseColor = _ref.decreaseColor;
49315
49353
  //Waterfall TODO: fix chart for other x types
49316
49354
  if (chart.x.scale.dataType === 'date_time' || chart.x.scale.dataType === 'number') {
49317
49355
  return null;
@@ -49560,6 +49598,8 @@ var WaterfallChart$2 = function WaterfallChart(_ref) {
49560
49598
  left: barGroup.x0,
49561
49599
  children: barGroup.bars.map(function (bar) {
49562
49600
  return jsxRuntime.jsx(Bar$1, {
49601
+ increaseColor: increaseColor,
49602
+ decreaseColor: decreaseColor,
49563
49603
  bar: bar,
49564
49604
  barGroup: barGroup,
49565
49605
  yScale: yScale,
@@ -49580,7 +49620,9 @@ var WaterfallChart$2 = function WaterfallChart(_ref) {
49580
49620
  })]
49581
49621
  }), jsxRuntime.jsx(Legend$2, {
49582
49622
  showLegend: options.showLegend,
49583
- margin: margin
49623
+ margin: margin,
49624
+ increaseColor: increaseColor,
49625
+ decreaseColor: decreaseColor
49584
49626
  }), jsxRuntime.jsx(Tooltip$2, {
49585
49627
  showTooltip: tooltipOpen,
49586
49628
  tooltipData: tooltipData,
@@ -49596,7 +49638,9 @@ var Bar$1 = function Bar(_ref4) {
49596
49638
  var bar = _ref4.bar,
49597
49639
  barGroup = _ref4.barGroup,
49598
49640
  yScale = _ref4.yScale,
49599
- formattedChartDataForBarChart = _ref4.formattedChartDataForBarChart;
49641
+ formattedChartDataForBarChart = _ref4.formattedChartDataForBarChart,
49642
+ increaseColor = _ref4.increaseColor,
49643
+ decreaseColor = _ref4.decreaseColor;
49600
49644
  var step = formattedChartDataForBarChart.steps[barGroup.index];
49601
49645
  var y = yScale(Math.max(step.start, step.end));
49602
49646
  var barHeight = Math.abs(yScale(step.start) - yScale(step.end));
@@ -49606,7 +49650,7 @@ var Bar$1 = function Bar(_ref4) {
49606
49650
  y: y,
49607
49651
  width: bar.width,
49608
49652
  height: barHeight,
49609
- fill: getBarFill$1(formattedChartDataForBarChart.bars, formattedChartDataForBarChart.conditionalFormattingRules, bar.key, bar.value),
49653
+ fill: bar.value > 0 ? increaseColor : decreaseColor,
49610
49654
  rx: 4
49611
49655
  }, "bar-group-bar-" + barGroup.index + "-" + bar.index + "-" + bar.value + "-" + bar.key)
49612
49656
  });
@@ -49882,7 +49926,9 @@ var WaterfallChartView = function WaterfallChartView(props) {
49882
49926
  xAxisPrefix = props.xAxisPrefix,
49883
49927
  yAxisFormat = props.yAxisFormat,
49884
49928
  yAxisPostfix = props.yAxisPostfix,
49885
- yAxisPrefix = props.yAxisPrefix;
49929
+ yAxisPrefix = props.yAxisPrefix,
49930
+ increaseColor = props.increaseColor,
49931
+ decreaseColor = props.decreaseColor;
49886
49932
  var _useDashboardBehaviou = useDashboardBehaviourContext(),
49887
49933
  textOverride = _useDashboardBehaviou.textOverride,
49888
49934
  valueAlias = _useDashboardBehaviou.valueAlias,
@@ -49976,7 +50022,9 @@ var WaterfallChartView = function WaterfallChartView(props) {
49976
50022
  },
49977
50023
  theme: theme == null ? void 0 : theme.charts,
49978
50024
  chart: chartRepresentation,
49979
- steps: steps
50025
+ steps: steps,
50026
+ increaseColor: increaseColor,
50027
+ decreaseColor: decreaseColor
49980
50028
  });
49981
50029
  }
49982
50030
  })
@@ -60472,6 +60520,47 @@ var RichTextFormatSection = function RichTextFormatSection(props) {
60472
60520
  });
60473
60521
  };
60474
60522
 
60523
+ var WaterfallColorsSection = function WaterfallColorsSection(props) {
60524
+ var _props$section;
60525
+ var _useDashboardBehaviou = useDashboardBehaviourContext(),
60526
+ textOverride = _useDashboardBehaviou.textOverride;
60527
+ if (props.attributes.type != 'waterfallChart') return null;
60528
+ var _props$attributes = props.attributes,
60529
+ increaseColor = _props$attributes.increaseColor,
60530
+ decreaseColor = _props$attributes.decreaseColor;
60531
+ var debouncedSetAttributes = _.debounce(props.setAttributes, 200);
60532
+ return jsxRuntime.jsx(Section, {
60533
+ title: props == null ? void 0 : props.section.title,
60534
+ tooltip: props == null || (_props$section = props.section) == null ? void 0 : _props$section.description,
60535
+ children: jsxRuntime.jsxs(Section.Grid, {
60536
+ columns: 2,
60537
+ children: [jsxRuntime.jsx("div", {
60538
+ children: jsxRuntime.jsx(ColorInput, {
60539
+ id: 'waterfall-increase-color',
60540
+ label: textOverride('increase_color', 'Positive value'),
60541
+ currentValue: increaseColor,
60542
+ setColor: function setColor(increaseColor) {
60543
+ return debouncedSetAttributes({
60544
+ increaseColor: increaseColor
60545
+ });
60546
+ }
60547
+ })
60548
+ }), jsxRuntime.jsx("div", {
60549
+ children: jsxRuntime.jsx(ColorInput, {
60550
+ id: 'waterfall-decrease-color',
60551
+ label: textOverride('decrease_color', 'Negative value'),
60552
+ currentValue: decreaseColor,
60553
+ setColor: function setColor(decreaseColor) {
60554
+ return debouncedSetAttributes({
60555
+ decreaseColor: decreaseColor
60556
+ });
60557
+ }
60558
+ })
60559
+ })]
60560
+ })
60561
+ });
60562
+ };
60563
+
60475
60564
  var FormatPanelFromConfig = function FormatPanelFromConfig(props) {
60476
60565
  return jsxRuntime.jsx(EditorGrid, {
60477
60566
  children: props == null ? void 0 : props.formatPanelConfig.map(function (section, i) {
@@ -60502,6 +60591,8 @@ var FormatPanelFromConfig = function FormatPanelFromConfig(props) {
60502
60591
  section: section
60503
60592
  })), section.type === 'mapColors' && jsxRuntime.jsx(MapColorsSection, _extends({}, props, {
60504
60593
  section: section
60594
+ })), section.type === 'waterfallColors' && jsxRuntime.jsx(WaterfallColorsSection, _extends({}, props, {
60595
+ section: section
60505
60596
  })), section.type === 'conditionalFormatting' && jsxRuntime.jsx(ConditionalFormattingSection, _extends({}, props, {
60506
60597
  section: section
60507
60598
  })), section.type === 'goalLine' && jsxRuntime.jsx(GoalLineSection, _extends({}, props, {