@vizzly/dashboard 0.15.0-dev-ec22f31a049b4f844d3ea606a85bd487c4553b03 → 0.15.0-dev-9c2753f2944feccf9be062635a5a86838c409695

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.
@@ -15,4 +15,4 @@ export declare type AxisBottomProps = {
15
15
  xScale: ScaleBand<string> | ScaleBand<Date> | ScaleBand<number> | ScaleLinear<number, number, never> | ScalePoint<string> | ScaleTime<number, number, never> | null;
16
16
  height: number;
17
17
  };
18
- export declare function AxisBottom({ x, margin, themeCSS, show, removeStroke, xScaleDataType, xScale, height, baselineShift }: AxisBottomProps): JSX.Element | null;
18
+ export declare function AxisBottom({ x, margin, themeCSS, show, removeStroke, xScaleDataType, xScale, height, baselineShift, }: AxisBottomProps): JSX.Element | null;
@@ -1,7 +1,7 @@
1
1
  /// <reference types="react" />
2
2
  import { BarChartRepresentation } from '../../../../../shared-logic/src/BarChartV2/types';
3
- import { ChartTheme } from '../../../types';
4
3
  import { ChartOnViewClick } from '../../../../../shared-logic/src/ChartsV2/types';
4
+ import { ChartTheme } from '../../../types';
5
5
  export declare type BarChartProps = {
6
6
  width: number;
7
7
  height: number;
@@ -21,4 +21,4 @@ export declare type BarChartProps = {
21
21
  enableHover?: boolean;
22
22
  numberOfDimensions: number;
23
23
  };
24
- export declare const BarChart: ({ chart, width, height, options, theme, onClick, enableHover, numberOfDimensions }: BarChartProps) => JSX.Element;
24
+ export declare const BarChart: ({ chart, width, height, options, theme, onClick, enableHover, numberOfDimensions, }: BarChartProps) => JSX.Element;
@@ -1,8 +1,8 @@
1
1
  /// <reference types="react" />
2
- import { ChartDataDefinition, ConditionalFormattingRule, ShapeDefinition } from "../../../../../shared-logic/src/ChartsV2/types";
3
- import { BarStyles } from "../../../../../shared-logic/src/BarChartV2/types";
4
- import { ScaleLinear, ScaleBand } from '@visx/vendor/d3-scale';
5
- import { DataType } from "../../../../../shared-logic/src/Field/types";
2
+ import { ScaleBand, ScaleLinear } from '@visx/vendor/d3-scale';
3
+ import { BarStyles } from '../../../../../shared-logic/src/BarChartV2/types';
4
+ import { ChartDataDefinition, ConditionalFormattingRule, ShapeDefinition } from '../../../../../shared-logic/src/ChartsV2/types';
5
+ import { DataType } from '../../../../../shared-logic/src/Field/types';
6
6
  export declare type BarGroupProps = {
7
7
  data: ChartDataDefinition[];
8
8
  keys: string[];
@@ -1,8 +1,8 @@
1
1
  /// <reference types="react" />
2
- import { BarStyles } from "../../../../../shared-logic/src/BarChartV2/types";
3
- import { ConditionalFormattingRule, ShapeDefinition } from "../../../../../shared-logic/src/ChartsV2/types";
4
- import { ScaleLinear } from '@visx/vendor/d3-scale';
5
2
  import { DatumObject } from '@visx/shape/lib/types';
3
+ import { ScaleLinear } from '@visx/vendor/d3-scale';
4
+ import { BarStyles } from '../../../../../shared-logic/src/BarChartV2/types';
5
+ import { ConditionalFormattingRule, ShapeDefinition } from '../../../../../shared-logic/src/ChartsV2/types';
6
6
  export declare type BarStackedProps = {
7
7
  conditionalFormattingRules: ConditionalFormattingRule[];
8
8
  bars: ShapeDefinition<BarStyles>[];
@@ -15,4 +15,4 @@ export declare type BarStackedProps = {
15
15
  height: number;
16
16
  width: number;
17
17
  };
18
- export declare const BarStacked: ({ xScaleDataType, data, xScaleKey, yScale, keys, bars, conditionalFormattingRules, xScale, height, width }: BarStackedProps) => JSX.Element;
18
+ export declare const BarStacked: ({ xScaleDataType, data, xScaleKey, yScale, keys, bars, conditionalFormattingRules, xScale, height, width, }: BarStackedProps) => JSX.Element;
@@ -44471,58 +44471,7 @@ function Lines(_ref2) {
44471
44471
  });
44472
44472
  }
44473
44473
 
44474
- var PADDING = {
44475
- paddingOuter: 0.05,
44476
- paddingInner: 0.3
44477
- };
44478
-
44479
- function useBarXScale(xScaleDataType, innerWidth, xScaleKey, data) {
44480
- return React.useMemo(function () {
44481
- if (xScaleDataType === 'string') {
44482
- return scale.scaleBand(_extends({
44483
- range: [0, innerWidth],
44484
- domain: xScaleKey ? [].concat(data.map(function (d) {
44485
- return d[xScaleKey] && d[xScaleKey].value !== null ? String(d[xScaleKey].value) : '';
44486
- })) : []
44487
- }, PADDING));
44488
- }
44489
- if (xScaleDataType === 'date_time' && xScaleKey) {
44490
- return scale.scaleBand(_extends({
44491
- range: [0, innerWidth],
44492
- domain: data.map(function (d) {
44493
- return new Date(d[xScaleKey].value);
44494
- })
44495
- }, PADDING));
44496
- }
44497
- if (xScaleDataType === 'number' && xScaleKey) {
44498
- return scale.scaleBand(_extends({
44499
- range: [0, innerWidth],
44500
- domain: data.map(function (d) {
44501
- return d[xScaleKey] && d[xScaleKey].value !== null ? Number(d[xScaleKey].value) : 0;
44502
- })
44503
- }, PADDING));
44504
- }
44505
- return null;
44506
- }, [innerWidth, data]);
44507
- }
44508
-
44509
- var useBottomAxisBaseLineShift = function useBottomAxisBaseLineShift(_ref) {
44510
- var showDetailedSubGroupingLabels = _ref.showDetailedSubGroupingLabels,
44511
- hasBottomTitle = _ref.hasBottomTitle,
44512
- hasLeftTitle = _ref.hasLeftTitle;
44513
- if (!showDetailedSubGroupingLabels) {
44514
- return {
44515
- bottomAxisBaselineShift: 0,
44516
- bottomOffset: 0,
44517
- leftOffset: 0
44518
- };
44519
- }
44520
- return {
44521
- bottomAxisBaselineShift: hasBottomTitle ? -65 : -60,
44522
- bottomOffset: hasBottomTitle ? -15 : 10,
44523
- leftOffset: hasLeftTitle ? -10 : 0
44524
- };
44525
- };
44474
+ var BAR_RADIUS = 2;
44526
44475
 
44527
44476
  function getBarFill(bars, conditionalFormattingRules, barKey, barValues) {
44528
44477
  var _bars$find;
@@ -44548,73 +44497,6 @@ function getBarFill(bars, conditionalFormattingRules, barKey, barValues) {
44548
44497
  return fill;
44549
44498
  }
44550
44499
 
44551
- var BAR_RADIUS = 2;
44552
-
44553
- var BarStacked = function BarStacked(_ref) {
44554
- var xScaleDataType = _ref.xScaleDataType,
44555
- data = _ref.data,
44556
- xScaleKey = _ref.xScaleKey,
44557
- yScale = _ref.yScale,
44558
- keys = _ref.keys,
44559
- bars = _ref.bars,
44560
- conditionalFormattingRules = _ref.conditionalFormattingRules,
44561
- xScale = _ref.xScale,
44562
- height = _ref.height,
44563
- width = _ref.width;
44564
- var handleGetXValue = function handleGetXValue(d) {
44565
- var xValue = d[xScaleKey];
44566
- if (xScaleDataType === 'string') return String(xValue);
44567
- if (xScaleDataType === 'date_time') {
44568
- return new Date(xValue);
44569
- }
44570
- if (xScaleDataType === 'number') {
44571
- return Number(xValue);
44572
- }
44573
- return String(xValue);
44574
- };
44575
- return jsxRuntime.jsx(shape.BarStack, {
44576
- x: handleGetXValue,
44577
- xScale: xScale,
44578
- yScale: yScale,
44579
- data: data,
44580
- keys: keys,
44581
- color: function color() {
44582
- return '';
44583
- },
44584
- height: height,
44585
- width: width,
44586
- offset: "none",
44587
- children: function children(barStacks) {
44588
- return barStacks.map(function (barStack) {
44589
- return barStack.bars.map(function (bar) {
44590
- return jsxRuntime.jsx(Bar, {
44591
- bar: bar,
44592
- barStack: barStack,
44593
- bars: bars,
44594
- conditionalFormattingRules: conditionalFormattingRules
44595
- }, bar.key.toString());
44596
- });
44597
- });
44598
- }
44599
- });
44600
- };
44601
- var Bar = function Bar(_ref2) {
44602
- var bar = _ref2.bar,
44603
- barStack = _ref2.barStack,
44604
- bars = _ref2.bars,
44605
- conditionalFormattingRules = _ref2.conditionalFormattingRules;
44606
- var BAR_PADDING = 1.5;
44607
- if (bar.height < 3) return null;
44608
- return jsxRuntime.jsx("rect", {
44609
- x: bar.x,
44610
- y: bar.y,
44611
- width: bar.width,
44612
- height: bar.height - BAR_PADDING,
44613
- fill: getBarFill(bars, conditionalFormattingRules, bar.key, bar.bar.data),
44614
- rx: BAR_RADIUS
44615
- }, "bar-stack-" + barStack.index + "-" + bar.index);
44616
- };
44617
-
44618
44500
  function _EMOTION_STRINGIFIED_CSS_ERROR__$9() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
44619
44501
  function BarGroup(_ref) {
44620
44502
  var data = _ref.data,
@@ -44664,7 +44546,7 @@ function BarGroup(_ref) {
44664
44546
  return jsxRuntime.jsx(group.Group, {
44665
44547
  left: barGroup.x0,
44666
44548
  children: barGroup.bars.map(function (bar) {
44667
- return jsxRuntime.jsx(Bar$1, {
44549
+ return jsxRuntime.jsx(Bar, {
44668
44550
  bar: bar,
44669
44551
  barGroup: barGroup,
44670
44552
  bars: bars,
@@ -44682,7 +44564,7 @@ function BarGroup(_ref) {
44682
44564
  }
44683
44565
  });
44684
44566
  }
44685
- var Bar$1 = function Bar(_ref2) {
44567
+ var Bar = function Bar(_ref2) {
44686
44568
  var bar = _ref2.bar,
44687
44569
  barGroup = _ref2.barGroup,
44688
44570
  bars = _ref2.bars,
@@ -44696,6 +44578,7 @@ var Bar$1 = function Bar(_ref2) {
44696
44578
  var showBar = bar.value !== null && bar.height > 0 && bar.width > 0;
44697
44579
  return jsxRuntime.jsxs(React.Fragment, {
44698
44580
  children: [showBar && jsxRuntime.jsx(BarRect, {
44581
+ barRectKey: "bar-group-bar-" + barGroup.index + "-" + bar.index + "-" + bar.value + "-" + String(bar.key),
44699
44582
  x: bar.x,
44700
44583
  y: bar.y,
44701
44584
  width: bar.width,
@@ -44705,7 +44588,7 @@ var Bar$1 = function Bar(_ref2) {
44705
44588
  return _onClick(e, barGroup, bar);
44706
44589
  },
44707
44590
  enableHover: enableHover
44708
- }, "bar-group-bar-" + barGroup.index + "-" + bar.index + "-" + bar.value + "-" + String(bar.key)), jsxRuntime.jsx(BarLabel, {
44591
+ }), jsxRuntime.jsx(BarLabel, {
44709
44592
  bar: bar,
44710
44593
  barGroup: barGroup,
44711
44594
  yLabelPosition: yLabelPosition,
@@ -44722,7 +44605,7 @@ var BarRect = function BarRect(_ref3) {
44722
44605
  y = _ref3.y,
44723
44606
  width = _ref3.width,
44724
44607
  height = _ref3.height,
44725
- key = _ref3.key,
44608
+ barRectKey = _ref3.barRectKey,
44726
44609
  enableHover = _ref3.enableHover;
44727
44610
  var _useState = React.useState(fill),
44728
44611
  fillColor = _useState[0],
@@ -44730,7 +44613,7 @@ var BarRect = function BarRect(_ref3) {
44730
44613
  var classes = enableHover ? /*#__PURE__*/css$1.css( {
44731
44614
  name: "1ltmijl-classes",
44732
44615
  styles: "cursor:pointer;label:classes;",
44733
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["BarGroup.tsx"],"names":[],"mappings":"AAmLkC","file":"BarGroup.tsx","sourcesContent":["import { css } from \"@emotion/css\";\nimport { Fragment, useState } from \"react\";\nimport { lightenColor } from \"../../../styles/color.functions\";\nimport { BAR_RADIUS } from '../../constants/BORDER_RADIUS'\nimport { getBarFill } from \"../getBarFill\";\nimport { ChartDataDefinition, ConditionalFormattingRule, ShapeDefinition } from \"shared-logic/src/ChartsV2/types\";\nimport { BarStyles } from \"shared-logic/src/BarChartV2/types\";\nimport { BarGroup as VisxBarGroup } from '@visx/shape';\nimport { ScaleLinear, ScaleBand } from '@visx/vendor/d3-scale';\nimport { DataType } from \"shared-logic/src/Field/types\";\nimport { DatumObject } from '@visx/shape/lib/types';\nimport { Group } from '@visx/group';\n\nexport type BarGroupProps = {\n    data: ChartDataDefinition[];\n    keys: string[];\n    height: number;\n    xKey: string;\n    xScaleDataType: DataType;\n    xScale: ScaleBand<string> | ScaleBand<Date> | ScaleBand<number> | null;\n    innerXScale: ScaleBand<string> | undefined;\n    yScale: ScaleLinear<number, number, never>;\n    onClick: (e: React.MouseEvent<SVGRectElement, MouseEvent>, barGroup: any, bar: any) => void;\n    conditionalFormattingRules: ConditionalFormattingRule[];\n    bars: ShapeDefinition<BarStyles>[];\n    enableHover?: boolean;\n    yAxisLabels?: string[];\n    yLabelPosition?: number;\n    showDetailedSubGroupingLabels: boolean;\n    labelStyle?: React.CSSProperties;\n};\n\nexport function BarGroup({\n    data,\n    keys,\n    height,\n    xKey,\n    xScaleDataType,\n    xScale,\n    innerXScale,\n    yScale,\n    onClick,\n    conditionalFormattingRules,\n    bars,\n    enableHover,\n    yAxisLabels,\n    yLabelPosition,\n    showDetailedSubGroupingLabels,\n    labelStyle,\n}: BarGroupProps) {\n    const getGroupPosition = (d: DatumObject) => {\n        const xValue = d[xKey as keyof typeof d];\n\n        if (xScaleDataType === 'string') return String(xValue);\n\n        if (xScaleDataType === 'date_time') {\n            return new Date(String(xValue));\n        }\n\n        if (xScaleDataType === 'number') {\n            return Number(xValue);\n        }\n\n        return String(xValue);\n    };\n\n    return (\n        <VisxBarGroup<DatumObject>\n            data={data as DatumObject[]}\n            keys={keys}\n            height={height}\n            x0={getGroupPosition}\n            // @ts-ignore\n            x0Scale={xScale}\n            // @ts-ignore\n            x1Scale={innerXScale}\n            yScale={yScale}\n            color={() => ''}\n        >\n            {barGroups => {\n                return barGroups.map(barGroup => (\n                    <Group key={`bar-group-${barGroup.index}-${barGroup.x0}`} left={barGroup.x0}>\n                        {barGroup.bars.map(bar => (\n                            <Bar\n                                key={`bar-${bar.index}-${bar.x}`}\n                                bar={bar}\n                                barGroup={barGroup}\n                                bars={bars}\n                                conditionalFormattingRules={conditionalFormattingRules}\n                                enableHover={enableHover}\n                                labelStyle={labelStyle}\n                                onClick={onClick}\n                                showDetailedSubGroupingLabels={showDetailedSubGroupingLabels}\n                                yAxisLabels={yAxisLabels}\n                                yLabelPosition={yLabelPosition}\n                            />\n                        ))}\n                    </Group>\n                ));\n            }}\n        </VisxBarGroup>\n    );\n}\n\ntype BarProps = {\n    bar: any,\n    barGroup: any,\n    bars: ShapeDefinition<BarStyles>[];\n    conditionalFormattingRules: ConditionalFormattingRule[];\n    enableHover?: boolean;\n    onClick: (e: React.MouseEvent<SVGRectElement, MouseEvent>, barGroup: any, bar: any) => void;\n    showDetailedSubGroupingLabels: boolean;\n    labelStyle?: React.CSSProperties;\n    yAxisLabels?: string[];\n    yLabelPosition?: number;\n}\n\nconst Bar = ({\n    bar,\n    barGroup,\n    bars,\n    conditionalFormattingRules,\n    enableHover,\n    labelStyle,\n    onClick,\n    showDetailedSubGroupingLabels,\n    yAxisLabels,\n    yLabelPosition,\n}: BarProps) => {\n    const showBar = bar.value !== null && bar.height > 0 && bar.width > 0;\n\n    return (\n        <Fragment>\n            {showBar && <BarRect\n                key={`bar-group-bar-${barGroup.index}-${bar.index}-${bar.value}-${String(bar.key)}`}\n                x={bar.x}\n                y={bar.y}\n                width={bar.width}\n                height={bar.height}\n                fill={getBarFill(bars, conditionalFormattingRules, String(bar.key), bar.value)}\n                onClick={e => onClick(e, barGroup, bar)}\n                enableHover={enableHover}\n            />}\n            \n            <BarLabel\n                bar={bar}\n                barGroup={barGroup}\n                yLabelPosition={yLabelPosition}\n                yAxisLabels={yAxisLabels}\n                showDetailedSubGroupingLabels={showDetailedSubGroupingLabels}\n                labelStyle={labelStyle}\n            />\n        </Fragment>\n    );\n};\n\ntype BarRectProps = {\n    onClick: (e: React.MouseEvent<SVGRectElement, MouseEvent>) => void;\n    fill?: string;\n    x: number;\n    y: number;\n    width: number;\n    height: number;\n    key: string;\n    enableHover?: boolean;\n};\n\nconst BarRect = ({\n    onClick,\n    fill,\n    x,\n    y,\n    width,\n    height,\n    key,\n    enableHover,\n}: BarRectProps) => {\n    const [fillColor, setFillColor] = useState(fill);\n\n    const classes = enableHover ? css({ cursor: 'pointer' }) : '';\n\n    const handleOnMouseEnter = () => {\n        if (enableHover) {\n            setFillColor(lightenColor(fill, 0.8));\n        }\n    }\n\n    const handleOnMouseLeave = () => {\n        if (enableHover) {\n            setFillColor(fill);\n        }\n    }\n\n    return (\n        <rect\n            key={key}\n            x={x}\n            y={y}\n            width={width}\n            height={height}\n            fill={fillColor}\n            rx={BAR_RADIUS}\n            onClick={onClick}\n            onMouseEnter={handleOnMouseEnter}\n            onMouseLeave={handleOnMouseLeave}\n            className={classes}\n        />\n    );\n};\n\ntype BarLabelProps = {\n    bar: any;\n    barGroup: any;\n    yLabelPosition?: number;\n    yAxisLabels?: string[];\n    showDetailedSubGroupingLabels: boolean;\n    labelStyle?: React.CSSProperties;\n};\n\nconst BarLabel = ({\n    bar,\n    barGroup,\n    yLabelPosition,\n    yAxisLabels,\n    showDetailedSubGroupingLabels,\n    labelStyle,\n}: BarLabelProps) => {\n    if (!showDetailedSubGroupingLabels || !yLabelPosition || !yAxisLabels) return null;\n\n    const label = yAxisLabels[bar.index];\n    const columnLabel = label.split('•')[0];\n\n    let formattedColumnLabel: string;\n    if (columnLabel.length >= 13) {\n        formattedColumnLabel = columnLabel.slice(0, 10) + '...';\n    } else {\n        formattedColumnLabel = columnLabel.slice(0, 13);\n    }\n\n    const labelXGap = 4;\n    const labelXPosition = bar.x + (bar.width / 2) + labelXGap;\n\n    const labelYGap = 15;\n    const labelYPosition = yLabelPosition + labelYGap;\n\n    const labelKey = `label-${barGroup.index}-${bar.index}-${label}`;\n\n    return <text\n        key={labelKey}\n        x={labelXPosition}\n        y={labelYPosition}\n        style={labelStyle}\n        transform={`rotate(-70, ${labelXPosition}, ${labelYPosition})`}\n        textAnchor='end'\n    >\n        {formattedColumnLabel}\n    </text>\n}"]} */",
44616
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["BarGroup.tsx"],"names":[],"mappings":"AA4KgC","file":"BarGroup.tsx","sourcesContent":["import { css } from '@emotion/css';\nimport { Group } from '@visx/group';\nimport { BarGroup as VisxBarGroup } from '@visx/shape';\nimport { DatumObject } from '@visx/shape/lib/types';\nimport { ScaleBand, ScaleLinear } from '@visx/vendor/d3-scale';\nimport { Fragment, useState } from 'react';\nimport { BarStyles } from 'shared-logic/src/BarChartV2/types';\nimport { ChartDataDefinition, ConditionalFormattingRule, ShapeDefinition } from 'shared-logic/src/ChartsV2/types';\nimport { DataType } from 'shared-logic/src/Field/types';\nimport { lightenColor } from '../../../styles/color.functions';\nimport { BAR_RADIUS } from '../../constants/BORDER_RADIUS';\nimport { getBarFill } from '../getBarFill';\n\nexport type BarGroupProps = {\n  data: ChartDataDefinition[];\n  keys: string[];\n  height: number;\n  xKey: string;\n  xScaleDataType: DataType;\n  xScale: ScaleBand<string> | ScaleBand<Date> | ScaleBand<number> | null;\n  innerXScale: ScaleBand<string> | undefined;\n  yScale: ScaleLinear<number, number, never>;\n  onClick: (e: React.MouseEvent<SVGRectElement, MouseEvent>, barGroup: any, bar: any) => void;\n  conditionalFormattingRules: ConditionalFormattingRule[];\n  bars: ShapeDefinition<BarStyles>[];\n  enableHover?: boolean;\n  yAxisLabels?: string[];\n  yLabelPosition?: number;\n  showDetailedSubGroupingLabels: boolean;\n  labelStyle?: React.CSSProperties;\n};\n\nexport function BarGroup({\n  data,\n  keys,\n  height,\n  xKey,\n  xScaleDataType,\n  xScale,\n  innerXScale,\n  yScale,\n  onClick,\n  conditionalFormattingRules,\n  bars,\n  enableHover,\n  yAxisLabels,\n  yLabelPosition,\n  showDetailedSubGroupingLabels,\n  labelStyle,\n}: BarGroupProps) {\n  const getGroupPosition = (d: DatumObject) => {\n    const xValue = d[xKey as keyof typeof d];\n\n    if (xScaleDataType === 'string') return String(xValue);\n\n    if (xScaleDataType === 'date_time') {\n      return new Date(String(xValue));\n    }\n\n    if (xScaleDataType === 'number') {\n      return Number(xValue);\n    }\n\n    return String(xValue);\n  };\n\n  return (\n    <VisxBarGroup<DatumObject>\n      data={data as DatumObject[]}\n      keys={keys}\n      height={height}\n      x0={getGroupPosition}\n      // @ts-ignore\n      x0Scale={xScale}\n      // @ts-ignore\n      x1Scale={innerXScale}\n      yScale={yScale}\n      color={() => ''}\n    >\n      {(barGroups) => {\n        return barGroups.map((barGroup) => (\n          <Group key={`bar-group-${barGroup.index}-${barGroup.x0}`} left={barGroup.x0}>\n            {barGroup.bars.map((bar) => (\n              <Bar\n                key={`bar-${bar.index}-${bar.x}`}\n                bar={bar}\n                barGroup={barGroup}\n                bars={bars}\n                conditionalFormattingRules={conditionalFormattingRules}\n                enableHover={enableHover}\n                labelStyle={labelStyle}\n                onClick={onClick}\n                showDetailedSubGroupingLabels={showDetailedSubGroupingLabels}\n                yAxisLabels={yAxisLabels}\n                yLabelPosition={yLabelPosition}\n              />\n            ))}\n          </Group>\n        ));\n      }}\n    </VisxBarGroup>\n  );\n}\n\ntype BarProps = {\n  bar: any;\n  barGroup: any;\n  bars: ShapeDefinition<BarStyles>[];\n  conditionalFormattingRules: ConditionalFormattingRule[];\n  enableHover?: boolean;\n  onClick: (e: React.MouseEvent<SVGRectElement, MouseEvent>, barGroup: any, bar: any) => void;\n  showDetailedSubGroupingLabels: boolean;\n  labelStyle?: React.CSSProperties;\n  yAxisLabels?: string[];\n  yLabelPosition?: number;\n};\n\nconst Bar = ({\n  bar,\n  barGroup,\n  bars,\n  conditionalFormattingRules,\n  enableHover,\n  labelStyle,\n  onClick,\n  showDetailedSubGroupingLabels,\n  yAxisLabels,\n  yLabelPosition,\n}: BarProps) => {\n  const showBar = bar.value !== null && bar.height > 0 && bar.width > 0;\n\n  return (\n    <Fragment>\n      {showBar && (\n        <BarRect\n          barRectKey={`bar-group-bar-${barGroup.index}-${bar.index}-${bar.value}-${String(bar.key)}`}\n          x={bar.x}\n          y={bar.y}\n          width={bar.width}\n          height={bar.height}\n          fill={getBarFill(bars, conditionalFormattingRules, String(bar.key), bar.value)}\n          onClick={(e) => onClick(e, barGroup, bar)}\n          enableHover={enableHover}\n        />\n      )}\n\n      <BarLabel\n        bar={bar}\n        barGroup={barGroup}\n        yLabelPosition={yLabelPosition}\n        yAxisLabels={yAxisLabels}\n        showDetailedSubGroupingLabels={showDetailedSubGroupingLabels}\n        labelStyle={labelStyle}\n      />\n    </Fragment>\n  );\n};\n\ntype BarRectProps = {\n  onClick: (e: React.MouseEvent<SVGRectElement, MouseEvent>) => void;\n  fill?: string;\n  x: number;\n  y: number;\n  width: number;\n  height: number;\n  barRectKey: string;\n  enableHover?: boolean;\n};\n\nconst BarRect = ({ onClick, fill, x, y, width, height, barRectKey, enableHover }: BarRectProps) => {\n  const [fillColor, setFillColor] = useState(fill);\n\n  const classes = enableHover ? css({ cursor: 'pointer' }) : '';\n\n  const handleOnMouseEnter = () => {\n    if (enableHover) {\n      setFillColor(lightenColor(fill, 0.8));\n    }\n  };\n\n  const handleOnMouseLeave = () => {\n    if (enableHover) {\n      setFillColor(fill);\n    }\n  };\n\n  return (\n    <rect\n      key={barRectKey}\n      x={x}\n      y={y}\n      width={width}\n      height={height}\n      fill={fillColor}\n      rx={BAR_RADIUS}\n      onClick={onClick}\n      onMouseEnter={handleOnMouseEnter}\n      onMouseLeave={handleOnMouseLeave}\n      className={classes}\n    />\n  );\n};\n\ntype BarLabelProps = {\n  bar: any;\n  barGroup: any;\n  yLabelPosition?: number;\n  yAxisLabels?: string[];\n  showDetailedSubGroupingLabels: boolean;\n  labelStyle?: React.CSSProperties;\n};\n\nconst BarLabel = ({\n  bar,\n  barGroup,\n  yLabelPosition,\n  yAxisLabels,\n  showDetailedSubGroupingLabels,\n  labelStyle,\n}: BarLabelProps) => {\n  if (!showDetailedSubGroupingLabels || !yLabelPosition || !yAxisLabels) return null;\n\n  const label = yAxisLabels[bar.index];\n  const columnLabel = label.split('•')[0];\n\n  let formattedColumnLabel: string;\n  if (columnLabel.length >= 13) {\n    formattedColumnLabel = columnLabel.slice(0, 10) + '...';\n  } else {\n    formattedColumnLabel = columnLabel.slice(0, 13);\n  }\n\n  const labelXGap = 4;\n  const labelXPosition = bar.x + bar.width / 2 + labelXGap;\n\n  const labelYGap = 15;\n  const labelYPosition = yLabelPosition + labelYGap;\n\n  const labelKey = `label-${barGroup.index}-${bar.index}-${label}`;\n\n  return (\n    <text\n      key={labelKey}\n      x={labelXPosition}\n      y={labelYPosition}\n      style={labelStyle}\n      transform={`rotate(-70, ${labelXPosition}, ${labelYPosition})`}\n      textAnchor=\"end\"\n    >\n      {formattedColumnLabel}\n    </text>\n  );\n};\n"]} */",
44734
44617
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$9
44735
44618
  }) : '';
44736
44619
  var handleOnMouseEnter = function handleOnMouseEnter() {
@@ -44754,7 +44637,7 @@ var BarRect = function BarRect(_ref3) {
44754
44637
  onMouseEnter: handleOnMouseEnter,
44755
44638
  onMouseLeave: handleOnMouseLeave,
44756
44639
  className: classes
44757
- }, key);
44640
+ }, barRectKey);
44758
44641
  };
44759
44642
  var BarLabel = function BarLabel(_ref4) {
44760
44643
  var bar = _ref4.bar,
@@ -44787,6 +44670,124 @@ var BarLabel = function BarLabel(_ref4) {
44787
44670
  }, labelKey);
44788
44671
  };
44789
44672
 
44673
+ var BarStacked = function BarStacked(_ref) {
44674
+ var xScaleDataType = _ref.xScaleDataType,
44675
+ data = _ref.data,
44676
+ xScaleKey = _ref.xScaleKey,
44677
+ yScale = _ref.yScale,
44678
+ keys = _ref.keys,
44679
+ bars = _ref.bars,
44680
+ conditionalFormattingRules = _ref.conditionalFormattingRules,
44681
+ xScale = _ref.xScale,
44682
+ height = _ref.height,
44683
+ width = _ref.width;
44684
+ var handleGetXValue = function handleGetXValue(d) {
44685
+ var xValue = d[xScaleKey];
44686
+ if (xScaleDataType === 'string') return String(xValue);
44687
+ if (xScaleDataType === 'date_time') {
44688
+ return new Date(xValue);
44689
+ }
44690
+ if (xScaleDataType === 'number') {
44691
+ return Number(xValue);
44692
+ }
44693
+ return String(xValue);
44694
+ };
44695
+ return jsxRuntime.jsx(shape.BarStack, {
44696
+ x: handleGetXValue,
44697
+ xScale: xScale,
44698
+ yScale: yScale,
44699
+ data: data,
44700
+ keys: keys,
44701
+ color: function color() {
44702
+ return '';
44703
+ },
44704
+ height: height,
44705
+ width: width,
44706
+ offset: "none",
44707
+ children: function children(barStacks) {
44708
+ return barStacks.map(function (barStack) {
44709
+ return barStack.bars.map(function (bar) {
44710
+ return jsxRuntime.jsx(Bar$1, {
44711
+ bar: bar,
44712
+ barStack: barStack,
44713
+ bars: bars,
44714
+ conditionalFormattingRules: conditionalFormattingRules
44715
+ }, bar.key.toString() + "-" + bar.index + "-" + bar.x);
44716
+ });
44717
+ });
44718
+ }
44719
+ });
44720
+ };
44721
+ var Bar$1 = function Bar(_ref2) {
44722
+ var bar = _ref2.bar,
44723
+ barStack = _ref2.barStack,
44724
+ bars = _ref2.bars,
44725
+ conditionalFormattingRules = _ref2.conditionalFormattingRules;
44726
+ var BAR_PADDING = 1.5;
44727
+ if (bar.height < 3) return null;
44728
+ return jsxRuntime.jsx("rect", {
44729
+ x: bar.x,
44730
+ y: bar.y,
44731
+ width: bar.width,
44732
+ height: bar.height - BAR_PADDING,
44733
+ fill: getBarFill(bars, conditionalFormattingRules, bar.key, bar.bar.data),
44734
+ rx: BAR_RADIUS
44735
+ }, "bar-stack-" + barStack.index + "-" + bar.index);
44736
+ };
44737
+
44738
+ var useBottomAxisBaseLineShift = function useBottomAxisBaseLineShift(_ref) {
44739
+ var showDetailedSubGroupingLabels = _ref.showDetailedSubGroupingLabels,
44740
+ hasBottomTitle = _ref.hasBottomTitle,
44741
+ hasLeftTitle = _ref.hasLeftTitle;
44742
+ if (!showDetailedSubGroupingLabels) {
44743
+ return {
44744
+ bottomAxisBaselineShift: 0,
44745
+ bottomOffset: 0,
44746
+ leftOffset: 0
44747
+ };
44748
+ }
44749
+ return {
44750
+ bottomAxisBaselineShift: hasBottomTitle ? -65 : -60,
44751
+ bottomOffset: hasBottomTitle ? -15 : 10,
44752
+ leftOffset: hasLeftTitle ? -10 : 0
44753
+ };
44754
+ };
44755
+
44756
+ var PADDING = {
44757
+ paddingOuter: 0.05,
44758
+ paddingInner: 0.3
44759
+ };
44760
+
44761
+ function useBarXScale(xScaleDataType, innerWidth, xScaleKey, data) {
44762
+ return React.useMemo(function () {
44763
+ if (xScaleDataType === 'string') {
44764
+ return scale.scaleBand(_extends({
44765
+ range: [0, innerWidth],
44766
+ domain: xScaleKey ? [].concat(data.map(function (d) {
44767
+ return d[xScaleKey] && d[xScaleKey].value !== null ? String(d[xScaleKey].value) : '';
44768
+ })) : []
44769
+ }, PADDING));
44770
+ }
44771
+ if (xScaleDataType === 'date_time' && xScaleKey) {
44772
+ return scale.scaleBand(_extends({
44773
+ range: [0, innerWidth],
44774
+ domain: data.map(function (d) {
44775
+ return new Date(d[xScaleKey].value);
44776
+ })
44777
+ }, PADDING));
44778
+ }
44779
+ if (xScaleDataType === 'number' && xScaleKey) {
44780
+ return scale.scaleBand(_extends({
44781
+ range: [0, innerWidth],
44782
+ domain: data.map(function (d) {
44783
+ return d[xScaleKey] && d[xScaleKey].value !== null ? Number(d[xScaleKey].value) : 0;
44784
+ })
44785
+ }, PADDING));
44786
+ }
44787
+ return null;
44788
+ }, [innerWidth, data]);
44789
+ }
44790
+
44790
44791
  var BarChart$5 = function BarChart(_ref) {
44791
44792
  var _theme$axis;
44792
44793
  var chart = _ref.chart,
@@ -44808,7 +44809,7 @@ var BarChart$5 = function BarChart(_ref) {
44808
44809
  tooltipData = _useTooltip.tooltipData,
44809
44810
  hideTooltip = _useTooltip.hideTooltip,
44810
44811
  showTooltip = _useTooltip.showTooltip;
44811
- var showDetailedSubGroupingLabels = numberOfDimensions === 2 && width > 450;
44812
+ var showDetailedSubGroupingLabels = !options.stacked && numberOfDimensions === 2 && width > 450;
44812
44813
  var hasBottomTitle = chart.x.title != null;
44813
44814
  var hasLeftTitle = chart.y.title != null;
44814
44815
  var _useBottomAxisBaseLin = useBottomAxisBaseLineShift({
@@ -44821,7 +44822,7 @@ var BarChart$5 = function BarChart(_ref) {
44821
44822
  leftOffset = _useBottomAxisBaseLin.leftOffset;
44822
44823
  var margin = buildMargin(chart.y.ticks, options.axis.showYAxisLabels, hasLeftTitle, hasBottomTitle, showDetailedSubGroupingLabels);
44823
44824
  var innerWidth = width - margin.left - margin.right;
44824
- var innerHeight = height - margin.top - margin.bottom - (options.showLegend ? 50 : 0) - (showDetailedSubGroupingLabels ? 50 : 0);
44825
+ var innerHeight = height - margin.top - margin.bottom - (options.showLegend ? 50 : 0) - (showDetailedSubGroupingLabels ? 50 : 0) + (options.axis.showXAxisLabels ? 0 : 25);
44825
44826
  var xKey = chart.x.key;
44826
44827
  var xScaleKey = chart.x.scale.key;
44827
44828
  var xScaleDataType = chart.x.scale.dataType;