@vizzly/dashboard 0.15.0-dev-4a90180f693d878d9bfd1449280e08ac6afa15d7 → 0.15.0-dev-0deaef621a2f2e1193124d502137c2500f5e1855

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.
@@ -50,10 +50,10 @@ import html2canvas from 'html2canvas';
50
50
  import jsPDF from 'jspdf';
51
51
  import { localPoint } from '@visx/event';
52
52
  import { bisector } from '@visx/vendor/d3-array';
53
- import { GridRows as GridRows$1, GridColumns as GridColumns$1 } from '@visx/grid';
54
53
  import { AxisBottom as AxisBottom$1, AxisLeft as AxisLeft$1 } from '@visx/axis';
55
54
  import { Text } from '@visx/text';
56
55
  import { Annotation as Annotation$1, Label as Label$1 } from '@visx/annotation';
56
+ import { GridRows as GridRows$1, GridColumns as GridColumns$1 } from '@visx/grid';
57
57
  import { GlyphDot } from '@visx/glyph';
58
58
  import { RectClipPath } from '@visx/clip-path';
59
59
  import { Point } from '@visx/point';
@@ -6921,18 +6921,18 @@ var ComboChartV2 = function ComboChartV2(config) {
6921
6921
  }), namespace(CONSTANTS$8, 'combo_chart_dimension'), namespace(CONSTANTS$8, 'sort'), namespace(CONSTANTS$8, 'filter'), namespace(CONSTANTS$8, 'custom_metrics'), namespace(CONSTANTS$8, 'limit')];
6922
6922
  },
6923
6923
  formatPanelConfig: function formatPanelConfig() {
6924
- var _CONSTANTS$format_pan, _CONSTANTS$format_pan2, _CONSTANTS$format_pan3, _CONSTANTS$format_pan4, _CONSTANTS$format_pan5, _CONSTANTS$format_pan6, _CONSTANTS$format_pan7, _CONSTANTS$format_pan8;
6924
+ var _CONSTANTS$format_pan, _CONSTANTS$format_pan2, _CONSTANTS$format_pan3, _CONSTANTS$format_pan4, _CONSTANTS$format_pan5, _CONSTANTS$format_pan6, _CONSTANTS$format_pan7, _CONSTANTS$format_pan8, _CONSTANTS$format_pan9;
6925
6925
  return [headingConstant(CONSTANTS$8), _extends({}, namespace(CONSTANTS$8, 'chart_styles'), {
6926
- subSection: [(_CONSTANTS$format_pan = CONSTANTS$8.format_panel.chart_styles) == null ? void 0 : _CONSTANTS$format_pan.subSectionDefinition.legend, (_CONSTANTS$format_pan2 = CONSTANTS$8.format_panel.chart_styles) == null ? void 0 : _CONSTANTS$format_pan2.subSectionDefinition.labels]
6926
+ subSection: [(_CONSTANTS$format_pan = CONSTANTS$8.format_panel.chart_styles) == null ? void 0 : _CONSTANTS$format_pan.subSectionDefinition.stacked, (_CONSTANTS$format_pan2 = CONSTANTS$8.format_panel.chart_styles) == null ? void 0 : _CONSTANTS$format_pan2.subSectionDefinition.legend, (_CONSTANTS$format_pan3 = CONSTANTS$8.format_panel.chart_styles) == null ? void 0 : _CONSTANTS$format_pan3.subSectionDefinition.labels]
6927
6927
  }), axisLabelsConstants(CONSTANTS$8), _extends({}, namespace(CONSTANTS$8, 'conditional_formatting'), {
6928
6928
  ruleType: 'backgroundColor',
6929
6929
  subSection: [{
6930
- title: (_CONSTANTS$format_pan3 = (_CONSTANTS$format_pan4 = CONSTANTS$8.format_panel.conditional_formatting) == null || (_CONSTANTS$format_pan4 = _CONSTANTS$format_pan4.subSectionDefinition) == null ? void 0 : _CONSTANTS$format_pan4.bar.title) != null ? _CONSTANTS$format_pan3 : '',
6931
- namespace: (_CONSTANTS$format_pan5 = CONSTANTS$8.format_panel.conditional_formatting) == null || (_CONSTANTS$format_pan5 = _CONSTANTS$format_pan5.subSectionDefinition) == null ? void 0 : _CONSTANTS$format_pan5.bar.namespace,
6930
+ title: (_CONSTANTS$format_pan4 = (_CONSTANTS$format_pan5 = CONSTANTS$8.format_panel.conditional_formatting) == null || (_CONSTANTS$format_pan5 = _CONSTANTS$format_pan5.subSectionDefinition) == null ? void 0 : _CONSTANTS$format_pan5.bar.title) != null ? _CONSTANTS$format_pan4 : '',
6931
+ namespace: (_CONSTANTS$format_pan6 = CONSTANTS$8.format_panel.conditional_formatting) == null || (_CONSTANTS$format_pan6 = _CONSTANTS$format_pan6.subSectionDefinition) == null ? void 0 : _CONSTANTS$format_pan6.bar.namespace,
6932
6932
  propKey: 'bar'
6933
6933
  }, {
6934
- title: (_CONSTANTS$format_pan6 = (_CONSTANTS$format_pan7 = CONSTANTS$8.format_panel.conditional_formatting) == null || (_CONSTANTS$format_pan7 = _CONSTANTS$format_pan7.subSectionDefinition) == null ? void 0 : _CONSTANTS$format_pan7.line.title) != null ? _CONSTANTS$format_pan6 : '',
6935
- namespace: (_CONSTANTS$format_pan8 = CONSTANTS$8.format_panel.conditional_formatting) == null || (_CONSTANTS$format_pan8 = _CONSTANTS$format_pan8.subSectionDefinition) == null ? void 0 : _CONSTANTS$format_pan8.line.namespace,
6934
+ title: (_CONSTANTS$format_pan7 = (_CONSTANTS$format_pan8 = CONSTANTS$8.format_panel.conditional_formatting) == null || (_CONSTANTS$format_pan8 = _CONSTANTS$format_pan8.subSectionDefinition) == null ? void 0 : _CONSTANTS$format_pan8.line.title) != null ? _CONSTANTS$format_pan7 : '',
6935
+ namespace: (_CONSTANTS$format_pan9 = CONSTANTS$8.format_panel.conditional_formatting) == null || (_CONSTANTS$format_pan9 = _CONSTANTS$format_pan9.subSectionDefinition) == null ? void 0 : _CONSTANTS$format_pan9.line.namespace,
6936
6936
  propKey: 'line'
6937
6937
  }]
6938
6938
  }), namespace(CONSTANTS$8, 'goal_line')];
@@ -44351,388 +44351,6 @@ function buildComboTooltipData(barTooltipData, lineTooltipData, xScaleKey) {
44351
44351
  return barTooltipData && lineTooltipData ? _extends({}, barTooltipData, lineTooltipData) : undefined;
44352
44352
  }
44353
44353
 
44354
- var LegendItemBox = function LegendItemBox(_ref) {
44355
- var color = _ref.color,
44356
- style = _ref.style;
44357
- return jsx("svg", {
44358
- width: 10,
44359
- height: 10,
44360
- style: {
44361
- display: 'block'
44362
- },
44363
- children: style.type === 'line' ? style.strokeDasharray !== null ? jsx("line", {
44364
- x1: "0",
44365
- y1: "5",
44366
- x2: "10",
44367
- y2: "5",
44368
- stroke: color,
44369
- strokeWidth: style.strokeWidth,
44370
- strokeDasharray: 2
44371
- }) : jsx("line", {
44372
- x1: "0",
44373
- y1: "5",
44374
- x2: "10",
44375
- y2: "5",
44376
- stroke: color,
44377
- strokeWidth: style.strokeWidth
44378
- }) : jsx("rect", {
44379
- fill: color,
44380
- width: 10,
44381
- height: 10,
44382
- rx: "2"
44383
- })
44384
- });
44385
- };
44386
- var LegendItemSquare = function LegendItemSquare(_ref2) {
44387
- var color = _ref2.color;
44388
- return jsx("svg", {
44389
- width: 8,
44390
- height: 8,
44391
- style: {
44392
- display: 'block'
44393
- },
44394
- children: jsx("rect", {
44395
- fill: color,
44396
- width: 8,
44397
- height: 8,
44398
- rx: "2"
44399
- })
44400
- });
44401
- };
44402
- var LegendItemTriangle = function LegendItemTriangle(_ref3) {
44403
- var color = _ref3.color;
44404
- return jsx("svg", {
44405
- width: 8,
44406
- height: 8,
44407
- style: {
44408
- display: 'block',
44409
- borderRadius: 1
44410
- },
44411
- children: jsx("polygon", {
44412
- points: "0,0 10,10 0,10",
44413
- fill: color
44414
- })
44415
- });
44416
- };
44417
-
44418
- function _EMOTION_STRINGIFIED_CSS_ERROR__$5() { 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)."; }
44419
- var MIN_TOOLTIP_WIDTH = 180;
44420
- var TOOLTIP_OFFSET = 20;
44421
- var SCROLLBAR_WIDTH = 40;
44422
- var getTooltipValue = function getTooltipValue(tooltipData, yKey) {
44423
- var data = tooltipData[yKey];
44424
- return (data == null ? void 0 : data.formattedValue) || (data == null ? void 0 : data.value) || '';
44425
- };
44426
- var Tooltip$1 = function Tooltip(_ref) {
44427
- var _tooltipData$xKey$for, _tooltipData$xKey;
44428
- var keys = _ref.keys,
44429
- showRoundedTotal = _ref.showRoundedTotal,
44430
- tooltipData = _ref.tooltipData,
44431
- tooltipLeft = _ref.tooltipLeft,
44432
- tooltipTop = _ref.tooltipTop,
44433
- xKey = _ref.xKey,
44434
- yKeys = _ref.yKeys,
44435
- theme = _ref.theme,
44436
- items = _ref.items,
44437
- _ref$shouldShowColorL = _ref.shouldShowColorLegend,
44438
- shouldShowColorLegend = _ref$shouldShowColorL === void 0 ? true : _ref$shouldShowColorL;
44439
- var tooltipRef = useRef(null);
44440
- var _useState = useState({
44441
- left: tooltipLeft
44442
- }),
44443
- position = _useState[0],
44444
- setPosition = _useState[1];
44445
- useEffect(function () {
44446
- var adjustTooltipPosition = function adjustTooltipPosition() {
44447
- var tooltipElement = tooltipRef.current;
44448
- if (tooltipElement) {
44449
- var screenWidth = window.innerWidth;
44450
- var rect = tooltipElement.getBoundingClientRect();
44451
- var width = rect.width;
44452
- if (width < MIN_TOOLTIP_WIDTH) {
44453
- width = MIN_TOOLTIP_WIDTH;
44454
- }
44455
- var left = tooltipLeft + TOOLTIP_OFFSET;
44456
- if (tooltipLeft + width > screenWidth - SCROLLBAR_WIDTH) {
44457
- left = tooltipLeft - width - TOOLTIP_OFFSET;
44458
- }
44459
- setPosition({
44460
- left: left
44461
- });
44462
- }
44463
- };
44464
- adjustTooltipPosition();
44465
- }, [tooltipLeft]);
44466
- return /*#__PURE__*/createPortal(jsx("div", {
44467
- ref: tooltipRef,
44468
- style: _extends({
44469
- position: 'absolute',
44470
- left: position.left,
44471
- top: tooltipTop,
44472
- zIndex: 2147483647 * 10
44473
- }, theme),
44474
- children: jsxs("div", {
44475
- style: {
44476
- wordBreak: 'break-all'
44477
- },
44478
- children: [jsx("div", {
44479
- className: /*#__PURE__*/css$1({
44480
- fontFamily: 'inherit',
44481
- lineHeight: 'inherit',
44482
- letterSpacing: 'inherit',
44483
- fontWeight: 'bold',
44484
- fontSize: '15px',
44485
- width: '100%',
44486
- minWidth: MIN_TOOLTIP_WIDTH
44487
- }, process.env.NODE_ENV === "production" ? "" : ";label:Tooltip;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Tooltip.tsx"],"names":[],"mappings":"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"]} */"),
44488
- children: (_tooltipData$xKey$for = (_tooltipData$xKey = tooltipData[xKey]) == null ? void 0 : _tooltipData$xKey.formattedValue) != null ? _tooltipData$xKey$for : tooltipData[xKey].value
44489
- }), tooltipData['__quadrant__'] && jsx("div", {
44490
- className: /*#__PURE__*/css$1(process.env.NODE_ENV === "production" ? {
44491
- name: "1knrfgk",
44492
- styles: "font-family:inherit;line-height:inherit;letter-spacing:inherit;font-size:13px;font-weight:bold"
44493
- } : {
44494
- name: "woqoxg-Tooltip",
44495
- styles: "font-family:inherit;line-height:inherit;letter-spacing:inherit;font-size:13px;font-weight:bold;label:Tooltip;",
44496
- 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"]} */",
44497
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__$5
44498
- }),
44499
- children: tooltipData['__quadrant__'].value
44500
- }), jsx("table", {
44501
- cellPadding: 0,
44502
- cellSpacing: 0,
44503
- className: /*#__PURE__*/css$1(process.env.NODE_ENV === "production" ? {
44504
- name: "x8luwd",
44505
- styles: "margin:0;border-spacing:0;border-collapse:inherit;border:none"
44506
- } : {
44507
- name: "9a1sa-Tooltip",
44508
- styles: "margin:0;border-spacing:0;border-collapse:inherit;border:none;label:Tooltip;",
44509
- 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"]} */",
44510
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__$5
44511
- }),
44512
- children: jsxs("tbody", {
44513
- children: [items.map(function (item, index) {
44514
- var _item$legendItems;
44515
- return jsx(Fragment, {
44516
- children: (_item$legendItems = item.legendItems) == null ? void 0 : _item$legendItems.map(function (legendItem, index) {
44517
- var _item$visibleYKeys, _item$conditionalForm;
44518
- if (!tooltipData[legendItem.yKey] || tooltipData[legendItem.yKey].value === null) {
44519
- // yKey could not be found in tooltipData
44520
- return null;
44521
- }
44522
- return ((_item$visibleYKeys = item.visibleYKeys) == null ? void 0 : _item$visibleYKeys.includes(legendItem.yKey)) && jsxs("tr", {
44523
- children: [shouldShowColorLegend && jsx("td", {
44524
- style: {
44525
- verticalAlign: 'middle',
44526
- padding: index === 0 ? '12px 8px 0 0' : '8px 8px 0 0',
44527
- width: 'auto'
44528
- },
44529
- children: jsx(LegendItemBox, {
44530
- color: getColor({
44531
- defaultColor: legendItem.color,
44532
- value: tooltipData[legendItem.yKey].value,
44533
- yKey: legendItem.yKey,
44534
- conditionalFormattingRules: (_item$conditionalForm = item.conditionalFormattingRules) != null ? _item$conditionalForm : []
44535
- }),
44536
- style: legendItem.style,
44537
- yKey: legendItem.yKey
44538
- })
44539
- }), jsx("td", {
44540
- style: {
44541
- padding: '8px 0 0 0'
44542
- },
44543
- children: keys[legendItem.yKey].keyFormatted
44544
- }), jsx("td", {
44545
- style: {
44546
- fontWeight: 'bold',
44547
- padding: '8px 0 0 16px'
44548
- },
44549
- children: getTooltipValue(tooltipData, legendItem.yKey)
44550
- })]
44551
- }, legendItem.yKey + "-" + index + "-" + tooltipData[legendItem.yKey].value);
44552
- })
44553
- }, index);
44554
- }), showRoundedTotal && yKeys && jsxs("tr", {
44555
- children: [jsx("td", {
44556
- colSpan: 2,
44557
- style: {
44558
- padding: '12px 0 0 0'
44559
- },
44560
- children: "Rounded Total"
44561
- }), jsx("td", {
44562
- style: {
44563
- fontWeight: 'bold',
44564
- padding: '12px 0 0 16px'
44565
- },
44566
- children: yKeys.reduce(function (total, key) {
44567
- return total + Math.round(tooltipData[key].value);
44568
- }, 0)
44569
- })]
44570
- })]
44571
- })
44572
- })]
44573
- })
44574
- }), document.body);
44575
- };
44576
-
44577
- function _EMOTION_STRINGIFIED_CSS_ERROR__$6() { 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)."; }
44578
- var LegendItem = function LegendItem(_ref) {
44579
- var yKey = _ref.yKey,
44580
- yKeyFormatted = _ref.yKeyFormatted,
44581
- color = _ref.color,
44582
- style = _ref.style,
44583
- onClick = _ref.onClick,
44584
- visible = _ref.visible,
44585
- conditionalFormattingRules = _ref.conditionalFormattingRules;
44586
- var relevantRules = useMemo(function () {
44587
- return conditionalFormattingRules.filter(function (rule) {
44588
- return yKey.includes(rule.yKey);
44589
- });
44590
- }, [conditionalFormattingRules]);
44591
- return jsxs("button", {
44592
- type: "button",
44593
- style: {
44594
- all: 'unset',
44595
- display: 'flex',
44596
- flexWrap: 'nowrap',
44597
- alignItems: 'center',
44598
- outline: 'revert',
44599
- gap: '4px',
44600
- padding: '4px',
44601
- cursor: 'pointer',
44602
- marginRight: '10px'
44603
- },
44604
- onClick: onClick,
44605
- children: [style.type === 'line' && jsxs("span", {
44606
- className: /*#__PURE__*/css$1(process.env.NODE_ENV === "production" ? {
44607
- name: "1mfeugk",
44608
- styles: "height:10px;display:flex"
44609
- } : {
44610
- name: "mefz6m-LegendItem",
44611
- styles: "height:10px;display:flex;label:LegendItem;",
44612
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZEl0ZW0udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWlEeUIiLCJmaWxlIjoiTGVnZW5kSXRlbS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgdXNlTWVtbyB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IExlZ2VuZEl0ZW1Cb3ggfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94JztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBMZWdlbmRJdGVtU3F1YXJlLCBMZWdlbmRJdGVtVHJpYW5nbGUgfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94L0xlZ2VuZEl0ZW1Cb3gnO1xuaW1wb3J0IHsgU2hhcGVEZWZpbml0aW9uLCBDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9DaGFydHNWMi90eXBlcyc7XG5pbXBvcnQgeyBMaW5lU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9MaW5lQ2hhcnRWMi90eXBlcyc7XG5pbXBvcnQgeyBCYXJTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0JhckNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQXJlYVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQXJlYUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQnViYmxlU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9CdWJibGVDaGFydFYyL3R5cGVzJztcblxuaW50ZXJmYWNlIExlZ2VuZEl0ZW1Qcm9wczxUPiBleHRlbmRzIFNoYXBlRGVmaW5pdGlvbjxUPiB7XG4gIG9uQ2xpY2s6ICgpID0+IHZvaWQ7XG4gIHZpc2libGU6IGJvb2xlYW47XG4gIHlLZXlGb3JtYXR0ZWQ6IHN0cmluZyB8IHVuZGVmaW5lZDtcbiAgY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXM6IEFycmF5PENvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGU+O1xufVxuXG5leHBvcnQgY29uc3QgTGVnZW5kSXRlbSA9ICh7XG4gIHlLZXksXG4gIHlLZXlGb3JtYXR0ZWQsXG4gIGNvbG9yLFxuICBzdHlsZSxcbiAgb25DbGljayxcbiAgdmlzaWJsZSxcbiAgY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXMsXG59OiBMZWdlbmRJdGVtUHJvcHM8QmFyU3R5bGVzIHwgTGluZVN0eWxlcyB8IEFyZWFTdHlsZXMgfCBCdWJibGVTdHlsZXM+KSA9PiB7XG4gIGNvbnN0IHJlbGV2YW50UnVsZXMgPSB1c2VNZW1vKFxuICAgICgpID0+IGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzLmZpbHRlcigocnVsZSkgPT4geUtleS5pbmNsdWRlcyhydWxlLnlLZXkpKSxcbiAgICBbY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXNdLFxuICApO1xuXG4gIHJldHVybiAoXG4gICAgPGJ1dHRvblxuICAgICAga2V5PXtgbGVnZW5kLSR7eUtleX1gfVxuICAgICAgdHlwZT1cImJ1dHRvblwiXG4gICAgICBzdHlsZT17e1xuICAgICAgICBhbGw6ICd1bnNldCcsXG4gICAgICAgIGRpc3BsYXk6ICdmbGV4JyxcbiAgICAgICAgZmxleFdyYXA6ICdub3dyYXAnLFxuICAgICAgICBhbGlnbkl0ZW1zOiAnY2VudGVyJyxcbiAgICAgICAgb3V0bGluZTogJ3JldmVydCcsXG4gICAgICAgIGdhcDogJzRweCcsXG4gICAgICAgIHBhZGRpbmc6ICc0cHgnLFxuICAgICAgICBjdXJzb3I6ICdwb2ludGVyJyxcbiAgICAgICAgbWFyZ2luUmlnaHQ6ICcxMHB4JyxcbiAgICAgIH19XG4gICAgICBvbkNsaWNrPXtvbkNsaWNrfVxuICAgID5cbiAgICAgIHtzdHlsZS50eXBlID09PSAnbGluZScgJiYgKFxuICAgICAgICA8c3BhbiBjbGFzc05hbWU9e2Nzcyh7IGhlaWdodDogMTAsIGRpc3BsYXk6ICdmbGV4JyB9KX0+XG4gICAgICAgICAgPExlZ2VuZEl0ZW1Cb3ggY29sb3I9e2NvbG9yfSBzdHlsZT17c3R5bGUgYXMgTGluZVN0eWxlc30geUtleT17eUtleX0gLz5cbiAgICAgICAgICB7cmVsZXZhbnRSdWxlcy5sZW5ndGggPiAwICYmXG4gICAgICAgICAgICByZWxldmFudFJ1bGVzLm1hcCgocnVsZSkgPT4gKFxuICAgICAgICAgICAgICA8TGVnZW5kSXRlbUJveFxuICAgICAgICAgICAgICAgIGNvbG9yPXtydWxlLmNvbG9yfVxuICAgICAgICAgICAgICAgIGtleT17YHJ1bGUtJHtKU09OLnN0cmluZ2lmeShydWxlKX1gfVxuICAgICAgICAgICAgICAgIHN0eWxlPXtzdHlsZSBhcyBMaW5lU3R5bGVzfVxuICAgICAgICAgICAgICAgIHlLZXk9e3lLZXl9XG4gICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICApKX1cbiAgICAgICAgPC9zcGFuPlxuICAgICAgKX1cbiAgICAgIHtzdHlsZS50eXBlID09PSAnYmFyJyAmJiAoXG4gICAgICAgIDxzcGFuIGNsYXNzTmFtZT17Y3NzKHsgZGlzcGxheTogJ2ZsZXgnLCBmbGV4RGlyZWN0aW9uOiAncm93JywgYWxpZ25JdGVtczogJ2NlbnRlcicsIGdhcDogMiB9KX0+XG4gICAgICAgICAgPExlZ2VuZEl0ZW1TcXVhcmUgY29sb3I9e2NvbG9yfSAvPlxuICAgICAgICAgIHtyZWxldmFudFJ1bGVzLmxlbmd0aCA+IDAgJiZcbiAgICAgICAgICAgIHJlbGV2YW50UnVsZXMubWFwKChydWxlKSA9PiA8TGVnZW5kSXRlbVNxdWFyZSBjb2xvcj17cnVsZS5jb2xvcn0ga2V5PXtgcnVsZS0ke0pTT04uc3RyaW5naWZ5KHJ1bGUpfWB9IC8+KX1cbiAgICAgICAgPC9zcGFuPlxuICAgICAgKX1cbiAgICAgIHtzdHlsZS50eXBlID09PSAnYXJlYScgJiYgKFxuICAgICAgICA8c3BhbiBjbGFzc05hbWU9e2Nzcyh7IGRpc3BsYXk6ICdmbGV4JywgZmxleERpcmVjdGlvbjogJ3JvdycsIGFsaWduSXRlbXM6ICdjZW50ZXInLCBnYXA6IDIgfSl9PlxuICAgICAgICAgIDxMZWdlbmRJdGVtVHJpYW5nbGUgY29sb3I9e2NvbG9yfSAvPlxuICAgICAgICAgIHtyZWxldmFudFJ1bGVzLmxlbmd0aCA+IDAgJiZcbiAgICAgICAgICAgIHJlbGV2YW50UnVsZXMubWFwKChydWxlKSA9PiA8TGVnZW5kSXRlbVRyaWFuZ2xlIGNvbG9yPXtydWxlLmNvbG9yfSBrZXk9e2BydWxlLSR7SlNPTi5zdHJpbmdpZnkocnVsZSl9YH0gLz4pfVxuICAgICAgICA8L3NwYW4+XG4gICAgICApfVxuICAgICAgPHNwYW5cbiAgICAgICAgc3R5bGU9e3tcbiAgICAgICAgICBmb250U2l6ZTogJzEycHgnLFxuICAgICAgICAgIGxpbmVIZWlnaHQ6ICcxNnB4JyxcbiAgICAgICAgICBkaXNwbGF5OiAnYmxvY2snLFxuICAgICAgICAgIHRleHREZWNvcmF0aW9uOiB2aXNpYmxlID8gJ25vbmUnIDogJ2xpbmUtdGhyb3VnaCcsXG4gICAgICAgICAgdGV4dFdyYXA6ICdub3dyYXAnLFxuICAgICAgICB9fVxuICAgICAgPlxuICAgICAgICB7eUtleUZvcm1hdHRlZCA/IHlLZXlGb3JtYXR0ZWQgOiB5S2V5fVxuICAgICAgPC9zcGFuPlxuICAgIDwvYnV0dG9uPlxuICApO1xufTtcbiJdfQ== */",
44613
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__$6
44614
- }),
44615
- children: [jsx(LegendItemBox, {
44616
- color: color,
44617
- style: style,
44618
- yKey: yKey
44619
- }), relevantRules.length > 0 && relevantRules.map(function (rule) {
44620
- return jsx(LegendItemBox, {
44621
- color: rule.color,
44622
- style: style,
44623
- yKey: yKey
44624
- }, "rule-" + JSON.stringify(rule));
44625
- })]
44626
- }), style.type === 'bar' && jsxs("span", {
44627
- className: /*#__PURE__*/css$1(process.env.NODE_ENV === "production" ? {
44628
- name: "6b52m3",
44629
- styles: "display:flex;flex-direction:row;align-items:center;gap:2px"
44630
- } : {
44631
- name: "pglbco-LegendItem",
44632
- styles: "display:flex;flex-direction:row;align-items:center;gap:2px;label:LegendItem;",
44633
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZEl0ZW0udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQStEeUIiLCJmaWxlIjoiTGVnZW5kSXRlbS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgdXNlTWVtbyB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IExlZ2VuZEl0ZW1Cb3ggfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94JztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBMZWdlbmRJdGVtU3F1YXJlLCBMZWdlbmRJdGVtVHJpYW5nbGUgfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94L0xlZ2VuZEl0ZW1Cb3gnO1xuaW1wb3J0IHsgU2hhcGVEZWZpbml0aW9uLCBDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9DaGFydHNWMi90eXBlcyc7XG5pbXBvcnQgeyBMaW5lU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9MaW5lQ2hhcnRWMi90eXBlcyc7XG5pbXBvcnQgeyBCYXJTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0JhckNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQXJlYVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQXJlYUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQnViYmxlU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9CdWJibGVDaGFydFYyL3R5cGVzJztcblxuaW50ZXJmYWNlIExlZ2VuZEl0ZW1Qcm9wczxUPiBleHRlbmRzIFNoYXBlRGVmaW5pdGlvbjxUPiB7XG4gIG9uQ2xpY2s6ICgpID0+IHZvaWQ7XG4gIHZpc2libGU6IGJvb2xlYW47XG4gIHlLZXlGb3JtYXR0ZWQ6IHN0cmluZyB8IHVuZGVmaW5lZDtcbiAgY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXM6IEFycmF5PENvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGU+O1xufVxuXG5leHBvcnQgY29uc3QgTGVnZW5kSXRlbSA9ICh7XG4gIHlLZXksXG4gIHlLZXlGb3JtYXR0ZWQsXG4gIGNvbG9yLFxuICBzdHlsZSxcbiAgb25DbGljayxcbiAgdmlzaWJsZSxcbiAgY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXMsXG59OiBMZWdlbmRJdGVtUHJvcHM8QmFyU3R5bGVzIHwgTGluZVN0eWxlcyB8IEFyZWFTdHlsZXMgfCBCdWJibGVTdHlsZXM+KSA9PiB7XG4gIGNvbnN0IHJlbGV2YW50UnVsZXMgPSB1c2VNZW1vKFxuICAgICgpID0+IGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzLmZpbHRlcigocnVsZSkgPT4geUtleS5pbmNsdWRlcyhydWxlLnlLZXkpKSxcbiAgICBbY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXNdLFxuICApO1xuXG4gIHJldHVybiAoXG4gICAgPGJ1dHRvblxuICAgICAga2V5PXtgbGVnZW5kLSR7eUtleX1gfVxuICAgICAgdHlwZT1cImJ1dHRvblwiXG4gICAgICBzdHlsZT17e1xuICAgICAgICBhbGw6ICd1bnNldCcsXG4gICAgICAgIGRpc3BsYXk6ICdmbGV4JyxcbiAgICAgICAgZmxleFdyYXA6ICdub3dyYXAnLFxuICAgICAgICBhbGlnbkl0ZW1zOiAnY2VudGVyJyxcbiAgICAgICAgb3V0bGluZTogJ3JldmVydCcsXG4gICAgICAgIGdhcDogJzRweCcsXG4gICAgICAgIHBhZGRpbmc6ICc0cHgnLFxuICAgICAgICBjdXJzb3I6ICdwb2ludGVyJyxcbiAgICAgICAgbWFyZ2luUmlnaHQ6ICcxMHB4JyxcbiAgICAgIH19XG4gICAgICBvbkNsaWNrPXtvbkNsaWNrfVxuICAgID5cbiAgICAgIHtzdHlsZS50eXBlID09PSAnbGluZScgJiYgKFxuICAgICAgICA8c3BhbiBjbGFzc05hbWU9e2Nzcyh7IGhlaWdodDogMTAsIGRpc3BsYXk6ICdmbGV4JyB9KX0+XG4gICAgICAgICAgPExlZ2VuZEl0ZW1Cb3ggY29sb3I9e2NvbG9yfSBzdHlsZT17c3R5bGUgYXMgTGluZVN0eWxlc30geUtleT17eUtleX0gLz5cbiAgICAgICAgICB7cmVsZXZhbnRSdWxlcy5sZW5ndGggPiAwICYmXG4gICAgICAgICAgICByZWxldmFudFJ1bGVzLm1hcCgocnVsZSkgPT4gKFxuICAgICAgICAgICAgICA8TGVnZW5kSXRlbUJveFxuICAgICAgICAgICAgICAgIGNvbG9yPXtydWxlLmNvbG9yfVxuICAgICAgICAgICAgICAgIGtleT17YHJ1bGUtJHtKU09OLnN0cmluZ2lmeShydWxlKX1gfVxuICAgICAgICAgICAgICAgIHN0eWxlPXtzdHlsZSBhcyBMaW5lU3R5bGVzfVxuICAgICAgICAgICAgICAgIHlLZXk9e3lLZXl9XG4gICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICApKX1cbiAgICAgICAgPC9zcGFuPlxuICAgICAgKX1cbiAgICAgIHtzdHlsZS50eXBlID09PSAnYmFyJyAmJiAoXG4gICAgICAgIDxzcGFuIGNsYXNzTmFtZT17Y3NzKHsgZGlzcGxheTogJ2ZsZXgnLCBmbGV4RGlyZWN0aW9uOiAncm93JywgYWxpZ25JdGVtczogJ2NlbnRlcicsIGdhcDogMiB9KX0+XG4gICAgICAgICAgPExlZ2VuZEl0ZW1TcXVhcmUgY29sb3I9e2NvbG9yfSAvPlxuICAgICAgICAgIHtyZWxldmFudFJ1bGVzLmxlbmd0aCA+IDAgJiZcbiAgICAgICAgICAgIHJlbGV2YW50UnVsZXMubWFwKChydWxlKSA9PiA8TGVnZW5kSXRlbVNxdWFyZSBjb2xvcj17cnVsZS5jb2xvcn0ga2V5PXtgcnVsZS0ke0pTT04uc3RyaW5naWZ5KHJ1bGUpfWB9IC8+KX1cbiAgICAgICAgPC9zcGFuPlxuICAgICAgKX1cbiAgICAgIHtzdHlsZS50eXBlID09PSAnYXJlYScgJiYgKFxuICAgICAgICA8c3BhbiBjbGFzc05hbWU9e2Nzcyh7IGRpc3BsYXk6ICdmbGV4JywgZmxleERpcmVjdGlvbjogJ3JvdycsIGFsaWduSXRlbXM6ICdjZW50ZXInLCBnYXA6IDIgfSl9PlxuICAgICAgICAgIDxMZWdlbmRJdGVtVHJpYW5nbGUgY29sb3I9e2NvbG9yfSAvPlxuICAgICAgICAgIHtyZWxldmFudFJ1bGVzLmxlbmd0aCA+IDAgJiZcbiAgICAgICAgICAgIHJlbGV2YW50UnVsZXMubWFwKChydWxlKSA9PiA8TGVnZW5kSXRlbVRyaWFuZ2xlIGNvbG9yPXtydWxlLmNvbG9yfSBrZXk9e2BydWxlLSR7SlNPTi5zdHJpbmdpZnkocnVsZSl9YH0gLz4pfVxuICAgICAgICA8L3NwYW4+XG4gICAgICApfVxuICAgICAgPHNwYW5cbiAgICAgICAgc3R5bGU9e3tcbiAgICAgICAgICBmb250U2l6ZTogJzEycHgnLFxuICAgICAgICAgIGxpbmVIZWlnaHQ6ICcxNnB4JyxcbiAgICAgICAgICBkaXNwbGF5OiAnYmxvY2snLFxuICAgICAgICAgIHRleHREZWNvcmF0aW9uOiB2aXNpYmxlID8gJ25vbmUnIDogJ2xpbmUtdGhyb3VnaCcsXG4gICAgICAgICAgdGV4dFdyYXA6ICdub3dyYXAnLFxuICAgICAgICB9fVxuICAgICAgPlxuICAgICAgICB7eUtleUZvcm1hdHRlZCA/IHlLZXlGb3JtYXR0ZWQgOiB5S2V5fVxuICAgICAgPC9zcGFuPlxuICAgIDwvYnV0dG9uPlxuICApO1xufTtcbiJdfQ== */",
44634
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__$6
44635
- }),
44636
- children: [jsx(LegendItemSquare, {
44637
- color: color
44638
- }), relevantRules.length > 0 && relevantRules.map(function (rule) {
44639
- return jsx(LegendItemSquare, {
44640
- color: rule.color
44641
- }, "rule-" + JSON.stringify(rule));
44642
- })]
44643
- }), style.type === 'area' && jsxs("span", {
44644
- className: /*#__PURE__*/css$1(process.env.NODE_ENV === "production" ? {
44645
- name: "6b52m3",
44646
- styles: "display:flex;flex-direction:row;align-items:center;gap:2px"
44647
- } : {
44648
- name: "pglbco-LegendItem",
44649
- styles: "display:flex;flex-direction:row;align-items:center;gap:2px;label:LegendItem;",
44650
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZEl0ZW0udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXNFeUIiLCJmaWxlIjoiTGVnZW5kSXRlbS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgdXNlTWVtbyB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IExlZ2VuZEl0ZW1Cb3ggfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94JztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBMZWdlbmRJdGVtU3F1YXJlLCBMZWdlbmRJdGVtVHJpYW5nbGUgfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94L0xlZ2VuZEl0ZW1Cb3gnO1xuaW1wb3J0IHsgU2hhcGVEZWZpbml0aW9uLCBDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9DaGFydHNWMi90eXBlcyc7XG5pbXBvcnQgeyBMaW5lU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9MaW5lQ2hhcnRWMi90eXBlcyc7XG5pbXBvcnQgeyBCYXJTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0JhckNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQXJlYVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQXJlYUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQnViYmxlU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9CdWJibGVDaGFydFYyL3R5cGVzJztcblxuaW50ZXJmYWNlIExlZ2VuZEl0ZW1Qcm9wczxUPiBleHRlbmRzIFNoYXBlRGVmaW5pdGlvbjxUPiB7XG4gIG9uQ2xpY2s6ICgpID0+IHZvaWQ7XG4gIHZpc2libGU6IGJvb2xlYW47XG4gIHlLZXlGb3JtYXR0ZWQ6IHN0cmluZyB8IHVuZGVmaW5lZDtcbiAgY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXM6IEFycmF5PENvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGU+O1xufVxuXG5leHBvcnQgY29uc3QgTGVnZW5kSXRlbSA9ICh7XG4gIHlLZXksXG4gIHlLZXlGb3JtYXR0ZWQsXG4gIGNvbG9yLFxuICBzdHlsZSxcbiAgb25DbGljayxcbiAgdmlzaWJsZSxcbiAgY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXMsXG59OiBMZWdlbmRJdGVtUHJvcHM8QmFyU3R5bGVzIHwgTGluZVN0eWxlcyB8IEFyZWFTdHlsZXMgfCBCdWJibGVTdHlsZXM+KSA9PiB7XG4gIGNvbnN0IHJlbGV2YW50UnVsZXMgPSB1c2VNZW1vKFxuICAgICgpID0+IGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzLmZpbHRlcigocnVsZSkgPT4geUtleS5pbmNsdWRlcyhydWxlLnlLZXkpKSxcbiAgICBbY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXNdLFxuICApO1xuXG4gIHJldHVybiAoXG4gICAgPGJ1dHRvblxuICAgICAga2V5PXtgbGVnZW5kLSR7eUtleX1gfVxuICAgICAgdHlwZT1cImJ1dHRvblwiXG4gICAgICBzdHlsZT17e1xuICAgICAgICBhbGw6ICd1bnNldCcsXG4gICAgICAgIGRpc3BsYXk6ICdmbGV4JyxcbiAgICAgICAgZmxleFdyYXA6ICdub3dyYXAnLFxuICAgICAgICBhbGlnbkl0ZW1zOiAnY2VudGVyJyxcbiAgICAgICAgb3V0bGluZTogJ3JldmVydCcsXG4gICAgICAgIGdhcDogJzRweCcsXG4gICAgICAgIHBhZGRpbmc6ICc0cHgnLFxuICAgICAgICBjdXJzb3I6ICdwb2ludGVyJyxcbiAgICAgICAgbWFyZ2luUmlnaHQ6ICcxMHB4JyxcbiAgICAgIH19XG4gICAgICBvbkNsaWNrPXtvbkNsaWNrfVxuICAgID5cbiAgICAgIHtzdHlsZS50eXBlID09PSAnbGluZScgJiYgKFxuICAgICAgICA8c3BhbiBjbGFzc05hbWU9e2Nzcyh7IGhlaWdodDogMTAsIGRpc3BsYXk6ICdmbGV4JyB9KX0+XG4gICAgICAgICAgPExlZ2VuZEl0ZW1Cb3ggY29sb3I9e2NvbG9yfSBzdHlsZT17c3R5bGUgYXMgTGluZVN0eWxlc30geUtleT17eUtleX0gLz5cbiAgICAgICAgICB7cmVsZXZhbnRSdWxlcy5sZW5ndGggPiAwICYmXG4gICAgICAgICAgICByZWxldmFudFJ1bGVzLm1hcCgocnVsZSkgPT4gKFxuICAgICAgICAgICAgICA8TGVnZW5kSXRlbUJveFxuICAgICAgICAgICAgICAgIGNvbG9yPXtydWxlLmNvbG9yfVxuICAgICAgICAgICAgICAgIGtleT17YHJ1bGUtJHtKU09OLnN0cmluZ2lmeShydWxlKX1gfVxuICAgICAgICAgICAgICAgIHN0eWxlPXtzdHlsZSBhcyBMaW5lU3R5bGVzfVxuICAgICAgICAgICAgICAgIHlLZXk9e3lLZXl9XG4gICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICApKX1cbiAgICAgICAgPC9zcGFuPlxuICAgICAgKX1cbiAgICAgIHtzdHlsZS50eXBlID09PSAnYmFyJyAmJiAoXG4gICAgICAgIDxzcGFuIGNsYXNzTmFtZT17Y3NzKHsgZGlzcGxheTogJ2ZsZXgnLCBmbGV4RGlyZWN0aW9uOiAncm93JywgYWxpZ25JdGVtczogJ2NlbnRlcicsIGdhcDogMiB9KX0+XG4gICAgICAgICAgPExlZ2VuZEl0ZW1TcXVhcmUgY29sb3I9e2NvbG9yfSAvPlxuICAgICAgICAgIHtyZWxldmFudFJ1bGVzLmxlbmd0aCA+IDAgJiZcbiAgICAgICAgICAgIHJlbGV2YW50UnVsZXMubWFwKChydWxlKSA9PiA8TGVnZW5kSXRlbVNxdWFyZSBjb2xvcj17cnVsZS5jb2xvcn0ga2V5PXtgcnVsZS0ke0pTT04uc3RyaW5naWZ5KHJ1bGUpfWB9IC8+KX1cbiAgICAgICAgPC9zcGFuPlxuICAgICAgKX1cbiAgICAgIHtzdHlsZS50eXBlID09PSAnYXJlYScgJiYgKFxuICAgICAgICA8c3BhbiBjbGFzc05hbWU9e2Nzcyh7IGRpc3BsYXk6ICdmbGV4JywgZmxleERpcmVjdGlvbjogJ3JvdycsIGFsaWduSXRlbXM6ICdjZW50ZXInLCBnYXA6IDIgfSl9PlxuICAgICAgICAgIDxMZWdlbmRJdGVtVHJpYW5nbGUgY29sb3I9e2NvbG9yfSAvPlxuICAgICAgICAgIHtyZWxldmFudFJ1bGVzLmxlbmd0aCA+IDAgJiZcbiAgICAgICAgICAgIHJlbGV2YW50UnVsZXMubWFwKChydWxlKSA9PiA8TGVnZW5kSXRlbVRyaWFuZ2xlIGNvbG9yPXtydWxlLmNvbG9yfSBrZXk9e2BydWxlLSR7SlNPTi5zdHJpbmdpZnkocnVsZSl9YH0gLz4pfVxuICAgICAgICA8L3NwYW4+XG4gICAgICApfVxuICAgICAgPHNwYW5cbiAgICAgICAgc3R5bGU9e3tcbiAgICAgICAgICBmb250U2l6ZTogJzEycHgnLFxuICAgICAgICAgIGxpbmVIZWlnaHQ6ICcxNnB4JyxcbiAgICAgICAgICBkaXNwbGF5OiAnYmxvY2snLFxuICAgICAgICAgIHRleHREZWNvcmF0aW9uOiB2aXNpYmxlID8gJ25vbmUnIDogJ2xpbmUtdGhyb3VnaCcsXG4gICAgICAgICAgdGV4dFdyYXA6ICdub3dyYXAnLFxuICAgICAgICB9fVxuICAgICAgPlxuICAgICAgICB7eUtleUZvcm1hdHRlZCA/IHlLZXlGb3JtYXR0ZWQgOiB5S2V5fVxuICAgICAgPC9zcGFuPlxuICAgIDwvYnV0dG9uPlxuICApO1xufTtcbiJdfQ== */",
44651
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__$6
44652
- }),
44653
- children: [jsx(LegendItemTriangle, {
44654
- color: color
44655
- }), relevantRules.length > 0 && relevantRules.map(function (rule) {
44656
- return jsx(LegendItemTriangle, {
44657
- color: rule.color
44658
- }, "rule-" + JSON.stringify(rule));
44659
- })]
44660
- }), jsx("span", {
44661
- style: {
44662
- fontSize: '12px',
44663
- lineHeight: '16px',
44664
- display: 'block',
44665
- textDecoration: visible ? 'none' : 'line-through',
44666
- textWrap: 'nowrap'
44667
- },
44668
- children: yKeyFormatted ? yKeyFormatted : yKey
44669
- })]
44670
- }, "legend-" + yKey);
44671
- };
44672
-
44673
- function _EMOTION_STRINGIFIED_CSS_ERROR__$7() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
44674
- var Legend$1 = function Legend(_ref) {
44675
- var keys = _ref.keys,
44676
- setVisibleYKeys = _ref.setVisibleYKeys,
44677
- marginLeft = _ref.marginLeft,
44678
- items = _ref.items;
44679
- var handleOnClick = function handleOnClick(item, legendItem) {
44680
- setVisibleYKeys && setVisibleYKeys(function (prev) {
44681
- var newVisibleLegendItems = [];
44682
- if (prev.length === item.legendItems.length) {
44683
- newVisibleLegendItems = [legendItem.yKey];
44684
- } else {
44685
- if (prev.includes(legendItem.yKey)) {
44686
- newVisibleLegendItems = prev.filter(function (prevLegendItemId) {
44687
- return prevLegendItemId !== legendItem.yKey;
44688
- });
44689
- } else {
44690
- newVisibleLegendItems = [].concat(prev, [legendItem.yKey]);
44691
- }
44692
- }
44693
- return newVisibleLegendItems.length === 0 ? item.legendItems.map(function (legendItem) {
44694
- return legendItem.yKey;
44695
- }) : newVisibleLegendItems;
44696
- });
44697
- };
44698
- return jsx("div", {
44699
- className: /*#__PURE__*/css$1(process.env.NODE_ENV === "production" ? {
44700
- name: "1nbollx",
44701
- styles: "height:40px;padding-top:8px"
44702
- } : {
44703
- name: "qz6h7j-Legend",
44704
- styles: "height:40px;padding-top:8px;label:Legend;",
44705
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBc0RvQiIsImZpbGUiOiJMZWdlbmQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0LCB7IEZyYWdtZW50IH0gZnJvbSAncmVhY3QnO1xuXG5pbXBvcnQgeyBMZWdlbmRJdGVtIH0gZnJvbSAnLi9MZWdlbmRJdGVtJztcbmltcG9ydCB7IFNoYXBlRGVmaW5pdGlvbiwgQ29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZSwgS2V5IH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9DaGFydHNWMi90eXBlcyc7XG5pbXBvcnQgeyBTY3JvbGxiYXIgfSBmcm9tICcuLi8uLi8uLi9TY3JvbGxiYXIvU2Nyb2xsYmFyJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBCYXJTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0JhckNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgTGluZVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvTGluZUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQXJlYVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQXJlYUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQnViYmxlU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9CdWJibGVDaGFydFYyL3R5cGVzJztcblxudHlwZSBJdGVtPFQ+ID0ge1xuICBsZWdlbmRJdGVtczogQXJyYXk8U2hhcGVEZWZpbml0aW9uPFQ+PjtcbiAgdmlzaWJsZVlLZXlzOiBBcnJheTxzdHJpbmc+O1xuICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlczogQXJyYXk8Q29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZT47XG59O1xuZXhwb3J0IHR5cGUgTGVnZW5kUHJvcHM8VD4gPSB7XG4gIHNldFZpc2libGVZS2V5cz86IFJlYWN0LkRpc3BhdGNoPFJlYWN0LlNldFN0YXRlQWN0aW9uPEFycmF5PHN0cmluZz4+PjtcbiAga2V5czogeyBba2V5OiBzdHJpbmddOiBLZXkgfTtcbiAgbWFyZ2luTGVmdDogbnVtYmVyO1xuICBpdGVtczogSXRlbTxUPltdO1xufTtcblxuZXhwb3J0IGNvbnN0IExlZ2VuZCA9ICh7XG4gIGtleXMsXG4gIHNldFZpc2libGVZS2V5cyxcbiAgbWFyZ2luTGVmdCxcbiAgaXRlbXMsXG59OiBMZWdlbmRQcm9wczxCYXJTdHlsZXMgfCBMaW5lU3R5bGVzIHwgQXJlYVN0eWxlcyB8IEJ1YmJsZVN0eWxlcz4pID0+IHtcbiAgY29uc3QgaGFuZGxlT25DbGljayA9IChcbiAgICBpdGVtOiBJdGVtPEJhclN0eWxlcyB8IExpbmVTdHlsZXMgfCBBcmVhU3R5bGVzIHwgQnViYmxlU3R5bGVzPixcbiAgICBsZWdlbmRJdGVtOiBTaGFwZURlZmluaXRpb248QmFyU3R5bGVzIHwgTGluZVN0eWxlcyB8IEFyZWFTdHlsZXMgfCBCdWJibGVTdHlsZXM+XG4gICkgPT4ge1xuICAgIHNldFZpc2libGVZS2V5cyAmJlxuICAgICAgc2V0VmlzaWJsZVlLZXlzKHByZXYgPT4ge1xuICAgICAgICBsZXQgbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zOiBBcnJheTxzdHJpbmc+ID0gW107XG5cbiAgICAgICAgaWYgKHByZXYubGVuZ3RoID09PSBpdGVtLmxlZ2VuZEl0ZW1zLmxlbmd0aCkge1xuICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IFtsZWdlbmRJdGVtLnlLZXldO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgIGlmIChwcmV2LmluY2x1ZGVzKGxlZ2VuZEl0ZW0ueUtleSkpIHtcbiAgICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IHByZXYuZmlsdGVyKHByZXZMZWdlbmRJdGVtSWQgPT4gcHJldkxlZ2VuZEl0ZW1JZCAhPT0gbGVnZW5kSXRlbS55S2V5KTtcbiAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zID0gWy4uLnByZXYsIGxlZ2VuZEl0ZW0ueUtleV07XG4gICAgICAgICAgfVxuICAgICAgICB9XG5cbiAgICAgICAgcmV0dXJuIG5ld1Zpc2libGVMZWdlbmRJdGVtcy5sZW5ndGggPT09IDBcbiAgICAgICAgICA/IGl0ZW0ubGVnZW5kSXRlbXMubWFwKGxlZ2VuZEl0ZW0gPT4gbGVnZW5kSXRlbS55S2V5KVxuICAgICAgICAgIDogbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zO1xuICAgICAgfSk7XG4gIH07XG5cbiAgcmV0dXJuIChcbiAgICA8ZGl2IGNsYXNzTmFtZT17Y3NzKHsgaGVpZ2h0OiA0MCwgcGFkZGluZ1RvcDogOCB9KX0+XG4gICAgICA8U2Nyb2xsYmFyXG4gICAgICAgIGNsYXNzTmFtZT17Y3NzKHtcbiAgICAgICAgICBkaXNwbGF5OiAnZmxleCcsXG4gICAgICAgICAgZmxleERpcmVjdGlvbjogJ3JvdycsXG4gICAgICAgICAgZmxleFdyYXA6ICdub3dyYXAnLFxuICAgICAgICAgIGFsaWduSXRlbXM6ICdjZW50ZXInLFxuICAgICAgICAgIG1hcmdpbkxlZnQ6IG1hcmdpbkxlZnQgPyBgJHttYXJnaW5MZWZ0fXB4YCA6IHVuZGVmaW5lZCxcbiAgICAgICAgfSl9XG4gICAgICAgIHg9e3RydWV9XG4gICAgICA+XG4gICAgICAgIHtpdGVtcy5tYXAoKGl0ZW0sIGluZGV4KSA9PiAoXG4gICAgICAgICAgPEZyYWdtZW50IGtleT17aW5kZXh9PlxuICAgICAgICAgICAge2l0ZW0ubGVnZW5kSXRlbXMubWFwKFxuICAgICAgICAgICAgICBsZWdlbmRJdGVtID0+XG4gICAgICAgICAgICAgICAga2V5c1tsZWdlbmRJdGVtLnlLZXldICYmIChcbiAgICAgICAgICAgICAgICAgIDxMZWdlbmRJdGVtXG4gICAgICAgICAgICAgICAgICAgIHsuLi5sZWdlbmRJdGVtfVxuICAgICAgICAgICAgICAgICAgICBrZXk9e2BsZWdlbmQtJHtsZWdlbmRJdGVtLnlLZXl9YH1cbiAgICAgICAgICAgICAgICAgICAgeUtleUZvcm1hdHRlZD17a2V5c1tsZWdlbmRJdGVtLnlLZXldLmtleUZvcm1hdHRlZH1cbiAgICAgICAgICAgICAgICAgICAgb25DbGljaz17KCkgPT4ge1xuICAgICAgICAgICAgICAgICAgICAgIGhhbmRsZU9uQ2xpY2soaXRlbSwgbGVnZW5kSXRlbSk7XG4gICAgICAgICAgICAgICAgICAgIH19XG4gICAgICAgICAgICAgICAgICAgIHZpc2libGU9e3NldFZpc2libGVZS2V5cyA/IGl0ZW0udmlzaWJsZVlLZXlzLmluY2x1ZGVzKGxlZ2VuZEl0ZW0ueUtleSkgOiB0cnVlfVxuICAgICAgICAgICAgICAgICAgICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlcz17aXRlbS5jb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlc31cbiAgICAgICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICAgICAgKVxuICAgICAgICAgICAgKX1cbiAgICAgICAgICA8L0ZyYWdtZW50PlxuICAgICAgICApKX1cbiAgICAgIDwvU2Nyb2xsYmFyPlxuICAgIDwvZGl2PlxuICApO1xufTtcbiJdfQ== */",
44706
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__$7
44707
- }),
44708
- children: jsx(Scrollbar, {
44709
- className: /*#__PURE__*/css$1({
44710
- display: 'flex',
44711
- flexDirection: 'row',
44712
- flexWrap: 'nowrap',
44713
- alignItems: 'center',
44714
- marginLeft: marginLeft ? marginLeft + "px" : undefined
44715
- }, process.env.NODE_ENV === "production" ? "" : ";label:Legend;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBd0RtQiIsImZpbGUiOiJMZWdlbmQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0LCB7IEZyYWdtZW50IH0gZnJvbSAncmVhY3QnO1xuXG5pbXBvcnQgeyBMZWdlbmRJdGVtIH0gZnJvbSAnLi9MZWdlbmRJdGVtJztcbmltcG9ydCB7IFNoYXBlRGVmaW5pdGlvbiwgQ29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZSwgS2V5IH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9DaGFydHNWMi90eXBlcyc7XG5pbXBvcnQgeyBTY3JvbGxiYXIgfSBmcm9tICcuLi8uLi8uLi9TY3JvbGxiYXIvU2Nyb2xsYmFyJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBCYXJTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0JhckNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgTGluZVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvTGluZUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQXJlYVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQXJlYUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQnViYmxlU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9CdWJibGVDaGFydFYyL3R5cGVzJztcblxudHlwZSBJdGVtPFQ+ID0ge1xuICBsZWdlbmRJdGVtczogQXJyYXk8U2hhcGVEZWZpbml0aW9uPFQ+PjtcbiAgdmlzaWJsZVlLZXlzOiBBcnJheTxzdHJpbmc+O1xuICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlczogQXJyYXk8Q29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZT47XG59O1xuZXhwb3J0IHR5cGUgTGVnZW5kUHJvcHM8VD4gPSB7XG4gIHNldFZpc2libGVZS2V5cz86IFJlYWN0LkRpc3BhdGNoPFJlYWN0LlNldFN0YXRlQWN0aW9uPEFycmF5PHN0cmluZz4+PjtcbiAga2V5czogeyBba2V5OiBzdHJpbmddOiBLZXkgfTtcbiAgbWFyZ2luTGVmdDogbnVtYmVyO1xuICBpdGVtczogSXRlbTxUPltdO1xufTtcblxuZXhwb3J0IGNvbnN0IExlZ2VuZCA9ICh7XG4gIGtleXMsXG4gIHNldFZpc2libGVZS2V5cyxcbiAgbWFyZ2luTGVmdCxcbiAgaXRlbXMsXG59OiBMZWdlbmRQcm9wczxCYXJTdHlsZXMgfCBMaW5lU3R5bGVzIHwgQXJlYVN0eWxlcyB8IEJ1YmJsZVN0eWxlcz4pID0+IHtcbiAgY29uc3QgaGFuZGxlT25DbGljayA9IChcbiAgICBpdGVtOiBJdGVtPEJhclN0eWxlcyB8IExpbmVTdHlsZXMgfCBBcmVhU3R5bGVzIHwgQnViYmxlU3R5bGVzPixcbiAgICBsZWdlbmRJdGVtOiBTaGFwZURlZmluaXRpb248QmFyU3R5bGVzIHwgTGluZVN0eWxlcyB8IEFyZWFTdHlsZXMgfCBCdWJibGVTdHlsZXM+XG4gICkgPT4ge1xuICAgIHNldFZpc2libGVZS2V5cyAmJlxuICAgICAgc2V0VmlzaWJsZVlLZXlzKHByZXYgPT4ge1xuICAgICAgICBsZXQgbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zOiBBcnJheTxzdHJpbmc+ID0gW107XG5cbiAgICAgICAgaWYgKHByZXYubGVuZ3RoID09PSBpdGVtLmxlZ2VuZEl0ZW1zLmxlbmd0aCkge1xuICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IFtsZWdlbmRJdGVtLnlLZXldO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgIGlmIChwcmV2LmluY2x1ZGVzKGxlZ2VuZEl0ZW0ueUtleSkpIHtcbiAgICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IHByZXYuZmlsdGVyKHByZXZMZWdlbmRJdGVtSWQgPT4gcHJldkxlZ2VuZEl0ZW1JZCAhPT0gbGVnZW5kSXRlbS55S2V5KTtcbiAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zID0gWy4uLnByZXYsIGxlZ2VuZEl0ZW0ueUtleV07XG4gICAgICAgICAgfVxuICAgICAgICB9XG5cbiAgICAgICAgcmV0dXJuIG5ld1Zpc2libGVMZWdlbmRJdGVtcy5sZW5ndGggPT09IDBcbiAgICAgICAgICA/IGl0ZW0ubGVnZW5kSXRlbXMubWFwKGxlZ2VuZEl0ZW0gPT4gbGVnZW5kSXRlbS55S2V5KVxuICAgICAgICAgIDogbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zO1xuICAgICAgfSk7XG4gIH07XG5cbiAgcmV0dXJuIChcbiAgICA8ZGl2IGNsYXNzTmFtZT17Y3NzKHsgaGVpZ2h0OiA0MCwgcGFkZGluZ1RvcDogOCB9KX0+XG4gICAgICA8U2Nyb2xsYmFyXG4gICAgICAgIGNsYXNzTmFtZT17Y3NzKHtcbiAgICAgICAgICBkaXNwbGF5OiAnZmxleCcsXG4gICAgICAgICAgZmxleERpcmVjdGlvbjogJ3JvdycsXG4gICAgICAgICAgZmxleFdyYXA6ICdub3dyYXAnLFxuICAgICAgICAgIGFsaWduSXRlbXM6ICdjZW50ZXInLFxuICAgICAgICAgIG1hcmdpbkxlZnQ6IG1hcmdpbkxlZnQgPyBgJHttYXJnaW5MZWZ0fXB4YCA6IHVuZGVmaW5lZCxcbiAgICAgICAgfSl9XG4gICAgICAgIHg9e3RydWV9XG4gICAgICA+XG4gICAgICAgIHtpdGVtcy5tYXAoKGl0ZW0sIGluZGV4KSA9PiAoXG4gICAgICAgICAgPEZyYWdtZW50IGtleT17aW5kZXh9PlxuICAgICAgICAgICAge2l0ZW0ubGVnZW5kSXRlbXMubWFwKFxuICAgICAgICAgICAgICBsZWdlbmRJdGVtID0+XG4gICAgICAgICAgICAgICAga2V5c1tsZWdlbmRJdGVtLnlLZXldICYmIChcbiAgICAgICAgICAgICAgICAgIDxMZWdlbmRJdGVtXG4gICAgICAgICAgICAgICAgICAgIHsuLi5sZWdlbmRJdGVtfVxuICAgICAgICAgICAgICAgICAgICBrZXk9e2BsZWdlbmQtJHtsZWdlbmRJdGVtLnlLZXl9YH1cbiAgICAgICAgICAgICAgICAgICAgeUtleUZvcm1hdHRlZD17a2V5c1tsZWdlbmRJdGVtLnlLZXldLmtleUZvcm1hdHRlZH1cbiAgICAgICAgICAgICAgICAgICAgb25DbGljaz17KCkgPT4ge1xuICAgICAgICAgICAgICAgICAgICAgIGhhbmRsZU9uQ2xpY2soaXRlbSwgbGVnZW5kSXRlbSk7XG4gICAgICAgICAgICAgICAgICAgIH19XG4gICAgICAgICAgICAgICAgICAgIHZpc2libGU9e3NldFZpc2libGVZS2V5cyA/IGl0ZW0udmlzaWJsZVlLZXlzLmluY2x1ZGVzKGxlZ2VuZEl0ZW0ueUtleSkgOiB0cnVlfVxuICAgICAgICAgICAgICAgICAgICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlcz17aXRlbS5jb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlc31cbiAgICAgICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICAgICAgKVxuICAgICAgICAgICAgKX1cbiAgICAgICAgICA8L0ZyYWdtZW50PlxuICAgICAgICApKX1cbiAgICAgIDwvU2Nyb2xsYmFyPlxuICAgIDwvZGl2PlxuICApO1xufTtcbiJdfQ== */"),
44716
- x: true,
44717
- children: items.map(function (item, index) {
44718
- return jsx(Fragment, {
44719
- children: item.legendItems.map(function (legendItem) {
44720
- return keys[legendItem.yKey] && createElement$1(LegendItem, _extends({}, legendItem, {
44721
- key: "legend-" + legendItem.yKey,
44722
- yKeyFormatted: keys[legendItem.yKey].keyFormatted,
44723
- onClick: function onClick() {
44724
- handleOnClick(item, legendItem);
44725
- },
44726
- visible: setVisibleYKeys ? item.visibleYKeys.includes(legendItem.yKey) : true,
44727
- conditionalFormattingRules: item.conditionalFormattingRules
44728
- }));
44729
- })
44730
- }, index);
44731
- })
44732
- })
44733
- });
44734
- };
44735
-
44736
44354
  var ASSUMED_AVERAGE_CHAR_WIDTH = 7.1;
44737
44355
  var ASSUMED_AVERAGE_CHAR_HEIGHT = 24;
44738
44356
 
@@ -44986,33 +44604,15 @@ var buildMarginForHorizontalChart = function buildMarginForHorizontalChart(xTick
44986
44604
  };
44987
44605
  };
44988
44606
 
44989
- var LINE_STYLES = {
44990
- strokeWidth: 2,
44991
- strokeOpacity: 0.8,
44992
- strokeLinecap: 'round',
44993
- strokeDasharray: '0.5 5',
44994
- stroke: 'rgba(0, 0, 0, 0.1)'
44995
- };
44996
-
44997
- var GridRows = function GridRows(_ref) {
44998
- var ticks = _ref.ticks,
44999
- yScale = _ref.yScale,
45000
- removeStroke = _ref.removeStroke,
45001
- width = _ref.width,
45002
- height = _ref.height,
45003
- themeCSS = _ref.themeCSS;
45004
- return jsx(GridRows$1, {
45005
- tickValues: ticks.length > 0 ? ticks : undefined,
45006
- scale: yScale,
45007
- width: width,
45008
- height: height,
45009
- pointerEvents: "none",
45010
- strokeDasharray: "0.5 5",
45011
- strokeWidth: removeStroke ? 0 : 2,
45012
- lineStyle: _extends({
45013
- stroke: themeCSS.grid.stroke
45014
- }, LINE_STYLES)
45015
- });
44607
+ var useableId = function useableId(key, prefix) {
44608
+ var newKey = key.toLowerCase()
44609
+ // Remove characters that aren't letters, digits, underscores, or spaces
44610
+ .replace(/[^\w\s-]+/g, '')
44611
+ // Replace whitespace with hyphens
44612
+ .replace(/\s+/g, '-')
44613
+ // Remove leading or trailing hyphens
44614
+ .replace(/^-+|-+$/g, '');
44615
+ return prefix + '-' + newKey;
45016
44616
  };
45017
44617
 
45018
44618
  var AXIS_TITLE_STYLES = {
@@ -45134,7 +44734,7 @@ var AxisLeft = function AxisLeft(_ref) {
45134
44734
  };
45135
44735
 
45136
44736
  var _excluded$g = ["children", "width", "height", "showLegend", "onMouseMove", "onMouseLeave"];
45137
- 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)."; }
44737
+ function _EMOTION_STRINGIFIED_CSS_ERROR__$5() { 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)."; }
45138
44738
  var ChartWrapper$1 = function ChartWrapper(_ref) {
45139
44739
  var children = _ref.children,
45140
44740
  width = _ref.width,
@@ -45155,13 +44755,41 @@ var ChartWrapper$1 = function ChartWrapper(_ref) {
45155
44755
  name: "fx4tbw-ChartWrapper",
45156
44756
  styles: "display:block;label:ChartWrapper;",
45157
44757
  map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNoYXJ0V3JhcHBlci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMEJpQiIsImZpbGUiOiJDaGFydFdyYXBwZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vY3NzJztcblxudHlwZSBDaGFydFdyYXBwZXJQcm9wcyA9IHtcbiAgY2hpbGRyZW46IFJlYWN0LlJlYWN0Tm9kZTtcbiAgd2lkdGg6IG51bWJlcjtcbiAgaGVpZ2h0OiBudW1iZXI7XG4gIHNob3dMZWdlbmQ6IGJvb2xlYW47XG4gIG9uTW91c2VNb3ZlPzogUmVhY3QuTW91c2VFdmVudEhhbmRsZXI8U1ZHU1ZHRWxlbWVudD47XG4gIG9uTW91c2VMZWF2ZT86IFJlYWN0Lk1vdXNlRXZlbnRIYW5kbGVyPFNWR1NWR0VsZW1lbnQ+O1xufSAmIFJlYWN0LlNWR1Byb3BzPFNWR1NWR0VsZW1lbnQ+O1xuXG5leHBvcnQgY29uc3QgQ2hhcnRXcmFwcGVyID0gKHtcbiAgY2hpbGRyZW4sXG4gIHdpZHRoLFxuICBoZWlnaHQsXG4gIHNob3dMZWdlbmQsXG4gIG9uTW91c2VNb3ZlLFxuICBvbk1vdXNlTGVhdmUsXG4gIC4uLnN2Z1Byb3BzXG59OiBDaGFydFdyYXBwZXJQcm9wcykgPT4ge1xuICByZXR1cm4gKFxuICAgIDxzdmdcbiAgICAgIHdpZHRoPXt3aWR0aH1cbiAgICAgIGhlaWdodD17aGVpZ2h0IC0gKHNob3dMZWdlbmQgPyA0MCA6IDApfVxuICAgICAgb25Nb3VzZU1vdmU9e29uTW91c2VNb3ZlfVxuICAgICAgb25Nb3VzZUxlYXZlPXtvbk1vdXNlTGVhdmV9XG4gICAgICBjbGFzc05hbWU9e2Nzcyh7IGRpc3BsYXk6ICdibG9jaycgfSl9XG4gICAgICB7Li4uc3ZnUHJvcHN9XG4gICAgPlxuICAgICAge2NoaWxkcmVufVxuICAgIDwvc3ZnPlxuICApO1xufTtcbiJdfQ== */",
45158
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__$8
44758
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__$5
45159
44759
  })
45160
44760
  }, svgProps, {
45161
44761
  children: children
45162
44762
  }));
45163
44763
  };
45164
44764
 
44765
+ var DataLabel = function DataLabel(_ref) {
44766
+ var x = _ref.x,
44767
+ y = _ref.y,
44768
+ title = _ref.title,
44769
+ dx = _ref.dx,
44770
+ dy = _ref.dy,
44771
+ color = _ref.color,
44772
+ backgroundColor = _ref.backgroundColor,
44773
+ _ref$horizontalAnchor = _ref.horizontalAnchor,
44774
+ horizontalAnchor = _ref$horizontalAnchor === void 0 ? undefined : _ref$horizontalAnchor;
44775
+ return jsx(Annotation$1, {
44776
+ x: x,
44777
+ y: y,
44778
+ dx: dx,
44779
+ dy: dy,
44780
+ children: jsx(Label$1, {
44781
+ title: title,
44782
+ showAnchorLine: false,
44783
+ showBackground: false,
44784
+ backgroundFill: backgroundColor,
44785
+ fontColor: color,
44786
+ titleFontSize: 10,
44787
+ verticalAnchor: "middle",
44788
+ horizontalAnchor: horizontalAnchor
44789
+ })
44790
+ });
44791
+ };
44792
+
45165
44793
  var GoalLine = function GoalLine(_ref) {
45166
44794
  var goalLine = _ref.goalLine,
45167
44795
  innerWidth = _ref.innerWidth,
@@ -45249,6 +44877,35 @@ var GoalLines = function GoalLines(_ref) {
45249
44877
  };
45250
44878
  var GoalLines$1 = /*#__PURE__*/memo(GoalLines, shouldUpdate$1);
45251
44879
 
44880
+ var LINE_STYLES = {
44881
+ strokeWidth: 2,
44882
+ strokeOpacity: 0.8,
44883
+ strokeLinecap: 'round',
44884
+ strokeDasharray: '0.5 5',
44885
+ stroke: 'rgba(0, 0, 0, 0.1)'
44886
+ };
44887
+
44888
+ var GridRows = function GridRows(_ref) {
44889
+ var ticks = _ref.ticks,
44890
+ yScale = _ref.yScale,
44891
+ removeStroke = _ref.removeStroke,
44892
+ width = _ref.width,
44893
+ height = _ref.height,
44894
+ themeCSS = _ref.themeCSS;
44895
+ return jsx(GridRows$1, {
44896
+ tickValues: ticks.length > 0 ? ticks : undefined,
44897
+ scale: yScale,
44898
+ width: width,
44899
+ height: height,
44900
+ pointerEvents: "none",
44901
+ strokeDasharray: "0.5 5",
44902
+ strokeWidth: removeStroke ? 0 : 2,
44903
+ lineStyle: _extends({
44904
+ stroke: themeCSS.grid.stroke
44905
+ }, LINE_STYLES)
44906
+ });
44907
+ };
44908
+
45252
44909
  function useFlattenedData(xScaleKey, xScaleDataType, data, yKeys) {
45253
44910
  return useMemo(function () {
45254
44911
  if (xScaleKey && xScaleDataType && yKeys.length > 0) {
@@ -45264,6 +44921,533 @@ function useFlattenedData(xScaleKey, xScaleDataType, data, yKeys) {
45264
44921
  }, [data, xScaleKey, xScaleDataType, yKeys]);
45265
44922
  }
45266
44923
 
44924
+ var _excluded$h = ["tooltipOpen"];
44925
+ function useTooltip$1(initialTooltipState) {
44926
+ var _useState = useState(_extends({
44927
+ tooltipOpen: false
44928
+ }, initialTooltipState)),
44929
+ tooltipState = _useState[0],
44930
+ setTooltipState = _useState[1];
44931
+ var showTooltip = useCallback(function (showArgs) {
44932
+ return setTooltipState(typeof showArgs === 'function' ? function (_ref) {
44933
+ var show = _objectWithoutPropertiesLoose(_ref, _excluded$h);
44934
+ return _extends({}, showArgs(show), {
44935
+ tooltipOpen: true
44936
+ });
44937
+ } : {
44938
+ tooltipOpen: true,
44939
+ tooltipLeft: showArgs.tooltipLeft,
44940
+ tooltipTop: showArgs.tooltipTop,
44941
+ lineLeft: showArgs.lineLeft,
44942
+ tooltipData: showArgs.tooltipData
44943
+ });
44944
+ }, [setTooltipState]);
44945
+ var hideTooltip = useCallback(function () {
44946
+ return setTooltipState({
44947
+ tooltipOpen: false,
44948
+ tooltipLeft: undefined,
44949
+ lineLeft: undefined,
44950
+ tooltipTop: undefined,
44951
+ tooltipData: undefined
44952
+ });
44953
+ }, [setTooltipState]);
44954
+ return {
44955
+ tooltipOpen: tooltipState.tooltipOpen,
44956
+ tooltipLeft: tooltipState.tooltipLeft,
44957
+ tooltipTop: tooltipState.tooltipTop,
44958
+ lineLeft: tooltipState.lineLeft,
44959
+ tooltipData: tooltipState.tooltipData,
44960
+ updateTooltip: setTooltipState,
44961
+ showTooltip: showTooltip,
44962
+ hideTooltip: hideTooltip
44963
+ };
44964
+ }
44965
+
44966
+ function useVisibleYKeys(areas) {
44967
+ var _useState = useState(areas.map(function (legendItem) {
44968
+ return legendItem.yKey;
44969
+ })),
44970
+ visibleYKeysState = _useState[0],
44971
+ setVisibleYKeys = _useState[1];
44972
+ useEffect(function () {
44973
+ setVisibleYKeys(areas.map(function (legendItem) {
44974
+ return legendItem.yKey;
44975
+ }));
44976
+ return function () {
44977
+ setVisibleYKeys([]);
44978
+ };
44979
+ }, [areas]);
44980
+ return {
44981
+ visibleYKeys: visibleYKeysState,
44982
+ setVisibleYKeys: setVisibleYKeys
44983
+ };
44984
+ }
44985
+
44986
+ function useYScale(innerHeight, scale) {
44987
+ return useMemo(function () {
44988
+ return scaleLinear({
44989
+ range: [innerHeight, 0],
44990
+ domain: scale.ordering === 'asc' ? [scale.min, scale.max] : [scale.max, scale.min],
44991
+ nice: true,
44992
+ round: true
44993
+ });
44994
+ }, [innerHeight, scale]);
44995
+ }
44996
+
44997
+ var LegendItemBox = function LegendItemBox(_ref) {
44998
+ var color = _ref.color,
44999
+ style = _ref.style;
45000
+ return jsx("svg", {
45001
+ width: 10,
45002
+ height: 10,
45003
+ style: {
45004
+ display: 'block'
45005
+ },
45006
+ children: style.type === 'line' ? style.strokeDasharray !== null ? jsx("line", {
45007
+ x1: "0",
45008
+ y1: "5",
45009
+ x2: "10",
45010
+ y2: "5",
45011
+ stroke: color,
45012
+ strokeWidth: style.strokeWidth,
45013
+ strokeDasharray: 2
45014
+ }) : jsx("line", {
45015
+ x1: "0",
45016
+ y1: "5",
45017
+ x2: "10",
45018
+ y2: "5",
45019
+ stroke: color,
45020
+ strokeWidth: style.strokeWidth
45021
+ }) : jsx("rect", {
45022
+ fill: color,
45023
+ width: 10,
45024
+ height: 10,
45025
+ rx: "2"
45026
+ })
45027
+ });
45028
+ };
45029
+ var LegendItemSquare = function LegendItemSquare(_ref2) {
45030
+ var color = _ref2.color;
45031
+ return jsx("svg", {
45032
+ width: 8,
45033
+ height: 8,
45034
+ style: {
45035
+ display: 'block'
45036
+ },
45037
+ children: jsx("rect", {
45038
+ fill: color,
45039
+ width: 8,
45040
+ height: 8,
45041
+ rx: "2"
45042
+ })
45043
+ });
45044
+ };
45045
+ var LegendItemTriangle = function LegendItemTriangle(_ref3) {
45046
+ var color = _ref3.color;
45047
+ return jsx("svg", {
45048
+ width: 8,
45049
+ height: 8,
45050
+ style: {
45051
+ display: 'block',
45052
+ borderRadius: 1
45053
+ },
45054
+ children: jsx("polygon", {
45055
+ points: "0,0 10,10 0,10",
45056
+ fill: color
45057
+ })
45058
+ });
45059
+ };
45060
+
45061
+ function _EMOTION_STRINGIFIED_CSS_ERROR__$6() { 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)."; }
45062
+ var LegendItem = function LegendItem(_ref) {
45063
+ var yKey = _ref.yKey,
45064
+ yKeyFormatted = _ref.yKeyFormatted,
45065
+ color = _ref.color,
45066
+ style = _ref.style,
45067
+ onClick = _ref.onClick,
45068
+ visible = _ref.visible,
45069
+ conditionalFormattingRules = _ref.conditionalFormattingRules;
45070
+ var relevantRules = useMemo(function () {
45071
+ return conditionalFormattingRules.filter(function (rule) {
45072
+ return yKey.includes(rule.yKey);
45073
+ });
45074
+ }, [conditionalFormattingRules]);
45075
+ return jsxs("button", {
45076
+ type: "button",
45077
+ style: {
45078
+ all: 'unset',
45079
+ display: 'flex',
45080
+ flexWrap: 'nowrap',
45081
+ alignItems: 'center',
45082
+ outline: 'revert',
45083
+ gap: '4px',
45084
+ padding: '4px',
45085
+ cursor: 'pointer',
45086
+ marginRight: '10px'
45087
+ },
45088
+ onClick: onClick,
45089
+ children: [style.type === 'line' && jsxs("span", {
45090
+ className: /*#__PURE__*/css$1(process.env.NODE_ENV === "production" ? {
45091
+ name: "1mfeugk",
45092
+ styles: "height:10px;display:flex"
45093
+ } : {
45094
+ name: "mefz6m-LegendItem",
45095
+ styles: "height:10px;display:flex;label:LegendItem;",
45096
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZEl0ZW0udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWlEeUIiLCJmaWxlIjoiTGVnZW5kSXRlbS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgdXNlTWVtbyB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IExlZ2VuZEl0ZW1Cb3ggfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94JztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBMZWdlbmRJdGVtU3F1YXJlLCBMZWdlbmRJdGVtVHJpYW5nbGUgfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94L0xlZ2VuZEl0ZW1Cb3gnO1xuaW1wb3J0IHsgU2hhcGVEZWZpbml0aW9uLCBDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9DaGFydHNWMi90eXBlcyc7XG5pbXBvcnQgeyBMaW5lU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9MaW5lQ2hhcnRWMi90eXBlcyc7XG5pbXBvcnQgeyBCYXJTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0JhckNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQXJlYVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQXJlYUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQnViYmxlU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9CdWJibGVDaGFydFYyL3R5cGVzJztcblxuaW50ZXJmYWNlIExlZ2VuZEl0ZW1Qcm9wczxUPiBleHRlbmRzIFNoYXBlRGVmaW5pdGlvbjxUPiB7XG4gIG9uQ2xpY2s6ICgpID0+IHZvaWQ7XG4gIHZpc2libGU6IGJvb2xlYW47XG4gIHlLZXlGb3JtYXR0ZWQ6IHN0cmluZyB8IHVuZGVmaW5lZDtcbiAgY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXM6IEFycmF5PENvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGU+O1xufVxuXG5leHBvcnQgY29uc3QgTGVnZW5kSXRlbSA9ICh7XG4gIHlLZXksXG4gIHlLZXlGb3JtYXR0ZWQsXG4gIGNvbG9yLFxuICBzdHlsZSxcbiAgb25DbGljayxcbiAgdmlzaWJsZSxcbiAgY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXMsXG59OiBMZWdlbmRJdGVtUHJvcHM8QmFyU3R5bGVzIHwgTGluZVN0eWxlcyB8IEFyZWFTdHlsZXMgfCBCdWJibGVTdHlsZXM+KSA9PiB7XG4gIGNvbnN0IHJlbGV2YW50UnVsZXMgPSB1c2VNZW1vKFxuICAgICgpID0+IGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzLmZpbHRlcigocnVsZSkgPT4geUtleS5pbmNsdWRlcyhydWxlLnlLZXkpKSxcbiAgICBbY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXNdLFxuICApO1xuXG4gIHJldHVybiAoXG4gICAgPGJ1dHRvblxuICAgICAga2V5PXtgbGVnZW5kLSR7eUtleX1gfVxuICAgICAgdHlwZT1cImJ1dHRvblwiXG4gICAgICBzdHlsZT17e1xuICAgICAgICBhbGw6ICd1bnNldCcsXG4gICAgICAgIGRpc3BsYXk6ICdmbGV4JyxcbiAgICAgICAgZmxleFdyYXA6ICdub3dyYXAnLFxuICAgICAgICBhbGlnbkl0ZW1zOiAnY2VudGVyJyxcbiAgICAgICAgb3V0bGluZTogJ3JldmVydCcsXG4gICAgICAgIGdhcDogJzRweCcsXG4gICAgICAgIHBhZGRpbmc6ICc0cHgnLFxuICAgICAgICBjdXJzb3I6ICdwb2ludGVyJyxcbiAgICAgICAgbWFyZ2luUmlnaHQ6ICcxMHB4JyxcbiAgICAgIH19XG4gICAgICBvbkNsaWNrPXtvbkNsaWNrfVxuICAgID5cbiAgICAgIHtzdHlsZS50eXBlID09PSAnbGluZScgJiYgKFxuICAgICAgICA8c3BhbiBjbGFzc05hbWU9e2Nzcyh7IGhlaWdodDogMTAsIGRpc3BsYXk6ICdmbGV4JyB9KX0+XG4gICAgICAgICAgPExlZ2VuZEl0ZW1Cb3ggY29sb3I9e2NvbG9yfSBzdHlsZT17c3R5bGUgYXMgTGluZVN0eWxlc30geUtleT17eUtleX0gLz5cbiAgICAgICAgICB7cmVsZXZhbnRSdWxlcy5sZW5ndGggPiAwICYmXG4gICAgICAgICAgICByZWxldmFudFJ1bGVzLm1hcCgocnVsZSkgPT4gKFxuICAgICAgICAgICAgICA8TGVnZW5kSXRlbUJveFxuICAgICAgICAgICAgICAgIGNvbG9yPXtydWxlLmNvbG9yfVxuICAgICAgICAgICAgICAgIGtleT17YHJ1bGUtJHtKU09OLnN0cmluZ2lmeShydWxlKX1gfVxuICAgICAgICAgICAgICAgIHN0eWxlPXtzdHlsZSBhcyBMaW5lU3R5bGVzfVxuICAgICAgICAgICAgICAgIHlLZXk9e3lLZXl9XG4gICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICApKX1cbiAgICAgICAgPC9zcGFuPlxuICAgICAgKX1cbiAgICAgIHtzdHlsZS50eXBlID09PSAnYmFyJyAmJiAoXG4gICAgICAgIDxzcGFuIGNsYXNzTmFtZT17Y3NzKHsgZGlzcGxheTogJ2ZsZXgnLCBmbGV4RGlyZWN0aW9uOiAncm93JywgYWxpZ25JdGVtczogJ2NlbnRlcicsIGdhcDogMiB9KX0+XG4gICAgICAgICAgPExlZ2VuZEl0ZW1TcXVhcmUgY29sb3I9e2NvbG9yfSAvPlxuICAgICAgICAgIHtyZWxldmFudFJ1bGVzLmxlbmd0aCA+IDAgJiZcbiAgICAgICAgICAgIHJlbGV2YW50UnVsZXMubWFwKChydWxlKSA9PiA8TGVnZW5kSXRlbVNxdWFyZSBjb2xvcj17cnVsZS5jb2xvcn0ga2V5PXtgcnVsZS0ke0pTT04uc3RyaW5naWZ5KHJ1bGUpfWB9IC8+KX1cbiAgICAgICAgPC9zcGFuPlxuICAgICAgKX1cbiAgICAgIHtzdHlsZS50eXBlID09PSAnYXJlYScgJiYgKFxuICAgICAgICA8c3BhbiBjbGFzc05hbWU9e2Nzcyh7IGRpc3BsYXk6ICdmbGV4JywgZmxleERpcmVjdGlvbjogJ3JvdycsIGFsaWduSXRlbXM6ICdjZW50ZXInLCBnYXA6IDIgfSl9PlxuICAgICAgICAgIDxMZWdlbmRJdGVtVHJpYW5nbGUgY29sb3I9e2NvbG9yfSAvPlxuICAgICAgICAgIHtyZWxldmFudFJ1bGVzLmxlbmd0aCA+IDAgJiZcbiAgICAgICAgICAgIHJlbGV2YW50UnVsZXMubWFwKChydWxlKSA9PiA8TGVnZW5kSXRlbVRyaWFuZ2xlIGNvbG9yPXtydWxlLmNvbG9yfSBrZXk9e2BydWxlLSR7SlNPTi5zdHJpbmdpZnkocnVsZSl9YH0gLz4pfVxuICAgICAgICA8L3NwYW4+XG4gICAgICApfVxuICAgICAgPHNwYW5cbiAgICAgICAgc3R5bGU9e3tcbiAgICAgICAgICBmb250U2l6ZTogJzEycHgnLFxuICAgICAgICAgIGxpbmVIZWlnaHQ6ICcxNnB4JyxcbiAgICAgICAgICBkaXNwbGF5OiAnYmxvY2snLFxuICAgICAgICAgIHRleHREZWNvcmF0aW9uOiB2aXNpYmxlID8gJ25vbmUnIDogJ2xpbmUtdGhyb3VnaCcsXG4gICAgICAgICAgdGV4dFdyYXA6ICdub3dyYXAnLFxuICAgICAgICB9fVxuICAgICAgPlxuICAgICAgICB7eUtleUZvcm1hdHRlZCA/IHlLZXlGb3JtYXR0ZWQgOiB5S2V5fVxuICAgICAgPC9zcGFuPlxuICAgIDwvYnV0dG9uPlxuICApO1xufTtcbiJdfQ== */",
45097
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__$6
45098
+ }),
45099
+ children: [jsx(LegendItemBox, {
45100
+ color: color,
45101
+ style: style,
45102
+ yKey: yKey
45103
+ }), relevantRules.length > 0 && relevantRules.map(function (rule) {
45104
+ return jsx(LegendItemBox, {
45105
+ color: rule.color,
45106
+ style: style,
45107
+ yKey: yKey
45108
+ }, "rule-" + JSON.stringify(rule));
45109
+ })]
45110
+ }), style.type === 'bar' && jsxs("span", {
45111
+ className: /*#__PURE__*/css$1(process.env.NODE_ENV === "production" ? {
45112
+ name: "6b52m3",
45113
+ styles: "display:flex;flex-direction:row;align-items:center;gap:2px"
45114
+ } : {
45115
+ name: "pglbco-LegendItem",
45116
+ styles: "display:flex;flex-direction:row;align-items:center;gap:2px;label:LegendItem;",
45117
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZEl0ZW0udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQStEeUIiLCJmaWxlIjoiTGVnZW5kSXRlbS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgdXNlTWVtbyB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IExlZ2VuZEl0ZW1Cb3ggfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94JztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBMZWdlbmRJdGVtU3F1YXJlLCBMZWdlbmRJdGVtVHJpYW5nbGUgfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94L0xlZ2VuZEl0ZW1Cb3gnO1xuaW1wb3J0IHsgU2hhcGVEZWZpbml0aW9uLCBDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9DaGFydHNWMi90eXBlcyc7XG5pbXBvcnQgeyBMaW5lU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9MaW5lQ2hhcnRWMi90eXBlcyc7XG5pbXBvcnQgeyBCYXJTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0JhckNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQXJlYVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQXJlYUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQnViYmxlU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9CdWJibGVDaGFydFYyL3R5cGVzJztcblxuaW50ZXJmYWNlIExlZ2VuZEl0ZW1Qcm9wczxUPiBleHRlbmRzIFNoYXBlRGVmaW5pdGlvbjxUPiB7XG4gIG9uQ2xpY2s6ICgpID0+IHZvaWQ7XG4gIHZpc2libGU6IGJvb2xlYW47XG4gIHlLZXlGb3JtYXR0ZWQ6IHN0cmluZyB8IHVuZGVmaW5lZDtcbiAgY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXM6IEFycmF5PENvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGU+O1xufVxuXG5leHBvcnQgY29uc3QgTGVnZW5kSXRlbSA9ICh7XG4gIHlLZXksXG4gIHlLZXlGb3JtYXR0ZWQsXG4gIGNvbG9yLFxuICBzdHlsZSxcbiAgb25DbGljayxcbiAgdmlzaWJsZSxcbiAgY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXMsXG59OiBMZWdlbmRJdGVtUHJvcHM8QmFyU3R5bGVzIHwgTGluZVN0eWxlcyB8IEFyZWFTdHlsZXMgfCBCdWJibGVTdHlsZXM+KSA9PiB7XG4gIGNvbnN0IHJlbGV2YW50UnVsZXMgPSB1c2VNZW1vKFxuICAgICgpID0+IGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzLmZpbHRlcigocnVsZSkgPT4geUtleS5pbmNsdWRlcyhydWxlLnlLZXkpKSxcbiAgICBbY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXNdLFxuICApO1xuXG4gIHJldHVybiAoXG4gICAgPGJ1dHRvblxuICAgICAga2V5PXtgbGVnZW5kLSR7eUtleX1gfVxuICAgICAgdHlwZT1cImJ1dHRvblwiXG4gICAgICBzdHlsZT17e1xuICAgICAgICBhbGw6ICd1bnNldCcsXG4gICAgICAgIGRpc3BsYXk6ICdmbGV4JyxcbiAgICAgICAgZmxleFdyYXA6ICdub3dyYXAnLFxuICAgICAgICBhbGlnbkl0ZW1zOiAnY2VudGVyJyxcbiAgICAgICAgb3V0bGluZTogJ3JldmVydCcsXG4gICAgICAgIGdhcDogJzRweCcsXG4gICAgICAgIHBhZGRpbmc6ICc0cHgnLFxuICAgICAgICBjdXJzb3I6ICdwb2ludGVyJyxcbiAgICAgICAgbWFyZ2luUmlnaHQ6ICcxMHB4JyxcbiAgICAgIH19XG4gICAgICBvbkNsaWNrPXtvbkNsaWNrfVxuICAgID5cbiAgICAgIHtzdHlsZS50eXBlID09PSAnbGluZScgJiYgKFxuICAgICAgICA8c3BhbiBjbGFzc05hbWU9e2Nzcyh7IGhlaWdodDogMTAsIGRpc3BsYXk6ICdmbGV4JyB9KX0+XG4gICAgICAgICAgPExlZ2VuZEl0ZW1Cb3ggY29sb3I9e2NvbG9yfSBzdHlsZT17c3R5bGUgYXMgTGluZVN0eWxlc30geUtleT17eUtleX0gLz5cbiAgICAgICAgICB7cmVsZXZhbnRSdWxlcy5sZW5ndGggPiAwICYmXG4gICAgICAgICAgICByZWxldmFudFJ1bGVzLm1hcCgocnVsZSkgPT4gKFxuICAgICAgICAgICAgICA8TGVnZW5kSXRlbUJveFxuICAgICAgICAgICAgICAgIGNvbG9yPXtydWxlLmNvbG9yfVxuICAgICAgICAgICAgICAgIGtleT17YHJ1bGUtJHtKU09OLnN0cmluZ2lmeShydWxlKX1gfVxuICAgICAgICAgICAgICAgIHN0eWxlPXtzdHlsZSBhcyBMaW5lU3R5bGVzfVxuICAgICAgICAgICAgICAgIHlLZXk9e3lLZXl9XG4gICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICApKX1cbiAgICAgICAgPC9zcGFuPlxuICAgICAgKX1cbiAgICAgIHtzdHlsZS50eXBlID09PSAnYmFyJyAmJiAoXG4gICAgICAgIDxzcGFuIGNsYXNzTmFtZT17Y3NzKHsgZGlzcGxheTogJ2ZsZXgnLCBmbGV4RGlyZWN0aW9uOiAncm93JywgYWxpZ25JdGVtczogJ2NlbnRlcicsIGdhcDogMiB9KX0+XG4gICAgICAgICAgPExlZ2VuZEl0ZW1TcXVhcmUgY29sb3I9e2NvbG9yfSAvPlxuICAgICAgICAgIHtyZWxldmFudFJ1bGVzLmxlbmd0aCA+IDAgJiZcbiAgICAgICAgICAgIHJlbGV2YW50UnVsZXMubWFwKChydWxlKSA9PiA8TGVnZW5kSXRlbVNxdWFyZSBjb2xvcj17cnVsZS5jb2xvcn0ga2V5PXtgcnVsZS0ke0pTT04uc3RyaW5naWZ5KHJ1bGUpfWB9IC8+KX1cbiAgICAgICAgPC9zcGFuPlxuICAgICAgKX1cbiAgICAgIHtzdHlsZS50eXBlID09PSAnYXJlYScgJiYgKFxuICAgICAgICA8c3BhbiBjbGFzc05hbWU9e2Nzcyh7IGRpc3BsYXk6ICdmbGV4JywgZmxleERpcmVjdGlvbjogJ3JvdycsIGFsaWduSXRlbXM6ICdjZW50ZXInLCBnYXA6IDIgfSl9PlxuICAgICAgICAgIDxMZWdlbmRJdGVtVHJpYW5nbGUgY29sb3I9e2NvbG9yfSAvPlxuICAgICAgICAgIHtyZWxldmFudFJ1bGVzLmxlbmd0aCA+IDAgJiZcbiAgICAgICAgICAgIHJlbGV2YW50UnVsZXMubWFwKChydWxlKSA9PiA8TGVnZW5kSXRlbVRyaWFuZ2xlIGNvbG9yPXtydWxlLmNvbG9yfSBrZXk9e2BydWxlLSR7SlNPTi5zdHJpbmdpZnkocnVsZSl9YH0gLz4pfVxuICAgICAgICA8L3NwYW4+XG4gICAgICApfVxuICAgICAgPHNwYW5cbiAgICAgICAgc3R5bGU9e3tcbiAgICAgICAgICBmb250U2l6ZTogJzEycHgnLFxuICAgICAgICAgIGxpbmVIZWlnaHQ6ICcxNnB4JyxcbiAgICAgICAgICBkaXNwbGF5OiAnYmxvY2snLFxuICAgICAgICAgIHRleHREZWNvcmF0aW9uOiB2aXNpYmxlID8gJ25vbmUnIDogJ2xpbmUtdGhyb3VnaCcsXG4gICAgICAgICAgdGV4dFdyYXA6ICdub3dyYXAnLFxuICAgICAgICB9fVxuICAgICAgPlxuICAgICAgICB7eUtleUZvcm1hdHRlZCA/IHlLZXlGb3JtYXR0ZWQgOiB5S2V5fVxuICAgICAgPC9zcGFuPlxuICAgIDwvYnV0dG9uPlxuICApO1xufTtcbiJdfQ== */",
45118
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__$6
45119
+ }),
45120
+ children: [jsx(LegendItemSquare, {
45121
+ color: color
45122
+ }), relevantRules.length > 0 && relevantRules.map(function (rule) {
45123
+ return jsx(LegendItemSquare, {
45124
+ color: rule.color
45125
+ }, "rule-" + JSON.stringify(rule));
45126
+ })]
45127
+ }), style.type === 'area' && jsxs("span", {
45128
+ className: /*#__PURE__*/css$1(process.env.NODE_ENV === "production" ? {
45129
+ name: "6b52m3",
45130
+ styles: "display:flex;flex-direction:row;align-items:center;gap:2px"
45131
+ } : {
45132
+ name: "pglbco-LegendItem",
45133
+ styles: "display:flex;flex-direction:row;align-items:center;gap:2px;label:LegendItem;",
45134
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZEl0ZW0udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXNFeUIiLCJmaWxlIjoiTGVnZW5kSXRlbS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgdXNlTWVtbyB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IExlZ2VuZEl0ZW1Cb3ggfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94JztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBMZWdlbmRJdGVtU3F1YXJlLCBMZWdlbmRJdGVtVHJpYW5nbGUgfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94L0xlZ2VuZEl0ZW1Cb3gnO1xuaW1wb3J0IHsgU2hhcGVEZWZpbml0aW9uLCBDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9DaGFydHNWMi90eXBlcyc7XG5pbXBvcnQgeyBMaW5lU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9MaW5lQ2hhcnRWMi90eXBlcyc7XG5pbXBvcnQgeyBCYXJTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0JhckNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQXJlYVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQXJlYUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQnViYmxlU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9CdWJibGVDaGFydFYyL3R5cGVzJztcblxuaW50ZXJmYWNlIExlZ2VuZEl0ZW1Qcm9wczxUPiBleHRlbmRzIFNoYXBlRGVmaW5pdGlvbjxUPiB7XG4gIG9uQ2xpY2s6ICgpID0+IHZvaWQ7XG4gIHZpc2libGU6IGJvb2xlYW47XG4gIHlLZXlGb3JtYXR0ZWQ6IHN0cmluZyB8IHVuZGVmaW5lZDtcbiAgY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXM6IEFycmF5PENvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGU+O1xufVxuXG5leHBvcnQgY29uc3QgTGVnZW5kSXRlbSA9ICh7XG4gIHlLZXksXG4gIHlLZXlGb3JtYXR0ZWQsXG4gIGNvbG9yLFxuICBzdHlsZSxcbiAgb25DbGljayxcbiAgdmlzaWJsZSxcbiAgY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXMsXG59OiBMZWdlbmRJdGVtUHJvcHM8QmFyU3R5bGVzIHwgTGluZVN0eWxlcyB8IEFyZWFTdHlsZXMgfCBCdWJibGVTdHlsZXM+KSA9PiB7XG4gIGNvbnN0IHJlbGV2YW50UnVsZXMgPSB1c2VNZW1vKFxuICAgICgpID0+IGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzLmZpbHRlcigocnVsZSkgPT4geUtleS5pbmNsdWRlcyhydWxlLnlLZXkpKSxcbiAgICBbY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXNdLFxuICApO1xuXG4gIHJldHVybiAoXG4gICAgPGJ1dHRvblxuICAgICAga2V5PXtgbGVnZW5kLSR7eUtleX1gfVxuICAgICAgdHlwZT1cImJ1dHRvblwiXG4gICAgICBzdHlsZT17e1xuICAgICAgICBhbGw6ICd1bnNldCcsXG4gICAgICAgIGRpc3BsYXk6ICdmbGV4JyxcbiAgICAgICAgZmxleFdyYXA6ICdub3dyYXAnLFxuICAgICAgICBhbGlnbkl0ZW1zOiAnY2VudGVyJyxcbiAgICAgICAgb3V0bGluZTogJ3JldmVydCcsXG4gICAgICAgIGdhcDogJzRweCcsXG4gICAgICAgIHBhZGRpbmc6ICc0cHgnLFxuICAgICAgICBjdXJzb3I6ICdwb2ludGVyJyxcbiAgICAgICAgbWFyZ2luUmlnaHQ6ICcxMHB4JyxcbiAgICAgIH19XG4gICAgICBvbkNsaWNrPXtvbkNsaWNrfVxuICAgID5cbiAgICAgIHtzdHlsZS50eXBlID09PSAnbGluZScgJiYgKFxuICAgICAgICA8c3BhbiBjbGFzc05hbWU9e2Nzcyh7IGhlaWdodDogMTAsIGRpc3BsYXk6ICdmbGV4JyB9KX0+XG4gICAgICAgICAgPExlZ2VuZEl0ZW1Cb3ggY29sb3I9e2NvbG9yfSBzdHlsZT17c3R5bGUgYXMgTGluZVN0eWxlc30geUtleT17eUtleX0gLz5cbiAgICAgICAgICB7cmVsZXZhbnRSdWxlcy5sZW5ndGggPiAwICYmXG4gICAgICAgICAgICByZWxldmFudFJ1bGVzLm1hcCgocnVsZSkgPT4gKFxuICAgICAgICAgICAgICA8TGVnZW5kSXRlbUJveFxuICAgICAgICAgICAgICAgIGNvbG9yPXtydWxlLmNvbG9yfVxuICAgICAgICAgICAgICAgIGtleT17YHJ1bGUtJHtKU09OLnN0cmluZ2lmeShydWxlKX1gfVxuICAgICAgICAgICAgICAgIHN0eWxlPXtzdHlsZSBhcyBMaW5lU3R5bGVzfVxuICAgICAgICAgICAgICAgIHlLZXk9e3lLZXl9XG4gICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICApKX1cbiAgICAgICAgPC9zcGFuPlxuICAgICAgKX1cbiAgICAgIHtzdHlsZS50eXBlID09PSAnYmFyJyAmJiAoXG4gICAgICAgIDxzcGFuIGNsYXNzTmFtZT17Y3NzKHsgZGlzcGxheTogJ2ZsZXgnLCBmbGV4RGlyZWN0aW9uOiAncm93JywgYWxpZ25JdGVtczogJ2NlbnRlcicsIGdhcDogMiB9KX0+XG4gICAgICAgICAgPExlZ2VuZEl0ZW1TcXVhcmUgY29sb3I9e2NvbG9yfSAvPlxuICAgICAgICAgIHtyZWxldmFudFJ1bGVzLmxlbmd0aCA+IDAgJiZcbiAgICAgICAgICAgIHJlbGV2YW50UnVsZXMubWFwKChydWxlKSA9PiA8TGVnZW5kSXRlbVNxdWFyZSBjb2xvcj17cnVsZS5jb2xvcn0ga2V5PXtgcnVsZS0ke0pTT04uc3RyaW5naWZ5KHJ1bGUpfWB9IC8+KX1cbiAgICAgICAgPC9zcGFuPlxuICAgICAgKX1cbiAgICAgIHtzdHlsZS50eXBlID09PSAnYXJlYScgJiYgKFxuICAgICAgICA8c3BhbiBjbGFzc05hbWU9e2Nzcyh7IGRpc3BsYXk6ICdmbGV4JywgZmxleERpcmVjdGlvbjogJ3JvdycsIGFsaWduSXRlbXM6ICdjZW50ZXInLCBnYXA6IDIgfSl9PlxuICAgICAgICAgIDxMZWdlbmRJdGVtVHJpYW5nbGUgY29sb3I9e2NvbG9yfSAvPlxuICAgICAgICAgIHtyZWxldmFudFJ1bGVzLmxlbmd0aCA+IDAgJiZcbiAgICAgICAgICAgIHJlbGV2YW50UnVsZXMubWFwKChydWxlKSA9PiA8TGVnZW5kSXRlbVRyaWFuZ2xlIGNvbG9yPXtydWxlLmNvbG9yfSBrZXk9e2BydWxlLSR7SlNPTi5zdHJpbmdpZnkocnVsZSl9YH0gLz4pfVxuICAgICAgICA8L3NwYW4+XG4gICAgICApfVxuICAgICAgPHNwYW5cbiAgICAgICAgc3R5bGU9e3tcbiAgICAgICAgICBmb250U2l6ZTogJzEycHgnLFxuICAgICAgICAgIGxpbmVIZWlnaHQ6ICcxNnB4JyxcbiAgICAgICAgICBkaXNwbGF5OiAnYmxvY2snLFxuICAgICAgICAgIHRleHREZWNvcmF0aW9uOiB2aXNpYmxlID8gJ25vbmUnIDogJ2xpbmUtdGhyb3VnaCcsXG4gICAgICAgICAgdGV4dFdyYXA6ICdub3dyYXAnLFxuICAgICAgICB9fVxuICAgICAgPlxuICAgICAgICB7eUtleUZvcm1hdHRlZCA/IHlLZXlGb3JtYXR0ZWQgOiB5S2V5fVxuICAgICAgPC9zcGFuPlxuICAgIDwvYnV0dG9uPlxuICApO1xufTtcbiJdfQ== */",
45135
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__$6
45136
+ }),
45137
+ children: [jsx(LegendItemTriangle, {
45138
+ color: color
45139
+ }), relevantRules.length > 0 && relevantRules.map(function (rule) {
45140
+ return jsx(LegendItemTriangle, {
45141
+ color: rule.color
45142
+ }, "rule-" + JSON.stringify(rule));
45143
+ })]
45144
+ }), jsx("span", {
45145
+ style: {
45146
+ fontSize: '12px',
45147
+ lineHeight: '16px',
45148
+ display: 'block',
45149
+ textDecoration: visible ? 'none' : 'line-through',
45150
+ textWrap: 'nowrap'
45151
+ },
45152
+ children: yKeyFormatted ? yKeyFormatted : yKey
45153
+ })]
45154
+ }, "legend-" + yKey);
45155
+ };
45156
+
45157
+ function _EMOTION_STRINGIFIED_CSS_ERROR__$7() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
45158
+ var Legend$1 = function Legend(_ref) {
45159
+ var keys = _ref.keys,
45160
+ setVisibleYKeys = _ref.setVisibleYKeys,
45161
+ marginLeft = _ref.marginLeft,
45162
+ items = _ref.items;
45163
+ var handleOnClick = function handleOnClick(item, legendItem) {
45164
+ setVisibleYKeys && setVisibleYKeys(function (prev) {
45165
+ var newVisibleLegendItems = [];
45166
+ if (prev.length === item.legendItems.length) {
45167
+ newVisibleLegendItems = [legendItem.yKey];
45168
+ } else {
45169
+ if (prev.includes(legendItem.yKey)) {
45170
+ newVisibleLegendItems = prev.filter(function (prevLegendItemId) {
45171
+ return prevLegendItemId !== legendItem.yKey;
45172
+ });
45173
+ } else {
45174
+ newVisibleLegendItems = [].concat(prev, [legendItem.yKey]);
45175
+ }
45176
+ }
45177
+ return newVisibleLegendItems.length === 0 ? item.legendItems.map(function (legendItem) {
45178
+ return legendItem.yKey;
45179
+ }) : newVisibleLegendItems;
45180
+ });
45181
+ };
45182
+ return jsx("div", {
45183
+ className: /*#__PURE__*/css$1(process.env.NODE_ENV === "production" ? {
45184
+ name: "1nbollx",
45185
+ styles: "height:40px;padding-top:8px"
45186
+ } : {
45187
+ name: "qz6h7j-Legend",
45188
+ styles: "height:40px;padding-top:8px;label:Legend;",
45189
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBc0RvQiIsImZpbGUiOiJMZWdlbmQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0LCB7IEZyYWdtZW50IH0gZnJvbSAncmVhY3QnO1xuXG5pbXBvcnQgeyBMZWdlbmRJdGVtIH0gZnJvbSAnLi9MZWdlbmRJdGVtJztcbmltcG9ydCB7IFNoYXBlRGVmaW5pdGlvbiwgQ29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZSwgS2V5IH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9DaGFydHNWMi90eXBlcyc7XG5pbXBvcnQgeyBTY3JvbGxiYXIgfSBmcm9tICcuLi8uLi8uLi9TY3JvbGxiYXIvU2Nyb2xsYmFyJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBCYXJTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0JhckNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgTGluZVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvTGluZUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQXJlYVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQXJlYUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQnViYmxlU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9CdWJibGVDaGFydFYyL3R5cGVzJztcblxudHlwZSBJdGVtPFQ+ID0ge1xuICBsZWdlbmRJdGVtczogQXJyYXk8U2hhcGVEZWZpbml0aW9uPFQ+PjtcbiAgdmlzaWJsZVlLZXlzOiBBcnJheTxzdHJpbmc+O1xuICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlczogQXJyYXk8Q29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZT47XG59O1xuZXhwb3J0IHR5cGUgTGVnZW5kUHJvcHM8VD4gPSB7XG4gIHNldFZpc2libGVZS2V5cz86IFJlYWN0LkRpc3BhdGNoPFJlYWN0LlNldFN0YXRlQWN0aW9uPEFycmF5PHN0cmluZz4+PjtcbiAga2V5czogeyBba2V5OiBzdHJpbmddOiBLZXkgfTtcbiAgbWFyZ2luTGVmdDogbnVtYmVyO1xuICBpdGVtczogSXRlbTxUPltdO1xufTtcblxuZXhwb3J0IGNvbnN0IExlZ2VuZCA9ICh7XG4gIGtleXMsXG4gIHNldFZpc2libGVZS2V5cyxcbiAgbWFyZ2luTGVmdCxcbiAgaXRlbXMsXG59OiBMZWdlbmRQcm9wczxCYXJTdHlsZXMgfCBMaW5lU3R5bGVzIHwgQXJlYVN0eWxlcyB8IEJ1YmJsZVN0eWxlcz4pID0+IHtcbiAgY29uc3QgaGFuZGxlT25DbGljayA9IChcbiAgICBpdGVtOiBJdGVtPEJhclN0eWxlcyB8IExpbmVTdHlsZXMgfCBBcmVhU3R5bGVzIHwgQnViYmxlU3R5bGVzPixcbiAgICBsZWdlbmRJdGVtOiBTaGFwZURlZmluaXRpb248QmFyU3R5bGVzIHwgTGluZVN0eWxlcyB8IEFyZWFTdHlsZXMgfCBCdWJibGVTdHlsZXM+XG4gICkgPT4ge1xuICAgIHNldFZpc2libGVZS2V5cyAmJlxuICAgICAgc2V0VmlzaWJsZVlLZXlzKHByZXYgPT4ge1xuICAgICAgICBsZXQgbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zOiBBcnJheTxzdHJpbmc+ID0gW107XG5cbiAgICAgICAgaWYgKHByZXYubGVuZ3RoID09PSBpdGVtLmxlZ2VuZEl0ZW1zLmxlbmd0aCkge1xuICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IFtsZWdlbmRJdGVtLnlLZXldO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgIGlmIChwcmV2LmluY2x1ZGVzKGxlZ2VuZEl0ZW0ueUtleSkpIHtcbiAgICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IHByZXYuZmlsdGVyKHByZXZMZWdlbmRJdGVtSWQgPT4gcHJldkxlZ2VuZEl0ZW1JZCAhPT0gbGVnZW5kSXRlbS55S2V5KTtcbiAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zID0gWy4uLnByZXYsIGxlZ2VuZEl0ZW0ueUtleV07XG4gICAgICAgICAgfVxuICAgICAgICB9XG5cbiAgICAgICAgcmV0dXJuIG5ld1Zpc2libGVMZWdlbmRJdGVtcy5sZW5ndGggPT09IDBcbiAgICAgICAgICA/IGl0ZW0ubGVnZW5kSXRlbXMubWFwKGxlZ2VuZEl0ZW0gPT4gbGVnZW5kSXRlbS55S2V5KVxuICAgICAgICAgIDogbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zO1xuICAgICAgfSk7XG4gIH07XG5cbiAgcmV0dXJuIChcbiAgICA8ZGl2IGNsYXNzTmFtZT17Y3NzKHsgaGVpZ2h0OiA0MCwgcGFkZGluZ1RvcDogOCB9KX0+XG4gICAgICA8U2Nyb2xsYmFyXG4gICAgICAgIGNsYXNzTmFtZT17Y3NzKHtcbiAgICAgICAgICBkaXNwbGF5OiAnZmxleCcsXG4gICAgICAgICAgZmxleERpcmVjdGlvbjogJ3JvdycsXG4gICAgICAgICAgZmxleFdyYXA6ICdub3dyYXAnLFxuICAgICAgICAgIGFsaWduSXRlbXM6ICdjZW50ZXInLFxuICAgICAgICAgIG1hcmdpbkxlZnQ6IG1hcmdpbkxlZnQgPyBgJHttYXJnaW5MZWZ0fXB4YCA6IHVuZGVmaW5lZCxcbiAgICAgICAgfSl9XG4gICAgICAgIHg9e3RydWV9XG4gICAgICA+XG4gICAgICAgIHtpdGVtcy5tYXAoKGl0ZW0sIGluZGV4KSA9PiAoXG4gICAgICAgICAgPEZyYWdtZW50IGtleT17aW5kZXh9PlxuICAgICAgICAgICAge2l0ZW0ubGVnZW5kSXRlbXMubWFwKFxuICAgICAgICAgICAgICBsZWdlbmRJdGVtID0+XG4gICAgICAgICAgICAgICAga2V5c1tsZWdlbmRJdGVtLnlLZXldICYmIChcbiAgICAgICAgICAgICAgICAgIDxMZWdlbmRJdGVtXG4gICAgICAgICAgICAgICAgICAgIHsuLi5sZWdlbmRJdGVtfVxuICAgICAgICAgICAgICAgICAgICBrZXk9e2BsZWdlbmQtJHtsZWdlbmRJdGVtLnlLZXl9YH1cbiAgICAgICAgICAgICAgICAgICAgeUtleUZvcm1hdHRlZD17a2V5c1tsZWdlbmRJdGVtLnlLZXldLmtleUZvcm1hdHRlZH1cbiAgICAgICAgICAgICAgICAgICAgb25DbGljaz17KCkgPT4ge1xuICAgICAgICAgICAgICAgICAgICAgIGhhbmRsZU9uQ2xpY2soaXRlbSwgbGVnZW5kSXRlbSk7XG4gICAgICAgICAgICAgICAgICAgIH19XG4gICAgICAgICAgICAgICAgICAgIHZpc2libGU9e3NldFZpc2libGVZS2V5cyA/IGl0ZW0udmlzaWJsZVlLZXlzLmluY2x1ZGVzKGxlZ2VuZEl0ZW0ueUtleSkgOiB0cnVlfVxuICAgICAgICAgICAgICAgICAgICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlcz17aXRlbS5jb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlc31cbiAgICAgICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICAgICAgKVxuICAgICAgICAgICAgKX1cbiAgICAgICAgICA8L0ZyYWdtZW50PlxuICAgICAgICApKX1cbiAgICAgIDwvU2Nyb2xsYmFyPlxuICAgIDwvZGl2PlxuICApO1xufTtcbiJdfQ== */",
45190
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__$7
45191
+ }),
45192
+ children: jsx(Scrollbar, {
45193
+ className: /*#__PURE__*/css$1({
45194
+ display: 'flex',
45195
+ flexDirection: 'row',
45196
+ flexWrap: 'nowrap',
45197
+ alignItems: 'center',
45198
+ marginLeft: marginLeft ? marginLeft + "px" : undefined
45199
+ }, process.env.NODE_ENV === "production" ? "" : ";label:Legend;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBd0RtQiIsImZpbGUiOiJMZWdlbmQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0LCB7IEZyYWdtZW50IH0gZnJvbSAncmVhY3QnO1xuXG5pbXBvcnQgeyBMZWdlbmRJdGVtIH0gZnJvbSAnLi9MZWdlbmRJdGVtJztcbmltcG9ydCB7IFNoYXBlRGVmaW5pdGlvbiwgQ29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZSwgS2V5IH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9DaGFydHNWMi90eXBlcyc7XG5pbXBvcnQgeyBTY3JvbGxiYXIgfSBmcm9tICcuLi8uLi8uLi9TY3JvbGxiYXIvU2Nyb2xsYmFyJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBCYXJTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0JhckNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgTGluZVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvTGluZUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQXJlYVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQXJlYUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQnViYmxlU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9CdWJibGVDaGFydFYyL3R5cGVzJztcblxudHlwZSBJdGVtPFQ+ID0ge1xuICBsZWdlbmRJdGVtczogQXJyYXk8U2hhcGVEZWZpbml0aW9uPFQ+PjtcbiAgdmlzaWJsZVlLZXlzOiBBcnJheTxzdHJpbmc+O1xuICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlczogQXJyYXk8Q29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZT47XG59O1xuZXhwb3J0IHR5cGUgTGVnZW5kUHJvcHM8VD4gPSB7XG4gIHNldFZpc2libGVZS2V5cz86IFJlYWN0LkRpc3BhdGNoPFJlYWN0LlNldFN0YXRlQWN0aW9uPEFycmF5PHN0cmluZz4+PjtcbiAga2V5czogeyBba2V5OiBzdHJpbmddOiBLZXkgfTtcbiAgbWFyZ2luTGVmdDogbnVtYmVyO1xuICBpdGVtczogSXRlbTxUPltdO1xufTtcblxuZXhwb3J0IGNvbnN0IExlZ2VuZCA9ICh7XG4gIGtleXMsXG4gIHNldFZpc2libGVZS2V5cyxcbiAgbWFyZ2luTGVmdCxcbiAgaXRlbXMsXG59OiBMZWdlbmRQcm9wczxCYXJTdHlsZXMgfCBMaW5lU3R5bGVzIHwgQXJlYVN0eWxlcyB8IEJ1YmJsZVN0eWxlcz4pID0+IHtcbiAgY29uc3QgaGFuZGxlT25DbGljayA9IChcbiAgICBpdGVtOiBJdGVtPEJhclN0eWxlcyB8IExpbmVTdHlsZXMgfCBBcmVhU3R5bGVzIHwgQnViYmxlU3R5bGVzPixcbiAgICBsZWdlbmRJdGVtOiBTaGFwZURlZmluaXRpb248QmFyU3R5bGVzIHwgTGluZVN0eWxlcyB8IEFyZWFTdHlsZXMgfCBCdWJibGVTdHlsZXM+XG4gICkgPT4ge1xuICAgIHNldFZpc2libGVZS2V5cyAmJlxuICAgICAgc2V0VmlzaWJsZVlLZXlzKHByZXYgPT4ge1xuICAgICAgICBsZXQgbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zOiBBcnJheTxzdHJpbmc+ID0gW107XG5cbiAgICAgICAgaWYgKHByZXYubGVuZ3RoID09PSBpdGVtLmxlZ2VuZEl0ZW1zLmxlbmd0aCkge1xuICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IFtsZWdlbmRJdGVtLnlLZXldO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgIGlmIChwcmV2LmluY2x1ZGVzKGxlZ2VuZEl0ZW0ueUtleSkpIHtcbiAgICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IHByZXYuZmlsdGVyKHByZXZMZWdlbmRJdGVtSWQgPT4gcHJldkxlZ2VuZEl0ZW1JZCAhPT0gbGVnZW5kSXRlbS55S2V5KTtcbiAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zID0gWy4uLnByZXYsIGxlZ2VuZEl0ZW0ueUtleV07XG4gICAgICAgICAgfVxuICAgICAgICB9XG5cbiAgICAgICAgcmV0dXJuIG5ld1Zpc2libGVMZWdlbmRJdGVtcy5sZW5ndGggPT09IDBcbiAgICAgICAgICA/IGl0ZW0ubGVnZW5kSXRlbXMubWFwKGxlZ2VuZEl0ZW0gPT4gbGVnZW5kSXRlbS55S2V5KVxuICAgICAgICAgIDogbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zO1xuICAgICAgfSk7XG4gIH07XG5cbiAgcmV0dXJuIChcbiAgICA8ZGl2IGNsYXNzTmFtZT17Y3NzKHsgaGVpZ2h0OiA0MCwgcGFkZGluZ1RvcDogOCB9KX0+XG4gICAgICA8U2Nyb2xsYmFyXG4gICAgICAgIGNsYXNzTmFtZT17Y3NzKHtcbiAgICAgICAgICBkaXNwbGF5OiAnZmxleCcsXG4gICAgICAgICAgZmxleERpcmVjdGlvbjogJ3JvdycsXG4gICAgICAgICAgZmxleFdyYXA6ICdub3dyYXAnLFxuICAgICAgICAgIGFsaWduSXRlbXM6ICdjZW50ZXInLFxuICAgICAgICAgIG1hcmdpbkxlZnQ6IG1hcmdpbkxlZnQgPyBgJHttYXJnaW5MZWZ0fXB4YCA6IHVuZGVmaW5lZCxcbiAgICAgICAgfSl9XG4gICAgICAgIHg9e3RydWV9XG4gICAgICA+XG4gICAgICAgIHtpdGVtcy5tYXAoKGl0ZW0sIGluZGV4KSA9PiAoXG4gICAgICAgICAgPEZyYWdtZW50IGtleT17aW5kZXh9PlxuICAgICAgICAgICAge2l0ZW0ubGVnZW5kSXRlbXMubWFwKFxuICAgICAgICAgICAgICBsZWdlbmRJdGVtID0+XG4gICAgICAgICAgICAgICAga2V5c1tsZWdlbmRJdGVtLnlLZXldICYmIChcbiAgICAgICAgICAgICAgICAgIDxMZWdlbmRJdGVtXG4gICAgICAgICAgICAgICAgICAgIHsuLi5sZWdlbmRJdGVtfVxuICAgICAgICAgICAgICAgICAgICBrZXk9e2BsZWdlbmQtJHtsZWdlbmRJdGVtLnlLZXl9YH1cbiAgICAgICAgICAgICAgICAgICAgeUtleUZvcm1hdHRlZD17a2V5c1tsZWdlbmRJdGVtLnlLZXldLmtleUZvcm1hdHRlZH1cbiAgICAgICAgICAgICAgICAgICAgb25DbGljaz17KCkgPT4ge1xuICAgICAgICAgICAgICAgICAgICAgIGhhbmRsZU9uQ2xpY2soaXRlbSwgbGVnZW5kSXRlbSk7XG4gICAgICAgICAgICAgICAgICAgIH19XG4gICAgICAgICAgICAgICAgICAgIHZpc2libGU9e3NldFZpc2libGVZS2V5cyA/IGl0ZW0udmlzaWJsZVlLZXlzLmluY2x1ZGVzKGxlZ2VuZEl0ZW0ueUtleSkgOiB0cnVlfVxuICAgICAgICAgICAgICAgICAgICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlcz17aXRlbS5jb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlc31cbiAgICAgICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICAgICAgKVxuICAgICAgICAgICAgKX1cbiAgICAgICAgICA8L0ZyYWdtZW50PlxuICAgICAgICApKX1cbiAgICAgIDwvU2Nyb2xsYmFyPlxuICAgIDwvZGl2PlxuICApO1xufTtcbiJdfQ== */"),
45200
+ x: true,
45201
+ children: items.map(function (item, index) {
45202
+ return jsx(Fragment, {
45203
+ children: item.legendItems.map(function (legendItem) {
45204
+ return keys[legendItem.yKey] && createElement$1(LegendItem, _extends({}, legendItem, {
45205
+ key: "legend-" + legendItem.yKey,
45206
+ yKeyFormatted: keys[legendItem.yKey].keyFormatted,
45207
+ onClick: function onClick() {
45208
+ handleOnClick(item, legendItem);
45209
+ },
45210
+ visible: setVisibleYKeys ? item.visibleYKeys.includes(legendItem.yKey) : true,
45211
+ conditionalFormattingRules: item.conditionalFormattingRules
45212
+ }));
45213
+ })
45214
+ }, index);
45215
+ })
45216
+ })
45217
+ });
45218
+ };
45219
+
45220
+ var thresholdId$1 = function thresholdId(args, idPrefix, position, uniqueId) {
45221
+ var rawIdKey = args.yKey + "_" + args.value + "_" + args.operator;
45222
+ return (position + "_" + idPrefix + "_" + uniqueId + "_" + btoa(rawIdKey)).replace(/=/g, '');
45223
+ };
45224
+ function buildClipPathId$1(rule, idPrefix, uniqueId) {
45225
+ var isGreater = rule.operator === '>=';
45226
+ var clipPathId = isGreater ? thresholdId$1(rule, idPrefix, 'above', uniqueId) : thresholdId$1(rule, idPrefix, 'below', uniqueId);
45227
+ return clipPathId;
45228
+ }
45229
+ function getRule(rules, yKey) {
45230
+ return rules.filter(function (threshold) {
45231
+ return threshold.yKey === yKey;
45232
+ });
45233
+ }
45234
+
45235
+ var ThresholdArea = function ThresholdArea(props) {
45236
+ var chartHeight = props.height - props.margin.top;
45237
+ return jsxs(Fragment, {
45238
+ children: [jsx("g", {
45239
+ transform: "translate(50, 0)",
45240
+ children: props.rules.map(function (thresh, index) {
45241
+ var _props$theme$stroke, _props$theme;
45242
+ var thresholdYCoord = props.yScale(thresh.value);
45243
+ return jsx("g", {
45244
+ children: jsx("line", {
45245
+ x1: 0,
45246
+ y1: thresholdYCoord,
45247
+ x2: props.width - props.margin.right - props.margin.left,
45248
+ y2: thresholdYCoord,
45249
+ stroke: (_props$theme$stroke = (_props$theme = props.theme) == null ? void 0 : _props$theme.stroke) != null ? _props$theme$stroke : '#F4F4F4',
45250
+ strokeWidth: "1",
45251
+ fill: "transparent",
45252
+ "data-themeapi": "charts.threshold.stroke"
45253
+ })
45254
+ }, "threshold-" + index);
45255
+ })
45256
+ }), jsx("defs", {
45257
+ children: props.rules.map(function (thresh, index) {
45258
+ var thresholdYCoord = props.yScale(thresh.value);
45259
+ if (!thresholdYCoord) return null;
45260
+ return jsxs(Fragment, {
45261
+ children: [jsx("clipPath", {
45262
+ id: thresholdId$1(thresh, props.idPrefix, 'above', props.uniqueId),
45263
+ children: jsx("rect", {
45264
+ x: "0",
45265
+ y: "0",
45266
+ width: "100%",
45267
+ height: thresholdYCoord
45268
+ })
45269
+ }), jsx("clipPath", {
45270
+ id: thresholdId$1(thresh, props.idPrefix, 'intermediate', props.uniqueId),
45271
+ children: jsx("rect", {
45272
+ x: "0",
45273
+ y: thresholdYCoord,
45274
+ width: "100%",
45275
+ height: 0
45276
+ })
45277
+ }), jsx("clipPath", {
45278
+ id: thresholdId$1(thresh, props.idPrefix, 'below', props.uniqueId),
45279
+ children: jsx("rect", {
45280
+ x: "0",
45281
+ y: thresholdYCoord,
45282
+ width: "100%",
45283
+ height: chartHeight - thresholdYCoord
45284
+ })
45285
+ })]
45286
+ }, "threshold-" + index);
45287
+ })
45288
+ })]
45289
+ });
45290
+ };
45291
+
45292
+ 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)."; }
45293
+ var MIN_TOOLTIP_WIDTH = 180;
45294
+ var TOOLTIP_OFFSET = 20;
45295
+ var SCROLLBAR_WIDTH = 40;
45296
+ var getTooltipValue = function getTooltipValue(tooltipData, yKey) {
45297
+ var data = tooltipData[yKey];
45298
+ return (data == null ? void 0 : data.formattedValue) || (data == null ? void 0 : data.value) || '';
45299
+ };
45300
+ var Tooltip$1 = function Tooltip(_ref) {
45301
+ var _tooltipData$xKey$for, _tooltipData$xKey;
45302
+ var keys = _ref.keys,
45303
+ showRoundedTotal = _ref.showRoundedTotal,
45304
+ tooltipData = _ref.tooltipData,
45305
+ tooltipLeft = _ref.tooltipLeft,
45306
+ tooltipTop = _ref.tooltipTop,
45307
+ xKey = _ref.xKey,
45308
+ yKeys = _ref.yKeys,
45309
+ theme = _ref.theme,
45310
+ items = _ref.items,
45311
+ _ref$shouldShowColorL = _ref.shouldShowColorLegend,
45312
+ shouldShowColorLegend = _ref$shouldShowColorL === void 0 ? true : _ref$shouldShowColorL;
45313
+ var tooltipRef = useRef(null);
45314
+ var _useState = useState({
45315
+ left: tooltipLeft
45316
+ }),
45317
+ position = _useState[0],
45318
+ setPosition = _useState[1];
45319
+ useEffect(function () {
45320
+ var adjustTooltipPosition = function adjustTooltipPosition() {
45321
+ var tooltipElement = tooltipRef.current;
45322
+ if (tooltipElement) {
45323
+ var screenWidth = window.innerWidth;
45324
+ var rect = tooltipElement.getBoundingClientRect();
45325
+ var width = rect.width;
45326
+ if (width < MIN_TOOLTIP_WIDTH) {
45327
+ width = MIN_TOOLTIP_WIDTH;
45328
+ }
45329
+ var left = tooltipLeft + TOOLTIP_OFFSET;
45330
+ if (tooltipLeft + width > screenWidth - SCROLLBAR_WIDTH) {
45331
+ left = tooltipLeft - width - TOOLTIP_OFFSET;
45332
+ }
45333
+ setPosition({
45334
+ left: left
45335
+ });
45336
+ }
45337
+ };
45338
+ adjustTooltipPosition();
45339
+ }, [tooltipLeft]);
45340
+ return /*#__PURE__*/createPortal(jsx("div", {
45341
+ ref: tooltipRef,
45342
+ style: _extends({
45343
+ position: 'absolute',
45344
+ left: position.left,
45345
+ top: tooltipTop,
45346
+ zIndex: 2147483647 * 10
45347
+ }, theme),
45348
+ children: jsxs("div", {
45349
+ style: {
45350
+ wordBreak: 'break-all'
45351
+ },
45352
+ children: [jsx("div", {
45353
+ className: /*#__PURE__*/css$1({
45354
+ fontFamily: 'inherit',
45355
+ lineHeight: 'inherit',
45356
+ letterSpacing: 'inherit',
45357
+ fontWeight: 'bold',
45358
+ fontSize: '15px',
45359
+ width: '100%',
45360
+ minWidth: MIN_TOOLTIP_WIDTH
45361
+ }, process.env.NODE_ENV === "production" ? "" : ";label:Tooltip;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Tooltip.tsx"],"names":[],"mappings":"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"]} */"),
45362
+ children: (_tooltipData$xKey$for = (_tooltipData$xKey = tooltipData[xKey]) == null ? void 0 : _tooltipData$xKey.formattedValue) != null ? _tooltipData$xKey$for : tooltipData[xKey].value
45363
+ }), tooltipData['__quadrant__'] && jsx("div", {
45364
+ className: /*#__PURE__*/css$1(process.env.NODE_ENV === "production" ? {
45365
+ name: "1knrfgk",
45366
+ styles: "font-family:inherit;line-height:inherit;letter-spacing:inherit;font-size:13px;font-weight:bold"
45367
+ } : {
45368
+ name: "woqoxg-Tooltip",
45369
+ styles: "font-family:inherit;line-height:inherit;letter-spacing:inherit;font-size:13px;font-weight:bold;label:Tooltip;",
45370
+ 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"]} */",
45371
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__$8
45372
+ }),
45373
+ children: tooltipData['__quadrant__'].value
45374
+ }), jsx("table", {
45375
+ cellPadding: 0,
45376
+ cellSpacing: 0,
45377
+ className: /*#__PURE__*/css$1(process.env.NODE_ENV === "production" ? {
45378
+ name: "x8luwd",
45379
+ styles: "margin:0;border-spacing:0;border-collapse:inherit;border:none"
45380
+ } : {
45381
+ name: "9a1sa-Tooltip",
45382
+ styles: "margin:0;border-spacing:0;border-collapse:inherit;border:none;label:Tooltip;",
45383
+ 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"]} */",
45384
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__$8
45385
+ }),
45386
+ children: jsxs("tbody", {
45387
+ children: [items.map(function (item, index) {
45388
+ var _item$legendItems;
45389
+ return jsx(Fragment, {
45390
+ children: (_item$legendItems = item.legendItems) == null ? void 0 : _item$legendItems.map(function (legendItem, index) {
45391
+ var _item$visibleYKeys, _item$conditionalForm;
45392
+ if (!tooltipData[legendItem.yKey] || tooltipData[legendItem.yKey].value === null) {
45393
+ // yKey could not be found in tooltipData
45394
+ return null;
45395
+ }
45396
+ return ((_item$visibleYKeys = item.visibleYKeys) == null ? void 0 : _item$visibleYKeys.includes(legendItem.yKey)) && jsxs("tr", {
45397
+ children: [shouldShowColorLegend && jsx("td", {
45398
+ style: {
45399
+ verticalAlign: 'middle',
45400
+ padding: index === 0 ? '12px 8px 0 0' : '8px 8px 0 0',
45401
+ width: 'auto'
45402
+ },
45403
+ children: jsx(LegendItemBox, {
45404
+ color: getColor({
45405
+ defaultColor: legendItem.color,
45406
+ value: tooltipData[legendItem.yKey].value,
45407
+ yKey: legendItem.yKey,
45408
+ conditionalFormattingRules: (_item$conditionalForm = item.conditionalFormattingRules) != null ? _item$conditionalForm : []
45409
+ }),
45410
+ style: legendItem.style,
45411
+ yKey: legendItem.yKey
45412
+ })
45413
+ }), jsx("td", {
45414
+ style: {
45415
+ padding: '8px 0 0 0'
45416
+ },
45417
+ children: keys[legendItem.yKey].keyFormatted
45418
+ }), jsx("td", {
45419
+ style: {
45420
+ fontWeight: 'bold',
45421
+ padding: '8px 0 0 16px'
45422
+ },
45423
+ children: getTooltipValue(tooltipData, legendItem.yKey)
45424
+ })]
45425
+ }, legendItem.yKey + "-" + index + "-" + tooltipData[legendItem.yKey].value);
45426
+ })
45427
+ }, index);
45428
+ }), showRoundedTotal && yKeys && jsxs("tr", {
45429
+ children: [jsx("td", {
45430
+ colSpan: 2,
45431
+ style: {
45432
+ padding: '12px 0 0 0'
45433
+ },
45434
+ children: "Rounded Total"
45435
+ }), jsx("td", {
45436
+ style: {
45437
+ fontWeight: 'bold',
45438
+ padding: '12px 0 0 16px'
45439
+ },
45440
+ children: yKeys.reduce(function (total, key) {
45441
+ return total + Math.round(tooltipData[key].value);
45442
+ }, 0)
45443
+ })]
45444
+ })]
45445
+ })
45446
+ })]
45447
+ })
45448
+ }), document.body);
45449
+ };
45450
+
45267
45451
  var CrosshairCircle = function CrosshairCircle(_ref) {
45268
45452
  var dataType = _ref.dataType,
45269
45453
  yKeys = _ref.yKeys,
@@ -45325,185 +45509,40 @@ var Line = function Line(_ref) {
45325
45509
  opacity: 0.8
45326
45510
  });
45327
45511
  };
45328
-
45329
- var useableId = function useableId(key, prefix) {
45330
- var newKey = key.toLowerCase()
45331
- // Remove characters that aren't letters, digits, underscores, or spaces
45332
- .replace(/[^\w\s-]+/g, '')
45333
- // Replace whitespace with hyphens
45334
- .replace(/\s+/g, '-')
45335
- // Remove leading or trailing hyphens
45336
- .replace(/^-+|-+$/g, '');
45337
- return prefix + '-' + newKey;
45338
- };
45339
-
45340
- function useVisibleYKeys(areas) {
45341
- var _useState = useState(areas.map(function (legendItem) {
45342
- return legendItem.yKey;
45343
- })),
45344
- visibleYKeysState = _useState[0],
45345
- setVisibleYKeys = _useState[1];
45346
- useEffect(function () {
45347
- setVisibleYKeys(areas.map(function (legendItem) {
45348
- return legendItem.yKey;
45349
- }));
45350
- return function () {
45351
- setVisibleYKeys([]);
45352
- };
45353
- }, [areas]);
45354
- return {
45355
- visibleYKeys: visibleYKeysState,
45356
- setVisibleYKeys: setVisibleYKeys
45357
- };
45358
- }
45359
-
45360
- var thresholdId$1 = function thresholdId(args, idPrefix, position, uniqueId) {
45361
- var rawIdKey = args.yKey + "_" + args.value + "_" + args.operator;
45362
- return (position + "_" + idPrefix + "_" + uniqueId + "_" + btoa(rawIdKey)).replace(/=/g, '');
45363
- };
45364
- function buildClipPathId$1(rule, idPrefix, uniqueId) {
45365
- var isGreater = rule.operator === '>=';
45366
- var clipPathId = isGreater ? thresholdId$1(rule, idPrefix, 'above', uniqueId) : thresholdId$1(rule, idPrefix, 'below', uniqueId);
45367
- return clipPathId;
45368
- }
45369
- function getRule(rules, yKey) {
45370
- return rules.filter(function (threshold) {
45371
- return threshold.yKey === yKey;
45372
- });
45373
- }
45374
-
45375
- var ThresholdArea = function ThresholdArea(props) {
45376
- var chartHeight = props.height - props.margin.top;
45377
- return jsxs(Fragment, {
45378
- children: [jsx("g", {
45379
- transform: "translate(50, 0)",
45380
- children: props.rules.map(function (thresh, index) {
45381
- var _props$theme$stroke, _props$theme;
45382
- var thresholdYCoord = props.yScale(thresh.value);
45383
- return jsx("g", {
45384
- children: jsx("line", {
45385
- x1: 0,
45386
- y1: thresholdYCoord,
45387
- x2: props.width - props.margin.right - props.margin.left,
45388
- y2: thresholdYCoord,
45389
- stroke: (_props$theme$stroke = (_props$theme = props.theme) == null ? void 0 : _props$theme.stroke) != null ? _props$theme$stroke : '#F4F4F4',
45390
- strokeWidth: "1",
45391
- fill: "transparent",
45392
- "data-themeapi": "charts.threshold.stroke"
45393
- })
45394
- }, "threshold-" + index);
45395
- })
45396
- }), jsx("defs", {
45397
- children: props.rules.map(function (thresh, index) {
45398
- var thresholdYCoord = props.yScale(thresh.value);
45399
- if (!thresholdYCoord) return null;
45400
- return jsxs(Fragment, {
45401
- children: [jsx("clipPath", {
45402
- id: thresholdId$1(thresh, props.idPrefix, 'above', props.uniqueId),
45403
- children: jsx("rect", {
45404
- x: "0",
45405
- y: "0",
45406
- width: "100%",
45407
- height: thresholdYCoord
45408
- })
45409
- }), jsx("clipPath", {
45410
- id: thresholdId$1(thresh, props.idPrefix, 'intermediate', props.uniqueId),
45411
- children: jsx("rect", {
45412
- x: "0",
45413
- y: thresholdYCoord,
45414
- width: "100%",
45415
- height: 0
45416
- })
45417
- }), jsx("clipPath", {
45418
- id: thresholdId$1(thresh, props.idPrefix, 'below', props.uniqueId),
45419
- children: jsx("rect", {
45420
- x: "0",
45421
- y: thresholdYCoord,
45422
- width: "100%",
45423
- height: chartHeight - thresholdYCoord
45424
- })
45425
- })]
45426
- }, "threshold-" + index);
45427
- })
45428
- })]
45512
+ var ZeroHorizontalLine = function ZeroHorizontalLine(_ref2) {
45513
+ var yScale = _ref2.yScale,
45514
+ chartWidth = _ref2.chartWidth;
45515
+ return jsx(Line$1, {
45516
+ from: {
45517
+ x: 0,
45518
+ y: yScale(0)
45519
+ },
45520
+ to: {
45521
+ x: chartWidth,
45522
+ y: yScale(0)
45523
+ },
45524
+ stroke: '#aaa',
45525
+ strokeWidth: 1,
45526
+ pointerEvents: "none",
45527
+ opacity: 0.8
45429
45528
  });
45430
45529
  };
45431
-
45432
- var _excluded$h = ["tooltipOpen"];
45433
- function useTooltip$1(initialTooltipState) {
45434
- var _useState = useState(_extends({
45435
- tooltipOpen: false
45436
- }, initialTooltipState)),
45437
- tooltipState = _useState[0],
45438
- setTooltipState = _useState[1];
45439
- var showTooltip = useCallback(function (showArgs) {
45440
- return setTooltipState(typeof showArgs === 'function' ? function (_ref) {
45441
- var show = _objectWithoutPropertiesLoose(_ref, _excluded$h);
45442
- return _extends({}, showArgs(show), {
45443
- tooltipOpen: true
45444
- });
45445
- } : {
45446
- tooltipOpen: true,
45447
- tooltipLeft: showArgs.tooltipLeft,
45448
- tooltipTop: showArgs.tooltipTop,
45449
- lineLeft: showArgs.lineLeft,
45450
- tooltipData: showArgs.tooltipData
45451
- });
45452
- }, [setTooltipState]);
45453
- var hideTooltip = useCallback(function () {
45454
- return setTooltipState({
45455
- tooltipOpen: false,
45456
- tooltipLeft: undefined,
45457
- lineLeft: undefined,
45458
- tooltipTop: undefined,
45459
- tooltipData: undefined
45460
- });
45461
- }, [setTooltipState]);
45462
- return {
45463
- tooltipOpen: tooltipState.tooltipOpen,
45464
- tooltipLeft: tooltipState.tooltipLeft,
45465
- tooltipTop: tooltipState.tooltipTop,
45466
- lineLeft: tooltipState.lineLeft,
45467
- tooltipData: tooltipState.tooltipData,
45468
- updateTooltip: setTooltipState,
45469
- showTooltip: showTooltip,
45470
- hideTooltip: hideTooltip
45471
- };
45472
- }
45473
-
45474
- function useYScale(innerHeight, scale) {
45475
- return useMemo(function () {
45476
- return scaleLinear({
45477
- range: [innerHeight, 0],
45478
- domain: scale.ordering === 'asc' ? [scale.min, scale.max] : [scale.max, scale.min],
45479
- nice: true,
45480
- round: true
45481
- });
45482
- }, [innerHeight, scale]);
45483
- }
45484
-
45485
- var DataLabel = function DataLabel(_ref) {
45486
- var x = _ref.x,
45487
- y = _ref.y,
45488
- title = _ref.title,
45489
- dx = _ref.dx,
45490
- dy = _ref.dy,
45491
- color = _ref.color,
45492
- backgroundColor = _ref.backgroundColor;
45493
- return jsx(Annotation$1, {
45494
- x: x,
45495
- y: y,
45496
- dx: dx,
45497
- dy: dy,
45498
- children: jsx(Label$1, {
45499
- title: title,
45500
- showAnchorLine: false,
45501
- showBackground: false,
45502
- backgroundFill: backgroundColor,
45503
- fontColor: color,
45504
- titleFontSize: 10,
45505
- verticalAnchor: "middle"
45506
- })
45530
+ var ZeroVerticalLine = function ZeroVerticalLine(_ref3) {
45531
+ var xScale = _ref3.xScale,
45532
+ chartHeight = _ref3.chartHeight;
45533
+ return jsx(Line$1, {
45534
+ from: {
45535
+ x: xScale(0),
45536
+ y: 0
45537
+ },
45538
+ to: {
45539
+ x: xScale(0),
45540
+ y: chartHeight
45541
+ },
45542
+ stroke: '#aaa',
45543
+ strokeWidth: 1,
45544
+ pointerEvents: "none",
45545
+ opacity: 0.8
45507
45546
  });
45508
45547
  };
45509
45548
 
@@ -45579,9 +45618,7 @@ var AreaChart$5 = function AreaChart(_ref) {
45579
45618
  var _useMemo = useMemo(function () {
45580
45619
  var allValues = getAllChartValues(dataFlattened, chart.y.keys);
45581
45620
  return getMinMaxChartValueFromNumberArray(allValues);
45582
- }, [dataFlattened, chart.y.keys]),
45583
- minValue = _useMemo.minValue,
45584
- maxValue = _useMemo.maxValue;
45621
+ }, [dataFlattened, chart.y.keys]);
45585
45622
  var handleMouseMove = useCallback(function (event) {
45586
45623
  if (!xKey || !xScaleKey || xScale === null) return;
45587
45624
  var tooltipData = getTooltipData({
@@ -45616,6 +45653,7 @@ var AreaChart$5 = function AreaChart(_ref) {
45616
45653
  var labelDictionary = useMemo(function () {
45617
45654
  return getLabelDictionary(chart.data, chart.y.keys);
45618
45655
  }, [chart.data, chart.y.keys]);
45656
+ var showZeroLine = chart.y.scale.min && chart.y.scale.min < 0 && chart.y.scale.max && chart.y.scale.max > 0;
45619
45657
  if (width === 0 || height === 0 || xScale === null) return jsx(React__default.Fragment, {});
45620
45658
  var yTickValues = chart.y.ticks.map(function (tick) {
45621
45659
  return Number(tick.value);
@@ -45709,16 +45747,20 @@ var AreaChart$5 = function AreaChart(_ref) {
45709
45747
  return _yScale(d[1]);
45710
45748
  },
45711
45749
  curve: areaCurve(),
45750
+ offset: "diverging",
45712
45751
  children: function children(_ref2) {
45713
45752
  var stacks = _ref2.stacks,
45714
45753
  path = _ref2.path;
45715
- return stacks.map(function (stack) {
45716
- return jsx(Fragment, {
45717
- children: jsx("path", {
45718
- d: path(stack) || '',
45719
- fill: "url(#" + useableId(stack.key, AREA_GRADIENT_ID_PREFIX) + ")"
45720
- })
45721
- }, "stack-" + stack.index + "-" + stack.key);
45754
+ return jsx(AreaStacked, {
45755
+ areaStacks: stacks,
45756
+ path: path,
45757
+ chartDataDefinition: dataFlattened,
45758
+ yKeys: chart.y.keys,
45759
+ xScaleKey: xScaleKey,
45760
+ xScale: xScale,
45761
+ yScale: _yScale,
45762
+ showLabels: options.showLabels,
45763
+ labelDictionary: labelDictionary
45722
45764
  });
45723
45765
  }
45724
45766
  }), !options.stacked && chart.y.keys.map(function (yKey) {
@@ -45746,22 +45788,25 @@ var AreaChart$5 = function AreaChart(_ref) {
45746
45788
  clipPath: "url(#" + buildClipPathId$1(areaThreshold, AREA_GRADIENT_ID_PREFIX, uniqueId) + ")",
45747
45789
  fill: "url(#" + id + ")"
45748
45790
  }, yKey + "-" + AREA_GRADIENT_ID_PREFIX + "-" + thresholdIndex);
45749
- }), dataFlattened.map(function (d) {
45791
+ }), dataFlattened.map(function (chartData) {
45750
45792
  return jsx(AreaLabel, {
45751
- chartData: d,
45793
+ chartData: chartData,
45752
45794
  yKey: yKey,
45753
45795
  xScaleKey: xScaleKey,
45754
45796
  xScale: xScale,
45755
45797
  yScale: _yScale,
45756
45798
  totalItems: dataFlattened.length,
45757
- minValue: minValue,
45758
- maxValue: maxValue,
45759
45799
  showLabels: options.showLabels,
45760
45800
  labelDictionary: labelDictionary
45761
45801
  });
45762
45802
  })]
45763
45803
  }, yKey + "-" + AREA_GRADIENT_ID_PREFIX);
45764
45804
  })]
45805
+ }), showZeroLine && jsx("g", {
45806
+ children: jsx(ZeroHorizontalLine, {
45807
+ yScale: _yScale,
45808
+ chartWidth: innerWidth
45809
+ })
45765
45810
  })]
45766
45811
  }), tooltipData && jsxs("g", {
45767
45812
  children: [jsx(Line, {
@@ -45810,43 +45855,121 @@ var AreaChart$5 = function AreaChart(_ref) {
45810
45855
  })]
45811
45856
  });
45812
45857
  };
45813
- function AreaLabel(_ref3) {
45814
- var chartData = _ref3.chartData,
45815
- yKey = _ref3.yKey,
45858
+ function AreaStacked(_ref3) {
45859
+ var areaStacks = _ref3.areaStacks,
45860
+ path = _ref3.path,
45861
+ chartDataDefinition = _ref3.chartDataDefinition,
45862
+ yKeys = _ref3.yKeys,
45816
45863
  xScaleKey = _ref3.xScaleKey,
45817
45864
  xScale = _ref3.xScale,
45818
45865
  yScale = _ref3.yScale,
45819
- totalItems = _ref3.totalItems,
45820
45866
  showLabels = _ref3.showLabels,
45821
45867
  labelDictionary = _ref3.labelDictionary;
45868
+ return areaStacks && path && jsxs(Fragment$1, {
45869
+ children: [areaStacks.map(function (stack) {
45870
+ return jsx(Fragment, {
45871
+ children: jsx("path", {
45872
+ d: path(stack) || '',
45873
+ fill: "url(#" + useableId(stack.key, AREA_GRADIENT_ID_PREFIX) + ")"
45874
+ })
45875
+ }, "stack-" + stack.index + "-" + stack.key);
45876
+ }), chartDataDefinition && yKeys && xScaleKey && jsx(Fragment$1, {
45877
+ children: yKeys.map(function (yKey) {
45878
+ return chartDataDefinition.map(function (chartData) {
45879
+ return jsx(AreaStackedLabel, {
45880
+ areaStacks: areaStacks,
45881
+ chartData: chartData,
45882
+ yKey: yKey,
45883
+ xScaleKey: xScaleKey,
45884
+ xScale: xScale,
45885
+ yScale: yScale,
45886
+ totalItems: chartDataDefinition.length,
45887
+ showLabels: showLabels,
45888
+ labelDictionary: labelDictionary
45889
+ });
45890
+ });
45891
+ })
45892
+ })]
45893
+ });
45894
+ }
45895
+ function AreaStackedLabel(_ref4) {
45896
+ var _areaStacks$find, _yScale2, _yScale3;
45897
+ var areaStacks = _ref4.areaStacks,
45898
+ chartData = _ref4.chartData,
45899
+ yKey = _ref4.yKey,
45900
+ xScaleKey = _ref4.xScaleKey,
45901
+ xScale = _ref4.xScale,
45902
+ yScale = _ref4.yScale,
45903
+ totalItems = _ref4.totalItems,
45904
+ showLabels = _ref4.showLabels,
45905
+ labelDictionary = _ref4.labelDictionary;
45906
+ var minHeight = 10;
45907
+ var correspondingAreaStack = areaStacks == null || (_areaStacks$find = areaStacks.find(function (stack) {
45908
+ return stack.key === yKey;
45909
+ })) == null ? void 0 : _areaStacks$find.find(function (subStack) {
45910
+ return subStack.data === chartData;
45911
+ });
45912
+ var areaStackTopY = (_yScale2 = yScale(correspondingAreaStack ? correspondingAreaStack[0] : 0)) != null ? _yScale2 : 0;
45913
+ var areaStackBottomY = (_yScale3 = yScale(correspondingAreaStack ? correspondingAreaStack[1] : 0)) != null ? _yScale3 : 0;
45914
+ var areaStackHeight = Math.abs(areaStackTopY - areaStackBottomY);
45915
+ var xValue = chartData[xScaleKey];
45916
+ var yValue = chartData[yKey];
45917
+ var xLabelPosition = xScale(xValue);
45918
+ var yLabelPosition = areaStackBottomY + areaStackHeight / 2;
45919
+ var showMinMax = showLabels && showDataLabel(totalItems);
45920
+ var hasPositionForLabel = showLabels && xLabelPosition && yLabelPosition && areaStackHeight > minHeight;
45921
+ var displayValue = getFormattedValue(yValue, labelDictionary);
45922
+ return jsx(Fragment$1, {
45923
+ children: showMinMax && hasPositionForLabel && jsx(DataLabel, {
45924
+ x: xLabelPosition,
45925
+ y: yLabelPosition,
45926
+ dx: 0,
45927
+ dy: 0,
45928
+ title: displayValue !== 0 ? displayValue : '0',
45929
+ horizontalAnchor: "middle"
45930
+ })
45931
+ });
45932
+ }
45933
+ function AreaLabel(_ref5) {
45934
+ var chartData = _ref5.chartData,
45935
+ yKey = _ref5.yKey,
45936
+ xScaleKey = _ref5.xScaleKey,
45937
+ xScale = _ref5.xScale,
45938
+ yScale = _ref5.yScale,
45939
+ totalItems = _ref5.totalItems,
45940
+ showLabels = _ref5.showLabels,
45941
+ labelDictionary = _ref5.labelDictionary;
45822
45942
  var xValue = chartData[xScaleKey];
45823
45943
  var yValue = chartData[yKey];
45824
- var xPadding = 18;
45825
- var yPadding = 8;
45826
- var xPosition = xScale(xValue);
45827
- var yPosition = yScale(yValue);
45944
+ var xLabelPosition = xScale(xValue);
45945
+ var yLabelPosition = yScale(yValue);
45946
+ var yLabelPaddingAdjustment = yValue >= 0 ? -8 : 8;
45828
45947
  var showMinMax = showDataLabel(totalItems);
45829
- if (xPosition == null || yPosition == null || !showMinMax || !showLabels) return null;
45948
+ var hasPositionForLabel = showLabels && xLabelPosition && yLabelPosition;
45830
45949
  var displayValue = getFormattedValue(yValue, labelDictionary);
45831
- return jsx(DataLabel, {
45832
- x: xPosition - xPadding,
45833
- y: yPosition - yPadding,
45834
- dx: 2,
45835
- dy: 0,
45836
- title: displayValue
45950
+ return jsx(Fragment$1, {
45951
+ children: showMinMax && hasPositionForLabel && jsx(DataLabel, {
45952
+ x: xLabelPosition,
45953
+ y: yLabelPosition + yLabelPaddingAdjustment,
45954
+ dx: 0,
45955
+ dy: 0,
45956
+ title: displayValue !== 0 ? displayValue : '0',
45957
+ horizontalAnchor: "middle"
45958
+ })
45837
45959
  });
45838
45960
  }
45839
- function Area(_ref4) {
45840
- var data = _ref4.data,
45841
- xScaleDataType = _ref4.xScaleDataType,
45842
- xScale = _ref4.xScale,
45843
- yScale = _ref4.yScale,
45844
- yKey = _ref4.yKey,
45845
- curve = _ref4.curve,
45846
- clipPath = _ref4.clipPath,
45847
- xKey = _ref4.xKey,
45848
- fill = _ref4.fill,
45849
- stroke = _ref4.stroke;
45961
+ function Area(_ref6) {
45962
+ var _yScale4;
45963
+ var data = _ref6.data,
45964
+ xScaleDataType = _ref6.xScaleDataType,
45965
+ xScale = _ref6.xScale,
45966
+ yScale = _ref6.yScale,
45967
+ yKey = _ref6.yKey,
45968
+ curve = _ref6.curve,
45969
+ clipPath = _ref6.clipPath,
45970
+ xKey = _ref6.xKey,
45971
+ fill = _ref6.fill,
45972
+ stroke = _ref6.stroke;
45850
45973
  return jsx(AreaClosed, {
45851
45974
  data: data,
45852
45975
  x: function x(d) {
@@ -45856,10 +45979,12 @@ function Area(_ref4) {
45856
45979
  // @ts-ignore
45857
45980
  return (_xScale2 = xScale(xValueAdjusted)) != null ? _xScale2 : 0;
45858
45981
  },
45982
+ y0: (_yScale4 = yScale(0)) != null ? _yScale4 : 0,
45859
45983
  y: function y(d) {
45860
- var _yScale2;
45984
+ var _yScale5, _yScale6;
45861
45985
  var value = d[yKey];
45862
- return value !== null ? (_yScale2 = yScale(value)) != null ? _yScale2 : 0 : 0;
45986
+ var zero = (_yScale5 = yScale(0)) != null ? _yScale5 : 0;
45987
+ return value !== null ? (_yScale6 = yScale(value)) != null ? _yScale6 : 0 : zero;
45863
45988
  },
45864
45989
  defined: function defined(d) {
45865
45990
  return d !== null && d[yKey] !== null;
@@ -45890,12 +46015,18 @@ function convertToStackedPercentages(data, yKeys, xKey) {
45890
46015
  }
45891
46016
  yKeys.forEach(function (key) {
45892
46017
  if (item[key]) {
46018
+ var _item$key$formattedVa;
45893
46019
  var value = Number(item[key].value) || 0;
45894
- var percentage = value / total * 100;
46020
+ var isValuePositive = value >= 0;
46021
+ var absolutePercentage = Math.abs(value / total) * 100;
46022
+ var percentage = isValuePositive ? absolutePercentage : -absolutePercentage;
46023
+ var formattedPercentage = percentage.toFixed(0) + "%";
46024
+ var originalFormattedValue = (_item$key$formattedVa = item[key].formattedValue) != null ? _item$key$formattedVa : "" + value;
46025
+ var newFormattedValue = isValuePositive ? originalFormattedValue : "(" + originalFormattedValue.replace('-', '') + ")";
45895
46026
  convertedItem[key] = _extends({}, item[key], {
45896
46027
  value: percentage / 100,
45897
46028
  originalValue: item[key].value,
45898
- formattedValue: "" + percentage.toFixed(1)
46029
+ formattedValue: formattedPercentage + ", " + newFormattedValue
45899
46030
  });
45900
46031
  }
45901
46032
  });
@@ -45903,6 +46034,162 @@ function convertToStackedPercentages(data, yKeys, xKey) {
45903
46034
  });
45904
46035
  }
45905
46036
 
46037
+ function getStackedPercentageScaleLinearDomain(convertedStackedPercentageData, yKeys, xKey) {
46038
+ var minDomain = 0.0;
46039
+ var maxDomain = 1.0;
46040
+ if (xKey && yKeys.length > 0) {
46041
+ convertedStackedPercentageData.forEach(function (item) {
46042
+ var positiveTotal = 0.0;
46043
+ var negativeTotal = 0.0;
46044
+ yKeys.forEach(function (key) {
46045
+ var _item$key;
46046
+ var value = Number((_item$key = item[key]) == null ? void 0 : _item$key.value) || 0;
46047
+ if (value >= 0) {
46048
+ positiveTotal += value;
46049
+ } else {
46050
+ negativeTotal += value;
46051
+ }
46052
+ });
46053
+ if (positiveTotal > maxDomain) {
46054
+ maxDomain = positiveTotal;
46055
+ }
46056
+ if (negativeTotal < minDomain) {
46057
+ minDomain = negativeTotal;
46058
+ }
46059
+ });
46060
+ }
46061
+ return [minDomain, maxDomain];
46062
+ }
46063
+
46064
+ var DEFAULT_TICK_COUNT = 10;
46065
+ function getNiceInterval(interval) {
46066
+ var exponent = Math.floor(Math.log10(interval));
46067
+ var fraction = interval / Math.pow(10, exponent);
46068
+ var niceFraction;
46069
+ if (fraction <= 1) {
46070
+ niceFraction = 1;
46071
+ } else if (fraction <= 1.25) {
46072
+ niceFraction = 1.25;
46073
+ } else if (fraction <= 1.5) {
46074
+ niceFraction = 1.5;
46075
+ } else if (fraction <= 2) {
46076
+ niceFraction = 2;
46077
+ } else if (fraction <= 2.5) {
46078
+ niceFraction = 2.5;
46079
+ } else if (fraction <= 3) {
46080
+ niceFraction = 3;
46081
+ } else if (fraction <= 5) {
46082
+ niceFraction = 5;
46083
+ } else if (fraction <= 7) {
46084
+ niceFraction = 7;
46085
+ } else if (fraction <= 10) {
46086
+ niceFraction = 10;
46087
+ } else {
46088
+ niceFraction = 10;
46089
+ }
46090
+ return niceFraction * Math.pow(10, exponent);
46091
+ }
46092
+ function getAxisTick(value, nullValue, formattingFunction) {
46093
+ var formattedValue = formattingFunction(value, nullValue);
46094
+ return {
46095
+ value: value,
46096
+ formattedValue: formattedValue,
46097
+ scaleValue: value
46098
+ };
46099
+ }
46100
+ var getMetricAxisTickValues = function getMetricAxisTickValues(_ref) {
46101
+ var min = _ref.min,
46102
+ max = _ref.max,
46103
+ interval = _ref.interval,
46104
+ stacked = _ref.stacked;
46105
+ var niceInterval = getNiceInterval(interval);
46106
+ var limitTicksCount = stacked ? 0 : 1;
46107
+ var axisTickValues = [0];
46108
+ if (min < 0) {
46109
+ var negativeTickCount = Math.floor(Math.abs(min) / niceInterval) + limitTicksCount;
46110
+ for (var i = 1; i <= negativeTickCount; i++) {
46111
+ axisTickValues.unshift(-i * niceInterval);
46112
+ }
46113
+ }
46114
+ if (max > 0) {
46115
+ var positiveTickCount = Math.floor(max / niceInterval) + limitTicksCount;
46116
+ for (var _i = 1; _i <= positiveTickCount; _i++) {
46117
+ axisTickValues.push(_i * niceInterval);
46118
+ }
46119
+ }
46120
+ return axisTickValues.map(function (tickValue) {
46121
+ return Math.round(tickValue / niceInterval) * niceInterval;
46122
+ }); // To avoid floating point precision issues;
46123
+ };
46124
+ var getMetricAxisTicks = function getMetricAxisTicks(_ref2) {
46125
+ var min = _ref2.min,
46126
+ max = _ref2.max,
46127
+ tickCount = _ref2.tickCount,
46128
+ nullValue = _ref2.nullValue,
46129
+ formattingFunction = _ref2.formattingFunction,
46130
+ stacked = _ref2.stacked;
46131
+ var axisMax = max || 0;
46132
+ var axisMin = Math.min(min || 0, 0);
46133
+ var minMaxInterval = axisMax - axisMin;
46134
+ var axisTickCount = tickCount != null ? tickCount : DEFAULT_TICK_COUNT;
46135
+ var expectedTickInterval = minMaxInterval / (axisTickCount - 1);
46136
+ var axisTickValues = getMetricAxisTickValues({
46137
+ min: axisMin,
46138
+ max: axisMax,
46139
+ interval: expectedTickInterval,
46140
+ stacked: stacked
46141
+ });
46142
+ var outerLabelPadding = stacked ? 0 : minMaxInterval * 0.05;
46143
+ var minWithOuterLabelPadding = axisMin - (axisMin < 0 ? outerLabelPadding : 0);
46144
+ var maxWithOuterLabelPadding = axisMax + (axisMax >= 0 ? outerLabelPadding : 0);
46145
+ return {
46146
+ ticks: axisTickValues.map(function (tickValue) {
46147
+ return getAxisTick(tickValue, nullValue, formattingFunction);
46148
+ }),
46149
+ minTickValue: Math.min.apply(Math, axisTickValues.concat([minWithOuterLabelPadding])),
46150
+ maxTickValue: Math.max.apply(Math, axisTickValues.concat([maxWithOuterLabelPadding]))
46151
+ };
46152
+ };
46153
+
46154
+ function getStackedPercentageTickValues(convertedStackedPercentageData, yKeys, xKey) {
46155
+ var scaleLinearDomain = getStackedPercentageScaleLinearDomain(convertedStackedPercentageData, yKeys, xKey);
46156
+ var minTick = Math.min.apply(Math, scaleLinearDomain);
46157
+ var maxTick = Math.max.apply(Math, scaleLinearDomain);
46158
+ var extraNegative20PercentTicks = Math.max(Math.ceil(Math.abs(minTick) / 0.2), 0);
46159
+ var extraPositive20PercentTicks = Math.max(Math.ceil((maxTick - 1) / 0.2), 0);
46160
+ var totalExtra20PercentTicks = extraNegative20PercentTicks + extraPositive20PercentTicks;
46161
+ if (totalExtra20PercentTicks > DEFAULT_TICK_COUNT) {
46162
+ return getMetricAxisTickValues({
46163
+ min: minTick,
46164
+ max: maxTick,
46165
+ interval: (maxTick - minTick) / DEFAULT_TICK_COUNT,
46166
+ stacked: true
46167
+ });
46168
+ }
46169
+ var tickValues = [0, 0.2, 0.4, 0.6, 0.8, 1];
46170
+ for (var i = 1; i <= extraNegative20PercentTicks; i++) {
46171
+ tickValues.unshift(-i * 0.2);
46172
+ }
46173
+ for (var _i = 1; _i <= extraPositive20PercentTicks; _i++) {
46174
+ tickValues.push(1 + _i * 0.2);
46175
+ }
46176
+ return tickValues.map(function (tick) {
46177
+ return Math.round(tick * 10) / 10;
46178
+ }); // To avoid floating point precision issues
46179
+ }
46180
+
46181
+ function getStackedPercentageAxisTicks(convertedStackedPercentageData, yKeys, xKey) {
46182
+ var tickValues = getStackedPercentageTickValues(convertedStackedPercentageData, yKeys, xKey);
46183
+ return tickValues.map(function (value) {
46184
+ var roundPercentage = Math.round(value * 100);
46185
+ return {
46186
+ value: value,
46187
+ formattedValue: "" + roundPercentage,
46188
+ scaleValue: value
46189
+ };
46190
+ });
46191
+ }
46192
+
45906
46193
  var BAR_RADIUS = 2;
45907
46194
 
45908
46195
  function getBarFill(bars, conditionalFormattingRules, barKey, barValues) {
@@ -46042,14 +46329,15 @@ var Bar = function Bar(_ref2) {
46042
46329
  yScale = _ref2.yScale,
46043
46330
  containerHeight = _ref2.containerHeight,
46044
46331
  chartWidth = _ref2.chartWidth;
46045
- var X_PADDING = 10;
46046
46332
  var Y_PADDING = 8;
46047
46333
  var minWidth = 20;
46048
46334
  var minContainerHeight = 50;
46049
- var showBar = bar.value !== null && bar.height > 0 && bar.width > 0;
46050
- var barTopY = yScale(bar.value);
46051
- var labelX = bar.x - X_PADDING;
46052
- var labelY = barTopY - Y_PADDING;
46335
+ var barY = bar.value >= 0 ? yScale(bar.value) : yScale(0);
46336
+ var barHeight = Math.abs(yScale(bar.value) - yScale(0));
46337
+ var showBar = bar.value !== null && barHeight > 0 && bar.width > 0;
46338
+ var labelX = bar.x + bar.width / 2;
46339
+ var labelYPaddingAdjustment = bar.value >= 0 ? Y_PADDING : -Y_PADDING;
46340
+ var labelY = yScale(bar.value) - labelYPaddingAdjustment;
46053
46341
  var showMinMax = showDataLabel(totalItems);
46054
46342
  var hasSpaceForLabel = showLabels && bar.width > minWidth && containerHeight > minContainerHeight;
46055
46343
  var displayValue = getFormattedValue(bar.value, labelDictionary);
@@ -46058,20 +46346,21 @@ var Bar = function Bar(_ref2) {
46058
46346
  children: [showBar && jsx(BarRect, {
46059
46347
  barRectKey: "bar-group-bar-" + barGroup.index + "-" + bar.index + "-" + bar.value + "-" + String(bar.key),
46060
46348
  x: bar.x,
46061
- y: bar.y,
46349
+ y: barY,
46062
46350
  width: bar.width,
46063
- height: bar.height,
46351
+ height: barHeight,
46064
46352
  fill: getBarFill(bars, conditionalFormattingRules, String(bar.key), bar.value),
46065
46353
  onClick: function onClick(e) {
46066
46354
  return _onClick(e, barGroup, bar);
46067
46355
  },
46068
46356
  enableHover: enableHover
46069
46357
  }), hasSpaceForLabel && showMinMax && barPosition !== false && jsx(DataLabel, {
46070
- x: barPosition,
46358
+ x: labelX,
46071
46359
  y: labelY,
46072
- title: displayValue,
46073
- dx: 1,
46074
- dy: 0
46360
+ title: displayValue !== 0 ? displayValue : '0',
46361
+ dx: 0,
46362
+ dy: 0,
46363
+ horizontalAnchor: "middle"
46075
46364
  }), jsx(BarLabel, {
46076
46365
  bar: bar,
46077
46366
  barGroup: barGroup,
@@ -46100,7 +46389,7 @@ var BarRect = function BarRect(_ref3) {
46100
46389
  } : {
46101
46390
  name: "1ltmijl-classes",
46102
46391
  styles: "cursor:pointer;label:classes;",
46103
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["BarGroup.tsx"],"names":[],"mappings":"AA2PgC","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, useMemo, useState } from 'react';\nimport { BarStyles } from 'shared-logic/src/BarChartV2/types';\nimport { ChartDataDefinition, ConditionalFormattingRule, ShapeDefinition } from 'shared-logic/src/ChartsV2/types';\nimport { getAllChartValues, getFormattedValue, showDataLabel } from 'shared-logic/src/DataLabel/index';\nimport { DataType } from 'shared-logic/src/Field/types';\nimport { lightenColor } from '../../../styles/color.functions';\nimport { DataLabel } from '../../components/DataLabel';\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  width?: 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  showLabels?: boolean;\n  labelDictionary: { [key: string]: string };\n};\n\nexport function BarGroup({\n  data,\n  keys,\n  height,\n  width,\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  showLabels,\n  labelDictionary,\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  const totalItems = useMemo(() => {\n    const allBarValues = getAllChartValues(data, keys);\n    return allBarValues.length;\n  }, [data, keys]);\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                totalItems={totalItems}\n                showLabels={showLabels}\n                labelDictionary={labelDictionary}\n                yScale={yScale}\n                containerHeight={height}\n                chartWidth={width}\n              />\n            ))}\n          </Group>\n        ));\n      }}\n    </VisxBarGroup>\n  );\n}\n\nfunction calculateBarLabelPosition(\n  bar: any,\n  barGroup: any,\n  chartWidth: number,\n  displayValue: string | null,\n): number | false {\n  if (!displayValue) return false;\n\n  const ESTIMATED_FONT_WIDTH = 5.75;\n\n  const minWidthPercent = 0.02;\n  const maxWidthPercent = 0.15;\n  const minWidthPx = chartWidth * minWidthPercent;\n  const maxWidthPx = chartWidth * maxWidthPercent;\n\n  const minSize = 0.5;\n  const maxSize = 1.2;\n\n  const normalizedBarWidth = Math.min(Math.max(bar.width, minWidthPx), maxWidthPx);\n  const logInput = 1 + ((normalizedBarWidth - minWidthPx) / (maxWidthPx - minWidthPx)) * (Math.E - 1);\n  const logRatio = Math.log(logInput);\n  const size = minSize + logRatio * (maxSize - minSize);\n\n  const basePosition = barGroup.bars.length > 1 ? bar.x + (bar.width * size) / 2 : (bar.width * size) / 2;\n\n  return basePosition - (displayValue.length * ESTIMATED_FONT_WIDTH) / 2;\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  totalItems: number;\n  showLabels?: boolean;\n  labelDictionary?: { [key: string]: string };\n  yScale: ScaleLinear<number, number, never>;\n  containerHeight: number;\n  chartWidth?: 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  totalItems,\n  showLabels,\n  labelDictionary,\n  yScale,\n  containerHeight,\n  chartWidth,\n}: BarProps) => {\n  const X_PADDING = 10;\n  const Y_PADDING = 8;\n\n  const minWidth = 20;\n  const minContainerHeight = 50;\n\n  const showBar = bar.value !== null && bar.height > 0 && bar.width > 0;\n\n  const barTopY = yScale(bar.value);\n  const labelX = bar.x - X_PADDING;\n  const labelY = barTopY - Y_PADDING;\n\n  const showMinMax = showDataLabel(totalItems);\n  const hasSpaceForLabel = showLabels && bar.width > minWidth && containerHeight > minContainerHeight;\n\n  const displayValue = getFormattedValue(bar.value, labelDictionary);\n  const barPosition = chartWidth ? calculateBarLabelPosition(bar, barGroup, chartWidth, displayValue) : labelX;\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      {hasSpaceForLabel && showMinMax && barPosition !== false && (\n        <DataLabel x={barPosition} y={labelY} title={displayValue} dx={1} dy={0} />\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 [isHovered, setIsHovered] = useState(false);\n\n  const classes = enableHover ? css({ cursor: 'pointer' }) : '';\n\n  const displayColor = isHovered && enableHover ? lightenColor(fill, 0.8) : fill;\n\n  const handleOnMouseEnter = () => {\n    if (enableHover) {\n      setIsHovered(true);\n    }\n  };\n\n  const handleOnMouseLeave = () => {\n    if (enableHover) {\n      setIsHovered(false);\n    }\n  };\n\n  return (\n    <rect\n      key={barRectKey}\n      x={x}\n      y={y}\n      width={width}\n      height={height}\n      fill={displayColor}\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"]} */",
46392
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["BarGroup.tsx"],"names":[],"mappings":"AAoQgC","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, useMemo, useState } from 'react';\nimport { BarStyles } from 'shared-logic/src/BarChartV2/types';\nimport { ChartDataDefinition, ConditionalFormattingRule, ShapeDefinition } from 'shared-logic/src/ChartsV2/types';\nimport { getAllChartValues, getFormattedValue, showDataLabel } from 'shared-logic/src/DataLabel/index';\nimport { DataType } from 'shared-logic/src/Field/types';\nimport { lightenColor } from '../../../styles/color.functions';\nimport { DataLabel } from '../../components/DataLabel';\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  width?: 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  showLabels?: boolean;\n  labelDictionary: { [key: string]: string };\n};\n\nexport function BarGroup({\n  data,\n  keys,\n  height,\n  width,\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  showLabels,\n  labelDictionary,\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  const totalItems = useMemo(() => {\n    const allBarValues = getAllChartValues(data, keys);\n    return allBarValues.length;\n  }, [data, keys]);\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                totalItems={totalItems}\n                showLabels={showLabels}\n                labelDictionary={labelDictionary}\n                yScale={yScale}\n                containerHeight={height}\n                chartWidth={width}\n              />\n            ))}\n          </Group>\n        ));\n      }}\n    </VisxBarGroup>\n  );\n}\n\nfunction calculateBarLabelPosition(\n  bar: any,\n  barGroup: any,\n  chartWidth: number,\n  displayValue: string | null,\n): number | false {\n  if (!displayValue) return false;\n\n  const ESTIMATED_FONT_WIDTH = 5.75;\n\n  const minWidthPercent = 0.02;\n  const maxWidthPercent = 0.15;\n  const minWidthPx = chartWidth * minWidthPercent;\n  const maxWidthPx = chartWidth * maxWidthPercent;\n\n  const minSize = 0.5;\n  const maxSize = 1.2;\n\n  const normalizedBarWidth = Math.min(Math.max(bar.width, minWidthPx), maxWidthPx);\n  const logInput = 1 + ((normalizedBarWidth - minWidthPx) / (maxWidthPx - minWidthPx)) * (Math.E - 1);\n  const logRatio = Math.log(logInput);\n  const size = minSize + logRatio * (maxSize - minSize);\n\n  const basePosition = barGroup.bars.length > 1 ? bar.x + (bar.width * size) / 2 : (bar.width * size) / 2;\n\n  return basePosition - (displayValue.length * ESTIMATED_FONT_WIDTH) / 2;\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  totalItems: number;\n  showLabels?: boolean;\n  labelDictionary?: { [key: string]: string };\n  yScale: ScaleLinear<number, number, never>;\n  containerHeight: number;\n  chartWidth?: 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  totalItems,\n  showLabels,\n  labelDictionary,\n  yScale,\n  containerHeight,\n  chartWidth,\n}: BarProps) => {\n  const Y_PADDING = 8;\n\n  const minWidth = 20;\n  const minContainerHeight = 50;\n\n  const barY = bar.value >= 0 ? yScale(bar.value) : yScale(0);\n  const barHeight = Math.abs(yScale(bar.value) - yScale(0));\n\n  const showBar = bar.value !== null && barHeight > 0 && bar.width > 0;\n\n  const labelX = bar.x + bar.width / 2;\n  const labelYPaddingAdjustment = bar.value >= 0 ? Y_PADDING : -Y_PADDING;\n  const labelY = yScale(bar.value) - labelYPaddingAdjustment;\n\n  const showMinMax = showDataLabel(totalItems);\n  const hasSpaceForLabel = showLabels && bar.width > minWidth && containerHeight > minContainerHeight;\n\n  const displayValue = getFormattedValue(bar.value, labelDictionary);\n  const barPosition = chartWidth ? calculateBarLabelPosition(bar, barGroup, chartWidth, displayValue) : labelX;\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={barY}\n          width={bar.width}\n          height={barHeight}\n          fill={getBarFill(bars, conditionalFormattingRules, String(bar.key), bar.value)}\n          onClick={(e) => onClick(e, barGroup, bar)}\n          enableHover={enableHover}\n        />\n      )}\n\n      {hasSpaceForLabel && showMinMax && barPosition !== false && (\n        <DataLabel\n          x={labelX}\n          y={labelY}\n          title={displayValue !== 0 ? displayValue : '0'}\n          dx={0}\n          dy={0}\n          horizontalAnchor=\"middle\"\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 [isHovered, setIsHovered] = useState(false);\n\n  const classes = enableHover ? css({ cursor: 'pointer' }) : '';\n\n  const displayColor = isHovered && enableHover ? lightenColor(fill, 0.8) : fill;\n\n  const handleOnMouseEnter = () => {\n    if (enableHover) {\n      setIsHovered(true);\n    }\n  };\n\n  const handleOnMouseLeave = () => {\n    if (enableHover) {\n      setIsHovered(false);\n    }\n  };\n\n  return (\n    <rect\n      key={barRectKey}\n      x={x}\n      y={y}\n      width={width}\n      height={height}\n      fill={displayColor}\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"]} */",
46104
46393
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$9
46105
46394
  }) : '';
46106
46395
  var displayColor = isHovered && enableHover ? lightenColor$2(fill, 0.8) : fill;
@@ -46171,7 +46460,8 @@ var BarStacked = function BarStacked(_ref) {
46171
46460
  width = _ref.width,
46172
46461
  showLabels = _ref.showLabels,
46173
46462
  labelDictionary = _ref.labelDictionary,
46174
- isStacked100 = _ref.isStacked100;
46463
+ _ref$isStacked = _ref.isStacked100,
46464
+ isStacked100 = _ref$isStacked === void 0 ? false : _ref$isStacked;
46175
46465
  var handleGetXValue = function handleGetXValue(d) {
46176
46466
  var xValue = d[xScaleKey];
46177
46467
  if (xScaleDataType === 'string') return String(xValue);
@@ -46198,7 +46488,7 @@ var BarStacked = function BarStacked(_ref) {
46198
46488
  },
46199
46489
  height: height,
46200
46490
  width: width,
46201
- offset: isStacked100 ? 'expand' : 'none',
46491
+ offset: "diverging",
46202
46492
  children: function children(barStacks) {
46203
46493
  return barStacks.map(function (barStack) {
46204
46494
  return barStack.bars.map(function (bar) {
@@ -46209,7 +46499,8 @@ var BarStacked = function BarStacked(_ref) {
46209
46499
  conditionalFormattingRules: conditionalFormattingRules,
46210
46500
  totalItems: totalItems,
46211
46501
  showLabels: showLabels,
46212
- labelDictionary: labelDictionary
46502
+ labelDictionary: labelDictionary,
46503
+ isStacked100: isStacked100
46213
46504
  }, bar.key.toString() + "-" + bar.index + "-" + bar.x);
46214
46505
  });
46215
46506
  });
@@ -46223,13 +46514,15 @@ var Bar$1 = function Bar(_ref2) {
46223
46514
  conditionalFormattingRules = _ref2.conditionalFormattingRules,
46224
46515
  totalItems = _ref2.totalItems,
46225
46516
  showLabels = _ref2.showLabels,
46226
- labelDictionary = _ref2.labelDictionary;
46517
+ labelDictionary = _ref2.labelDictionary,
46518
+ _ref2$isStacked = _ref2.isStacked100,
46519
+ isStacked100 = _ref2$isStacked === void 0 ? false : _ref2$isStacked;
46227
46520
  var BAR_PADDING = 1.5;
46228
- var X_PADDING = 20;
46229
- var minWidth = 40;
46521
+ var minWidthMultiplier = isStacked100 ? 1.75 : 1;
46522
+ var minWidth = 40 * minWidthMultiplier;
46230
46523
  var minHeight = 15;
46231
- var labelX = bar.x + bar.width / 2 + X_PADDING;
46232
- var labelY = bar.y + bar.height / 3;
46524
+ var labelX = bar.x + bar.width / 2;
46525
+ var labelY = bar.y + bar.height / 2;
46233
46526
  var showMinMax = showDataLabel(totalItems);
46234
46527
  var hasSpaceForLabel = showLabels && bar.width > minWidth && bar.height > minHeight;
46235
46528
  var displayValue = getFormattedValue(bar.bar.data[barStack.key], labelDictionary);
@@ -46250,7 +46543,8 @@ var Bar$1 = function Bar(_ref2) {
46250
46543
  color: textColor,
46251
46544
  title: displayValue,
46252
46545
  dx: 0,
46253
- dy: 0
46546
+ dy: 0,
46547
+ horizontalAnchor: "middle"
46254
46548
  })]
46255
46549
  });
46256
46550
  };
@@ -46369,9 +46663,10 @@ var BarChart$5 = function BarChart(_ref) {
46369
46663
  var defaultYScale = useYScale(innerHeight, chart.y.scale);
46370
46664
  var yScale = useMemo(function () {
46371
46665
  if (isStacked100) {
46666
+ var domain = getStackedPercentageScaleLinearDomain(processedData, chart.y.keys, xKey);
46372
46667
  return scaleLinear({
46373
46668
  range: [innerHeight, 0],
46374
- domain: [0, 1],
46669
+ domain: domain,
46375
46670
  nice: true,
46376
46671
  round: true
46377
46672
  });
@@ -46380,7 +46675,7 @@ var BarChart$5 = function BarChart(_ref) {
46380
46675
  }, [innerHeight, defaultYScale, options.stacked]);
46381
46676
  var yTickValues = useMemo(function () {
46382
46677
  if (isStacked100) {
46383
- return [0, 0.2, 0.4, 0.6, 0.8, 1];
46678
+ return getStackedPercentageTickValues(processedData, chart.y.keys, xKey);
46384
46679
  }
46385
46680
  return chart.y.ticks.map(function (tick) {
46386
46681
  return Number(tick.value);
@@ -46388,32 +46683,9 @@ var BarChart$5 = function BarChart(_ref) {
46388
46683
  }, [isStacked100, chart.y.ticks]);
46389
46684
  var yAxisConfig = useMemo(function () {
46390
46685
  if (isStacked100) {
46686
+ var ticks = getStackedPercentageAxisTicks(processedData, chart.y.keys, xKey);
46391
46687
  return _extends({}, chart.y, {
46392
- ticks: [{
46393
- value: 0,
46394
- formattedValue: '0',
46395
- scaleValue: 0
46396
- }, {
46397
- value: 0.2,
46398
- formattedValue: '20',
46399
- scaleValue: 0.2
46400
- }, {
46401
- value: 0.4,
46402
- formattedValue: '40',
46403
- scaleValue: 0.4
46404
- }, {
46405
- value: 0.6,
46406
- formattedValue: '60',
46407
- scaleValue: 0.6
46408
- }, {
46409
- value: 0.8,
46410
- formattedValue: '80',
46411
- scaleValue: 0.8
46412
- }, {
46413
- value: 1,
46414
- formattedValue: '100',
46415
- scaleValue: 1
46416
- }]
46688
+ ticks: ticks
46417
46689
  });
46418
46690
  }
46419
46691
  return chart.y;
@@ -46494,6 +46766,7 @@ var BarChart$5 = function BarChart(_ref) {
46494
46766
  var formattedLabelsDict = useMemo(function () {
46495
46767
  return getLabelDictionary(processedData, yScaleKeys);
46496
46768
  }, [processedData, yScaleKeys]);
46769
+ var showZeroLine = chart.y.scale.min && chart.y.scale.min < 0 && chart.y.scale.max && chart.y.scale.max > 0;
46497
46770
  return jsxs(Fragment, {
46498
46771
  children: [jsxs(ChartWrapper$1, {
46499
46772
  width: width,
@@ -46566,6 +46839,11 @@ var BarChart$5 = function BarChart(_ref) {
46566
46839
  labelDictionary: formattedLabelsDict,
46567
46840
  isStacked100: isStacked100
46568
46841
  })]
46842
+ }), showZeroLine && jsx("g", {
46843
+ children: jsx(ZeroHorizontalLine, {
46844
+ yScale: yScale,
46845
+ chartWidth: innerWidth
46846
+ })
46569
46847
  })]
46570
46848
  }), tooltipData && jsx("g", {
46571
46849
  children: jsx(Line, {
@@ -46978,6 +47256,7 @@ function HorizontalBarGroup(_ref) {
46978
47256
  totalItems: totalItems,
46979
47257
  showLabels: showLabels,
46980
47258
  labelDictionary: labelDictionary,
47259
+ xScale: xScale,
46981
47260
  containerWidth: width
46982
47261
  }, "horizontal-bar-" + bar.index + "-" + bar.y);
46983
47262
  })
@@ -47000,22 +47279,27 @@ var HorizontalBar = function HorizontalBar(_ref2) {
47000
47279
  totalItems = _ref2.totalItems,
47001
47280
  showLabels = _ref2.showLabels,
47002
47281
  labelDictionary = _ref2.labelDictionary,
47282
+ xScale = _ref2.xScale,
47003
47283
  containerWidth = _ref2.containerWidth;
47004
47284
  var X_PADDING = -5;
47005
47285
  var minHeight = 15;
47006
47286
  var minContainerWidth = 50;
47287
+ var barX = bar.value >= 0 ? xScale(0) : xScale(bar.value);
47288
+ var barWidth = Math.abs(xScale(bar.value) - xScale(0));
47007
47289
  var showBar = bar.value !== null && bar.height > 0 && bar.width > 0;
47008
- var labelX = bar.x + bar.width + X_PADDING;
47290
+ var labelXPaddingAdjustment = bar.value >= 0 ? X_PADDING : 0;
47291
+ var labelX = xScale(bar.value) + labelXPaddingAdjustment;
47009
47292
  var labelY = bar.y + bar.height / 2;
47293
+ var labelHorizontalAnchor = bar.value < 0 ? 'end' : undefined;
47010
47294
  var showMinMax = showDataLabel(totalItems);
47011
47295
  var hasSpaceForLabel = showLabels && bar.height > minHeight && containerWidth > minContainerWidth;
47012
47296
  var displayValue = getFormattedValue(bar.value, labelDictionary);
47013
47297
  return jsxs(Fragment, {
47014
47298
  children: [showBar && jsx(HorizontalBarRect, {
47015
47299
  barRectKey: "horizontal-bar-group-bar-" + barGroup.index + "-" + bar.index + "-" + bar.value + "-" + String(bar.key),
47016
- x: bar.x,
47300
+ x: barX,
47017
47301
  y: bar.y,
47018
- width: bar.width,
47302
+ width: barWidth,
47019
47303
  height: bar.height,
47020
47304
  fill: getBarFill(bars, conditionalFormattingRules, String(bar.key), bar.value),
47021
47305
  onClick: function onClick(e) {
@@ -47025,9 +47309,10 @@ var HorizontalBar = function HorizontalBar(_ref2) {
47025
47309
  }), hasSpaceForLabel && showMinMax && jsx(DataLabel, {
47026
47310
  x: labelX,
47027
47311
  y: labelY,
47028
- title: displayValue,
47312
+ title: displayValue !== 0 ? displayValue : '0',
47029
47313
  dx: 1,
47030
- dy: 0
47314
+ dy: 0,
47315
+ horizontalAnchor: labelHorizontalAnchor
47031
47316
  }), jsx(HorizontalBarLabel, {
47032
47317
  bar: bar,
47033
47318
  barGroup: barGroup,
@@ -47056,7 +47341,7 @@ var HorizontalBarRect = function HorizontalBarRect(_ref3) {
47056
47341
  } : {
47057
47342
  name: "1ltmijl-classes",
47058
47343
  styles: "cursor:pointer;label:classes;",
47059
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["HorizontalBarGroup.tsx"],"names":[],"mappings":"AAgNgC","file":"HorizontalBarGroup.tsx","sourcesContent":["import { css } from '@emotion/css';\nimport { Group } from '@visx/group';\nimport { BarGroupHorizontal as VisxBarGroupHorizontal } from '@visx/shape';\nimport { DatumObject } from '@visx/shape/lib/types';\nimport { ScaleBand, ScaleLinear } from '@visx/vendor/d3-scale';\nimport { Fragment, useMemo, useState } from 'react';\nimport { BarStyles } from 'shared-logic/src/BarChartV2/types';\nimport { ChartDataDefinition, ConditionalFormattingRule, ShapeDefinition } from 'shared-logic/src/ChartsV2/types';\nimport { getAllChartValues, getFormattedValue, showDataLabel } from 'shared-logic/src/DataLabel/index';\nimport { DataType } from 'shared-logic/src/Field/types';\nimport { lightenColor } from '../../../styles/color.functions';\nimport { DataLabel } from '../../components/DataLabel';\nimport { BAR_RADIUS } from '../../constants/BORDER_RADIUS';\nimport { getBarFill } from '../getBarFill';\n\nexport type HorizontalBarGroupProps = {\n  data: ChartDataDefinition[];\n  keys: string[];\n  width: number;\n  yKey: string;\n  yScaleDataType: DataType;\n  yScale: ScaleBand<string> | ScaleBand<Date> | ScaleBand<number>;\n  innerYScale: ScaleBand<string>;\n  xScale: 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  xAxisLabels?: string[];\n  xLabelPosition?: number;\n  showDetailedSubGroupingLabels: boolean;\n  labelStyle?: React.CSSProperties;\n  showLabels: boolean;\n  labelDictionary: { [key: string]: string };\n};\n\nexport function HorizontalBarGroup({\n  data,\n  keys,\n  width,\n  yKey,\n  yScaleDataType,\n  yScale,\n  innerYScale,\n  xScale,\n  onClick,\n  conditionalFormattingRules,\n  bars,\n  enableHover,\n  xAxisLabels,\n  xLabelPosition,\n  showDetailedSubGroupingLabels,\n  labelStyle,\n  showLabels,\n  labelDictionary,\n}: HorizontalBarGroupProps) {\n  const getGroupPosition = (d: DatumObject) => {\n    const yValue = d[yKey as keyof typeof d];\n\n    if (yScaleDataType === 'string') return String(yValue);\n\n    if (yScaleDataType === 'date_time') {\n      return new Date(String(yValue));\n    }\n\n    if (yScaleDataType === 'number') {\n      return Number(yValue);\n    }\n\n    return String(yValue);\n  };\n\n  const totalItems = useMemo(() => {\n    const allBarValues = getAllChartValues(data, keys);\n    return allBarValues.length;\n  }, [data, keys]);\n\n  return (\n    <VisxBarGroupHorizontal<DatumObject>\n      data={data as DatumObject[]}\n      keys={keys}\n      width={width}\n      y0={getGroupPosition}\n      y0Scale={yScale}\n      y1Scale={innerYScale}\n      xScale={xScale}\n      color={() => ''}\n    >\n      {(barGroups) => {\n        return barGroups.map((barGroup) => (\n          <Group key={`horizontal-bar-group-${barGroup.index}-${barGroup.y0}`} top={barGroup.y0}>\n            {barGroup.bars.map((bar) => (\n              <HorizontalBar\n                key={`horizontal-bar-${bar.index}-${bar.y}`}\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                xAxisLabels={xAxisLabels}\n                xLabelPosition={xLabelPosition}\n                totalItems={totalItems}\n                showLabels={showLabels}\n                labelDictionary={labelDictionary}\n                containerWidth={width}\n              />\n            ))}\n          </Group>\n        ));\n      }}\n    </VisxBarGroupHorizontal>\n  );\n}\n\ntype HorizontalBarProps = {\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  xAxisLabels?: string[];\n  xLabelPosition?: number;\n  totalItems: number;\n  showLabels: boolean;\n  labelDictionary: { [key: string]: string };\n  containerWidth: number;\n};\n\nconst HorizontalBar = ({\n  bar,\n  barGroup,\n  bars,\n  conditionalFormattingRules,\n  enableHover,\n  labelStyle,\n  onClick,\n  showDetailedSubGroupingLabels,\n  xAxisLabels,\n  xLabelPosition,\n  totalItems,\n  showLabels,\n  labelDictionary,\n  containerWidth,\n}: HorizontalBarProps) => {\n  const X_PADDING = -5;\n\n  const minHeight = 15;\n  const minContainerWidth = 50;\n\n  const showBar = bar.value !== null && bar.height > 0 && bar.width > 0;\n\n  const labelX = bar.x + bar.width + X_PADDING;\n  const labelY = bar.y + bar.height / 2;\n\n  const showMinMax = showDataLabel(totalItems);\n  const hasSpaceForLabel = showLabels && bar.height > minHeight && containerWidth > minContainerWidth;\n\n  const displayValue = getFormattedValue(bar.value, labelDictionary);\n\n  return (\n    <Fragment>\n      {showBar && (\n        <HorizontalBarRect\n          barRectKey={`horizontal-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      {hasSpaceForLabel && showMinMax && <DataLabel x={labelX} y={labelY} title={displayValue} dx={1} dy={0} />}\n\n      <HorizontalBarLabel\n        bar={bar}\n        barGroup={barGroup}\n        xLabelPosition={xLabelPosition}\n        xAxisLabels={xAxisLabels}\n        showDetailedSubGroupingLabels={showDetailedSubGroupingLabels}\n        labelStyle={labelStyle}\n      />\n    </Fragment>\n  );\n};\n\ntype HorizontalBarRectProps = {\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 HorizontalBarRect = ({ onClick, fill, x, y, width, height, barRectKey, enableHover }: HorizontalBarRectProps) => {\n  const [isHovered, setIsHovered] = useState(false);\n\n  const classes = enableHover ? css({ cursor: 'pointer' }) : '';\n\n  const displayColor = isHovered && enableHover ? lightenColor(fill, 0.8) : fill;\n\n  const handleOnMouseEnter = () => {\n    if (enableHover) {\n      setIsHovered(true);\n    }\n  };\n\n  const handleOnMouseLeave = () => {\n    if (enableHover) {\n      setIsHovered(false);\n    }\n  };\n\n  return (\n    <rect\n      key={barRectKey}\n      x={x}\n      y={y}\n      width={width}\n      height={height}\n      fill={displayColor}\n      rx={BAR_RADIUS}\n      onClick={onClick}\n      onMouseEnter={handleOnMouseEnter}\n      onMouseLeave={handleOnMouseLeave}\n      className={classes}\n    />\n  );\n};\n\ntype HorizontalBarLabelProps = {\n  bar: any;\n  barGroup: any;\n  xLabelPosition?: number;\n  xAxisLabels?: string[];\n  showDetailedSubGroupingLabels: boolean;\n  labelStyle?: React.CSSProperties;\n};\n\nconst HorizontalBarLabel = ({\n  bar,\n  barGroup,\n  xLabelPosition,\n  xAxisLabels,\n  showDetailedSubGroupingLabels,\n  labelStyle,\n}: HorizontalBarLabelProps) => {\n  if (!showDetailedSubGroupingLabels || !xLabelPosition || !xAxisLabels) return null;\n\n  const label = xAxisLabels[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 labelYGap = 4;\n  const labelYPosition = bar.y + bar.height / 2 + labelYGap;\n\n  const labelXGap = 15;\n  const labelXPosition = xLabelPosition + labelXGap;\n\n  const labelKey = `horizontal-label-${barGroup.index}-${bar.index}-${label}`;\n\n  return (\n    <text\n      key={labelKey}\n      x={labelXPosition}\n      y={labelYPosition}\n      style={labelStyle}\n      textAnchor=\"middle\"\n      transform={`rotate(-70, ${labelXPosition}, ${labelYPosition})`}\n    >\n      {formattedColumnLabel}\n    </text>\n  );\n};\n"]} */",
47344
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["HorizontalBarGroup.tsx"],"names":[],"mappings":"AAiOgC","file":"HorizontalBarGroup.tsx","sourcesContent":["import { css } from '@emotion/css';\nimport { Group } from '@visx/group';\nimport { BarGroupHorizontal as VisxBarGroupHorizontal } from '@visx/shape';\nimport { DatumObject } from '@visx/shape/lib/types';\nimport { ScaleBand, ScaleLinear } from '@visx/vendor/d3-scale';\nimport { Fragment, useMemo, useState } from 'react';\nimport { BarStyles } from 'shared-logic/src/BarChartV2/types';\nimport { ChartDataDefinition, ConditionalFormattingRule, ShapeDefinition } from 'shared-logic/src/ChartsV2/types';\nimport { getAllChartValues, getFormattedValue, showDataLabel } from 'shared-logic/src/DataLabel/index';\nimport { DataType } from 'shared-logic/src/Field/types';\nimport { lightenColor } from '../../../styles/color.functions';\nimport { DataLabel } from '../../components/DataLabel';\nimport { BAR_RADIUS } from '../../constants/BORDER_RADIUS';\nimport { getBarFill } from '../getBarFill';\n\nexport type HorizontalBarGroupProps = {\n  data: ChartDataDefinition[];\n  keys: string[];\n  width: number;\n  yKey: string;\n  yScaleDataType: DataType;\n  yScale: ScaleBand<string> | ScaleBand<Date> | ScaleBand<number>;\n  innerYScale: ScaleBand<string>;\n  xScale: 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  xAxisLabels?: string[];\n  xLabelPosition?: number;\n  showDetailedSubGroupingLabels: boolean;\n  labelStyle?: React.CSSProperties;\n  showLabels: boolean;\n  labelDictionary: { [key: string]: string };\n};\n\nexport function HorizontalBarGroup({\n  data,\n  keys,\n  width,\n  yKey,\n  yScaleDataType,\n  yScale,\n  innerYScale,\n  xScale,\n  onClick,\n  conditionalFormattingRules,\n  bars,\n  enableHover,\n  xAxisLabels,\n  xLabelPosition,\n  showDetailedSubGroupingLabels,\n  labelStyle,\n  showLabels,\n  labelDictionary,\n}: HorizontalBarGroupProps) {\n  const getGroupPosition = (d: DatumObject) => {\n    const yValue = d[yKey as keyof typeof d];\n\n    if (yScaleDataType === 'string') return String(yValue);\n\n    if (yScaleDataType === 'date_time') {\n      return new Date(String(yValue));\n    }\n\n    if (yScaleDataType === 'number') {\n      return Number(yValue);\n    }\n\n    return String(yValue);\n  };\n\n  const totalItems = useMemo(() => {\n    const allBarValues = getAllChartValues(data, keys);\n    return allBarValues.length;\n  }, [data, keys]);\n\n  return (\n    <VisxBarGroupHorizontal<DatumObject>\n      data={data as DatumObject[]}\n      keys={keys}\n      width={width}\n      y0={getGroupPosition}\n      y0Scale={yScale}\n      y1Scale={innerYScale}\n      xScale={xScale}\n      color={() => ''}\n    >\n      {(barGroups) => {\n        return barGroups.map((barGroup) => (\n          <Group key={`horizontal-bar-group-${barGroup.index}-${barGroup.y0}`} top={barGroup.y0}>\n            {barGroup.bars.map((bar) => (\n              <HorizontalBar\n                key={`horizontal-bar-${bar.index}-${bar.y}`}\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                xAxisLabels={xAxisLabels}\n                xLabelPosition={xLabelPosition}\n                totalItems={totalItems}\n                showLabels={showLabels}\n                labelDictionary={labelDictionary}\n                xScale={xScale}\n                containerWidth={width}\n              />\n            ))}\n          </Group>\n        ));\n      }}\n    </VisxBarGroupHorizontal>\n  );\n}\n\ntype HorizontalBarProps = {\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  xAxisLabels?: string[];\n  xLabelPosition?: number;\n  totalItems: number;\n  showLabels: boolean;\n  labelDictionary: { [key: string]: string };\n  xScale: ScaleLinear<number, number, never>;\n  containerWidth: number;\n};\n\nconst HorizontalBar = ({\n  bar,\n  barGroup,\n  bars,\n  conditionalFormattingRules,\n  enableHover,\n  labelStyle,\n  onClick,\n  showDetailedSubGroupingLabels,\n  xAxisLabels,\n  xLabelPosition,\n  totalItems,\n  showLabels,\n  labelDictionary,\n  xScale,\n  containerWidth,\n}: HorizontalBarProps) => {\n  const X_PADDING = -5;\n\n  const minHeight = 15;\n  const minContainerWidth = 50;\n\n  const barX = bar.value >= 0 ? xScale(0) : xScale(bar.value);\n  const barWidth = Math.abs(xScale(bar.value) - xScale(0));\n\n  const showBar = bar.value !== null && bar.height > 0 && bar.width > 0;\n\n  const labelXPaddingAdjustment = bar.value >= 0 ? X_PADDING : 0;\n  const labelX = xScale(bar.value) + labelXPaddingAdjustment;\n  const labelY = bar.y + bar.height / 2;\n  const labelHorizontalAnchor = bar.value < 0 ? 'end' : undefined;\n\n  const showMinMax = showDataLabel(totalItems);\n  const hasSpaceForLabel = showLabels && bar.height > minHeight && containerWidth > minContainerWidth;\n\n  const displayValue = getFormattedValue(bar.value, labelDictionary);\n\n  return (\n    <Fragment>\n      {showBar && (\n        <HorizontalBarRect\n          barRectKey={`horizontal-bar-group-bar-${barGroup.index}-${bar.index}-${bar.value}-${String(bar.key)}`}\n          x={barX}\n          y={bar.y}\n          width={barWidth}\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      {hasSpaceForLabel && showMinMax && (\n        <DataLabel\n          x={labelX}\n          y={labelY}\n          title={displayValue !== 0 ? displayValue : '0'}\n          dx={1}\n          dy={0}\n          horizontalAnchor={labelHorizontalAnchor}\n        />\n      )}\n\n      <HorizontalBarLabel\n        bar={bar}\n        barGroup={barGroup}\n        xLabelPosition={xLabelPosition}\n        xAxisLabels={xAxisLabels}\n        showDetailedSubGroupingLabels={showDetailedSubGroupingLabels}\n        labelStyle={labelStyle}\n      />\n    </Fragment>\n  );\n};\n\ntype HorizontalBarRectProps = {\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 HorizontalBarRect = ({ onClick, fill, x, y, width, height, barRectKey, enableHover }: HorizontalBarRectProps) => {\n  const [isHovered, setIsHovered] = useState(false);\n\n  const classes = enableHover ? css({ cursor: 'pointer' }) : '';\n\n  const displayColor = isHovered && enableHover ? lightenColor(fill, 0.8) : fill;\n\n  const handleOnMouseEnter = () => {\n    if (enableHover) {\n      setIsHovered(true);\n    }\n  };\n\n  const handleOnMouseLeave = () => {\n    if (enableHover) {\n      setIsHovered(false);\n    }\n  };\n\n  return (\n    <rect\n      key={barRectKey}\n      x={x}\n      y={y}\n      width={width}\n      height={height}\n      fill={displayColor}\n      rx={BAR_RADIUS}\n      onClick={onClick}\n      onMouseEnter={handleOnMouseEnter}\n      onMouseLeave={handleOnMouseLeave}\n      className={classes}\n    />\n  );\n};\n\ntype HorizontalBarLabelProps = {\n  bar: any;\n  barGroup: any;\n  xLabelPosition?: number;\n  xAxisLabels?: string[];\n  showDetailedSubGroupingLabels: boolean;\n  labelStyle?: React.CSSProperties;\n};\n\nconst HorizontalBarLabel = ({\n  bar,\n  barGroup,\n  xLabelPosition,\n  xAxisLabels,\n  showDetailedSubGroupingLabels,\n  labelStyle,\n}: HorizontalBarLabelProps) => {\n  if (!showDetailedSubGroupingLabels || !xLabelPosition || !xAxisLabels) return null;\n\n  const label = xAxisLabels[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 labelYGap = 4;\n  const labelYPosition = bar.y + bar.height / 2 + labelYGap;\n\n  const labelXGap = 15;\n  const labelXPosition = xLabelPosition + labelXGap;\n\n  const labelKey = `horizontal-label-${barGroup.index}-${bar.index}-${label}`;\n\n  return (\n    <text\n      key={labelKey}\n      x={labelXPosition}\n      y={labelYPosition}\n      style={labelStyle}\n      textAnchor=\"middle\"\n      transform={`rotate(-70, ${labelXPosition}, ${labelYPosition})`}\n    >\n      {formattedColumnLabel}\n    </text>\n  );\n};\n"]} */",
47060
47345
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$a
47061
47346
  }) : '';
47062
47347
  var displayColor = isHovered && enableHover ? lightenColor$2(fill, 0.8) : fill;
@@ -47127,7 +47412,8 @@ var HorizontalBarStacked = function HorizontalBarStacked(_ref) {
47127
47412
  width = _ref.width,
47128
47413
  showLabels = _ref.showLabels,
47129
47414
  labelDictionary = _ref.labelDictionary,
47130
- isStacked100 = _ref.isStacked100;
47415
+ _ref$isStacked = _ref.isStacked100,
47416
+ isStacked100 = _ref$isStacked === void 0 ? false : _ref$isStacked;
47131
47417
  var handleGetYValue = function handleGetYValue(d) {
47132
47418
  var yValue = d[yScaleKey];
47133
47419
  if (yScaleDataType === 'string') return String(yValue);
@@ -47154,7 +47440,7 @@ var HorizontalBarStacked = function HorizontalBarStacked(_ref) {
47154
47440
  },
47155
47441
  height: height,
47156
47442
  width: width,
47157
- offset: isStacked100 ? 'expand' : 'none',
47443
+ offset: "diverging",
47158
47444
  children: function children(barStacks) {
47159
47445
  return barStacks.map(function (barStack) {
47160
47446
  return barStack.bars.map(function (bar) {
@@ -47165,7 +47451,8 @@ var HorizontalBarStacked = function HorizontalBarStacked(_ref) {
47165
47451
  conditionalFormattingRules: conditionalFormattingRules,
47166
47452
  totalItems: totalItems,
47167
47453
  showLabels: showLabels,
47168
- labelDictionary: labelDictionary
47454
+ labelDictionary: labelDictionary,
47455
+ isStacked100: isStacked100
47169
47456
  }, bar.key.toString() + "-" + bar.index + "-" + bar.y);
47170
47457
  });
47171
47458
  });
@@ -47179,13 +47466,15 @@ var HorizontalBar$1 = function HorizontalBar(_ref2) {
47179
47466
  conditionalFormattingRules = _ref2.conditionalFormattingRules,
47180
47467
  totalItems = _ref2.totalItems,
47181
47468
  showLabels = _ref2.showLabels,
47182
- labelDictionary = _ref2.labelDictionary;
47469
+ labelDictionary = _ref2.labelDictionary,
47470
+ _ref2$isStacked = _ref2.isStacked100,
47471
+ isStacked100 = _ref2$isStacked === void 0 ? false : _ref2$isStacked;
47183
47472
  var BAR_PADDING = 1.5;
47184
- var X_PADDING = 5;
47185
47473
  var Y_PADDING = -2;
47186
- var minWidth = 30;
47474
+ var minWidthMultiplier = isStacked100 ? 1.75 : 1;
47475
+ var minWidth = 30 * minWidthMultiplier;
47187
47476
  var minHeight = 15;
47188
- var labelX = bar.x + bar.width + X_PADDING;
47477
+ var labelX = bar.x + bar.width / 2;
47189
47478
  var labelY = bar.y + bar.height / 2 + Y_PADDING;
47190
47479
  var showMinMax = showDataLabel(totalItems);
47191
47480
  var hasSpaceForLabel = showLabels && bar.width > minWidth && bar.height > minHeight;
@@ -47207,7 +47496,8 @@ var HorizontalBar$1 = function HorizontalBar(_ref2) {
47207
47496
  color: textColor,
47208
47497
  title: displayValue,
47209
47498
  dx: 0,
47210
- dy: 0
47499
+ dy: 0,
47500
+ horizontalAnchor: "middle"
47211
47501
  })]
47212
47502
  });
47213
47503
  };
@@ -47488,13 +47778,24 @@ var HorizontalBarChart$3 = function HorizontalBarChart(_ref) {
47488
47778
  var innerWidth = width - margin.left - margin.right + groupingAxisBaselineShift;
47489
47779
  var innerHeight = Math.max(0, height - margin.top - margin.bottom - legendOffset);
47490
47780
  var isStacked100 = options.stacked === '100%';
47781
+ var yKey = chart.y.key;
47782
+ var yScaleKey = chart.y.scale.key;
47783
+ var yScaleDataType = chart.y.scale.dataType;
47491
47784
  var xScaleKeys = chart.x.keys;
47785
+ var processedData = useMemo(function () {
47786
+ if (isStacked100) {
47787
+ return convertToStackedPercentages(chart.data, chart.x.keys, yKey);
47788
+ }
47789
+ return chart.data;
47790
+ }, [isStacked100, chart.data, chart.x.keys, yKey]);
47791
+ var yScale = useHorizontalBarYScale(yScaleDataType, innerHeight, yScaleKey, processedData);
47492
47792
  var defaultXScale = useHorizontalBarXScale(innerWidth, chart.x.scale, -groupingAxisBaselineShift);
47493
47793
  var xScale = useMemo(function () {
47494
47794
  if (isStacked100) {
47795
+ var domain = getStackedPercentageScaleLinearDomain(processedData, chart.x.keys, yKey);
47495
47796
  return scaleLinear({
47496
47797
  range: [-groupingAxisBaselineShift, innerWidth + -groupingAxisBaselineShift],
47497
- domain: [0, 1],
47798
+ domain: domain,
47498
47799
  nice: true,
47499
47800
  round: true
47500
47801
  });
@@ -47504,7 +47805,7 @@ var HorizontalBarChart$3 = function HorizontalBarChart(_ref) {
47504
47805
  var barGroupXScale = useHorizontalBarXScale(innerWidth, chart.x.scale, 0);
47505
47806
  var xTickValues = useMemo(function () {
47506
47807
  if (isStacked100) {
47507
- return [0, 0.2, 0.4, 0.6, 0.8, 1.0];
47808
+ return getStackedPercentageTickValues(processedData, chart.x.keys, yKey);
47508
47809
  }
47509
47810
  return chart.x.ticks.map(function (tick) {
47510
47811
  return Number(tick.value);
@@ -47512,32 +47813,9 @@ var HorizontalBarChart$3 = function HorizontalBarChart(_ref) {
47512
47813
  }, [isStacked100, chart.x.ticks]);
47513
47814
  var xAxisConfig = useMemo(function () {
47514
47815
  if (isStacked100) {
47816
+ var ticks = getStackedPercentageAxisTicks(processedData, chart.x.keys, yKey);
47515
47817
  return _extends({}, chart.x, {
47516
- ticks: [{
47517
- value: 0,
47518
- formattedValue: '0',
47519
- scaleValue: 0
47520
- }, {
47521
- value: 0.2,
47522
- formattedValue: '20',
47523
- scaleValue: 0.2
47524
- }, {
47525
- value: 0.4,
47526
- formattedValue: '40',
47527
- scaleValue: 0.4
47528
- }, {
47529
- value: 0.6,
47530
- formattedValue: '60',
47531
- scaleValue: 0.6
47532
- }, {
47533
- value: 0.8,
47534
- formattedValue: '80',
47535
- scaleValue: 0.8
47536
- }, {
47537
- value: 1,
47538
- formattedValue: '100',
47539
- scaleValue: 1
47540
- }]
47818
+ ticks: ticks
47541
47819
  });
47542
47820
  }
47543
47821
  return chart.x;
@@ -47547,16 +47825,6 @@ var HorizontalBarChart$3 = function HorizontalBarChart(_ref) {
47547
47825
  return (_chart$keys$legendIte = (_chart$keys$legendIte2 = chart.keys[legendItem.yKey]) == null ? void 0 : _chart$keys$legendIte2.keyFormatted) != null ? _chart$keys$legendIte : '';
47548
47826
  });
47549
47827
  var xSubLabelPosition = groupingAxisBaselineShift - leftOffset;
47550
- var yKey = chart.y.key;
47551
- var yScaleKey = chart.y.scale.key;
47552
- var yScaleDataType = chart.y.scale.dataType;
47553
- var processedData = useMemo(function () {
47554
- if (isStacked100) {
47555
- return convertToStackedPercentages(chart.data, chart.x.keys, yKey);
47556
- }
47557
- return chart.data;
47558
- }, [isStacked100, chart.data, chart.x.keys, yKey]);
47559
- var yScale = useHorizontalBarYScale(yScaleDataType, innerHeight, yScaleKey, processedData);
47560
47828
  var innerYScale = useMemo(function () {
47561
47829
  if (!options.stacked && yScale && 'bandwidth' in yScale) {
47562
47830
  return scaleBand({
@@ -47658,6 +47926,7 @@ var HorizontalBarChart$3 = function HorizontalBarChart(_ref) {
47658
47926
  var formattedLabelsDict = useMemo(function () {
47659
47927
  return getLabelDictionary(processedData, xScaleKeys);
47660
47928
  }, [processedData, xScaleKeys]);
47929
+ var showZeroLine = chart.x.scale.min && chart.x.scale.min < 0 && chart.x.scale.max && chart.x.scale.max > 0;
47661
47930
  return jsxs(Fragment, {
47662
47931
  children: [jsxs(ChartWrapper$1, {
47663
47932
  width: width,
@@ -47759,6 +48028,11 @@ var HorizontalBarChart$3 = function HorizontalBarChart(_ref) {
47759
48028
  labelDictionary: formattedLabelsDict,
47760
48029
  isStacked100: isStacked100
47761
48030
  })]
48031
+ }), showZeroLine && jsx("g", {
48032
+ children: jsx(ZeroVerticalLine, {
48033
+ xScale: xScale,
48034
+ chartHeight: innerHeight
48035
+ })
47762
48036
  })]
47763
48037
  }), tooltipData && jsx("g", {
47764
48038
  children: jsx(Line, {
@@ -47884,6 +48158,7 @@ var LineChart$5 = function LineChart(_ref) {
47884
48158
  var labelDictionary = useMemo(function () {
47885
48159
  return getLabelDictionary(chart.data, chart.y.keys);
47886
48160
  }, [chart.data, chart.y.keys]);
48161
+ var showZeroLine = chart.y.scale.min && chart.y.scale.min < 0 && chart.y.scale.max && chart.y.scale.max > 0;
47887
48162
  var memoizedLines = useMemo(function () {
47888
48163
  if (xScaleKey === null || xScale === null) return null;
47889
48164
  return jsx(Lines, {
@@ -47944,8 +48219,13 @@ var LineChart$5 = function LineChart(_ref) {
47944
48219
  yScale: _yScale,
47945
48220
  ticks: yTickValues,
47946
48221
  stroke: theme == null || (_theme$axis = theme.axis) == null ? void 0 : _theme$axis.stroke
47947
- }), jsx(Group$2, {
47948
- children: memoizedLines
48222
+ }), jsxs(Group$2, {
48223
+ children: [memoizedLines, showZeroLine && jsx("g", {
48224
+ children: jsx(ZeroHorizontalLine, {
48225
+ yScale: _yScale,
48226
+ chartWidth: innerWidth
48227
+ })
48228
+ })]
47949
48229
  })]
47950
48230
  }), tooltipData && jsxs("g", {
47951
48231
  children: [jsx(Line, {
@@ -48140,19 +48420,21 @@ var LineLabel = /*#__PURE__*/memo(function LineLabel(_ref5) {
48140
48420
  labelDictionary = _ref5.labelDictionary;
48141
48421
  var xValue = chartData[xScaleKey];
48142
48422
  var yValue = chartData[yKey];
48143
- var xPadding = 18;
48144
- var yPadding = 8;
48145
- var xPosition = xScale(xValue);
48146
- var yPosition = yScale(yValue);
48423
+ var xLabelPosition = xScale(xValue);
48424
+ var yLabelPosition = yScale(yValue);
48425
+ var yLabelPaddingAdjustment = yValue >= 0 ? -8 : 8;
48147
48426
  var showMinMax = showDataLabel(totalItems);
48427
+ var hasPositionForLabel = showLabels && xLabelPosition && yLabelPosition;
48148
48428
  var displayValue = getFormattedValue(yValue, labelDictionary);
48149
- if (xPosition == null || yPosition == null || !showMinMax || !showLabels) return null;
48150
- return jsx(DataLabel, {
48151
- x: xPosition - xPadding,
48152
- y: yPosition - yPadding,
48153
- dx: 2,
48154
- dy: 0,
48155
- title: displayValue
48429
+ return jsx(Fragment$1, {
48430
+ children: showMinMax && hasPositionForLabel && jsx(DataLabel, {
48431
+ x: xLabelPosition,
48432
+ y: yLabelPosition + yLabelPaddingAdjustment,
48433
+ dx: 0,
48434
+ dy: 0,
48435
+ title: displayValue !== 0 ? displayValue : '0',
48436
+ horizontalAnchor: "middle"
48437
+ })
48156
48438
  });
48157
48439
  });
48158
48440
 
@@ -48652,7 +48934,7 @@ var getMinAndMax = function getMinAndMax(_ref) {
48652
48934
  }
48653
48935
  };
48654
48936
 
48655
- function getNiceInterval(interval) {
48937
+ function getNiceInterval$1(interval) {
48656
48938
  // Round the interval to a "nice" value (1, 2, 5, etc.)
48657
48939
  var exponent = Math.floor(Math.log10(interval));
48658
48940
  var fraction = interval / Math.pow(10, exponent);
@@ -48693,7 +48975,7 @@ var getScaleAndTicks = function getScaleAndTicks(_ref) {
48693
48975
  var maxY = y.max ? y.max * 1.1 : y.max || 1;
48694
48976
  var minY = Math.min(y.min || 0, 0);
48695
48977
  var tickCountYAxis = approxYAxisLabelCount === 'auto' ? 10 : approxYAxisLabelCount;
48696
- var yTickInterval = getNiceInterval((maxY - minY) / (tickCountYAxis - 1));
48978
+ var yTickInterval = getNiceInterval$1((maxY - minY) / (tickCountYAxis - 1));
48697
48979
  var i = 0;
48698
48980
  while (yTickInterval * i <= maxY + yTickInterval) {
48699
48981
  var _value = yTickInterval * i;
@@ -48707,7 +48989,7 @@ var getScaleAndTicks = function getScaleAndTicks(_ref) {
48707
48989
  }
48708
48990
  var maxX = x.max ? x.max * 1.05 : x.max || 1;
48709
48991
  var minX = Math.min(x.min || 0, 0);
48710
- var xTickInterval = getNiceInterval((maxX - minX) / (10 - 1));
48992
+ var xTickInterval = getNiceInterval$1((maxX - minX) / (10 - 1));
48711
48993
  i = 0;
48712
48994
  while (xTickInterval * i <= maxX + xTickInterval) {
48713
48995
  var _value2 = xTickInterval * i;
@@ -49800,14 +50082,22 @@ var getStackedMinAndMax = function getStackedMinAndMax(_ref) {
49800
50082
  min: null
49801
50083
  };
49802
50084
  if (stacked) {
49803
- var totals = data.map(function (dataItem) {
50085
+ var positiveTotals = data.map(function (dataItem) {
49804
50086
  return keys.reduce(function (sum, key) {
49805
50087
  var value = dataItem[key] ? dataItem[key].value : 0;
49806
- return sum + (typeof value === 'number' ? value : 0);
50088
+ var valueNumber = typeof value === 'number' ? value : 0;
50089
+ return sum + (valueNumber > 0 ? valueNumber : 0);
49807
50090
  }, 0);
49808
50091
  });
49809
- var maxTotal = Math.max.apply(Math, totals);
49810
- var minTotal = Math.min.apply(Math, totals);
50092
+ var negativeTotals = data.map(function (dataItem) {
50093
+ return keys.reduce(function (sum, key) {
50094
+ var value = dataItem[key] ? dataItem[key].value : 0;
50095
+ var valueNumber = typeof value === 'number' ? value : 0;
50096
+ return sum + (valueNumber < 0 ? valueNumber : 0);
50097
+ }, 0);
50098
+ });
50099
+ var maxTotal = Math.max.apply(Math, positiveTotals);
50100
+ var minTotal = Math.min.apply(Math, negativeTotals);
49811
50101
  return {
49812
50102
  max: maxTotal,
49813
50103
  min: minTotal
@@ -49843,34 +50133,6 @@ var getStackedMinAndMax = function getStackedMinAndMax(_ref) {
49843
50133
  };
49844
50134
  };
49845
50135
 
49846
- var DEFAULT_TICK_COUNT = 10;
49847
- function getNiceInterval$1(interval) {
49848
- var exponent = Math.floor(Math.log10(interval));
49849
- var fraction = interval / Math.pow(10, exponent);
49850
- var niceFraction;
49851
- if (fraction <= 1) {
49852
- niceFraction = 1;
49853
- } else if (fraction <= 1.25) {
49854
- niceFraction = 1.25;
49855
- } else if (fraction <= 1.5) {
49856
- niceFraction = 1.5;
49857
- } else if (fraction <= 2) {
49858
- niceFraction = 2;
49859
- } else if (fraction <= 2.5) {
49860
- niceFraction = 2.5;
49861
- } else if (fraction <= 3) {
49862
- niceFraction = 3;
49863
- } else if (fraction <= 5) {
49864
- niceFraction = 5;
49865
- } else if (fraction <= 7) {
49866
- niceFraction = 7;
49867
- } else if (fraction <= 10) {
49868
- niceFraction = 10;
49869
- } else {
49870
- niceFraction = 10;
49871
- }
49872
- return niceFraction * Math.pow(10, exponent);
49873
- }
49874
50136
  var getScaleAndTicks$1 = function getScaleAndTicks(_ref) {
49875
50137
  var _order$;
49876
50138
  var data = _ref.data,
@@ -49927,20 +50189,16 @@ var getScaleAndTicks$1 = function getScaleAndTicks(_ref) {
49927
50189
  goalLines: goalLines,
49928
50190
  stacked: stacked
49929
50191
  });
49930
- var maxY = y.max || 0;
49931
- var minY = Math.min(y.min || 0, 0);
49932
- var yTickCount = tickCountYAxis != null ? tickCountYAxis : DEFAULT_TICK_COUNT;
49933
- var yTickInterval = getNiceInterval$1((maxY - minY) / (yTickCount - 1));
49934
- var yTicks = [];
49935
- for (var i = 0; i < yTickCount; i++) {
49936
- var _value = minY + yTickInterval * i;
49937
- var formattedValue = formattingFunctionY(_value, nullValue);
49938
- yTicks.push({
49939
- value: _value,
49940
- formattedValue: formattedValue,
49941
- scaleValue: _value
49942
- });
49943
- }
50192
+ var yTicks = getMetricAxisTicks({
50193
+ min: y.min,
50194
+ max: y.max,
50195
+ tickCount: tickCountYAxis,
50196
+ nullValue: nullValue,
50197
+ formattingFunction: formattingFunctionY,
50198
+ stacked: stacked != null ? stacked : false
50199
+ });
50200
+ var maxY = Math.max(yTicks.maxTickValue, y.max || 0);
50201
+ var minY = Math.min(yTicks.minTickValue, y.min || 0);
49944
50202
  return {
49945
50203
  x: {
49946
50204
  ticks: xTicks,
@@ -49953,7 +50211,7 @@ var getScaleAndTicks$1 = function getScaleAndTicks(_ref) {
49953
50211
  }
49954
50212
  },
49955
50213
  y: {
49956
- ticks: yTicks,
50214
+ ticks: yTicks.ticks,
49957
50215
  scale: {
49958
50216
  dataType: 'number',
49959
50217
  key: null,
@@ -50165,7 +50423,8 @@ var buildLineChartRepresentation = function buildLineChartRepresentation(_ref) {
50165
50423
  data: chartData,
50166
50424
  lines: styleDefinition,
50167
50425
  conditionalFormattingRules: conditionalFormattingRules,
50168
- goalLines: goalLines
50426
+ goalLines: goalLines,
50427
+ formattingFunctionY: formattingFunctionY
50169
50428
  };
50170
50429
  return chart;
50171
50430
  };
@@ -50906,7 +51165,8 @@ var buildBarChartRepresentation = function buildBarChartRepresentation(_ref) {
50906
51165
  data: updatedData,
50907
51166
  bars: styleDefinition,
50908
51167
  conditionalFormattingRules: conditionalFormattingRules,
50909
- goalLines: goalLines
51168
+ goalLines: goalLines,
51169
+ formattingFunctionY: formattingFunctionY
50910
51170
  };
50911
51171
  return chart;
50912
51172
  };
@@ -51417,6 +51677,7 @@ var ComboChart$4 = function ComboChart(_ref) {
51417
51677
  var formattedLabelsDict = useMemo(function () {
51418
51678
  return getLabelDictionary(chart.bars.data, yBarKeys);
51419
51679
  }, [chart.bars.data, yBarKeys]);
51680
+ var showZeroLine = chart.y.scale.min && chart.y.scale.min < 0 && chart.y.scale.max && chart.y.scale.max > 0;
51420
51681
  return jsxs(Fragment, {
51421
51682
  children: [jsxs(ChartWrapper$1, {
51422
51683
  width: width,
@@ -51499,6 +51760,11 @@ var ComboChart$4 = function ComboChart(_ref) {
51499
51760
  showLabels: options.showLabels,
51500
51761
  labelDictionary: labelDictionary
51501
51762
  })
51763
+ }), showZeroLine && jsx("g", {
51764
+ children: jsx(ZeroHorizontalLine, {
51765
+ yScale: yScale,
51766
+ chartWidth: innerWidth
51767
+ })
51502
51768
  })]
51503
51769
  })]
51504
51770
  }), tooltipData && jsx("g", {
@@ -51544,7 +51810,7 @@ function adjustColors(maybeColors, defaultColors, shift) {
51544
51810
  }
51545
51811
 
51546
51812
  function buildComboChartRepresentation(xKeyField, barChartRepresentation, lineChartRepresentation) {
51547
- var _barChartRepresentati, _lineChartRepresentat, _barChartRepresentati2, _lineChartRepresentat2, _lineChartRepresentat4, _lineChartRepresentat5, _lineChartRepresentat6, _barChartRepresentati4, _barChartRepresentati5, _ref, _lineChartRepresentat7;
51813
+ var _barChartRepresentati, _barChartRepresentati2, _lineChartRepresentat, _lineChartRepresentat2, _lineChartRepresentat3, _lineChartRepresentat4, _lineChartRepresentat5, _barChartRepresentati3, _barChartRepresentati4, _ref, _lineChartRepresentat6;
51548
51814
  var xScale = function () {
51549
51815
  if ((xKeyField == null ? void 0 : xKeyField.dataType) === 'number') {
51550
51816
  return _extends({}, barChartRepresentation.x.scale, {
@@ -51563,15 +51829,39 @@ function buildComboChartRepresentation(xKeyField, barChartRepresentation, lineCh
51563
51829
  max: null
51564
51830
  });
51565
51831
  }();
51566
- var yScale = _extends({}, barChartRepresentation.y.scale, {
51567
- max: Math.max((_barChartRepresentati = barChartRepresentation.y.scale.max) != null ? _barChartRepresentati : 0, (_lineChartRepresentat = lineChartRepresentation.y.scale.max) != null ? _lineChartRepresentat : 0),
51568
- min: Math.max((_barChartRepresentati2 = barChartRepresentation.y.scale.min) != null ? _barChartRepresentati2 : 0, (_lineChartRepresentat2 = lineChartRepresentation.y.scale.min) != null ? _lineChartRepresentat2 : 0)
51569
- });
51570
- var yTicks = function (_barChartRepresentati3, _lineChartRepresentat3) {
51571
- if (((_barChartRepresentati3 = barChartRepresentation.y.scale.max) != null ? _barChartRepresentati3 : 0) > ((_lineChartRepresentat3 = lineChartRepresentation.y.scale.max) != null ? _lineChartRepresentat3 : 0)) {
51832
+ var barChartMaxY = (_barChartRepresentati = barChartRepresentation.y.scale.max) != null ? _barChartRepresentati : 0;
51833
+ var barChartMinY = (_barChartRepresentati2 = barChartRepresentation.y.scale.min) != null ? _barChartRepresentati2 : 0;
51834
+ var lineChartMaxY = (_lineChartRepresentat = lineChartRepresentation.y.scale.max) != null ? _lineChartRepresentat : 0;
51835
+ var lineChartMinY = (_lineChartRepresentat2 = lineChartRepresentation.y.scale.min) != null ? _lineChartRepresentat2 : 0;
51836
+ var comboChartMaxY = Math.max(barChartMaxY, lineChartMaxY);
51837
+ var comboChartMinY = Math.min(barChartMinY, lineChartMinY);
51838
+ var yTicks = function () {
51839
+ if (barChartMaxY >= lineChartMaxY && barChartMinY <= lineChartMinY) {
51572
51840
  return barChartRepresentation.y.ticks;
51573
- } else {
51841
+ } else if (lineChartMaxY >= barChartMaxY && lineChartMinY <= barChartMinY) {
51574
51842
  return lineChartRepresentation.y.ticks;
51843
+ } else {
51844
+ var comboChartTicksLength = Math.max(barChartRepresentation.y.ticks.length, lineChartRepresentation.y.ticks.length);
51845
+ var formattingFunctionY = function formattingFunctionY(value) {
51846
+ if (barChartRepresentation.formattingFunctionY) {
51847
+ return barChartRepresentation.formattingFunctionY(value);
51848
+ } else if (lineChartRepresentation.formattingFunctionY) {
51849
+ return lineChartRepresentation.formattingFunctionY(value);
51850
+ } else {
51851
+ return String(value);
51852
+ }
51853
+ };
51854
+ var _yTicks = getMetricAxisTicks({
51855
+ min: comboChartMinY,
51856
+ max: comboChartMaxY,
51857
+ tickCount: comboChartTicksLength,
51858
+ nullValue: undefined,
51859
+ formattingFunction: formattingFunctionY,
51860
+ stacked: false
51861
+ });
51862
+ comboChartMaxY = Math.max(_yTicks.maxTickValue, comboChartMaxY);
51863
+ comboChartMinY = Math.min(_yTicks.minTickValue, comboChartMinY);
51864
+ return _yTicks.ticks;
51575
51865
  }
51576
51866
  }();
51577
51867
  return {
@@ -51581,22 +51871,25 @@ function buildComboChartRepresentation(xKeyField, barChartRepresentation, lineCh
51581
51871
  }),
51582
51872
  keys: _extends({}, lineChartRepresentation == null ? void 0 : lineChartRepresentation.keys, barChartRepresentation == null ? void 0 : barChartRepresentation.keys),
51583
51873
  y: _extends({}, barChartRepresentation.y, {
51584
- scale: yScale,
51874
+ scale: _extends({}, barChartRepresentation.y.scale, {
51875
+ max: comboChartMaxY,
51876
+ min: comboChartMinY
51877
+ }),
51585
51878
  ticks: yTicks,
51586
51879
  barKeys: barChartRepresentation.y.keys,
51587
51880
  lineKeys: lineChartRepresentation.y.keys
51588
51881
  }),
51589
51882
  lines: {
51590
- definitions: (_lineChartRepresentat4 = lineChartRepresentation == null ? void 0 : lineChartRepresentation.lines) != null ? _lineChartRepresentat4 : [],
51591
- data: (_lineChartRepresentat5 = lineChartRepresentation == null ? void 0 : lineChartRepresentation.data) != null ? _lineChartRepresentat5 : [],
51592
- conditionalFormattingRules: (_lineChartRepresentat6 = lineChartRepresentation == null ? void 0 : lineChartRepresentation.conditionalFormattingRules) != null ? _lineChartRepresentat6 : []
51883
+ definitions: (_lineChartRepresentat3 = lineChartRepresentation == null ? void 0 : lineChartRepresentation.lines) != null ? _lineChartRepresentat3 : [],
51884
+ data: (_lineChartRepresentat4 = lineChartRepresentation == null ? void 0 : lineChartRepresentation.data) != null ? _lineChartRepresentat4 : [],
51885
+ conditionalFormattingRules: (_lineChartRepresentat5 = lineChartRepresentation == null ? void 0 : lineChartRepresentation.conditionalFormattingRules) != null ? _lineChartRepresentat5 : []
51593
51886
  },
51594
51887
  bars: {
51595
51888
  definitions: barChartRepresentation.bars,
51596
- data: (_barChartRepresentati4 = barChartRepresentation == null ? void 0 : barChartRepresentation.data) != null ? _barChartRepresentati4 : [],
51597
- conditionalFormattingRules: (_barChartRepresentati5 = barChartRepresentation.conditionalFormattingRules) != null ? _barChartRepresentati5 : []
51889
+ data: (_barChartRepresentati3 = barChartRepresentation == null ? void 0 : barChartRepresentation.data) != null ? _barChartRepresentati3 : [],
51890
+ conditionalFormattingRules: (_barChartRepresentati4 = barChartRepresentation.conditionalFormattingRules) != null ? _barChartRepresentati4 : []
51598
51891
  },
51599
- goalLines: (_ref = (_lineChartRepresentat7 = lineChartRepresentation == null ? void 0 : lineChartRepresentation.goalLines) != null ? _lineChartRepresentat7 : lineChartRepresentation == null ? void 0 : lineChartRepresentation.goalLines) != null ? _ref : []
51892
+ goalLines: (_ref = (_lineChartRepresentat6 = lineChartRepresentation == null ? void 0 : lineChartRepresentation.goalLines) != null ? _lineChartRepresentat6 : lineChartRepresentation == null ? void 0 : lineChartRepresentation.goalLines) != null ? _ref : []
51600
51893
  };
51601
51894
  }
51602
51895