@vizzly/dashboard 0.15.0-dev-45f4268b92d46ac8f53b9683a04bb9e8d2dac16a → 0.15.0-dev-7c9658e993e6c1d321c4d69f2e166bbb37cca3aa

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.
@@ -3192,6 +3192,17 @@ var goalLineSchema = function goalLineSchema() {
3192
3192
  var goalLinesSchema = function goalLinesSchema() {
3193
3193
  return Joi.array().items(goalLineSchema());
3194
3194
  };
3195
+ var quadrantsSchema = function quadrantsSchema() {
3196
+ return Joi.object({
3197
+ enabled: Joi["boolean"]().required(),
3198
+ labels: Joi.object({
3199
+ quadrantOne: Joi.string().allow('').optional(),
3200
+ quadrantTwo: Joi.string().allow('').optional(),
3201
+ quadrantThree: Joi.string().allow('').optional(),
3202
+ quadrantFour: Joi.string().allow('').optional()
3203
+ }).required()
3204
+ });
3205
+ };
3195
3206
  var headlineSchema = function headlineSchema() {
3196
3207
  return Joi.object({
3197
3208
  func: Joi.string().valid('mean', 'sum', 'current').allow(null).optional()
@@ -5794,6 +5805,7 @@ var attributesSchema$6 = function attributesSchema(config) {
5794
5805
  type: Joi.valid('bubbleChartV2').required(),
5795
5806
  parameters: parametersSchema(config.queryEngineConfig, config.attributesSchemaOptions),
5796
5807
  lineCurve: lineCurveSchema,
5808
+ quadrants: quadrantsSchema(),
5797
5809
  conditionalFormattingRules: conditionalFormattingRulesSchema(config.queryEngineConfig),
5798
5810
  goalLines: goalLinesSchema(),
5799
5811
  axisTitles: axisTitleSchema(),
@@ -5982,6 +5994,11 @@ var CONSTANTS$6 = {
5982
5994
  }
5983
5995
  }
5984
5996
  },
5997
+ quadrants: {
5998
+ type: 'quadrants',
5999
+ title: '',
6000
+ description: ''
6001
+ },
5985
6002
  conditional_formatting: {
5986
6003
  type: 'conditionalFormatting',
5987
6004
  title: 'Conditional Formatting',
@@ -6039,6 +6056,7 @@ var BubbleChartV2 = function BubbleChartV2(config) {
6039
6056
  yAxisFormat: dumped.yAxisFormat,
6040
6057
  xAxisFormat: dumped.xAxisFormat,
6041
6058
  lineCurve: dumped.lineCurve,
6059
+ quadrants: dumped.quadrants,
6042
6060
  conditionalFormattingRules: upcast$1(config.queryEngineConfig, dumped.conditionalFormattingRules),
6043
6061
  drilldown: dumped.drilldown,
6044
6062
  legend: dumped.legend,
@@ -6079,6 +6097,7 @@ var BubbleChartV2 = function BubbleChartV2(config) {
6079
6097
  yAxisFormat: null,
6080
6098
  xAxisFormat: null,
6081
6099
  lineCurve: 'natural',
6100
+ quadrants: undefined,
6082
6101
  conditionalFormattingRules: [],
6083
6102
  drilldown: [],
6084
6103
  legend: true,
@@ -6183,7 +6202,7 @@ var BubbleChartV2 = function BubbleChartV2(config) {
6183
6202
  }), namespace(CONSTANTS$6, 'sort'), namespace(CONSTANTS$6, 'filter'), namespace(CONSTANTS$6, 'custom_metrics'), namespace(CONSTANTS$6, 'limit')];
6184
6203
  },
6185
6204
  formatPanelConfig: function formatPanelConfig() {
6186
- return [headingConstant(CONSTANTS$6), chartStylesConstant(CONSTANTS$6, true, false), axisLabelsConstants(CONSTANTS$6), _extends({}, namespace(CONSTANTS$6, 'conditional_formatting'), {
6205
+ return [headingConstant(CONSTANTS$6), chartStylesConstant(CONSTANTS$6, true, false), axisLabelsConstants(CONSTANTS$6), namespace(CONSTANTS$6, 'quadrants'), _extends({}, namespace(CONSTANTS$6, 'conditional_formatting'), {
6187
6206
  ruleType: 'lineColor'
6188
6207
  }), namespace(CONSTANTS$6, 'goal_line')
6189
6208
  // namespace<'trends'>(CONSTANTS, 'trends'),
@@ -10551,6 +10570,7 @@ var attributesSchema$j = function attributesSchema(config) {
10551
10570
  approxYAxisLabelCount: approxAxisLabelCountSchema,
10552
10571
  approxXAxisLabelCount: approxAxisLabelCountSchema,
10553
10572
  goalLines: goalLinesSchema(),
10573
+ quadrants: quadrantsSchema(),
10554
10574
  axisTitles: axisTitleSchema(),
10555
10575
  tags: tagsSchema()
10556
10576
  }));
@@ -10737,6 +10757,11 @@ var CONSTANTS$l = {
10737
10757
  type: 'goalLine',
10738
10758
  title: 'Goal Lines',
10739
10759
  description: ''
10760
+ },
10761
+ quadrants: {
10762
+ type: 'quadrants',
10763
+ title: '',
10764
+ description: ''
10740
10765
  }
10741
10766
  }
10742
10767
  };
@@ -10776,6 +10801,7 @@ var ScatterChart = function ScatterChart(config) {
10776
10801
  approxXAxisLabelCount: upcastAxisLabel(dumped.approxXAxisLabelCount),
10777
10802
  approxYAxisLabelCount: upcastAxisLabel(dumped.approxYAxisLabelCount),
10778
10803
  goalLines: dumped.goalLines,
10804
+ quadrants: dumped.quadrants,
10779
10805
  axisTitles: dumped.axisTitles,
10780
10806
  tags: (_dumped$tags = dumped.tags) != null ? _dumped$tags : []
10781
10807
  };
@@ -10809,6 +10835,7 @@ var ScatterChart = function ScatterChart(config) {
10809
10835
  approxXAxisLabelCount: 'auto',
10810
10836
  approxYAxisLabelCount: 'auto',
10811
10837
  goalLines: undefined,
10838
+ quadrants: undefined,
10812
10839
  axisTitles: undefined,
10813
10840
  tags: []
10814
10841
  }, overrides);
@@ -10865,7 +10892,7 @@ var ScatterChart = function ScatterChart(config) {
10865
10892
  var _CONSTANTS$format_pan;
10866
10893
  return [headingConstant(CONSTANTS$l), _extends({}, namespace(CONSTANTS$l, 'chart_styles'), {
10867
10894
  subSection: [(_CONSTANTS$format_pan = CONSTANTS$l.format_panel.chart_styles) == null ? void 0 : _CONSTANTS$format_pan.subSectionDefinition.legend]
10868
- }), axisLabelsConstants(CONSTANTS$l), namespace(CONSTANTS$l, 'goal_line')];
10895
+ }), axisLabelsConstants(CONSTANTS$l), namespace(CONSTANTS$l, 'quadrants'), namespace(CONSTANTS$l, 'goal_line')];
10869
10896
  },
10870
10897
  supportedCustomFields: {
10871
10898
  percentages: true,
@@ -32718,6 +32745,86 @@ var Annotations = function Annotations(props) {
32718
32745
  });
32719
32746
  };
32720
32747
 
32748
+ var QuadrantOverlay = function QuadrantOverlay(_ref) {
32749
+ var innerWidth = _ref.innerWidth,
32750
+ innerHeight = _ref.innerHeight,
32751
+ topLeftText = _ref.topLeftText,
32752
+ topRightText = _ref.topRightText,
32753
+ bottomLeftText = _ref.bottomLeftText,
32754
+ bottomRightText = _ref.bottomRightText;
32755
+ var BLOCK_WIDTH = innerWidth / 2;
32756
+ var BLOCK_HEIGHT = innerHeight / 2;
32757
+ var BLOCK_COLOR = '#C7CCD1';
32758
+ var TEXT_COLOR = '#333';
32759
+ return jsxRuntime.jsxs(React__default.Fragment, {
32760
+ children: [jsxRuntime.jsx("rect", {
32761
+ width: BLOCK_WIDTH,
32762
+ height: BLOCK_HEIGHT,
32763
+ fill: "none"
32764
+ }), jsxRuntime.jsx("rect", {
32765
+ width: BLOCK_WIDTH,
32766
+ height: BLOCK_HEIGHT,
32767
+ y: BLOCK_HEIGHT,
32768
+ fill: "none"
32769
+ }), jsxRuntime.jsx("rect", {
32770
+ width: BLOCK_WIDTH,
32771
+ height: BLOCK_HEIGHT,
32772
+ x: BLOCK_WIDTH,
32773
+ fill: "none"
32774
+ }), jsxRuntime.jsx("rect", {
32775
+ width: BLOCK_WIDTH,
32776
+ height: BLOCK_HEIGHT,
32777
+ x: BLOCK_WIDTH,
32778
+ y: BLOCK_HEIGHT,
32779
+ fillOpacity: 0
32780
+ }), jsxRuntime.jsx("line", {
32781
+ x1: 0,
32782
+ y1: BLOCK_HEIGHT,
32783
+ x2: innerWidth,
32784
+ y2: BLOCK_HEIGHT,
32785
+ stroke: BLOCK_COLOR,
32786
+ strokeWidth: 2
32787
+ }), jsxRuntime.jsx("line", {
32788
+ x1: BLOCK_WIDTH,
32789
+ y1: 0,
32790
+ x2: BLOCK_WIDTH,
32791
+ y2: innerHeight,
32792
+ stroke: BLOCK_COLOR,
32793
+ strokeWidth: 2
32794
+ }), jsxRuntime.jsx("text", {
32795
+ x: 10,
32796
+ y: 20,
32797
+ fill: TEXT_COLOR,
32798
+ fontSize: "12",
32799
+ fontWeight: "bold",
32800
+ children: topLeftText
32801
+ }), jsxRuntime.jsx("text", {
32802
+ x: innerWidth - 10,
32803
+ y: 20,
32804
+ fill: TEXT_COLOR,
32805
+ fontSize: "12",
32806
+ fontWeight: "bold",
32807
+ textAnchor: "end",
32808
+ children: topRightText
32809
+ }), jsxRuntime.jsx("text", {
32810
+ x: 10,
32811
+ y: innerHeight - 20,
32812
+ fill: TEXT_COLOR,
32813
+ fontSize: "12",
32814
+ fontWeight: "bold",
32815
+ children: bottomLeftText
32816
+ }), jsxRuntime.jsx("text", {
32817
+ x: innerWidth - 10,
32818
+ y: innerHeight - 20,
32819
+ fill: TEXT_COLOR,
32820
+ fontSize: "12",
32821
+ fontWeight: "bold",
32822
+ textAnchor: "end",
32823
+ children: bottomRightText
32824
+ })]
32825
+ });
32826
+ };
32827
+
32721
32828
  // Foo.prototype.toString = function() {
32722
32829
  // return "[object Foo]";
32723
32830
  // }
@@ -34759,7 +34866,7 @@ var LABEL_TEXT_STYLE = {
34759
34866
  fontWeight: 500
34760
34867
  };
34761
34868
  var VizzlyXYChart = function VizzlyXYChart(props) {
34762
- var _props$height, _theme$axis$stroke, _theme$axis, _ref, _props$lines$data$len, _props$lines, _props$areas, _props$bars, _props$lines$threshol, _props$lines2, _props$areas2, _props$forceXAxisAsTi, _props$bars2, _props$lines3, _theme$grid$stroke, _theme$grid, _props$axisTitles, _props$axisTitles2, _props$axisTitles3, _props$axisTitles4, _props$areas7, _props$bars3, _props$bars7, _props$lines4, _props$lines7, _props$trends2, _props$lines13, _props$bars14, _props$goalLine, _props$bars15, _props$bars16, _props$bars17;
34869
+ var _props$height, _theme$axis$stroke, _theme$axis, _ref, _props$lines$data$len, _props$lines, _props$areas, _props$bars, _props$lines$threshol, _props$lines2, _props$areas2, _props$forceXAxisAsTi, _props$bars2, _props$lines3, _theme$grid$stroke, _theme$grid, _props$quadrants, _props$width, _props$quadrants$labe, _props$quadrants$labe2, _props$quadrants$labe3, _props$quadrants$labe4, _props$axisTitles, _props$axisTitles2, _props$axisTitles3, _props$axisTitles4, _props$areas7, _props$bars3, _props$bars7, _props$lines4, _props$lines7, _props$trends2, _props$lines13, _props$bars14, _props$goalLine, _props$bars15, _props$bars16, _props$bars17;
34763
34870
  var height = adjustHeight((_props$height = props == null ? void 0 : props.height) != null ? _props$height : 300, props == null ? void 0 : props.legend);
34764
34871
  var _props$approxYAxisLab = props.approxYAxisLabelCount,
34765
34872
  approxYAxisLabelCount = _props$approxYAxisLab === void 0 ? 'auto' : _props$approxYAxisLab,
@@ -34860,6 +34967,16 @@ var VizzlyXYChart = function VizzlyXYChart(props) {
34860
34967
  strokeLinecap: 'round',
34861
34968
  stroke: (_theme$grid$stroke = theme == null || (_theme$grid = theme.grid) == null ? void 0 : _theme$grid.stroke) != null ? _theme$grid$stroke : 'rgba(200, 200, 200, 0.2)'
34862
34969
  }
34970
+ }), ((_props$quadrants = props.quadrants) == null ? void 0 : _props$quadrants.enabled) && !props.sparkline && jsxRuntime.jsx("g", {
34971
+ transform: "translate(" + margin.left + ", " + margin.top + ")",
34972
+ children: jsxRuntime.jsx(QuadrantOverlay, {
34973
+ innerWidth: ((_props$width = props == null ? void 0 : props.width) != null ? _props$width : 0) - (margin.left - margin.right) * 2,
34974
+ innerHeight: height - margin.top - margin.bottom,
34975
+ topLeftText: (_props$quadrants$labe = props.quadrants.labels) == null ? void 0 : _props$quadrants$labe.quadrantOne,
34976
+ topRightText: (_props$quadrants$labe2 = props.quadrants.labels) == null ? void 0 : _props$quadrants$labe2.quadrantTwo,
34977
+ bottomLeftText: (_props$quadrants$labe3 = props.quadrants.labels) == null ? void 0 : _props$quadrants$labe3.quadrantThree,
34978
+ bottomRightText: (_props$quadrants$labe4 = props.quadrants.labels) == null ? void 0 : _props$quadrants$labe4.quadrantFour
34979
+ })
34863
34980
  }), !(props != null && props.sparkline) && jsxRuntime.jsxs(jsxRuntime.Fragment, {
34864
34981
  children: [xAxisType !== 'none' && jsxRuntime.jsx(xychart.Axis, _extends({}, xAxisAttributes, {
34865
34982
  tickLabelProps: function tickLabelProps() {
@@ -35268,12 +35385,12 @@ var VizzlyXYChart = function VizzlyXYChart(props) {
35268
35385
  children: function children(axisProps) {
35269
35386
  var _props$goalLine2;
35270
35387
  return (_props$goalLine2 = props.goalLine) == null ? void 0 : _props$goalLine2.map(function (goalLine, index) {
35271
- var _props$width;
35388
+ var _props$width2;
35272
35389
  return jsxRuntime.jsx(ChartGoalLine, {
35273
35390
  axisProps: axisProps,
35274
35391
  goalLine: goalLine,
35275
35392
  value: goalLine.value,
35276
- toX: ((_props$width = props == null ? void 0 : props.width) != null ? _props$width : 0) - margin.left - margin.right,
35393
+ toX: ((_props$width2 = props == null ? void 0 : props.width) != null ? _props$width2 : 0) - margin.left - margin.right,
35277
35394
  marginRight: margin.right,
35278
35395
  maxValueOfYAxis: maxValue,
35279
35396
  formatYAxisLabel: props == null ? void 0 : props.formatYAxisLabel
@@ -36758,7 +36875,9 @@ function buildOnViewClick(clickedValue, nearestDatum, params, runViewClickQuery)
36758
36875
  var getGrouping = function getGrouping() {
36759
36876
  var _params$dimension;
36760
36877
  var grouping = [];
36761
- var datums = Object.keys(nearestDatum != null ? nearestDatum : {}).map(function (d) {
36878
+ var datums = Object.keys(nearestDatum != null ? nearestDatum : {}).filter(function (key) {
36879
+ return key !== 'quadrant';
36880
+ }).map(function (d) {
36762
36881
  return parse(d);
36763
36882
  });
36764
36883
  if (params != null && params.dimension && (params == null || (_params$dimension = params.dimension) == null ? void 0 : _params$dimension.length) > 0) {
@@ -38095,7 +38214,8 @@ var ScatterChart$2 = /*#__PURE__*/React.forwardRef(function (props, ref) {
38095
38214
  goalLine: props == null ? void 0 : props.goalLine,
38096
38215
  axisTitles: props == null ? void 0 : props.axisTitles,
38097
38216
  idPrefix: props == null ? void 0 : props.idPrefix,
38098
- popOverMenuStyles: props.popOverMenuStyles
38217
+ popOverMenuStyles: props.popOverMenuStyles,
38218
+ quadrants: props.quadrants
38099
38219
  });
38100
38220
  }
38101
38221
  });
@@ -38121,7 +38241,8 @@ var defaultProps$4 = {
38121
38241
  legend: false,
38122
38242
  approxXAxisLabelCount: 'auto',
38123
38243
  approxYAxisLabelCount: 'auto',
38124
- tags: []
38244
+ tags: [],
38245
+ quadrants: undefined
38125
38246
  };
38126
38247
  var ScatterChartView = function ScatterChartView(props) {
38127
38248
  var _props$library, _props2, _props$viewId, _props3, _props$library2, _props4, _props5, _props6, _props7, _props$viewId2, _props8, _theme$charts;
@@ -38225,7 +38346,8 @@ var ScatterChartView = function ScatterChartView(props) {
38225
38346
  goalLine: buildGoalLine(variables, props.goalLines),
38226
38347
  axisTitles: (_props8 = props) == null ? void 0 : _props8.axisTitles,
38227
38348
  idPrefix: props.idPrefix,
38228
- popOverMenuStyles: theme == null || (_theme$charts = theme.charts) == null ? void 0 : _theme$charts.popoverMenus
38349
+ popOverMenuStyles: theme == null || (_theme$charts = theme.charts) == null ? void 0 : _theme$charts.popoverMenus,
38350
+ quadrants: props.quadrants
38229
38351
  })
38230
38352
  })]
38231
38353
  })
@@ -44209,15 +44331,23 @@ var Tooltip$1 = function Tooltip(_ref) {
44209
44331
  fontSize: '15px',
44210
44332
  width: '100%',
44211
44333
  minWidth: MIN_TOOLTIP_WIDTH
44212
- }, ";label:Tooltip;", "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Tooltip.tsx"],"names":[],"mappings":"AAkGqB","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\nconst getTooltipValue = (tooltipData: { [keyId: string]: DataItem }, yKey: string): string | number => {\n  const data = tooltipData[yKey];\n  return data?.formattedValue || data?.value || '';\n};\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                            {getTooltipValue(tooltipData, legendItem.yKey)}\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"]} */"),
44334
+ }, ";label:Tooltip;", "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Tooltip.tsx"],"names":[],"mappings":"AAkGqB","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\nconst getTooltipValue = (tooltipData: { [keyId: string]: DataItem }, yKey: string): string | number => {\n  const data = tooltipData[yKey];\n  return data?.formattedValue || data?.value || '';\n};\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        {tooltipData['__quadrant__'] && (\n          <div\n            className={css({\n              fontFamily: 'inherit',\n              lineHeight: 'inherit',\n              letterSpacing: 'inherit',\n              fontSize: '13px',\n              fontWeight: 'bold',\n            })}\n          >\n            {tooltipData['__quadrant__'].value}\n          </div>\n        )}\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                            {getTooltipValue(tooltipData, legendItem.yKey)}\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"]} */"),
44213
44335
  children: (_tooltipData$xKey$for = (_tooltipData$xKey = tooltipData[xKey]) == null ? void 0 : _tooltipData$xKey.formattedValue) != null ? _tooltipData$xKey$for : tooltipData[xKey].value
44336
+ }), tooltipData['__quadrant__'] && jsxRuntime.jsx("div", {
44337
+ className: /*#__PURE__*/css$1.css( {
44338
+ name: "woqoxg-Tooltip",
44339
+ styles: "font-family:inherit;line-height:inherit;letter-spacing:inherit;font-size:13px;font-weight:bold;label:Tooltip;",
44340
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Tooltip.tsx"],"names":[],"mappings":"AAgHuB","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\nconst getTooltipValue = (tooltipData: { [keyId: string]: DataItem }, yKey: string): string | number => {\n  const data = tooltipData[yKey];\n  return data?.formattedValue || data?.value || '';\n};\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        {tooltipData['__quadrant__'] && (\n          <div\n            className={css({\n              fontFamily: 'inherit',\n              lineHeight: 'inherit',\n              letterSpacing: 'inherit',\n              fontSize: '13px',\n              fontWeight: 'bold',\n            })}\n          >\n            {tooltipData['__quadrant__'].value}\n          </div>\n        )}\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                            {getTooltipValue(tooltipData, legendItem.yKey)}\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"]} */",
44341
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__$5
44342
+ }),
44343
+ children: tooltipData['__quadrant__'].value
44214
44344
  }), jsxRuntime.jsx("table", {
44215
44345
  cellPadding: 0,
44216
44346
  cellSpacing: 0,
44217
44347
  className: /*#__PURE__*/css$1.css( {
44218
44348
  name: "9a1sa-Tooltip",
44219
44349
  styles: "margin:0;border-spacing:0;border-collapse:inherit;border:none;label:Tooltip;",
44220
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Tooltip.tsx"],"names":[],"mappings":"AAiHqB","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\nconst getTooltipValue = (tooltipData: { [keyId: string]: DataItem }, yKey: string): string | number => {\n  const data = tooltipData[yKey];\n  return data?.formattedValue || data?.value || '';\n};\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                            {getTooltipValue(tooltipData, legendItem.yKey)}\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"]} */",
44350
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Tooltip.tsx"],"names":[],"mappings":"AA8HqB","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\nconst getTooltipValue = (tooltipData: { [keyId: string]: DataItem }, yKey: string): string | number => {\n  const data = tooltipData[yKey];\n  return data?.formattedValue || data?.value || '';\n};\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        {tooltipData['__quadrant__'] && (\n          <div\n            className={css({\n              fontFamily: 'inherit',\n              lineHeight: 'inherit',\n              letterSpacing: 'inherit',\n              fontSize: '13px',\n              fontWeight: 'bold',\n            })}\n          >\n            {tooltipData['__quadrant__'].value}\n          </div>\n        )}\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                            {getTooltipValue(tooltipData, legendItem.yKey)}\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"]} */",
44221
44351
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$5
44222
44352
  }),
44223
44353
  children: jsxRuntime.jsxs("tbody", {
@@ -46267,9 +46397,24 @@ var BarChart$5 = function BarChart(_ref) {
46267
46397
  });
46268
46398
  };
46269
46399
 
46400
+ var getQuadrantInfo = function getQuadrantInfo(x, y, innerWidth, innerHeight, quadrantLabels) {
46401
+ if (!quadrantLabels) return null;
46402
+ var midX = innerWidth / 2;
46403
+ var midY = innerHeight / 2;
46404
+ if (x >= midX && y < midY) {
46405
+ return quadrantLabels.quadrantTwo || 'Quadrant 2';
46406
+ } else if (x < midX && y < midY) {
46407
+ return quadrantLabels.quadrantOne || 'Quadrant 1';
46408
+ } else if (x < midX && y >= midY) {
46409
+ return quadrantLabels.quadrantThree || 'Quadrant 3';
46410
+ } else if (x >= midX && y >= midY) {
46411
+ return quadrantLabels.quadrantFour || 'Quadrant 4';
46412
+ }
46413
+ return null;
46414
+ };
46270
46415
  var MAX_BUBBLE_RADIUS = 30;
46271
46416
  var BubbleChart$4 = function BubbleChart(_ref) {
46272
- var _theme$axis;
46417
+ var _chart$quadrants$labe, _chart$quadrants$labe2, _chart$quadrants$labe3, _chart$quadrants$labe4, _theme$axis;
46273
46418
  var chart = _ref.chart,
46274
46419
  options = _ref.options,
46275
46420
  theme = _ref.theme,
@@ -46354,7 +46499,7 @@ var BubbleChart$4 = function BubbleChart(_ref) {
46354
46499
  }
46355
46500
  return null;
46356
46501
  }, [innerWidth, chart.x, chart.data]);
46357
- var _yScale = useYScale(innerHeight, chart.y.scale);
46502
+ var _yScale2 = useYScale(innerHeight, chart.y.scale);
46358
46503
  var dataFlattened = useFlattenedData(xScaleKey, xScaleDataType, chart.data, chart.y.keys).flat();
46359
46504
  var dataWithBubbleSize = dataFlattened.map(function (d, i) {
46360
46505
  return _extends({}, d, {
@@ -46373,13 +46518,30 @@ var BubbleChart$4 = function BubbleChart(_ref) {
46373
46518
  xScale: xScale,
46374
46519
  chartType: 'bubble'
46375
46520
  });
46521
+ if (tooltipData != null && tooltipData.tooltipData) {
46522
+ var _tooltipData$tooltipD, _tooltipData$tooltipD2;
46523
+ var xValue = (_tooltipData$tooltipD = tooltipData.tooltipData[xScaleKey]) == null ? void 0 : _tooltipData$tooltipD.value;
46524
+ var yValue = (_tooltipData$tooltipD2 = tooltipData.tooltipData[chart.y.keys[0]]) == null ? void 0 : _tooltipData$tooltipD2.value;
46525
+ if (xValue !== null && xValue !== undefined && yValue !== null && yValue !== undefined) {
46526
+ var _ref2, _yScale;
46527
+ var bubbleX = (_ref2 = xScale(xValue)) != null ? _ref2 : 0;
46528
+ var bubbleY = (_yScale = _yScale2(yValue)) != null ? _yScale : 0;
46529
+ var quadrantInfo = getQuadrantInfo(bubbleX, bubbleY, innerWidth, innerHeight, chart.quadrants.labels);
46530
+ if (chart.quadrants.enabled && quadrantInfo) {
46531
+ tooltipData.tooltipData['__quadrant__'] = {
46532
+ value: quadrantInfo,
46533
+ formattedValue: quadrantInfo
46534
+ };
46535
+ }
46536
+ }
46537
+ }
46376
46538
  showTooltip({
46377
46539
  lineLeft: tooltipData == null ? void 0 : tooltipData.lineLeft,
46378
46540
  tooltipLeft: event.pageX,
46379
46541
  tooltipTop: event.pageY,
46380
46542
  tooltipData: tooltipData == null ? void 0 : tooltipData.tooltipData
46381
46543
  });
46382
- }, [showTooltip, xScale, margin, xKey, xScaleKey, xScaleDataType, chart.x.scale.ordering, chart.data]);
46544
+ }, [showTooltip, xScale, _yScale2, margin, xKey, xScaleKey, xScaleDataType, chart.x.scale.ordering, chart.data, chart.y.keys, chart.quadrants, innerWidth, innerHeight]);
46383
46545
  var handleMouseLeave = React.useCallback(function () {
46384
46546
  hideTooltip();
46385
46547
  }, [hideTooltip]);
@@ -46409,9 +46571,16 @@ var BubbleChart$4 = function BubbleChart(_ref) {
46409
46571
  children: [jsxRuntime.jsxs(group.Group, {
46410
46572
  left: margin.left,
46411
46573
  top: margin.top,
46412
- children: [jsxRuntime.jsx(GridRows, {
46574
+ children: [chart.quadrants.enabled && jsxRuntime.jsx(QuadrantOverlay, {
46575
+ innerWidth: innerWidth,
46576
+ innerHeight: innerHeight,
46577
+ topLeftText: (_chart$quadrants$labe = chart.quadrants.labels) == null ? void 0 : _chart$quadrants$labe.quadrantOne,
46578
+ topRightText: (_chart$quadrants$labe2 = chart.quadrants.labels) == null ? void 0 : _chart$quadrants$labe2.quadrantTwo,
46579
+ bottomLeftText: (_chart$quadrants$labe3 = chart.quadrants.labels) == null ? void 0 : _chart$quadrants$labe3.quadrantThree,
46580
+ bottomRightText: (_chart$quadrants$labe4 = chart.quadrants.labels) == null ? void 0 : _chart$quadrants$labe4.quadrantFour
46581
+ }), jsxRuntime.jsx(GridRows, {
46413
46582
  ticks: yTickValues,
46414
- yScale: _yScale,
46583
+ yScale: _yScale2,
46415
46584
  width: innerWidth,
46416
46585
  height: innerHeight,
46417
46586
  removeStroke: options.removeStroke,
@@ -46430,7 +46599,7 @@ var BubbleChart$4 = function BubbleChart(_ref) {
46430
46599
  y: chart.y,
46431
46600
  margin: margin,
46432
46601
  themeCSS: themeCSS,
46433
- yScale: _yScale,
46602
+ yScale: _yScale2,
46434
46603
  ticks: yTickValues,
46435
46604
  stroke: theme == null || (_theme$axis = theme.axis) == null ? void 0 : _theme$axis.stroke
46436
46605
  }), jsxRuntime.jsx(group.Group, {
@@ -46442,7 +46611,7 @@ var BubbleChart$4 = function BubbleChart(_ref) {
46442
46611
  xScaleKey: xScaleKey,
46443
46612
  xScaleDataType: xScaleDataType,
46444
46613
  xScale: xScale,
46445
- yScale: _yScale,
46614
+ yScale: _yScale2,
46446
46615
  chart: chart
46447
46616
  })
46448
46617
  })]
@@ -46457,7 +46626,7 @@ var BubbleChart$4 = function BubbleChart(_ref) {
46457
46626
  dataType: xScaleDataType,
46458
46627
  legendItems: chart.lines,
46459
46628
  yScale: function yScale(yKey) {
46460
- return _yScale(tooltipData[yKey].value !== null ? tooltipData[yKey].value : 0);
46629
+ return _yScale2(tooltipData[yKey].value !== null ? tooltipData[yKey].value : 0);
46461
46630
  }
46462
46631
  // @ts-ignore
46463
46632
  ,
@@ -46470,7 +46639,7 @@ var BubbleChart$4 = function BubbleChart(_ref) {
46470
46639
  }), jsxRuntime.jsx(GoalLines$1, {
46471
46640
  goalLines: chart.goalLines,
46472
46641
  y: function y(d) {
46473
- return _yScale(d);
46642
+ return _yScale2(d);
46474
46643
  },
46475
46644
  margin: margin,
46476
46645
  width: innerWidth
@@ -46493,23 +46662,23 @@ var BubbleChart$4 = function BubbleChart(_ref) {
46493
46662
  })]
46494
46663
  });
46495
46664
  };
46496
- function Bubbles(_ref2) {
46497
- var yKeys = _ref2.yKeys,
46498
- data = _ref2.data,
46499
- xScaleKey = _ref2.xScaleKey,
46500
- xScale = _ref2.xScale,
46501
- yScale = _ref2.yScale,
46502
- chart = _ref2.chart;
46665
+ function Bubbles(_ref3) {
46666
+ var yKeys = _ref3.yKeys,
46667
+ data = _ref3.data,
46668
+ xScaleKey = _ref3.xScaleKey,
46669
+ xScale = _ref3.xScale,
46670
+ yScale = _ref3.yScale,
46671
+ chart = _ref3.chart;
46503
46672
  var getBubbleColor = function getBubbleColor(index) {
46504
46673
  return chart.legend.items[index % chart.legend.items.length].color;
46505
46674
  };
46506
46675
  return jsxRuntime.jsx(React.Fragment, {
46507
46676
  children: data.map(function (d, index) {
46508
- var _ref3, _yScale2;
46677
+ var _ref4, _yScale3;
46509
46678
  return jsxRuntime.jsx(glyph.GlyphDot, {
46510
46679
  r: d.bubbleSize,
46511
- cx: (_ref3 = xScale(d[xScaleKey])) != null ? _ref3 : 0,
46512
- cy: (_yScale2 = yScale(d[yKeys[0]])) != null ? _yScale2 : 0,
46680
+ cx: (_ref4 = xScale(d[xScaleKey])) != null ? _ref4 : 0,
46681
+ cy: (_yScale3 = yScale(d[yKeys[0]])) != null ? _yScale3 : 0,
46513
46682
  fill: getBubbleColor(index)
46514
46683
  }, "bubble_chart_" + index);
46515
46684
  })
@@ -48509,7 +48678,8 @@ var buildBubbleChartRepresentation = function buildBubbleChartRepresentation(_re
48509
48678
  yAxisPrefix = _ref.yAxisPrefix,
48510
48679
  approxYAxisLabelCount = _ref.approxYAxisLabelCount,
48511
48680
  _valueAlias = _ref.valueAlias,
48512
- zFieldId = _ref.zFieldId;
48681
+ zFieldId = _ref.zFieldId,
48682
+ quadrantsAttributes = _ref.quadrantsAttributes;
48513
48683
  var allPrefixes = {};
48514
48684
  var allPostfixes = {};
48515
48685
  var nullValues = {};
@@ -48690,6 +48860,15 @@ var buildBubbleChartRepresentation = function buildBubbleChartRepresentation(_re
48690
48860
  keyFormatted: (_row$groupByKey$forma = (_row$groupByKey3 = row[groupByKey]) == null ? void 0 : _row$groupByKey3.formattedValue) != null ? _row$groupByKey$forma : ''
48691
48861
  };
48692
48862
  });
48863
+ var quadrants = quadrantsAttributes != null ? quadrantsAttributes : {
48864
+ enabled: false,
48865
+ labels: {
48866
+ quadrantOne: 'Quadrant 1',
48867
+ quadrantTwo: 'Quadrant 2',
48868
+ quadrantThree: 'Quadrant 3',
48869
+ quadrantFour: 'Quadrant 4'
48870
+ }
48871
+ };
48693
48872
 
48694
48873
  // ----- Conditional Formatting -----
48695
48874
 
@@ -48735,7 +48914,8 @@ var buildBubbleChartRepresentation = function buildBubbleChartRepresentation(_re
48735
48914
  legend: {
48736
48915
  keys: legendKeys,
48737
48916
  items: legendItems
48738
- }
48917
+ },
48918
+ quadrants: quadrants
48739
48919
  };
48740
48920
  return chart;
48741
48921
  };
@@ -48787,6 +48967,7 @@ var BubbleChartV2View = function BubbleChartV2View(props) {
48787
48967
  order: props.attributes.order,
48788
48968
  numberFormatOptions: props.numberFormatOptions,
48789
48969
  dateTimeFormatOptions: props.dateTimeFormatOptions,
48970
+ quadrantsAttributes: props.attributes.quadrants,
48790
48971
  goalLineAttributes: (_props$attributes$goa = props.attributes.goalLines) != null ? _props$attributes$goa : [],
48791
48972
  conditionalFormattingAttributes: props.attributes.conditionalFormattingRules,
48792
48973
  defaultFormats: props.defaultFormats
@@ -65800,6 +65981,97 @@ var WaterfallColorsSection = function WaterfallColorsSection(props) {
65800
65981
  });
65801
65982
  };
65802
65983
 
65984
+ var QuadrantSection = function QuadrantSection(props) {
65985
+ var _props$attributes$qua, _props$attributes$qua2, _props$section;
65986
+ var _useDashboardBehaviou = useDashboardBehaviourContext(),
65987
+ textOverride = _useDashboardBehaviou.textOverride;
65988
+ var isQuadrantsEnabled = ((_props$attributes$qua = props.attributes.quadrants) == null ? void 0 : _props$attributes$qua.enabled) || false;
65989
+ var handleQuadrantsToggle = function handleQuadrantsToggle(enabled) {
65990
+ if (enabled) {
65991
+ props.setAttributes({
65992
+ quadrants: {
65993
+ enabled: true,
65994
+ labels: {
65995
+ quadrantOne: 'Quadrant 1',
65996
+ quadrantTwo: 'Quadrant 2',
65997
+ quadrantThree: 'Quadrant 3',
65998
+ quadrantFour: 'Quadrant 4'
65999
+ }
66000
+ }
66001
+ });
66002
+ } else {
66003
+ props.setAttributes({
66004
+ quadrants: {
66005
+ enabled: false,
66006
+ labels: {
66007
+ quadrantOne: undefined,
66008
+ quadrantTwo: undefined,
66009
+ quadrantThree: undefined,
66010
+ quadrantFour: undefined
66011
+ }
66012
+ }
66013
+ });
66014
+ }
66015
+ };
66016
+ var handleQuadrantLabelChange = React.useCallback(function (quadrantKey, value) {
66017
+ var _extends2;
66018
+ var currentQuadrants = props.attributes.quadrants || {
66019
+ enabled: true,
66020
+ labels: {
66021
+ quadrantOne: 'Quadrant 1',
66022
+ quadrantTwo: 'Quadrant 2',
66023
+ quadrantThree: 'Quadrant 3',
66024
+ quadrantFour: 'Quadrant 4'
66025
+ }
66026
+ };
66027
+ props.setAttributes({
66028
+ quadrants: _extends({}, currentQuadrants, {
66029
+ labels: _extends({}, currentQuadrants.labels, (_extends2 = {}, _extends2[quadrantKey] = value, _extends2))
66030
+ })
66031
+ });
66032
+ }, [props]);
66033
+ var debouncedHandleQuadrantLabelChange = React.useMemo(function () {
66034
+ return _.debounce(handleQuadrantLabelChange, 400);
66035
+ }, [handleQuadrantLabelChange]);
66036
+ var quadrantLabels = ((_props$attributes$qua2 = props.attributes.quadrants) == null ? void 0 : _props$attributes$qua2.labels) || {
66037
+ quadrantOne: 'Quadrant 1',
66038
+ quadrantTwo: 'Quadrant 2',
66039
+ quadrantThree: 'Quadrant 3',
66040
+ quadrantFour: 'Quadrant 4'
66041
+ };
66042
+ return jsxRuntime.jsx(Section, {
66043
+ tooltip: (_props$section = props.section) == null ? void 0 : _props$section.description,
66044
+ children: jsxRuntime.jsxs(Grid, {
66045
+ gap: "1rem",
66046
+ children: [jsxRuntime.jsx(BooleanInput, {
66047
+ label: textOverride('plot_quadrants', 'Plot quadrants'),
66048
+ setChecked: handleQuadrantsToggle,
66049
+ currentValue: isQuadrantsEnabled,
66050
+ id: "show-quadrants-input"
66051
+ }), isQuadrantsEnabled && jsxRuntime.jsx(Section.Grid, {
66052
+ "data-component": "quadrant-labels",
66053
+ gap: "1rem",
66054
+ children: Object.entries(quadrantLabels).map(function (_ref, index) {
66055
+ var key = _ref[0],
66056
+ value = _ref[1];
66057
+ return jsxRuntime.jsx(Section, {
66058
+ title: textOverride("quadrant_" + (index + 1), "Quadrant " + (index + 1)),
66059
+ children: jsxRuntime.jsx(TextInput, {
66060
+ label: textOverride("quadrant_" + (index + 1), 'Label'),
66061
+ currentValue: value,
66062
+ setText: function setText(inputValue) {
66063
+ return debouncedHandleQuadrantLabelChange(key, inputValue);
66064
+ },
66065
+ id: "quadrant-" + (index + 1) + "-input",
66066
+ maxLength: 30
66067
+ })
66068
+ }, key);
66069
+ })
66070
+ })]
66071
+ })
66072
+ });
66073
+ };
66074
+
65803
66075
  var FormatPanelFromConfig = function FormatPanelFromConfig(props) {
65804
66076
  return jsxRuntime.jsx(EditorGrid, {
65805
66077
  children: props == null ? void 0 : props.formatPanelConfig.map(function (section, i) {
@@ -65832,6 +66104,8 @@ var FormatPanelFromConfig = function FormatPanelFromConfig(props) {
65832
66104
  section: section
65833
66105
  })), section.type === 'waterfallColors' && jsxRuntime.jsx(WaterfallColorsSection, _extends({}, props, {
65834
66106
  section: section
66107
+ })), section.type === 'quadrants' && jsxRuntime.jsx(QuadrantSection, _extends({}, props, {
66108
+ section: section
65835
66109
  })), section.type === 'conditionalFormatting' && jsxRuntime.jsx(ConditionalFormattingSection, _extends({}, props, {
65836
66110
  section: section
65837
66111
  })), section.type === 'goalLine' && jsxRuntime.jsx(GoalLineSection, _extends({}, props, {