@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.
- package/dist/charts/src/v2/components/Axis/AxisBottom.d.ts +1 -1
- package/dist/charts/src/v2/components/BarChart/BarChart.d.ts +2 -2
- package/dist/charts/src/v2/utils/components/BarGroup.d.ts +4 -4
- package/dist/charts/src/v2/utils/components/BarStacked.d.ts +4 -4
- package/dist/dashboard.cjs.development.js +128 -127
- package/dist/dashboard.cjs.production.min.js +1 -1
- package/dist/dashboard.esm.js +129 -128
- package/dist/shared-ui/src/components/BarChartV2/BarChartV2View.d.ts +3 -3
- package/package.json +1 -1
|
@@ -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 {
|
|
3
|
-
import { BarStyles } from
|
|
4
|
-
import {
|
|
5
|
-
import { DataType } from
|
|
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
|
|
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
|
|
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
|
|
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
|
-
}
|
|
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
|
-
|
|
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
|
-
},
|
|
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;
|