@vizzly/dashboard 0.15.0-dev-ec22f31a049b4f844d3ea606a85bd487c4553b03 → 0.15.0-dev-eee3e3fd0a4936db9e65592ae2ac639fc993b559

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.
@@ -14557,7 +14557,7 @@ var buildDefaults = function buildDefaults(partialFeatureToggles) {
14557
14557
  };
14558
14558
  };
14559
14559
 
14560
- var ALL_COMPONENT_TYPES = ['barChart', 'bubbleChart', 'bubbleChartV2', 'horizontalBarChart', 'funnelChart', 'areaChart', 'areaChartV2', 'lineChart', 'lineChartV2', 'barChartV2', 'comboChartV2', 'scatterChart', 'pieChart', 'sunburstChart', 'singleStat', 'dataTable', 'basicTable', 'comboChart', 'mercatorMap', 'progress', 'richText', 'custom', 'waterfallChart', 'radarChart'];
14560
+ var ALL_COMPONENT_TYPES = ['barChart', 'barChartV2', 'horizontalBarChart', 'funnelChart', 'areaChart', 'areaChartV2', 'lineChart', 'lineChartV2', 'comboChartV2', 'scatterChart', 'bubbleChart', 'bubbleChartV2', 'pieChart', 'sunburstChart', 'singleStat', 'dataTable', 'basicTable', 'comboChart', 'mercatorMap', 'progress', 'richText', 'custom', 'waterfallChart', 'radarChart'];
14561
14561
  var ALL_VIZZLY_COMPONENT_TYPES = /*#__PURE__*/[].concat(ALL_COMPONENT_TYPES).filter(function (type) {
14562
14562
  return type != 'custom';
14563
14563
  });
@@ -43338,7 +43338,9 @@ var Tooltip$1 = function Tooltip(_ref) {
43338
43338
  xKey = _ref.xKey,
43339
43339
  yKeys = _ref.yKeys,
43340
43340
  theme = _ref.theme,
43341
- items = _ref.items;
43341
+ items = _ref.items,
43342
+ _ref$shouldShowColorL = _ref.shouldShowColorLegend,
43343
+ shouldShowColorLegend = _ref$shouldShowColorL === void 0 ? true : _ref$shouldShowColorL;
43342
43344
  var tooltipRef = React.useRef(null);
43343
43345
  var _useState = React.useState({
43344
43346
  left: tooltipLeft
@@ -43387,7 +43389,7 @@ var Tooltip$1 = function Tooltip(_ref) {
43387
43389
  fontSize: '15px',
43388
43390
  width: '100%',
43389
43391
  minWidth: MIN_TOOLTIP_WIDTH
43390
- }, ";label:Tooltip;", "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlRvb2x0aXAudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTJGcUIiLCJmaWxlIjoiVG9vbHRpcC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgQ1NTUHJvcGVydGllcywgRnJhZ21lbnQsIHVzZUVmZmVjdCwgdXNlUmVmLCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IGNyZWF0ZVBvcnRhbCB9IGZyb20gJ3JlYWN0LWRvbSc7XG5cbmltcG9ydCB7IGdldENvbG9yIH0gZnJvbSAnLi4vLi4vdXRpbHMnO1xuaW1wb3J0IHsgTGVnZW5kSXRlbUJveCB9IGZyb20gJy4uL0xlZ2VuZC9MZWdlbmRJdGVtQm94JztcbmltcG9ydCB7IFNoYXBlRGVmaW5pdGlvbiwgQ29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZSwgRGF0YUl0ZW0sIEtleSB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQ2hhcnRzVjIvdHlwZXMnO1xuaW1wb3J0IHsgTGluZVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvTGluZUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQmFyU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9CYXJDaGFydFYyL3R5cGVzJztcbmltcG9ydCB7IEFyZWFTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0FyZWFDaGFydFYyL3R5cGVzJztcbmltcG9ydCB7IEJ1YmJsZVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQnViYmxlQ2hhcnRWMi90eXBlcyc7XG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9jc3MnO1xuXG5jb25zdCBNSU5fVE9PTFRJUF9XSURUSCA9IDE4MDtcbmNvbnN0IFRPT0xUSVBfT0ZGU0VUID0gMjA7XG5jb25zdCBTQ1JPTExCQVJfV0lEVEggPSA0MDtcblxuaW50ZXJmYWNlIFRvb2x0aXBQcm9wczxUPiB7XG4gIGtleXM6IHsgW2tleTogc3RyaW5nXTogS2V5IH07XG4gIHNob3dSb3VuZGVkVG90YWw6IGJvb2xlYW47XG4gIHRvb2x0aXBEYXRhOiB7XG4gICAgW2tleUlkOiBzdHJpbmddOiBEYXRhSXRlbTtcbiAgfTtcbiAgdG9vbHRpcExlZnQ6IG51bWJlcjtcbiAgdG9vbHRpcFRvcDogbnVtYmVyO1xuICB4S2V5OiBzdHJpbmc7XG4gIHlLZXlzPzogc3RyaW5nW107XG4gIGl0ZW1zOiB7XG4gICAgbGVnZW5kSXRlbXM6IEFycmF5PFNoYXBlRGVmaW5pdGlvbjxUPj47XG4gICAgY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXM6IEFycmF5PENvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGU+O1xuICAgIHZpc2libGVZS2V5czogc3RyaW5nW107XG4gIH1bXTtcbiAgdGhlbWU6IENTU1Byb3BlcnRpZXM7XG59XG5cbmV4cG9ydCBjb25zdCBUb29sdGlwID0gKHtcbiAga2V5cyxcbiAgc2hvd1JvdW5kZWRUb3RhbCxcbiAgdG9vbHRpcERhdGEsXG4gIHRvb2x0aXBMZWZ0LFxuICB0b29sdGlwVG9wLFxuICB4S2V5LFxuICB5S2V5cyxcbiAgdGhlbWUsXG4gIGl0ZW1zLFxufTogVG9vbHRpcFByb3BzPExpbmVTdHlsZXMgfCBCYXJTdHlsZXMgfCBBcmVhU3R5bGVzIHwgQnViYmxlU3R5bGVzPikgPT4ge1xuICBjb25zdCB0b29sdGlwUmVmID0gdXNlUmVmPEhUTUxEaXZFbGVtZW50PihudWxsKTtcbiAgY29uc3QgW3Bvc2l0aW9uLCBzZXRQb3NpdGlvbl0gPSB1c2VTdGF0ZTx7IGxlZnQ6IG51bWJlciB9Pih7XG4gICAgbGVmdDogdG9vbHRpcExlZnQsXG4gIH0pO1xuXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgY29uc3QgYWRqdXN0VG9vbHRpcFBvc2l0aW9uID0gKCkgPT4ge1xuICAgICAgY29uc3QgdG9vbHRpcEVsZW1lbnQgPSB0b29sdGlwUmVmLmN1cnJlbnQ7XG5cbiAgICAgIGlmICh0b29sdGlwRWxlbWVudCkge1xuICAgICAgICBjb25zdCBzY3JlZW5XaWR0aCA9IHdpbmRvdy5pbm5lcldpZHRoO1xuXG4gICAgICAgIGNvbnN0IHJlY3QgPSB0b29sdGlwRWxlbWVudC5nZXRCb3VuZGluZ0NsaWVudFJlY3QoKTtcblxuICAgICAgICBsZXQgd2lkdGggPSByZWN0LndpZHRoO1xuXG4gICAgICAgIGlmICh3aWR0aCA8IE1JTl9UT09MVElQX1dJRFRIKSB7XG4gICAgICAgICAgd2lkdGggPSBNSU5fVE9PTFRJUF9XSURUSDtcbiAgICAgICAgfVxuXG4gICAgICAgIGxldCBsZWZ0ID0gdG9vbHRpcExlZnQgKyBUT09MVElQX09GRlNFVDtcblxuICAgICAgICBpZiAodG9vbHRpcExlZnQgKyB3aWR0aCA+IHNjcmVlbldpZHRoIC0gU0NST0xMQkFSX1dJRFRIKSB7XG4gICAgICAgICAgbGVmdCA9IHRvb2x0aXBMZWZ0IC0gd2lkdGggLSBUT09MVElQX09GRlNFVDtcbiAgICAgICAgfVxuXG4gICAgICAgIHNldFBvc2l0aW9uKHsgbGVmdCB9KTtcbiAgICAgIH1cbiAgICB9O1xuXG4gICAgYWRqdXN0VG9vbHRpcFBvc2l0aW9uKCk7XG4gIH0sIFt0b29sdGlwTGVmdF0pO1xuXG4gIHJldHVybiBjcmVhdGVQb3J0YWwoXG4gICAgPGRpdlxuICAgICAgcmVmPXt0b29sdGlwUmVmfVxuICAgICAgc3R5bGU9e3tcbiAgICAgICAgcG9zaXRpb246ICdhYnNvbHV0ZScsXG4gICAgICAgIGxlZnQ6IHBvc2l0aW9uLmxlZnQsXG4gICAgICAgIHRvcDogdG9vbHRpcFRvcCxcbiAgICAgICAgekluZGV4OiAyMTQ3NDgzNjQ3ICogMTAsXG4gICAgICAgIC4uLnRoZW1lLFxuICAgICAgfX1cbiAgICA+XG4gICAgICA8ZGl2IHN0eWxlPXt7IHdvcmRCcmVhazogJ2JyZWFrLWFsbCcgfX0+XG4gICAgICAgIDxkaXZcbiAgICAgICAgICBjbGFzc05hbWU9e2Nzcyh7XG4gICAgICAgICAgICBmb250RmFtaWx5OiAnaW5oZXJpdCcsXG4gICAgICAgICAgICBsaW5lSGVpZ2h0OiAnaW5oZXJpdCcsXG4gICAgICAgICAgICBsZXR0ZXJTcGFjaW5nOiAnaW5oZXJpdCcsXG4gICAgICAgICAgICBmb250V2VpZ2h0OiAnYm9sZCcsXG4gICAgICAgICAgICBmb250U2l6ZTogJzE1cHgnLFxuICAgICAgICAgICAgd2lkdGg6ICcxMDAlJyxcbiAgICAgICAgICAgIG1pbldpZHRoOiBNSU5fVE9PTFRJUF9XSURUSCxcbiAgICAgICAgICB9KX1cbiAgICAgICAgPlxuICAgICAgICAgIHt0b29sdGlwRGF0YVt4S2V5XT8uZm9ybWF0dGVkVmFsdWUgPz8gdG9vbHRpcERhdGFbeEtleV0udmFsdWV9XG4gICAgICAgIDwvZGl2PlxuICAgICAgICA8dGFibGVcbiAgICAgICAgICBjZWxsUGFkZGluZz17MH1cbiAgICAgICAgICBjZWxsU3BhY2luZz17MH1cbiAgICAgICAgICBjbGFzc05hbWU9e2Nzcyh7XG4gICAgICAgICAgICBtYXJnaW46ICcwJyxcbiAgICAgICAgICAgIGJvcmRlclNwYWNpbmc6ICcwJyxcbiAgICAgICAgICAgIGJvcmRlckNvbGxhcHNlOiAnaW5oZXJpdCcsXG4gICAgICAgICAgICBib3JkZXI6ICdub25lJyxcbiAgICAgICAgICB9KX1cbiAgICAgICAgPlxuICAgICAgICAgIDx0Ym9keT5cbiAgICAgICAgICAgIHtpdGVtcy5tYXAoKGl0ZW0sIGluZGV4KSA9PiB7XG4gICAgICAgICAgICAgIHJldHVybiAoXG4gICAgICAgICAgICAgICAgPEZyYWdtZW50IGtleT17aW5kZXh9PlxuICAgICAgICAgICAgICAgICAge2l0ZW0ubGVnZW5kSXRlbXM/Lm1hcCgobGVnZW5kSXRlbSwgaW5kZXgpID0+IHtcbiAgICAgICAgICAgICAgICAgICAgaWYgKCF0b29sdGlwRGF0YVtsZWdlbmRJdGVtLnlLZXldIHx8IHRvb2x0aXBEYXRhW2xlZ2VuZEl0ZW0ueUtleV0udmFsdWUgPT09IG51bGwpIHtcbiAgICAgICAgICAgICAgICAgICAgICAvLyB5S2V5IGNvdWxkIG5vdCBiZSBmb3VuZCBpbiB0b29sdGlwRGF0YVxuICAgICAgICAgICAgICAgICAgICAgIHJldHVybiBudWxsO1xuICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICAgIHJldHVybiAoXG4gICAgICAgICAgICAgICAgICAgICAgaXRlbS52aXNpYmxlWUtleXM/LmluY2x1ZGVzKGxlZ2VuZEl0ZW0ueUtleSkgJiYgKFxuICAgICAgICAgICAgICAgICAgICAgICAgPHRyIGtleT17bGVnZW5kSXRlbS55S2V5fT5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgPHRkXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgc3R5bGU9e3tcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHZlcnRpY2FsQWxpZ246ICdtaWRkbGUnLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgcGFkZGluZzogaW5kZXggPT09IDAgPyAnMTJweCA4cHggMCAwJyA6ICc4cHggOHB4IDAgMCcsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICB3aWR0aDogJ2F1dG8nLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIH19XG4gICAgICAgICAgICAgICAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICA8TGVnZW5kSXRlbUJveFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgY29sb3I9e2dldENvbG9yKHtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgZGVmYXVsdENvbG9yOiBsZWdlbmRJdGVtLmNvbG9yLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB2YWx1ZTogdG9vbHRpcERhdGFbbGVnZW5kSXRlbS55S2V5XS52YWx1ZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgeUtleTogbGVnZW5kSXRlbS55S2V5LFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlczogaXRlbS5jb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlcyA/PyBbXSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIH0pfVxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgc3R5bGU9e2xlZ2VuZEl0ZW0uc3R5bGUgYXMgTGluZVN0eWxlc31cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHlLZXk9e2xlZ2VuZEl0ZW0ueUtleX1cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgICAgICAgICAgICAgICA8L3RkPlxuICAgICAgICAgICAgICAgICAgICAgICAgICA8dGQgc3R5bGU9e3sgcGFkZGluZzogJzhweCAwIDAgMCcgfX0+e2tleXNbbGVnZW5kSXRlbS55S2V5XS5rZXlGb3JtYXR0ZWR9PC90ZD5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgPHRkIHN0eWxlPXt7IGZvbnRXZWlnaHQ6ICdib2xkJywgcGFkZGluZzogJzhweCAwIDAgMTZweCcgfX0+XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAge3Rvb2x0aXBEYXRhW2xlZ2VuZEl0ZW0ueUtleV0uZm9ybWF0dGVkVmFsdWVcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgID8gdG9vbHRpcERhdGFbbGVnZW5kSXRlbS55S2V5XS5mb3JtYXR0ZWRWYWx1ZVxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgOiB0b29sdGlwRGF0YVtsZWdlbmRJdGVtLnlLZXldLnZhbHVlfVxuICAgICAgICAgICAgICAgICAgICAgICAgICA8L3RkPlxuICAgICAgICAgICAgICAgICAgICAgICAgPC90cj5cbiAgICAgICAgICAgICAgICAgICAgICApXG4gICAgICAgICAgICAgICAgICAgICk7XG4gICAgICAgICAgICAgICAgICB9KX1cbiAgICAgICAgICAgICAgICA8L0ZyYWdtZW50PlxuICAgICAgICAgICAgICApO1xuICAgICAgICAgICAgfSl9XG5cbiAgICAgICAgICAgIHtzaG93Um91bmRlZFRvdGFsICYmIHlLZXlzICYmIChcbiAgICAgICAgICAgICAgPHRyPlxuICAgICAgICAgICAgICAgIDx0ZCBjb2xTcGFuPXsyfSBzdHlsZT17eyBwYWRkaW5nOiAnMTJweCAwIDAgMCcgfX0+XG4gICAgICAgICAgICAgICAgICBSb3VuZGVkIFRvdGFsXG4gICAgICAgICAgICAgICAgPC90ZD5cbiAgICAgICAgICAgICAgICA8dGQgc3R5bGU9e3sgZm9udFdlaWdodDogJ2JvbGQnLCBwYWRkaW5nOiAnMTJweCAwIDAgMTZweCcgfX0+XG4gICAgICAgICAgICAgICAgICB7eUtleXMucmVkdWNlKCh0b3RhbCwga2V5KSA9PiB7XG4gICAgICAgICAgICAgICAgICAgIHJldHVybiB0b3RhbCArIE1hdGgucm91bmQodG9vbHRpcERhdGFba2V5XS52YWx1ZSBhcyBudW1iZXIpO1xuICAgICAgICAgICAgICAgICAgfSwgMCl9XG4gICAgICAgICAgICAgICAgPC90ZD5cbiAgICAgICAgICAgICAgPC90cj5cbiAgICAgICAgICAgICl9XG4gICAgICAgICAgPC90Ym9keT5cbiAgICAgICAgPC90YWJsZT5cbiAgICAgIDwvZGl2PlxuICAgIDwvZGl2PixcbiAgICBkb2N1bWVudC5ib2R5XG4gICk7XG59O1xuIl19 */"),
43392
+ }, ";label:Tooltip;", "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Tooltip.tsx"],"names":[],"mappings":"AA6FqB","file":"Tooltip.tsx","sourcesContent":["import React, { CSSProperties, Fragment, 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 { BubbleStyles } from 'shared-logic/src/BubbleChartV2/types';\nimport { css } from '@emotion/css';\n\nconst MIN_TOOLTIP_WIDTH = 180;\nconst TOOLTIP_OFFSET = 20;\nconst SCROLLBAR_WIDTH = 40;\n\ninterface TooltipProps<T> {\n  keys: { [key: string]: Key };\n  showRoundedTotal: boolean;\n  tooltipData: {\n    [keyId: string]: DataItem;\n  };\n  tooltipLeft: number;\n  tooltipTop: number;\n  xKey: string;\n  yKeys?: string[];\n  items: {\n    legendItems: Array<ShapeDefinition<T>>;\n    conditionalFormattingRules: Array<ConditionalFormattingRule>;\n    visibleYKeys: string[];\n  }[];\n  theme: CSSProperties;\n  shouldShowColorLegend?: boolean;\n}\n\nexport const Tooltip = ({\n  keys,\n  showRoundedTotal,\n  tooltipData,\n  tooltipLeft,\n  tooltipTop,\n  xKey,\n  yKeys,\n  theme,\n  items,\n  shouldShowColorLegend = true,\n}: TooltipProps<LineStyles | BarStyles | AreaStyles | BubbleStyles>) => {\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            {items.map((item, index) => {\n              return (\n                <Fragment key={index}>\n                  {item.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                      item.visibleYKeys?.includes(legendItem.yKey) && (\n                        <tr key={`${legendItem.yKey}-${index}-${tooltipData[legendItem.yKey].value}`}>\n                          {shouldShowColorLegend && (\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: item.conditionalFormattingRules ?? [],\n                                })}\n                                style={legendItem.style as LineStyles}\n                                yKey={legendItem.yKey}\n                              />\n                            </td>\n                          )}\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                </Fragment>\n              );\n            })}\n\n            {showRoundedTotal && yKeys && (\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"]} */"),
43391
43393
  children: (_tooltipData$xKey$for = (_tooltipData$xKey = tooltipData[xKey]) == null ? void 0 : _tooltipData$xKey.formattedValue) != null ? _tooltipData$xKey$for : tooltipData[xKey].value
43392
43394
  }), jsxRuntime.jsx("table", {
43393
43395
  cellPadding: 0,
@@ -43395,7 +43397,7 @@ var Tooltip$1 = function Tooltip(_ref) {
43395
43397
  className: /*#__PURE__*/css$1.css( {
43396
43398
  name: "9a1sa-Tooltip",
43397
43399
  styles: "margin:0;border-spacing:0;border-collapse:inherit;border:none;label:Tooltip;",
43398
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlRvb2x0aXAudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTBHcUIiLCJmaWxlIjoiVG9vbHRpcC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgQ1NTUHJvcGVydGllcywgRnJhZ21lbnQsIHVzZUVmZmVjdCwgdXNlUmVmLCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IGNyZWF0ZVBvcnRhbCB9IGZyb20gJ3JlYWN0LWRvbSc7XG5cbmltcG9ydCB7IGdldENvbG9yIH0gZnJvbSAnLi4vLi4vdXRpbHMnO1xuaW1wb3J0IHsgTGVnZW5kSXRlbUJveCB9IGZyb20gJy4uL0xlZ2VuZC9MZWdlbmRJdGVtQm94JztcbmltcG9ydCB7IFNoYXBlRGVmaW5pdGlvbiwgQ29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZSwgRGF0YUl0ZW0sIEtleSB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQ2hhcnRzVjIvdHlwZXMnO1xuaW1wb3J0IHsgTGluZVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvTGluZUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQmFyU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9CYXJDaGFydFYyL3R5cGVzJztcbmltcG9ydCB7IEFyZWFTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0FyZWFDaGFydFYyL3R5cGVzJztcbmltcG9ydCB7IEJ1YmJsZVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQnViYmxlQ2hhcnRWMi90eXBlcyc7XG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9jc3MnO1xuXG5jb25zdCBNSU5fVE9PTFRJUF9XSURUSCA9IDE4MDtcbmNvbnN0IFRPT0xUSVBfT0ZGU0VUID0gMjA7XG5jb25zdCBTQ1JPTExCQVJfV0lEVEggPSA0MDtcblxuaW50ZXJmYWNlIFRvb2x0aXBQcm9wczxUPiB7XG4gIGtleXM6IHsgW2tleTogc3RyaW5nXTogS2V5IH07XG4gIHNob3dSb3VuZGVkVG90YWw6IGJvb2xlYW47XG4gIHRvb2x0aXBEYXRhOiB7XG4gICAgW2tleUlkOiBzdHJpbmddOiBEYXRhSXRlbTtcbiAgfTtcbiAgdG9vbHRpcExlZnQ6IG51bWJlcjtcbiAgdG9vbHRpcFRvcDogbnVtYmVyO1xuICB4S2V5OiBzdHJpbmc7XG4gIHlLZXlzPzogc3RyaW5nW107XG4gIGl0ZW1zOiB7XG4gICAgbGVnZW5kSXRlbXM6IEFycmF5PFNoYXBlRGVmaW5pdGlvbjxUPj47XG4gICAgY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXM6IEFycmF5PENvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGU+O1xuICAgIHZpc2libGVZS2V5czogc3RyaW5nW107XG4gIH1bXTtcbiAgdGhlbWU6IENTU1Byb3BlcnRpZXM7XG59XG5cbmV4cG9ydCBjb25zdCBUb29sdGlwID0gKHtcbiAga2V5cyxcbiAgc2hvd1JvdW5kZWRUb3RhbCxcbiAgdG9vbHRpcERhdGEsXG4gIHRvb2x0aXBMZWZ0LFxuICB0b29sdGlwVG9wLFxuICB4S2V5LFxuICB5S2V5cyxcbiAgdGhlbWUsXG4gIGl0ZW1zLFxufTogVG9vbHRpcFByb3BzPExpbmVTdHlsZXMgfCBCYXJTdHlsZXMgfCBBcmVhU3R5bGVzIHwgQnViYmxlU3R5bGVzPikgPT4ge1xuICBjb25zdCB0b29sdGlwUmVmID0gdXNlUmVmPEhUTUxEaXZFbGVtZW50PihudWxsKTtcbiAgY29uc3QgW3Bvc2l0aW9uLCBzZXRQb3NpdGlvbl0gPSB1c2VTdGF0ZTx7IGxlZnQ6IG51bWJlciB9Pih7XG4gICAgbGVmdDogdG9vbHRpcExlZnQsXG4gIH0pO1xuXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgY29uc3QgYWRqdXN0VG9vbHRpcFBvc2l0aW9uID0gKCkgPT4ge1xuICAgICAgY29uc3QgdG9vbHRpcEVsZW1lbnQgPSB0b29sdGlwUmVmLmN1cnJlbnQ7XG5cbiAgICAgIGlmICh0b29sdGlwRWxlbWVudCkge1xuICAgICAgICBjb25zdCBzY3JlZW5XaWR0aCA9IHdpbmRvdy5pbm5lcldpZHRoO1xuXG4gICAgICAgIGNvbnN0IHJlY3QgPSB0b29sdGlwRWxlbWVudC5nZXRCb3VuZGluZ0NsaWVudFJlY3QoKTtcblxuICAgICAgICBsZXQgd2lkdGggPSByZWN0LndpZHRoO1xuXG4gICAgICAgIGlmICh3aWR0aCA8IE1JTl9UT09MVElQX1dJRFRIKSB7XG4gICAgICAgICAgd2lkdGggPSBNSU5fVE9PTFRJUF9XSURUSDtcbiAgICAgICAgfVxuXG4gICAgICAgIGxldCBsZWZ0ID0gdG9vbHRpcExlZnQgKyBUT09MVElQX09GRlNFVDtcblxuICAgICAgICBpZiAodG9vbHRpcExlZnQgKyB3aWR0aCA+IHNjcmVlbldpZHRoIC0gU0NST0xMQkFSX1dJRFRIKSB7XG4gICAgICAgICAgbGVmdCA9IHRvb2x0aXBMZWZ0IC0gd2lkdGggLSBUT09MVElQX09GRlNFVDtcbiAgICAgICAgfVxuXG4gICAgICAgIHNldFBvc2l0aW9uKHsgbGVmdCB9KTtcbiAgICAgIH1cbiAgICB9O1xuXG4gICAgYWRqdXN0VG9vbHRpcFBvc2l0aW9uKCk7XG4gIH0sIFt0b29sdGlwTGVmdF0pO1xuXG4gIHJldHVybiBjcmVhdGVQb3J0YWwoXG4gICAgPGRpdlxuICAgICAgcmVmPXt0b29sdGlwUmVmfVxuICAgICAgc3R5bGU9e3tcbiAgICAgICAgcG9zaXRpb246ICdhYnNvbHV0ZScsXG4gICAgICAgIGxlZnQ6IHBvc2l0aW9uLmxlZnQsXG4gICAgICAgIHRvcDogdG9vbHRpcFRvcCxcbiAgICAgICAgekluZGV4OiAyMTQ3NDgzNjQ3ICogMTAsXG4gICAgICAgIC4uLnRoZW1lLFxuICAgICAgfX1cbiAgICA+XG4gICAgICA8ZGl2IHN0eWxlPXt7IHdvcmRCcmVhazogJ2JyZWFrLWFsbCcgfX0+XG4gICAgICAgIDxkaXZcbiAgICAgICAgICBjbGFzc05hbWU9e2Nzcyh7XG4gICAgICAgICAgICBmb250RmFtaWx5OiAnaW5oZXJpdCcsXG4gICAgICAgICAgICBsaW5lSGVpZ2h0OiAnaW5oZXJpdCcsXG4gICAgICAgICAgICBsZXR0ZXJTcGFjaW5nOiAnaW5oZXJpdCcsXG4gICAgICAgICAgICBmb250V2VpZ2h0OiAnYm9sZCcsXG4gICAgICAgICAgICBmb250U2l6ZTogJzE1cHgnLFxuICAgICAgICAgICAgd2lkdGg6ICcxMDAlJyxcbiAgICAgICAgICAgIG1pbldpZHRoOiBNSU5fVE9PTFRJUF9XSURUSCxcbiAgICAgICAgICB9KX1cbiAgICAgICAgPlxuICAgICAgICAgIHt0b29sdGlwRGF0YVt4S2V5XT8uZm9ybWF0dGVkVmFsdWUgPz8gdG9vbHRpcERhdGFbeEtleV0udmFsdWV9XG4gICAgICAgIDwvZGl2PlxuICAgICAgICA8dGFibGVcbiAgICAgICAgICBjZWxsUGFkZGluZz17MH1cbiAgICAgICAgICBjZWxsU3BhY2luZz17MH1cbiAgICAgICAgICBjbGFzc05hbWU9e2Nzcyh7XG4gICAgICAgICAgICBtYXJnaW46ICcwJyxcbiAgICAgICAgICAgIGJvcmRlclNwYWNpbmc6ICcwJyxcbiAgICAgICAgICAgIGJvcmRlckNvbGxhcHNlOiAnaW5oZXJpdCcsXG4gICAgICAgICAgICBib3JkZXI6ICdub25lJyxcbiAgICAgICAgICB9KX1cbiAgICAgICAgPlxuICAgICAgICAgIDx0Ym9keT5cbiAgICAgICAgICAgIHtpdGVtcy5tYXAoKGl0ZW0sIGluZGV4KSA9PiB7XG4gICAgICAgICAgICAgIHJldHVybiAoXG4gICAgICAgICAgICAgICAgPEZyYWdtZW50IGtleT17aW5kZXh9PlxuICAgICAgICAgICAgICAgICAge2l0ZW0ubGVnZW5kSXRlbXM/Lm1hcCgobGVnZW5kSXRlbSwgaW5kZXgpID0+IHtcbiAgICAgICAgICAgICAgICAgICAgaWYgKCF0b29sdGlwRGF0YVtsZWdlbmRJdGVtLnlLZXldIHx8IHRvb2x0aXBEYXRhW2xlZ2VuZEl0ZW0ueUtleV0udmFsdWUgPT09IG51bGwpIHtcbiAgICAgICAgICAgICAgICAgICAgICAvLyB5S2V5IGNvdWxkIG5vdCBiZSBmb3VuZCBpbiB0b29sdGlwRGF0YVxuICAgICAgICAgICAgICAgICAgICAgIHJldHVybiBudWxsO1xuICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICAgIHJldHVybiAoXG4gICAgICAgICAgICAgICAgICAgICAgaXRlbS52aXNpYmxlWUtleXM/LmluY2x1ZGVzKGxlZ2VuZEl0ZW0ueUtleSkgJiYgKFxuICAgICAgICAgICAgICAgICAgICAgICAgPHRyIGtleT17bGVnZW5kSXRlbS55S2V5fT5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgPHRkXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgc3R5bGU9e3tcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHZlcnRpY2FsQWxpZ246ICdtaWRkbGUnLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgcGFkZGluZzogaW5kZXggPT09IDAgPyAnMTJweCA4cHggMCAwJyA6ICc4cHggOHB4IDAgMCcsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICB3aWR0aDogJ2F1dG8nLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIH19XG4gICAgICAgICAgICAgICAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICA8TGVnZW5kSXRlbUJveFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgY29sb3I9e2dldENvbG9yKHtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgZGVmYXVsdENvbG9yOiBsZWdlbmRJdGVtLmNvbG9yLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB2YWx1ZTogdG9vbHRpcERhdGFbbGVnZW5kSXRlbS55S2V5XS52YWx1ZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgeUtleTogbGVnZW5kSXRlbS55S2V5LFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlczogaXRlbS5jb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlcyA/PyBbXSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIH0pfVxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgc3R5bGU9e2xlZ2VuZEl0ZW0uc3R5bGUgYXMgTGluZVN0eWxlc31cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHlLZXk9e2xlZ2VuZEl0ZW0ueUtleX1cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgICAgICAgICAgICAgICA8L3RkPlxuICAgICAgICAgICAgICAgICAgICAgICAgICA8dGQgc3R5bGU9e3sgcGFkZGluZzogJzhweCAwIDAgMCcgfX0+e2tleXNbbGVnZW5kSXRlbS55S2V5XS5rZXlGb3JtYXR0ZWR9PC90ZD5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgPHRkIHN0eWxlPXt7IGZvbnRXZWlnaHQ6ICdib2xkJywgcGFkZGluZzogJzhweCAwIDAgMTZweCcgfX0+XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAge3Rvb2x0aXBEYXRhW2xlZ2VuZEl0ZW0ueUtleV0uZm9ybWF0dGVkVmFsdWVcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgID8gdG9vbHRpcERhdGFbbGVnZW5kSXRlbS55S2V5XS5mb3JtYXR0ZWRWYWx1ZVxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgOiB0b29sdGlwRGF0YVtsZWdlbmRJdGVtLnlLZXldLnZhbHVlfVxuICAgICAgICAgICAgICAgICAgICAgICAgICA8L3RkPlxuICAgICAgICAgICAgICAgICAgICAgICAgPC90cj5cbiAgICAgICAgICAgICAgICAgICAgICApXG4gICAgICAgICAgICAgICAgICAgICk7XG4gICAgICAgICAgICAgICAgICB9KX1cbiAgICAgICAgICAgICAgICA8L0ZyYWdtZW50PlxuICAgICAgICAgICAgICApO1xuICAgICAgICAgICAgfSl9XG5cbiAgICAgICAgICAgIHtzaG93Um91bmRlZFRvdGFsICYmIHlLZXlzICYmIChcbiAgICAgICAgICAgICAgPHRyPlxuICAgICAgICAgICAgICAgIDx0ZCBjb2xTcGFuPXsyfSBzdHlsZT17eyBwYWRkaW5nOiAnMTJweCAwIDAgMCcgfX0+XG4gICAgICAgICAgICAgICAgICBSb3VuZGVkIFRvdGFsXG4gICAgICAgICAgICAgICAgPC90ZD5cbiAgICAgICAgICAgICAgICA8dGQgc3R5bGU9e3sgZm9udFdlaWdodDogJ2JvbGQnLCBwYWRkaW5nOiAnMTJweCAwIDAgMTZweCcgfX0+XG4gICAgICAgICAgICAgICAgICB7eUtleXMucmVkdWNlKCh0b3RhbCwga2V5KSA9PiB7XG4gICAgICAgICAgICAgICAgICAgIHJldHVybiB0b3RhbCArIE1hdGgucm91bmQodG9vbHRpcERhdGFba2V5XS52YWx1ZSBhcyBudW1iZXIpO1xuICAgICAgICAgICAgICAgICAgfSwgMCl9XG4gICAgICAgICAgICAgICAgPC90ZD5cbiAgICAgICAgICAgICAgPC90cj5cbiAgICAgICAgICAgICl9XG4gICAgICAgICAgPC90Ym9keT5cbiAgICAgICAgPC90YWJsZT5cbiAgICAgIDwvZGl2PlxuICAgIDwvZGl2PixcbiAgICBkb2N1bWVudC5ib2R5XG4gICk7XG59O1xuIl19 */",
43400
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Tooltip.tsx"],"names":[],"mappings":"AA4GqB","file":"Tooltip.tsx","sourcesContent":["import React, { CSSProperties, Fragment, 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 { BubbleStyles } from 'shared-logic/src/BubbleChartV2/types';\nimport { css } from '@emotion/css';\n\nconst MIN_TOOLTIP_WIDTH = 180;\nconst TOOLTIP_OFFSET = 20;\nconst SCROLLBAR_WIDTH = 40;\n\ninterface TooltipProps<T> {\n  keys: { [key: string]: Key };\n  showRoundedTotal: boolean;\n  tooltipData: {\n    [keyId: string]: DataItem;\n  };\n  tooltipLeft: number;\n  tooltipTop: number;\n  xKey: string;\n  yKeys?: string[];\n  items: {\n    legendItems: Array<ShapeDefinition<T>>;\n    conditionalFormattingRules: Array<ConditionalFormattingRule>;\n    visibleYKeys: string[];\n  }[];\n  theme: CSSProperties;\n  shouldShowColorLegend?: boolean;\n}\n\nexport const Tooltip = ({\n  keys,\n  showRoundedTotal,\n  tooltipData,\n  tooltipLeft,\n  tooltipTop,\n  xKey,\n  yKeys,\n  theme,\n  items,\n  shouldShowColorLegend = true,\n}: TooltipProps<LineStyles | BarStyles | AreaStyles | BubbleStyles>) => {\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            {items.map((item, index) => {\n              return (\n                <Fragment key={index}>\n                  {item.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                      item.visibleYKeys?.includes(legendItem.yKey) && (\n                        <tr key={`${legendItem.yKey}-${index}-${tooltipData[legendItem.yKey].value}`}>\n                          {shouldShowColorLegend && (\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: item.conditionalFormattingRules ?? [],\n                                })}\n                                style={legendItem.style as LineStyles}\n                                yKey={legendItem.yKey}\n                              />\n                            </td>\n                          )}\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                </Fragment>\n              );\n            })}\n\n            {showRoundedTotal && yKeys && (\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"]} */",
43399
43401
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$5
43400
43402
  }),
43401
43403
  children: jsxRuntime.jsxs("tbody", {
@@ -43409,7 +43411,7 @@ var Tooltip$1 = function Tooltip(_ref) {
43409
43411
  return null;
43410
43412
  }
43411
43413
  return ((_item$visibleYKeys = item.visibleYKeys) == null ? void 0 : _item$visibleYKeys.includes(legendItem.yKey)) && jsxRuntime.jsxs("tr", {
43412
- children: [jsxRuntime.jsx("td", {
43414
+ children: [shouldShowColorLegend && jsxRuntime.jsx("td", {
43413
43415
  style: {
43414
43416
  verticalAlign: 'middle',
43415
43417
  padding: index === 0 ? '12px 8px 0 0' : '8px 8px 0 0',
@@ -43437,7 +43439,7 @@ var Tooltip$1 = function Tooltip(_ref) {
43437
43439
  },
43438
43440
  children: tooltipData[legendItem.yKey].formattedValue ? tooltipData[legendItem.yKey].formattedValue : tooltipData[legendItem.yKey].value
43439
43441
  })]
43440
- }, legendItem.yKey);
43442
+ }, legendItem.yKey + "-" + index + "-" + tooltipData[legendItem.yKey].value);
43441
43443
  })
43442
43444
  }, index);
43443
43445
  }), showRoundedTotal && yKeys && jsxRuntime.jsxs("tr", {
@@ -44051,21 +44053,30 @@ var GridRows = function GridRows(_ref) {
44051
44053
  });
44052
44054
  };
44053
44055
 
44056
+ var _excluded$g = ["children", "width", "height", "showLegend", "onMouseMove", "onMouseLeave"];
44054
44057
  function _EMOTION_STRINGIFIED_CSS_ERROR__$8() { 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)."; }
44055
- var ChartWrapper$1 = function ChartWrapper(props) {
44056
- return jsxRuntime.jsx("svg", {
44057
- width: props.width,
44058
- height: props.height - (props.showLegend ? 40 : 0),
44059
- onMouseMove: props.onMouseMove,
44060
- onMouseLeave: props.onMouseLeave,
44058
+ var ChartWrapper$1 = function ChartWrapper(_ref) {
44059
+ var children = _ref.children,
44060
+ width = _ref.width,
44061
+ height = _ref.height,
44062
+ showLegend = _ref.showLegend,
44063
+ onMouseMove = _ref.onMouseMove,
44064
+ onMouseLeave = _ref.onMouseLeave,
44065
+ svgProps = _objectWithoutPropertiesLoose(_ref, _excluded$g);
44066
+ return jsxRuntime.jsx("svg", _extends({
44067
+ width: width,
44068
+ height: height - (showLegend ? 40 : 0),
44069
+ onMouseMove: onMouseMove,
44070
+ onMouseLeave: onMouseLeave,
44061
44071
  className: /*#__PURE__*/css$1.css( {
44062
44072
  name: "fx4tbw-ChartWrapper",
44063
44073
  styles: "display:block;label:ChartWrapper;",
44064
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNoYXJ0V3JhcHBlci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBZ0JpQiIsImZpbGUiOiJDaGFydFdyYXBwZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vY3NzJztcblxuZXhwb3J0IGNvbnN0IENoYXJ0V3JhcHBlciA9IChwcm9wczoge1xuICBjaGlsZHJlbjogUmVhY3QuUmVhY3ROb2RlO1xuICB3aWR0aDogbnVtYmVyO1xuICBoZWlnaHQ6IG51bWJlcjtcbiAgc2hvd0xlZ2VuZDogYm9vbGVhbjtcbiAgb25Nb3VzZU1vdmU/OiBSZWFjdC5Nb3VzZUV2ZW50SGFuZGxlcjxTVkdTVkdFbGVtZW50PjtcbiAgb25Nb3VzZUxlYXZlPzogUmVhY3QuTW91c2VFdmVudEhhbmRsZXI8U1ZHU1ZHRWxlbWVudD47XG59KSA9PiB7XG4gIHJldHVybiAoXG4gICAgPHN2Z1xuICAgICAgd2lkdGg9e3Byb3BzLndpZHRofVxuICAgICAgaGVpZ2h0PXtwcm9wcy5oZWlnaHQgLSAocHJvcHMuc2hvd0xlZ2VuZCA/IDQwIDogMCl9XG4gICAgICBvbk1vdXNlTW92ZT17cHJvcHMub25Nb3VzZU1vdmV9XG4gICAgICBvbk1vdXNlTGVhdmU9e3Byb3BzLm9uTW91c2VMZWF2ZX1cbiAgICAgIGNsYXNzTmFtZT17Y3NzKHsgZGlzcGxheTogJ2Jsb2NrJyB9KX1cbiAgICA+XG4gICAgICB7cHJvcHMuY2hpbGRyZW59XG4gICAgPC9zdmc+XG4gICk7XG59O1xuIl19 */",
44074
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNoYXJ0V3JhcHBlci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMEJpQiIsImZpbGUiOiJDaGFydFdyYXBwZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vY3NzJztcblxudHlwZSBDaGFydFdyYXBwZXJQcm9wcyA9IHtcbiAgY2hpbGRyZW46IFJlYWN0LlJlYWN0Tm9kZTtcbiAgd2lkdGg6IG51bWJlcjtcbiAgaGVpZ2h0OiBudW1iZXI7XG4gIHNob3dMZWdlbmQ6IGJvb2xlYW47XG4gIG9uTW91c2VNb3ZlPzogUmVhY3QuTW91c2VFdmVudEhhbmRsZXI8U1ZHU1ZHRWxlbWVudD47XG4gIG9uTW91c2VMZWF2ZT86IFJlYWN0Lk1vdXNlRXZlbnRIYW5kbGVyPFNWR1NWR0VsZW1lbnQ+O1xufSAmIFJlYWN0LlNWR1Byb3BzPFNWR1NWR0VsZW1lbnQ+O1xuXG5leHBvcnQgY29uc3QgQ2hhcnRXcmFwcGVyID0gKHtcbiAgY2hpbGRyZW4sXG4gIHdpZHRoLFxuICBoZWlnaHQsXG4gIHNob3dMZWdlbmQsXG4gIG9uTW91c2VNb3ZlLFxuICBvbk1vdXNlTGVhdmUsXG4gIC4uLnN2Z1Byb3BzXG59OiBDaGFydFdyYXBwZXJQcm9wcykgPT4ge1xuICByZXR1cm4gKFxuICAgIDxzdmdcbiAgICAgIHdpZHRoPXt3aWR0aH1cbiAgICAgIGhlaWdodD17aGVpZ2h0IC0gKHNob3dMZWdlbmQgPyA0MCA6IDApfVxuICAgICAgb25Nb3VzZU1vdmU9e29uTW91c2VNb3ZlfVxuICAgICAgb25Nb3VzZUxlYXZlPXtvbk1vdXNlTGVhdmV9XG4gICAgICBjbGFzc05hbWU9e2Nzcyh7IGRpc3BsYXk6ICdibG9jaycgfSl9XG4gICAgICB7Li4uc3ZnUHJvcHN9XG4gICAgPlxuICAgICAge2NoaWxkcmVufVxuICAgIDwvc3ZnPlxuICApO1xufTtcbiJdfQ== */",
44065
44075
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$8
44066
- }),
44067
- children: props.children
44068
- });
44076
+ })
44077
+ }, svgProps, {
44078
+ children: children
44079
+ }));
44069
44080
  };
44070
44081
 
44071
44082
  var CrosshairCircle = function CrosshairCircle(_ref) {
@@ -44130,7 +44141,7 @@ var Line = function Line(_ref) {
44130
44141
  });
44131
44142
  };
44132
44143
 
44133
- var _excluded$g = ["tooltipOpen"];
44144
+ var _excluded$h = ["tooltipOpen"];
44134
44145
  function useTooltip$1(initialTooltipState) {
44135
44146
  var _useState = React.useState(_extends({
44136
44147
  tooltipOpen: false
@@ -44139,7 +44150,7 @@ function useTooltip$1(initialTooltipState) {
44139
44150
  setTooltipState = _useState[1];
44140
44151
  var showTooltip = React.useCallback(function (showArgs) {
44141
44152
  return setTooltipState(typeof showArgs === 'function' ? function (_ref) {
44142
- var show = _objectWithoutPropertiesLoose(_ref, _excluded$g);
44153
+ var show = _objectWithoutPropertiesLoose(_ref, _excluded$h);
44143
44154
  return _extends({}, showArgs(show), {
44144
44155
  tooltipOpen: true
44145
44156
  });
@@ -44471,58 +44482,7 @@ function Lines(_ref2) {
44471
44482
  });
44472
44483
  }
44473
44484
 
44474
- var PADDING = {
44475
- paddingOuter: 0.05,
44476
- paddingInner: 0.3
44477
- };
44478
-
44479
- function useBarXScale(xScaleDataType, innerWidth, xScaleKey, data) {
44480
- return React.useMemo(function () {
44481
- if (xScaleDataType === 'string') {
44482
- return scale.scaleBand(_extends({
44483
- range: [0, innerWidth],
44484
- domain: xScaleKey ? [].concat(data.map(function (d) {
44485
- return d[xScaleKey] && d[xScaleKey].value !== null ? String(d[xScaleKey].value) : '';
44486
- })) : []
44487
- }, PADDING));
44488
- }
44489
- if (xScaleDataType === 'date_time' && xScaleKey) {
44490
- return scale.scaleBand(_extends({
44491
- range: [0, innerWidth],
44492
- domain: data.map(function (d) {
44493
- return new Date(d[xScaleKey].value);
44494
- })
44495
- }, PADDING));
44496
- }
44497
- if (xScaleDataType === 'number' && xScaleKey) {
44498
- return scale.scaleBand(_extends({
44499
- range: [0, innerWidth],
44500
- domain: data.map(function (d) {
44501
- return d[xScaleKey] && d[xScaleKey].value !== null ? Number(d[xScaleKey].value) : 0;
44502
- })
44503
- }, PADDING));
44504
- }
44505
- return null;
44506
- }, [innerWidth, data]);
44507
- }
44508
-
44509
- var useBottomAxisBaseLineShift = function useBottomAxisBaseLineShift(_ref) {
44510
- var showDetailedSubGroupingLabels = _ref.showDetailedSubGroupingLabels,
44511
- hasBottomTitle = _ref.hasBottomTitle,
44512
- hasLeftTitle = _ref.hasLeftTitle;
44513
- if (!showDetailedSubGroupingLabels) {
44514
- return {
44515
- bottomAxisBaselineShift: 0,
44516
- bottomOffset: 0,
44517
- leftOffset: 0
44518
- };
44519
- }
44520
- return {
44521
- bottomAxisBaselineShift: hasBottomTitle ? -65 : -60,
44522
- bottomOffset: hasBottomTitle ? -15 : 10,
44523
- leftOffset: hasLeftTitle ? -10 : 0
44524
- };
44525
- };
44485
+ var BAR_RADIUS = 2;
44526
44486
 
44527
44487
  function getBarFill(bars, conditionalFormattingRules, barKey, barValues) {
44528
44488
  var _bars$find;
@@ -44548,73 +44508,6 @@ function getBarFill(bars, conditionalFormattingRules, barKey, barValues) {
44548
44508
  return fill;
44549
44509
  }
44550
44510
 
44551
- var BAR_RADIUS = 2;
44552
-
44553
- var BarStacked = function BarStacked(_ref) {
44554
- var xScaleDataType = _ref.xScaleDataType,
44555
- data = _ref.data,
44556
- xScaleKey = _ref.xScaleKey,
44557
- yScale = _ref.yScale,
44558
- keys = _ref.keys,
44559
- bars = _ref.bars,
44560
- conditionalFormattingRules = _ref.conditionalFormattingRules,
44561
- xScale = _ref.xScale,
44562
- height = _ref.height,
44563
- width = _ref.width;
44564
- var handleGetXValue = function handleGetXValue(d) {
44565
- var xValue = d[xScaleKey];
44566
- if (xScaleDataType === 'string') return String(xValue);
44567
- if (xScaleDataType === 'date_time') {
44568
- return new Date(xValue);
44569
- }
44570
- if (xScaleDataType === 'number') {
44571
- return Number(xValue);
44572
- }
44573
- return String(xValue);
44574
- };
44575
- return jsxRuntime.jsx(shape.BarStack, {
44576
- x: handleGetXValue,
44577
- xScale: xScale,
44578
- yScale: yScale,
44579
- data: data,
44580
- keys: keys,
44581
- color: function color() {
44582
- return '';
44583
- },
44584
- height: height,
44585
- width: width,
44586
- offset: "none",
44587
- children: function children(barStacks) {
44588
- return barStacks.map(function (barStack) {
44589
- return barStack.bars.map(function (bar) {
44590
- return jsxRuntime.jsx(Bar, {
44591
- bar: bar,
44592
- barStack: barStack,
44593
- bars: bars,
44594
- conditionalFormattingRules: conditionalFormattingRules
44595
- }, bar.key.toString());
44596
- });
44597
- });
44598
- }
44599
- });
44600
- };
44601
- var Bar = function Bar(_ref2) {
44602
- var bar = _ref2.bar,
44603
- barStack = _ref2.barStack,
44604
- bars = _ref2.bars,
44605
- conditionalFormattingRules = _ref2.conditionalFormattingRules;
44606
- var BAR_PADDING = 1.5;
44607
- if (bar.height < 3) return null;
44608
- return jsxRuntime.jsx("rect", {
44609
- x: bar.x,
44610
- y: bar.y,
44611
- width: bar.width,
44612
- height: bar.height - BAR_PADDING,
44613
- fill: getBarFill(bars, conditionalFormattingRules, bar.key, bar.bar.data),
44614
- rx: BAR_RADIUS
44615
- }, "bar-stack-" + barStack.index + "-" + bar.index);
44616
- };
44617
-
44618
44511
  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)."; }
44619
44512
  function BarGroup(_ref) {
44620
44513
  var data = _ref.data,
@@ -44664,7 +44557,7 @@ function BarGroup(_ref) {
44664
44557
  return jsxRuntime.jsx(group.Group, {
44665
44558
  left: barGroup.x0,
44666
44559
  children: barGroup.bars.map(function (bar) {
44667
- return jsxRuntime.jsx(Bar$1, {
44560
+ return jsxRuntime.jsx(Bar, {
44668
44561
  bar: bar,
44669
44562
  barGroup: barGroup,
44670
44563
  bars: bars,
@@ -44682,7 +44575,7 @@ function BarGroup(_ref) {
44682
44575
  }
44683
44576
  });
44684
44577
  }
44685
- var Bar$1 = function Bar(_ref2) {
44578
+ var Bar = function Bar(_ref2) {
44686
44579
  var bar = _ref2.bar,
44687
44580
  barGroup = _ref2.barGroup,
44688
44581
  bars = _ref2.bars,
@@ -44696,6 +44589,7 @@ var Bar$1 = function Bar(_ref2) {
44696
44589
  var showBar = bar.value !== null && bar.height > 0 && bar.width > 0;
44697
44590
  return jsxRuntime.jsxs(React.Fragment, {
44698
44591
  children: [showBar && jsxRuntime.jsx(BarRect, {
44592
+ barRectKey: "bar-group-bar-" + barGroup.index + "-" + bar.index + "-" + bar.value + "-" + String(bar.key),
44699
44593
  x: bar.x,
44700
44594
  y: bar.y,
44701
44595
  width: bar.width,
@@ -44705,7 +44599,7 @@ var Bar$1 = function Bar(_ref2) {
44705
44599
  return _onClick(e, barGroup, bar);
44706
44600
  },
44707
44601
  enableHover: enableHover
44708
- }, "bar-group-bar-" + barGroup.index + "-" + bar.index + "-" + bar.value + "-" + String(bar.key)), jsxRuntime.jsx(BarLabel, {
44602
+ }), jsxRuntime.jsx(BarLabel, {
44709
44603
  bar: bar,
44710
44604
  barGroup: barGroup,
44711
44605
  yLabelPosition: yLabelPosition,
@@ -44722,7 +44616,7 @@ var BarRect = function BarRect(_ref3) {
44722
44616
  y = _ref3.y,
44723
44617
  width = _ref3.width,
44724
44618
  height = _ref3.height,
44725
- key = _ref3.key,
44619
+ barRectKey = _ref3.barRectKey,
44726
44620
  enableHover = _ref3.enableHover;
44727
44621
  var _useState = React.useState(fill),
44728
44622
  fillColor = _useState[0],
@@ -44730,7 +44624,7 @@ var BarRect = function BarRect(_ref3) {
44730
44624
  var classes = enableHover ? /*#__PURE__*/css$1.css( {
44731
44625
  name: "1ltmijl-classes",
44732
44626
  styles: "cursor:pointer;label:classes;",
44733
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["BarGroup.tsx"],"names":[],"mappings":"AAmLkC","file":"BarGroup.tsx","sourcesContent":["import { css } from \"@emotion/css\";\nimport { Fragment, useState } from \"react\";\nimport { lightenColor } from \"../../../styles/color.functions\";\nimport { BAR_RADIUS } from '../../constants/BORDER_RADIUS'\nimport { getBarFill } from \"../getBarFill\";\nimport { ChartDataDefinition, ConditionalFormattingRule, ShapeDefinition } from \"shared-logic/src/ChartsV2/types\";\nimport { BarStyles } from \"shared-logic/src/BarChartV2/types\";\nimport { BarGroup as VisxBarGroup } from '@visx/shape';\nimport { ScaleLinear, ScaleBand } from '@visx/vendor/d3-scale';\nimport { DataType } from \"shared-logic/src/Field/types\";\nimport { DatumObject } from '@visx/shape/lib/types';\nimport { Group } from '@visx/group';\n\nexport type BarGroupProps = {\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    yAxisLabels?: string[];\n    yLabelPosition?: number;\n    showDetailedSubGroupingLabels: boolean;\n    labelStyle?: React.CSSProperties;\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    yAxisLabels,\n    yLabelPosition,\n    showDetailedSubGroupingLabels,\n    labelStyle,\n}: BarGroupProps) {\n    const getGroupPosition = (d: DatumObject) => {\n        const xValue = d[xKey as keyof typeof d];\n\n        if (xScaleDataType === 'string') return String(xValue);\n\n        if (xScaleDataType === 'date_time') {\n            return new Date(String(xValue));\n        }\n\n        if (xScaleDataType === 'number') {\n            return Number(xValue);\n        }\n\n        return String(xValue);\n    };\n\n    return (\n        <VisxBarGroup<DatumObject>\n            data={data as DatumObject[]}\n            keys={keys}\n            height={height}\n            x0={getGroupPosition}\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                            <Bar\n                                key={`bar-${bar.index}-${bar.x}`}\n                                bar={bar}\n                                barGroup={barGroup}\n                                bars={bars}\n                                conditionalFormattingRules={conditionalFormattingRules}\n                                enableHover={enableHover}\n                                labelStyle={labelStyle}\n                                onClick={onClick}\n                                showDetailedSubGroupingLabels={showDetailedSubGroupingLabels}\n                                yAxisLabels={yAxisLabels}\n                                yLabelPosition={yLabelPosition}\n                            />\n                        ))}\n                    </Group>\n                ));\n            }}\n        </VisxBarGroup>\n    );\n}\n\ntype BarProps = {\n    bar: any,\n    barGroup: any,\n    bars: ShapeDefinition<BarStyles>[];\n    conditionalFormattingRules: ConditionalFormattingRule[];\n    enableHover?: boolean;\n    onClick: (e: React.MouseEvent<SVGRectElement, MouseEvent>, barGroup: any, bar: any) => void;\n    showDetailedSubGroupingLabels: boolean;\n    labelStyle?: React.CSSProperties;\n    yAxisLabels?: string[];\n    yLabelPosition?: number;\n}\n\nconst Bar = ({\n    bar,\n    barGroup,\n    bars,\n    conditionalFormattingRules,\n    enableHover,\n    labelStyle,\n    onClick,\n    showDetailedSubGroupingLabels,\n    yAxisLabels,\n    yLabelPosition,\n}: BarProps) => {\n    const showBar = bar.value !== null && bar.height > 0 && bar.width > 0;\n\n    return (\n        <Fragment>\n            {showBar && <BarRect\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            <BarLabel\n                bar={bar}\n                barGroup={barGroup}\n                yLabelPosition={yLabelPosition}\n                yAxisLabels={yAxisLabels}\n                showDetailedSubGroupingLabels={showDetailedSubGroupingLabels}\n                labelStyle={labelStyle}\n            />\n        </Fragment>\n    );\n};\n\ntype BarRectProps = {\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\nconst BarRect = ({\n    onClick,\n    fill,\n    x,\n    y,\n    width,\n    height,\n    key,\n    enableHover,\n}: BarRectProps) => {\n    const [fillColor, setFillColor] = useState(fill);\n\n    const classes = enableHover ? css({ cursor: 'pointer' }) : '';\n\n    const handleOnMouseEnter = () => {\n        if (enableHover) {\n            setFillColor(lightenColor(fill, 0.8));\n        }\n    }\n\n    const handleOnMouseLeave = () => {\n        if (enableHover) {\n            setFillColor(fill);\n        }\n    }\n\n    return (\n        <rect\n            key={key}\n            x={x}\n            y={y}\n            width={width}\n            height={height}\n            fill={fillColor}\n            rx={BAR_RADIUS}\n            onClick={onClick}\n            onMouseEnter={handleOnMouseEnter}\n            onMouseLeave={handleOnMouseLeave}\n            className={classes}\n        />\n    );\n};\n\ntype BarLabelProps = {\n    bar: any;\n    barGroup: any;\n    yLabelPosition?: number;\n    yAxisLabels?: string[];\n    showDetailedSubGroupingLabels: boolean;\n    labelStyle?: React.CSSProperties;\n};\n\nconst BarLabel = ({\n    bar,\n    barGroup,\n    yLabelPosition,\n    yAxisLabels,\n    showDetailedSubGroupingLabels,\n    labelStyle,\n}: BarLabelProps) => {\n    if (!showDetailedSubGroupingLabels || !yLabelPosition || !yAxisLabels) return null;\n\n    const label = yAxisLabels[bar.index];\n    const columnLabel = label.split('•')[0];\n\n    let formattedColumnLabel: string;\n    if (columnLabel.length >= 13) {\n        formattedColumnLabel = columnLabel.slice(0, 10) + '...';\n    } else {\n        formattedColumnLabel = columnLabel.slice(0, 13);\n    }\n\n    const labelXGap = 4;\n    const labelXPosition = bar.x + (bar.width / 2) + labelXGap;\n\n    const labelYGap = 15;\n    const labelYPosition = yLabelPosition + labelYGap;\n\n    const labelKey = `label-${barGroup.index}-${bar.index}-${label}`;\n\n    return <text\n        key={labelKey}\n        x={labelXPosition}\n        y={labelYPosition}\n        style={labelStyle}\n        transform={`rotate(-70, ${labelXPosition}, ${labelYPosition})`}\n        textAnchor='end'\n    >\n        {formattedColumnLabel}\n    </text>\n}"]} */",
44627
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["BarGroup.tsx"],"names":[],"mappings":"AA4KgC","file":"BarGroup.tsx","sourcesContent":["import { css } from '@emotion/css';\nimport { Group } from '@visx/group';\nimport { BarGroup as VisxBarGroup } from '@visx/shape';\nimport { DatumObject } from '@visx/shape/lib/types';\nimport { ScaleBand, ScaleLinear } from '@visx/vendor/d3-scale';\nimport { Fragment, useState } from 'react';\nimport { BarStyles } from 'shared-logic/src/BarChartV2/types';\nimport { ChartDataDefinition, ConditionalFormattingRule, ShapeDefinition } from 'shared-logic/src/ChartsV2/types';\nimport { DataType } from 'shared-logic/src/Field/types';\nimport { lightenColor } from '../../../styles/color.functions';\nimport { BAR_RADIUS } from '../../constants/BORDER_RADIUS';\nimport { getBarFill } from '../getBarFill';\n\nexport type BarGroupProps = {\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  yAxisLabels?: string[];\n  yLabelPosition?: number;\n  showDetailedSubGroupingLabels: boolean;\n  labelStyle?: React.CSSProperties;\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  yAxisLabels,\n  yLabelPosition,\n  showDetailedSubGroupingLabels,\n  labelStyle,\n}: BarGroupProps) {\n  const getGroupPosition = (d: DatumObject) => {\n    const xValue = d[xKey as keyof typeof d];\n\n    if (xScaleDataType === 'string') return String(xValue);\n\n    if (xScaleDataType === 'date_time') {\n      return new Date(String(xValue));\n    }\n\n    if (xScaleDataType === 'number') {\n      return Number(xValue);\n    }\n\n    return String(xValue);\n  };\n\n  return (\n    <VisxBarGroup<DatumObject>\n      data={data as DatumObject[]}\n      keys={keys}\n      height={height}\n      x0={getGroupPosition}\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              <Bar\n                key={`bar-${bar.index}-${bar.x}`}\n                bar={bar}\n                barGroup={barGroup}\n                bars={bars}\n                conditionalFormattingRules={conditionalFormattingRules}\n                enableHover={enableHover}\n                labelStyle={labelStyle}\n                onClick={onClick}\n                showDetailedSubGroupingLabels={showDetailedSubGroupingLabels}\n                yAxisLabels={yAxisLabels}\n                yLabelPosition={yLabelPosition}\n              />\n            ))}\n          </Group>\n        ));\n      }}\n    </VisxBarGroup>\n  );\n}\n\ntype BarProps = {\n  bar: any;\n  barGroup: any;\n  bars: ShapeDefinition<BarStyles>[];\n  conditionalFormattingRules: ConditionalFormattingRule[];\n  enableHover?: boolean;\n  onClick: (e: React.MouseEvent<SVGRectElement, MouseEvent>, barGroup: any, bar: any) => void;\n  showDetailedSubGroupingLabels: boolean;\n  labelStyle?: React.CSSProperties;\n  yAxisLabels?: string[];\n  yLabelPosition?: number;\n};\n\nconst Bar = ({\n  bar,\n  barGroup,\n  bars,\n  conditionalFormattingRules,\n  enableHover,\n  labelStyle,\n  onClick,\n  showDetailedSubGroupingLabels,\n  yAxisLabels,\n  yLabelPosition,\n}: BarProps) => {\n  const showBar = bar.value !== null && bar.height > 0 && bar.width > 0;\n\n  return (\n    <Fragment>\n      {showBar && (\n        <BarRect\n          barRectKey={`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      <BarLabel\n        bar={bar}\n        barGroup={barGroup}\n        yLabelPosition={yLabelPosition}\n        yAxisLabels={yAxisLabels}\n        showDetailedSubGroupingLabels={showDetailedSubGroupingLabels}\n        labelStyle={labelStyle}\n      />\n    </Fragment>\n  );\n};\n\ntype BarRectProps = {\n  onClick: (e: React.MouseEvent<SVGRectElement, MouseEvent>) => void;\n  fill?: string;\n  x: number;\n  y: number;\n  width: number;\n  height: number;\n  barRectKey: string;\n  enableHover?: boolean;\n};\n\nconst BarRect = ({ onClick, fill, x, y, width, height, barRectKey, enableHover }: BarRectProps) => {\n  const [fillColor, setFillColor] = useState(fill);\n\n  const classes = enableHover ? css({ cursor: 'pointer' }) : '';\n\n  const handleOnMouseEnter = () => {\n    if (enableHover) {\n      setFillColor(lightenColor(fill, 0.8));\n    }\n  };\n\n  const handleOnMouseLeave = () => {\n    if (enableHover) {\n      setFillColor(fill);\n    }\n  };\n\n  return (\n    <rect\n      key={barRectKey}\n      x={x}\n      y={y}\n      width={width}\n      height={height}\n      fill={fillColor}\n      rx={BAR_RADIUS}\n      onClick={onClick}\n      onMouseEnter={handleOnMouseEnter}\n      onMouseLeave={handleOnMouseLeave}\n      className={classes}\n    />\n  );\n};\n\ntype BarLabelProps = {\n  bar: any;\n  barGroup: any;\n  yLabelPosition?: number;\n  yAxisLabels?: string[];\n  showDetailedSubGroupingLabels: boolean;\n  labelStyle?: React.CSSProperties;\n};\n\nconst BarLabel = ({\n  bar,\n  barGroup,\n  yLabelPosition,\n  yAxisLabels,\n  showDetailedSubGroupingLabels,\n  labelStyle,\n}: BarLabelProps) => {\n  if (!showDetailedSubGroupingLabels || !yLabelPosition || !yAxisLabels) return null;\n\n  const label = yAxisLabels[bar.index];\n  const columnLabel = label.split('•')[0];\n\n  let formattedColumnLabel: string;\n  if (columnLabel.length >= 13) {\n    formattedColumnLabel = columnLabel.slice(0, 10) + '...';\n  } else {\n    formattedColumnLabel = columnLabel.slice(0, 13);\n  }\n\n  const labelXGap = 4;\n  const labelXPosition = bar.x + bar.width / 2 + labelXGap;\n\n  const labelYGap = 15;\n  const labelYPosition = yLabelPosition + labelYGap;\n\n  const labelKey = `label-${barGroup.index}-${bar.index}-${label}`;\n\n  return (\n    <text\n      key={labelKey}\n      x={labelXPosition}\n      y={labelYPosition}\n      style={labelStyle}\n      transform={`rotate(-70, ${labelXPosition}, ${labelYPosition})`}\n      textAnchor=\"end\"\n    >\n      {formattedColumnLabel}\n    </text>\n  );\n};\n"]} */",
44734
44628
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$9
44735
44629
  }) : '';
44736
44630
  var handleOnMouseEnter = function handleOnMouseEnter() {
@@ -44754,7 +44648,7 @@ var BarRect = function BarRect(_ref3) {
44754
44648
  onMouseEnter: handleOnMouseEnter,
44755
44649
  onMouseLeave: handleOnMouseLeave,
44756
44650
  className: classes
44757
- }, key);
44651
+ }, barRectKey);
44758
44652
  };
44759
44653
  var BarLabel = function BarLabel(_ref4) {
44760
44654
  var bar = _ref4.bar,
@@ -44787,6 +44681,124 @@ var BarLabel = function BarLabel(_ref4) {
44787
44681
  }, labelKey);
44788
44682
  };
44789
44683
 
44684
+ var BarStacked = function BarStacked(_ref) {
44685
+ var xScaleDataType = _ref.xScaleDataType,
44686
+ data = _ref.data,
44687
+ xScaleKey = _ref.xScaleKey,
44688
+ yScale = _ref.yScale,
44689
+ keys = _ref.keys,
44690
+ bars = _ref.bars,
44691
+ conditionalFormattingRules = _ref.conditionalFormattingRules,
44692
+ xScale = _ref.xScale,
44693
+ height = _ref.height,
44694
+ width = _ref.width;
44695
+ var handleGetXValue = function handleGetXValue(d) {
44696
+ var xValue = d[xScaleKey];
44697
+ if (xScaleDataType === 'string') return String(xValue);
44698
+ if (xScaleDataType === 'date_time') {
44699
+ return new Date(xValue);
44700
+ }
44701
+ if (xScaleDataType === 'number') {
44702
+ return Number(xValue);
44703
+ }
44704
+ return String(xValue);
44705
+ };
44706
+ return jsxRuntime.jsx(shape.BarStack, {
44707
+ x: handleGetXValue,
44708
+ xScale: xScale,
44709
+ yScale: yScale,
44710
+ data: data,
44711
+ keys: keys,
44712
+ color: function color() {
44713
+ return '';
44714
+ },
44715
+ height: height,
44716
+ width: width,
44717
+ offset: "none",
44718
+ children: function children(barStacks) {
44719
+ return barStacks.map(function (barStack) {
44720
+ return barStack.bars.map(function (bar) {
44721
+ return jsxRuntime.jsx(Bar$1, {
44722
+ bar: bar,
44723
+ barStack: barStack,
44724
+ bars: bars,
44725
+ conditionalFormattingRules: conditionalFormattingRules
44726
+ }, bar.key.toString() + "-" + bar.index + "-" + bar.x);
44727
+ });
44728
+ });
44729
+ }
44730
+ });
44731
+ };
44732
+ var Bar$1 = function Bar(_ref2) {
44733
+ var bar = _ref2.bar,
44734
+ barStack = _ref2.barStack,
44735
+ bars = _ref2.bars,
44736
+ conditionalFormattingRules = _ref2.conditionalFormattingRules;
44737
+ var BAR_PADDING = 1.5;
44738
+ if (bar.height < 3) return null;
44739
+ return jsxRuntime.jsx("rect", {
44740
+ x: bar.x,
44741
+ y: bar.y,
44742
+ width: bar.width,
44743
+ height: bar.height - BAR_PADDING,
44744
+ fill: getBarFill(bars, conditionalFormattingRules, bar.key, bar.bar.data),
44745
+ rx: BAR_RADIUS
44746
+ }, "bar-stack-" + barStack.index + "-" + bar.index);
44747
+ };
44748
+
44749
+ var useBottomAxisBaseLineShift = function useBottomAxisBaseLineShift(_ref) {
44750
+ var showDetailedSubGroupingLabels = _ref.showDetailedSubGroupingLabels,
44751
+ hasBottomTitle = _ref.hasBottomTitle,
44752
+ hasLeftTitle = _ref.hasLeftTitle;
44753
+ if (!showDetailedSubGroupingLabels) {
44754
+ return {
44755
+ bottomAxisBaselineShift: 0,
44756
+ bottomOffset: 0,
44757
+ leftOffset: 0
44758
+ };
44759
+ }
44760
+ return {
44761
+ bottomAxisBaselineShift: hasBottomTitle ? -65 : -60,
44762
+ bottomOffset: hasBottomTitle ? -15 : 10,
44763
+ leftOffset: hasLeftTitle ? -10 : 0
44764
+ };
44765
+ };
44766
+
44767
+ var PADDING = {
44768
+ paddingOuter: 0.05,
44769
+ paddingInner: 0.3
44770
+ };
44771
+
44772
+ function useBarXScale(xScaleDataType, innerWidth, xScaleKey, data) {
44773
+ return React.useMemo(function () {
44774
+ if (xScaleDataType === 'string') {
44775
+ return scale.scaleBand(_extends({
44776
+ range: [0, innerWidth],
44777
+ domain: xScaleKey ? [].concat(data.map(function (d) {
44778
+ return d[xScaleKey] && d[xScaleKey].value !== null ? String(d[xScaleKey].value) : '';
44779
+ })) : []
44780
+ }, PADDING));
44781
+ }
44782
+ if (xScaleDataType === 'date_time' && xScaleKey) {
44783
+ return scale.scaleBand(_extends({
44784
+ range: [0, innerWidth],
44785
+ domain: data.map(function (d) {
44786
+ return new Date(d[xScaleKey].value);
44787
+ })
44788
+ }, PADDING));
44789
+ }
44790
+ if (xScaleDataType === 'number' && xScaleKey) {
44791
+ return scale.scaleBand(_extends({
44792
+ range: [0, innerWidth],
44793
+ domain: data.map(function (d) {
44794
+ return d[xScaleKey] && d[xScaleKey].value !== null ? Number(d[xScaleKey].value) : 0;
44795
+ })
44796
+ }, PADDING));
44797
+ }
44798
+ return null;
44799
+ }, [innerWidth, data]);
44800
+ }
44801
+
44790
44802
  var BarChart$5 = function BarChart(_ref) {
44791
44803
  var _theme$axis;
44792
44804
  var chart = _ref.chart,
@@ -44808,7 +44820,7 @@ var BarChart$5 = function BarChart(_ref) {
44808
44820
  tooltipData = _useTooltip.tooltipData,
44809
44821
  hideTooltip = _useTooltip.hideTooltip,
44810
44822
  showTooltip = _useTooltip.showTooltip;
44811
- var showDetailedSubGroupingLabels = numberOfDimensions === 2 && width > 450;
44823
+ var showDetailedSubGroupingLabels = !options.stacked && numberOfDimensions === 2 && width > 450;
44812
44824
  var hasBottomTitle = chart.x.title != null;
44813
44825
  var hasLeftTitle = chart.y.title != null;
44814
44826
  var _useBottomAxisBaseLin = useBottomAxisBaseLineShift({
@@ -44821,7 +44833,7 @@ var BarChart$5 = function BarChart(_ref) {
44821
44833
  leftOffset = _useBottomAxisBaseLin.leftOffset;
44822
44834
  var margin = buildMargin(chart.y.ticks, options.axis.showYAxisLabels, hasLeftTitle, hasBottomTitle, showDetailedSubGroupingLabels);
44823
44835
  var innerWidth = width - margin.left - margin.right;
44824
- var innerHeight = height - margin.top - margin.bottom - (options.showLegend ? 50 : 0) - (showDetailedSubGroupingLabels ? 50 : 0);
44836
+ var innerHeight = height - margin.top - margin.bottom - (options.showLegend ? 50 : 0) - (showDetailedSubGroupingLabels ? 50 : 0) + (options.axis.showXAxisLabels ? 0 : 25);
44825
44837
  var xKey = chart.x.key;
44826
44838
  var xScaleKey = chart.x.scale.key;
44827
44839
  var xScaleDataType = chart.x.scale.dataType;
@@ -45415,6 +45427,7 @@ function Area(_ref3) {
45415
45427
  });
45416
45428
  }
45417
45429
 
45430
+ var MAX_BUBBLE_RADIUS = 30;
45418
45431
  var BubbleChart$4 = function BubbleChart(_ref) {
45419
45432
  var _theme$axis;
45420
45433
  var chart = _ref.chart,
@@ -45436,25 +45449,34 @@ var BubbleChart$4 = function BubbleChart(_ref) {
45436
45449
  var zValues = chart.z ? chart.data.map(function (d) {
45437
45450
  return d[chart.z];
45438
45451
  }).map(function (d) {
45439
- return d.value;
45452
+ return d == null ? void 0 : d.value;
45440
45453
  }) : [];
45441
45454
  var normaliseArray = function normaliseArray(array, min, max) {
45442
45455
  var arrayMin = Math.min.apply(Math, array);
45443
45456
  var arrayMax = Math.max.apply(Math, array);
45457
+ if (arrayMin === arrayMax) {
45458
+ return array.map(function () {
45459
+ return min;
45460
+ });
45461
+ }
45444
45462
  return array.map(function (value) {
45445
45463
  return (value - arrayMin) / (arrayMax - arrayMin) * (max - min) + min;
45446
45464
  });
45447
45465
  };
45448
- var scaledSizeValues = normaliseArray(zValues, 5, 30);
45466
+ var scaledSizeValues = normaliseArray(zValues, 5, MAX_BUBBLE_RADIUS);
45449
45467
  var margin = buildMargin(chart.y.ticks, options.axis.showYAxisLabels, chart.y.title != null, chart.x.title != null);
45450
45468
  var _useState = React.useState(chart.lines.map(function (legendItem) {
45451
45469
  return legendItem.yKey;
45470
+ }).filter(function (yKey) {
45471
+ return yKey !== chart.groupByKey;
45452
45472
  })),
45453
45473
  visibleYKeys = _useState[0],
45454
45474
  setVisibleYKeys = _useState[1];
45455
45475
  React.useEffect(function () {
45456
45476
  setVisibleYKeys(chart.lines.map(function (legendItem) {
45457
45477
  return legendItem.yKey;
45478
+ }).filter(function (yKey) {
45479
+ return yKey !== chart.groupByKey;
45458
45480
  }));
45459
45481
  return function () {
45460
45482
  setVisibleYKeys([]);
@@ -45480,13 +45502,13 @@ var BubbleChart$4 = function BubbleChart(_ref) {
45480
45502
  if (xScaleDataType === 'date_time') {
45481
45503
  return scale.scaleTime({
45482
45504
  range: [0, innerWidth],
45483
- domain: chart.x.scale.ordering === 'asc' ? [chart.x.scale.min, chart.x.scale.max] : [chart.x.scale.max, chart.x.scale.min]
45505
+ domain: chart.x.scale.ordering === 'desc' ? [chart.x.scale.max, chart.x.scale.min] : [chart.x.scale.min, chart.x.scale.max]
45484
45506
  });
45485
45507
  }
45486
45508
  if (xScaleDataType === 'number') {
45487
45509
  return scale.scaleLinear({
45488
45510
  range: [0, innerWidth],
45489
- domain: chart.x.scale.ordering === 'asc' ? [chart.x.scale.min, chart.x.scale.max] : [chart.x.scale.max, chart.x.scale.min],
45511
+ domain: chart.x.scale.ordering === 'desc' ? [chart.x.scale.max, chart.x.scale.min] : [chart.x.scale.min, chart.x.scale.max],
45490
45512
  nice: true
45491
45513
  });
45492
45514
  }
@@ -45525,11 +45547,18 @@ var BubbleChart$4 = function BubbleChart(_ref) {
45525
45547
  var yTickValues = chart.y.ticks.map(function (tick) {
45526
45548
  return Number(tick.value);
45527
45549
  });
45528
- var legendTooltipItems = [{
45550
+ var tooltipItems = [{
45529
45551
  legendItems: chart.lines,
45530
45552
  visibleYKeys: visibleYKeys,
45531
45553
  conditionalFormattingRules: chart.conditionalFormattingRules
45532
45554
  }];
45555
+ var legendItems = chart.legend.items.map(function (legendItem) {
45556
+ return {
45557
+ legendItems: [legendItem],
45558
+ visibleYKeys: [legendItem.yKey],
45559
+ conditionalFormattingRules: chart.conditionalFormattingRules
45560
+ };
45561
+ });
45533
45562
  return jsxRuntime.jsxs(React__default.Fragment, {
45534
45563
  children: [jsxRuntime.jsxs(ChartWrapper$1, {
45535
45564
  width: width,
@@ -45607,20 +45636,20 @@ var BubbleChart$4 = function BubbleChart(_ref) {
45607
45636
  width: innerWidth
45608
45637
  })]
45609
45638
  }), options.showLegend && jsxRuntime.jsx(Legend$1, {
45610
- items: legendTooltipItems,
45611
- setVisibleYKeys: setVisibleYKeys,
45612
- keys: chart.keys,
45639
+ items: legendItems,
45640
+ keys: chart.legend.keys,
45613
45641
  marginLeft: margin.left - margin.leftTitleOffset
45614
45642
  }), tooltipOpen && tooltipData && xKey && jsxRuntime.jsx(Tooltip$1, {
45615
- items: legendTooltipItems,
45643
+ items: tooltipItems,
45616
45644
  tooltipData: tooltipData,
45617
45645
  tooltipLeft: tooltipLeft,
45618
45646
  tooltipTop: tooltipTop,
45619
- xKey: xKey,
45647
+ xKey: chart.groupByKey,
45620
45648
  keys: chart.keys,
45621
45649
  yKeys: chart.y.keys,
45622
45650
  showRoundedTotal: options.showRoundedTotal,
45623
- theme: themeCSS.popoverMenus
45651
+ theme: themeCSS.popoverMenus,
45652
+ shouldShowColorLegend: false
45624
45653
  })]
45625
45654
  });
45626
45655
  };
@@ -45631,6 +45660,9 @@ function Bubbles(_ref2) {
45631
45660
  xScale = _ref2.xScale,
45632
45661
  yScale = _ref2.yScale,
45633
45662
  chart = _ref2.chart;
45663
+ var getBubbleColor = function getBubbleColor(index) {
45664
+ return chart.legend.items[index % chart.legend.items.length].color;
45665
+ };
45634
45666
  return jsxRuntime.jsx(React.Fragment, {
45635
45667
  children: data.map(function (d, index) {
45636
45668
  var _ref3, _yScale2;
@@ -45638,10 +45670,7 @@ function Bubbles(_ref2) {
45638
45670
  r: d.bubbleSize,
45639
45671
  cx: (_ref3 = xScale(d[xScaleKey])) != null ? _ref3 : 0,
45640
45672
  cy: (_yScale2 = yScale(d[yKeys[0]])) != null ? _yScale2 : 0,
45641
- fill: chart.lines[0].color,
45642
- style: {
45643
- zIndex: -d.bubbleSize
45644
- }
45673
+ fill: getBubbleColor(index)
45645
45674
  }, "bubble_chart_" + index);
45646
45675
  })
45647
45676
  });
@@ -45916,6 +45945,21 @@ var RadarChart$2 = function RadarChart(_ref) {
45916
45945
  });
45917
45946
  };
45918
45947
 
45948
+ var init$d = function init(xMeasure, yMeasure) {
45949
+ return {
45950
+ x: xMeasure.map(function (measure) {
45951
+ return id(measure);
45952
+ }),
45953
+ y: yMeasure.map(function (measure) {
45954
+ return id(measure);
45955
+ }),
45956
+ detailed: {
45957
+ x: xMeasure,
45958
+ y: yMeasure
45959
+ }
45960
+ };
45961
+ };
45962
+
45919
45963
  var getStyleDefinition = function getStyleDefinition(_ref) {
45920
45964
  var colors = _ref.colors,
45921
45965
  yKeys = _ref.yKeys;
@@ -45994,7 +46038,7 @@ var getScaleAndTicks = function getScaleAndTicks(_ref) {
45994
46038
  yKeys = _ref.yKeys,
45995
46039
  xScaleDataType = _ref.xScaleDataType,
45996
46040
  nullValue = _ref.nullValue,
45997
- tickCountYAxis = _ref.tickCountYAxis,
46041
+ approxYAxisLabelCount = _ref.approxYAxisLabelCount,
45998
46042
  formattingFunctionX = _ref.formattingFunctionX,
45999
46043
  formattingFunctionY = _ref.formattingFunctionY,
46000
46044
  order = _ref.order,
@@ -46011,32 +46055,18 @@ var getScaleAndTicks = function getScaleAndTicks(_ref) {
46011
46055
  keys: xScale.key === null ? [] : [xScale.key],
46012
46056
  dataType: xScale.dataType
46013
46057
  });
46014
- if (xKey) {
46015
- xTicks = data.map(function (dataItem) {
46016
- var _dataItem$xKey, _dataItem$xScale$key, _dataItem$xScale$key2;
46017
- var xValue = (_dataItem$xKey = dataItem[xKey]) != null && _dataItem$xKey.value ? dataItem[xKey].value : null;
46018
- var xformattedValue = formattingFunctionX(xValue, nullValue);
46019
- var xScaleValue = xScale.key !== null && (_dataItem$xScale$key = dataItem[xScale.key]) != null && _dataItem$xScale$key.value ? (_dataItem$xScale$key2 = dataItem[xScale.key]) == null ? void 0 : _dataItem$xScale$key2.value : '';
46020
- var xScaleValueAdjusted = xScale.dataType === 'date_time' ? new Date(xScaleValue) : xScale.dataType === 'string' ? String(xScaleValue) : xScale.dataType === 'number' ? Number(xScaleValue) : xScaleValue;
46021
- return {
46022
- value: xValue !== null ? xValue : '',
46023
- formattedValue: xformattedValue !== null ? "" + xformattedValue : null,
46024
- scaleValue: xScaleValueAdjusted
46025
- };
46026
- });
46027
- }
46028
- // ----- Y Axis ("number") -----
46029
-
46030
46058
  var y = getMinAndMax({
46031
46059
  data: data,
46032
46060
  keys: yKeys,
46033
46061
  dataType: 'number',
46034
46062
  goalLines: goalLines
46035
46063
  });
46036
- var maxY = y.max || 0;
46064
+ var maxY = y.max ? y.max * 1.1 : y.max || 1;
46037
46065
  var minY = Math.min(y.min || 0, 0);
46066
+ var tickCountYAxis = approxYAxisLabelCount === 'auto' ? 10 : approxYAxisLabelCount;
46038
46067
  var yTickInterval = getNiceInterval((maxY - minY) / (tickCountYAxis - 1));
46039
- for (var i = 0; i < tickCountYAxis; i++) {
46068
+ var i = 0;
46069
+ while (yTickInterval * i <= maxY + yTickInterval) {
46040
46070
  var _value = yTickInterval * i;
46041
46071
  var formattedValue = formattingFunctionY(_value, nullValue);
46042
46072
  yTicks.push({
@@ -46044,14 +46074,29 @@ var getScaleAndTicks = function getScaleAndTicks(_ref) {
46044
46074
  formattedValue: formattedValue,
46045
46075
  scaleValue: _value
46046
46076
  });
46077
+ i++;
46078
+ }
46079
+ var maxX = x.max ? x.max * 1.05 : x.max || 1;
46080
+ var minX = Math.min(x.min || 0, 0);
46081
+ var xTickInterval = getNiceInterval((maxX - minX) / (10 - 1));
46082
+ i = 0;
46083
+ while (xTickInterval * i <= maxX + xTickInterval) {
46084
+ var _value2 = xTickInterval * i;
46085
+ var _formattedValue = formattingFunctionX(_value2, nullValue);
46086
+ xTicks.push({
46087
+ value: _value2,
46088
+ formattedValue: _formattedValue,
46089
+ scaleValue: _value2
46090
+ });
46091
+ i++;
46047
46092
  }
46048
46093
  return {
46049
46094
  x: {
46050
46095
  ticks: xTicks,
46051
46096
  scale: {
46052
46097
  dataType: xScale.dataType,
46053
- max: x.max,
46054
- min: x.min,
46098
+ max: maxX,
46099
+ min: minX,
46055
46100
  key: xScale.key,
46056
46101
  ordering: xScale.ordering
46057
46102
  }
@@ -46060,7 +46105,7 @@ var getScaleAndTicks = function getScaleAndTicks(_ref) {
46060
46105
  ticks: yTicks,
46061
46106
  scale: {
46062
46107
  dataType: 'number',
46063
- key: null,
46108
+ key: yKeys[0],
46064
46109
  ordering: 'asc',
46065
46110
  max: maxY,
46066
46111
  min: minY
@@ -46098,223 +46143,6 @@ var getGoalLines = function getGoalLines(_ref) {
46098
46143
  });
46099
46144
  };
46100
46145
 
46101
- var buildTrendAndForecast = function buildTrendAndForecast(_ref) {
46102
- var data = _ref.data,
46103
- forecastUnits = _ref.forecastUnits,
46104
- xKey = _ref.xKey,
46105
- yKey = _ref.yKey,
46106
- timeUnit = _ref.timeUnit,
46107
- includeForecast = _ref.includeForecast;
46108
- var forecastKey = yKey + "_forecast";
46109
- var trendKey = yKey + "_trend";
46110
- var trendData = [];
46111
- var forecastData = [];
46112
- var values = data.map(function (point) {
46113
- return Number(point[yKey].value);
46114
- });
46115
- var dates = data.map(function (point) {
46116
- return new Date(point[xKey].value);
46117
- });
46118
- var n = values.length;
46119
- var daysSinceStart = dates.map(function (date) {
46120
- return (date.getTime() - dates[0].getTime()) / 86400000;
46121
- });
46122
- var meanX = daysSinceStart.reduce(function (a, b) {
46123
- return a + b;
46124
- }, 0) / n;
46125
- var meanY = values.reduce(function (a, b) {
46126
- return a + b;
46127
- }, 0) / n;
46128
- var numerator = 0,
46129
- denominator = 0;
46130
- for (var i = 0; i < n; i++) {
46131
- numerator += (daysSinceStart[i] - meanX) * (values[i] - meanY);
46132
- denominator += Math.pow(daysSinceStart[i] - meanX, 2);
46133
- }
46134
- var slope = numerator / denominator;
46135
- var intercept = meanY - slope * meanX;
46136
- var forecastDate = new Date(dates[n - 1]); // Start from the last date in the data
46137
-
46138
- for (var _i = 0; _i < n + (includeForecast ? forecastUnits : 0); _i++) {
46139
- var x = void 0;
46140
- if (_i < n) {
46141
- // Use existing dates for current trend values
46142
- x = dates[_i];
46143
- } else if (includeForecast) {
46144
- // Generate future dates for forecast values if includeForecast is true
46145
- switch (timeUnit) {
46146
- case 'week':
46147
- forecastDate.setDate(forecastDate.getDate() + 7);
46148
- break;
46149
- case 'month':
46150
- forecastDate.setMonth(forecastDate.getMonth() + 1);
46151
- break;
46152
- case 'quarter':
46153
- forecastDate.setMonth(forecastDate.getMonth() + 3);
46154
- break;
46155
- case 'year':
46156
- forecastDate.setFullYear(forecastDate.getFullYear() + 1);
46157
- break;
46158
- }
46159
- x = new Date(forecastDate);
46160
- } else {
46161
- continue; // Skip this iteration if forecasting is not included
46162
- }
46163
- var dayCount = (x.getTime() - dates[0].getTime()) / 86400000; // 1 day in milliseconds
46164
- var forecastedValue = slope * dayCount + intercept;
46165
- var currentValue = slope * dayCount + intercept;
46166
- if (_i >= n - 1) {
46167
- if (_i === n - 1) {
46168
- trendData.push({
46169
- date: x.toISOString(),
46170
- value: parseFloat(currentValue.toFixed(2))
46171
- });
46172
- }
46173
- if (includeForecast) {
46174
- forecastData.push({
46175
- date: x.toISOString(),
46176
- value: parseFloat(forecastedValue.toFixed(2))
46177
- });
46178
- }
46179
- } else {
46180
- trendData.push({
46181
- date: x.toISOString(),
46182
- value: parseFloat(currentValue.toFixed(2))
46183
- });
46184
- }
46185
- }
46186
- return {
46187
- trendData: trendData,
46188
- trendKey: trendKey,
46189
- forecastData: forecastData,
46190
- forecastKey: forecastKey
46191
- };
46192
- };
46193
-
46194
- var getTrendsAndForecastsData = function getTrendsAndForecastsData(_ref) {
46195
- var _trendsAndForecasts$;
46196
- var chartData = _ref.chartData,
46197
- formattingFunctionX = _ref.formattingFunctionX,
46198
- formattingFunctionY = _ref.formattingFunctionY,
46199
- keys = _ref.keys,
46200
- nullValue = _ref.nullValue,
46201
- orderFunction = _ref.orderFunction,
46202
- trendsAndForecasts = _ref.trendsAndForecasts,
46203
- xAxisPostfix = _ref.xAxisPostfix,
46204
- xAxisPrefix = _ref.xAxisPrefix,
46205
- xKey = _ref.xKey,
46206
- xScaleDataType = _ref.xScaleDataType,
46207
- yAxisPostfix = _ref.yAxisPostfix,
46208
- yAxisPrefix = _ref.yAxisPrefix,
46209
- yKeys = _ref.yKeys;
46210
- if (!trendsAndForecasts || trendsAndForecasts.length === 0 || xScaleDataType !== 'date_time') return {
46211
- chartData: chartData
46212
- };
46213
- if (!orderFunction || !['week', 'month', 'quarter', 'year'].includes(orderFunction)) return {
46214
- chartData: chartData
46215
- };
46216
-
46217
- // ----- Technically we should do a loop here but at the moment we'll only have one trend/forecast so use trendsAndForecasts[0] -----
46218
-
46219
- var includeForecast = trendsAndForecasts[0].type === 'Forecast';
46220
- var forecastUnits = trendsAndForecasts[0].type === 'Forecast' ? (_trendsAndForecasts$ = trendsAndForecasts[0].value) != null ? _trendsAndForecasts$ : 0 : 0;
46221
- var yKey = yKeys[0];
46222
- var newKeys = _.cloneDeep(keys);
46223
- var _buildTrendAndForecas = buildTrendAndForecast({
46224
- data: chartData,
46225
- forecastUnits: forecastUnits,
46226
- xKey: xKey,
46227
- yKey: yKey,
46228
- timeUnit: orderFunction,
46229
- includeForecast: includeForecast
46230
- }),
46231
- trendData = _buildTrendAndForecas.trendData,
46232
- trendKey = _buildTrendAndForecas.trendKey,
46233
- forecastData = _buildTrendAndForecas.forecastData,
46234
- forecastKey = _buildTrendAndForecas.forecastKey;
46235
-
46236
- // ----- Add Trend To Existing Data Array And Trend Key -----
46237
-
46238
- var newData = chartData.map(function (dataItem) {
46239
- var date = dataItem[xKey].value;
46240
- var trend = trendData.find(function (trendItem) {
46241
- return trendItem.date === date;
46242
- });
46243
- if (trend) {
46244
- var trendDataItem = {
46245
- value: trend.value,
46246
- formattedValue: "" + yAxisPrefix + formattingFunctionY(trend.value, nullValue) + yAxisPostfix
46247
- };
46248
- if (includeForecast && forecastData.length > 0) {
46249
- var _extends2;
46250
- return _extends({}, dataItem, (_extends2 = {}, _extends2[trendKey] = trendDataItem, _extends2[forecastKey] = {
46251
- value: null,
46252
- formattedValue: null
46253
- }, _extends2));
46254
- } else {
46255
- var _extends3;
46256
- return _extends({}, dataItem, (_extends3 = {}, _extends3[trendKey] = trendDataItem, _extends3));
46257
- }
46258
- }
46259
- return null;
46260
- });
46261
-
46262
- // ----- Add New Array Items For Forecast & Forecast Key -----
46263
-
46264
- if (includeForecast && forecastData.length > 0) {
46265
- var _loop = function _loop() {
46266
- var _forecastIncrement;
46267
- var forecastDataItem = forecastData[index];
46268
- var forecastIncrement = (_forecastIncrement = {}, _forecastIncrement[xKey] = {
46269
- value: forecastDataItem.date,
46270
- formattedValue: "" + xAxisPrefix + formattingFunctionX(forecastDataItem.date, nullValue) + xAxisPostfix
46271
- }, _forecastIncrement[trendKey] = {
46272
- value: null,
46273
- formattedValue: null
46274
- }, _forecastIncrement[forecastKey] = {
46275
- value: forecastDataItem.value,
46276
- formattedValue: "" + yAxisPrefix + formattingFunctionY(forecastDataItem.value, nullValue) + yAxisPostfix
46277
- }, _forecastIncrement);
46278
- yKeys.forEach(function (key) {
46279
- forecastIncrement[key] = {
46280
- value: null,
46281
- formattedValue: null
46282
- };
46283
- });
46284
- newData.push(forecastIncrement);
46285
- };
46286
- for (var index = 0; index < forecastUnits; index++) {
46287
- _loop();
46288
- }
46289
- }
46290
-
46291
- // ----- Update Keys -----
46292
-
46293
- var newYKeys = includeForecast && forecastData.length > 0 ? [].concat(yKeys, [trendKey, forecastKey]) : [].concat(yKeys, [trendKey]);
46294
- newKeys[trendKey] = {
46295
- key: trendKey,
46296
- keyFormatted: newKeys[yKey].keyFormatted + " \u2022 Trend",
46297
- dataType: 'number'
46298
- };
46299
- if (includeForecast && forecastData.length > 0) {
46300
- newKeys[forecastKey] = {
46301
- key: forecastKey,
46302
- keyFormatted: newKeys[yKey].keyFormatted + " \u2022 Forecast",
46303
- dataType: 'number'
46304
- };
46305
- }
46306
-
46307
- // ----- Create style definitions for trend and forecast in the form of legend items to append to getStyleDefinition() -----
46308
-
46309
- // TODO
46310
-
46311
- return {
46312
- newChartData: newData,
46313
- newYKeys: newYKeys,
46314
- newKeys: newKeys
46315
- };
46316
- };
46317
-
46318
46146
  /**
46319
46147
  * When provided with a result, and formatting parameters, it returns a
46320
46148
  * populated result including the formatted value to show.
@@ -46411,77 +46239,28 @@ var formatResult = function formatResult(result, params) {
46411
46239
  };
46412
46240
  };
46413
46241
 
46414
- var formattedResultToSeries = function formattedResultToSeries(formattedResult, pivotConfig, seriesLabelFormatter, zFieldId) {
46415
- var _formattedResult$fiel, _formattedResult$fiel2;
46242
+ var formattedResultToSeries = function formattedResultToSeries(formattedResult, pivotConfig, zFieldId) {
46416
46243
  var keys = {};
46417
-
46418
- // Collect the result fields which are going to be used on the Y axis.
46419
- var yResultFields = formattedResult.fields.filter(function (resultField) {
46420
- var isNotXPivot = !pivotConfig.x.includes(resultField.id);
46421
- var isNotYPivot = !pivotConfig.y.includes(resultField.id);
46422
- return isNotXPivot && isNotYPivot;
46423
- });
46424
- var xPivotFields = formattedResult.fields.filter(function (resultField) {
46425
- return pivotConfig.x.includes(resultField.id);
46426
- });
46427
- var yPivotFields = formattedResult.fields.filter(function (resultField) {
46428
- return pivotConfig.y.includes(resultField.id);
46429
- });
46430
- var pivotedData = {};
46431
- var xKeyOrdering = [];
46432
- var yKeys = {};
46433
- formattedResult.contentMapped.forEach(function (row) {
46434
- xPivotFields.forEach(function (xPivotField) {
46435
- var _extends2;
46436
- var uniqueXValue = xPivotField.id + ":" + row[xPivotField.id].value;
46437
- xKeyOrdering.push(uniqueXValue);
46438
-
46439
- // Add any existing values, and the x key itself
46440
-
46441
- var yPivotPrefix = yPivotFields.map(function (yPivotField) {
46442
- return yPivotField.id + ":" + row[yPivotField.id].value;
46443
- }).join('_');
46444
- pivotedData[uniqueXValue] = _extends({}, pivotedData[uniqueXValue] || {}, (_extends2 = {}, _extends2[xPivotField.id] = row[xPivotField.id], _extends2));
46445
- yResultFields.forEach(function (yResultField) {
46446
- var _extends3;
46447
- var key = yPivotFields.length > 0 ? [yPivotPrefix, yResultField.id].join('_') : yResultField.id;
46448
- yKeys[key] = true;
46449
- keys[key] = {
46450
- key: key,
46451
- dataType: yResultField.dataType,
46452
- outputDataType: yResultField.outputDataType,
46453
- keyFormatted: seriesLabelFormatter({
46454
- yResultField: yResultField,
46455
- yPivotFields: yPivotFields,
46456
- row: row
46457
- })
46458
- };
46459
- pivotedData[uniqueXValue] = _extends({}, pivotedData[uniqueXValue] || {}, (_extends3 = {}, _extends3[key] = row[yResultField.id], _extends3));
46460
- });
46461
- });
46462
- });
46463
- var seriesDataFlattened = _.uniq(xKeyOrdering).map(function (xKey) {
46464
- return pivotedData[xKey];
46465
- });
46466
- var mappedXKeys = xPivotFields.map(function (r) {
46467
- return r.id;
46244
+ formattedResult.fields.forEach(function (field) {
46245
+ keys[field.id] = {
46246
+ key: field.id,
46247
+ dataType: field.dataType,
46248
+ outputDataType: field.outputDataType,
46249
+ keyFormatted: field["function"] === 'none' ? field.publicName : field.publicName + " (" + field["function"] + ")"
46250
+ };
46468
46251
  });
46469
- var mappedYKeys = Object.keys(yKeys);
46470
- var mappedZKey = (_formattedResult$fiel = (_formattedResult$fiel2 = formattedResult.fields.find(function (resultField) {
46471
- return resultField.fieldId === zFieldId;
46472
- })) == null ? void 0 : _formattedResult$fiel2.id) != null ? _formattedResult$fiel : '';
46473
46252
  var formattedResultReturn = {
46474
- xKeys: mappedXKeys,
46475
- yKeys: mappedYKeys,
46476
- zKey: mappedZKey,
46253
+ xKeys: pivotConfig.x,
46254
+ yKeys: pivotConfig.y,
46255
+ zKey: zFieldId,
46477
46256
  keys: keys,
46478
- seriesData: seriesDataFlattened
46257
+ seriesData: formattedResult.contentMapped
46479
46258
  };
46480
46259
  return formattedResultReturn;
46481
46260
  };
46482
46261
 
46483
46262
  var buildBubbleChartRepresentation = function buildBubbleChartRepresentation(_ref) {
46484
- var _pivotConfig$x$, _xKeys$, _axisTitles$x, _axisTitles$y;
46263
+ var _pivotConfig$x$, _xKeys$, _formattedResult$fiel, _formattedResult$fiel2, _axisTitles$x, _axisTitles$y;
46485
46264
  var axisTitles = _ref.axisTitles,
46486
46265
  colors = _ref.colors,
46487
46266
  conditionalFormattingAttributes = _ref.conditionalFormattingAttributes,
@@ -46493,7 +46272,6 @@ var buildBubbleChartRepresentation = function buildBubbleChartRepresentation(_re
46493
46272
  order = _ref.order,
46494
46273
  pivotConfig = _ref.pivotConfig,
46495
46274
  result = _ref.result,
46496
- trendsAndForecasts = _ref.trendsAndForecasts,
46497
46275
  xAxisFormat = _ref.xAxisFormat,
46498
46276
  xAxisPostfix = _ref.xAxisPostfix,
46499
46277
  xAxisPrefix = _ref.xAxisPrefix,
@@ -46501,7 +46279,6 @@ var buildBubbleChartRepresentation = function buildBubbleChartRepresentation(_re
46501
46279
  yAxisPostfix = _ref.yAxisPostfix,
46502
46280
  yAxisPrefix = _ref.yAxisPrefix,
46503
46281
  approxYAxisLabelCount = _ref.approxYAxisLabelCount,
46504
- seriesLabelFormatter = _ref.seriesLabelFormatter,
46505
46282
  _valueAlias = _ref.valueAlias,
46506
46283
  zFieldId = _ref.zFieldId;
46507
46284
  var allPrefixes = {};
@@ -46584,7 +46361,6 @@ var buildBubbleChartRepresentation = function buildBubbleChartRepresentation(_re
46584
46361
  var xKeyField = result.fields.find(function (field) {
46585
46362
  return field.id === xKeyTemp;
46586
46363
  });
46587
- var orderFunction = order.length > 0 ? order[0]["function"] : undefined;
46588
46364
 
46589
46365
  // ----- Formatting -----
46590
46366
 
@@ -46601,7 +46377,7 @@ var buildBubbleChartRepresentation = function buildBubbleChartRepresentation(_re
46601
46377
  var formattingFunctionY = function formattingFunctionY(value) {
46602
46378
  // Use any y axis field as they are all formatted in the same way (for now...);
46603
46379
  var nonPivotField = formattedResult.fields.find(function (resultField) {
46604
- return ![].concat(pivotConfig.x, pivotConfig.y).includes(resultField.id);
46380
+ return pivotConfig.y.includes(resultField.id);
46605
46381
  });
46606
46382
  if (!nonPivotField) return '';
46607
46383
  return formattedResult.formatterFunc(value, {
@@ -46613,32 +46389,22 @@ var buildBubbleChartRepresentation = function buildBubbleChartRepresentation(_re
46613
46389
 
46614
46390
  // ----- Keys & Prep -----
46615
46391
  var xScaleDataType = (xKeyField == null ? void 0 : xKeyField.outputDataType) || 'string';
46616
- var _formattedResultToSer = formattedResultToSeries(formattedResult, pivotConfig, seriesLabelFormatter, zFieldId),
46392
+ var _formattedResultToSer = formattedResultToSeries(formattedResult, pivotConfig, zFieldId),
46617
46393
  keys = _formattedResultToSer.keys,
46618
46394
  yKeys = _formattedResultToSer.yKeys,
46619
46395
  xKeys = _formattedResultToSer.xKeys,
46620
46396
  zKey = _formattedResultToSer.zKey,
46621
46397
  chartData = _formattedResultToSer.seriesData;
46622
- var xKey = (_xKeys$ = xKeys[0]) != null ? _xKeys$ : null;
46623
-
46624
- // ----- Trends & Forecasts -----
46625
-
46626
- var trendsAndForecastData = getTrendsAndForecastsData({
46627
- chartData: chartData,
46628
- formattingFunctionX: formattingFunctionX,
46629
- formattingFunctionY: formattingFunctionY,
46630
- keys: keys,
46631
- nullValue: nullValue,
46632
- trendsAndForecasts: trendsAndForecasts,
46633
- xAxisPostfix: xAxisPostfix,
46634
- xKey: xKey,
46635
- yKeys: yKeys,
46636
- xAxisPrefix: xAxisPrefix,
46637
- xScaleDataType: xScaleDataType,
46638
- yAxisPostfix: yAxisPostfix,
46639
- yAxisPrefix: yAxisPrefix,
46640
- orderFunction: orderFunction
46398
+ var sortedChartData = chartData.sort(function (a, b) {
46399
+ var _order$, _a$pivotConfig$x$, _b$pivotConfig$x$;
46400
+ var isDescending = ((_order$ = order[0]) == null ? void 0 : _order$.direction) === 'desc';
46401
+ var xValueA = (_a$pivotConfig$x$ = a[pivotConfig.x[0]]) == null ? void 0 : _a$pivotConfig$x$.value;
46402
+ var xValueB = (_b$pivotConfig$x$ = b[pivotConfig.x[0]]) == null ? void 0 : _b$pivotConfig$x$.value;
46403
+ if (xValueA < xValueB) return isDescending ? 1 : -1;
46404
+ if (xValueA > xValueB) return isDescending ? -1 : 1;
46405
+ return 0;
46641
46406
  });
46407
+ var xKey = (_xKeys$ = xKeys[0]) != null ? _xKeys$ : null;
46642
46408
 
46643
46409
  // ----- Goal Lines -----
46644
46410
 
@@ -46650,11 +46416,11 @@ var buildBubbleChartRepresentation = function buildBubbleChartRepresentation(_re
46650
46416
  // ----- Ticks -----
46651
46417
 
46652
46418
  var ticks = getScaleAndTicks({
46653
- data: chartData,
46419
+ data: sortedChartData,
46654
46420
  xKey: xKey,
46655
46421
  xScaleDataType: xScaleDataType,
46656
46422
  yKeys: yKeys,
46657
- tickCountYAxis: approxYAxisLabelCount,
46423
+ approxYAxisLabelCount: approxYAxisLabelCount,
46658
46424
  formattingFunctionX: formattingFunctionX,
46659
46425
  formattingFunctionY: formattingFunctionY,
46660
46426
  nullValue: nullValue,
@@ -46664,9 +46430,36 @@ var buildBubbleChartRepresentation = function buildBubbleChartRepresentation(_re
46664
46430
 
46665
46431
  // ----- Lines -----
46666
46432
 
46433
+ var groupByKey = (_formattedResult$fiel = (_formattedResult$fiel2 = formattedResult.fields.find(function (field) {
46434
+ return field["function"] === 'none';
46435
+ })) == null ? void 0 : _formattedResult$fiel2.id) != null ? _formattedResult$fiel : '';
46667
46436
  var styleDefinition = getStyleDefinition({
46668
- colors: colors != null ? colors : ['#feae4a', '#5fbaff', '#e15e9d'],
46669
- yKeys: yKeys
46437
+ colors: colors,
46438
+ yKeys: [].concat(yKeys, [xKey, zKey])
46439
+ });
46440
+
46441
+ // ----- Legend -----
46442
+ var colorScale = themeToColorScale(colors, sortedChartData.length);
46443
+ var legendItems = sortedChartData.map(function (d, index) {
46444
+ var _d$groupByKey, _colorScale;
46445
+ return {
46446
+ yKey: (_d$groupByKey = d[groupByKey]) == null ? void 0 : _d$groupByKey.value,
46447
+ color: (_colorScale = colorScale[index % colorScale.length]) != null ? _colorScale : '',
46448
+ style: {
46449
+ strokeWidth: 3,
46450
+ strokeDasharray: null,
46451
+ type: 'line'
46452
+ }
46453
+ };
46454
+ });
46455
+ var legendKeys = {};
46456
+ sortedChartData.forEach(function (row) {
46457
+ var _row$groupByKey, _row$groupByKey$value, _row$groupByKey2, _row$groupByKey$forma, _row$groupByKey3;
46458
+ legendKeys[(_row$groupByKey = row[groupByKey]) == null ? void 0 : _row$groupByKey.value] = {
46459
+ key: (_row$groupByKey$value = (_row$groupByKey2 = row[groupByKey]) == null ? void 0 : _row$groupByKey2.value) != null ? _row$groupByKey$value : '',
46460
+ dataType: 'string',
46461
+ keyFormatted: (_row$groupByKey$forma = (_row$groupByKey3 = row[groupByKey]) == null ? void 0 : _row$groupByKey3.formattedValue) != null ? _row$groupByKey$forma : ''
46462
+ };
46670
46463
  });
46671
46464
 
46672
46465
  // ----- Conditional Formatting -----
@@ -46705,21 +46498,24 @@ var buildBubbleChartRepresentation = function buildBubbleChartRepresentation(_re
46705
46498
  title: (_axisTitles$y = axisTitles == null ? void 0 : axisTitles.y) != null ? _axisTitles$y : null
46706
46499
  },
46707
46500
  z: zKey,
46708
- data: chartData,
46501
+ data: sortedChartData,
46709
46502
  lines: styleDefinition,
46710
46503
  conditionalFormattingRules: conditionalFormattingRules,
46711
- goalLines: goalLines
46504
+ goalLines: goalLines,
46505
+ groupByKey: groupByKey,
46506
+ legend: {
46507
+ keys: legendKeys,
46508
+ items: legendItems
46509
+ }
46712
46510
  };
46713
46511
  return chart;
46714
46512
  };
46715
46513
 
46716
46514
  var BubbleChartV2View = function BubbleChartV2View(props) {
46717
- var _props$library, _props$attributes$vie;
46515
+ var _props$library, _props$attributes$vie, _props$result, _props$result2, _props$result3;
46718
46516
  var _useDashboardBehaviou = useDashboardBehaviourContext(),
46719
46517
  textOverride = _useDashboardBehaviou.textOverride,
46720
- valueAlias = _useDashboardBehaviou.valueAlias,
46721
- labelFormat = _useDashboardBehaviou.labelFormat,
46722
- queryEngineConfig = _useDashboardBehaviou.queryEngineConfig;
46518
+ valueAlias = _useDashboardBehaviou.valueAlias;
46723
46519
  var headerProps = {
46724
46520
  displayTitle: props.attributes.displayTitle,
46725
46521
  displaySubject: props.attributes.displaySubject,
@@ -46740,12 +46536,12 @@ var BubbleChartV2View = function BubbleChartV2View(props) {
46740
46536
  var showHeadline = headlineAvailable(props.attributes.order, props.attributes.headline, null);
46741
46537
  var theme = useTheme();
46742
46538
  var BubbleChartV2Component = getComponentInterface(props.attributes.type);
46743
- var pivotConfig = init$c(props.attributes);
46539
+ var pivotConfig = init$d(props.attributes.xMeasure, props.attributes.measure);
46744
46540
  var chartRepresentation = null;
46745
46541
  if (!isLoading(props.result) && !hasFailed(props.result) && !isEmpty(props.result) && BubbleChartV2Component.isRunnable(props.attributes)) {
46746
46542
  var _theme$charts$colors, _theme$charts, _props$attributes$goa;
46747
46543
  chartRepresentation = buildBubbleChartRepresentation({
46748
- zFieldId: props.attributes.zMeasure[0].field,
46544
+ zFieldId: id(props.attributes.zMeasure[0]),
46749
46545
  axisTitles: props.attributes.axisTitles,
46750
46546
  xAxisPostfix: props.attributes.xAxisPostfix,
46751
46547
  xAxisPrefix: props.attributes.xAxisPrefix,
@@ -46753,7 +46549,7 @@ var BubbleChartV2View = function BubbleChartV2View(props) {
46753
46549
  yAxisPrefix: props.attributes.yAxisPrefix,
46754
46550
  yAxisFormat: props.attributes.yAxisFormat,
46755
46551
  xAxisFormat: props.attributes.xAxisFormat,
46756
- approxYAxisLabelCount: props.attributes.approxYAxisLabelCount === 'auto' ? 10 : props.attributes.approxYAxisLabelCount,
46552
+ approxYAxisLabelCount: props.attributes.approxYAxisLabelCount,
46757
46553
  colors: (_theme$charts$colors = theme == null || (_theme$charts = theme.charts) == null ? void 0 : _theme$charts.colors) != null ? _theme$charts$colors : DEFAULT_CHART_COLORS,
46758
46554
  valueAlias: valueAlias,
46759
46555
  nullValue: checkForNullValue(props.attributes.dataSetId, props.attributes.dimension, props.attributes.timeDimension, textOverride, valueAlias),
@@ -46764,27 +46560,7 @@ var BubbleChartV2View = function BubbleChartV2View(props) {
46764
46560
  dateTimeFormatOptions: props.dateTimeFormatOptions,
46765
46561
  goalLineAttributes: (_props$attributes$goa = props.attributes.goalLines) != null ? _props$attributes$goa : [],
46766
46562
  conditionalFormattingAttributes: props.attributes.conditionalFormattingRules,
46767
- trendsAndForecasts: props.attributes.trends,
46768
- defaultFormats: props.defaultFormats,
46769
- seriesLabelFormatter: function seriesLabelFormatter(labelFormatParams) {
46770
- var _queryEngineConfig$su, _queryEngineConfig$su2, _queryEngineConfig$su3;
46771
- var yResultField = labelFormatParams.yResultField,
46772
- yPivotFields = labelFormatParams.yPivotFields,
46773
- row = labelFormatParams.row;
46774
- var formattedFunctionName = ((_queryEngineConfig$su = queryEngineConfig.supportedAggregates[yResultField["function"]]) == null ? void 0 : _queryEngineConfig$su.publicName) || ((_queryEngineConfig$su2 = queryEngineConfig.supportedTimeTruncFunctions[yResultField["function"]]) == null ? void 0 : _queryEngineConfig$su2.publicName) || ((_queryEngineConfig$su3 = queryEngineConfig.supportedTransformationFunctions[yResultField["function"]]) == null ? void 0 : _queryEngineConfig$su3.publicName);
46775
- var formattedFunction = yResultField["function"] === 'none' ? '' : " \u2022 " + formattedFunctionName;
46776
- var defaultLabelFormat = "" + yPivotFields.map(function (field) {
46777
- return row[field.id].formattedValue;
46778
- }).join(' • ') + (yPivotFields.length === 0 ? '' : ' • ') + yResultField.publicName + formattedFunction;
46779
- if (!labelFormat) return defaultLabelFormat;
46780
- return labelFormat({
46781
- viewId: props.attributes.viewId,
46782
- fieldId: yResultField.fieldId,
46783
- func: yResultField["function"],
46784
- type: 'bubbleChartV2',
46785
- defaultLabel: defaultLabelFormat
46786
- }) || defaultLabelFormat;
46787
- }
46563
+ defaultFormats: props.defaultFormats
46788
46564
  });
46789
46565
  }
46790
46566
 
@@ -46794,6 +46570,16 @@ var BubbleChartV2View = function BubbleChartV2View(props) {
46794
46570
  title: "Missing parameters"
46795
46571
  });
46796
46572
  }
46573
+ if (((_props$result = props.result) == null ? void 0 : _props$result.fields.filter(function (r) {
46574
+ return pivotConfig.x.includes(r.id);
46575
+ }).length) === 0) return jsxRuntime.jsx(LoadingComponent, {});
46576
+ if (((_props$result2 = props.result) == null ? void 0 : _props$result2.fields.filter(function (r) {
46577
+ return pivotConfig.y.includes(r.id);
46578
+ }).length) === 0) return jsxRuntime.jsx(LoadingComponent, {});
46579
+ if (((_props$result3 = props.result) == null ? void 0 : _props$result3.fields.filter(function (r) {
46580
+ var _Field$id;
46581
+ return (_Field$id = id(props.attributes.zMeasure[0])) == null ? void 0 : _Field$id.includes(r.id);
46582
+ }).length) === 0) return jsxRuntime.jsx(LoadingComponent, {});
46797
46583
  if (isLoading(props.result)) return jsxRuntime.jsx(LoadingComponent, {});
46798
46584
  if (hasFailed(props.result)) return jsxRuntime.jsx(FailedToLoadDataNotice, {});
46799
46585
  if (isEmpty(props.result)) return jsxRuntime.jsx(NoResultContentToShowNotice, _extends({}, headerProps));
@@ -47005,7 +46791,76 @@ function getStyleDefinition$1(_ref) {
47005
46791
  });
47006
46792
  }
47007
46793
 
47008
- var buildTrendAndForecast$1 = function buildTrendAndForecast(_ref) {
46794
+ var formattedResultToSeries$1 = function formattedResultToSeries(formattedResult, pivotConfig, seriesLabelFormatter, zFieldId) {
46795
+ var _formattedResult$fiel, _formattedResult$fiel2;
46796
+ var keys = {};
46797
+
46798
+ // Collect the result fields which are going to be used on the Y axis.
46799
+ var yResultFields = formattedResult.fields.filter(function (resultField) {
46800
+ var isNotXPivot = !pivotConfig.x.includes(resultField.id);
46801
+ var isNotYPivot = !pivotConfig.y.includes(resultField.id);
46802
+ return isNotXPivot && isNotYPivot;
46803
+ });
46804
+ var xPivotFields = formattedResult.fields.filter(function (resultField) {
46805
+ return pivotConfig.x.includes(resultField.id);
46806
+ });
46807
+ var yPivotFields = formattedResult.fields.filter(function (resultField) {
46808
+ return pivotConfig.y.includes(resultField.id);
46809
+ });
46810
+ var pivotedData = {};
46811
+ var xKeyOrdering = [];
46812
+ var yKeys = {};
46813
+ formattedResult.contentMapped.forEach(function (row) {
46814
+ xPivotFields.forEach(function (xPivotField) {
46815
+ var _extends2;
46816
+ var uniqueXValue = xPivotField.id + ":" + row[xPivotField.id].value;
46817
+ xKeyOrdering.push(uniqueXValue);
46818
+
46819
+ // Add any existing values, and the x key itself
46820
+
46821
+ var yPivotPrefix = yPivotFields.map(function (yPivotField) {
46822
+ return yPivotField.id + ":" + row[yPivotField.id].value;
46823
+ }).join('_');
46824
+ pivotedData[uniqueXValue] = _extends({}, pivotedData[uniqueXValue] || {}, (_extends2 = {}, _extends2[xPivotField.id] = row[xPivotField.id], _extends2));
46825
+ yResultFields.forEach(function (yResultField) {
46826
+ var _extends3;
46827
+ var key = yPivotFields.length > 0 ? [yPivotPrefix, yResultField.id].join('_') : yResultField.id;
46828
+ yKeys[key] = true;
46829
+ keys[key] = {
46830
+ key: key,
46831
+ dataType: yResultField.dataType,
46832
+ outputDataType: yResultField.outputDataType,
46833
+ keyFormatted: seriesLabelFormatter({
46834
+ yResultField: yResultField,
46835
+ yPivotFields: yPivotFields,
46836
+ row: row
46837
+ })
46838
+ };
46839
+ pivotedData[uniqueXValue] = _extends({}, pivotedData[uniqueXValue] || {}, (_extends3 = {}, _extends3[key] = row[yResultField.id], _extends3));
46840
+ });
46841
+ });
46842
+ });
46843
+ var seriesDataFlattened = _.uniq(xKeyOrdering).map(function (xKey) {
46844
+ return pivotedData[xKey];
46845
+ });
46846
+ var mappedXKeys = xPivotFields.map(function (r) {
46847
+ return r.id;
46848
+ });
46849
+ var mappedYKeys = Object.keys(yKeys);
46850
+ var mappedZKey = (_formattedResult$fiel = (_formattedResult$fiel2 = formattedResult.fields.find(function (resultField) {
46851
+ return resultField.fieldId === zFieldId;
46852
+ })) == null ? void 0 : _formattedResult$fiel2.id) != null ? _formattedResult$fiel : '';
46853
+ var formattedResultReturn = {
46854
+ xKeys: mappedXKeys,
46855
+ yKeys: mappedYKeys,
46856
+ zKey: mappedZKey,
46857
+ keys: keys,
46858
+ seriesData: seriesDataFlattened
46859
+ };
46860
+ return formattedResultReturn;
46861
+ };
46862
+
46863
+ var buildTrendAndForecast = function buildTrendAndForecast(_ref) {
47009
46864
  var data = _ref.data,
47010
46865
  forecastUnits = _ref.forecastUnits,
47011
46866
  xKey = _ref.xKey,
@@ -47098,7 +46953,7 @@ var buildTrendAndForecast$1 = function buildTrendAndForecast(_ref) {
47098
46953
  };
47099
46954
  };
47100
46955
 
47101
- var getTrendsAndForecastsData$1 = function getTrendsAndForecastsData(_ref) {
46956
+ var getTrendsAndForecastsData = function getTrendsAndForecastsData(_ref) {
47102
46957
  var _trendsAndForecasts$;
47103
46958
  var chartData = _ref.chartData,
47104
46959
  formattingFunctionX = _ref.formattingFunctionX,
@@ -47127,7 +46982,7 @@ var getTrendsAndForecastsData$1 = function getTrendsAndForecastsData(_ref) {
47127
46982
  var forecastUnits = trendsAndForecasts[0].type === 'Forecast' ? (_trendsAndForecasts$ = trendsAndForecasts[0].value) != null ? _trendsAndForecasts$ : 0 : 0;
47128
46983
  var yKey = yKeys[0];
47129
46984
  var newKeys = _.cloneDeep(keys);
47130
- var _buildTrendAndForecas = buildTrendAndForecast$1({
46985
+ var _buildTrendAndForecas = buildTrendAndForecast({
47131
46986
  data: chartData,
47132
46987
  forecastUnits: forecastUnits,
47133
46988
  xKey: xKey,
@@ -47566,7 +47421,7 @@ var buildLineChartRepresentation = function buildLineChartRepresentation(_ref) {
47566
47421
 
47567
47422
  // ----- Keys & Prep -----
47568
47423
  var xScaleDataType = (xKeyField == null ? void 0 : xKeyField.outputDataType) || 'string';
47569
- var _formattedResultToSer = formattedResultToSeries(formattedResult, pivotConfig, seriesLabelFormatter),
47424
+ var _formattedResultToSer = formattedResultToSeries$1(formattedResult, pivotConfig, seriesLabelFormatter),
47570
47425
  keys = _formattedResultToSer.keys,
47571
47426
  yKeys = _formattedResultToSer.yKeys,
47572
47427
  xKeys = _formattedResultToSer.xKeys,
@@ -47576,7 +47431,7 @@ var buildLineChartRepresentation = function buildLineChartRepresentation(_ref) {
47576
47431
  // ----- Trends & Forecasts -----
47577
47432
 
47578
47433
  var orderFunction = order.length > 0 ? order[0]["function"] : undefined;
47579
- var trendsAndForecastData = getTrendsAndForecastsData$1({
47434
+ var trendsAndForecastData = getTrendsAndForecastsData({
47580
47435
  chartData: chartData,
47581
47436
  formattingFunctionX: function formattingFunctionX$1(value) {
47582
47437
  return formattingFunctionX(value, formattedResult, xKeyField);
@@ -47945,7 +47800,7 @@ var buildAreaChartRepresentation = function buildAreaChartRepresentation(_ref) {
47945
47800
 
47946
47801
  // ----- Keys & Prep -----
47947
47802
  var xScaleDataType = (xKeyField == null ? void 0 : xKeyField.outputDataType) || 'string';
47948
- var _formattedResultToSer = formattedResultToSeries(formattedResult, pivotConfig, seriesLabelFormatter),
47803
+ var _formattedResultToSer = formattedResultToSeries$1(formattedResult, pivotConfig, seriesLabelFormatter),
47949
47804
  keys = _formattedResultToSer.keys,
47950
47805
  yKeys = _formattedResultToSer.yKeys,
47951
47806
  xKeys = _formattedResultToSer.xKeys,
@@ -48297,7 +48152,7 @@ var buildBarChartRepresentation = function buildBarChartRepresentation(_ref) {
48297
48152
 
48298
48153
  // ----- Keys & Prep -----
48299
48154
  var xScaleDataType = (xKeyField == null ? void 0 : xKeyField.outputDataType) || 'string';
48300
- var _formattedResultToSer = formattedResultToSeries(formattedResult, pivotConfig, seriesLabelFormatter),
48155
+ var _formattedResultToSer = formattedResultToSeries$1(formattedResult, pivotConfig, seriesLabelFormatter),
48301
48156
  keys = _formattedResultToSer.keys,
48302
48157
  yKeys = _formattedResultToSer.yKeys,
48303
48158
  xKeys = _formattedResultToSer.xKeys,
@@ -52523,7 +52378,7 @@ var buildRadarChartRepresentation = function buildRadarChartRepresentation(_ref)
52523
52378
  }).formattedValue;
52524
52379
  };
52525
52380
  var xScaleDataType = (xKeyField == null ? void 0 : xKeyField.outputDataType) || 'string';
52526
- var _formattedResultToSer = formattedResultToSeries(formattedResult, pivotConfig, seriesLabelFormatter),
52381
+ var _formattedResultToSer = formattedResultToSeries$1(formattedResult, pivotConfig, seriesLabelFormatter),
52527
52382
  keys = _formattedResultToSer.keys,
52528
52383
  yKeys = _formattedResultToSer.yKeys,
52529
52384
  xKeys = _formattedResultToSer.xKeys,
@@ -53518,7 +53373,7 @@ var Legend$2 = function Legend(_ref) {
53518
53373
  });
53519
53374
  };
53520
53375
 
53521
- var _excluded$h = ["formattedValue"],
53376
+ var _excluded$i = ["formattedValue"],
53522
53377
  _excluded2$4 = ["formattedValue"];
53523
53378
  var AXIS_TITLE_STYLES$1 = {
53524
53379
  opacity: '0.75',
@@ -53728,7 +53583,7 @@ var WaterfallChart$2 = function WaterfallChart(_ref) {
53728
53583
  tickValues: xTickValues,
53729
53584
  tickComponent: function tickComponent(_ref2) {
53730
53585
  var formattedValue = _ref2.formattedValue,
53731
- tickProps = _objectWithoutPropertiesLoose(_ref2, _excluded$h);
53586
+ tickProps = _objectWithoutPropertiesLoose(_ref2, _excluded$i);
53732
53587
  return jsxRuntime.jsx(text$3.Text, _extends({
53733
53588
  style: themeCSS.labels
53734
53589
  }, tickProps, {
@@ -70266,7 +70121,7 @@ var fromToken = function fromToken(token) {
70266
70121
  });
70267
70122
  };
70268
70123
 
70269
- var init$d = function init(dashboardSessionToken, dataAccessToken, queryEngineAccessToken, dashboardAdminOverrideToken) {
70124
+ var init$e = function init(dashboardSessionToken, dataAccessToken, queryEngineAccessToken, dashboardAdminOverrideToken) {
70270
70125
  var dashboardAccessContent = fromToken(dashboardSessionToken);
70271
70126
  if (!('scope' in dashboardAccessContent)) {
70272
70127
  dashboardAccessContent.scope = 'read_write';
@@ -70332,7 +70187,7 @@ var fetchIdentityConfig = /*#__PURE__*/function () {
70332
70187
  throw new FailedToLoadIdentity('Failed to fetch identity config.');
70333
70188
  case 6:
70334
70189
  dashboardAdminOverride = isClientSide() ? getDashboardAdminOverride(window.location.href) : null;
70335
- identityConfig = init$d(tokens.dashboardAccessToken, tokens.dataAccessToken, tokens.queryEngineAccessToken, dashboardAdminOverride);
70190
+ identityConfig = init$e(tokens.dashboardAccessToken, tokens.dataAccessToken, tokens.queryEngineAccessToken, dashboardAdminOverride);
70336
70191
  return _context.abrupt("return", {
70337
70192
  identityConfig: identityConfig,
70338
70193
  tokens: tokens
@@ -76284,7 +76139,7 @@ var GlobalProviderContents = function GlobalProviderContents(props) {
76284
76139
  });
76285
76140
  };
76286
76141
 
76287
- var _excluded$i = ["view"];
76142
+ var _excluded$j = ["view"];
76288
76143
  var Dashboard$2 = function Dashboard(props) {
76289
76144
  var handleOnError = function handleOnError(error, errorInfo) {
76290
76145
  return (props == null ? void 0 : props.onError) && (props == null ? void 0 : props.onError(error, errorInfo));
@@ -76305,7 +76160,7 @@ var Editor$1 = function Editor(props) {
76305
76160
  var handleOnError = function handleOnError(error, errorInfo) {
76306
76161
  return (props == null ? void 0 : props.onError) && (props == null ? void 0 : props.onError(error, errorInfo));
76307
76162
  };
76308
- var resetProps = _objectWithoutPropertiesLoose(props, _excluded$i);
76163
+ var resetProps = _objectWithoutPropertiesLoose(props, _excluded$j);
76309
76164
  return jsxRuntime.jsxs(ErrorBoundary, {
76310
76165
  renderOnError: function renderOnError() {
76311
76166
  return jsxRuntime.jsx("p", {