@vizzly/dashboard 0.15.0-dev-ac044c49c73d54ff3c144918a639d24aea98b549 → 0.15.0-dev-01ea5aa946daad108dcca8cdb39a89202fb70c38
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/utils/components/BarGroup.d.ts +2 -1
- package/dist/dashboard.cjs.development.js +69 -26
- package/dist/dashboard.cjs.production.min.js +1 -1
- package/dist/dashboard.esm.js +69 -26
- package/dist/shared-logic/src/utils/defaultSortingDateTimes.d.ts +4 -0
- package/package.json +1 -1
|
@@ -7,6 +7,7 @@ export declare type BarGroupProps = {
|
|
|
7
7
|
data: ChartDataDefinition[];
|
|
8
8
|
keys: string[];
|
|
9
9
|
height: number;
|
|
10
|
+
width?: number;
|
|
10
11
|
xKey: string;
|
|
11
12
|
xScaleDataType: DataType;
|
|
12
13
|
xScale: ScaleBand<string> | ScaleBand<Date> | ScaleBand<number> | null;
|
|
@@ -25,4 +26,4 @@ export declare type BarGroupProps = {
|
|
|
25
26
|
[key: string]: string;
|
|
26
27
|
};
|
|
27
28
|
};
|
|
28
|
-
export declare function BarGroup({ data, keys, height, xKey, xScaleDataType, xScale, innerXScale, yScale, onClick, conditionalFormattingRules, bars, enableHover, yAxisLabels, yLabelPosition, showDetailedSubGroupingLabels, labelStyle, showLabels, labelDictionary, }: BarGroupProps): JSX.Element;
|
|
29
|
+
export declare function BarGroup({ data, keys, height, width, xKey, xScaleDataType, xScale, innerXScale, yScale, onClick, conditionalFormattingRules, bars, enableHover, yAxisLabels, yLabelPosition, showDetailedSubGroupingLabels, labelStyle, showLabels, labelDictionary, }: BarGroupProps): JSX.Element;
|
|
@@ -34825,16 +34825,6 @@ var calculateMinMax = function calculateMinMax(values) {
|
|
|
34825
34825
|
maxValue: maxValue
|
|
34826
34826
|
};
|
|
34827
34827
|
};
|
|
34828
|
-
var normalizeKey = function normalizeKey(value) {
|
|
34829
|
-
if (typeof value === 'number' || !isNaN(Number(value)) && !isNaN(parseFloat(value))) {
|
|
34830
|
-
var numValue = Number(value);
|
|
34831
|
-
if (numValue >= 0 && numValue <= 1) {
|
|
34832
|
-
return numValue.toString();
|
|
34833
|
-
}
|
|
34834
|
-
return numValue.toString().split('.')[0];
|
|
34835
|
-
}
|
|
34836
|
-
return String(value);
|
|
34837
|
-
};
|
|
34838
34828
|
|
|
34839
34829
|
// @TODO: Adjust the totalItems logic to be flexible based on the available width
|
|
34840
34830
|
var showDataLabel = function showDataLabel(totalItems) {
|
|
@@ -34854,7 +34844,7 @@ var getLabelDictionary = function getLabelDictionary(formattedData, keys) {
|
|
|
34854
34844
|
var convertedArray = keys.map(function (key) {
|
|
34855
34845
|
var _d$key, _ref;
|
|
34856
34846
|
if (!((_d$key = d[key]) != null && _d$key.formattedValue)) return;
|
|
34857
|
-
var valueKey =
|
|
34847
|
+
var valueKey = String(d[key].value);
|
|
34858
34848
|
var label = d[key].formattedValue;
|
|
34859
34849
|
return _ref = {}, _ref[valueKey] = label, _ref;
|
|
34860
34850
|
}).flat();
|
|
@@ -34878,11 +34868,10 @@ var getLabelDictionary = function getLabelDictionary(formattedData, keys) {
|
|
|
34878
34868
|
return dictionary;
|
|
34879
34869
|
};
|
|
34880
34870
|
var getFormattedValue = function getFormattedValue(value, dictionary) {
|
|
34881
|
-
var _dictionary$
|
|
34871
|
+
var _dictionary$actualVal;
|
|
34882
34872
|
var actualValue = (value == null ? void 0 : value.value) !== undefined ? value.value : value;
|
|
34883
34873
|
if (!dictionary) return actualValue;
|
|
34884
|
-
|
|
34885
|
-
return (_dictionary$normalize = dictionary[normalizedKey]) != null ? _dictionary$normalize : actualValue;
|
|
34874
|
+
return (_dictionary$actualVal = dictionary[actualValue]) != null ? _dictionary$actualVal : actualValue;
|
|
34886
34875
|
};
|
|
34887
34876
|
var getAllChartValues = function getAllChartValues(data, keys) {
|
|
34888
34877
|
var allValues = [];
|
|
@@ -45820,6 +45809,7 @@ function BarGroup(_ref) {
|
|
|
45820
45809
|
var data = _ref.data,
|
|
45821
45810
|
keys = _ref.keys,
|
|
45822
45811
|
height = _ref.height,
|
|
45812
|
+
width = _ref.width,
|
|
45823
45813
|
xKey = _ref.xKey,
|
|
45824
45814
|
xScaleDataType = _ref.xScaleDataType,
|
|
45825
45815
|
xScale = _ref.xScale,
|
|
@@ -45885,7 +45875,8 @@ function BarGroup(_ref) {
|
|
|
45885
45875
|
showLabels: showLabels,
|
|
45886
45876
|
labelDictionary: labelDictionary,
|
|
45887
45877
|
yScale: yScale,
|
|
45888
|
-
containerHeight: height
|
|
45878
|
+
containerHeight: height,
|
|
45879
|
+
chartWidth: width
|
|
45889
45880
|
}, "bar-" + bar.index + "-" + bar.x);
|
|
45890
45881
|
})
|
|
45891
45882
|
}, "bar-group-" + barGroup.index + "-" + barGroup.x0);
|
|
@@ -45893,6 +45884,22 @@ function BarGroup(_ref) {
|
|
|
45893
45884
|
}
|
|
45894
45885
|
});
|
|
45895
45886
|
}
|
|
45887
|
+
function calculateBarLabelPosition(bar, barGroup, chartWidth, displayValue) {
|
|
45888
|
+
if (!displayValue) return false;
|
|
45889
|
+
var ESTIMATED_FONT_WIDTH = 5.75;
|
|
45890
|
+
var minWidthPercent = 0.02;
|
|
45891
|
+
var maxWidthPercent = 0.15;
|
|
45892
|
+
var minWidthPx = chartWidth * minWidthPercent;
|
|
45893
|
+
var maxWidthPx = chartWidth * maxWidthPercent;
|
|
45894
|
+
var minSize = 0.5;
|
|
45895
|
+
var maxSize = 1.2;
|
|
45896
|
+
var normalizedBarWidth = Math.min(Math.max(bar.width, minWidthPx), maxWidthPx);
|
|
45897
|
+
var logInput = 1 + (normalizedBarWidth - minWidthPx) / (maxWidthPx - minWidthPx) * (Math.E - 1);
|
|
45898
|
+
var logRatio = Math.log(logInput);
|
|
45899
|
+
var size = minSize + logRatio * (maxSize - minSize);
|
|
45900
|
+
var basePosition = barGroup.bars.length > 1 ? bar.x + bar.width * size / 2 : bar.width * size / 2;
|
|
45901
|
+
return basePosition - displayValue.length * ESTIMATED_FONT_WIDTH / 2;
|
|
45902
|
+
}
|
|
45896
45903
|
var Bar = function Bar(_ref2) {
|
|
45897
45904
|
var bar = _ref2.bar,
|
|
45898
45905
|
barGroup = _ref2.barGroup,
|
|
@@ -45908,18 +45915,20 @@ var Bar = function Bar(_ref2) {
|
|
|
45908
45915
|
showLabels = _ref2.showLabels,
|
|
45909
45916
|
labelDictionary = _ref2.labelDictionary,
|
|
45910
45917
|
yScale = _ref2.yScale,
|
|
45911
|
-
containerHeight = _ref2.containerHeight
|
|
45918
|
+
containerHeight = _ref2.containerHeight,
|
|
45919
|
+
chartWidth = _ref2.chartWidth;
|
|
45912
45920
|
var X_PADDING = 10;
|
|
45913
45921
|
var Y_PADDING = 8;
|
|
45914
45922
|
var minWidth = 20;
|
|
45915
45923
|
var minContainerHeight = 50;
|
|
45916
45924
|
var showBar = bar.value !== null && bar.height > 0 && bar.width > 0;
|
|
45917
|
-
var labelX = bar.x - X_PADDING;
|
|
45918
45925
|
var barTopY = yScale(bar.value);
|
|
45926
|
+
var labelX = bar.x - X_PADDING;
|
|
45919
45927
|
var labelY = barTopY - Y_PADDING;
|
|
45920
45928
|
var showMinMax = showDataLabel(totalItems);
|
|
45921
45929
|
var hasSpaceForLabel = showLabels && bar.width > minWidth && containerHeight > minContainerHeight;
|
|
45922
45930
|
var displayValue = getFormattedValue(bar.value, labelDictionary);
|
|
45931
|
+
var barPosition = chartWidth ? calculateBarLabelPosition(bar, barGroup, chartWidth, displayValue) : labelX;
|
|
45923
45932
|
return jsxRuntime.jsxs(React.Fragment, {
|
|
45924
45933
|
children: [showBar && jsxRuntime.jsx(BarRect, {
|
|
45925
45934
|
barRectKey: "bar-group-bar-" + barGroup.index + "-" + bar.index + "-" + bar.value + "-" + String(bar.key),
|
|
@@ -45932,8 +45941,8 @@ var Bar = function Bar(_ref2) {
|
|
|
45932
45941
|
return _onClick(e, barGroup, bar);
|
|
45933
45942
|
},
|
|
45934
45943
|
enableHover: enableHover
|
|
45935
|
-
}), hasSpaceForLabel && showMinMax && jsxRuntime.jsx(DataLabel, {
|
|
45936
|
-
x:
|
|
45944
|
+
}), hasSpaceForLabel && showMinMax && barPosition !== false && jsxRuntime.jsx(DataLabel, {
|
|
45945
|
+
x: barPosition,
|
|
45937
45946
|
y: labelY,
|
|
45938
45947
|
title: displayValue,
|
|
45939
45948
|
dx: 1,
|
|
@@ -45963,7 +45972,7 @@ var BarRect = function BarRect(_ref3) {
|
|
|
45963
45972
|
var classes = enableHover ? /*#__PURE__*/css$1.css( {
|
|
45964
45973
|
name: "1ltmijl-classes",
|
|
45965
45974
|
styles: "cursor:pointer;label:classes;",
|
|
45966
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["BarGroup.tsx"],"names":[],"mappings":"AAuNgC","file":"BarGroup.tsx","sourcesContent":["import { css } from '@emotion/css';\nimport { Group } from '@visx/group';\nimport { BarGroup as VisxBarGroup } from '@visx/shape';\nimport { DatumObject } from '@visx/shape/lib/types';\nimport { ScaleBand, ScaleLinear } from '@visx/vendor/d3-scale';\nimport { Fragment, useMemo, useState } from 'react';\nimport { BarStyles } from 'shared-logic/src/BarChartV2/types';\nimport { ChartDataDefinition, ConditionalFormattingRule, ShapeDefinition } from 'shared-logic/src/ChartsV2/types';\nimport { getAllChartValues, getFormattedValue, showDataLabel } from 'shared-logic/src/DataLabel/index';\nimport { DataType } from 'shared-logic/src/Field/types';\nimport { lightenColor } from '../../../styles/color.functions';\nimport { DataLabel } from '../../components/DataLabel';\nimport { BAR_RADIUS } from '../../constants/BORDER_RADIUS';\nimport { getBarFill } from '../getBarFill';\n\nexport type BarGroupProps = {\n  data: ChartDataDefinition[];\n  keys: string[];\n  height: number;\n  xKey: string;\n  xScaleDataType: DataType;\n  xScale: ScaleBand<string> | ScaleBand<Date> | ScaleBand<number> | null;\n  innerXScale: ScaleBand<string> | undefined;\n  yScale: ScaleLinear<number, number, never>;\n  onClick: (e: React.MouseEvent<SVGRectElement, MouseEvent>, barGroup: any, bar: any) => void;\n  conditionalFormattingRules: ConditionalFormattingRule[];\n  bars: ShapeDefinition<BarStyles>[];\n  enableHover?: boolean;\n  yAxisLabels?: string[];\n  yLabelPosition?: number;\n  showDetailedSubGroupingLabels: boolean;\n  labelStyle?: React.CSSProperties;\n  showLabels?: boolean;\n  labelDictionary: { [key: string]: string };\n};\n\nexport function BarGroup({\n  data,\n  keys,\n  height,\n  xKey,\n  xScaleDataType,\n  xScale,\n  innerXScale,\n  yScale,\n  onClick,\n  conditionalFormattingRules,\n  bars,\n  enableHover,\n  yAxisLabels,\n  yLabelPosition,\n  showDetailedSubGroupingLabels,\n  labelStyle,\n  showLabels,\n  labelDictionary,\n}: BarGroupProps) {\n  const getGroupPosition = (d: DatumObject) => {\n    const xValue = d[xKey as keyof typeof d];\n\n    if (xScaleDataType === 'string') return String(xValue);\n\n    if (xScaleDataType === 'date_time') {\n      return new Date(String(xValue));\n    }\n\n    if (xScaleDataType === 'number') {\n      return Number(xValue);\n    }\n\n    return String(xValue);\n  };\n\n  const totalItems = useMemo(() => {\n    const allBarValues = getAllChartValues(data, keys);\n    return allBarValues.length;\n  }, [data, keys]);\n\n  return (\n    <VisxBarGroup<DatumObject>\n      data={data as DatumObject[]}\n      keys={keys}\n      height={height}\n      x0={getGroupPosition}\n      // @ts-ignore\n      x0Scale={xScale}\n      // @ts-ignore\n      x1Scale={innerXScale}\n      yScale={yScale}\n      color={() => ''}\n    >\n      {(barGroups) => {\n        return barGroups.map((barGroup) => (\n          <Group key={`bar-group-${barGroup.index}-${barGroup.x0}`} left={barGroup.x0}>\n            {barGroup.bars.map((bar) => (\n              <Bar\n                key={`bar-${bar.index}-${bar.x}`}\n                bar={bar}\n                barGroup={barGroup}\n                bars={bars}\n                conditionalFormattingRules={conditionalFormattingRules}\n                enableHover={enableHover}\n                labelStyle={labelStyle}\n                onClick={onClick}\n                showDetailedSubGroupingLabels={showDetailedSubGroupingLabels}\n                yAxisLabels={yAxisLabels}\n                yLabelPosition={yLabelPosition}\n                totalItems={totalItems}\n                showLabels={showLabels}\n                labelDictionary={labelDictionary}\n                yScale={yScale}\n                containerHeight={height}\n              />\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  totalItems: number;\n  showLabels?: boolean;\n  labelDictionary?: { [key: string]: string };\n  yScale: ScaleLinear<number, number, never>;\n  containerHeight: number;\n};\n\nconst Bar = ({\n  bar,\n  barGroup,\n  bars,\n  conditionalFormattingRules,\n  enableHover,\n  labelStyle,\n  onClick,\n  showDetailedSubGroupingLabels,\n  yAxisLabels,\n  yLabelPosition,\n  totalItems,\n  showLabels,\n  labelDictionary,\n  yScale,\n  containerHeight,\n}: BarProps) => {\n  const X_PADDING = 10;\n  const Y_PADDING = 8;\n\n  const minWidth = 20;\n  const minContainerHeight = 50;\n\n  const showBar = bar.value !== null && bar.height > 0 && bar.width > 0;\n\n  const labelX = bar.x - X_PADDING;\n  const barTopY = yScale(bar.value);\n  const labelY = barTopY - Y_PADDING;\n\n  const showMinMax = showDataLabel(totalItems);\n  const hasSpaceForLabel = showLabels && bar.width > minWidth && containerHeight > minContainerHeight;\n\n  const displayValue = getFormattedValue(bar.value, labelDictionary);\n\n  return (\n    <Fragment>\n      {showBar && (\n        <BarRect\n          barRectKey={`bar-group-bar-${barGroup.index}-${bar.index}-${bar.value}-${String(bar.key)}`}\n          x={bar.x}\n          y={bar.y}\n          width={bar.width}\n          height={bar.height}\n          fill={getBarFill(bars, conditionalFormattingRules, String(bar.key), bar.value)}\n          onClick={(e) => onClick(e, barGroup, bar)}\n          enableHover={enableHover}\n        />\n      )}\n\n      {hasSpaceForLabel && showMinMax && <DataLabel x={labelX} y={labelY} title={displayValue} dx={1} dy={0} />}\n\n      <BarLabel\n        bar={bar}\n        barGroup={barGroup}\n        yLabelPosition={yLabelPosition}\n        yAxisLabels={yAxisLabels}\n        showDetailedSubGroupingLabels={showDetailedSubGroupingLabels}\n        labelStyle={labelStyle}\n      />\n    </Fragment>\n  );\n};\n\ntype BarRectProps = {\n  onClick: (e: React.MouseEvent<SVGRectElement, MouseEvent>) => void;\n  fill?: string;\n  x: number;\n  y: number;\n  width: number;\n  height: number;\n  barRectKey: string;\n  enableHover?: boolean;\n};\n\nconst BarRect = ({ onClick, fill, x, y, width, height, barRectKey, enableHover }: BarRectProps) => {\n  const [isHovered, setIsHovered] = useState(false);\n\n  const classes = enableHover ? css({ cursor: 'pointer' }) : '';\n\n  const displayColor = isHovered && enableHover ? lightenColor(fill, 0.8) : fill;\n\n  const handleOnMouseEnter = () => {\n    if (enableHover) {\n      setIsHovered(true);\n    }\n  };\n\n  const handleOnMouseLeave = () => {\n    if (enableHover) {\n      setIsHovered(false);\n    }\n  };\n\n  return (\n    <rect\n      key={barRectKey}\n      x={x}\n      y={y}\n      width={width}\n      height={height}\n      fill={displayColor}\n      rx={BAR_RADIUS}\n      onClick={onClick}\n      onMouseEnter={handleOnMouseEnter}\n      onMouseLeave={handleOnMouseLeave}\n      className={classes}\n    />\n  );\n};\n\ntype BarLabelProps = {\n  bar: any;\n  barGroup: any;\n  yLabelPosition?: number;\n  yAxisLabels?: string[];\n  showDetailedSubGroupingLabels: boolean;\n  labelStyle?: React.CSSProperties;\n};\n\nconst BarLabel = ({\n  bar,\n  barGroup,\n  yLabelPosition,\n  yAxisLabels,\n  showDetailedSubGroupingLabels,\n  labelStyle,\n}: BarLabelProps) => {\n  if (!showDetailedSubGroupingLabels || !yLabelPosition || !yAxisLabels) return null;\n\n  const label = yAxisLabels[bar.index];\n  const columnLabel = label.split('•')[0];\n\n  let formattedColumnLabel: string;\n  if (columnLabel.length >= 13) {\n    formattedColumnLabel = columnLabel.slice(0, 10) + '...';\n  } else {\n    formattedColumnLabel = columnLabel.slice(0, 13);\n  }\n\n  const labelXGap = 4;\n  const labelXPosition = bar.x + bar.width / 2 + labelXGap;\n\n  const labelYGap = 15;\n  const labelYPosition = yLabelPosition + labelYGap;\n\n  const labelKey = `label-${barGroup.index}-${bar.index}-${label}`;\n\n  return (\n    <text\n      key={labelKey}\n      x={labelXPosition}\n      y={labelYPosition}\n      style={labelStyle}\n      transform={`rotate(-70, ${labelXPosition}, ${labelYPosition})`}\n      textAnchor=\"end\"\n    >\n      {formattedColumnLabel}\n    </text>\n  );\n};\n"]} */",
|
|
45975
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["BarGroup.tsx"],"names":[],"mappings":"AA2PgC","file":"BarGroup.tsx","sourcesContent":["import { css } from '@emotion/css';\nimport { Group } from '@visx/group';\nimport { BarGroup as VisxBarGroup } from '@visx/shape';\nimport { DatumObject } from '@visx/shape/lib/types';\nimport { ScaleBand, ScaleLinear } from '@visx/vendor/d3-scale';\nimport { Fragment, useMemo, useState } from 'react';\nimport { BarStyles } from 'shared-logic/src/BarChartV2/types';\nimport { ChartDataDefinition, ConditionalFormattingRule, ShapeDefinition } from 'shared-logic/src/ChartsV2/types';\nimport { getAllChartValues, getFormattedValue, showDataLabel } from 'shared-logic/src/DataLabel/index';\nimport { DataType } from 'shared-logic/src/Field/types';\nimport { lightenColor } from '../../../styles/color.functions';\nimport { DataLabel } from '../../components/DataLabel';\nimport { BAR_RADIUS } from '../../constants/BORDER_RADIUS';\nimport { getBarFill } from '../getBarFill';\n\nexport type BarGroupProps = {\n  data: ChartDataDefinition[];\n  keys: string[];\n  height: number;\n  width?: number;\n  xKey: string;\n  xScaleDataType: DataType;\n  xScale: ScaleBand<string> | ScaleBand<Date> | ScaleBand<number> | null;\n  innerXScale: ScaleBand<string> | undefined;\n  yScale: ScaleLinear<number, number, never>;\n  onClick: (e: React.MouseEvent<SVGRectElement, MouseEvent>, barGroup: any, bar: any) => void;\n  conditionalFormattingRules: ConditionalFormattingRule[];\n  bars: ShapeDefinition<BarStyles>[];\n  enableHover?: boolean;\n  yAxisLabels?: string[];\n  yLabelPosition?: number;\n  showDetailedSubGroupingLabels: boolean;\n  labelStyle?: React.CSSProperties;\n  showLabels?: boolean;\n  labelDictionary: { [key: string]: string };\n};\n\nexport function BarGroup({\n  data,\n  keys,\n  height,\n  width,\n  xKey,\n  xScaleDataType,\n  xScale,\n  innerXScale,\n  yScale,\n  onClick,\n  conditionalFormattingRules,\n  bars,\n  enableHover,\n  yAxisLabels,\n  yLabelPosition,\n  showDetailedSubGroupingLabels,\n  labelStyle,\n  showLabels,\n  labelDictionary,\n}: BarGroupProps) {\n  const getGroupPosition = (d: DatumObject) => {\n    const xValue = d[xKey as keyof typeof d];\n\n    if (xScaleDataType === 'string') return String(xValue);\n\n    if (xScaleDataType === 'date_time') {\n      return new Date(String(xValue));\n    }\n\n    if (xScaleDataType === 'number') {\n      return Number(xValue);\n    }\n\n    return String(xValue);\n  };\n\n  const totalItems = useMemo(() => {\n    const allBarValues = getAllChartValues(data, keys);\n    return allBarValues.length;\n  }, [data, keys]);\n\n  return (\n    <VisxBarGroup<DatumObject>\n      data={data as DatumObject[]}\n      keys={keys}\n      height={height}\n      x0={getGroupPosition}\n      // @ts-ignore\n      x0Scale={xScale}\n      // @ts-ignore\n      x1Scale={innerXScale}\n      yScale={yScale}\n      color={() => ''}\n    >\n      {(barGroups) => {\n        return barGroups.map((barGroup) => (\n          <Group key={`bar-group-${barGroup.index}-${barGroup.x0}`} left={barGroup.x0}>\n            {barGroup.bars.map((bar) => (\n              <Bar\n                key={`bar-${bar.index}-${bar.x}`}\n                bar={bar}\n                barGroup={barGroup}\n                bars={bars}\n                conditionalFormattingRules={conditionalFormattingRules}\n                enableHover={enableHover}\n                labelStyle={labelStyle}\n                onClick={onClick}\n                showDetailedSubGroupingLabels={showDetailedSubGroupingLabels}\n                yAxisLabels={yAxisLabels}\n                yLabelPosition={yLabelPosition}\n                totalItems={totalItems}\n                showLabels={showLabels}\n                labelDictionary={labelDictionary}\n                yScale={yScale}\n                containerHeight={height}\n                chartWidth={width}\n              />\n            ))}\n          </Group>\n        ));\n      }}\n    </VisxBarGroup>\n  );\n}\n\nfunction calculateBarLabelPosition(\n  bar: any,\n  barGroup: any,\n  chartWidth: number,\n  displayValue: string | null,\n): number | false {\n  if (!displayValue) return false;\n\n  const ESTIMATED_FONT_WIDTH = 5.75;\n\n  const minWidthPercent = 0.02;\n  const maxWidthPercent = 0.15;\n  const minWidthPx = chartWidth * minWidthPercent;\n  const maxWidthPx = chartWidth * maxWidthPercent;\n\n  const minSize = 0.5;\n  const maxSize = 1.2;\n\n  const normalizedBarWidth = Math.min(Math.max(bar.width, minWidthPx), maxWidthPx);\n  const logInput = 1 + ((normalizedBarWidth - minWidthPx) / (maxWidthPx - minWidthPx)) * (Math.E - 1);\n  const logRatio = Math.log(logInput);\n  const size = minSize + logRatio * (maxSize - minSize);\n\n  const basePosition = barGroup.bars.length > 1 ? bar.x + (bar.width * size) / 2 : (bar.width * size) / 2;\n\n  return basePosition - (displayValue.length * ESTIMATED_FONT_WIDTH) / 2;\n}\n\ntype BarProps = {\n  bar: any;\n  barGroup: any;\n  bars: ShapeDefinition<BarStyles>[];\n  conditionalFormattingRules: ConditionalFormattingRule[];\n  enableHover?: boolean;\n  onClick: (e: React.MouseEvent<SVGRectElement, MouseEvent>, barGroup: any, bar: any) => void;\n  showDetailedSubGroupingLabels: boolean;\n  labelStyle?: React.CSSProperties;\n  yAxisLabels?: string[];\n  yLabelPosition?: number;\n  totalItems: number;\n  showLabels?: boolean;\n  labelDictionary?: { [key: string]: string };\n  yScale: ScaleLinear<number, number, never>;\n  containerHeight: number;\n  chartWidth?: number;\n};\n\nconst Bar = ({\n  bar,\n  barGroup,\n  bars,\n  conditionalFormattingRules,\n  enableHover,\n  labelStyle,\n  onClick,\n  showDetailedSubGroupingLabels,\n  yAxisLabels,\n  yLabelPosition,\n  totalItems,\n  showLabels,\n  labelDictionary,\n  yScale,\n  containerHeight,\n  chartWidth,\n}: BarProps) => {\n  const X_PADDING = 10;\n  const Y_PADDING = 8;\n\n  const minWidth = 20;\n  const minContainerHeight = 50;\n\n  const showBar = bar.value !== null && bar.height > 0 && bar.width > 0;\n\n  const barTopY = yScale(bar.value);\n  const labelX = bar.x - X_PADDING;\n  const labelY = barTopY - Y_PADDING;\n\n  const showMinMax = showDataLabel(totalItems);\n  const hasSpaceForLabel = showLabels && bar.width > minWidth && containerHeight > minContainerHeight;\n\n  const displayValue = getFormattedValue(bar.value, labelDictionary);\n  const barPosition = chartWidth ? calculateBarLabelPosition(bar, barGroup, chartWidth, displayValue) : labelX;\n\n  return (\n    <Fragment>\n      {showBar && (\n        <BarRect\n          barRectKey={`bar-group-bar-${barGroup.index}-${bar.index}-${bar.value}-${String(bar.key)}`}\n          x={bar.x}\n          y={bar.y}\n          width={bar.width}\n          height={bar.height}\n          fill={getBarFill(bars, conditionalFormattingRules, String(bar.key), bar.value)}\n          onClick={(e) => onClick(e, barGroup, bar)}\n          enableHover={enableHover}\n        />\n      )}\n\n      {hasSpaceForLabel && showMinMax && barPosition !== false && (\n        <DataLabel x={barPosition} y={labelY} title={displayValue} dx={1} dy={0} />\n      )}\n\n      <BarLabel\n        bar={bar}\n        barGroup={barGroup}\n        yLabelPosition={yLabelPosition}\n        yAxisLabels={yAxisLabels}\n        showDetailedSubGroupingLabels={showDetailedSubGroupingLabels}\n        labelStyle={labelStyle}\n      />\n    </Fragment>\n  );\n};\n\ntype BarRectProps = {\n  onClick: (e: React.MouseEvent<SVGRectElement, MouseEvent>) => void;\n  fill?: string;\n  x: number;\n  y: number;\n  width: number;\n  height: number;\n  barRectKey: string;\n  enableHover?: boolean;\n};\n\nconst BarRect = ({ onClick, fill, x, y, width, height, barRectKey, enableHover }: BarRectProps) => {\n  const [isHovered, setIsHovered] = useState(false);\n\n  const classes = enableHover ? css({ cursor: 'pointer' }) : '';\n\n  const displayColor = isHovered && enableHover ? lightenColor(fill, 0.8) : fill;\n\n  const handleOnMouseEnter = () => {\n    if (enableHover) {\n      setIsHovered(true);\n    }\n  };\n\n  const handleOnMouseLeave = () => {\n    if (enableHover) {\n      setIsHovered(false);\n    }\n  };\n\n  return (\n    <rect\n      key={barRectKey}\n      x={x}\n      y={y}\n      width={width}\n      height={height}\n      fill={displayColor}\n      rx={BAR_RADIUS}\n      onClick={onClick}\n      onMouseEnter={handleOnMouseEnter}\n      onMouseLeave={handleOnMouseLeave}\n      className={classes}\n    />\n  );\n};\n\ntype BarLabelProps = {\n  bar: any;\n  barGroup: any;\n  yLabelPosition?: number;\n  yAxisLabels?: string[];\n  showDetailedSubGroupingLabels: boolean;\n  labelStyle?: React.CSSProperties;\n};\n\nconst BarLabel = ({\n  bar,\n  barGroup,\n  yLabelPosition,\n  yAxisLabels,\n  showDetailedSubGroupingLabels,\n  labelStyle,\n}: BarLabelProps) => {\n  if (!showDetailedSubGroupingLabels || !yLabelPosition || !yAxisLabels) return null;\n\n  const label = yAxisLabels[bar.index];\n  const columnLabel = label.split('•')[0];\n\n  let formattedColumnLabel: string;\n  if (columnLabel.length >= 13) {\n    formattedColumnLabel = columnLabel.slice(0, 10) + '...';\n  } else {\n    formattedColumnLabel = columnLabel.slice(0, 13);\n  }\n\n  const labelXGap = 4;\n  const labelXPosition = bar.x + bar.width / 2 + labelXGap;\n\n  const labelYGap = 15;\n  const labelYPosition = yLabelPosition + labelYGap;\n\n  const labelKey = `label-${barGroup.index}-${bar.index}-${label}`;\n\n  return (\n    <text\n      key={labelKey}\n      x={labelXPosition}\n      y={labelYPosition}\n      style={labelStyle}\n      transform={`rotate(-70, ${labelXPosition}, ${labelYPosition})`}\n      textAnchor=\"end\"\n    >\n      {formattedColumnLabel}\n    </text>\n  );\n};\n"]} */",
|
|
45967
45976
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$9
|
|
45968
45977
|
}) : '';
|
|
45969
45978
|
var displayColor = isHovered && enableHover ? lightenColor$2(fill, 0.8) : fill;
|
|
@@ -46398,6 +46407,7 @@ var BarChart$5 = function BarChart(_ref) {
|
|
|
46398
46407
|
data: dataFlattened,
|
|
46399
46408
|
keys: yScaleKeys,
|
|
46400
46409
|
height: innerHeight,
|
|
46410
|
+
width: width,
|
|
46401
46411
|
xKey: xKey,
|
|
46402
46412
|
xScaleDataType: xScaleDataType,
|
|
46403
46413
|
xScale: xScale,
|
|
@@ -50003,6 +50013,24 @@ var buildLineChartRepresentation = function buildLineChartRepresentation(_ref) {
|
|
|
50003
50013
|
return chart;
|
|
50004
50014
|
};
|
|
50005
50015
|
|
|
50016
|
+
var sortDateTimeByDefault = function sortDateTimeByDefault(attributes, dataSet, queryEngineConfig) {
|
|
50017
|
+
if (attributes.order.length > 0) {
|
|
50018
|
+
return attributes.order;
|
|
50019
|
+
}
|
|
50020
|
+
var automaticOrders = [];
|
|
50021
|
+
attributes.dimension.forEach(function (dimension) {
|
|
50022
|
+
var dimensionField = findField(dataSet, dimension.field);
|
|
50023
|
+
if (dimensionField.dataType === 'date_time' && queryEngineConfig.supportedTimeTruncFunctions[dimension["function"]]) {
|
|
50024
|
+
automaticOrders.push({
|
|
50025
|
+
field: dimension.field,
|
|
50026
|
+
direction: 'asc',
|
|
50027
|
+
"function": dimension["function"]
|
|
50028
|
+
});
|
|
50029
|
+
}
|
|
50030
|
+
});
|
|
50031
|
+
return automaticOrders;
|
|
50032
|
+
};
|
|
50033
|
+
|
|
50006
50034
|
var LineChartV2View = function LineChartV2View(props) {
|
|
50007
50035
|
var _props$library, _props$attributes$vie;
|
|
50008
50036
|
var _useDashboardBehaviou = useDashboardBehaviourContext(),
|
|
@@ -50048,7 +50076,7 @@ var LineChartV2View = function LineChartV2View(props) {
|
|
|
50048
50076
|
nullValue: checkForNullValue(props.attributes.dataSetId, props.attributes.dimension, props.attributes.timeDimension, textOverride, valueAlias),
|
|
50049
50077
|
result: props.result,
|
|
50050
50078
|
pivotConfig: pivotConfig,
|
|
50051
|
-
order: props.attributes.
|
|
50079
|
+
order: sortDateTimeByDefault(props.attributes, props.dataSet, queryEngineConfig),
|
|
50052
50080
|
numberFormatOptions: props.numberFormatOptions,
|
|
50053
50081
|
dateTimeFormatOptions: props.dateTimeFormatOptions,
|
|
50054
50082
|
goalLineAttributes: (_props$attributes$goa = props.attributes.goalLines) != null ? _props$attributes$goa : [],
|
|
@@ -50419,7 +50447,7 @@ var AreaChartV2View = function AreaChartV2View(props) {
|
|
|
50419
50447
|
nullValue: checkForNullValue(props.attributes.dataSetId, props.attributes.dimension, props.attributes.timeDimension, textOverride, valueAlias),
|
|
50420
50448
|
result: props.result,
|
|
50421
50449
|
pivotConfig: pivotConfig,
|
|
50422
|
-
order: props.attributes.
|
|
50450
|
+
order: sortDateTimeByDefault(props.attributes, props.dataSet, queryEngineConfig),
|
|
50423
50451
|
numberFormatOptions: props.numberFormatOptions,
|
|
50424
50452
|
dateTimeFormatOptions: props.dateTimeFormatOptions,
|
|
50425
50453
|
goalLineAttributes: (_props$attributes$goa = props.attributes.goalLines) != null ? _props$attributes$goa : [],
|
|
@@ -57043,10 +57071,9 @@ var Bar$2 = function Bar(_ref4) {
|
|
|
57043
57071
|
var labelX = bar.x - xPadding;
|
|
57044
57072
|
var labelY = getStepYPosition(step, barHeight, y);
|
|
57045
57073
|
var isFirstOrLastStep = barGroup.index === 0 || barGroup.index === totalItems - 1;
|
|
57046
|
-
var
|
|
57047
|
-
var displayValue = getFormattedValue(keyValue, labelDictionary);
|
|
57074
|
+
var displayValue = getFormattedValue(bar.value, labelDictionary);
|
|
57048
57075
|
var unformattedValue = displayValue.length > 15;
|
|
57049
|
-
if (unformattedValue) displayValue =
|
|
57076
|
+
if (unformattedValue) displayValue = bar.value;
|
|
57050
57077
|
var showMinMax = unformattedValue ? isFirstOrLastStep : totalItems < 20 || isFirstOrLastStep;
|
|
57051
57078
|
var shouldShowLabel = showLabels && showMinMax;
|
|
57052
57079
|
return jsxRuntime.jsxs(jsxRuntime.Fragment, {
|
|
@@ -64408,8 +64435,24 @@ var ComboChartCompareSection = function ComboChartCompareSection(props) {
|
|
|
64408
64435
|
setPartialAttributes: function setPartialAttributes(attr) {
|
|
64409
64436
|
if (attr['timeDimensions']) {
|
|
64410
64437
|
var _attr$timeDimensions$;
|
|
64438
|
+
var newTimeDimension = (_attr$timeDimensions$ = attr['timeDimensions'][0]) != null ? _attr$timeDimensions$ : null;
|
|
64439
|
+
var comboAttrs = props.attributes;
|
|
64440
|
+
var orderField = [].concat(comboAttrs.order);
|
|
64441
|
+
if (newTimeDimension) {
|
|
64442
|
+
var existingOrderIndex = orderField.findIndex(function (order) {
|
|
64443
|
+
return order.field === newTimeDimension.field && order["function"] === newTimeDimension.truncate;
|
|
64444
|
+
});
|
|
64445
|
+
if (existingOrderIndex === -1) {
|
|
64446
|
+
orderField.push({
|
|
64447
|
+
field: newTimeDimension.field,
|
|
64448
|
+
direction: 'asc',
|
|
64449
|
+
"function": newTimeDimension.truncate
|
|
64450
|
+
});
|
|
64451
|
+
}
|
|
64452
|
+
}
|
|
64411
64453
|
props == null || props.setAttributes({
|
|
64412
|
-
timeDimension:
|
|
64454
|
+
timeDimension: newTimeDimension,
|
|
64455
|
+
order: orderField
|
|
64413
64456
|
});
|
|
64414
64457
|
}
|
|
64415
64458
|
}
|