@vizzly/dashboard 0.15.0-dev-966d08f66bb4c83a14c4b77d8e622320035ddaf5 → 0.15.0-dev-45f4268b92d46ac8f53b9683a04bb9e8d2dac16a

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.
@@ -20,5 +20,7 @@ export declare type HorizontalBarChartProps = {
20
20
  onClick?: (params: ChartOnViewClick) => void;
21
21
  enableHover?: boolean;
22
22
  numberOfDimensions: number;
23
+ formatXAxisLabel?: (value: any) => any;
24
+ formatYAxisLabel?: (value: any) => any;
23
25
  };
24
- export declare const HorizontalBarChart: ({ chart, width, height, options, theme, onClick, enableHover, numberOfDimensions, }: HorizontalBarChartProps) => JSX.Element;
26
+ export declare const HorizontalBarChart: ({ chart, width, height, options, theme, onClick, enableHover, numberOfDimensions, formatXAxisLabel, formatYAxisLabel, }: HorizontalBarChartProps) => JSX.Element;
@@ -1786,6 +1786,25 @@ function inclusiveExclusiveCurrent(op, filter) {
1786
1786
  throw new Error('Unknown date operation');
1787
1787
  }
1788
1788
  }
1789
+ var buildAdvancedFilters = function buildAdvancedFilters(filterValue, fieldIds) {
1790
+ if (!filterValue) return [];
1791
+ var hasValidConditions = Array.isArray(filterValue) && filterValue.every(function (conditionGroup) {
1792
+ return Array.isArray(conditionGroup);
1793
+ });
1794
+ if (hasValidConditions) {
1795
+ filterValue = removeEmptyConditions(filterValue);
1796
+ if (filterValue.length === 0) return [];
1797
+ var correctFiltersForField = filterValue.map(function (conditionGroup) {
1798
+ return conditionGroup.filter(function (filter) {
1799
+ return fieldIds.includes(filter.field);
1800
+ });
1801
+ }).filter(function (conditionGroup) {
1802
+ return conditionGroup.length > 0;
1803
+ });
1804
+ return correctFiltersForField;
1805
+ }
1806
+ return [];
1807
+ };
1789
1808
  function getCascadeOptionsFilters(globalFilters, dataSets, dateFilterOptions, variables, cascadeFilterSelection) {
1790
1809
  if (!cascadeFilterSelection) return undefined;
1791
1810
  var dataSetMap = new Map(dataSets.map(function (ds) {
@@ -1865,7 +1884,10 @@ function getFilterDataType(filter, dataSets) {
1865
1884
  var toQueryAttributesFilter = function toQueryAttributesFilter(dataSet, filter, customTimeRangeFuncs) {
1866
1885
  // For any filter that already contains the full filter object,
1867
1886
  if (isAdditionalFilter(filter.value)) {
1868
- return removeEmptyConditions(filter.value || []);
1887
+ var dataSetFieldIds = dataSet.fields.map(function (field) {
1888
+ return field.id;
1889
+ });
1890
+ return buildAdvancedFilters(filter.value, dataSetFieldIds);
1869
1891
  }
1870
1892
  return filter.appliesToFields.flatMap(function (field) {
1871
1893
  var _filter$value, _filter$value2, _filter$value3;
@@ -3070,7 +3092,7 @@ var queryFilterSchema = function queryFilterSchema(queryEngineConfig, maxDepth)
3070
3092
  value: whereFilterSchema.required()
3071
3093
  }), Joi.object({
3072
3094
  type: Joi.string().valid('andWhere', 'orWhere').required(),
3073
- value: Joi.array().items(_buildRecursiveSchema(depth - 1)).min(1).required().description('Array of nested filters')
3095
+ value: Joi.array().items(_buildRecursiveSchema(depth - 1)).required().description('Array of nested filters')
3074
3096
  }));
3075
3097
  };
3076
3098
  return _buildRecursiveSchema(maxDepth);
@@ -23622,8 +23644,7 @@ var dashboardFilters = function dashboardFilters(state, pipelineTransformationOp
23622
23644
  return !gF.managedByConfiguration;
23623
23645
  });
23624
23646
  var dashboardFiltersFromDataSets = fromDashboardRequiredFilterGroups(state.dashboard.dataSets);
23625
- var dataSetsInUse = getDataSetsUsedOnDashboard(state.dashboard);
23626
- var programmaticallyManagedDashboardFilters = dashboardFilters(dataSetsInUse, EMPTY_USER_DEFINED_DASHBOARD_FILTERS).map(function (f) {
23647
+ var programmaticallyManagedDashboardFilters = dashboardFilters(state.dashboard.dataSets, EMPTY_USER_DEFINED_DASHBOARD_FILTERS).map(function (f) {
23627
23648
  return _extends({}, f, {
23628
23649
  managedByConfiguration: true
23629
23650
  });
@@ -44123,6 +44144,10 @@ function _EMOTION_STRINGIFIED_CSS_ERROR__$5() { return "You have tried to string
44123
44144
  var MIN_TOOLTIP_WIDTH = 180;
44124
44145
  var TOOLTIP_OFFSET = 20;
44125
44146
  var SCROLLBAR_WIDTH = 40;
44147
+ var getTooltipValue = function getTooltipValue(tooltipData, yKey) {
44148
+ var data = tooltipData[yKey];
44149
+ return (data == null ? void 0 : data.formattedValue) || (data == null ? void 0 : data.value) || '';
44150
+ };
44126
44151
  var Tooltip$1 = function Tooltip(_ref) {
44127
44152
  var _tooltipData$xKey$for, _tooltipData$xKey;
44128
44153
  var keys = _ref.keys,
@@ -44184,7 +44209,7 @@ var Tooltip$1 = function Tooltip(_ref) {
44184
44209
  fontSize: '15px',
44185
44210
  width: '100%',
44186
44211
  minWidth: MIN_TOOLTIP_WIDTH
44187
- }, ";label:Tooltip;", "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Tooltip.tsx"],"names":[],"mappings":"AA6FqB","file":"Tooltip.tsx","sourcesContent":["import React, { CSSProperties, Fragment, useEffect, useRef, useState } from 'react';\nimport { createPortal } from 'react-dom';\n\nimport { getColor } from '../../utils';\nimport { LegendItemBox } from '../Legend/LegendItemBox';\nimport { ShapeDefinition, ConditionalFormattingRule, DataItem, Key } from 'shared-logic/src/ChartsV2/types';\nimport { LineStyles } from 'shared-logic/src/LineChartV2/types';\nimport { BarStyles } from 'shared-logic/src/BarChartV2/types';\nimport { AreaStyles } from 'shared-logic/src/AreaChartV2/types';\nimport { BubbleStyles } from 'shared-logic/src/BubbleChartV2/types';\nimport { css } from '@emotion/css';\n\nconst MIN_TOOLTIP_WIDTH = 180;\nconst TOOLTIP_OFFSET = 20;\nconst SCROLLBAR_WIDTH = 40;\n\ninterface TooltipProps<T> {\n  keys: { [key: string]: Key };\n  showRoundedTotal: boolean;\n  tooltipData: {\n    [keyId: string]: DataItem;\n  };\n  tooltipLeft: number;\n  tooltipTop: number;\n  xKey: string;\n  yKeys?: string[];\n  items: {\n    legendItems: Array<ShapeDefinition<T>>;\n    conditionalFormattingRules: Array<ConditionalFormattingRule>;\n    visibleYKeys: string[];\n  }[];\n  theme: CSSProperties;\n  shouldShowColorLegend?: boolean;\n}\n\nexport const Tooltip = ({\n  keys,\n  showRoundedTotal,\n  tooltipData,\n  tooltipLeft,\n  tooltipTop,\n  xKey,\n  yKeys,\n  theme,\n  items,\n  shouldShowColorLegend = true,\n}: TooltipProps<LineStyles | BarStyles | AreaStyles | BubbleStyles>) => {\n  const tooltipRef = useRef<HTMLDivElement>(null);\n  const [position, setPosition] = useState<{ left: number }>({\n    left: tooltipLeft,\n  });\n\n  useEffect(() => {\n    const adjustTooltipPosition = () => {\n      const tooltipElement = tooltipRef.current;\n\n      if (tooltipElement) {\n        const screenWidth = window.innerWidth;\n\n        const rect = tooltipElement.getBoundingClientRect();\n\n        let width = rect.width;\n\n        if (width < MIN_TOOLTIP_WIDTH) {\n          width = MIN_TOOLTIP_WIDTH;\n        }\n\n        let left = tooltipLeft + TOOLTIP_OFFSET;\n\n        if (tooltipLeft + width > screenWidth - SCROLLBAR_WIDTH) {\n          left = tooltipLeft - width - TOOLTIP_OFFSET;\n        }\n\n        setPosition({ left });\n      }\n    };\n\n    adjustTooltipPosition();\n  }, [tooltipLeft]);\n\n  return createPortal(\n    <div\n      ref={tooltipRef}\n      style={{\n        position: 'absolute',\n        left: position.left,\n        top: tooltipTop,\n        zIndex: 2147483647 * 10,\n        ...theme,\n      }}\n    >\n      <div style={{ wordBreak: 'break-all' }}>\n        <div\n          className={css({\n            fontFamily: 'inherit',\n            lineHeight: 'inherit',\n            letterSpacing: 'inherit',\n            fontWeight: 'bold',\n            fontSize: '15px',\n            width: '100%',\n            minWidth: MIN_TOOLTIP_WIDTH,\n          })}\n        >\n          {tooltipData[xKey]?.formattedValue ?? tooltipData[xKey].value}\n        </div>\n        <table\n          cellPadding={0}\n          cellSpacing={0}\n          className={css({\n            margin: '0',\n            borderSpacing: '0',\n            borderCollapse: 'inherit',\n            border: 'none',\n          })}\n        >\n          <tbody>\n            {items.map((item, index) => {\n              return (\n                <Fragment key={index}>\n                  {item.legendItems?.map((legendItem, index) => {\n                    if (!tooltipData[legendItem.yKey] || tooltipData[legendItem.yKey].value === null) {\n                      // yKey could not be found in tooltipData\n                      return null;\n                    }\n                    return (\n                      item.visibleYKeys?.includes(legendItem.yKey) && (\n                        <tr key={`${legendItem.yKey}-${index}-${tooltipData[legendItem.yKey].value}`}>\n                          {shouldShowColorLegend && (\n                            <td\n                              style={{\n                                verticalAlign: 'middle',\n                                padding: index === 0 ? '12px 8px 0 0' : '8px 8px 0 0',\n                                width: 'auto',\n                              }}\n                            >\n                              <LegendItemBox\n                                color={getColor({\n                                  defaultColor: legendItem.color,\n                                  value: tooltipData[legendItem.yKey].value,\n                                  yKey: legendItem.yKey,\n                                  conditionalFormattingRules: item.conditionalFormattingRules ?? [],\n                                })}\n                                style={legendItem.style as LineStyles}\n                                yKey={legendItem.yKey}\n                              />\n                            </td>\n                          )}\n                          <td style={{ padding: '8px 0 0 0' }}>{keys[legendItem.yKey].keyFormatted}</td>\n                          <td style={{ fontWeight: 'bold', padding: '8px 0 0 16px' }}>\n                            {tooltipData[legendItem.yKey].formattedValue\n                              ? tooltipData[legendItem.yKey].formattedValue\n                              : tooltipData[legendItem.yKey].value}\n                          </td>\n                        </tr>\n                      )\n                    );\n                  })}\n                </Fragment>\n              );\n            })}\n\n            {showRoundedTotal && yKeys && (\n              <tr>\n                <td colSpan={2} style={{ padding: '12px 0 0 0' }}>\n                  Rounded Total\n                </td>\n                <td style={{ fontWeight: 'bold', padding: '12px 0 0 16px' }}>\n                  {yKeys.reduce((total, key) => {\n                    return total + Math.round(tooltipData[key].value as number);\n                  }, 0)}\n                </td>\n              </tr>\n            )}\n          </tbody>\n        </table>\n      </div>\n    </div>,\n    document.body,\n  );\n};\n"]} */"),
44212
+ }, ";label:Tooltip;", "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Tooltip.tsx"],"names":[],"mappings":"AAkGqB","file":"Tooltip.tsx","sourcesContent":["import React, { CSSProperties, Fragment, useEffect, useRef, useState } from 'react';\nimport { createPortal } from 'react-dom';\n\nimport { getColor } from '../../utils';\nimport { LegendItemBox } from '../Legend/LegendItemBox';\nimport { ShapeDefinition, ConditionalFormattingRule, DataItem, Key } from 'shared-logic/src/ChartsV2/types';\nimport { LineStyles } from 'shared-logic/src/LineChartV2/types';\nimport { BarStyles } from 'shared-logic/src/BarChartV2/types';\nimport { AreaStyles } from 'shared-logic/src/AreaChartV2/types';\nimport { BubbleStyles } from 'shared-logic/src/BubbleChartV2/types';\nimport { css } from '@emotion/css';\n\nconst MIN_TOOLTIP_WIDTH = 180;\nconst TOOLTIP_OFFSET = 20;\nconst SCROLLBAR_WIDTH = 40;\n\nconst getTooltipValue = (tooltipData: { [keyId: string]: DataItem }, yKey: string): string | number => {\n  const data = tooltipData[yKey];\n  return data?.formattedValue || data?.value || '';\n};\n\ninterface TooltipProps<T> {\n  keys: { [key: string]: Key };\n  showRoundedTotal: boolean;\n  tooltipData: {\n    [keyId: string]: DataItem;\n  };\n  tooltipLeft: number;\n  tooltipTop: number;\n  xKey: string;\n  yKeys?: string[];\n  items: {\n    legendItems: Array<ShapeDefinition<T>>;\n    conditionalFormattingRules: Array<ConditionalFormattingRule>;\n    visibleYKeys: string[];\n  }[];\n  theme: CSSProperties;\n  shouldShowColorLegend?: boolean;\n}\n\nexport const Tooltip = ({\n  keys,\n  showRoundedTotal,\n  tooltipData,\n  tooltipLeft,\n  tooltipTop,\n  xKey,\n  yKeys,\n  theme,\n  items,\n  shouldShowColorLegend = true,\n}: TooltipProps<LineStyles | BarStyles | AreaStyles | BubbleStyles>) => {\n  const tooltipRef = useRef<HTMLDivElement>(null);\n  const [position, setPosition] = useState<{ left: number }>({\n    left: tooltipLeft,\n  });\n\n  useEffect(() => {\n    const adjustTooltipPosition = () => {\n      const tooltipElement = tooltipRef.current;\n\n      if (tooltipElement) {\n        const screenWidth = window.innerWidth;\n\n        const rect = tooltipElement.getBoundingClientRect();\n\n        let width = rect.width;\n\n        if (width < MIN_TOOLTIP_WIDTH) {\n          width = MIN_TOOLTIP_WIDTH;\n        }\n\n        let left = tooltipLeft + TOOLTIP_OFFSET;\n\n        if (tooltipLeft + width > screenWidth - SCROLLBAR_WIDTH) {\n          left = tooltipLeft - width - TOOLTIP_OFFSET;\n        }\n\n        setPosition({ left });\n      }\n    };\n\n    adjustTooltipPosition();\n  }, [tooltipLeft]);\n\n  return createPortal(\n    <div\n      ref={tooltipRef}\n      style={{\n        position: 'absolute',\n        left: position.left,\n        top: tooltipTop,\n        zIndex: 2147483647 * 10,\n        ...theme,\n      }}\n    >\n      <div style={{ wordBreak: 'break-all' }}>\n        <div\n          className={css({\n            fontFamily: 'inherit',\n            lineHeight: 'inherit',\n            letterSpacing: 'inherit',\n            fontWeight: 'bold',\n            fontSize: '15px',\n            width: '100%',\n            minWidth: MIN_TOOLTIP_WIDTH,\n          })}\n        >\n          {tooltipData[xKey]?.formattedValue ?? tooltipData[xKey].value}\n        </div>\n        <table\n          cellPadding={0}\n          cellSpacing={0}\n          className={css({\n            margin: '0',\n            borderSpacing: '0',\n            borderCollapse: 'inherit',\n            border: 'none',\n          })}\n        >\n          <tbody>\n            {items.map((item, index) => {\n              return (\n                <Fragment key={index}>\n                  {item.legendItems?.map((legendItem, index) => {\n                    if (!tooltipData[legendItem.yKey] || tooltipData[legendItem.yKey].value === null) {\n                      // yKey could not be found in tooltipData\n                      return null;\n                    }\n                    return (\n                      item.visibleYKeys?.includes(legendItem.yKey) && (\n                        <tr key={`${legendItem.yKey}-${index}-${tooltipData[legendItem.yKey].value}`}>\n                          {shouldShowColorLegend && (\n                            <td\n                              style={{\n                                verticalAlign: 'middle',\n                                padding: index === 0 ? '12px 8px 0 0' : '8px 8px 0 0',\n                                width: 'auto',\n                              }}\n                            >\n                              <LegendItemBox\n                                color={getColor({\n                                  defaultColor: legendItem.color,\n                                  value: tooltipData[legendItem.yKey].value,\n                                  yKey: legendItem.yKey,\n                                  conditionalFormattingRules: item.conditionalFormattingRules ?? [],\n                                })}\n                                style={legendItem.style as LineStyles}\n                                yKey={legendItem.yKey}\n                              />\n                            </td>\n                          )}\n                          <td style={{ padding: '8px 0 0 0' }}>{keys[legendItem.yKey].keyFormatted}</td>\n                          <td style={{ fontWeight: 'bold', padding: '8px 0 0 16px' }}>\n                            {getTooltipValue(tooltipData, legendItem.yKey)}\n                          </td>\n                        </tr>\n                      )\n                    );\n                  })}\n                </Fragment>\n              );\n            })}\n\n            {showRoundedTotal && yKeys && (\n              <tr>\n                <td colSpan={2} style={{ padding: '12px 0 0 0' }}>\n                  Rounded Total\n                </td>\n                <td style={{ fontWeight: 'bold', padding: '12px 0 0 16px' }}>\n                  {yKeys.reduce((total, key) => {\n                    return total + Math.round(tooltipData[key].value as number);\n                  }, 0)}\n                </td>\n              </tr>\n            )}\n          </tbody>\n        </table>\n      </div>\n    </div>,\n    document.body,\n  );\n};\n"]} */"),
44188
44213
  children: (_tooltipData$xKey$for = (_tooltipData$xKey = tooltipData[xKey]) == null ? void 0 : _tooltipData$xKey.formattedValue) != null ? _tooltipData$xKey$for : tooltipData[xKey].value
44189
44214
  }), jsxRuntime.jsx("table", {
44190
44215
  cellPadding: 0,
@@ -44192,7 +44217,7 @@ var Tooltip$1 = function Tooltip(_ref) {
44192
44217
  className: /*#__PURE__*/css$1.css( {
44193
44218
  name: "9a1sa-Tooltip",
44194
44219
  styles: "margin:0;border-spacing:0;border-collapse:inherit;border:none;label:Tooltip;",
44195
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Tooltip.tsx"],"names":[],"mappings":"AA4GqB","file":"Tooltip.tsx","sourcesContent":["import React, { CSSProperties, Fragment, useEffect, useRef, useState } from 'react';\nimport { createPortal } from 'react-dom';\n\nimport { getColor } from '../../utils';\nimport { LegendItemBox } from '../Legend/LegendItemBox';\nimport { ShapeDefinition, ConditionalFormattingRule, DataItem, Key } from 'shared-logic/src/ChartsV2/types';\nimport { LineStyles } from 'shared-logic/src/LineChartV2/types';\nimport { BarStyles } from 'shared-logic/src/BarChartV2/types';\nimport { AreaStyles } from 'shared-logic/src/AreaChartV2/types';\nimport { BubbleStyles } from 'shared-logic/src/BubbleChartV2/types';\nimport { css } from '@emotion/css';\n\nconst MIN_TOOLTIP_WIDTH = 180;\nconst TOOLTIP_OFFSET = 20;\nconst SCROLLBAR_WIDTH = 40;\n\ninterface TooltipProps<T> {\n  keys: { [key: string]: Key };\n  showRoundedTotal: boolean;\n  tooltipData: {\n    [keyId: string]: DataItem;\n  };\n  tooltipLeft: number;\n  tooltipTop: number;\n  xKey: string;\n  yKeys?: string[];\n  items: {\n    legendItems: Array<ShapeDefinition<T>>;\n    conditionalFormattingRules: Array<ConditionalFormattingRule>;\n    visibleYKeys: string[];\n  }[];\n  theme: CSSProperties;\n  shouldShowColorLegend?: boolean;\n}\n\nexport const Tooltip = ({\n  keys,\n  showRoundedTotal,\n  tooltipData,\n  tooltipLeft,\n  tooltipTop,\n  xKey,\n  yKeys,\n  theme,\n  items,\n  shouldShowColorLegend = true,\n}: TooltipProps<LineStyles | BarStyles | AreaStyles | BubbleStyles>) => {\n  const tooltipRef = useRef<HTMLDivElement>(null);\n  const [position, setPosition] = useState<{ left: number }>({\n    left: tooltipLeft,\n  });\n\n  useEffect(() => {\n    const adjustTooltipPosition = () => {\n      const tooltipElement = tooltipRef.current;\n\n      if (tooltipElement) {\n        const screenWidth = window.innerWidth;\n\n        const rect = tooltipElement.getBoundingClientRect();\n\n        let width = rect.width;\n\n        if (width < MIN_TOOLTIP_WIDTH) {\n          width = MIN_TOOLTIP_WIDTH;\n        }\n\n        let left = tooltipLeft + TOOLTIP_OFFSET;\n\n        if (tooltipLeft + width > screenWidth - SCROLLBAR_WIDTH) {\n          left = tooltipLeft - width - TOOLTIP_OFFSET;\n        }\n\n        setPosition({ left });\n      }\n    };\n\n    adjustTooltipPosition();\n  }, [tooltipLeft]);\n\n  return createPortal(\n    <div\n      ref={tooltipRef}\n      style={{\n        position: 'absolute',\n        left: position.left,\n        top: tooltipTop,\n        zIndex: 2147483647 * 10,\n        ...theme,\n      }}\n    >\n      <div style={{ wordBreak: 'break-all' }}>\n        <div\n          className={css({\n            fontFamily: 'inherit',\n            lineHeight: 'inherit',\n            letterSpacing: 'inherit',\n            fontWeight: 'bold',\n            fontSize: '15px',\n            width: '100%',\n            minWidth: MIN_TOOLTIP_WIDTH,\n          })}\n        >\n          {tooltipData[xKey]?.formattedValue ?? tooltipData[xKey].value}\n        </div>\n        <table\n          cellPadding={0}\n          cellSpacing={0}\n          className={css({\n            margin: '0',\n            borderSpacing: '0',\n            borderCollapse: 'inherit',\n            border: 'none',\n          })}\n        >\n          <tbody>\n            {items.map((item, index) => {\n              return (\n                <Fragment key={index}>\n                  {item.legendItems?.map((legendItem, index) => {\n                    if (!tooltipData[legendItem.yKey] || tooltipData[legendItem.yKey].value === null) {\n                      // yKey could not be found in tooltipData\n                      return null;\n                    }\n                    return (\n                      item.visibleYKeys?.includes(legendItem.yKey) && (\n                        <tr key={`${legendItem.yKey}-${index}-${tooltipData[legendItem.yKey].value}`}>\n                          {shouldShowColorLegend && (\n                            <td\n                              style={{\n                                verticalAlign: 'middle',\n                                padding: index === 0 ? '12px 8px 0 0' : '8px 8px 0 0',\n                                width: 'auto',\n                              }}\n                            >\n                              <LegendItemBox\n                                color={getColor({\n                                  defaultColor: legendItem.color,\n                                  value: tooltipData[legendItem.yKey].value,\n                                  yKey: legendItem.yKey,\n                                  conditionalFormattingRules: item.conditionalFormattingRules ?? [],\n                                })}\n                                style={legendItem.style as LineStyles}\n                                yKey={legendItem.yKey}\n                              />\n                            </td>\n                          )}\n                          <td style={{ padding: '8px 0 0 0' }}>{keys[legendItem.yKey].keyFormatted}</td>\n                          <td style={{ fontWeight: 'bold', padding: '8px 0 0 16px' }}>\n                            {tooltipData[legendItem.yKey].formattedValue\n                              ? tooltipData[legendItem.yKey].formattedValue\n                              : tooltipData[legendItem.yKey].value}\n                          </td>\n                        </tr>\n                      )\n                    );\n                  })}\n                </Fragment>\n              );\n            })}\n\n            {showRoundedTotal && yKeys && (\n              <tr>\n                <td colSpan={2} style={{ padding: '12px 0 0 0' }}>\n                  Rounded Total\n                </td>\n                <td style={{ fontWeight: 'bold', padding: '12px 0 0 16px' }}>\n                  {yKeys.reduce((total, key) => {\n                    return total + Math.round(tooltipData[key].value as number);\n                  }, 0)}\n                </td>\n              </tr>\n            )}\n          </tbody>\n        </table>\n      </div>\n    </div>,\n    document.body,\n  );\n};\n"]} */",
44220
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Tooltip.tsx"],"names":[],"mappings":"AAiHqB","file":"Tooltip.tsx","sourcesContent":["import React, { CSSProperties, Fragment, useEffect, useRef, useState } from 'react';\nimport { createPortal } from 'react-dom';\n\nimport { getColor } from '../../utils';\nimport { LegendItemBox } from '../Legend/LegendItemBox';\nimport { ShapeDefinition, ConditionalFormattingRule, DataItem, Key } from 'shared-logic/src/ChartsV2/types';\nimport { LineStyles } from 'shared-logic/src/LineChartV2/types';\nimport { BarStyles } from 'shared-logic/src/BarChartV2/types';\nimport { AreaStyles } from 'shared-logic/src/AreaChartV2/types';\nimport { BubbleStyles } from 'shared-logic/src/BubbleChartV2/types';\nimport { css } from '@emotion/css';\n\nconst MIN_TOOLTIP_WIDTH = 180;\nconst TOOLTIP_OFFSET = 20;\nconst SCROLLBAR_WIDTH = 40;\n\nconst getTooltipValue = (tooltipData: { [keyId: string]: DataItem }, yKey: string): string | number => {\n  const data = tooltipData[yKey];\n  return data?.formattedValue || data?.value || '';\n};\n\ninterface TooltipProps<T> {\n  keys: { [key: string]: Key };\n  showRoundedTotal: boolean;\n  tooltipData: {\n    [keyId: string]: DataItem;\n  };\n  tooltipLeft: number;\n  tooltipTop: number;\n  xKey: string;\n  yKeys?: string[];\n  items: {\n    legendItems: Array<ShapeDefinition<T>>;\n    conditionalFormattingRules: Array<ConditionalFormattingRule>;\n    visibleYKeys: string[];\n  }[];\n  theme: CSSProperties;\n  shouldShowColorLegend?: boolean;\n}\n\nexport const Tooltip = ({\n  keys,\n  showRoundedTotal,\n  tooltipData,\n  tooltipLeft,\n  tooltipTop,\n  xKey,\n  yKeys,\n  theme,\n  items,\n  shouldShowColorLegend = true,\n}: TooltipProps<LineStyles | BarStyles | AreaStyles | BubbleStyles>) => {\n  const tooltipRef = useRef<HTMLDivElement>(null);\n  const [position, setPosition] = useState<{ left: number }>({\n    left: tooltipLeft,\n  });\n\n  useEffect(() => {\n    const adjustTooltipPosition = () => {\n      const tooltipElement = tooltipRef.current;\n\n      if (tooltipElement) {\n        const screenWidth = window.innerWidth;\n\n        const rect = tooltipElement.getBoundingClientRect();\n\n        let width = rect.width;\n\n        if (width < MIN_TOOLTIP_WIDTH) {\n          width = MIN_TOOLTIP_WIDTH;\n        }\n\n        let left = tooltipLeft + TOOLTIP_OFFSET;\n\n        if (tooltipLeft + width > screenWidth - SCROLLBAR_WIDTH) {\n          left = tooltipLeft - width - TOOLTIP_OFFSET;\n        }\n\n        setPosition({ left });\n      }\n    };\n\n    adjustTooltipPosition();\n  }, [tooltipLeft]);\n\n  return createPortal(\n    <div\n      ref={tooltipRef}\n      style={{\n        position: 'absolute',\n        left: position.left,\n        top: tooltipTop,\n        zIndex: 2147483647 * 10,\n        ...theme,\n      }}\n    >\n      <div style={{ wordBreak: 'break-all' }}>\n        <div\n          className={css({\n            fontFamily: 'inherit',\n            lineHeight: 'inherit',\n            letterSpacing: 'inherit',\n            fontWeight: 'bold',\n            fontSize: '15px',\n            width: '100%',\n            minWidth: MIN_TOOLTIP_WIDTH,\n          })}\n        >\n          {tooltipData[xKey]?.formattedValue ?? tooltipData[xKey].value}\n        </div>\n        <table\n          cellPadding={0}\n          cellSpacing={0}\n          className={css({\n            margin: '0',\n            borderSpacing: '0',\n            borderCollapse: 'inherit',\n            border: 'none',\n          })}\n        >\n          <tbody>\n            {items.map((item, index) => {\n              return (\n                <Fragment key={index}>\n                  {item.legendItems?.map((legendItem, index) => {\n                    if (!tooltipData[legendItem.yKey] || tooltipData[legendItem.yKey].value === null) {\n                      // yKey could not be found in tooltipData\n                      return null;\n                    }\n                    return (\n                      item.visibleYKeys?.includes(legendItem.yKey) && (\n                        <tr key={`${legendItem.yKey}-${index}-${tooltipData[legendItem.yKey].value}`}>\n                          {shouldShowColorLegend && (\n                            <td\n                              style={{\n                                verticalAlign: 'middle',\n                                padding: index === 0 ? '12px 8px 0 0' : '8px 8px 0 0',\n                                width: 'auto',\n                              }}\n                            >\n                              <LegendItemBox\n                                color={getColor({\n                                  defaultColor: legendItem.color,\n                                  value: tooltipData[legendItem.yKey].value,\n                                  yKey: legendItem.yKey,\n                                  conditionalFormattingRules: item.conditionalFormattingRules ?? [],\n                                })}\n                                style={legendItem.style as LineStyles}\n                                yKey={legendItem.yKey}\n                              />\n                            </td>\n                          )}\n                          <td style={{ padding: '8px 0 0 0' }}>{keys[legendItem.yKey].keyFormatted}</td>\n                          <td style={{ fontWeight: 'bold', padding: '8px 0 0 16px' }}>\n                            {getTooltipValue(tooltipData, legendItem.yKey)}\n                          </td>\n                        </tr>\n                      )\n                    );\n                  })}\n                </Fragment>\n              );\n            })}\n\n            {showRoundedTotal && yKeys && (\n              <tr>\n                <td colSpan={2} style={{ padding: '12px 0 0 0' }}>\n                  Rounded Total\n                </td>\n                <td style={{ fontWeight: 'bold', padding: '12px 0 0 16px' }}>\n                  {yKeys.reduce((total, key) => {\n                    return total + Math.round(tooltipData[key].value as number);\n                  }, 0)}\n                </td>\n              </tr>\n            )}\n          </tbody>\n        </table>\n      </div>\n    </div>,\n    document.body,\n  );\n};\n"]} */",
44196
44221
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$5
44197
44222
  }),
44198
44223
  children: jsxRuntime.jsxs("tbody", {
@@ -44232,7 +44257,7 @@ var Tooltip$1 = function Tooltip(_ref) {
44232
44257
  fontWeight: 'bold',
44233
44258
  padding: '8px 0 0 16px'
44234
44259
  },
44235
- children: tooltipData[legendItem.yKey].formattedValue ? tooltipData[legendItem.yKey].formattedValue : tooltipData[legendItem.yKey].value
44260
+ children: getTooltipValue(tooltipData, legendItem.yKey)
44236
44261
  })]
44237
44262
  }, legendItem.yKey + "-" + index + "-" + tooltipData[legendItem.yKey].value);
44238
44263
  })
@@ -45543,6 +45568,36 @@ function Area(_ref4) {
45543
45568
  });
45544
45569
  }
45545
45570
 
45571
+ function convertToStackedPercentages(data, yKeys, xKey) {
45572
+ if (!xKey || yKeys.length === 0) {
45573
+ return data;
45574
+ }
45575
+ return data.map(function (item) {
45576
+ var convertedItem = _extends({}, item);
45577
+ var total = 0;
45578
+ yKeys.forEach(function (key) {
45579
+ var _item$key;
45580
+ var value = Number((_item$key = item[key]) == null ? void 0 : _item$key.value) || 0;
45581
+ total += value;
45582
+ });
45583
+ if (total === 0) {
45584
+ return convertedItem;
45585
+ }
45586
+ yKeys.forEach(function (key) {
45587
+ if (item[key]) {
45588
+ var value = Number(item[key].value) || 0;
45589
+ var percentage = value / total * 100;
45590
+ convertedItem[key] = _extends({}, item[key], {
45591
+ value: percentage / 100,
45592
+ originalValue: item[key].value,
45593
+ formattedValue: "" + percentage.toFixed(1)
45594
+ });
45595
+ }
45596
+ });
45597
+ return convertedItem;
45598
+ });
45599
+ }
45600
+
45546
45601
  var BAR_RADIUS = 2;
45547
45602
 
45548
45603
  function getBarFill(bars, conditionalFormattingRules, barKey, barValues) {
@@ -45973,8 +46028,14 @@ var BarChart$5 = function BarChart(_ref) {
45973
46028
  var xKey = chart.x.key;
45974
46029
  var xScaleKey = chart.x.scale.key;
45975
46030
  var xScaleDataType = chart.x.scale.dataType;
45976
- var xScale = useBarXScale(xScaleDataType, innerWidth, xScaleKey, chart.data);
45977
46031
  var yScaleKeys = chart.y.keys;
46032
+ var processedData = React.useMemo(function () {
46033
+ if (isStacked100) {
46034
+ return convertToStackedPercentages(chart.data, chart.y.keys, xKey);
46035
+ }
46036
+ return chart.data;
46037
+ }, [isStacked100, chart.data, chart.y.keys, xKey]);
46038
+ var xScale = useBarXScale(xScaleDataType, innerWidth, xScaleKey, processedData);
45978
46039
  var defaultYScale = useYScale(innerHeight, chart.y.scale);
45979
46040
  var yScale = React.useMemo(function () {
45980
46041
  if (isStacked100) {
@@ -45987,9 +46048,54 @@ var BarChart$5 = function BarChart(_ref) {
45987
46048
  }
45988
46049
  return defaultYScale;
45989
46050
  }, [innerHeight, defaultYScale, options.stacked]);
45990
- var yTickValues = chart.y.ticks.map(function (tick) {
45991
- return Number(tick.value);
45992
- });
46051
+ var yTickValues = React.useMemo(function () {
46052
+ if (isStacked100) {
46053
+ return [0, 0.2, 0.4, 0.6, 0.8, 1];
46054
+ }
46055
+ return chart.y.ticks.map(function (tick) {
46056
+ return Number(tick.value);
46057
+ });
46058
+ }, [isStacked100, chart.y.ticks]);
46059
+ var yAxisConfig = React.useMemo(function () {
46060
+ if (isStacked100) {
46061
+ return _extends({}, chart.y, {
46062
+ ticks: [{
46063
+ value: 0,
46064
+ formattedValue: '0',
46065
+ scaleValue: 0
46066
+ }, {
46067
+ value: 0.2,
46068
+ formattedValue: '20',
46069
+ scaleValue: 0.2
46070
+ }, {
46071
+ value: 0.4,
46072
+ formattedValue: '40',
46073
+ scaleValue: 0.4
46074
+ }, {
46075
+ value: 0.6,
46076
+ formattedValue: '60',
46077
+ scaleValue: 0.6
46078
+ }, {
46079
+ value: 0.8,
46080
+ formattedValue: '80',
46081
+ scaleValue: 0.8
46082
+ }, {
46083
+ value: 1,
46084
+ formattedValue: '100',
46085
+ scaleValue: 1
46086
+ }]
46087
+ });
46088
+ }
46089
+ return chart.y;
46090
+ }, [isStacked100, chart.y]);
46091
+ var xAxisConfig = React.useMemo(function () {
46092
+ if (isStacked100) {
46093
+ return _extends({}, chart.x, {
46094
+ ticks: chart.x.ticks
46095
+ });
46096
+ }
46097
+ return chart.x;
46098
+ }, [isStacked100, chart.x]);
45993
46099
  var yAxisLabels = chart.bars.map(function (legendItem) {
45994
46100
  var _chart$keys$legendIte, _chart$keys$legendIte2;
45995
46101
  return (_chart$keys$legendIte = (_chart$keys$legendIte2 = chart.keys[legendItem.yKey]) == null ? void 0 : _chart$keys$legendIte2.keyFormatted) != null ? _chart$keys$legendIte : '';
@@ -46005,7 +46111,7 @@ var BarChart$5 = function BarChart(_ref) {
46005
46111
  }
46006
46112
  return undefined;
46007
46113
  }, [xScale, yScaleKeys, options.stacked]);
46008
- var dataFlattened = useFlattenedData(xScaleKey, xScaleDataType, chart.data, chart.y.keys);
46114
+ var dataFlattened = useFlattenedData(xScaleKey, xScaleDataType, processedData, chart.y.keys);
46009
46115
  var themeCSS = React.useMemo(function () {
46010
46116
  return getChartThemeCSS(theme);
46011
46117
  }, [theme]);
@@ -46019,7 +46125,7 @@ var BarChart$5 = function BarChart(_ref) {
46019
46125
  var handleMouseMove = React.useCallback(function (event) {
46020
46126
  if (!xKey || !xScaleKey || xScale === null) return;
46021
46127
  var tooltipData = getTooltipData({
46022
- data: chart.data,
46128
+ data: processedData,
46023
46129
  event: event,
46024
46130
  margin: margin,
46025
46131
  xScaleKey: xScaleKey,
@@ -46034,12 +46140,12 @@ var BarChart$5 = function BarChart(_ref) {
46034
46140
  tooltipTop: event.pageY,
46035
46141
  tooltipData: tooltipData == null ? void 0 : tooltipData.tooltipData
46036
46142
  });
46037
- }, [showTooltip, xScale, margin, xKey, xScaleKey, xScaleDataType, chart.x.scale.ordering, chart.data]);
46143
+ }, [showTooltip, xScale, margin, xKey, xScaleKey, xScaleDataType, chart.x.scale.ordering, processedData, isStacked100]);
46038
46144
  var handleMouseLeave = React.useCallback(function () {
46039
46145
  hideTooltip();
46040
46146
  }, [hideTooltip]);
46041
46147
  var handleOnBarClick = React.useCallback(function (event, barGroup, bar) {
46042
- var _chart$data$barGroup$;
46148
+ var _processedData$barGro;
46043
46149
  onClick == null || onClick({
46044
46150
  clickedValue: {
46045
46151
  index: barGroup.index,
@@ -46048,16 +46154,16 @@ var BarChart$5 = function BarChart(_ref) {
46048
46154
  value: bar.value
46049
46155
  },
46050
46156
  x: _extends({}, chart.x.ticks[barGroup.index], {
46051
- value: (_chart$data$barGroup$ = chart.data[barGroup.index][xKey].value) != null ? _chart$data$barGroup$ : '',
46157
+ value: (_processedData$barGro = processedData[barGroup.index][xKey].value) != null ? _processedData$barGro : '',
46052
46158
  key: xKey
46053
46159
  })
46054
46160
  },
46055
46161
  clickEvent: event
46056
46162
  });
46057
- }, [onClick, chart.data, xKey]);
46163
+ }, [onClick, processedData, xKey]);
46058
46164
  var formattedLabelsDict = React.useMemo(function () {
46059
- return getLabelDictionary(chart.data, yScaleKeys);
46060
- }, [chart.data, yScaleKeys]);
46165
+ return getLabelDictionary(processedData, yScaleKeys);
46166
+ }, [processedData, yScaleKeys]);
46061
46167
  return jsxRuntime.jsxs(React.Fragment, {
46062
46168
  children: [jsxRuntime.jsxs(ChartWrapper$1, {
46063
46169
  width: width,
@@ -46076,7 +46182,7 @@ var BarChart$5 = function BarChart(_ref) {
46076
46182
  removeStroke: options.removeStroke,
46077
46183
  themeCSS: themeCSS
46078
46184
  }), jsxRuntime.jsx(AxisBottom, {
46079
- x: chart.x,
46185
+ x: xAxisConfig,
46080
46186
  margin: margin,
46081
46187
  themeCSS: themeCSS,
46082
46188
  show: options.axis.showXAxisLabels,
@@ -46087,7 +46193,7 @@ var BarChart$5 = function BarChart(_ref) {
46087
46193
  baselineShift: groupingAxisBaselineShift
46088
46194
  }), jsxRuntime.jsx(AxisLeft, {
46089
46195
  show: options.axis.showYAxisLabels,
46090
- y: chart.y,
46196
+ y: yAxisConfig,
46091
46197
  margin: margin,
46092
46198
  themeCSS: themeCSS,
46093
46199
  yScale: yScale,
@@ -46952,7 +47058,9 @@ var HorizontalBarChart$3 = function HorizontalBarChart(_ref) {
46952
47058
  theme = _ref.theme,
46953
47059
  onClick = _ref.onClick,
46954
47060
  enableHover = _ref.enableHover,
46955
- numberOfDimensions = _ref.numberOfDimensions;
47061
+ numberOfDimensions = _ref.numberOfDimensions,
47062
+ formatXAxisLabel = _ref.formatXAxisLabel,
47063
+ formatYAxisLabel = _ref.formatYAxisLabel;
46956
47064
  var _useTooltip = useTooltip$1(),
46957
47065
  tooltipOpen = _useTooltip.tooltipOpen,
46958
47066
  _useTooltip$tooltipLe = _useTooltip.tooltipLeft,
@@ -46994,9 +47102,46 @@ var HorizontalBarChart$3 = function HorizontalBarChart(_ref) {
46994
47102
  return defaultXScale;
46995
47103
  }, [innerWidth, defaultXScale, groupingAxisBaselineShift, options.stacked]);
46996
47104
  var barGroupXScale = useHorizontalBarXScale(innerWidth, chart.x.scale, 0);
46997
- var xTickValues = chart.x.ticks.map(function (tick) {
46998
- return Number(tick.value);
46999
- });
47105
+ var xTickValues = React.useMemo(function () {
47106
+ if (isStacked100) {
47107
+ return [0, 0.2, 0.4, 0.6, 0.8, 1.0];
47108
+ }
47109
+ return chart.x.ticks.map(function (tick) {
47110
+ return Number(tick.value);
47111
+ });
47112
+ }, [isStacked100, chart.x.ticks]);
47113
+ var xAxisConfig = React.useMemo(function () {
47114
+ if (isStacked100) {
47115
+ return _extends({}, chart.x, {
47116
+ ticks: [{
47117
+ value: 0,
47118
+ formattedValue: '0',
47119
+ scaleValue: 0
47120
+ }, {
47121
+ value: 0.2,
47122
+ formattedValue: '20',
47123
+ scaleValue: 0.2
47124
+ }, {
47125
+ value: 0.4,
47126
+ formattedValue: '40',
47127
+ scaleValue: 0.4
47128
+ }, {
47129
+ value: 0.6,
47130
+ formattedValue: '60',
47131
+ scaleValue: 0.6
47132
+ }, {
47133
+ value: 0.8,
47134
+ formattedValue: '80',
47135
+ scaleValue: 0.8
47136
+ }, {
47137
+ value: 1,
47138
+ formattedValue: '100',
47139
+ scaleValue: 1
47140
+ }]
47141
+ });
47142
+ }
47143
+ return chart.x;
47144
+ }, [isStacked100, chart.x]);
47000
47145
  var xAxisLabels = chart.bars.map(function (legendItem) {
47001
47146
  var _chart$keys$legendIte, _chart$keys$legendIte2;
47002
47147
  return (_chart$keys$legendIte = (_chart$keys$legendIte2 = chart.keys[legendItem.yKey]) == null ? void 0 : _chart$keys$legendIte2.keyFormatted) != null ? _chart$keys$legendIte : '';
@@ -47005,7 +47150,13 @@ var HorizontalBarChart$3 = function HorizontalBarChart(_ref) {
47005
47150
  var yKey = chart.y.key;
47006
47151
  var yScaleKey = chart.y.scale.key;
47007
47152
  var yScaleDataType = chart.y.scale.dataType;
47008
- var yScale = useHorizontalBarYScale(yScaleDataType, innerHeight, yScaleKey, chart.data);
47153
+ var processedData = React.useMemo(function () {
47154
+ if (isStacked100) {
47155
+ return convertToStackedPercentages(chart.data, chart.x.keys, yKey);
47156
+ }
47157
+ return chart.data;
47158
+ }, [isStacked100, chart.data, chart.x.keys, yKey]);
47159
+ var yScale = useHorizontalBarYScale(yScaleDataType, innerHeight, yScaleKey, processedData);
47009
47160
  var innerYScale = React.useMemo(function () {
47010
47161
  if (!options.stacked && yScale && 'bandwidth' in yScale) {
47011
47162
  return scale.scaleBand({
@@ -47016,7 +47167,7 @@ var HorizontalBarChart$3 = function HorizontalBarChart(_ref) {
47016
47167
  }
47017
47168
  return undefined;
47018
47169
  }, [xScale, xScaleKeys, options.stacked]);
47019
- var dataFlattened = useFlattenedData(yScaleKey, yScaleDataType, chart.data, chart.x.keys);
47170
+ var dataFlattened = useFlattenedData(yScaleKey, yScaleDataType, processedData, chart.x.keys);
47020
47171
  var themeCSS = React.useMemo(function () {
47021
47172
  return getChartThemeCSS(theme);
47022
47173
  }, [theme]);
@@ -47030,7 +47181,7 @@ var HorizontalBarChart$3 = function HorizontalBarChart(_ref) {
47030
47181
  var handleMouseMove = React.useCallback(function (event) {
47031
47182
  if (!yKey || !yScaleKey || yScale === null) return;
47032
47183
  var tooltipData = getTooltipDataForHorizontalChart({
47033
- data: chart.data,
47184
+ data: processedData,
47034
47185
  event: event,
47035
47186
  margin: margin,
47036
47187
  yScaleKey: yScaleKey,
@@ -47045,12 +47196,12 @@ var HorizontalBarChart$3 = function HorizontalBarChart(_ref) {
47045
47196
  tooltipTop: event.pageY,
47046
47197
  tooltipData: tooltipData == null ? void 0 : tooltipData.tooltipData
47047
47198
  });
47048
- }, [showTooltip, xScale, margin, yKey, yScaleKey, yScaleDataType, chart.x.scale.ordering, chart.data]);
47199
+ }, [showTooltip, xScale, margin, yKey, yScaleKey, yScaleDataType, chart.x.scale.ordering, processedData, isStacked100, xScaleKeys]);
47049
47200
  var handleMouseLeave = React.useCallback(function () {
47050
47201
  hideTooltip();
47051
47202
  }, [hideTooltip]);
47052
47203
  var handleOnBarClick = React.useCallback(function (event, barGroup, bar) {
47053
- var _chart$data$barGroup$;
47204
+ var _processedData$barGro;
47054
47205
  onClick == null || onClick({
47055
47206
  clickedValue: {
47056
47207
  index: barGroup.index,
@@ -47059,22 +47210,29 @@ var HorizontalBarChart$3 = function HorizontalBarChart(_ref) {
47059
47210
  value: bar.value
47060
47211
  },
47061
47212
  y: _extends({}, chart.y.ticks[barGroup.index], {
47062
- value: (_chart$data$barGroup$ = chart.data[barGroup.index][yKey].value) != null ? _chart$data$barGroup$ : '',
47213
+ value: (_processedData$barGro = processedData[barGroup.index][yKey].value) != null ? _processedData$barGro : '',
47063
47214
  key: yKey
47064
47215
  })
47065
47216
  },
47066
47217
  clickEvent: event
47067
47218
  });
47068
- }, [onClick, chart.data, yKey]);
47219
+ }, [onClick, processedData, yKey]);
47069
47220
  var tickXAxisFormat = React.useCallback(function (value) {
47070
- var item = chart.x.ticks.filter(function (tick) {
47221
+ var item = xAxisConfig.ticks.filter(function (tick) {
47071
47222
  return tick.value === value;
47072
47223
  })[0];
47073
47224
  if (!item) {
47074
47225
  return '';
47075
47226
  }
47076
- return item.formattedValue || item.value.toString();
47077
- }, [chart.x.ticks]);
47227
+ var displayValue = item.formattedValue || item.value.toString();
47228
+ if (isStacked100 && !formatXAxisLabel) {
47229
+ displayValue = "" + displayValue;
47230
+ }
47231
+ if (formatXAxisLabel) {
47232
+ return formatXAxisLabel(displayValue);
47233
+ }
47234
+ return displayValue;
47235
+ }, [xAxisConfig.ticks, formatXAxisLabel, isStacked100]);
47078
47236
  var tickYAxisFormat = React.useCallback(function (value) {
47079
47237
  var tick = null;
47080
47238
  if (yScaleDataType === 'date_time' && value instanceof Date) {
@@ -47089,16 +47247,17 @@ var HorizontalBarChart$3 = function HorizontalBarChart(_ref) {
47089
47247
  tick = _matchingTickValue || null;
47090
47248
  }
47091
47249
  if (tick) {
47092
- if (tick.formattedValue) {
47093
- return tick.formattedValue;
47250
+ var displayValue = tick.formattedValue || tick.value.toString();
47251
+ if (formatYAxisLabel) {
47252
+ return formatYAxisLabel(displayValue);
47094
47253
  }
47095
- return tick.value.toString();
47254
+ return displayValue;
47096
47255
  }
47097
47256
  return '';
47098
- }, [chart.y.ticks, yScaleDataType]);
47257
+ }, [chart.y.ticks, yScaleDataType, formatYAxisLabel]);
47099
47258
  var formattedLabelsDict = React.useMemo(function () {
47100
- return getLabelDictionary(chart.data, xScaleKeys);
47101
- }, [chart.data, xScaleKeys]);
47259
+ return getLabelDictionary(processedData, xScaleKeys);
47260
+ }, [processedData, xScaleKeys]);
47102
47261
  return jsxRuntime.jsxs(React.Fragment, {
47103
47262
  children: [jsxRuntime.jsxs(ChartWrapper$1, {
47104
47263
  width: width,
@@ -50137,35 +50296,6 @@ var AreaChartV2 = function AreaChartV2(props) {
50137
50296
  });
50138
50297
  };
50139
50298
 
50140
- function convertToStackedPercentages(data, yKeys, xKey) {
50141
- if (!xKey || yKeys.length === 0) {
50142
- return data;
50143
- }
50144
- return data.map(function (item) {
50145
- var convertedItem = _extends({}, item);
50146
- var total = 0;
50147
- yKeys.forEach(function (key) {
50148
- var _item$key;
50149
- var value = Number((_item$key = item[key]) == null ? void 0 : _item$key.value) || 0;
50150
- total += value;
50151
- });
50152
- if (total === 0) {
50153
- return convertedItem;
50154
- }
50155
- yKeys.forEach(function (key) {
50156
- if (item[key]) {
50157
- var value = Number(item[key].value) || 0;
50158
- var percentage = value / total;
50159
- convertedItem[key] = _extends({}, item[key], {
50160
- value: percentage,
50161
- originalValue: item[key].value
50162
- });
50163
- }
50164
- });
50165
- return convertedItem;
50166
- });
50167
- }
50168
-
50169
50299
  var buildBarChartRepresentation = function buildBarChartRepresentation(_ref) {
50170
50300
  var _xKeys$, _axisTitles$x, _axisTitles$y;
50171
50301
  var axisTitles = _ref.axisTitles,