@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
@@ -28,13 +28,13 @@ import { preserveOffsetOnSource } from '@atlaskit/pragmatic-drag-and-drop/elemen
28
28
  import { dropTargetForExternal } from '@atlaskit/pragmatic-drag-and-drop/external/adapter';
29
29
  import { DropIndicator } from '@atlaskit/pragmatic-drag-and-drop-react-drop-indicator/box';
30
30
  import { ParentSize } from '@visx/responsive';
31
- import { Annotation, AnnotationConnector, AnnotationLabel, DataContext, buildChartTheme, lightTheme, XYChart, Grid as Grid$2, Axis, AreaSeries, AreaStack, BarGroup, BarSeries, BarStack, GlyphSeries, LineSeries, Tooltip as Tooltip$3 } from '@visx/xychart';
31
+ import { Annotation, AnnotationConnector, AnnotationLabel, DataContext, buildChartTheme, lightTheme, XYChart, Grid as Grid$2, Axis, AreaSeries, AreaStack, BarGroup as BarGroup$1, BarSeries, BarStack, GlyphSeries, LineSeries, Tooltip as Tooltip$3 } from '@visx/xychart';
32
32
  import { LinearGradient } from '@visx/gradient';
33
33
  import { LegendItem as LegendItem$1, LegendLabel } from '@visx/legend';
34
- import { scaleOrdinal, scaleQuantize, scalePoint, scaleTime, scaleLinear, scaleBand } from '@visx/scale';
34
+ import { scaleOrdinal, scaleQuantize, scaleLinear, scalePoint, scaleTime, scaleBand } from '@visx/scale';
35
35
  import Ordinal from '@visx/legend/lib/legends/Ordinal';
36
36
  import { curveNatural, curveMonotoneX, curveMonotoneY, curveLinear, curveStep, curveStepBefore, curveStepAfter } from '@visx/curve';
37
- import { Line as Line$1, LinePath, BarGroup as BarGroup$1, BarStack as BarStack$1, AreaStack as AreaStack$1, AreaClosed, LineRadial } from '@visx/shape';
37
+ import { Line as Line$1, LinePath, BarStack as BarStack$1, BarGroup as BarGroup$2, AreaStack as AreaStack$1, AreaClosed, LineRadial } from '@visx/shape';
38
38
  import { Mercator, Graticule } from '@visx/geo';
39
39
  import { feature } from 'topojson-client';
40
40
  import ParentSize$1 from '@visx/responsive/lib/components/ParentSize';
@@ -1550,7 +1550,7 @@ var upcastFilterType = function upcastFilterType(type) {
1550
1550
  if (type === 'dateTimeFilter') {
1551
1551
  return DATE_FILTER;
1552
1552
  }
1553
- if (type === 'numericFilter' || type === 'multiSelectFilter') {
1553
+ if (type === 'numericFilter') {
1554
1554
  return ADVANCED_FILTER;
1555
1555
  }
1556
1556
  return type;
@@ -10009,7 +10009,9 @@ var attributesSchema$h = function attributesSchema(config) {
10009
10009
  parameters: parametersSchema(config.queryEngineConfig, config.attributesSchemaOptions),
10010
10010
  axisTitles: axisTitleSchema(),
10011
10011
  headline: headlineSchema(),
10012
- tags: tagsSchema()
10012
+ tags: tagsSchema(),
10013
+ increaseColor: Joi.string().required(),
10014
+ decreaseColor: Joi.string().required()
10013
10015
  }));
10014
10016
  };
10015
10017
 
@@ -10173,6 +10175,11 @@ var CONSTANTS$j = {
10173
10175
  type: 'headline',
10174
10176
  title: 'Headline',
10175
10177
  description: ''
10178
+ },
10179
+ waterfall_colors: {
10180
+ type: 'waterfallColors',
10181
+ title: 'Color selector',
10182
+ description: ''
10176
10183
  }
10177
10184
  }
10178
10185
  };
@@ -10212,6 +10219,8 @@ var WaterfallChart = function WaterfallChart(config) {
10212
10219
  axisTitles: dumped.axisTitles,
10213
10220
  displaySubject: dumped.displaySubject,
10214
10221
  displayTitle: dumped.displayTitle,
10222
+ increaseColor: dumped.increaseColor,
10223
+ decreaseColor: dumped.decreaseColor,
10215
10224
  protectedByOrganisation: dumped.protectedByOrganisation,
10216
10225
  type: dumped.type,
10217
10226
  offset: dumped.offset
@@ -10246,6 +10255,8 @@ var WaterfallChart = function WaterfallChart(config) {
10246
10255
  parameters: {},
10247
10256
  axisTitles: undefined,
10248
10257
  headline: undefined,
10258
+ increaseColor: '#00FF00',
10259
+ decreaseColor: '#FF0000',
10249
10260
  tags: [],
10250
10261
  approxXAxisLabelCount: 'auto',
10251
10262
  approxYAxisLabelCount: 'auto'
@@ -10300,7 +10311,7 @@ var WaterfallChart = function WaterfallChart(config) {
10300
10311
  }), namespace(CONSTANTS$j, 'sort'), namespace(CONSTANTS$j, 'filter'), namespace(CONSTANTS$j, 'custom_metrics'), namespace(CONSTANTS$j, 'limit')];
10301
10312
  },
10302
10313
  formatPanelConfig: function formatPanelConfig() {
10303
- return [headingConstant(CONSTANTS$j), chartStylesConstant(CONSTANTS$j, false, false), axisLabelsConstants(CONSTANTS$j)];
10314
+ return [headingConstant(CONSTANTS$j), namespace(CONSTANTS$j, 'waterfall_colors'), chartStylesConstant(CONSTANTS$j, false, false), axisLabelsConstants(CONSTANTS$j)];
10304
10315
  },
10305
10316
  supportedCustomFields: {
10306
10317
  percentages: true,
@@ -13767,8 +13778,7 @@ var ADMIN_FEATURE_TOGGLES = {
13767
13778
  forceMobile: false,
13768
13779
  unloadOffScreenViews: false,
13769
13780
  showSavingIndicator: false,
13770
- disablePersistingGlobalFiltersLocally: false,
13771
- simpleMultiSelectFilter: false
13781
+ disablePersistingGlobalFiltersLocally: false
13772
13782
  };
13773
13783
  var END_USER_DEFAULT_FEATURE_TOGGLES = {
13774
13784
  parameters: true,
@@ -13805,8 +13815,7 @@ var END_USER_DEFAULT_FEATURE_TOGGLES = {
13805
13815
  forceMobile: false,
13806
13816
  unloadOffScreenViews: false,
13807
13817
  showSavingIndicator: true,
13808
- disablePersistingGlobalFiltersLocally: false,
13809
- simpleMultiSelectFilter: false
13818
+ disablePersistingGlobalFiltersLocally: false
13810
13819
  };
13811
13820
  var build$b = function build(partialFeatureToggles, queryEngineConfig, mode, scope) {
13812
13821
  var featureToggles = {};
@@ -13863,7 +13872,7 @@ var build$b = function build(partialFeatureToggles, queryEngineConfig, mode, sco
13863
13872
  return featureToggles;
13864
13873
  };
13865
13874
  var buildDefaults = function buildDefaults(partialFeatureToggles) {
13866
- var _partialFeatureToggle, _partialFeatureToggle2, _partialFeatureToggle3;
13875
+ var _partialFeatureToggle, _partialFeatureToggle2;
13867
13876
  return {
13868
13877
  showDateAndTimeFilter: partialFeatureToggles.showDateAndTimeFilter !== undefined ? partialFeatureToggles.showDateAndTimeFilter : true,
13869
13878
  showDateFilter: partialFeatureToggles.showDateFilter !== undefined ? partialFeatureToggles.showDateFilter : true,
@@ -13874,8 +13883,7 @@ var buildDefaults = function buildDefaults(partialFeatureToggles) {
13874
13883
  canDownloadViewAsPNG: partialFeatureToggles.canDownloadViewAsPNG !== undefined ? partialFeatureToggles.canDownloadViewAsPNG : true,
13875
13884
  forceMobile: partialFeatureToggles.forceMobile !== undefined ? partialFeatureToggles.forceMobile : false,
13876
13885
  unloadOffScreenViews: partialFeatureToggles.unloadOffScreenViews !== undefined ? partialFeatureToggles.unloadOffScreenViews : false,
13877
- allowCalculatedField: (_partialFeatureToggle2 = partialFeatureToggles.allowCalculatedField) != null ? _partialFeatureToggle2 : false,
13878
- simpleMultiSelectFilter: (_partialFeatureToggle3 = partialFeatureToggles.simpleMultiSelectFilter) != null ? _partialFeatureToggle3 : false
13886
+ allowCalculatedField: (_partialFeatureToggle2 = partialFeatureToggles.allowCalculatedField) != null ? _partialFeatureToggle2 : false
13879
13887
  };
13880
13888
  };
13881
13889
 
@@ -28875,8 +28883,7 @@ var AdditionalFilter = function AdditionalFilter(props) {
28875
28883
  onChange = props.onChange,
28876
28884
  shouldAlwaysHaveValue = props.shouldAlwaysHaveValue;
28877
28885
  var _useDashboardBehaviou = useDashboardBehaviourContext(),
28878
- queryEngineConfig = _useDashboardBehaviou.queryEngineConfig,
28879
- featureToggles = _useDashboardBehaviou.featureToggles;
28886
+ queryEngineConfig = _useDashboardBehaviou.queryEngineConfig;
28880
28887
 
28881
28888
  /** Validate the new filter before setting it */
28882
28889
  var onChangeWithValidation = function onChangeWithValidation(newFilter) {
@@ -28927,7 +28934,7 @@ var AdditionalFilter = function AdditionalFilter(props) {
28927
28934
  dataSets: props.dataSets
28928
28935
  }, typeof props.filter.value === 'boolean' ? undefined : JSON.stringify(props.filter.value));
28929
28936
  }
28930
- if (filter.type == MULTI_SELECT_FILTER && featureToggles.simpleMultiSelectFilter) {
28937
+ if (filter.type == MULTI_SELECT_FILTER) {
28931
28938
  return jsx(MultiSelectFilter, {
28932
28939
  showClearBtn: !shouldAlwaysHaveValue,
28933
28940
  filter: filter,
@@ -33157,7 +33164,7 @@ var VizzlyXYChart = function VizzlyXYChart(props) {
33157
33164
  }), (props == null ? void 0 : props.bars) && !props.bars.stacked && !(props != null && (_props$bars3 = props.bars) != null && _props$bars3.funnelChart) && jsxs(Fragment, {
33158
33165
  children: [props.enableHover && jsx("style", {
33159
33166
  children: "\n /* We need to find a more accurate way to target the rect element. */\n .vizzly-xy-chart > div > svg > rect {\n cursor: pointer;\n }"
33160
- }), jsx(BarGroup, {
33167
+ }), jsx(BarGroup$1, {
33161
33168
  children: props.bars.keys.map(function (key, keyIndex) {
33162
33169
  var _props$bars$styles$co, _props$bars4, _props$bars5;
33163
33170
  return jsx(BarSeries, _extends({
@@ -38117,13 +38124,11 @@ var AddFilterForm = function AddFilterForm(props) {
38117
38124
  value: SINGLE_SELECT_FILTER,
38118
38125
  subText: textOverride('single_select_filter_description', 'Choose a single option from the list to filter. ')
38119
38126
  }];
38120
- if (featureToggles.simpleMultiSelectFilter) {
38121
- filterTypes.push({
38122
- label: textOverride('multi_select', 'Multi select'),
38123
- value: MULTI_SELECT_FILTER,
38124
- subText: textOverride('multi_select_description', 'Allow multiple selections.')
38125
- });
38126
- }
38127
+ filterTypes.push({
38128
+ label: textOverride('multi_select', 'Multi select'),
38129
+ value: MULTI_SELECT_FILTER,
38130
+ subText: textOverride('multi_select_description', 'Allow multiple selections.')
38131
+ });
38127
38132
  filterTypes.push({
38128
38133
  label: textOverride('advanced_filter', 'Advanced filter'),
38129
38134
  value: ADVANCED_FILTER,
@@ -42354,16 +42359,14 @@ var SCROLLBAR_WIDTH = 40;
42354
42359
  var Tooltip$1 = function Tooltip(_ref) {
42355
42360
  var _tooltipData$xKey$for;
42356
42361
  var keys = _ref.keys,
42357
- legendItems = _ref.legendItems,
42358
42362
  showRoundedTotal = _ref.showRoundedTotal,
42359
42363
  tooltipData = _ref.tooltipData,
42360
42364
  tooltipLeft = _ref.tooltipLeft,
42361
42365
  tooltipTop = _ref.tooltipTop,
42362
- visibleYKeys = _ref.visibleYKeys,
42363
42366
  xKey = _ref.xKey,
42364
42367
  yKeys = _ref.yKeys,
42365
- conditionalFormattingRules = _ref.conditionalFormattingRules,
42366
- theme = _ref.theme;
42368
+ theme = _ref.theme,
42369
+ items = _ref.items;
42367
42370
  var tooltipRef = useRef(null);
42368
42371
  var _useState = useState({
42369
42372
  left: tooltipLeft
@@ -42412,7 +42415,7 @@ var Tooltip$1 = function Tooltip(_ref) {
42412
42415
  fontSize: '15px',
42413
42416
  width: '100%',
42414
42417
  minWidth: MIN_TOOLTIP_WIDTH
42415
- }, process.env.NODE_ENV === "production" ? "" : ";label:Tooltip;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"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"]} */"),
42418
+ }, process.env.NODE_ENV === "production" ? "" : ";label:Tooltip;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlRvb2x0aXAudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTBGcUIiLCJmaWxlIjoiVG9vbHRpcC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgQ1NTUHJvcGVydGllcywgRnJhZ21lbnQsIHVzZUVmZmVjdCwgdXNlUmVmLCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IGNyZWF0ZVBvcnRhbCB9IGZyb20gJ3JlYWN0LWRvbSc7XG5cbmltcG9ydCB7IGdldENvbG9yIH0gZnJvbSAnLi4vLi4vdXRpbHMnO1xuaW1wb3J0IHsgTGVnZW5kSXRlbUJveCB9IGZyb20gJy4uL0xlZ2VuZC9MZWdlbmRJdGVtQm94JztcbmltcG9ydCB7IFNoYXBlRGVmaW5pdGlvbiwgQ29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZSwgRGF0YUl0ZW0sIEtleSB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQ2hhcnRzVjIvdHlwZXMnO1xuaW1wb3J0IHsgTGluZVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvTGluZUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQmFyU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9CYXJDaGFydFYyL3R5cGVzJztcbmltcG9ydCB7IEFyZWFTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0FyZWFDaGFydFYyL3R5cGVzJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5cbmNvbnN0IE1JTl9UT09MVElQX1dJRFRIID0gMTgwO1xuY29uc3QgVE9PTFRJUF9PRkZTRVQgPSAyMDtcbmNvbnN0IFNDUk9MTEJBUl9XSURUSCA9IDQwO1xuXG5pbnRlcmZhY2UgVG9vbHRpcFByb3BzPFQ+IHtcbiAga2V5czogeyBba2V5OiBzdHJpbmddOiBLZXkgfTtcbiAgc2hvd1JvdW5kZWRUb3RhbDogYm9vbGVhbjtcbiAgdG9vbHRpcERhdGE6IHtcbiAgICBba2V5SWQ6IHN0cmluZ106IERhdGFJdGVtO1xuICB9O1xuICB0b29sdGlwTGVmdDogbnVtYmVyO1xuICB0b29sdGlwVG9wOiBudW1iZXI7XG4gIHhLZXk6IHN0cmluZztcbiAgeUtleXM6IHN0cmluZ1tdO1xuICBpdGVtczoge1xuICAgIGxlZ2VuZEl0ZW1zOiBBcnJheTxTaGFwZURlZmluaXRpb248VD4+O1xuICAgIGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzOiBBcnJheTxDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlPjtcbiAgICB2aXNpYmxlWUtleXM6IHN0cmluZ1tdO1xuICB9W107XG4gIHRoZW1lOiBDU1NQcm9wZXJ0aWVzO1xufVxuXG5leHBvcnQgY29uc3QgVG9vbHRpcCA9ICh7XG4gIGtleXMsXG4gIHNob3dSb3VuZGVkVG90YWwsXG4gIHRvb2x0aXBEYXRhLFxuICB0b29sdGlwTGVmdCxcbiAgdG9vbHRpcFRvcCxcbiAgeEtleSxcbiAgeUtleXMsXG4gIHRoZW1lLFxuICBpdGVtcyxcbn06IFRvb2x0aXBQcm9wczxMaW5lU3R5bGVzIHwgQmFyU3R5bGVzIHwgQXJlYVN0eWxlcz4pID0+IHtcbiAgY29uc3QgdG9vbHRpcFJlZiA9IHVzZVJlZjxIVE1MRGl2RWxlbWVudD4obnVsbCk7XG4gIGNvbnN0IFtwb3NpdGlvbiwgc2V0UG9zaXRpb25dID0gdXNlU3RhdGU8eyBsZWZ0OiBudW1iZXIgfT4oe1xuICAgIGxlZnQ6IHRvb2x0aXBMZWZ0LFxuICB9KTtcblxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGNvbnN0IGFkanVzdFRvb2x0aXBQb3NpdGlvbiA9ICgpID0+IHtcbiAgICAgIGNvbnN0IHRvb2x0aXBFbGVtZW50ID0gdG9vbHRpcFJlZi5jdXJyZW50O1xuXG4gICAgICBpZiAodG9vbHRpcEVsZW1lbnQpIHtcbiAgICAgICAgY29uc3Qgc2NyZWVuV2lkdGggPSB3aW5kb3cuaW5uZXJXaWR0aDtcblxuICAgICAgICBjb25zdCByZWN0ID0gdG9vbHRpcEVsZW1lbnQuZ2V0Qm91bmRpbmdDbGllbnRSZWN0KCk7XG5cbiAgICAgICAgbGV0IHdpZHRoID0gcmVjdC53aWR0aDtcblxuICAgICAgICBpZiAod2lkdGggPCBNSU5fVE9PTFRJUF9XSURUSCkge1xuICAgICAgICAgIHdpZHRoID0gTUlOX1RPT0xUSVBfV0lEVEg7XG4gICAgICAgIH1cblxuICAgICAgICBsZXQgbGVmdCA9IHRvb2x0aXBMZWZ0ICsgVE9PTFRJUF9PRkZTRVQ7XG5cbiAgICAgICAgaWYgKHRvb2x0aXBMZWZ0ICsgd2lkdGggPiBzY3JlZW5XaWR0aCAtIFNDUk9MTEJBUl9XSURUSCkge1xuICAgICAgICAgIGxlZnQgPSB0b29sdGlwTGVmdCAtIHdpZHRoIC0gVE9PTFRJUF9PRkZTRVQ7XG4gICAgICAgIH1cblxuICAgICAgICBzZXRQb3NpdGlvbih7IGxlZnQgfSk7XG4gICAgICB9XG4gICAgfTtcblxuICAgIGFkanVzdFRvb2x0aXBQb3NpdGlvbigpO1xuICB9LCBbdG9vbHRpcExlZnRdKTtcblxuICByZXR1cm4gY3JlYXRlUG9ydGFsKFxuICAgIDxkaXZcbiAgICAgIHJlZj17dG9vbHRpcFJlZn1cbiAgICAgIHN0eWxlPXt7XG4gICAgICAgIHBvc2l0aW9uOiAnYWJzb2x1dGUnLFxuICAgICAgICBsZWZ0OiBwb3NpdGlvbi5sZWZ0LFxuICAgICAgICB0b3A6IHRvb2x0aXBUb3AsXG4gICAgICAgIHpJbmRleDogMjE0NzQ4MzY0NyAqIDEwLFxuICAgICAgICAuLi50aGVtZSxcbiAgICAgIH19XG4gICAgPlxuICAgICAgPGRpdiBzdHlsZT17eyB3b3JkQnJlYWs6ICdicmVhay1hbGwnIH19PlxuICAgICAgICA8ZGl2XG4gICAgICAgICAgY2xhc3NOYW1lPXtjc3Moe1xuICAgICAgICAgICAgZm9udEZhbWlseTogJ2luaGVyaXQnLFxuICAgICAgICAgICAgbGluZUhlaWdodDogJ2luaGVyaXQnLFxuICAgICAgICAgICAgbGV0dGVyU3BhY2luZzogJ2luaGVyaXQnLFxuICAgICAgICAgICAgZm9udFdlaWdodDogJ2JvbGQnLFxuICAgICAgICAgICAgZm9udFNpemU6ICcxNXB4JyxcbiAgICAgICAgICAgIHdpZHRoOiAnMTAwJScsXG4gICAgICAgICAgICBtaW5XaWR0aDogTUlOX1RPT0xUSVBfV0lEVEgsXG4gICAgICAgICAgfSl9XG4gICAgICAgID5cbiAgICAgICAgICB7dG9vbHRpcERhdGFbeEtleV0uZm9ybWF0dGVkVmFsdWUgPz8gdG9vbHRpcERhdGFbeEtleV0udmFsdWV9XG4gICAgICAgIDwvZGl2PlxuICAgICAgICA8dGFibGVcbiAgICAgICAgICBjZWxsUGFkZGluZz17MH1cbiAgICAgICAgICBjZWxsU3BhY2luZz17MH1cbiAgICAgICAgICBjbGFzc05hbWU9e2Nzcyh7XG4gICAgICAgICAgICBtYXJnaW46ICcwJyxcbiAgICAgICAgICAgIGJvcmRlclNwYWNpbmc6ICcwJyxcbiAgICAgICAgICAgIGJvcmRlckNvbGxhcHNlOiAnaW5oZXJpdCcsXG4gICAgICAgICAgICBib3JkZXI6ICdub25lJyxcbiAgICAgICAgICB9KX1cbiAgICAgICAgPlxuICAgICAgICAgIDx0Ym9keT5cbiAgICAgICAgICAgIHtpdGVtcy5tYXAoKGl0ZW0sIGluZGV4KSA9PiB7XG4gICAgICAgICAgICAgIHJldHVybiAoXG4gICAgICAgICAgICAgICAgPEZyYWdtZW50IGtleT17aW5kZXh9PlxuICAgICAgICAgICAgICAgICAge2l0ZW0ubGVnZW5kSXRlbXM/Lm1hcCgobGVnZW5kSXRlbSwgaW5kZXgpID0+IHtcbiAgICAgICAgICAgICAgICAgICAgaWYgKCF0b29sdGlwRGF0YVtsZWdlbmRJdGVtLnlLZXldIHx8IHRvb2x0aXBEYXRhW2xlZ2VuZEl0ZW0ueUtleV0udmFsdWUgPT09IG51bGwpIHtcbiAgICAgICAgICAgICAgICAgICAgICAvLyB5S2V5IGNvdWxkIG5vdCBiZSBmb3VuZCBpbiB0b29sdGlwRGF0YVxuICAgICAgICAgICAgICAgICAgICAgIHJldHVybiBudWxsO1xuICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICAgIHJldHVybiAoXG4gICAgICAgICAgICAgICAgICAgICAgaXRlbS52aXNpYmxlWUtleXM/LmluY2x1ZGVzKGxlZ2VuZEl0ZW0ueUtleSkgJiYgKFxuICAgICAgICAgICAgICAgICAgICAgICAgPHRyIGtleT17bGVnZW5kSXRlbS55S2V5fT5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgPHRkXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgc3R5bGU9e3tcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHZlcnRpY2FsQWxpZ246ICdtaWRkbGUnLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgcGFkZGluZzogaW5kZXggPT09IDAgPyAnMTJweCA4cHggMCAwJyA6ICc4cHggOHB4IDAgMCcsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICB3aWR0aDogJ2F1dG8nLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIH19XG4gICAgICAgICAgICAgICAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICA8TGVnZW5kSXRlbUJveFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgY29sb3I9e2dldENvbG9yKHtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgZGVmYXVsdENvbG9yOiBsZWdlbmRJdGVtLmNvbG9yLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB2YWx1ZTogdG9vbHRpcERhdGFbbGVnZW5kSXRlbS55S2V5XS52YWx1ZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgeUtleTogbGVnZW5kSXRlbS55S2V5LFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlczogaXRlbS5jb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlcyA/PyBbXSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIH0pfVxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgc3R5bGU9e2xlZ2VuZEl0ZW0uc3R5bGUgYXMgTGluZVN0eWxlc31cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHlLZXk9e2xlZ2VuZEl0ZW0ueUtleX1cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgICAgICAgICAgICAgICA8L3RkPlxuICAgICAgICAgICAgICAgICAgICAgICAgICA8dGQgc3R5bGU9e3sgcGFkZGluZzogJzhweCAwIDAgMCcgfX0+e2tleXNbbGVnZW5kSXRlbS55S2V5XS5rZXlGb3JtYXR0ZWR9PC90ZD5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgPHRkIHN0eWxlPXt7IGZvbnRXZWlnaHQ6ICdib2xkJywgcGFkZGluZzogJzhweCAwIDAgMTZweCcgfX0+XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAge3Rvb2x0aXBEYXRhW2xlZ2VuZEl0ZW0ueUtleV0uZm9ybWF0dGVkVmFsdWVcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgID8gdG9vbHRpcERhdGFbbGVnZW5kSXRlbS55S2V5XS5mb3JtYXR0ZWRWYWx1ZVxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgOiB0b29sdGlwRGF0YVtsZWdlbmRJdGVtLnlLZXldLnZhbHVlfVxuICAgICAgICAgICAgICAgICAgICAgICAgICA8L3RkPlxuICAgICAgICAgICAgICAgICAgICAgICAgPC90cj5cbiAgICAgICAgICAgICAgICAgICAgICApXG4gICAgICAgICAgICAgICAgICAgICk7XG4gICAgICAgICAgICAgICAgICB9KX1cbiAgICAgICAgICAgICAgICA8L0ZyYWdtZW50PlxuICAgICAgICAgICAgICApO1xuICAgICAgICAgICAgfSl9XG5cbiAgICAgICAgICAgIHtzaG93Um91bmRlZFRvdGFsICYmIChcbiAgICAgICAgICAgICAgPHRyPlxuICAgICAgICAgICAgICAgIDx0ZCBjb2xTcGFuPXsyfSBzdHlsZT17eyBwYWRkaW5nOiAnMTJweCAwIDAgMCcgfX0+XG4gICAgICAgICAgICAgICAgICBSb3VuZGVkIFRvdGFsXG4gICAgICAgICAgICAgICAgPC90ZD5cbiAgICAgICAgICAgICAgICA8dGQgc3R5bGU9e3sgZm9udFdlaWdodDogJ2JvbGQnLCBwYWRkaW5nOiAnMTJweCAwIDAgMTZweCcgfX0+XG4gICAgICAgICAgICAgICAgICB7eUtleXMucmVkdWNlKCh0b3RhbCwga2V5KSA9PiB7XG4gICAgICAgICAgICAgICAgICAgIHJldHVybiB0b3RhbCArIE1hdGgucm91bmQodG9vbHRpcERhdGFba2V5XS52YWx1ZSBhcyBudW1iZXIpO1xuICAgICAgICAgICAgICAgICAgfSwgMCl9XG4gICAgICAgICAgICAgICAgPC90ZD5cbiAgICAgICAgICAgICAgPC90cj5cbiAgICAgICAgICAgICl9XG4gICAgICAgICAgPC90Ym9keT5cbiAgICAgICAgPC90YWJsZT5cbiAgICAgIDwvZGl2PlxuICAgIDwvZGl2PixcbiAgICBkb2N1bWVudC5ib2R5XG4gICk7XG59O1xuIl19 */"),
42416
42419
  children: (_tooltipData$xKey$for = tooltipData[xKey].formattedValue) != null ? _tooltipData$xKey$for : tooltipData[xKey].value
42417
42420
  }), jsx("table", {
42418
42421
  cellPadding: 0,
@@ -42423,45 +42426,51 @@ var Tooltip$1 = function Tooltip(_ref) {
42423
42426
  } : {
42424
42427
  name: "9a1sa-Tooltip",
42425
42428
  styles: "margin:0;border-spacing:0;border-collapse:inherit;border:none;label:Tooltip;",
42426
- 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"]} */",
42429
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlRvb2x0aXAudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXlHcUIiLCJmaWxlIjoiVG9vbHRpcC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgQ1NTUHJvcGVydGllcywgRnJhZ21lbnQsIHVzZUVmZmVjdCwgdXNlUmVmLCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IGNyZWF0ZVBvcnRhbCB9IGZyb20gJ3JlYWN0LWRvbSc7XG5cbmltcG9ydCB7IGdldENvbG9yIH0gZnJvbSAnLi4vLi4vdXRpbHMnO1xuaW1wb3J0IHsgTGVnZW5kSXRlbUJveCB9IGZyb20gJy4uL0xlZ2VuZC9MZWdlbmRJdGVtQm94JztcbmltcG9ydCB7IFNoYXBlRGVmaW5pdGlvbiwgQ29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZSwgRGF0YUl0ZW0sIEtleSB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQ2hhcnRzVjIvdHlwZXMnO1xuaW1wb3J0IHsgTGluZVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvTGluZUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQmFyU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9CYXJDaGFydFYyL3R5cGVzJztcbmltcG9ydCB7IEFyZWFTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0FyZWFDaGFydFYyL3R5cGVzJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5cbmNvbnN0IE1JTl9UT09MVElQX1dJRFRIID0gMTgwO1xuY29uc3QgVE9PTFRJUF9PRkZTRVQgPSAyMDtcbmNvbnN0IFNDUk9MTEJBUl9XSURUSCA9IDQwO1xuXG5pbnRlcmZhY2UgVG9vbHRpcFByb3BzPFQ+IHtcbiAga2V5czogeyBba2V5OiBzdHJpbmddOiBLZXkgfTtcbiAgc2hvd1JvdW5kZWRUb3RhbDogYm9vbGVhbjtcbiAgdG9vbHRpcERhdGE6IHtcbiAgICBba2V5SWQ6IHN0cmluZ106IERhdGFJdGVtO1xuICB9O1xuICB0b29sdGlwTGVmdDogbnVtYmVyO1xuICB0b29sdGlwVG9wOiBudW1iZXI7XG4gIHhLZXk6IHN0cmluZztcbiAgeUtleXM6IHN0cmluZ1tdO1xuICBpdGVtczoge1xuICAgIGxlZ2VuZEl0ZW1zOiBBcnJheTxTaGFwZURlZmluaXRpb248VD4+O1xuICAgIGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzOiBBcnJheTxDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlPjtcbiAgICB2aXNpYmxlWUtleXM6IHN0cmluZ1tdO1xuICB9W107XG4gIHRoZW1lOiBDU1NQcm9wZXJ0aWVzO1xufVxuXG5leHBvcnQgY29uc3QgVG9vbHRpcCA9ICh7XG4gIGtleXMsXG4gIHNob3dSb3VuZGVkVG90YWwsXG4gIHRvb2x0aXBEYXRhLFxuICB0b29sdGlwTGVmdCxcbiAgdG9vbHRpcFRvcCxcbiAgeEtleSxcbiAgeUtleXMsXG4gIHRoZW1lLFxuICBpdGVtcyxcbn06IFRvb2x0aXBQcm9wczxMaW5lU3R5bGVzIHwgQmFyU3R5bGVzIHwgQXJlYVN0eWxlcz4pID0+IHtcbiAgY29uc3QgdG9vbHRpcFJlZiA9IHVzZVJlZjxIVE1MRGl2RWxlbWVudD4obnVsbCk7XG4gIGNvbnN0IFtwb3NpdGlvbiwgc2V0UG9zaXRpb25dID0gdXNlU3RhdGU8eyBsZWZ0OiBudW1iZXIgfT4oe1xuICAgIGxlZnQ6IHRvb2x0aXBMZWZ0LFxuICB9KTtcblxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGNvbnN0IGFkanVzdFRvb2x0aXBQb3NpdGlvbiA9ICgpID0+IHtcbiAgICAgIGNvbnN0IHRvb2x0aXBFbGVtZW50ID0gdG9vbHRpcFJlZi5jdXJyZW50O1xuXG4gICAgICBpZiAodG9vbHRpcEVsZW1lbnQpIHtcbiAgICAgICAgY29uc3Qgc2NyZWVuV2lkdGggPSB3aW5kb3cuaW5uZXJXaWR0aDtcblxuICAgICAgICBjb25zdCByZWN0ID0gdG9vbHRpcEVsZW1lbnQuZ2V0Qm91bmRpbmdDbGllbnRSZWN0KCk7XG5cbiAgICAgICAgbGV0IHdpZHRoID0gcmVjdC53aWR0aDtcblxuICAgICAgICBpZiAod2lkdGggPCBNSU5fVE9PTFRJUF9XSURUSCkge1xuICAgICAgICAgIHdpZHRoID0gTUlOX1RPT0xUSVBfV0lEVEg7XG4gICAgICAgIH1cblxuICAgICAgICBsZXQgbGVmdCA9IHRvb2x0aXBMZWZ0ICsgVE9PTFRJUF9PRkZTRVQ7XG5cbiAgICAgICAgaWYgKHRvb2x0aXBMZWZ0ICsgd2lkdGggPiBzY3JlZW5XaWR0aCAtIFNDUk9MTEJBUl9XSURUSCkge1xuICAgICAgICAgIGxlZnQgPSB0b29sdGlwTGVmdCAtIHdpZHRoIC0gVE9PTFRJUF9PRkZTRVQ7XG4gICAgICAgIH1cblxuICAgICAgICBzZXRQb3NpdGlvbih7IGxlZnQgfSk7XG4gICAgICB9XG4gICAgfTtcblxuICAgIGFkanVzdFRvb2x0aXBQb3NpdGlvbigpO1xuICB9LCBbdG9vbHRpcExlZnRdKTtcblxuICByZXR1cm4gY3JlYXRlUG9ydGFsKFxuICAgIDxkaXZcbiAgICAgIHJlZj17dG9vbHRpcFJlZn1cbiAgICAgIHN0eWxlPXt7XG4gICAgICAgIHBvc2l0aW9uOiAnYWJzb2x1dGUnLFxuICAgICAgICBsZWZ0OiBwb3NpdGlvbi5sZWZ0LFxuICAgICAgICB0b3A6IHRvb2x0aXBUb3AsXG4gICAgICAgIHpJbmRleDogMjE0NzQ4MzY0NyAqIDEwLFxuICAgICAgICAuLi50aGVtZSxcbiAgICAgIH19XG4gICAgPlxuICAgICAgPGRpdiBzdHlsZT17eyB3b3JkQnJlYWs6ICdicmVhay1hbGwnIH19PlxuICAgICAgICA8ZGl2XG4gICAgICAgICAgY2xhc3NOYW1lPXtjc3Moe1xuICAgICAgICAgICAgZm9udEZhbWlseTogJ2luaGVyaXQnLFxuICAgICAgICAgICAgbGluZUhlaWdodDogJ2luaGVyaXQnLFxuICAgICAgICAgICAgbGV0dGVyU3BhY2luZzogJ2luaGVyaXQnLFxuICAgICAgICAgICAgZm9udFdlaWdodDogJ2JvbGQnLFxuICAgICAgICAgICAgZm9udFNpemU6ICcxNXB4JyxcbiAgICAgICAgICAgIHdpZHRoOiAnMTAwJScsXG4gICAgICAgICAgICBtaW5XaWR0aDogTUlOX1RPT0xUSVBfV0lEVEgsXG4gICAgICAgICAgfSl9XG4gICAgICAgID5cbiAgICAgICAgICB7dG9vbHRpcERhdGFbeEtleV0uZm9ybWF0dGVkVmFsdWUgPz8gdG9vbHRpcERhdGFbeEtleV0udmFsdWV9XG4gICAgICAgIDwvZGl2PlxuICAgICAgICA8dGFibGVcbiAgICAgICAgICBjZWxsUGFkZGluZz17MH1cbiAgICAgICAgICBjZWxsU3BhY2luZz17MH1cbiAgICAgICAgICBjbGFzc05hbWU9e2Nzcyh7XG4gICAgICAgICAgICBtYXJnaW46ICcwJyxcbiAgICAgICAgICAgIGJvcmRlclNwYWNpbmc6ICcwJyxcbiAgICAgICAgICAgIGJvcmRlckNvbGxhcHNlOiAnaW5oZXJpdCcsXG4gICAgICAgICAgICBib3JkZXI6ICdub25lJyxcbiAgICAgICAgICB9KX1cbiAgICAgICAgPlxuICAgICAgICAgIDx0Ym9keT5cbiAgICAgICAgICAgIHtpdGVtcy5tYXAoKGl0ZW0sIGluZGV4KSA9PiB7XG4gICAgICAgICAgICAgIHJldHVybiAoXG4gICAgICAgICAgICAgICAgPEZyYWdtZW50IGtleT17aW5kZXh9PlxuICAgICAgICAgICAgICAgICAge2l0ZW0ubGVnZW5kSXRlbXM/Lm1hcCgobGVnZW5kSXRlbSwgaW5kZXgpID0+IHtcbiAgICAgICAgICAgICAgICAgICAgaWYgKCF0b29sdGlwRGF0YVtsZWdlbmRJdGVtLnlLZXldIHx8IHRvb2x0aXBEYXRhW2xlZ2VuZEl0ZW0ueUtleV0udmFsdWUgPT09IG51bGwpIHtcbiAgICAgICAgICAgICAgICAgICAgICAvLyB5S2V5IGNvdWxkIG5vdCBiZSBmb3VuZCBpbiB0b29sdGlwRGF0YVxuICAgICAgICAgICAgICAgICAgICAgIHJldHVybiBudWxsO1xuICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICAgIHJldHVybiAoXG4gICAgICAgICAgICAgICAgICAgICAgaXRlbS52aXNpYmxlWUtleXM/LmluY2x1ZGVzKGxlZ2VuZEl0ZW0ueUtleSkgJiYgKFxuICAgICAgICAgICAgICAgICAgICAgICAgPHRyIGtleT17bGVnZW5kSXRlbS55S2V5fT5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgPHRkXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgc3R5bGU9e3tcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHZlcnRpY2FsQWxpZ246ICdtaWRkbGUnLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgcGFkZGluZzogaW5kZXggPT09IDAgPyAnMTJweCA4cHggMCAwJyA6ICc4cHggOHB4IDAgMCcsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICB3aWR0aDogJ2F1dG8nLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIH19XG4gICAgICAgICAgICAgICAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICA8TGVnZW5kSXRlbUJveFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgY29sb3I9e2dldENvbG9yKHtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgZGVmYXVsdENvbG9yOiBsZWdlbmRJdGVtLmNvbG9yLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB2YWx1ZTogdG9vbHRpcERhdGFbbGVnZW5kSXRlbS55S2V5XS52YWx1ZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgeUtleTogbGVnZW5kSXRlbS55S2V5LFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlczogaXRlbS5jb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlcyA/PyBbXSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIH0pfVxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgc3R5bGU9e2xlZ2VuZEl0ZW0uc3R5bGUgYXMgTGluZVN0eWxlc31cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHlLZXk9e2xlZ2VuZEl0ZW0ueUtleX1cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgICAgICAgICAgICAgICA8L3RkPlxuICAgICAgICAgICAgICAgICAgICAgICAgICA8dGQgc3R5bGU9e3sgcGFkZGluZzogJzhweCAwIDAgMCcgfX0+e2tleXNbbGVnZW5kSXRlbS55S2V5XS5rZXlGb3JtYXR0ZWR9PC90ZD5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgPHRkIHN0eWxlPXt7IGZvbnRXZWlnaHQ6ICdib2xkJywgcGFkZGluZzogJzhweCAwIDAgMTZweCcgfX0+XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAge3Rvb2x0aXBEYXRhW2xlZ2VuZEl0ZW0ueUtleV0uZm9ybWF0dGVkVmFsdWVcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgID8gdG9vbHRpcERhdGFbbGVnZW5kSXRlbS55S2V5XS5mb3JtYXR0ZWRWYWx1ZVxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgOiB0b29sdGlwRGF0YVtsZWdlbmRJdGVtLnlLZXldLnZhbHVlfVxuICAgICAgICAgICAgICAgICAgICAgICAgICA8L3RkPlxuICAgICAgICAgICAgICAgICAgICAgICAgPC90cj5cbiAgICAgICAgICAgICAgICAgICAgICApXG4gICAgICAgICAgICAgICAgICAgICk7XG4gICAgICAgICAgICAgICAgICB9KX1cbiAgICAgICAgICAgICAgICA8L0ZyYWdtZW50PlxuICAgICAgICAgICAgICApO1xuICAgICAgICAgICAgfSl9XG5cbiAgICAgICAgICAgIHtzaG93Um91bmRlZFRvdGFsICYmIChcbiAgICAgICAgICAgICAgPHRyPlxuICAgICAgICAgICAgICAgIDx0ZCBjb2xTcGFuPXsyfSBzdHlsZT17eyBwYWRkaW5nOiAnMTJweCAwIDAgMCcgfX0+XG4gICAgICAgICAgICAgICAgICBSb3VuZGVkIFRvdGFsXG4gICAgICAgICAgICAgICAgPC90ZD5cbiAgICAgICAgICAgICAgICA8dGQgc3R5bGU9e3sgZm9udFdlaWdodDogJ2JvbGQnLCBwYWRkaW5nOiAnMTJweCAwIDAgMTZweCcgfX0+XG4gICAgICAgICAgICAgICAgICB7eUtleXMucmVkdWNlKCh0b3RhbCwga2V5KSA9PiB7XG4gICAgICAgICAgICAgICAgICAgIHJldHVybiB0b3RhbCArIE1hdGgucm91bmQodG9vbHRpcERhdGFba2V5XS52YWx1ZSBhcyBudW1iZXIpO1xuICAgICAgICAgICAgICAgICAgfSwgMCl9XG4gICAgICAgICAgICAgICAgPC90ZD5cbiAgICAgICAgICAgICAgPC90cj5cbiAgICAgICAgICAgICl9XG4gICAgICAgICAgPC90Ym9keT5cbiAgICAgICAgPC90YWJsZT5cbiAgICAgIDwvZGl2PlxuICAgIDwvZGl2PixcbiAgICBkb2N1bWVudC5ib2R5XG4gICk7XG59O1xuIl19 */",
42427
42430
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$5
42428
42431
  }),
42429
42432
  children: jsxs("tbody", {
42430
- children: [legendItems.map(function (legendItem, index) {
42431
- if (!tooltipData[legendItem.yKey] || tooltipData[legendItem.yKey].value === null) {
42432
- // yKey could not be found in tooltipData
42433
- return null;
42434
- }
42435
- return visibleYKeys.includes(legendItem.yKey) && jsxs("tr", {
42436
- children: [jsx("td", {
42437
- style: {
42438
- verticalAlign: 'middle',
42439
- padding: index === 0 ? '12px 8px 0 0' : '8px 8px 0 0',
42440
- width: 'auto'
42441
- },
42442
- children: jsx(LegendItemBox, {
42443
- color: getColor({
42444
- defaultColor: legendItem.color,
42445
- value: tooltipData[legendItem.yKey].value,
42446
- yKey: legendItem.yKey,
42447
- conditionalFormattingRules: conditionalFormattingRules
42448
- }),
42449
- style: legendItem.style,
42450
- yKey: legendItem.yKey
42451
- })
42452
- }), jsx("td", {
42453
- style: {
42454
- padding: '8px 0 0 0'
42455
- },
42456
- children: keys[legendItem.yKey].keyFormatted
42457
- }), jsx("td", {
42458
- style: {
42459
- fontWeight: 'bold',
42460
- padding: '8px 0 0 16px'
42461
- },
42462
- children: tooltipData[legendItem.yKey].formattedValue ? tooltipData[legendItem.yKey].formattedValue : tooltipData[legendItem.yKey].value
42463
- })]
42464
- }, legendItem.yKey);
42433
+ children: [items.map(function (item, index) {
42434
+ var _item$legendItems;
42435
+ return jsx(Fragment, {
42436
+ children: (_item$legendItems = item.legendItems) == null ? void 0 : _item$legendItems.map(function (legendItem, index) {
42437
+ var _item$visibleYKeys, _item$conditionalForm;
42438
+ if (!tooltipData[legendItem.yKey] || tooltipData[legendItem.yKey].value === null) {
42439
+ // yKey could not be found in tooltipData
42440
+ return null;
42441
+ }
42442
+ return ((_item$visibleYKeys = item.visibleYKeys) == null ? void 0 : _item$visibleYKeys.includes(legendItem.yKey)) && jsxs("tr", {
42443
+ children: [jsx("td", {
42444
+ style: {
42445
+ verticalAlign: 'middle',
42446
+ padding: index === 0 ? '12px 8px 0 0' : '8px 8px 0 0',
42447
+ width: 'auto'
42448
+ },
42449
+ children: jsx(LegendItemBox, {
42450
+ color: getColor({
42451
+ defaultColor: legendItem.color,
42452
+ value: tooltipData[legendItem.yKey].value,
42453
+ yKey: legendItem.yKey,
42454
+ conditionalFormattingRules: (_item$conditionalForm = item.conditionalFormattingRules) != null ? _item$conditionalForm : []
42455
+ }),
42456
+ style: legendItem.style,
42457
+ yKey: legendItem.yKey
42458
+ })
42459
+ }), jsx("td", {
42460
+ style: {
42461
+ padding: '8px 0 0 0'
42462
+ },
42463
+ children: keys[legendItem.yKey].keyFormatted
42464
+ }), jsx("td", {
42465
+ style: {
42466
+ fontWeight: 'bold',
42467
+ padding: '8px 0 0 16px'
42468
+ },
42469
+ children: tooltipData[legendItem.yKey].formattedValue ? tooltipData[legendItem.yKey].formattedValue : tooltipData[legendItem.yKey].value
42470
+ })]
42471
+ }, legendItem.yKey);
42472
+ })
42473
+ }, index);
42465
42474
  }), showRoundedTotal && jsxs("tr", {
42466
42475
  children: [jsx("td", {
42467
42476
  colSpan: 2,
@@ -42584,11 +42593,9 @@ var LegendItem = function LegendItem(_ref) {
42584
42593
  function _EMOTION_STRINGIFIED_CSS_ERROR__$7() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
42585
42594
  var Legend$1 = function Legend(_ref) {
42586
42595
  var keys = _ref.keys,
42587
- visibleYKeys = _ref.visibleYKeys,
42588
- legendItems = _ref.legendItems,
42589
42596
  setVisibleYKeys = _ref.setVisibleYKeys,
42590
- conditionalFormattingRules = _ref.conditionalFormattingRules,
42591
- marginLeft = _ref.marginLeft;
42597
+ marginLeft = _ref.marginLeft,
42598
+ items = _ref.items;
42592
42599
  return jsx("div", {
42593
42600
  className: /*#__PURE__*/css$1(process.env.NODE_ENV === "production" ? {
42594
42601
  name: "1nbollx",
@@ -42596,7 +42603,7 @@ var Legend$1 = function Legend(_ref) {
42596
42603
  } : {
42597
42604
  name: "qz6h7j-Legend",
42598
42605
  styles: "height:40px;padding-top:8px;label:Legend;",
42599
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNEJvQiIsImZpbGUiOiJMZWdlbmQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcblxuaW1wb3J0IHsgTGVnZW5kSXRlbSB9IGZyb20gJy4vTGVnZW5kSXRlbSc7XG5pbXBvcnQgeyBTaGFwZURlZmluaXRpb24sIENvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGUsIEtleSB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQ2hhcnRzVjIvdHlwZXMnO1xuaW1wb3J0IHsgU2Nyb2xsYmFyIH0gZnJvbSAnLi4vLi4vLi4vU2Nyb2xsYmFyL1Njcm9sbGJhcic7XG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9jc3MnO1xuaW1wb3J0IHsgQmFyU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9CYXJDaGFydFYyL3R5cGVzJztcbmltcG9ydCB7IExpbmVTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0xpbmVDaGFydFYyL3R5cGVzJztcbmltcG9ydCB7IEFyZWFTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0FyZWFDaGFydFYyL3R5cGVzJztcblxuaW50ZXJmYWNlIExlZ2VuZFByb3BzPFQ+IHtcbiAgc2V0VmlzaWJsZVlLZXlzOiBSZWFjdC5EaXNwYXRjaDxSZWFjdC5TZXRTdGF0ZUFjdGlvbjxBcnJheTxzdHJpbmc+Pj47XG4gIHZpc2libGVZS2V5czogQXJyYXk8c3RyaW5nPjtcbiAga2V5czogeyBba2V5OiBzdHJpbmddOiBLZXkgfTtcbiAgbGVnZW5kSXRlbXM6IEFycmF5PFNoYXBlRGVmaW5pdGlvbjxUPj47XG4gIGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzOiBBcnJheTxDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlPjtcbiAgbWFyZ2luTGVmdDogbnVtYmVyO1xufVxuXG5leHBvcnQgY29uc3QgTGVnZW5kID0gKHtcbiAga2V5cyxcbiAgdmlzaWJsZVlLZXlzLFxuICBsZWdlbmRJdGVtcyxcbiAgc2V0VmlzaWJsZVlLZXlzLFxuICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlcyxcbiAgbWFyZ2luTGVmdCxcbn06IExlZ2VuZFByb3BzPEJhclN0eWxlcyB8IExpbmVTdHlsZXMgfCBBcmVhU3R5bGVzPikgPT4ge1xuICByZXR1cm4gKFxuICAgIDxkaXYgY2xhc3NOYW1lPXtjc3MoeyBoZWlnaHQ6IDQwLCBwYWRkaW5nVG9wOiA4IH0pfT5cbiAgICAgIDxTY3JvbGxiYXJcbiAgICAgICAgY2xhc3NOYW1lPXtjc3Moe1xuICAgICAgICAgIGRpc3BsYXk6ICdmbGV4JyxcbiAgICAgICAgICBmbGV4RGlyZWN0aW9uOiAncm93JyxcbiAgICAgICAgICBmbGV4V3JhcDogJ25vd3JhcCcsXG4gICAgICAgICAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG4gICAgICAgICAgbWFyZ2luTGVmdDogbWFyZ2luTGVmdCA/IGAke21hcmdpbkxlZnR9cHhgIDogdW5kZWZpbmVkLFxuICAgICAgICB9KX1cbiAgICAgICAgeD17dHJ1ZX1cbiAgICAgID5cbiAgICAgICAge2xlZ2VuZEl0ZW1zLm1hcChcbiAgICAgICAgICBsZWdlbmRJdGVtID0+XG4gICAgICAgICAgICBrZXlzW2xlZ2VuZEl0ZW0ueUtleV0gJiYgKFxuICAgICAgICAgICAgICA8TGVnZW5kSXRlbVxuICAgICAgICAgICAgICAgIHsuLi5sZWdlbmRJdGVtfVxuICAgICAgICAgICAgICAgIGtleT17YGxlZ2VuZC0ke2xlZ2VuZEl0ZW0ueUtleX1gfVxuICAgICAgICAgICAgICAgIHlLZXlGb3JtYXR0ZWQ9e2tleXNbbGVnZW5kSXRlbS55S2V5XS5rZXlGb3JtYXR0ZWR9XG4gICAgICAgICAgICAgICAgb25DbGljaz17KCkgPT5cbiAgICAgICAgICAgICAgICAgIHNldFZpc2libGVZS2V5cyhwcmV2ID0+IHtcbiAgICAgICAgICAgICAgICAgICAgbGV0IG5ld1Zpc2libGVMZWdlbmRJdGVtczogQXJyYXk8c3RyaW5nPiA9IFtdO1xuXG4gICAgICAgICAgICAgICAgICAgIGlmIChwcmV2Lmxlbmd0aCA9PT0gbGVnZW5kSXRlbXMubGVuZ3RoKSB7XG4gICAgICAgICAgICAgICAgICAgICAgbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zID0gW2xlZ2VuZEl0ZW0ueUtleV07XG4gICAgICAgICAgICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICAgICAgICAgICAgaWYgKHByZXYuaW5jbHVkZXMobGVnZW5kSXRlbS55S2V5KSkge1xuICAgICAgICAgICAgICAgICAgICAgICAgbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zID0gcHJldi5maWx0ZXIocHJldkxlZ2VuZEl0ZW1JZCA9PiBwcmV2TGVnZW5kSXRlbUlkICE9PSBsZWdlbmRJdGVtLnlLZXkpO1xuICAgICAgICAgICAgICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICAgICAgICAgICAgICBuZXdWaXNpYmxlTGVnZW5kSXRlbXMgPSBbLi4ucHJldiwgbGVnZW5kSXRlbS55S2V5XTtcbiAgICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgICAgICAgICByZXR1cm4gbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zLmxlbmd0aCA9PT0gMFxuICAgICAgICAgICAgICAgICAgICAgID8gbGVnZW5kSXRlbXMubWFwKGxlZ2VuZEl0ZW0gPT4gbGVnZW5kSXRlbS55S2V5KVxuICAgICAgICAgICAgICAgICAgICAgIDogbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zO1xuICAgICAgICAgICAgICAgICAgfSlcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgdmlzaWJsZT17dmlzaWJsZVlLZXlzLmluY2x1ZGVzKGxlZ2VuZEl0ZW0ueUtleSl9XG4gICAgICAgICAgICAgICAgY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXM9e2NvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzfVxuICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgKVxuICAgICAgICApfVxuICAgICAgPC9TY3JvbGxiYXI+XG4gICAgPC9kaXY+XG4gICk7XG59O1xuIl19 */",
42606
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNEJvQiIsImZpbGUiOiJMZWdlbmQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0LCB7IEZyYWdtZW50IH0gZnJvbSAncmVhY3QnO1xuXG5pbXBvcnQgeyBMZWdlbmRJdGVtIH0gZnJvbSAnLi9MZWdlbmRJdGVtJztcbmltcG9ydCB7IFNoYXBlRGVmaW5pdGlvbiwgQ29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZSwgS2V5IH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9DaGFydHNWMi90eXBlcyc7XG5pbXBvcnQgeyBTY3JvbGxiYXIgfSBmcm9tICcuLi8uLi8uLi9TY3JvbGxiYXIvU2Nyb2xsYmFyJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBCYXJTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0JhckNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgTGluZVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvTGluZUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQXJlYVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQXJlYUNoYXJ0VjIvdHlwZXMnO1xuXG5pbnRlcmZhY2UgTGVnZW5kUHJvcHM8VD4ge1xuICBzZXRWaXNpYmxlWUtleXM/OiBSZWFjdC5EaXNwYXRjaDxSZWFjdC5TZXRTdGF0ZUFjdGlvbjxBcnJheTxzdHJpbmc+Pj47XG4gIGtleXM6IHsgW2tleTogc3RyaW5nXTogS2V5IH07XG4gIG1hcmdpbkxlZnQ6IG51bWJlcjtcbiAgaXRlbXM/OiB7XG4gICAgbGVnZW5kSXRlbXM6IEFycmF5PFNoYXBlRGVmaW5pdGlvbjxUPj47XG4gICAgdmlzaWJsZVlLZXlzOiBBcnJheTxzdHJpbmc+O1xuICAgIGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzOiBBcnJheTxDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlPjtcbiAgfVtdO1xufVxuXG5leHBvcnQgY29uc3QgTGVnZW5kID0gKHtcbiAga2V5cyxcbiAgc2V0VmlzaWJsZVlLZXlzLFxuICBtYXJnaW5MZWZ0LFxuICBpdGVtcyxcbn06IExlZ2VuZFByb3BzPEJhclN0eWxlcyB8IExpbmVTdHlsZXMgfCBBcmVhU3R5bGVzPikgPT4ge1xuICByZXR1cm4gKFxuICAgIDxkaXYgY2xhc3NOYW1lPXtjc3MoeyBoZWlnaHQ6IDQwLCBwYWRkaW5nVG9wOiA4IH0pfT5cbiAgICAgIDxTY3JvbGxiYXJcbiAgICAgICAgY2xhc3NOYW1lPXtjc3Moe1xuICAgICAgICAgIGRpc3BsYXk6ICdmbGV4JyxcbiAgICAgICAgICBmbGV4RGlyZWN0aW9uOiAncm93JyxcbiAgICAgICAgICBmbGV4V3JhcDogJ25vd3JhcCcsXG4gICAgICAgICAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG4gICAgICAgICAgbWFyZ2luTGVmdDogbWFyZ2luTGVmdCA/IGAke21hcmdpbkxlZnR9cHhgIDogdW5kZWZpbmVkLFxuICAgICAgICB9KX1cbiAgICAgICAgeD17dHJ1ZX1cbiAgICAgID5cbiAgICAgICAge2l0ZW1zPy5tYXAoKGl0ZW0sIGluZGV4KSA9PiAoXG4gICAgICAgICAgPEZyYWdtZW50IGtleT17aW5kZXh9PlxuICAgICAgICAgICAge2l0ZW0ubGVnZW5kSXRlbXM/Lm1hcChcbiAgICAgICAgICAgICAgbGVnZW5kSXRlbSA9PlxuICAgICAgICAgICAgICAgIGtleXNbbGVnZW5kSXRlbS55S2V5XSAmJiAoXG4gICAgICAgICAgICAgICAgICA8TGVnZW5kSXRlbVxuICAgICAgICAgICAgICAgICAgICB7Li4ubGVnZW5kSXRlbX1cbiAgICAgICAgICAgICAgICAgICAga2V5PXtgbGVnZW5kLSR7bGVnZW5kSXRlbS55S2V5fWB9XG4gICAgICAgICAgICAgICAgICAgIHlLZXlGb3JtYXR0ZWQ9e2tleXNbbGVnZW5kSXRlbS55S2V5XS5rZXlGb3JtYXR0ZWR9XG4gICAgICAgICAgICAgICAgICAgIG9uQ2xpY2s9eygpID0+XG4gICAgICAgICAgICAgICAgICAgICAgc2V0VmlzaWJsZVlLZXlzICYmXG4gICAgICAgICAgICAgICAgICAgICAgc2V0VmlzaWJsZVlLZXlzKHByZXYgPT4ge1xuICAgICAgICAgICAgICAgICAgICAgICAgbGV0IG5ld1Zpc2libGVMZWdlbmRJdGVtczogQXJyYXk8c3RyaW5nPiA9IFtdO1xuXG4gICAgICAgICAgICAgICAgICAgICAgICBpZiAocHJldi5sZW5ndGggPT09IGl0ZW0ubGVnZW5kSXRlbXMubGVuZ3RoKSB7XG4gICAgICAgICAgICAgICAgICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IFtsZWdlbmRJdGVtLnlLZXldO1xuICAgICAgICAgICAgICAgICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgaWYgKHByZXYuaW5jbHVkZXMobGVnZW5kSXRlbS55S2V5KSkge1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IHByZXYuZmlsdGVyKFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgcHJldkxlZ2VuZEl0ZW1JZCA9PiBwcmV2TGVnZW5kSXRlbUlkICE9PSBsZWdlbmRJdGVtLnlLZXlcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICApO1xuICAgICAgICAgICAgICAgICAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IFsuLi5wcmV2LCBsZWdlbmRJdGVtLnlLZXldO1xuICAgICAgICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICAgICAgICB9XG5cbiAgICAgICAgICAgICAgICAgICAgICAgIHJldHVybiBuZXdWaXNpYmxlTGVnZW5kSXRlbXMubGVuZ3RoID09PSAwXG4gICAgICAgICAgICAgICAgICAgICAgICAgID8gaXRlbS5sZWdlbmRJdGVtcy5tYXAobGVnZW5kSXRlbSA9PiBsZWdlbmRJdGVtLnlLZXkpXG4gICAgICAgICAgICAgICAgICAgICAgICAgIDogbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zO1xuICAgICAgICAgICAgICAgICAgICAgIH0pXG4gICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICAgICAgdmlzaWJsZT17c2V0VmlzaWJsZVlLZXlzID8gaXRlbS52aXNpYmxlWUtleXMuaW5jbHVkZXMobGVnZW5kSXRlbS55S2V5KSA6IHRydWV9XG4gICAgICAgICAgICAgICAgICAgIGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzPXtpdGVtLmNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzfVxuICAgICAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgICAgICApXG4gICAgICAgICAgICApfVxuICAgICAgICAgIDwvRnJhZ21lbnQ+XG4gICAgICAgICkpfVxuICAgICAgPC9TY3JvbGxiYXI+XG4gICAgPC9kaXY+XG4gICk7XG59O1xuIl19 */",
42600
42607
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$7
42601
42608
  }),
42602
42609
  children: jsx(Scrollbar, {
@@ -42606,34 +42613,39 @@ var Legend$1 = function Legend(_ref) {
42606
42613
  flexWrap: 'nowrap',
42607
42614
  alignItems: 'center',
42608
42615
  marginLeft: marginLeft ? marginLeft + "px" : undefined
42609
- }, process.env.NODE_ENV === "production" ? "" : ";label:Legend;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBOEJtQiIsImZpbGUiOiJMZWdlbmQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcblxuaW1wb3J0IHsgTGVnZW5kSXRlbSB9IGZyb20gJy4vTGVnZW5kSXRlbSc7XG5pbXBvcnQgeyBTaGFwZURlZmluaXRpb24sIENvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGUsIEtleSB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQ2hhcnRzVjIvdHlwZXMnO1xuaW1wb3J0IHsgU2Nyb2xsYmFyIH0gZnJvbSAnLi4vLi4vLi4vU2Nyb2xsYmFyL1Njcm9sbGJhcic7XG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9jc3MnO1xuaW1wb3J0IHsgQmFyU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9CYXJDaGFydFYyL3R5cGVzJztcbmltcG9ydCB7IExpbmVTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0xpbmVDaGFydFYyL3R5cGVzJztcbmltcG9ydCB7IEFyZWFTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0FyZWFDaGFydFYyL3R5cGVzJztcblxuaW50ZXJmYWNlIExlZ2VuZFByb3BzPFQ+IHtcbiAgc2V0VmlzaWJsZVlLZXlzOiBSZWFjdC5EaXNwYXRjaDxSZWFjdC5TZXRTdGF0ZUFjdGlvbjxBcnJheTxzdHJpbmc+Pj47XG4gIHZpc2libGVZS2V5czogQXJyYXk8c3RyaW5nPjtcbiAga2V5czogeyBba2V5OiBzdHJpbmddOiBLZXkgfTtcbiAgbGVnZW5kSXRlbXM6IEFycmF5PFNoYXBlRGVmaW5pdGlvbjxUPj47XG4gIGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzOiBBcnJheTxDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlPjtcbiAgbWFyZ2luTGVmdDogbnVtYmVyO1xufVxuXG5leHBvcnQgY29uc3QgTGVnZW5kID0gKHtcbiAga2V5cyxcbiAgdmlzaWJsZVlLZXlzLFxuICBsZWdlbmRJdGVtcyxcbiAgc2V0VmlzaWJsZVlLZXlzLFxuICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlcyxcbiAgbWFyZ2luTGVmdCxcbn06IExlZ2VuZFByb3BzPEJhclN0eWxlcyB8IExpbmVTdHlsZXMgfCBBcmVhU3R5bGVzPikgPT4ge1xuICByZXR1cm4gKFxuICAgIDxkaXYgY2xhc3NOYW1lPXtjc3MoeyBoZWlnaHQ6IDQwLCBwYWRkaW5nVG9wOiA4IH0pfT5cbiAgICAgIDxTY3JvbGxiYXJcbiAgICAgICAgY2xhc3NOYW1lPXtjc3Moe1xuICAgICAgICAgIGRpc3BsYXk6ICdmbGV4JyxcbiAgICAgICAgICBmbGV4RGlyZWN0aW9uOiAncm93JyxcbiAgICAgICAgICBmbGV4V3JhcDogJ25vd3JhcCcsXG4gICAgICAgICAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG4gICAgICAgICAgbWFyZ2luTGVmdDogbWFyZ2luTGVmdCA/IGAke21hcmdpbkxlZnR9cHhgIDogdW5kZWZpbmVkLFxuICAgICAgICB9KX1cbiAgICAgICAgeD17dHJ1ZX1cbiAgICAgID5cbiAgICAgICAge2xlZ2VuZEl0ZW1zLm1hcChcbiAgICAgICAgICBsZWdlbmRJdGVtID0+XG4gICAgICAgICAgICBrZXlzW2xlZ2VuZEl0ZW0ueUtleV0gJiYgKFxuICAgICAgICAgICAgICA8TGVnZW5kSXRlbVxuICAgICAgICAgICAgICAgIHsuLi5sZWdlbmRJdGVtfVxuICAgICAgICAgICAgICAgIGtleT17YGxlZ2VuZC0ke2xlZ2VuZEl0ZW0ueUtleX1gfVxuICAgICAgICAgICAgICAgIHlLZXlGb3JtYXR0ZWQ9e2tleXNbbGVnZW5kSXRlbS55S2V5XS5rZXlGb3JtYXR0ZWR9XG4gICAgICAgICAgICAgICAgb25DbGljaz17KCkgPT5cbiAgICAgICAgICAgICAgICAgIHNldFZpc2libGVZS2V5cyhwcmV2ID0+IHtcbiAgICAgICAgICAgICAgICAgICAgbGV0IG5ld1Zpc2libGVMZWdlbmRJdGVtczogQXJyYXk8c3RyaW5nPiA9IFtdO1xuXG4gICAgICAgICAgICAgICAgICAgIGlmIChwcmV2Lmxlbmd0aCA9PT0gbGVnZW5kSXRlbXMubGVuZ3RoKSB7XG4gICAgICAgICAgICAgICAgICAgICAgbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zID0gW2xlZ2VuZEl0ZW0ueUtleV07XG4gICAgICAgICAgICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICAgICAgICAgICAgaWYgKHByZXYuaW5jbHVkZXMobGVnZW5kSXRlbS55S2V5KSkge1xuICAgICAgICAgICAgICAgICAgICAgICAgbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zID0gcHJldi5maWx0ZXIocHJldkxlZ2VuZEl0ZW1JZCA9PiBwcmV2TGVnZW5kSXRlbUlkICE9PSBsZWdlbmRJdGVtLnlLZXkpO1xuICAgICAgICAgICAgICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICAgICAgICAgICAgICBuZXdWaXNpYmxlTGVnZW5kSXRlbXMgPSBbLi4ucHJldiwgbGVnZW5kSXRlbS55S2V5XTtcbiAgICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgICAgICAgICByZXR1cm4gbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zLmxlbmd0aCA9PT0gMFxuICAgICAgICAgICAgICAgICAgICAgID8gbGVnZW5kSXRlbXMubWFwKGxlZ2VuZEl0ZW0gPT4gbGVnZW5kSXRlbS55S2V5KVxuICAgICAgICAgICAgICAgICAgICAgIDogbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zO1xuICAgICAgICAgICAgICAgICAgfSlcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgdmlzaWJsZT17dmlzaWJsZVlLZXlzLmluY2x1ZGVzKGxlZ2VuZEl0ZW0ueUtleSl9XG4gICAgICAgICAgICAgICAgY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXM9e2NvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzfVxuICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgKVxuICAgICAgICApfVxuICAgICAgPC9TY3JvbGxiYXI+XG4gICAgPC9kaXY+XG4gICk7XG59O1xuIl19 */"),
42616
+ }, process.env.NODE_ENV === "production" ? "" : ";label:Legend;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBOEJtQiIsImZpbGUiOiJMZWdlbmQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0LCB7IEZyYWdtZW50IH0gZnJvbSAncmVhY3QnO1xuXG5pbXBvcnQgeyBMZWdlbmRJdGVtIH0gZnJvbSAnLi9MZWdlbmRJdGVtJztcbmltcG9ydCB7IFNoYXBlRGVmaW5pdGlvbiwgQ29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZSwgS2V5IH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9DaGFydHNWMi90eXBlcyc7XG5pbXBvcnQgeyBTY3JvbGxiYXIgfSBmcm9tICcuLi8uLi8uLi9TY3JvbGxiYXIvU2Nyb2xsYmFyJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBCYXJTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0JhckNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgTGluZVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvTGluZUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQXJlYVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQXJlYUNoYXJ0VjIvdHlwZXMnO1xuXG5pbnRlcmZhY2UgTGVnZW5kUHJvcHM8VD4ge1xuICBzZXRWaXNpYmxlWUtleXM/OiBSZWFjdC5EaXNwYXRjaDxSZWFjdC5TZXRTdGF0ZUFjdGlvbjxBcnJheTxzdHJpbmc+Pj47XG4gIGtleXM6IHsgW2tleTogc3RyaW5nXTogS2V5IH07XG4gIG1hcmdpbkxlZnQ6IG51bWJlcjtcbiAgaXRlbXM/OiB7XG4gICAgbGVnZW5kSXRlbXM6IEFycmF5PFNoYXBlRGVmaW5pdGlvbjxUPj47XG4gICAgdmlzaWJsZVlLZXlzOiBBcnJheTxzdHJpbmc+O1xuICAgIGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzOiBBcnJheTxDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlPjtcbiAgfVtdO1xufVxuXG5leHBvcnQgY29uc3QgTGVnZW5kID0gKHtcbiAga2V5cyxcbiAgc2V0VmlzaWJsZVlLZXlzLFxuICBtYXJnaW5MZWZ0LFxuICBpdGVtcyxcbn06IExlZ2VuZFByb3BzPEJhclN0eWxlcyB8IExpbmVTdHlsZXMgfCBBcmVhU3R5bGVzPikgPT4ge1xuICByZXR1cm4gKFxuICAgIDxkaXYgY2xhc3NOYW1lPXtjc3MoeyBoZWlnaHQ6IDQwLCBwYWRkaW5nVG9wOiA4IH0pfT5cbiAgICAgIDxTY3JvbGxiYXJcbiAgICAgICAgY2xhc3NOYW1lPXtjc3Moe1xuICAgICAgICAgIGRpc3BsYXk6ICdmbGV4JyxcbiAgICAgICAgICBmbGV4RGlyZWN0aW9uOiAncm93JyxcbiAgICAgICAgICBmbGV4V3JhcDogJ25vd3JhcCcsXG4gICAgICAgICAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG4gICAgICAgICAgbWFyZ2luTGVmdDogbWFyZ2luTGVmdCA/IGAke21hcmdpbkxlZnR9cHhgIDogdW5kZWZpbmVkLFxuICAgICAgICB9KX1cbiAgICAgICAgeD17dHJ1ZX1cbiAgICAgID5cbiAgICAgICAge2l0ZW1zPy5tYXAoKGl0ZW0sIGluZGV4KSA9PiAoXG4gICAgICAgICAgPEZyYWdtZW50IGtleT17aW5kZXh9PlxuICAgICAgICAgICAge2l0ZW0ubGVnZW5kSXRlbXM/Lm1hcChcbiAgICAgICAgICAgICAgbGVnZW5kSXRlbSA9PlxuICAgICAgICAgICAgICAgIGtleXNbbGVnZW5kSXRlbS55S2V5XSAmJiAoXG4gICAgICAgICAgICAgICAgICA8TGVnZW5kSXRlbVxuICAgICAgICAgICAgICAgICAgICB7Li4ubGVnZW5kSXRlbX1cbiAgICAgICAgICAgICAgICAgICAga2V5PXtgbGVnZW5kLSR7bGVnZW5kSXRlbS55S2V5fWB9XG4gICAgICAgICAgICAgICAgICAgIHlLZXlGb3JtYXR0ZWQ9e2tleXNbbGVnZW5kSXRlbS55S2V5XS5rZXlGb3JtYXR0ZWR9XG4gICAgICAgICAgICAgICAgICAgIG9uQ2xpY2s9eygpID0+XG4gICAgICAgICAgICAgICAgICAgICAgc2V0VmlzaWJsZVlLZXlzICYmXG4gICAgICAgICAgICAgICAgICAgICAgc2V0VmlzaWJsZVlLZXlzKHByZXYgPT4ge1xuICAgICAgICAgICAgICAgICAgICAgICAgbGV0IG5ld1Zpc2libGVMZWdlbmRJdGVtczogQXJyYXk8c3RyaW5nPiA9IFtdO1xuXG4gICAgICAgICAgICAgICAgICAgICAgICBpZiAocHJldi5sZW5ndGggPT09IGl0ZW0ubGVnZW5kSXRlbXMubGVuZ3RoKSB7XG4gICAgICAgICAgICAgICAgICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IFtsZWdlbmRJdGVtLnlLZXldO1xuICAgICAgICAgICAgICAgICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgaWYgKHByZXYuaW5jbHVkZXMobGVnZW5kSXRlbS55S2V5KSkge1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IHByZXYuZmlsdGVyKFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgcHJldkxlZ2VuZEl0ZW1JZCA9PiBwcmV2TGVnZW5kSXRlbUlkICE9PSBsZWdlbmRJdGVtLnlLZXlcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICApO1xuICAgICAgICAgICAgICAgICAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IFsuLi5wcmV2LCBsZWdlbmRJdGVtLnlLZXldO1xuICAgICAgICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICAgICAgICB9XG5cbiAgICAgICAgICAgICAgICAgICAgICAgIHJldHVybiBuZXdWaXNpYmxlTGVnZW5kSXRlbXMubGVuZ3RoID09PSAwXG4gICAgICAgICAgICAgICAgICAgICAgICAgID8gaXRlbS5sZWdlbmRJdGVtcy5tYXAobGVnZW5kSXRlbSA9PiBsZWdlbmRJdGVtLnlLZXkpXG4gICAgICAgICAgICAgICAgICAgICAgICAgIDogbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zO1xuICAgICAgICAgICAgICAgICAgICAgIH0pXG4gICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICAgICAgdmlzaWJsZT17c2V0VmlzaWJsZVlLZXlzID8gaXRlbS52aXNpYmxlWUtleXMuaW5jbHVkZXMobGVnZW5kSXRlbS55S2V5KSA6IHRydWV9XG4gICAgICAgICAgICAgICAgICAgIGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzPXtpdGVtLmNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzfVxuICAgICAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgICAgICApXG4gICAgICAgICAgICApfVxuICAgICAgICAgIDwvRnJhZ21lbnQ+XG4gICAgICAgICkpfVxuICAgICAgPC9TY3JvbGxiYXI+XG4gICAgPC9kaXY+XG4gICk7XG59O1xuIl19 */"),
42610
42617
  x: true,
42611
- children: legendItems.map(function (legendItem) {
42612
- return keys[legendItem.yKey] && createElement$1(LegendItem, _extends({}, legendItem, {
42613
- key: "legend-" + legendItem.yKey,
42614
- yKeyFormatted: keys[legendItem.yKey].keyFormatted,
42615
- onClick: function onClick() {
42616
- return setVisibleYKeys(function (prev) {
42617
- var newVisibleLegendItems = [];
42618
- if (prev.length === legendItems.length) {
42619
- newVisibleLegendItems = [legendItem.yKey];
42620
- } else {
42621
- if (prev.includes(legendItem.yKey)) {
42622
- newVisibleLegendItems = prev.filter(function (prevLegendItemId) {
42623
- return prevLegendItemId !== legendItem.yKey;
42624
- });
42625
- } else {
42626
- newVisibleLegendItems = [].concat(prev, [legendItem.yKey]);
42627
- }
42628
- }
42629
- return newVisibleLegendItems.length === 0 ? legendItems.map(function (legendItem) {
42630
- return legendItem.yKey;
42631
- }) : newVisibleLegendItems;
42632
- });
42633
- },
42634
- visible: visibleYKeys.includes(legendItem.yKey),
42635
- conditionalFormattingRules: conditionalFormattingRules
42636
- }));
42618
+ children: items == null ? void 0 : items.map(function (item, index) {
42619
+ var _item$legendItems;
42620
+ return jsx(Fragment, {
42621
+ children: (_item$legendItems = item.legendItems) == null ? void 0 : _item$legendItems.map(function (legendItem) {
42622
+ return keys[legendItem.yKey] && createElement$1(LegendItem, _extends({}, legendItem, {
42623
+ key: "legend-" + legendItem.yKey,
42624
+ yKeyFormatted: keys[legendItem.yKey].keyFormatted,
42625
+ onClick: function onClick() {
42626
+ return setVisibleYKeys && setVisibleYKeys(function (prev) {
42627
+ var newVisibleLegendItems = [];
42628
+ if (prev.length === item.legendItems.length) {
42629
+ newVisibleLegendItems = [legendItem.yKey];
42630
+ } else {
42631
+ if (prev.includes(legendItem.yKey)) {
42632
+ newVisibleLegendItems = prev.filter(function (prevLegendItemId) {
42633
+ return prevLegendItemId !== legendItem.yKey;
42634
+ });
42635
+ } else {
42636
+ newVisibleLegendItems = [].concat(prev, [legendItem.yKey]);
42637
+ }
42638
+ }
42639
+ return newVisibleLegendItems.length === 0 ? item.legendItems.map(function (legendItem) {
42640
+ return legendItem.yKey;
42641
+ }) : newVisibleLegendItems;
42642
+ });
42643
+ },
42644
+ visible: setVisibleYKeys ? item.visibleYKeys.includes(legendItem.yKey) : true,
42645
+ conditionalFormattingRules: item.conditionalFormattingRules
42646
+ }));
42647
+ })
42648
+ }, index);
42637
42649
  })
42638
42650
  })
42639
42651
  });
@@ -42735,19 +42747,19 @@ var buildMargin = function buildMargin(yTicks, showYAxisLabels, hasYAxisTitle, h
42735
42747
  };
42736
42748
  };
42737
42749
 
42738
- function useFlattenedData(xScaleKey, xScaleDataType, chart) {
42750
+ function useFlattenedData(xScaleKey, xScaleDataType, data, yKeys) {
42739
42751
  return useMemo(function () {
42740
- if (xScaleKey && xScaleDataType) {
42752
+ if (xScaleKey && xScaleDataType && yKeys.length > 0) {
42741
42753
  return flattenData({
42742
- data: chart.data,
42754
+ data: data,
42743
42755
  xScaleKey: xScaleKey,
42744
42756
  xScaleDataType: xScaleDataType,
42745
- yKeys: chart.y.keys
42757
+ yKeys: yKeys
42746
42758
  });
42747
42759
  } else {
42748
42760
  return [];
42749
42761
  }
42750
- }, [chart.data, xScaleKey, xScaleDataType, chart.y.keys]);
42762
+ }, [data, xScaleKey, xScaleDataType, yKeys]);
42751
42763
  }
42752
42764
 
42753
42765
  var GoalLine = function GoalLine(_ref) {
@@ -43099,6 +43111,17 @@ function useTooltip$1(initialTooltipState) {
43099
43111
  };
43100
43112
  }
43101
43113
 
43114
+ function useYScale(innerHeight, scale) {
43115
+ return useMemo(function () {
43116
+ return scaleLinear({
43117
+ range: [innerHeight, 0],
43118
+ domain: scale.ordering === 'asc' ? [scale.min, scale.max] : [scale.max, scale.min],
43119
+ nice: true,
43120
+ round: true
43121
+ });
43122
+ }, [innerHeight, scale]);
43123
+ }
43124
+
43102
43125
  var LineChart$5 = function LineChart(_ref) {
43103
43126
  var _theme$axis;
43104
43127
  var chart = _ref.chart,
@@ -43164,14 +43187,8 @@ var LineChart$5 = function LineChart(_ref) {
43164
43187
  }
43165
43188
  return null;
43166
43189
  }, [innerWidth, chart.x, chart.data]);
43167
- var _yScale = useMemo(function () {
43168
- return scaleLinear({
43169
- range: [innerHeight, 0],
43170
- domain: chart.y.scale.ordering === 'asc' ? [chart.y.scale.min, chart.y.scale.max] : [chart.y.scale.max, chart.y.scale.min],
43171
- nice: true
43172
- });
43173
- }, [innerHeight, chart.y]);
43174
- var dataFlattened = useFlattenedData(xScaleKey, xScaleDataType, chart);
43190
+ var _yScale = useYScale(innerHeight, chart.y.scale);
43191
+ var dataFlattened = useFlattenedData(xScaleKey, xScaleDataType, chart.data, chart.y.keys);
43175
43192
  var handleMouseMove = useCallback(function (event) {
43176
43193
  if (!xKey || !xScaleKey || xScale === null) return;
43177
43194
  var tooltipData = getTooltipData({
@@ -43198,6 +43215,11 @@ var LineChart$5 = function LineChart(_ref) {
43198
43215
  var yTickValues = chart.y.ticks.map(function (tick) {
43199
43216
  return Number(tick.value);
43200
43217
  });
43218
+ var legendTooltipItems = [{
43219
+ legendItems: chart.lines,
43220
+ visibleYKeys: visibleYKeys,
43221
+ conditionalFormattingRules: chart.conditionalFormattingRules
43222
+ }];
43201
43223
  return jsxs(React__default.Fragment, {
43202
43224
  children: [jsxs(ChartWrapper$1, {
43203
43225
  width: width,
@@ -43232,93 +43254,19 @@ var LineChart$5 = function LineChart(_ref) {
43232
43254
  yScale: _yScale,
43233
43255
  ticks: yTickValues,
43234
43256
  stroke: theme == null || (_theme$axis = theme.axis) == null ? void 0 : _theme$axis.stroke
43235
- }), jsxs(Group$2, {
43236
- children: [chart.y.keys.map(function (yKey) {
43237
- var _chart$lines$filter$;
43238
- return jsx(LinePath, {
43239
- visibility: visibleYKeys.includes(yKey) ? 'visible' : 'hidden',
43240
- data: dataFlattened,
43241
- x: function x(d) {
43242
- var _xScale;
43243
- // @ts-ignore
43244
- var xValue = d[xScaleKey];
43245
- var xValueAdjusted = xScaleDataType === 'date_time' ? new Date(xValue) : xScaleDataType === 'number' ? Number(xValue) : String(xValue);
43246
- // @ts-ignore
43247
- return (_xScale = xScale(xValueAdjusted)) != null ? _xScale : 0;
43248
- },
43249
- y: function y(d) {
43250
- return _yScale(Number(d[yKey]));
43251
- },
43252
- stroke: chart.lines.filter(function (legendItem) {
43253
- return legendItem.yKey === yKey;
43254
- })[0].color,
43255
- strokeWidth: chart.lines.filter(function (legendItem) {
43256
- return legendItem.yKey === yKey;
43257
- })[0].style.strokeWidth,
43258
- strokeLinecap: "round",
43259
- strokeDasharray: (_chart$lines$filter$ = chart.lines.filter(function (legendItem) {
43260
- return legendItem.yKey === yKey;
43261
- })[0].style.strokeDasharray) != null ? _chart$lines$filter$ : undefined,
43262
- shapeRendering: "smooth",
43263
- defined: function defined(d) {
43264
- return d[yKey] !== null;
43265
- },
43266
- curve: curve
43267
- }, yKey);
43268
- }), chart.conditionalFormattingRules.map(function (conditionalFormattingRule) {
43269
- var _chart$lines$filter$2;
43270
- if (conditionalFormattingRule.operator !== '<=' && conditionalFormattingRule.operator !== '>=') return null;
43271
- var yKey = conditionalFormattingRule.yKey;
43272
- var clipPathId = "clip-path-" + yKey + "-" + conditionalFormattingRule.value + "-" + conditionalFormattingRule.color + "-" + Math.random(); // Do not remove Math.random() - required to ensure unique clipPathId per view instance
43273
-
43274
- var clipArea = getClipArea({
43275
- conditionalFormattingRule: conditionalFormattingRule,
43276
- chart: {
43277
- width: innerWidth,
43278
- height: innerHeight,
43279
- yScale: _yScale
43280
- }
43281
- });
43282
-
43283
- // return a new <LinePath /> for each conditional formatting rule with a matching <ReactClipPath /> to frame the part of the path that should be visible
43284
- return jsxs(Group$2, {
43285
- children: [jsx(LinePath, {
43286
- clipPath: "url(#" + clipPathId + ")",
43287
- visibility: visibleYKeys.includes(yKey) ? 'visible' : 'hidden',
43288
- data: dataFlattened,
43289
- x: function x(d) {
43290
- var _xScale2;
43291
- // @ts-ignore
43292
- var xValue = d[xScaleKey];
43293
- var xValueAdjusted = xScaleDataType === 'date_time' ? new Date(xValue) : xScaleDataType === 'number' ? Number(xValue) : String(xValue);
43294
- // @ts-ignore
43295
- return (_xScale2 = xScale(xValueAdjusted)) != null ? _xScale2 : 0;
43296
- },
43297
- y: function y(d) {
43298
- return _yScale(Number(d[yKey]));
43299
- },
43300
- stroke: conditionalFormattingRule.color,
43301
- strokeWidth: chart.lines.filter(function (legendItem) {
43302
- return legendItem.yKey === yKey;
43303
- })[0].style.strokeWidth,
43304
- strokeLinecap: "round",
43305
- strokeDasharray: (_chart$lines$filter$2 = chart.lines.filter(function (legendItem) {
43306
- return legendItem.yKey === yKey;
43307
- })[0].style.strokeDasharray) != null ? _chart$lines$filter$2 : undefined,
43308
- shapeRendering: "smooth",
43309
- defined: function defined(d) {
43310
- return d[yKey] !== null;
43311
- },
43312
- curve: curve
43313
- }, yKey), jsx(RectClipPath, {
43314
- id: clipPathId,
43315
- x: clipArea.x,
43316
- y: clipArea.y,
43317
- width: clipArea.width,
43318
- height: clipArea.height
43319
- })]
43320
- }, clipPathId);
43321
- })]
43257
+ }), jsx(Group$2, {
43258
+ children: xScaleKey !== null && jsx(Lines, {
43259
+ lines: chart.lines,
43260
+ conditionalFormattingRules: chart.conditionalFormattingRules,
43261
+ curve: curve,
43262
+ yKeys: chart.y.keys,
43263
+ visibleYKeys: visibleYKeys,
43264
+ data: dataFlattened,
43265
+ xScaleKey: xScaleKey,
43266
+ xScaleDataType: xScaleDataType,
43267
+ xScale: xScale,
43268
+ yScale: _yScale
43269
+ })
43322
43270
  })]
43323
43271
  }), tooltipData && jsxs("g", {
43324
43272
  children: [jsx(Line, {
@@ -43350,27 +43298,117 @@ var LineChart$5 = function LineChart(_ref) {
43350
43298
  width: innerWidth
43351
43299
  })]
43352
43300
  }), options.showLegend && jsx(Legend$1, {
43353
- legendItems: chart.lines,
43354
- visibleYKeys: visibleYKeys,
43301
+ items: legendTooltipItems,
43355
43302
  setVisibleYKeys: setVisibleYKeys,
43356
43303
  keys: chart.keys,
43357
- conditionalFormattingRules: chart.conditionalFormattingRules,
43358
43304
  marginLeft: margin.left - margin.leftTitleOffset
43359
43305
  }), tooltipOpen && tooltipData && xKey && jsx(Tooltip$1, {
43306
+ items: legendTooltipItems,
43360
43307
  tooltipData: tooltipData,
43361
43308
  tooltipLeft: tooltipLeft,
43362
43309
  tooltipTop: tooltipTop,
43363
43310
  xKey: xKey,
43364
43311
  keys: chart.keys,
43365
- visibleYKeys: visibleYKeys,
43366
43312
  yKeys: chart.y.keys,
43367
- legendItems: chart.lines,
43368
43313
  showRoundedTotal: options.showRoundedTotal,
43369
- conditionalFormattingRules: chart.conditionalFormattingRules,
43370
43314
  theme: themeCSS.popoverMenus
43371
43315
  })]
43372
43316
  });
43373
43317
  };
43318
+ function Lines(_ref2) {
43319
+ var yKeys = _ref2.yKeys,
43320
+ visibleYKeys = _ref2.visibleYKeys,
43321
+ data = _ref2.data,
43322
+ xScaleKey = _ref2.xScaleKey,
43323
+ xScaleDataType = _ref2.xScaleDataType,
43324
+ xScale = _ref2.xScale,
43325
+ yScale = _ref2.yScale,
43326
+ lines = _ref2.lines,
43327
+ curve = _ref2.curve,
43328
+ conditionalFormattingRules = _ref2.conditionalFormattingRules;
43329
+ return jsxs(Fragment, {
43330
+ children: [yKeys.map(function (yKey) {
43331
+ var _lines$filter$0$style;
43332
+ return jsx(LinePath, {
43333
+ visibility: visibleYKeys.includes(yKey) ? 'visible' : 'hidden',
43334
+ data: data,
43335
+ x: function x(d) {
43336
+ var _ref3;
43337
+ var xValue = d[xScaleKey];
43338
+ var xValueAdjusted = xScaleDataType === 'date_time' ? new Date(xValue) : xScaleDataType === 'number' ? Number(xValue) : String(xValue);
43339
+ return (_ref3 = xScale(xValueAdjusted)) != null ? _ref3 : 0;
43340
+ },
43341
+ y: function y(d) {
43342
+ return yScale(d[yKey]);
43343
+ },
43344
+ stroke: lines.filter(function (legendItem) {
43345
+ return legendItem.yKey === yKey;
43346
+ })[0].color,
43347
+ strokeWidth: lines.filter(function (legendItem) {
43348
+ return legendItem.yKey === yKey;
43349
+ })[0].style.strokeWidth,
43350
+ strokeLinecap: "round",
43351
+ strokeDasharray: (_lines$filter$0$style = lines.filter(function (legendItem) {
43352
+ return legendItem.yKey === yKey;
43353
+ })[0].style.strokeDasharray) != null ? _lines$filter$0$style : undefined,
43354
+ shapeRendering: "smooth",
43355
+ defined: function defined(d) {
43356
+ return d[yKey] !== null;
43357
+ },
43358
+ curve: curve
43359
+ }, yKey);
43360
+ }), conditionalFormattingRules.map(function (conditionalFormattingRule) {
43361
+ var _lines$filter$0$style2;
43362
+ if (conditionalFormattingRule.operator !== '<=' && conditionalFormattingRule.operator !== '>=') return null;
43363
+ var yKey = conditionalFormattingRule.yKey;
43364
+ var clipPathId = "clip-path-" + yKey + "-" + conditionalFormattingRule.value + "-" + conditionalFormattingRule.color + "-" + Math.random(); // Do not remove Math.random() - required to ensure unique clipPathId per view instance
43365
+
43366
+ var clipArea = getClipArea({
43367
+ conditionalFormattingRule: conditionalFormattingRule,
43368
+ chart: {
43369
+ width: innerWidth,
43370
+ height: innerHeight,
43371
+ yScale: yScale
43372
+ }
43373
+ });
43374
+ return jsxs(Group$2, {
43375
+ children: [jsx(LinePath, {
43376
+ clipPath: "url(#" + clipPathId + ")",
43377
+ visibility: visibleYKeys.includes(yKey) ? 'visible' : 'hidden',
43378
+ data: data,
43379
+ x: function x(d) {
43380
+ var _ref4;
43381
+ var xValue = d[xScaleKey];
43382
+ var xValueAdjusted = xScaleDataType === 'date_time' ? new Date(xValue) : xScaleDataType === 'number' ? Number(xValue) : String(xValue);
43383
+ return (_ref4 = xScale(xValueAdjusted)) != null ? _ref4 : 0;
43384
+ },
43385
+ y: function y(d) {
43386
+ return yScale(d[yKey]);
43387
+ },
43388
+ stroke: conditionalFormattingRule.color,
43389
+ strokeWidth: lines.filter(function (legendItem) {
43390
+ return legendItem.yKey === yKey;
43391
+ })[0].style.strokeWidth,
43392
+ strokeLinecap: "round",
43393
+ strokeDasharray: (_lines$filter$0$style2 = lines.filter(function (legendItem) {
43394
+ return legendItem.yKey === yKey;
43395
+ })[0].style.strokeDasharray) != null ? _lines$filter$0$style2 : undefined,
43396
+ shapeRendering: "smooth",
43397
+ defined: function defined(d) {
43398
+ return d[yKey] !== null;
43399
+ },
43400
+ curve: curve
43401
+ }, yKey), jsx(RectClipPath, {
43402
+ id: clipPathId,
43403
+ x: clipArea.x,
43404
+ y: clipArea.y,
43405
+ width: clipArea.width,
43406
+ height: clipArea.height
43407
+ })]
43408
+ }, clipPathId);
43409
+ })]
43410
+ });
43411
+ }
43374
43412
 
43375
43413
  function getBarFill(bars, conditionalFormattingRules, barKey, barValues) {
43376
43414
  var _bars$find;
@@ -43387,7 +43425,7 @@ function getBarFill(bars, conditionalFormattingRules, barKey, barValues) {
43387
43425
  if (compare({
43388
43426
  op: rule.operator,
43389
43427
  value: rule.value
43390
- }, value)) {
43428
+ }, value) && rule.yKey === barKey) {
43391
43429
  fill = rule.color;
43392
43430
  break;
43393
43431
  }
@@ -43396,12 +43434,43 @@ function getBarFill(bars, conditionalFormattingRules, barKey, barValues) {
43396
43434
  return fill;
43397
43435
  }
43398
43436
 
43399
- function _EMOTION_STRINGIFIED_CSS_ERROR__$9() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
43400
- var BAR_RADIUS = 2;
43401
43437
  var PADDING = {
43402
43438
  paddingOuter: 0.05,
43403
43439
  paddingInner: 0.3
43404
43440
  };
43441
+
43442
+ function useBarXScale(xScaleDataType, innerWidth, xScaleKey, data) {
43443
+ return useMemo(function () {
43444
+ if (xScaleDataType === 'string') {
43445
+ return scaleBand(_extends({
43446
+ range: [0, innerWidth],
43447
+ domain: xScaleKey ? [].concat(data.map(function (d) {
43448
+ return d[xScaleKey] && d[xScaleKey].value !== null ? String(d[xScaleKey].value) : '';
43449
+ })) : []
43450
+ }, PADDING));
43451
+ }
43452
+ if (xScaleDataType === 'date_time' && xScaleKey) {
43453
+ return scaleBand(_extends({
43454
+ range: [0, innerWidth],
43455
+ domain: data.map(function (d) {
43456
+ return new Date(d[xScaleKey].value);
43457
+ })
43458
+ }, PADDING));
43459
+ }
43460
+ if (xScaleDataType === 'number' && xScaleKey) {
43461
+ return scaleBand(_extends({
43462
+ range: [0, innerWidth],
43463
+ domain: data.map(function (d) {
43464
+ return d[xScaleKey] && d[xScaleKey].value !== null ? Number(d[xScaleKey].value) : 0;
43465
+ })
43466
+ }, PADDING));
43467
+ }
43468
+ return null;
43469
+ }, [innerWidth, data]);
43470
+ }
43471
+
43472
+ 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)."; }
43473
+ var BAR_RADIUS = 2;
43405
43474
  var BarChart$5 = function BarChart(_ref) {
43406
43475
  var _theme$axis;
43407
43476
  var chart = _ref.chart,
@@ -43432,41 +43501,8 @@ var BarChart$5 = function BarChart(_ref) {
43432
43501
  var xScaleKey = chart.x.scale.key;
43433
43502
  var yScaleKeys = chart.y.keys;
43434
43503
  var xScaleDataType = chart.x.scale.dataType;
43435
- var xScale = useMemo(function () {
43436
- if (xScaleDataType === 'string') {
43437
- return scaleBand(_extends({
43438
- range: [0, innerWidth],
43439
- domain: xScaleKey ? [].concat(chart.data.map(function (d) {
43440
- return d[xScaleKey] && d[xScaleKey].value !== null ? String(d[xScaleKey].value) : '';
43441
- })) : []
43442
- }, PADDING));
43443
- }
43444
- if (xScaleDataType === 'date_time' && xScaleKey) {
43445
- return scaleBand(_extends({
43446
- range: [0, innerWidth],
43447
- domain: chart.data.map(function (d) {
43448
- return new Date(d[xScaleKey].value);
43449
- })
43450
- }, PADDING));
43451
- }
43452
- if (xScaleDataType === 'number' && xScaleKey) {
43453
- return scaleBand(_extends({
43454
- range: [0, innerWidth],
43455
- domain: chart.data.map(function (d) {
43456
- return d[xScaleKey] && d[xScaleKey].value !== null ? Number(d[xScaleKey].value) : 0;
43457
- })
43458
- }, PADDING));
43459
- }
43460
- return null;
43461
- }, [innerWidth, chart.x, chart.data]);
43462
- var yScale = useMemo(function () {
43463
- return scaleLinear({
43464
- range: [innerHeight, 0],
43465
- domain: chart.y.scale.ordering === 'asc' ? [chart.y.scale.min, chart.y.scale.max] : [chart.y.scale.max, chart.y.scale.min],
43466
- nice: true,
43467
- round: true
43468
- });
43469
- }, [innerHeight, chart.y]);
43504
+ var xScale = useBarXScale(xScaleDataType, innerWidth, xScaleKey, chart.data);
43505
+ var yScale = useYScale(innerHeight, chart.y.scale);
43470
43506
  var innerXScale = useMemo(function () {
43471
43507
  if (!options.stacked && xScale && 'bandwidth' in xScale) {
43472
43508
  return scaleBand({
@@ -43477,7 +43513,7 @@ var BarChart$5 = function BarChart(_ref) {
43477
43513
  }
43478
43514
  return undefined;
43479
43515
  }, [xScale, yScaleKeys, options.stacked, xScaleDataType]);
43480
- var dataFlattened = useFlattenedData(xScaleKey, xScaleDataType, chart);
43516
+ var dataFlattened = useFlattenedData(xScaleKey, xScaleDataType, chart.data, chart.y.keys);
43481
43517
  var handleMouseMove = useCallback(function (event) {
43482
43518
  if (!xKey || !xScaleKey || xScale === null) return;
43483
43519
  var tooltipData = getTooltipData({
@@ -43523,6 +43559,13 @@ var BarChart$5 = function BarChart(_ref) {
43523
43559
  var yTickValues = chart.y.ticks.map(function (tick) {
43524
43560
  return Number(tick.value);
43525
43561
  });
43562
+ var legendTooltipItems = [{
43563
+ visibleYKeys: chart.bars.map(function (legendItem) {
43564
+ return legendItem.yKey;
43565
+ }),
43566
+ legendItems: chart.bars,
43567
+ conditionalFormattingRules: chart.conditionalFormattingRules
43568
+ }];
43526
43569
  return jsxs(Fragment, {
43527
43570
  children: [jsxs(ChartWrapper$1, {
43528
43571
  width: width,
@@ -43558,57 +43601,25 @@ var BarChart$5 = function BarChart(_ref) {
43558
43601
  ticks: yTickValues,
43559
43602
  stroke: theme == null || (_theme$axis = theme.axis) == null ? void 0 : _theme$axis.stroke
43560
43603
  }), jsxs(Group$2, {
43561
- children: [!options.stacked && jsx(BarGroup$1, {
43604
+ children: [!options.stacked && jsx(BarGroup, {
43562
43605
  data: dataFlattened,
43563
43606
  keys: yScaleKeys,
43564
43607
  height: innerHeight,
43565
- x0: function x0(d) {
43566
- // @ts-ignore
43567
- var xValue = d[xScaleKey];
43568
- if (xScaleDataType === 'string') return xValue;
43569
- var xValueAdjusted = xScaleDataType === 'date_time' ? new Date(xValue) : xScaleDataType === 'number' ? Number(xValue) : String(xValue);
43570
- // @ts-ignore
43571
- return xValueAdjusted;
43572
- }
43573
- // @ts-ignore
43574
- ,
43575
- x0Scale: xScale
43576
- // @ts-ignore
43577
- ,
43578
- x1Scale: innerXScale,
43608
+ xKey: xKey,
43609
+ xScaleDataType: xScaleDataType,
43610
+ xScale: xScale,
43611
+ innerXScale: innerXScale,
43579
43612
  yScale: yScale,
43580
- color: function color() {
43581
- return '';
43582
- },
43583
- children: function children(barGroups) {
43584
- return barGroups.map(function (barGroup) {
43585
- return jsx(Group$2, {
43586
- left: barGroup.x0,
43587
- children: barGroup.bars.map(function (bar) {
43588
- if (bar.value === null) return null;
43589
- if (bar.height < 0 || bar.width < 0) return null;
43590
- return jsx(Bar, {
43591
- x: bar.x,
43592
- y: bar.y,
43593
- width: bar.width,
43594
- height: bar.height,
43595
- fill: getBarFill(chart.bars, chart.conditionalFormattingRules, bar.key, bar.value),
43596
- onClick: function onClick(e) {
43597
- return handleOnBarClick(e, barGroup, bar);
43598
- },
43599
- enableHover: enableHover
43600
- }, "bar-group-bar-" + barGroup.index + "-" + bar.index + "-" + bar.value + "-" + bar.key);
43601
- })
43602
- }, "bar-group-" + barGroup.index + "-" + barGroup.x0);
43603
- });
43604
- }
43613
+ onClick: handleOnBarClick,
43614
+ conditionalFormattingRules: chart.conditionalFormattingRules,
43615
+ bars: chart.bars,
43616
+ enableHover: enableHover
43605
43617
  }), options.stacked && jsx(BarStack$1, {
43606
43618
  x: function x(d) {
43607
43619
  // @ts-ignore
43608
43620
  var xValue = d[xScaleKey];
43609
43621
  if (xScaleDataType === 'string') return xValue;
43610
43622
  var xValueAdjusted = xScaleDataType === 'date_time' ? new Date(xValue) : xScaleDataType === 'number' ? Number(xValue) : String(xValue);
43611
- // @ts-ignore
43612
43623
  return xValueAdjusted;
43613
43624
  }
43614
43625
  // @ts-ignore
@@ -43656,31 +43667,79 @@ var BarChart$5 = function BarChart(_ref) {
43656
43667
  width: innerWidth
43657
43668
  })]
43658
43669
  }), options.showLegend && jsx(Legend$1, {
43659
- legendItems: chart.bars,
43660
- visibleYKeys: chart.bars.map(function (legendItem) {
43661
- return legendItem.yKey;
43662
- }),
43670
+ items: legendTooltipItems,
43663
43671
  setVisibleYKeys: function setVisibleYKeys() {},
43664
43672
  keys: chart.keys,
43665
- conditionalFormattingRules: chart.conditionalFormattingRules,
43666
43673
  marginLeft: margin.left - margin.leftTitleOffset
43667
43674
  }), tooltipOpen && tooltipData && xKey && jsx(Tooltip$1, {
43675
+ items: legendTooltipItems,
43668
43676
  tooltipData: tooltipData,
43669
43677
  tooltipLeft: tooltipLeft,
43670
43678
  tooltipTop: tooltipTop,
43671
43679
  xKey: xKey,
43672
43680
  keys: chart.keys,
43673
- visibleYKeys: chart.bars.map(function (legendItem) {
43674
- return legendItem.yKey;
43675
- }),
43676
43681
  yKeys: chart.y.keys,
43677
- legendItems: chart.bars,
43678
43682
  showRoundedTotal: options.showRoundedTotal,
43679
- conditionalFormattingRules: chart.conditionalFormattingRules,
43680
43683
  theme: themeCSS.popoverMenus
43681
43684
  })]
43682
43685
  });
43683
43686
  };
43687
+ function BarGroup(_ref2) {
43688
+ var data = _ref2.data,
43689
+ keys = _ref2.keys,
43690
+ height = _ref2.height,
43691
+ xKey = _ref2.xKey,
43692
+ xScaleDataType = _ref2.xScaleDataType,
43693
+ xScale = _ref2.xScale,
43694
+ innerXScale = _ref2.innerXScale,
43695
+ yScale = _ref2.yScale,
43696
+ _onClick = _ref2.onClick,
43697
+ conditionalFormattingRules = _ref2.conditionalFormattingRules,
43698
+ bars = _ref2.bars,
43699
+ enableHover = _ref2.enableHover;
43700
+ return jsx(BarGroup$2, {
43701
+ data: data,
43702
+ keys: keys,
43703
+ height: height,
43704
+ x0: function x0(d) {
43705
+ var xValue = d[xKey];
43706
+ if (xScaleDataType === 'string') return String(xValue);
43707
+ var xValueAdjusted = xScaleDataType === 'date_time' ? new Date(String(xValue)) : xScaleDataType === 'number' ? Number(xValue) : String(xValue);
43708
+ return xValueAdjusted;
43709
+ }
43710
+ // @ts-ignore
43711
+ ,
43712
+ x0Scale: xScale
43713
+ // @ts-ignore
43714
+ ,
43715
+ x1Scale: innerXScale,
43716
+ yScale: yScale,
43717
+ color: function color() {
43718
+ return '';
43719
+ },
43720
+ children: function children(barGroups) {
43721
+ return barGroups.map(function (barGroup) {
43722
+ return jsx(Group$2, {
43723
+ left: barGroup.x0,
43724
+ children: barGroup.bars.map(function (bar) {
43725
+ if (bar.value === null || bar.height < 0 || bar.width < 0) return null;
43726
+ return jsx(Bar, {
43727
+ x: bar.x,
43728
+ y: bar.y,
43729
+ width: bar.width,
43730
+ height: bar.height,
43731
+ fill: getBarFill(bars, conditionalFormattingRules, String(bar.key), bar.value),
43732
+ onClick: function onClick(e) {
43733
+ return _onClick(e, barGroup, bar);
43734
+ },
43735
+ enableHover: enableHover
43736
+ }, "bar-group-bar-" + barGroup.index + "-" + bar.index + "-" + bar.value + "-" + String(bar.key));
43737
+ })
43738
+ }, "bar-group-" + barGroup.index + "-" + barGroup.x0);
43739
+ });
43740
+ }
43741
+ });
43742
+ }
43684
43743
  var Bar = function Bar(props) {
43685
43744
  var _useState = useState(props.fill),
43686
43745
  fillColor = _useState[0],
@@ -43705,7 +43764,7 @@ var Bar = function Bar(props) {
43705
43764
  } : {
43706
43765
  name: "4nk3o1-Bar",
43707
43766
  styles: "cursor:pointer;label:Bar;",
43708
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["BarChart.tsx"],"names":[],"mappings":"AA0YqC","file":"BarChart.tsx","sourcesContent":["import { BarChartRepresentation } from 'shared-logic/src/BarChartV2/types';\nimport { ChartTheme } from '../../../types';\nimport { Group } from '@visx/group';\nimport { getChartThemeCSS, getTooltipData } from '../../utils';\nimport { Fragment, useCallback, useMemo, useState } from 'react';\nimport { Tooltip } from '../Tooltip';\nimport { Legend } from '../Legend';\nimport { BarGroup, BarStack } from '@visx/shape';\nimport { DataType } from 'shared-logic/src/Field/types';\nimport { scaleLinear, scaleBand } from '@visx/scale';\nimport { getBarFill } from './getBarFill';\nimport { buildMargin } from '../../utils/buildMargin';\nimport { ChartOnViewClick, ChartDataDefinition, DataItem } from 'shared-logic/src/ChartsV2/types';\nimport { lightenColor } from '../../../styles/color.functions';\nimport { css } from '@emotion/css';\nimport { BarGroupBar, BarGroup as BarGroupType } from '@visx/shape/lib/types';\nimport { useFlattenedData } from '../hooks/useFlattenedData';\nimport GoalLines from '../GoalLine/GoalLines';\nimport { AxisBottom } from '../Axis/AxisBottom';\nimport { AxisLeft } from '../Axis/AxisLeft';\nimport { GridRows } from '../GridRows/GridRows';\nimport { ChartWrapper } from '../ChartWrapper/ChartWrapper';\nimport { Line } from '../Tooltip/Line';\nimport useTooltip from '../hooks/useTooltip';\n\n// Need to look at updating BarChart to use this type method of rendering - https://codesandbox.io/p/sandbox/visx-bar-chart-j9smpj?file=%2FExample.tsx\n// Currently it's using Stacked Chart which isn't technically correct\n\nexport type BarChartProps = {\n  width: number;\n  height: number;\n  theme?: ChartTheme;\n  chart: BarChartRepresentation;\n  options: {\n    stacked: boolean;\n    showRoundedTotal: boolean;\n    showLegend: boolean;\n    removeStroke: boolean;\n    axis: {\n      showXAxisLabels: boolean;\n      showYAxisLabels: boolean;\n    };\n  };\n  onClick: (params: ChartOnViewClick) => void;\n  enableHover?: boolean;\n};\n\nconst BAR_RADIUS = 2;\n\nconst PADDING = {\n  paddingOuter: 0.05,\n  paddingInner: 0.3,\n};\n\nexport const BarChart = ({ chart, width, height, options, theme, onClick, enableHover }: BarChartProps) => {\n  const {\n    tooltipOpen,\n    tooltipLeft = 0,\n    tooltipTop = 0,\n    lineLeft = 0,\n    tooltipData,\n    hideTooltip,\n    showTooltip,\n  } = useTooltip<{\n    [keyId: string]: DataItem;\n  } | null>();\n\n  const margin = buildMargin(chart.y.ticks, options.axis.showYAxisLabels, chart.y.title != null, chart.x.title != null);\n\n  // const [visibleYKeys, setVisibleYKeys] = useState(chart.bars.map((legendItem) => legendItem.yKey));\n\n  const innerWidth = width - margin.left - margin.right;\n  const innerHeight = height - margin.top - margin.bottom - (options.showLegend ? 40 : 0);\n  const xKey = chart.x.key;\n  const xScaleKey = chart.x.scale.key;\n  const yScaleKeys = chart.y.keys;\n  const xScaleDataType: DataType = chart.x.scale.dataType;\n\n  const xScale = useMemo(() => {\n    if (xScaleDataType === 'string') {\n      return scaleBand<string>({\n        range: [0, innerWidth],\n        domain: xScaleKey\n          ? [...chart.data.map(d => (d[xScaleKey] && d[xScaleKey].value !== null ? String(d[xScaleKey].value) : ''))]\n          : [],\n        ...PADDING,\n      });\n    }\n\n    if (xScaleDataType === 'date_time' && xScaleKey) {\n      return scaleBand<Date>({\n        range: [0, innerWidth],\n        domain: chart.data.map(d => new Date(d[xScaleKey].value as string)),\n        ...PADDING,\n      });\n    }\n\n    if (xScaleDataType === 'number' && xScaleKey) {\n      return scaleBand<number>({\n        range: [0, innerWidth],\n        domain: chart.data.map(d => (d[xScaleKey] && d[xScaleKey].value !== null ? Number(d[xScaleKey].value) : 0)),\n        ...PADDING,\n      });\n    }\n\n    return null;\n  }, [innerWidth, chart.x, chart.data]);\n\n  const yScale = useMemo(\n    () =>\n      scaleLinear<number>({\n        range: [innerHeight, 0],\n        domain:\n          chart.y.scale.ordering === 'asc'\n            ? [chart.y.scale.min as number, chart.y.scale.max as number]\n            : [chart.y.scale.max as number, chart.y.scale.min as number],\n        nice: true,\n        round: true,\n      }),\n    [innerHeight, chart.y]\n  );\n\n  const innerXScale = useMemo(() => {\n    if (!options.stacked && xScale && 'bandwidth' in xScale) {\n      return scaleBand<string>({\n        range: [0, xScale?.bandwidth()],\n        domain: yScaleKeys,\n        padding: 0.1,\n      });\n    }\n\n    return undefined;\n  }, [xScale, yScaleKeys, options.stacked, xScaleDataType]);\n\n  const dataFlattened = useFlattenedData<BarChartRepresentation, ChartDataDefinition>(xScaleKey, xScaleDataType, chart);\n\n  const handleMouseMove = useCallback(\n    (event: React.MouseEvent<SVGElement>) => {\n      if (!xKey || !xScaleKey || xScale === null) return;\n\n      const tooltipData = getTooltipData({\n        data: chart.data,\n        event,\n        margin,\n        xScaleKey,\n        xScaleDataType,\n        xOrdering: chart.x.scale.ordering,\n        xScale,\n        chartType: 'bar',\n      });\n\n      showTooltip({\n        lineLeft: tooltipData?.lineLeft,\n        tooltipLeft: event.pageX,\n        tooltipTop: event.pageY,\n        tooltipData: tooltipData?.tooltipData,\n      });\n    },\n    [showTooltip, xScale, margin, xKey, xScaleKey, xScaleDataType, chart.x.scale.ordering, chart.data]\n  );\n\n  const handleMouseLeave = useCallback(() => {\n    hideTooltip();\n  }, [hideTooltip]);\n\n  const handleOnBarClick = useCallback(\n    (event: React.MouseEvent<SVGRectElement, MouseEvent>, barGroup: BarGroupType<string>, bar: BarGroupBar<string>) => {\n      onClick({\n        clickedValue: {\n          index: barGroup.index,\n          y: {\n            key: bar.key,\n            value: bar.value,\n          },\n          x: {\n            ...chart.x.ticks[barGroup.index],\n            value: chart.data[barGroup.index][xKey].value ?? '',\n            key: xKey,\n          },\n        },\n        clickEvent: event,\n      });\n    },\n    [onClick, chart.data, xKey]\n  );\n\n  const themeCSS = useMemo(() => getChartThemeCSS(theme), [theme]);\n\n  const yTickValues = chart.y.ticks.map(tick => Number(tick.value));\n\n  return (\n    <Fragment>\n      {/* width/height 100% required or useParentSize() continuously scales as parent element has no specified height */}\n      <ChartWrapper\n        width={width}\n        height={height}\n        onMouseMove={handleMouseMove}\n        onMouseLeave={handleMouseLeave}\n        showLegend={options.showLegend}\n      >\n        <Group left={margin.left} top={margin.top}>\n          <GridRows\n            ticks={yTickValues}\n            yScale={yScale}\n            width={innerWidth}\n            height={innerHeight}\n            removeStroke={options.removeStroke}\n            themeCSS={themeCSS}\n          />\n          <AxisBottom\n            x={chart.x}\n            margin={margin}\n            themeCSS={themeCSS}\n            show={options.axis.showXAxisLabels}\n            removeStroke={options.removeStroke}\n            xScaleDataType={xScaleDataType}\n            xScale={xScale}\n            height={innerHeight}\n          />\n          <AxisLeft\n            show={options.axis.showYAxisLabels}\n            y={chart.y}\n            margin={margin}\n            themeCSS={themeCSS}\n            yScale={yScale}\n            ticks={yTickValues}\n            stroke={theme?.axis?.stroke}\n          />\n          <Group>\n            {!options.stacked && (\n              <BarGroup\n                data={dataFlattened}\n                keys={yScaleKeys}\n                height={innerHeight}\n                x0={d => {\n                  // @ts-ignore\n                  const xValue = d[xScaleKey];\n\n                  if (xScaleDataType === 'string') return xValue;\n\n                  const xValueAdjusted =\n                    xScaleDataType === 'date_time'\n                      ? new Date(xValue)\n                      : xScaleDataType === 'number'\n                      ? Number(xValue)\n                      : String(xValue);\n                  // @ts-ignore\n                  return xValueAdjusted;\n                }}\n                // @ts-ignore\n                x0Scale={xScale}\n                // @ts-ignore\n                x1Scale={innerXScale}\n                yScale={yScale}\n                color={() => ''}\n              >\n                {barGroups => {\n                  return barGroups.map(barGroup => (\n                    <Group key={`bar-group-${barGroup.index}-${barGroup.x0}`} left={barGroup.x0}>\n                      {barGroup.bars.map(bar => {\n                        if (bar.value === null) return null;\n                        if (bar.height < 0 || bar.width < 0) return null;\n                        return (\n                          <Bar\n                            key={`bar-group-bar-${barGroup.index}-${bar.index}-${bar.value}-${bar.key}`}\n                            x={bar.x}\n                            y={bar.y}\n                            width={bar.width}\n                            height={bar.height}\n                            fill={getBarFill(chart.bars, chart.conditionalFormattingRules, bar.key, bar.value)}\n                            onClick={e => handleOnBarClick(e, barGroup, bar)}\n                            enableHover={enableHover}\n                          />\n                        );\n                      })}\n                    </Group>\n                  ));\n                }}\n              </BarGroup>\n            )}\n\n            {/* How to we get 'scaleValue' here? Will we need to start storing scaleKey as well as xKey? */}\n            {options.stacked && (\n              <BarStack\n                x={d => {\n                  // @ts-ignore\n                  const xValue = d[xScaleKey];\n                  if (xScaleDataType === 'string') return xValue;\n\n                  const xValueAdjusted =\n                    xScaleDataType === 'date_time'\n                      ? new Date(xValue)\n                      : xScaleDataType === 'number'\n                      ? Number(xValue)\n                      : String(xValue);\n                  // @ts-ignore\n                  return xValueAdjusted;\n                }}\n                // @ts-ignore\n                xScale={xScale}\n                yScale={yScale}\n                data={dataFlattened}\n                keys={chart.y.keys}\n                color={() => ''}\n                height={innerHeight}\n                width={innerWidth}\n                offset=\"none\"\n              >\n                {barStacks =>\n                  barStacks.map(barStack =>\n                    barStack.bars.map(bar => {\n                      if (bar.height < 3) return null;\n                      const BAR_PADDING = 1.5;\n                      return (\n                        <rect\n                          key={`bar-stack-${barStack.index}-${bar.index}`}\n                          x={bar.x}\n                          y={bar.y}\n                          width={bar.width}\n                          height={bar.height - BAR_PADDING}\n                          fill={getBarFill(chart.bars, chart.conditionalFormattingRules, bar.key, bar.bar.data)}\n                          rx={BAR_RADIUS}\n                        />\n                      );\n                    })\n                  )\n                }\n              </BarStack>\n            )}\n          </Group>\n        </Group>\n        {/* ----- TOOLTIP CROSSHAIR ----- */}\n        {tooltipData && (\n          <g>\n            <Line x={lineLeft} margin={margin} height={innerHeight} />\n          </g>\n        )}\n        {/* ----- GOAL LINES ------ */}\n        <GoalLines goalLines={chart.goalLines} y={d => yScale(d)} margin={margin} width={innerWidth} />\n      </ChartWrapper>\n      {/* ----- LEGEND ----- */}\n      {options.showLegend && (\n        <Legend\n          legendItems={chart.bars}\n          visibleYKeys={chart.bars.map(legendItem => legendItem.yKey)}\n          setVisibleYKeys={() => {}}\n          keys={chart.keys}\n          conditionalFormattingRules={chart.conditionalFormattingRules}\n          marginLeft={margin.left - margin.leftTitleOffset}\n        />\n      )}\n      {/* ----- TOOLTIP ----- */}\n      {tooltipOpen && tooltipData && xKey && (\n        <Tooltip\n          tooltipData={tooltipData}\n          tooltipLeft={tooltipLeft}\n          tooltipTop={tooltipTop}\n          xKey={xKey}\n          keys={chart.keys}\n          visibleYKeys={chart.bars.map(legendItem => legendItem.yKey)}\n          yKeys={chart.y.keys}\n          legendItems={chart.bars}\n          showRoundedTotal={options.showRoundedTotal}\n          conditionalFormattingRules={chart.conditionalFormattingRules}\n          theme={themeCSS.popoverMenus}\n        />\n      )}\n    </Fragment>\n  );\n};\n\nconst Bar = (props: {\n  onClick: (e: React.MouseEvent<SVGRectElement, MouseEvent>) => void;\n  fill?: string;\n  x: number;\n  y: number;\n  width: number;\n  height: number;\n  key: string;\n  enableHover?: boolean;\n}) => {\n  const [fillColor, setFillColor] = useState(props.fill);\n  return (\n    <rect\n      key={props.key}\n      x={props.x}\n      y={props.y}\n      width={props.width}\n      height={props.height}\n      fill={fillColor}\n      rx={BAR_RADIUS}\n      onClick={props.onClick}\n      onMouseEnter={() => props.enableHover && setFillColor(lightenColor(props.fill, 0.8))}\n      onMouseLeave={() => props.enableHover && setFillColor(props.fill)}\n      className={props.enableHover ? css({ cursor: 'pointer' }) : ''}\n    />\n  );\n};\n"]} */",
43767
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["BarChart.tsx"],"names":[],"mappings":"AA8YqC","file":"BarChart.tsx","sourcesContent":["import { BarChartRepresentation, BarStyles } from 'shared-logic/src/BarChartV2/types';\nimport { ChartTheme } from '../../../types';\nimport { Group } from '@visx/group';\nimport { getChartThemeCSS, getTooltipData } from '../../utils';\nimport { Fragment, useCallback, useMemo, useState } from 'react';\nimport { Tooltip } from '../Tooltip';\nimport { Legend } from '../Legend';\nimport { BarGroup as VisxBarGroup, BarStack } from '@visx/shape';\nimport { DataType } from 'shared-logic/src/Field/types';\nimport { scaleBand } from '@visx/scale';\nimport { getBarFill } from '../../utils/getBarFill';\nimport { buildMargin } from '../../utils/buildMargin';\nimport {\n  ChartDataDefinition,\n  ChartOnViewClick,\n  ConditionalFormattingRule,\n  DataItem,\n  ShapeDefinition,\n} from 'shared-logic/src/ChartsV2/types';\nimport { lightenColor } from '../../../styles/color.functions';\nimport { css } from '@emotion/css';\nimport { BarGroupBar, BarGroup as BarGroupType, DatumObject } from '@visx/shape/lib/types';\nimport { useFlattenedData } from '../hooks/useFlattenedData';\nimport GoalLines from '../GoalLine/GoalLines';\nimport { AxisBottom } from '../Axis/AxisBottom';\nimport { AxisLeft } from '../Axis/AxisLeft';\nimport { GridRows } from '../GridRows/GridRows';\nimport { ChartWrapper } from '../ChartWrapper/ChartWrapper';\nimport { ScaleLinear, ScaleBand } from '@visx/vendor/d3-scale';\nimport { Line } from '../Tooltip/Line';\nimport useTooltip from '../hooks/useTooltip';\nimport { useBarXScale } from './useBarXScale';\nimport { useYScale } from '../hooks/useYScale';\n\n// Need to look at updating BarChart to use this type method of rendering - https://codesandbox.io/p/sandbox/visx-bar-chart-j9smpj?file=%2FExample.tsx\n// Currently it's using Stacked Chart which isn't technically correct\n\nexport type BarChartProps = {\n  width: number;\n  height: number;\n  theme?: ChartTheme;\n  chart: BarChartRepresentation;\n  options: {\n    stacked: boolean;\n    showRoundedTotal: boolean;\n    showLegend: boolean;\n    removeStroke: boolean;\n    axis: {\n      showXAxisLabels: boolean;\n      showYAxisLabels: boolean;\n    };\n  };\n  onClick: (params: ChartOnViewClick) => void;\n  enableHover?: boolean;\n};\n\nconst BAR_RADIUS = 2;\n\nexport const BarChart = ({ chart, width, height, options, theme, onClick, enableHover }: BarChartProps) => {\n  const {\n    tooltipOpen,\n    tooltipLeft = 0,\n    tooltipTop = 0,\n    lineLeft = 0,\n    tooltipData,\n    hideTooltip,\n    showTooltip,\n  } = useTooltip<{\n    [keyId: string]: DataItem;\n  } | null>();\n\n  const margin = buildMargin(chart.y.ticks, options.axis.showYAxisLabels, chart.y.title != null, chart.x.title != null);\n\n  // const [visibleYKeys, setVisibleYKeys] = useState(chart.bars.map((legendItem) => legendItem.yKey));\n\n  const innerWidth = width - margin.left - margin.right;\n  const innerHeight = height - margin.top - margin.bottom - (options.showLegend ? 40 : 0);\n  const xKey = chart.x.key;\n  const xScaleKey = chart.x.scale.key;\n  const yScaleKeys = chart.y.keys;\n  const xScaleDataType: DataType = chart.x.scale.dataType;\n\n  const xScale = useBarXScale(xScaleDataType, innerWidth, xScaleKey, chart.data);\n\n  const yScale = useYScale(innerHeight, chart.y.scale);\n\n  const innerXScale = useMemo(() => {\n    if (!options.stacked && xScale && 'bandwidth' in xScale) {\n      return scaleBand<string>({\n        range: [0, xScale?.bandwidth()],\n        domain: yScaleKeys,\n        padding: 0.1,\n      });\n    }\n\n    return undefined;\n  }, [xScale, yScaleKeys, options.stacked, xScaleDataType]);\n\n  const dataFlattened = useFlattenedData<ChartDataDefinition>(xScaleKey, xScaleDataType, chart.data, chart.y.keys);\n\n  const handleMouseMove = useCallback(\n    (event: React.MouseEvent<SVGElement>) => {\n      if (!xKey || !xScaleKey || xScale === null) return;\n\n      const tooltipData = getTooltipData({\n        data: chart.data,\n        event,\n        margin,\n        xScaleKey,\n        xScaleDataType,\n        xOrdering: chart.x.scale.ordering,\n        xScale,\n        chartType: 'bar',\n      });\n\n      showTooltip({\n        lineLeft: tooltipData?.lineLeft,\n        tooltipLeft: event.pageX,\n        tooltipTop: event.pageY,\n        tooltipData: tooltipData?.tooltipData,\n      });\n    },\n    [showTooltip, xScale, margin, xKey, xScaleKey, xScaleDataType, chart.x.scale.ordering, chart.data]\n  );\n\n  const handleMouseLeave = useCallback(() => {\n    hideTooltip();\n  }, [hideTooltip]);\n\n  const handleOnBarClick = useCallback(\n    (event: React.MouseEvent<SVGRectElement, MouseEvent>, barGroup: BarGroupType<string>, bar: BarGroupBar<string>) => {\n      onClick({\n        clickedValue: {\n          index: barGroup.index,\n          y: {\n            key: bar.key,\n            value: bar.value,\n          },\n          x: {\n            ...chart.x.ticks[barGroup.index],\n            value: chart.data[barGroup.index][xKey].value ?? '',\n            key: xKey,\n          },\n        },\n        clickEvent: event,\n      });\n    },\n    [onClick, chart.data, xKey]\n  );\n\n  const themeCSS = useMemo(() => getChartThemeCSS(theme), [theme]);\n\n  const yTickValues = chart.y.ticks.map(tick => Number(tick.value));\n\n  const legendTooltipItems = [\n    {\n      visibleYKeys: chart.bars.map(legendItem => legendItem.yKey),\n      legendItems: chart.bars,\n      conditionalFormattingRules: chart.conditionalFormattingRules,\n    },\n  ];\n  return (\n    <Fragment>\n      <ChartWrapper\n        width={width}\n        height={height}\n        onMouseMove={handleMouseMove}\n        onMouseLeave={handleMouseLeave}\n        showLegend={options.showLegend}\n      >\n        <Group left={margin.left} top={margin.top}>\n          <GridRows\n            ticks={yTickValues}\n            yScale={yScale}\n            width={innerWidth}\n            height={innerHeight}\n            removeStroke={options.removeStroke}\n            themeCSS={themeCSS}\n          />\n          <AxisBottom\n            x={chart.x}\n            margin={margin}\n            themeCSS={themeCSS}\n            show={options.axis.showXAxisLabels}\n            removeStroke={options.removeStroke}\n            xScaleDataType={xScaleDataType}\n            xScale={xScale}\n            height={innerHeight}\n          />\n          <AxisLeft\n            show={options.axis.showYAxisLabels}\n            y={chart.y}\n            margin={margin}\n            themeCSS={themeCSS}\n            yScale={yScale}\n            ticks={yTickValues}\n            stroke={theme?.axis?.stroke}\n          />\n          <Group>\n            {!options.stacked && (\n              <BarGroup\n                data={dataFlattened}\n                keys={yScaleKeys}\n                height={innerHeight}\n                xKey={xKey}\n                xScaleDataType={xScaleDataType}\n                xScale={xScale}\n                innerXScale={innerXScale}\n                yScale={yScale}\n                onClick={handleOnBarClick}\n                conditionalFormattingRules={chart.conditionalFormattingRules}\n                bars={chart.bars}\n                enableHover={enableHover}\n              />\n            )}\n\n            {options.stacked && (\n              <BarStack\n                x={d => {\n                  // @ts-ignore\n                  const xValue = d[xScaleKey];\n                  if (xScaleDataType === 'string') return xValue;\n\n                  const xValueAdjusted =\n                    xScaleDataType === 'date_time'\n                      ? new Date(xValue)\n                      : xScaleDataType === 'number'\n                      ? Number(xValue)\n                      : String(xValue);\n                  return xValueAdjusted;\n                }}\n                // @ts-ignore\n                xScale={xScale}\n                yScale={yScale}\n                data={dataFlattened}\n                keys={chart.y.keys}\n                color={() => ''}\n                height={innerHeight}\n                width={innerWidth}\n                offset=\"none\"\n              >\n                {barStacks =>\n                  barStacks.map(barStack =>\n                    barStack.bars.map(bar => {\n                      if (bar.height < 3) return null;\n                      const BAR_PADDING = 1.5;\n                      return (\n                        <rect\n                          key={`bar-stack-${barStack.index}-${bar.index}`}\n                          x={bar.x}\n                          y={bar.y}\n                          width={bar.width}\n                          height={bar.height - BAR_PADDING}\n                          fill={getBarFill(chart.bars, chart.conditionalFormattingRules, bar.key, bar.bar.data)}\n                          rx={BAR_RADIUS}\n                        />\n                      );\n                    })\n                  )\n                }\n              </BarStack>\n            )}\n          </Group>\n        </Group>\n        {/* ----- TOOLTIP CROSSHAIR ----- */}\n        {tooltipData && (\n          <g>\n            <Line x={lineLeft} margin={margin} height={innerHeight} />\n          </g>\n        )}\n        {/* ----- GOAL LINES ------ */}\n        <GoalLines goalLines={chart.goalLines} y={d => yScale(d)} margin={margin} width={innerWidth} />\n      </ChartWrapper>\n      {/* ----- LEGEND ----- */}\n      {options.showLegend && (\n        <Legend\n          items={legendTooltipItems}\n          setVisibleYKeys={() => {}}\n          keys={chart.keys}\n          marginLeft={margin.left - margin.leftTitleOffset}\n        />\n      )}\n      {/* ----- TOOLTIP ----- */}\n      {tooltipOpen && tooltipData && xKey && (\n        <Tooltip\n          items={legendTooltipItems}\n          tooltipData={tooltipData}\n          tooltipLeft={tooltipLeft}\n          tooltipTop={tooltipTop}\n          xKey={xKey}\n          keys={chart.keys}\n          yKeys={chart.y.keys}\n          showRoundedTotal={options.showRoundedTotal}\n          theme={themeCSS.popoverMenus}\n        />\n      )}\n    </Fragment>\n  );\n};\n\nexport function BarGroup({\n  data,\n  keys,\n  height,\n  xKey,\n  xScaleDataType,\n  xScale,\n  innerXScale,\n  yScale,\n  onClick,\n  conditionalFormattingRules,\n  bars,\n  enableHover,\n}: {\n  data: ChartDataDefinition[];\n  keys: string[];\n  height: number;\n  xKey: string;\n  xScaleDataType: DataType;\n  xScale: ScaleBand<string> | ScaleBand<Date> | ScaleBand<number> | null;\n  innerXScale: ScaleBand<string> | undefined;\n  yScale: ScaleLinear<number, number, never>;\n  onClick: (e: React.MouseEvent<SVGRectElement, MouseEvent>, barGroup: any, bar: any) => void;\n  conditionalFormattingRules: ConditionalFormattingRule[];\n  bars: ShapeDefinition<BarStyles>[];\n  enableHover?: boolean;\n}) {\n  return (\n    <VisxBarGroup<DatumObject>\n      data={data as DatumObject[]}\n      keys={keys}\n      height={height}\n      x0={d => {\n        const xValue = d[xKey as keyof typeof d];\n        if (xScaleDataType === 'string') return String(xValue);\n        const xValueAdjusted =\n          xScaleDataType === 'date_time'\n            ? new Date(String(xValue))\n            : xScaleDataType === 'number'\n            ? Number(xValue)\n            : String(xValue);\n        return xValueAdjusted;\n      }}\n      // @ts-ignore\n      x0Scale={xScale}\n      // @ts-ignore\n      x1Scale={innerXScale}\n      yScale={yScale}\n      color={() => ''}\n    >\n      {barGroups => {\n        return barGroups.map(barGroup => (\n          <Group key={`bar-group-${barGroup.index}-${barGroup.x0}`} left={barGroup.x0}>\n            {barGroup.bars.map(bar => {\n              if (bar.value === null || bar.height < 0 || bar.width < 0) return null;\n              return (\n                <Bar\n                  key={`bar-group-bar-${barGroup.index}-${bar.index}-${bar.value}-${String(bar.key)}`}\n                  x={bar.x}\n                  y={bar.y}\n                  width={bar.width}\n                  height={bar.height}\n                  fill={getBarFill(bars, conditionalFormattingRules, String(bar.key), bar.value)}\n                  onClick={e => onClick(e, barGroup, bar)}\n                  enableHover={enableHover}\n                />\n              );\n            })}\n          </Group>\n        ));\n      }}\n    </VisxBarGroup>\n  );\n}\n\nconst Bar = (props: {\n  onClick: (e: React.MouseEvent<SVGRectElement, MouseEvent>) => void;\n  fill?: string;\n  x: number;\n  y: number;\n  width: number;\n  height: number;\n  key: string;\n  enableHover?: boolean;\n}) => {\n  const [fillColor, setFillColor] = useState(props.fill);\n  return (\n    <rect\n      key={props.key}\n      x={props.x}\n      y={props.y}\n      width={props.width}\n      height={props.height}\n      fill={fillColor}\n      rx={BAR_RADIUS}\n      onClick={props.onClick}\n      onMouseEnter={() => props.enableHover && setFillColor(lightenColor(props.fill, 0.8))}\n      onMouseLeave={() => props.enableHover && setFillColor(props.fill)}\n      className={props.enableHover ? css({ cursor: 'pointer' }) : ''}\n    />\n  );\n};\n"]} */",
43709
43768
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$9
43710
43769
  }) : ''
43711
43770
  }, props.key);
@@ -43881,14 +43940,8 @@ var AreaChart$5 = function AreaChart(_ref) {
43881
43940
  }
43882
43941
  return null;
43883
43942
  }, [innerWidth, chart.x, chart.data]);
43884
- var _yScale = useMemo(function () {
43885
- return scaleLinear({
43886
- range: [innerHeight, 0],
43887
- domain: chart.y.scale.ordering === 'asc' ? [chart.y.scale.min, chart.y.scale.max] : [chart.y.scale.max, chart.y.scale.min],
43888
- nice: true
43889
- });
43890
- }, [innerHeight, chart.y.scale]);
43891
- var dataFlattened = useFlattenedData(xScaleKey, xScaleDataType, chart);
43943
+ var _yScale = useYScale(innerHeight, chart.y.scale);
43944
+ var dataFlattened = useFlattenedData(xScaleKey, xScaleDataType, chart.data, chart.y.keys);
43892
43945
  var handleMouseMove = useCallback(function (event) {
43893
43946
  if (!xKey || !xScaleKey || xScale === null) return;
43894
43947
  var tooltipData = getTooltipData({
@@ -43918,12 +43971,17 @@ var AreaChart$5 = function AreaChart(_ref) {
43918
43971
  step: curveStep,
43919
43972
  straight: curveLinear
43920
43973
  };
43921
- return curveMap[(_options$curve = options.curve) != null ? _options$curve : 'monotoneX'];
43974
+ return curveMap[(_options$curve = options.curve) != null ? _options$curve : 'natural'];
43922
43975
  }, [options.curve]);
43923
43976
  if (width === 0 || height === 0 || xScale === null) return jsx(React__default.Fragment, {});
43924
43977
  var yTickValues = chart.y.ticks.map(function (tick) {
43925
43978
  return Number(tick.value);
43926
43979
  });
43980
+ var legendTooltipItems = [{
43981
+ visibleYKeys: visibleYKeys,
43982
+ legendItems: chart.areas,
43983
+ conditionalFormattingRules: chart.conditionalFormattingRules
43984
+ }];
43927
43985
  return jsxs(React__default.Fragment, {
43928
43986
  children: [jsxs(ChartWrapper$1, {
43929
43987
  width: width,
@@ -44079,23 +44137,19 @@ var AreaChart$5 = function AreaChart(_ref) {
44079
44137
  width: innerWidth
44080
44138
  })]
44081
44139
  }), options.showLegend && jsx(Legend$1, {
44082
- legendItems: chart.areas,
44083
- visibleYKeys: visibleYKeys,
44140
+ items: legendTooltipItems,
44084
44141
  setVisibleYKeys: setVisibleYKeys,
44085
44142
  keys: chart.keys,
44086
- conditionalFormattingRules: chart.conditionalFormattingRules,
44087
44143
  marginLeft: margin.left - margin.leftTitleOffset
44088
44144
  }), tooltipOpen && tooltipData && xKey && jsx(Tooltip$1, {
44145
+ items: legendTooltipItems,
44089
44146
  tooltipData: tooltipData,
44090
44147
  tooltipLeft: tooltipLeft,
44091
44148
  tooltipTop: tooltipTop,
44092
44149
  xKey: xKey,
44093
44150
  keys: chart.keys,
44094
- visibleYKeys: visibleYKeys,
44095
44151
  yKeys: chart.y.keys,
44096
- legendItems: chart.areas,
44097
44152
  showRoundedTotal: options.showRoundedTotal,
44098
- conditionalFormattingRules: chart.conditionalFormattingRules,
44099
44153
  theme: themeCSS.popoverMenus
44100
44154
  })]
44101
44155
  });
@@ -44398,11 +44452,13 @@ var RadarChart$2 = function RadarChart(_ref) {
44398
44452
  })]
44399
44453
  })
44400
44454
  }), options.showLegend && jsx(Legend$1, {
44401
- legendItems: chart.lines,
44402
- visibleYKeys: visibleYKeys,
44455
+ items: [{
44456
+ legendItems: chart.lines,
44457
+ visibleYKeys: visibleYKeys,
44458
+ conditionalFormattingRules: []
44459
+ }],
44403
44460
  setVisibleYKeys: setVisibleYKeys,
44404
44461
  keys: chart.keys,
44405
- conditionalFormattingRules: [],
44406
44462
  marginLeft: margin.left - margin.leftTitleOffset
44407
44463
  })]
44408
44464
  });
@@ -49114,30 +49170,6 @@ var BarChartV2 = function BarChartV2(props) {
49114
49170
  });
49115
49171
  };
49116
49172
 
49117
- function getBarFill$1(bars, conditionalFormattingRules, barKey, barValues) {
49118
- var _bars$find;
49119
- // Default fill color from the corresponding bar
49120
- var fill = (_bars$find = bars.find(function (chartBar) {
49121
- return chartBar.yKey === barKey;
49122
- })) == null ? void 0 : _bars$find.color;
49123
-
49124
- // Determine the value based on barValues type
49125
- var value = typeof barValues === 'number' ? barValues : barValues == null ? void 0 : barValues[barKey];
49126
- if (typeof value === 'number') {
49127
- for (var _iterator = _createForOfIteratorHelperLoose(conditionalFormattingRules), _step; !(_step = _iterator()).done;) {
49128
- var rule = _step.value;
49129
- if (compare({
49130
- op: rule.operator,
49131
- value: rule.value
49132
- }, value)) {
49133
- fill = rule.color;
49134
- break;
49135
- }
49136
- }
49137
- }
49138
- return fill;
49139
- }
49140
-
49141
49173
  var ASSUMED_AVERAGE_CHAR_WIDTH$1 = 8.8;
49142
49174
  function calculateWordWidth$1(word, avgCharWidth) {
49143
49175
  if (avgCharWidth === void 0) {
@@ -49319,15 +49351,17 @@ var IconTrendingDown$1 = function IconTrendingDown() {
49319
49351
 
49320
49352
  var Legend$2 = function Legend(_ref) {
49321
49353
  var showLegend = _ref.showLegend,
49322
- margin = _ref.margin;
49354
+ margin = _ref.margin,
49355
+ increaseColor = _ref.increaseColor,
49356
+ decreaseColor = _ref.decreaseColor;
49323
49357
  var items = [{
49324
- color: 'green',
49358
+ color: increaseColor,
49325
49359
  yKey: 'increase',
49326
49360
  style: {
49327
49361
  type: 'bar'
49328
49362
  }
49329
49363
  }, {
49330
- color: 'red',
49364
+ color: decreaseColor,
49331
49365
  yKey: 'decrease',
49332
49366
  style: {
49333
49367
  type: 'bar'
@@ -49347,11 +49381,13 @@ var Legend$2 = function Legend(_ref) {
49347
49381
  };
49348
49382
  if (!showLegend) return null;
49349
49383
  return jsx(Legend$1, {
49350
- legendItems: items,
49351
- visibleYKeys: ['increase', 'decrease'],
49384
+ items: [{
49385
+ legendItems: items,
49386
+ visibleYKeys: ['increase', 'decrease'],
49387
+ conditionalFormattingRules: []
49388
+ }],
49352
49389
  keys: keys,
49353
49390
  marginLeft: margin.left - margin.leftTitleOffset,
49354
- conditionalFormattingRules: [],
49355
49391
  setVisibleYKeys: function setVisibleYKeys() {}
49356
49392
  });
49357
49393
  };
@@ -49369,7 +49405,9 @@ var WaterfallChart$2 = function WaterfallChart(_ref) {
49369
49405
  options = _ref.options,
49370
49406
  chart = _ref.chart,
49371
49407
  steps = _ref.steps,
49372
- theme = _ref.theme;
49408
+ theme = _ref.theme,
49409
+ increaseColor = _ref.increaseColor,
49410
+ decreaseColor = _ref.decreaseColor;
49373
49411
  //Waterfall TODO: fix chart for other x types
49374
49412
  if (chart.x.scale.dataType === 'date_time' || chart.x.scale.dataType === 'number') {
49375
49413
  return null;
@@ -49597,7 +49635,7 @@ var WaterfallChart$2 = function WaterfallChart(_ref) {
49597
49635
  },
49598
49636
  stroke: (_theme$axis$stroke = theme == null || (_theme$axis = theme.axis) == null ? void 0 : _theme$axis.stroke) != null ? _theme$axis$stroke : 'transparent'
49599
49637
  }), jsx(Group$2, {
49600
- children: jsx(BarGroup$1, {
49638
+ children: jsx(BarGroup$2, {
49601
49639
  data: dataFlattened,
49602
49640
  keys: yScaleKeys,
49603
49641
  height: innerHeight,
@@ -49618,6 +49656,8 @@ var WaterfallChart$2 = function WaterfallChart(_ref) {
49618
49656
  left: barGroup.x0,
49619
49657
  children: barGroup.bars.map(function (bar) {
49620
49658
  return jsx(Bar$1, {
49659
+ increaseColor: increaseColor,
49660
+ decreaseColor: decreaseColor,
49621
49661
  bar: bar,
49622
49662
  barGroup: barGroup,
49623
49663
  yScale: yScale,
@@ -49638,7 +49678,9 @@ var WaterfallChart$2 = function WaterfallChart(_ref) {
49638
49678
  })]
49639
49679
  }), jsx(Legend$2, {
49640
49680
  showLegend: options.showLegend,
49641
- margin: margin
49681
+ margin: margin,
49682
+ increaseColor: increaseColor,
49683
+ decreaseColor: decreaseColor
49642
49684
  }), jsx(Tooltip$2, {
49643
49685
  showTooltip: tooltipOpen,
49644
49686
  tooltipData: tooltipData,
@@ -49654,7 +49696,9 @@ var Bar$1 = function Bar(_ref4) {
49654
49696
  var bar = _ref4.bar,
49655
49697
  barGroup = _ref4.barGroup,
49656
49698
  yScale = _ref4.yScale,
49657
- formattedChartDataForBarChart = _ref4.formattedChartDataForBarChart;
49699
+ formattedChartDataForBarChart = _ref4.formattedChartDataForBarChart,
49700
+ increaseColor = _ref4.increaseColor,
49701
+ decreaseColor = _ref4.decreaseColor;
49658
49702
  var step = formattedChartDataForBarChart.steps[barGroup.index];
49659
49703
  var y = yScale(Math.max(step.start, step.end));
49660
49704
  var barHeight = Math.abs(yScale(step.start) - yScale(step.end));
@@ -49664,7 +49708,7 @@ var Bar$1 = function Bar(_ref4) {
49664
49708
  y: y,
49665
49709
  width: bar.width,
49666
49710
  height: barHeight,
49667
- fill: getBarFill$1(formattedChartDataForBarChart.bars, formattedChartDataForBarChart.conditionalFormattingRules, bar.key, bar.value),
49711
+ fill: bar.value > 0 ? increaseColor : decreaseColor,
49668
49712
  rx: 4
49669
49713
  }, "bar-group-bar-" + barGroup.index + "-" + bar.index + "-" + bar.value + "-" + bar.key)
49670
49714
  });
@@ -49940,7 +49984,9 @@ var WaterfallChartView = function WaterfallChartView(props) {
49940
49984
  xAxisPrefix = props.xAxisPrefix,
49941
49985
  yAxisFormat = props.yAxisFormat,
49942
49986
  yAxisPostfix = props.yAxisPostfix,
49943
- yAxisPrefix = props.yAxisPrefix;
49987
+ yAxisPrefix = props.yAxisPrefix,
49988
+ increaseColor = props.increaseColor,
49989
+ decreaseColor = props.decreaseColor;
49944
49990
  var _useDashboardBehaviou = useDashboardBehaviourContext(),
49945
49991
  textOverride = _useDashboardBehaviou.textOverride,
49946
49992
  valueAlias = _useDashboardBehaviou.valueAlias,
@@ -50034,7 +50080,9 @@ var WaterfallChartView = function WaterfallChartView(props) {
50034
50080
  },
50035
50081
  theme: theme == null ? void 0 : theme.charts,
50036
50082
  chart: chartRepresentation,
50037
- steps: steps
50083
+ steps: steps,
50084
+ increaseColor: increaseColor,
50085
+ decreaseColor: decreaseColor
50038
50086
  });
50039
50087
  }
50040
50088
  })
@@ -60530,6 +60578,47 @@ var RichTextFormatSection = function RichTextFormatSection(props) {
60530
60578
  });
60531
60579
  };
60532
60580
 
60581
+ var WaterfallColorsSection = function WaterfallColorsSection(props) {
60582
+ var _props$section;
60583
+ var _useDashboardBehaviou = useDashboardBehaviourContext(),
60584
+ textOverride = _useDashboardBehaviou.textOverride;
60585
+ if (props.attributes.type != 'waterfallChart') return null;
60586
+ var _props$attributes = props.attributes,
60587
+ increaseColor = _props$attributes.increaseColor,
60588
+ decreaseColor = _props$attributes.decreaseColor;
60589
+ var debouncedSetAttributes = debounce$1(props.setAttributes, 200);
60590
+ return jsx(Section, {
60591
+ title: props == null ? void 0 : props.section.title,
60592
+ tooltip: props == null || (_props$section = props.section) == null ? void 0 : _props$section.description,
60593
+ children: jsxs(Section.Grid, {
60594
+ columns: 2,
60595
+ children: [jsx("div", {
60596
+ children: jsx(ColorInput, {
60597
+ id: 'waterfall-increase-color',
60598
+ label: textOverride('increase_color', 'Positive value'),
60599
+ currentValue: increaseColor,
60600
+ setColor: function setColor(increaseColor) {
60601
+ return debouncedSetAttributes({
60602
+ increaseColor: increaseColor
60603
+ });
60604
+ }
60605
+ })
60606
+ }), jsx("div", {
60607
+ children: jsx(ColorInput, {
60608
+ id: 'waterfall-decrease-color',
60609
+ label: textOverride('decrease_color', 'Negative value'),
60610
+ currentValue: decreaseColor,
60611
+ setColor: function setColor(decreaseColor) {
60612
+ return debouncedSetAttributes({
60613
+ decreaseColor: decreaseColor
60614
+ });
60615
+ }
60616
+ })
60617
+ })]
60618
+ })
60619
+ });
60620
+ };
60621
+
60533
60622
  var FormatPanelFromConfig = function FormatPanelFromConfig(props) {
60534
60623
  return jsx(EditorGrid, {
60535
60624
  children: props == null ? void 0 : props.formatPanelConfig.map(function (section, i) {
@@ -60560,6 +60649,8 @@ var FormatPanelFromConfig = function FormatPanelFromConfig(props) {
60560
60649
  section: section
60561
60650
  })), section.type === 'mapColors' && jsx(MapColorsSection, _extends({}, props, {
60562
60651
  section: section
60652
+ })), section.type === 'waterfallColors' && jsx(WaterfallColorsSection, _extends({}, props, {
60653
+ section: section
60563
60654
  })), section.type === 'conditionalFormatting' && jsx(ConditionalFormattingSection, _extends({}, props, {
60564
60655
  section: section
60565
60656
  })), section.type === 'goalLine' && jsx(GoalLineSection, _extends({}, props, {