@fluentui/react-charts 0.0.0-nightly-20250603-0406.1 → 0.0.0-nightly-20250605-0406.1

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.
Files changed (61) hide show
  1. package/CHANGELOG.md +15 -15
  2. package/dist/index.d.ts +1 -1
  3. package/lib/components/CommonComponents/CartesianChart.js +3 -0
  4. package/lib/components/CommonComponents/CartesianChart.js.map +1 -1
  5. package/lib/components/CommonComponents/CartesianChart.types.js.map +1 -1
  6. package/lib/components/CommonComponents/ChartPopover.js +10 -10
  7. package/lib/components/CommonComponents/ChartPopover.js.map +1 -1
  8. package/lib/components/DeclarativeChart/DeclarativeChart.js +7 -2
  9. package/lib/components/DeclarativeChart/DeclarativeChart.js.map +1 -1
  10. package/lib/components/DeclarativeChart/PlotlySchemaAdapter.js +7 -4
  11. package/lib/components/DeclarativeChart/PlotlySchemaAdapter.js.map +1 -1
  12. package/lib/components/DonutChart/Arc/Arc.js +2 -2
  13. package/lib/components/DonutChart/Arc/Arc.js.map +1 -1
  14. package/lib/components/DonutChart/DonutChart.js +2 -2
  15. package/lib/components/DonutChart/DonutChart.js.map +1 -1
  16. package/lib/components/GaugeChart/GaugeChart.js +9 -9
  17. package/lib/components/GaugeChart/GaugeChart.js.map +1 -1
  18. package/lib/components/GroupedVerticalBarChart/GroupedVerticalBarChart.js +2 -2
  19. package/lib/components/GroupedVerticalBarChart/GroupedVerticalBarChart.js.map +1 -1
  20. package/lib/components/HeatMapChart/HeatMapChart.js +3 -2
  21. package/lib/components/HeatMapChart/HeatMapChart.js.map +1 -1
  22. package/lib/components/HorizontalBarChart/HorizontalBarChart.js +8 -8
  23. package/lib/components/HorizontalBarChart/HorizontalBarChart.js.map +1 -1
  24. package/lib/components/VerticalBarChart/VerticalBarChart.js +2 -2
  25. package/lib/components/VerticalBarChart/VerticalBarChart.js.map +1 -1
  26. package/lib/components/VerticalStackedBarChart/VerticalStackedBarChart.js +2 -2
  27. package/lib/components/VerticalStackedBarChart/VerticalStackedBarChart.js.map +1 -1
  28. package/lib/utilities/utilities.js +232 -53
  29. package/lib/utilities/utilities.js.map +1 -1
  30. package/lib-commonjs/components/CommonComponents/CartesianChart.js +3 -0
  31. package/lib-commonjs/components/CommonComponents/CartesianChart.js.map +1 -1
  32. package/lib-commonjs/components/CommonComponents/CartesianChart.types.js.map +1 -1
  33. package/lib-commonjs/components/CommonComponents/ChartPopover.js +10 -10
  34. package/lib-commonjs/components/CommonComponents/ChartPopover.js.map +1 -1
  35. package/lib-commonjs/components/DeclarativeChart/DeclarativeChart.js +6 -1
  36. package/lib-commonjs/components/DeclarativeChart/DeclarativeChart.js.map +1 -1
  37. package/lib-commonjs/components/DeclarativeChart/PlotlySchemaAdapter.js +6 -3
  38. package/lib-commonjs/components/DeclarativeChart/PlotlySchemaAdapter.js.map +1 -1
  39. package/lib-commonjs/components/DonutChart/Arc/Arc.js +1 -1
  40. package/lib-commonjs/components/DonutChart/Arc/Arc.js.map +1 -1
  41. package/lib-commonjs/components/DonutChart/DonutChart.js +2 -2
  42. package/lib-commonjs/components/DonutChart/DonutChart.js.map +1 -1
  43. package/lib-commonjs/components/GaugeChart/GaugeChart.js +8 -8
  44. package/lib-commonjs/components/GaugeChart/GaugeChart.js.map +1 -1
  45. package/lib-commonjs/components/GroupedVerticalBarChart/GroupedVerticalBarChart.js +1 -1
  46. package/lib-commonjs/components/GroupedVerticalBarChart/GroupedVerticalBarChart.js.map +1 -1
  47. package/lib-commonjs/components/HeatMapChart/HeatMapChart.js +2 -1
  48. package/lib-commonjs/components/HeatMapChart/HeatMapChart.js.map +1 -1
  49. package/lib-commonjs/components/HorizontalBarChart/HorizontalBarChart.js +7 -7
  50. package/lib-commonjs/components/HorizontalBarChart/HorizontalBarChart.js.map +1 -1
  51. package/lib-commonjs/components/VerticalBarChart/VerticalBarChart.js +1 -1
  52. package/lib-commonjs/components/VerticalBarChart/VerticalBarChart.js.map +1 -1
  53. package/lib-commonjs/components/VerticalStackedBarChart/VerticalStackedBarChart.js +1 -1
  54. package/lib-commonjs/components/VerticalStackedBarChart/VerticalStackedBarChart.js.map +1 -1
  55. package/lib-commonjs/utilities/utilities.js +236 -61
  56. package/lib-commonjs/utilities/utilities.js.map +1 -1
  57. package/package.json +13 -13
  58. package/lib/utilities/locale-util.js +0 -15
  59. package/lib/utilities/locale-util.js.map +0 -1
  60. package/lib-commonjs/utilities/locale-util.js +0 -25
  61. package/lib-commonjs/utilities/locale-util.js.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"sources":["HorizontalBarChart.tsx"],"sourcesContent":["import * as React from 'react';\nimport { useHorizontalBarChartStyles } from './useHorizontalBarChartStyles.styles';\nimport { ChartProps, HorizontalBarChartProps, ChartDataPoint, RefArrayData, HorizontalBarChartVariant } from './index';\nimport { convertToLocaleString } from '../../utilities/locale-util';\nimport { formatValueWithSIPrefix, getAccessibleDataObject, useRtl } from '../../utilities/index';\nimport { useId } from '@fluentui/react-utilities';\nimport { tokens } from '@fluentui/react-theme';\nimport { useFocusableGroup } from '@fluentui/react-tabster';\nimport { ChartPopover } from '../CommonComponents/ChartPopover';\nimport { FocusableTooltipText } from '../../utilities/FocusableTooltipText';\nimport { Legend, Legends } from '../../index';\n\n/**\n * HorizontalBarChart is the context wrapper and container for all HorizontalBarChart content/controls,\n * It has no direct style or slot opinions.\n *\n * HorizontalBarChart also provides API interfaces for callbacks that will occur on navigation events.\n */\nexport const HorizontalBarChart: React.FunctionComponent<HorizontalBarChartProps> = React.forwardRef<\n HTMLDivElement,\n HorizontalBarChartProps\n>((props, forwardedRef) => {\n const legendContainer = React.useRef<HTMLDivElement | null>(null);\n const _uniqLineText: string = '_HorizontalLine_' + Math.random().toString(36).substring(7);\n const _refArray: RefArrayData[] = [];\n const _isRTL: boolean = useRtl();\n const barChartSvgRef: React.RefObject<SVGSVGElement> = React.createRef<SVGSVGElement>();\n const _emptyChartId: string = useId('_HBC_empty');\n let _barHeight: number;\n let _calloutAnchorPoint: ChartDataPoint | null;\n let isSingleBar: boolean = true;\n\n const [hoverValue, setHoverValue] = React.useState<string | number | Date | null>('');\n const [lineColor, setLineColor] = React.useState<string>('');\n const [legend, setLegend] = React.useState<string | null>('');\n const [xCalloutValue, setXCalloutValue] = React.useState<string | undefined>('');\n const [yCalloutValue, setYCalloutValue] = React.useState<string | undefined>('');\n const [barCalloutProps, setBarCalloutProps] = React.useState<ChartDataPoint>();\n const [barSpacingInPercent, setBarSpacingInPercent] = React.useState<number>(0);\n const [isPopoverOpen, setPopoverOpen] = React.useState<boolean>(false);\n const [clickPosition, setClickPosition] = React.useState({ x: 0, y: 0 });\n const [selectedLegend, setSelectedLegend] = React.useState<string>('');\n const [activeLegend, setActiveLegend] = React.useState<string>('');\n\n function _refCallback(element: SVGGElement, legendTitle: string | undefined): void {\n _refArray.push({ index: legendTitle, refElement: element });\n }\n\n function _hoverOn(\n event: React.MouseEvent<SVGRectElement, MouseEvent>,\n hoverVal: string | number | Date,\n point: ChartDataPoint,\n ): void {\n if (\n (!isPopoverOpen || legend !== point.legend!) &&\n _calloutAnchorPoint !== point &&\n (_legendHighlighted(point.legend) || _noLegendHighlighted())\n ) {\n _calloutAnchorPoint = point;\n updatePosition(event.clientX, event.clientY);\n setHoverValue(hoverVal);\n setLineColor(point.color!);\n setLegend(point.legend!);\n setXCalloutValue(point.xAxisCalloutData!);\n setYCalloutValue(point.yAxisCalloutData!);\n setBarCalloutProps(point);\n // ToDo - Confirm setting multiple state variables like this is performant.\n }\n }\n\n function _hoverOff(): void {\n /*ToDo. To fix*/\n }\n\n const _handleChartMouseLeave = () => {\n _calloutAnchorPoint = null;\n if (isPopoverOpen) {\n setPopoverOpen(false);\n setHoverValue('');\n setLineColor('');\n setLegend('');\n }\n };\n\n const _adjustProps = (): void => {\n _barHeight = props.barHeight || 12;\n };\n\n const _getChartDataText = (data: ChartProps) => {\n /* return props.barChartCustomData ? (\n <div role=\"text\">{props.barChartCustomData(data)}</div>\n ) : ( */\n return _getDefaultTextData(data);\n //)\n };\n\n function _createLegends(chartProps: ChartProps[]): JSX.Element {\n const legendItems: Legend[] = [];\n chartProps.forEach((point: ChartProps) => {\n point.chartData!.forEach((dataPoint: ChartDataPoint) => {\n const color: string = dataPoint.color!;\n // mapping data to the format Legends component needs\n const legendItem: Legend = {\n title: dataPoint.legend!,\n color,\n action: () => {\n if (selectedLegend === dataPoint.legend) {\n setSelectedLegend('');\n } else {\n setSelectedLegend(dataPoint.legend!);\n }\n },\n hoverAction: () => {\n _handleChartMouseLeave();\n setActiveLegend(dataPoint.legend!);\n },\n onMouseOutAction: () => {\n setActiveLegend('');\n },\n };\n legendItems.push(legendItem);\n });\n });\n const legends = (\n <Legends legends={legendItems} centerLegends overflowText={props.legendsOverflowText} {...props.legendProps} />\n );\n return legends;\n }\n\n function _getDefaultTextData(data: ChartProps): JSX.Element {\n const { culture } = props;\n const accessibilityData = getAccessibleDataObject(data.chartDataAccessibilityData!, 'text', false);\n if (!isSingleBar) {\n const total = data.chartData!.reduce(\n (acc: number, point: ChartDataPoint) =>\n acc + (point.horizontalBarChartdata!.x ? point.horizontalBarChartdata!.x : 0),\n 0,\n );\n return (\n <div className={classes.chartTitleRight} {...accessibilityData}>\n {convertToLocaleString(total, culture)}\n </div>\n );\n }\n const chartDataMode = props.chartDataMode || 'default';\n const chartData: ChartDataPoint = data!.chartData![0];\n const x = chartData.horizontalBarChartdata!.x;\n const y = chartData.horizontalBarChartdata!.total!;\n\n switch (chartDataMode) {\n case 'default':\n return (\n <div className={classes.chartTitleRight} {...accessibilityData}>\n {convertToLocaleString(x, culture)}\n </div>\n );\n case 'fraction':\n return (\n <div {...accessibilityData}>\n <span className={classes.chartTitleRight}>{convertToLocaleString(x, culture)}</span>\n <span className={classes.chartDataTextDenominator}>{' / ' + convertToLocaleString(y, culture)}</span>\n </div>\n );\n case 'percentage':\n const dataRatioPercentage = `${convertToLocaleString(Math.round((x / y) * 100), culture)}%`;\n return (\n <div className={classes.chartTitleRight} {...accessibilityData}>\n {dataRatioPercentage}\n </div>\n );\n }\n }\n\n function _createBenchmark(data: ChartProps): JSX.Element {\n if (data.chartData![0].horizontalBarChartdata!.total === undefined) {\n return <></>;\n }\n const totalData = data.chartData![0].horizontalBarChartdata!.total!;\n const benchmarkData = data.chartData![0].data;\n const benchmarkRatio = Math.round(((benchmarkData ? benchmarkData : 0) / totalData) * 100);\n\n const benchmarkStyles = {\n left: 'calc(' + benchmarkRatio + '% - 4px)',\n };\n\n return (\n <div className={classes.benchmarkContainer}>\n <div className={classes.triangle} style={benchmarkStyles} />\n </div>\n );\n }\n\n /**\n * This functions returns an array of <rect> elements, which form the bars\n * For each bar an x value, and a width needs to be specified\n * The computations are done based on percentages\n * Extra margin is also provided, in the x value to provide some spacing in between the bars\n */\n\n function _createBars(data: ChartProps): JSX.Element[] {\n const noOfBars =\n data.chartData?.reduce((count: number, point: ChartDataPoint) => (count += (point.data || 0) > 0 ? 1 : 0), 0) ||\n 1;\n const totalMarginPercent = barSpacingInPercent * (noOfBars - 1);\n const defaultColors: string[] = [\n tokens.colorPaletteBlueForeground2,\n tokens.colorPaletteCornflowerForeground2,\n tokens.colorPaletteDarkGreenForeground2,\n tokens.colorPaletteNavyForeground2,\n tokens.colorPaletteDarkOrangeForeground2,\n ];\n // calculating starting point of each bar and it's range\n const startingPoint: number[] = [];\n const total = data.chartData!.reduce(\n (acc: number, point: ChartDataPoint) =>\n acc + (point.horizontalBarChartdata!.x ? point.horizontalBarChartdata!.x : 0),\n 0,\n );\n let prevPosition = 0;\n let value = 0;\n\n let sumOfPercent = 0;\n data.chartData!.map((point: ChartDataPoint, index: number) => {\n const pointData = point.horizontalBarChartdata!.x ? point.horizontalBarChartdata!.x : 0;\n value = (pointData / total) * 100;\n if (value < 0) {\n value = 0;\n } else if (value < 1 && value !== 0) {\n value = 1;\n }\n sumOfPercent += value;\n\n return sumOfPercent;\n });\n\n /**\n * The %age of the space occupied by the margin needs to subtracted\n * while computing the scaling ratio, since the margins are not being\n * scaled down, only the data is being scaled down from a higher percentage to lower percentage\n * Eg: 95% of the space is taken by the bars, 5% by the margins\n * Now if the sumOfPercent is 120% -> This needs to be scaled down to 95%, not 100%\n * since that's only space available to the bars\n */\n const scalingRatio = sumOfPercent !== 0 ? (sumOfPercent - totalMarginPercent) / 100 : 1;\n\n const bars = data.chartData!.map((point: ChartDataPoint, index: number) => {\n const color: string = point.color ? point.color : defaultColors[Math.floor(Math.random() * 4 + 1)];\n const pointData = point.horizontalBarChartdata!.x ? point.horizontalBarChartdata!.x : 0;\n if (index > 0) {\n prevPosition += value;\n }\n value = (pointData / total) * 100;\n if (value < 0) {\n value = 0;\n } else if (value < 1 && value !== 0) {\n value = 1 / scalingRatio;\n } else {\n value = value / scalingRatio;\n }\n startingPoint.push(prevPosition);\n\n const xValue = point.horizontalBarChartdata!.x;\n const placeholderIndex = 1;\n const isLegendSelected: boolean = _legendHighlighted(point.legend) || _noLegendHighlighted();\n\n // Render bar label instead of placeholder bar for absolute-scale variant\n if (index === placeholderIndex && props.variant === HorizontalBarChartVariant.AbsoluteScale) {\n if (props.hideLabels) {\n return <text key={index} />;\n }\n\n const barValue = data.chartData![0].horizontalBarChartdata!.x;\n\n return (\n <text\n key={index}\n x={`${_isRTL ? 100 - startingPoint[index] : startingPoint[index]}%`}\n y={_barHeight / 2}\n dominantBaseline=\"central\"\n transform={`translate(${_isRTL ? -4 : 4})`}\n className={classes.barLabel}\n aria-hidden={true}\n >\n {formatValueWithSIPrefix(barValue)}\n </text>\n );\n }\n\n return (\n <rect\n key={index}\n x={`${\n _isRTL\n ? 100 - startingPoint[index] - value - index * barSpacingInPercent\n : startingPoint[index] + index * barSpacingInPercent\n }%`}\n y={0}\n data-is-focusable={point.legend !== '' ? true : false}\n width={value + '%'}\n height={_barHeight}\n fill={color}\n onMouseOver={point.legend !== '' ? event => _hoverOn(event, xValue, point) : undefined}\n onFocus={point.legend !== '' ? event => _hoverOn.bind(event, xValue, point) : undefined}\n role=\"img\"\n aria-label={_getAriaLabel(point)}\n onBlur={_hoverOff}\n onMouseLeave={_hoverOff}\n className={classes.barWrapper}\n opacity={isLegendSelected ? 1 : 0.1}\n tabIndex={point.legend !== '' ? 0 : undefined}\n />\n );\n });\n return bars;\n }\n\n const _getAriaLabel = (point: ChartDataPoint): string => {\n const legend = point.xAxisCalloutData || point.legend;\n const yValue =\n point.yAxisCalloutData ||\n (point.horizontalBarChartdata\n ? `${point.horizontalBarChartdata.x}/${point.horizontalBarChartdata.total ?? ''}`\n : 0);\n return point.callOutAccessibilityData?.ariaLabel || (legend ? `${legend}, ` : '') + `${yValue}.`;\n };\n\n function _isChartEmpty(): boolean {\n return !(props.data && props.data.length > 0);\n }\n\n function updatePosition(newX: number, newY: number): void {\n const threshold = 1; // Set a threshold for movement\n const { x, y } = clickPosition;\n\n // Calculate the distance moved\n const distance = Math.sqrt(Math.pow(newX - x, 2) + Math.pow(newY - y, 2));\n // Update the position only if the distance moved is greater than the threshold\n if (distance > threshold) {\n setClickPosition({ x: newX, y: newY });\n setPopoverOpen(true);\n }\n }\n\n React.useEffect(() => {\n const svgWidth = barChartSvgRef?.current?.getBoundingClientRect().width || 0;\n const MARGIN_WIDTH_IN_PX = 3;\n if (svgWidth) {\n const currentBarSpacing = (MARGIN_WIDTH_IN_PX / svgWidth) * 100;\n setBarSpacingInPercent(currentBarSpacing);\n }\n }, [barChartSvgRef]);\n\n function _legendHighlighted(barLegend?: string) {\n if (barLegend === undefined) {\n return false;\n }\n return selectedLegend === barLegend || (selectedLegend === '' && activeLegend === barLegend);\n }\n\n /**\n * This function checks if none of the legends is selected or hovered.*/\n\n function _noLegendHighlighted() {\n return selectedLegend === '' && activeLegend === '';\n }\n\n const { data } = props;\n _adjustProps();\n const classes = useHorizontalBarChartStyles(props);\n const focusAttributes = useFocusableGroup();\n const legendButtons = _createLegends(data!);\n\n let datapoint: number | undefined = 0;\n return !_isChartEmpty() ? (\n <div className={classes.root} onMouseLeave={_handleChartMouseLeave}>\n {data!.map((points: ChartProps, index: number) => {\n if (points.chartData && points.chartData![0] && points.chartData![0].horizontalBarChartdata!.x) {\n datapoint = points.chartData![0].horizontalBarChartdata!.x;\n } else {\n datapoint = 0;\n }\n isSingleBar =\n points.chartData!.length === 1 || (points.chartData!.length > 1 && points.chartData![1].legend === '');\n if (isSingleBar) {\n points.chartData![1] = {\n legend: '',\n horizontalBarChartdata: {\n x: points.chartData![0].horizontalBarChartdata!.total! - datapoint!,\n total: points.chartData![0].horizontalBarChartdata!.total!,\n },\n color: tokens.colorBackgroundOverlay,\n };\n }\n\n // Hide right side text of chart title for absolute-scale variant\n const chartDataText =\n props.variant === HorizontalBarChartVariant.AbsoluteScale ? null : _getChartDataText(points!);\n const bars = _createBars(points!);\n const keyVal = _uniqLineText + '_' + index;\n // ToDo - Showtriangle property is per data series. How to account for it in the new stylesheet\n /* const classes = useHorizontalBarChartStyles(props.styles!, {\n width: props.width,\n showTriangle: !!points!.chartData![0].data,\n variant: props.variant,\n }); */\n\n return (\n <div key={index}>\n <div className={classes.items} {...focusAttributes}>\n <div className={classes.chartTitle}>\n {points!.chartTitle && (\n <FocusableTooltipText\n className={classes.chartTitleLeft}\n content={points!.chartTitle}\n accessibilityData={points!.chartTitleAccessibilityData}\n />\n )}\n {chartDataText}\n </div>\n {points!.chartData![0].data && _createBenchmark(points!)}\n <svg ref={barChartSvgRef} className={classes.chart} aria-label={points!.chartTitle}>\n <g\n id={keyVal}\n key={keyVal}\n ref={(e: SVGGElement) => {\n _refCallback(e, points!.chartData![0].legend);\n }}\n // NOTE: points.chartData![0] contains current data value\n onClick={() => {\n const p = points!.chartData![0];\n if (p && p.onClick) {\n p.onClick();\n }\n }}\n >\n {bars}\n </g>\n </svg>\n </div>\n </div>\n );\n })}\n <ChartPopover\n xCalloutValue={xCalloutValue}\n yCalloutValue={yCalloutValue}\n culture={props.culture ?? 'en-us'}\n clickPosition={clickPosition}\n isPopoverOpen={isPopoverOpen}\n legend={legend!}\n YValue={hoverValue!}\n color={lineColor}\n isCalloutForStack={false}\n customCallout={{\n customizedCallout: props.onRenderCalloutPerHorizontalBar\n ? props.onRenderCalloutPerHorizontalBar(barCalloutProps!)\n : undefined,\n customCalloutProps: props.calloutPropsPerDataPoint\n ? props.calloutPropsPerDataPoint(barCalloutProps!)\n : undefined,\n }}\n isCartesian={false}\n />\n {!isSingleBar && (\n <div ref={(e: HTMLDivElement) => (legendContainer.current = e)} className={classes.legendContainer}>\n {legendButtons}\n </div>\n )}\n </div>\n ) : (\n <div id={_emptyChartId} role={'alert'} style={{ opacity: '0' }} aria-label={'Graph has no data to display'} />\n );\n //TODO validate and fix focus border for issue for popover\n});\nHorizontalBarChart.displayName = 'HorizontalBarChart';\n"],"names":["React","useHorizontalBarChartStyles","HorizontalBarChartVariant","convertToLocaleString","formatValueWithSIPrefix","getAccessibleDataObject","useRtl","useId","tokens","useFocusableGroup","ChartPopover","FocusableTooltipText","Legends","HorizontalBarChart","forwardRef","props","forwardedRef","legendContainer","useRef","_uniqLineText","Math","random","toString","substring","_refArray","_isRTL","barChartSvgRef","createRef","_emptyChartId","_barHeight","_calloutAnchorPoint","isSingleBar","hoverValue","setHoverValue","useState","lineColor","setLineColor","legend","setLegend","xCalloutValue","setXCalloutValue","yCalloutValue","setYCalloutValue","barCalloutProps","setBarCalloutProps","barSpacingInPercent","setBarSpacingInPercent","isPopoverOpen","setPopoverOpen","clickPosition","setClickPosition","x","y","selectedLegend","setSelectedLegend","activeLegend","setActiveLegend","_refCallback","element","legendTitle","push","index","refElement","_hoverOn","event","hoverVal","point","_legendHighlighted","_noLegendHighlighted","updatePosition","clientX","clientY","color","xAxisCalloutData","yAxisCalloutData","_hoverOff","_handleChartMouseLeave","_adjustProps","barHeight","_getChartDataText","data","_getDefaultTextData","_createLegends","chartProps","legendItems","forEach","chartData","dataPoint","legendItem","title","action","hoverAction","onMouseOutAction","legends","centerLegends","overflowText","legendsOverflowText","legendProps","culture","accessibilityData","chartDataAccessibilityData","total","reduce","acc","horizontalBarChartdata","div","className","classes","chartTitleRight","chartDataMode","span","chartDataTextDenominator","dataRatioPercentage","round","_createBenchmark","undefined","totalData","benchmarkData","benchmarkRatio","benchmarkStyles","left","benchmarkContainer","triangle","style","_createBars","noOfBars","count","totalMarginPercent","defaultColors","colorPaletteBlueForeground2","colorPaletteCornflowerForeground2","colorPaletteDarkGreenForeground2","colorPaletteNavyForeground2","colorPaletteDarkOrangeForeground2","startingPoint","prevPosition","value","sumOfPercent","map","pointData","scalingRatio","bars","floor","xValue","placeholderIndex","isLegendSelected","variant","AbsoluteScale","hideLabels","text","key","barValue","dominantBaseline","transform","barLabel","aria-hidden","rect","data-is-focusable","width","height","fill","onMouseOver","onFocus","bind","role","aria-label","_getAriaLabel","onBlur","onMouseLeave","barWrapper","opacity","tabIndex","yValue","callOutAccessibilityData","ariaLabel","_isChartEmpty","length","newX","newY","threshold","distance","sqrt","pow","useEffect","svgWidth","current","getBoundingClientRect","MARGIN_WIDTH_IN_PX","currentBarSpacing","barLegend","focusAttributes","legendButtons","datapoint","root","points","colorBackgroundOverlay","chartDataText","keyVal","items","chartTitle","chartTitleLeft","content","chartTitleAccessibilityData","svg","ref","chart","g","id","e","onClick","p","YValue","isCalloutForStack","customCallout","customizedCallout","onRenderCalloutPerHorizontalBar","customCalloutProps","calloutPropsPerDataPoint","isCartesian","displayName"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":"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"}
1
+ {"version":3,"sources":["HorizontalBarChart.tsx"],"sourcesContent":["import * as React from 'react';\nimport { useHorizontalBarChartStyles } from './useHorizontalBarChartStyles.styles';\nimport { ChartProps, HorizontalBarChartProps, ChartDataPoint, RefArrayData, HorizontalBarChartVariant } from './index';\nimport { formatToLocaleString } from '@fluentui/chart-utilities';\nimport { formatScientificLimitWidth, getAccessibleDataObject, useRtl } from '../../utilities/index';\nimport { useId } from '@fluentui/react-utilities';\nimport { tokens } from '@fluentui/react-theme';\nimport { useFocusableGroup } from '@fluentui/react-tabster';\nimport { ChartPopover } from '../CommonComponents/ChartPopover';\nimport { FocusableTooltipText } from '../../utilities/FocusableTooltipText';\nimport { Legend, Legends } from '../../index';\n\n/**\n * HorizontalBarChart is the context wrapper and container for all HorizontalBarChart content/controls,\n * It has no direct style or slot opinions.\n *\n * HorizontalBarChart also provides API interfaces for callbacks that will occur on navigation events.\n */\nexport const HorizontalBarChart: React.FunctionComponent<HorizontalBarChartProps> = React.forwardRef<\n HTMLDivElement,\n HorizontalBarChartProps\n>((props, forwardedRef) => {\n const legendContainer = React.useRef<HTMLDivElement | null>(null);\n const _uniqLineText: string = '_HorizontalLine_' + Math.random().toString(36).substring(7);\n const _refArray: RefArrayData[] = [];\n const _isRTL: boolean = useRtl();\n const barChartSvgRef: React.RefObject<SVGSVGElement> = React.createRef<SVGSVGElement>();\n const _emptyChartId: string = useId('_HBC_empty');\n let _barHeight: number;\n let _calloutAnchorPoint: ChartDataPoint | null;\n let isSingleBar: boolean = true;\n\n const [hoverValue, setHoverValue] = React.useState<string | number | Date | null>('');\n const [lineColor, setLineColor] = React.useState<string>('');\n const [legend, setLegend] = React.useState<string | null>('');\n const [xCalloutValue, setXCalloutValue] = React.useState<string | undefined>('');\n const [yCalloutValue, setYCalloutValue] = React.useState<string | undefined>('');\n const [barCalloutProps, setBarCalloutProps] = React.useState<ChartDataPoint>();\n const [barSpacingInPercent, setBarSpacingInPercent] = React.useState<number>(0);\n const [isPopoverOpen, setPopoverOpen] = React.useState<boolean>(false);\n const [clickPosition, setClickPosition] = React.useState({ x: 0, y: 0 });\n const [selectedLegend, setSelectedLegend] = React.useState<string>('');\n const [activeLegend, setActiveLegend] = React.useState<string>('');\n\n function _refCallback(element: SVGGElement, legendTitle: string | undefined): void {\n _refArray.push({ index: legendTitle, refElement: element });\n }\n\n function _hoverOn(\n event: React.MouseEvent<SVGRectElement, MouseEvent>,\n hoverVal: string | number | Date,\n point: ChartDataPoint,\n ): void {\n if (\n (!isPopoverOpen || legend !== point.legend!) &&\n _calloutAnchorPoint !== point &&\n (_legendHighlighted(point.legend) || _noLegendHighlighted())\n ) {\n _calloutAnchorPoint = point;\n updatePosition(event.clientX, event.clientY);\n setHoverValue(hoverVal);\n setLineColor(point.color!);\n setLegend(point.legend!);\n setXCalloutValue(point.xAxisCalloutData!);\n setYCalloutValue(point.yAxisCalloutData!);\n setBarCalloutProps(point);\n // ToDo - Confirm setting multiple state variables like this is performant.\n }\n }\n\n function _hoverOff(): void {\n /*ToDo. To fix*/\n }\n\n const _handleChartMouseLeave = () => {\n _calloutAnchorPoint = null;\n if (isPopoverOpen) {\n setPopoverOpen(false);\n setHoverValue('');\n setLineColor('');\n setLegend('');\n }\n };\n\n const _adjustProps = (): void => {\n _barHeight = props.barHeight || 12;\n };\n\n const _getChartDataText = (data: ChartProps) => {\n /* return props.barChartCustomData ? (\n <div role=\"text\">{props.barChartCustomData(data)}</div>\n ) : ( */\n return _getDefaultTextData(data);\n //)\n };\n\n function _createLegends(chartProps: ChartProps[]): JSX.Element {\n const legendItems: Legend[] = [];\n chartProps.forEach((point: ChartProps) => {\n point.chartData!.forEach((dataPoint: ChartDataPoint) => {\n const color: string = dataPoint.color!;\n // mapping data to the format Legends component needs\n const legendItem: Legend = {\n title: dataPoint.legend!,\n color,\n action: () => {\n if (selectedLegend === dataPoint.legend) {\n setSelectedLegend('');\n } else {\n setSelectedLegend(dataPoint.legend!);\n }\n },\n hoverAction: () => {\n _handleChartMouseLeave();\n setActiveLegend(dataPoint.legend!);\n },\n onMouseOutAction: () => {\n setActiveLegend('');\n },\n };\n legendItems.push(legendItem);\n });\n });\n const legends = (\n <Legends legends={legendItems} centerLegends overflowText={props.legendsOverflowText} {...props.legendProps} />\n );\n return legends;\n }\n\n function _getDefaultTextData(data: ChartProps): JSX.Element {\n const { culture } = props;\n const accessibilityData = getAccessibleDataObject(data.chartDataAccessibilityData!, 'text', false);\n if (!isSingleBar) {\n const total = data.chartData!.reduce(\n (acc: number, point: ChartDataPoint) =>\n acc + (point.horizontalBarChartdata!.x ? point.horizontalBarChartdata!.x : 0),\n 0,\n );\n return (\n <div className={classes.chartTitleRight} {...accessibilityData}>\n {formatToLocaleString(total, culture)}\n </div>\n );\n }\n const chartDataMode = props.chartDataMode || 'default';\n const chartData: ChartDataPoint = data!.chartData![0];\n const x = chartData.horizontalBarChartdata!.x;\n const y = chartData.horizontalBarChartdata!.total!;\n\n switch (chartDataMode) {\n case 'default':\n return (\n <div className={classes.chartTitleRight} {...accessibilityData}>\n {formatToLocaleString(x, culture)}\n </div>\n );\n case 'fraction':\n return (\n <div {...accessibilityData}>\n <span className={classes.chartTitleRight}>{formatToLocaleString(x, culture)}</span>\n <span className={classes.chartDataTextDenominator}>{' / ' + formatToLocaleString(y, culture)}</span>\n </div>\n );\n case 'percentage':\n const dataRatioPercentage = `${formatToLocaleString(Math.round((x / y) * 100), culture)}%`;\n return (\n <div className={classes.chartTitleRight} {...accessibilityData}>\n {dataRatioPercentage}\n </div>\n );\n }\n }\n\n function _createBenchmark(data: ChartProps): JSX.Element {\n if (data.chartData![0].horizontalBarChartdata!.total === undefined) {\n return <></>;\n }\n const totalData = data.chartData![0].horizontalBarChartdata!.total!;\n const benchmarkData = data.chartData![0].data;\n const benchmarkRatio = Math.round(((benchmarkData ? benchmarkData : 0) / totalData) * 100);\n\n const benchmarkStyles = {\n left: 'calc(' + benchmarkRatio + '% - 4px)',\n };\n\n return (\n <div className={classes.benchmarkContainer}>\n <div className={classes.triangle} style={benchmarkStyles} />\n </div>\n );\n }\n\n /**\n * This functions returns an array of <rect> elements, which form the bars\n * For each bar an x value, and a width needs to be specified\n * The computations are done based on percentages\n * Extra margin is also provided, in the x value to provide some spacing in between the bars\n */\n\n function _createBars(data: ChartProps): JSX.Element[] {\n const noOfBars =\n data.chartData?.reduce((count: number, point: ChartDataPoint) => (count += (point.data || 0) > 0 ? 1 : 0), 0) ||\n 1;\n const totalMarginPercent = barSpacingInPercent * (noOfBars - 1);\n const defaultColors: string[] = [\n tokens.colorPaletteBlueForeground2,\n tokens.colorPaletteCornflowerForeground2,\n tokens.colorPaletteDarkGreenForeground2,\n tokens.colorPaletteNavyForeground2,\n tokens.colorPaletteDarkOrangeForeground2,\n ];\n // calculating starting point of each bar and it's range\n const startingPoint: number[] = [];\n const total = data.chartData!.reduce(\n (acc: number, point: ChartDataPoint) =>\n acc + (point.horizontalBarChartdata!.x ? point.horizontalBarChartdata!.x : 0),\n 0,\n );\n let prevPosition = 0;\n let value = 0;\n\n let sumOfPercent = 0;\n data.chartData!.map((point: ChartDataPoint, index: number) => {\n const pointData = point.horizontalBarChartdata!.x ? point.horizontalBarChartdata!.x : 0;\n value = (pointData / total) * 100;\n if (value < 0) {\n value = 0;\n } else if (value < 1 && value !== 0) {\n value = 1;\n }\n sumOfPercent += value;\n\n return sumOfPercent;\n });\n\n /**\n * The %age of the space occupied by the margin needs to subtracted\n * while computing the scaling ratio, since the margins are not being\n * scaled down, only the data is being scaled down from a higher percentage to lower percentage\n * Eg: 95% of the space is taken by the bars, 5% by the margins\n * Now if the sumOfPercent is 120% -> This needs to be scaled down to 95%, not 100%\n * since that's only space available to the bars\n */\n const scalingRatio = sumOfPercent !== 0 ? (sumOfPercent - totalMarginPercent) / 100 : 1;\n\n const bars = data.chartData!.map((point: ChartDataPoint, index: number) => {\n const color: string = point.color ? point.color : defaultColors[Math.floor(Math.random() * 4 + 1)];\n const pointData = point.horizontalBarChartdata!.x ? point.horizontalBarChartdata!.x : 0;\n if (index > 0) {\n prevPosition += value;\n }\n value = (pointData / total) * 100;\n if (value < 0) {\n value = 0;\n } else if (value < 1 && value !== 0) {\n value = 1 / scalingRatio;\n } else {\n value = value / scalingRatio;\n }\n startingPoint.push(prevPosition);\n\n const xValue = point.horizontalBarChartdata!.x;\n const placeholderIndex = 1;\n const isLegendSelected: boolean = _legendHighlighted(point.legend) || _noLegendHighlighted();\n\n // Render bar label instead of placeholder bar for absolute-scale variant\n if (index === placeholderIndex && props.variant === HorizontalBarChartVariant.AbsoluteScale) {\n if (props.hideLabels) {\n return <text key={index} />;\n }\n\n const barValue = data.chartData![0].horizontalBarChartdata!.x;\n\n return (\n <text\n key={index}\n x={`${_isRTL ? 100 - startingPoint[index] : startingPoint[index]}%`}\n y={_barHeight / 2}\n dominantBaseline=\"central\"\n transform={`translate(${_isRTL ? -4 : 4})`}\n className={classes.barLabel}\n aria-hidden={true}\n >\n {formatScientificLimitWidth(barValue)}\n </text>\n );\n }\n\n return (\n <rect\n key={index}\n x={`${\n _isRTL\n ? 100 - startingPoint[index] - value - index * barSpacingInPercent\n : startingPoint[index] + index * barSpacingInPercent\n }%`}\n y={0}\n data-is-focusable={point.legend !== '' ? true : false}\n width={value + '%'}\n height={_barHeight}\n fill={color}\n onMouseOver={point.legend !== '' ? event => _hoverOn(event, xValue, point) : undefined}\n onFocus={point.legend !== '' ? event => _hoverOn.bind(event, xValue, point) : undefined}\n role=\"img\"\n aria-label={_getAriaLabel(point)}\n onBlur={_hoverOff}\n onMouseLeave={_hoverOff}\n className={classes.barWrapper}\n opacity={isLegendSelected ? 1 : 0.1}\n tabIndex={point.legend !== '' ? 0 : undefined}\n />\n );\n });\n return bars;\n }\n\n const _getAriaLabel = (point: ChartDataPoint): string => {\n const legend = point.xAxisCalloutData || point.legend;\n const yValue =\n point.yAxisCalloutData ||\n (point.horizontalBarChartdata\n ? `${point.horizontalBarChartdata.x}/${point.horizontalBarChartdata.total ?? ''}`\n : 0);\n return point.callOutAccessibilityData?.ariaLabel || (legend ? `${legend}, ` : '') + `${yValue}.`;\n };\n\n function _isChartEmpty(): boolean {\n return !(props.data && props.data.length > 0);\n }\n\n function updatePosition(newX: number, newY: number): void {\n const threshold = 1; // Set a threshold for movement\n const { x, y } = clickPosition;\n\n // Calculate the distance moved\n const distance = Math.sqrt(Math.pow(newX - x, 2) + Math.pow(newY - y, 2));\n // Update the position only if the distance moved is greater than the threshold\n if (distance > threshold) {\n setClickPosition({ x: newX, y: newY });\n setPopoverOpen(true);\n }\n }\n\n React.useEffect(() => {\n const svgWidth = barChartSvgRef?.current?.getBoundingClientRect().width || 0;\n const MARGIN_WIDTH_IN_PX = 3;\n if (svgWidth) {\n const currentBarSpacing = (MARGIN_WIDTH_IN_PX / svgWidth) * 100;\n setBarSpacingInPercent(currentBarSpacing);\n }\n }, [barChartSvgRef]);\n\n function _legendHighlighted(barLegend?: string) {\n if (barLegend === undefined) {\n return false;\n }\n return selectedLegend === barLegend || (selectedLegend === '' && activeLegend === barLegend);\n }\n\n /**\n * This function checks if none of the legends is selected or hovered.*/\n\n function _noLegendHighlighted() {\n return selectedLegend === '' && activeLegend === '';\n }\n\n const { data } = props;\n _adjustProps();\n const classes = useHorizontalBarChartStyles(props);\n const focusAttributes = useFocusableGroup();\n const legendButtons = _createLegends(data!);\n\n let datapoint: number | undefined = 0;\n return !_isChartEmpty() ? (\n <div className={classes.root} onMouseLeave={_handleChartMouseLeave}>\n {data!.map((points: ChartProps, index: number) => {\n if (points.chartData && points.chartData![0] && points.chartData![0].horizontalBarChartdata!.x) {\n datapoint = points.chartData![0].horizontalBarChartdata!.x;\n } else {\n datapoint = 0;\n }\n isSingleBar =\n points.chartData!.length === 1 || (points.chartData!.length > 1 && points.chartData![1].legend === '');\n if (isSingleBar) {\n points.chartData![1] = {\n legend: '',\n horizontalBarChartdata: {\n x: points.chartData![0].horizontalBarChartdata!.total! - datapoint!,\n total: points.chartData![0].horizontalBarChartdata!.total!,\n },\n color: tokens.colorBackgroundOverlay,\n };\n }\n\n // Hide right side text of chart title for absolute-scale variant\n const chartDataText =\n props.variant === HorizontalBarChartVariant.AbsoluteScale ? null : _getChartDataText(points!);\n const bars = _createBars(points!);\n const keyVal = _uniqLineText + '_' + index;\n // ToDo - Showtriangle property is per data series. How to account for it in the new stylesheet\n /* const classes = useHorizontalBarChartStyles(props.styles!, {\n width: props.width,\n showTriangle: !!points!.chartData![0].data,\n variant: props.variant,\n }); */\n\n return (\n <div key={index}>\n <div className={classes.items} {...focusAttributes}>\n <div className={classes.chartTitle}>\n {points!.chartTitle && (\n <FocusableTooltipText\n className={classes.chartTitleLeft}\n content={points!.chartTitle}\n accessibilityData={points!.chartTitleAccessibilityData}\n />\n )}\n {chartDataText}\n </div>\n {points!.chartData![0].data && _createBenchmark(points!)}\n <svg ref={barChartSvgRef} className={classes.chart} aria-label={points!.chartTitle}>\n <g\n id={keyVal}\n key={keyVal}\n ref={(e: SVGGElement) => {\n _refCallback(e, points!.chartData![0].legend);\n }}\n // NOTE: points.chartData![0] contains current data value\n onClick={() => {\n const p = points!.chartData![0];\n if (p && p.onClick) {\n p.onClick();\n }\n }}\n >\n {bars}\n </g>\n </svg>\n </div>\n </div>\n );\n })}\n <ChartPopover\n xCalloutValue={xCalloutValue}\n yCalloutValue={yCalloutValue}\n culture={props.culture ?? 'en-us'}\n clickPosition={clickPosition}\n isPopoverOpen={isPopoverOpen}\n legend={legend!}\n YValue={hoverValue!}\n color={lineColor}\n isCalloutForStack={false}\n customCallout={{\n customizedCallout: props.onRenderCalloutPerHorizontalBar\n ? props.onRenderCalloutPerHorizontalBar(barCalloutProps!)\n : undefined,\n customCalloutProps: props.calloutPropsPerDataPoint\n ? props.calloutPropsPerDataPoint(barCalloutProps!)\n : undefined,\n }}\n isCartesian={false}\n />\n {!isSingleBar && (\n <div ref={(e: HTMLDivElement) => (legendContainer.current = e)} className={classes.legendContainer}>\n {legendButtons}\n </div>\n )}\n </div>\n ) : (\n <div id={_emptyChartId} role={'alert'} style={{ opacity: '0' }} aria-label={'Graph has no data to display'} />\n );\n //TODO validate and fix focus border for issue for popover\n});\nHorizontalBarChart.displayName = 'HorizontalBarChart';\n"],"names":["React","useHorizontalBarChartStyles","HorizontalBarChartVariant","formatToLocaleString","formatScientificLimitWidth","getAccessibleDataObject","useRtl","useId","tokens","useFocusableGroup","ChartPopover","FocusableTooltipText","Legends","HorizontalBarChart","forwardRef","props","forwardedRef","legendContainer","useRef","_uniqLineText","Math","random","toString","substring","_refArray","_isRTL","barChartSvgRef","createRef","_emptyChartId","_barHeight","_calloutAnchorPoint","isSingleBar","hoverValue","setHoverValue","useState","lineColor","setLineColor","legend","setLegend","xCalloutValue","setXCalloutValue","yCalloutValue","setYCalloutValue","barCalloutProps","setBarCalloutProps","barSpacingInPercent","setBarSpacingInPercent","isPopoverOpen","setPopoverOpen","clickPosition","setClickPosition","x","y","selectedLegend","setSelectedLegend","activeLegend","setActiveLegend","_refCallback","element","legendTitle","push","index","refElement","_hoverOn","event","hoverVal","point","_legendHighlighted","_noLegendHighlighted","updatePosition","clientX","clientY","color","xAxisCalloutData","yAxisCalloutData","_hoverOff","_handleChartMouseLeave","_adjustProps","barHeight","_getChartDataText","data","_getDefaultTextData","_createLegends","chartProps","legendItems","forEach","chartData","dataPoint","legendItem","title","action","hoverAction","onMouseOutAction","legends","centerLegends","overflowText","legendsOverflowText","legendProps","culture","accessibilityData","chartDataAccessibilityData","total","reduce","acc","horizontalBarChartdata","div","className","classes","chartTitleRight","chartDataMode","span","chartDataTextDenominator","dataRatioPercentage","round","_createBenchmark","undefined","totalData","benchmarkData","benchmarkRatio","benchmarkStyles","left","benchmarkContainer","triangle","style","_createBars","noOfBars","count","totalMarginPercent","defaultColors","colorPaletteBlueForeground2","colorPaletteCornflowerForeground2","colorPaletteDarkGreenForeground2","colorPaletteNavyForeground2","colorPaletteDarkOrangeForeground2","startingPoint","prevPosition","value","sumOfPercent","map","pointData","scalingRatio","bars","floor","xValue","placeholderIndex","isLegendSelected","variant","AbsoluteScale","hideLabels","text","key","barValue","dominantBaseline","transform","barLabel","aria-hidden","rect","data-is-focusable","width","height","fill","onMouseOver","onFocus","bind","role","aria-label","_getAriaLabel","onBlur","onMouseLeave","barWrapper","opacity","tabIndex","yValue","callOutAccessibilityData","ariaLabel","_isChartEmpty","length","newX","newY","threshold","distance","sqrt","pow","useEffect","svgWidth","current","getBoundingClientRect","MARGIN_WIDTH_IN_PX","currentBarSpacing","barLegend","focusAttributes","legendButtons","datapoint","root","points","colorBackgroundOverlay","chartDataText","keyVal","items","chartTitle","chartTitleLeft","content","chartTitleAccessibilityData","svg","ref","chart","g","id","e","onClick","p","YValue","isCalloutForStack","customCallout","customizedCallout","onRenderCalloutPerHorizontalBar","customCalloutProps","calloutPropsPerDataPoint","isCartesian","displayName"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":"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"}
@@ -7,7 +7,7 @@ import { scaleLinear as d3ScaleLinear, scaleBand as d3ScaleBand, scaleUtc as d3S
7
7
  import { useId } from '@fluentui/react-utilities';
8
8
  import { tokens } from '@fluentui/react-theme';
9
9
  import { CartesianChart, Legends, ChartPopover } from '../../index';
10
- import { ChartTypes, getAccessibleDataObject, XAxisTypes, getTypeOfAxis, tooltipOfXAxislabels, formatValueWithSIPrefix, getBarWidth, getScalePadding, isScalePaddingDefined, calculateAppropriateBarWidth, useRtl, areArraysEqual, calculateLongestLabelWidth } from '../../utilities/index';
10
+ import { ChartTypes, getAccessibleDataObject, XAxisTypes, getTypeOfAxis, tooltipOfXAxislabels, formatScientificLimitWidth, getBarWidth, getScalePadding, isScalePaddingDefined, calculateAppropriateBarWidth, useRtl, areArraysEqual, calculateLongestLabelWidth } from '../../utilities/index';
11
11
  var CircleVisbility;
12
12
  (function(CircleVisbility) {
13
13
  CircleVisbility["show"] = "visibility";
@@ -787,7 +787,7 @@ const MIN_DOMAIN_MARGIN = 8;
787
787
  textAnchor: "middle",
788
788
  className: classes.barLabel,
789
789
  "aria-hidden": true
790
- }, formatValueWithSIPrefix(barValue));
790
+ }, formatScientificLimitWidth(barValue));
791
791
  }
792
792
  function _getDomainMargins(containerWidth) {
793
793
  _domainMargin = MIN_DOMAIN_MARGIN;
@@ -1 +1 @@
1
- {"version":3,"sources":["VerticalBarChart.tsx"],"sourcesContent":["import * as React from 'react';\nimport { useVerticalBarChartStyles } from './useVerticalBarChartStyles.styles';\nimport { max as d3Max, min as d3Min } from 'd3-array';\nimport { line as d3Line } from 'd3-shape';\nimport { select as d3Select } from 'd3-selection';\nimport {\n scaleLinear as d3ScaleLinear,\n ScaleLinear as D3ScaleLinear,\n scaleBand as d3ScaleBand,\n scaleUtc as d3ScaleUtc,\n} from 'd3-scale';\nimport { useId } from '@fluentui/react-utilities';\nimport { tokens } from '@fluentui/react-theme';\nimport {\n AccessibilityProps,\n CartesianChart,\n Margins,\n Legend,\n RefArrayData,\n VerticalBarChartProps,\n VerticalBarChartDataPoint,\n Legends,\n ChildProps,\n YValueHover,\n ChartPopover,\n Chart,\n} from '../../index';\nimport {\n ChartTypes,\n IAxisData,\n getAccessibleDataObject,\n XAxisTypes,\n NumericAxis,\n getTypeOfAxis,\n tooltipOfXAxislabels,\n formatValueWithSIPrefix,\n getBarWidth,\n getScalePadding,\n isScalePaddingDefined,\n calculateAppropriateBarWidth,\n useRtl,\n areArraysEqual,\n calculateLongestLabelWidth,\n} from '../../utilities/index';\n\nenum CircleVisbility {\n show = 'visibility',\n hide = 'hidden',\n}\n\nconst MIN_DOMAIN_MARGIN = 8;\n\n// Create a VerticalBarChart variant which uses these default styles and this styled subcomponent.\n/**\n * VerticalBarchart component\n * {@docCategory VerticalBarChart}\n */\nexport const VerticalBarChart: React.FunctionComponent<VerticalBarChartProps> = React.forwardRef<\n HTMLDivElement,\n VerticalBarChartProps\n>((props, forwardedRef) => {\n let _points: VerticalBarChartDataPoint[] = [];\n let _barWidth: number = 0;\n let _colors: string[];\n const _refArray: RefArrayData[] = [];\n let margins: Margins;\n const _useRtl: boolean = useRtl();\n let _bars: JSX.Element[];\n let _xAxisLabels: string[];\n let _yMax: number;\n let _yMin: number;\n let _isHavingLine: boolean = _checkForLine();\n const _tooltipId: string = useId('VCTooltipID_');\n const _xAxisType: XAxisTypes =\n props.data! && props.data!.length > 0\n ? (getTypeOfAxis(props.data![0].x, true) as XAxisTypes)\n : XAxisTypes.StringAxis;\n let _calloutAnchorPoint: VerticalBarChartDataPoint | null;\n let _domainMargin: number;\n const _emptyChartId: string = useId('_VBC_empty');\n const _vbcLineId: string = useId('_VBC_line_');\n const _vbcPointId: string = useId('_VBC_point_');\n const _vbcBarId: string = useId('_VBC_bar_');\n let _xAxisInnerPadding: number = 0;\n let _xAxisOuterPadding: number = 0;\n type ColorScale = (_p?: number) => string;\n const cartesianChartRef = React.useRef<Chart>(null);\n\n const [color, setColor] = React.useState<string>('');\n const [dataForHoverCard, setDataForHoverCard] = React.useState<number>(0);\n const [activeLegend, setActiveLegend] = React.useState<string | undefined>(undefined);\n const [xCalloutValue, setXCalloutValue] = React.useState<string | undefined>('');\n const [yCalloutValue, setYCalloutValue] = React.useState<string | undefined>('');\n const [activeXdataPoint, setActiveXDatapoint] = React.useState<string | number | Date | null>(null);\n const [hoveredYValues, setYValueHover] = React.useState<YValueHover[]>();\n const [hoverXValue, setHoverXValue] = React.useState<string | number | undefined>('');\n const [calloutLegend, setCalloutLegend] = React.useState<string>('');\n const [callOutAccessibilityData, setCalloutAccessibilityData] = React.useState<AccessibilityProps>();\n const [dataPointCalloutProps, setDataPointCalloutProps] = React.useState<VerticalBarChartDataPoint>();\n const [clickPosition, setClickPosition] = React.useState({ x: 0, y: 0 });\n const [isPopoverOpen, setPopoverOpen] = React.useState(false);\n const [selectedLegends, setSelectedLegends] = React.useState<string[]>(props.legendProps?.selectedLegends || []);\n const prevPropsRef = React.useRef<VerticalBarChartProps | null>(null);\n\n React.useImperativeHandle(\n props.componentRef,\n () => ({\n chartContainer: cartesianChartRef.current?.chartContainer ?? null,\n }),\n [],\n );\n\n React.useEffect(() => {\n if (prevPropsRef.current) {\n const prevProps = prevPropsRef.current;\n if (!areArraysEqual(prevProps.legendProps?.selectedLegends, props.legendProps?.selectedLegends)) {\n setSelectedLegends(props.legendProps?.selectedLegends || []);\n }\n if (prevProps.height !== props.height || prevProps.width !== props.width) {\n _adjustProps();\n }\n }\n prevPropsRef.current = props;\n }, [props, prevPropsRef, _adjustProps]);\n\n function _createLine(\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n xScale: any,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n yScale: any,\n containerHeight: number = 0,\n containerWidth: number = 0,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n yScaleSecondary?: any,\n ): React.ReactNode {\n const isStringAxis = _xAxisType === XAxisTypes.StringAxis;\n const colorScale = _createColors();\n const { data, lineLegendColor = tokens.colorPaletteYellowBackground1, lineLegendText } = props;\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const lineData: Array<any> = [];\n const line: JSX.Element[] = [];\n data &&\n data.forEach((item: VerticalBarChartDataPoint, index: number) => {\n if (item.lineData && item.lineData.y) {\n lineData.push({\n x: item.x,\n y: item.lineData!.y,\n useSecondaryYScale: item.lineData!.useSecondaryYScale ?? false,\n point: item,\n index,\n });\n }\n });\n const linePath = d3Line()\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n .x((d: any) => (isStringAxis ? xScale(d.x) + 0.5 * xScale.bandwidth() : xScale(d.x)))\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n .y((d: any) => (d.useSecondaryYScale && yScaleSecondary ? yScaleSecondary(d.y) : yScale(d.y)));\n const shouldHighlight = _legendHighlighted(lineLegendText!) || _noLegendHighlighted() ? true : false;\n const lineBorderWidth = props.lineOptions?.lineBorderWidth\n ? Number.parseFloat(props.lineOptions!.lineBorderWidth!.toString())\n : 0;\n\n if (lineBorderWidth > 0) {\n line.push(\n <path\n key={_vbcLineId}\n id={_vbcLineId}\n opacity={shouldHighlight ? 1 : 0.1}\n d={linePath(lineData)!}\n fill=\"transparent\"\n strokeLinecap=\"square\"\n strokeWidth={3 + lineBorderWidth * 2}\n stroke={tokens.colorNeutralBackground1}\n />,\n );\n }\n line.push(\n <path\n key={_vbcLineId}\n id={_vbcLineId}\n opacity={shouldHighlight ? 1 : 0.1}\n d={linePath(lineData)!}\n fill=\"transparent\"\n strokeLinecap=\"square\"\n strokeWidth={3}\n stroke={lineLegendColor}\n />,\n );\n\n const dots: React.ReactNode[] = lineData.map(\n (\n item: {\n x: number | string;\n y: number;\n useSecondaryYScale: boolean;\n point: VerticalBarChartDataPoint;\n index: number;\n },\n index: number,\n ) => {\n // Create an object to store line point ref so that the object can be passed by reference to the focus handler\n const circleRef: { refElement: SVGCircleElement | null } = { refElement: null };\n return (\n <circle\n key={index}\n id={`${_vbcPointId}-${index}`}\n cx={isStringAxis ? xScale(item.x) + 0.5 * xScale.bandwidth() : xScale(item.x)}\n cy={item.useSecondaryYScale && yScaleSecondary ? yScaleSecondary(item.y) : yScale(item.y)}\n onMouseOver={event =>\n _legendHighlighted(lineLegendText!)\n ? _lineHover(item.point, event)\n : _onBarHover(item.point, colorScale(item.y), event)\n }\n onMouseOut={_onBarLeave}\n r={_getCircleVisibilityAndRadius(item.x, lineLegendText!).radius}\n stroke={lineLegendColor}\n fill={tokens.colorNeutralBackground1}\n strokeWidth={3}\n visibility={_getCircleVisibilityAndRadius(item.x, lineLegendText!).visibility}\n onClick={item.point.lineData?.onClick}\n // When no legend is highlighted: Line points are automatically displayed along with the bars\n // at the same x-axis point in the stack callout. So to prevent an increase in focusable elements\n // and avoid conveying duplicate info, make these line points non-focusable.\n data-is-focusable={_legendHighlighted(lineLegendText!)}\n ref={e => (circleRef.refElement = e)}\n onFocus={_lineFocus.bind(item.point, circleRef)}\n onBlur={_handleChartMouseLeave}\n />\n );\n },\n );\n\n return (\n <>\n {line}\n {dots}\n </>\n );\n }\n\n function _getCircleVisibilityAndRadius(\n xAxisPoint: string | number | Date,\n legend: string,\n ): { visibility: CircleVisbility; radius: number } {\n if (!_noLegendHighlighted()) {\n if (xAxisPoint === activeXdataPoint && _legendHighlighted(legend)) {\n return { visibility: CircleVisbility.show, radius: 8 };\n } else if (_legendHighlighted(legend)) {\n // Don't hide the circle to keep it focusable. For more information,\n // see https://fuzzbomb.github.io/accessibility-demos/visually-hidden-focus-test.html\n return { visibility: CircleVisbility.show, radius: 0.3 };\n } else {\n return { visibility: CircleVisbility.hide, radius: 0 };\n }\n } else {\n return {\n visibility: activeXdataPoint === xAxisPoint ? CircleVisbility.show : CircleVisbility.hide,\n radius: 8,\n };\n }\n }\n\n function _checkForLine(): boolean {\n const { data } = props;\n return data!.some((item: VerticalBarChartDataPoint) => item?.lineData?.y !== undefined);\n }\n\n function _adjustProps(): void {\n _points = props.data || [];\n _barWidth = getBarWidth(props.barWidth, props.maxBarWidth);\n const defaultColors: string[] = [\n tokens.colorPaletteBlueForeground2,\n tokens.colorPaletteCornflowerForeground2,\n tokens.colorPaletteDarkGreenForeground2,\n tokens.colorPaletteNavyForeground2,\n tokens.colorPaletteDarkOrangeForeground2,\n ];\n _colors = props.colors || defaultColors;\n _isHavingLine = _checkForLine();\n _xAxisInnerPadding = getScalePadding(props.xAxisInnerPadding, props.xAxisPadding, 2 / 3);\n _xAxisOuterPadding = getScalePadding(props.xAxisOuterPadding, props.xAxisPadding, 0);\n }\n\n function _getMargins(_margins: Margins) {\n margins = _margins;\n }\n\n function _renderContentForBothLineAndBars(point: VerticalBarChartDataPoint): JSX.Element {\n // eslint-disable-next-line @typescript-eslint/no-shadow\n const { YValueHover, hoverXValue } = _getCalloutContentForLineAndBar(point);\n const content: JSX.Element[] = YValueHover.map((item: YValueHover, index: number) => {\n return (\n <>\n <ChartPopover\n culture={props.culture ?? 'en-us'}\n clickPosition={clickPosition}\n isPopoverOpen={isPopoverOpen}\n legend={item.legend!}\n {...(index === 0 && { XValue: `${hoverXValue || item.data}` })}\n YValue={item.data || item.y}\n color={item.color}\n isCalloutForStack={false}\n />\n </>\n );\n });\n return <>{content}</>;\n }\n\n function _renderContentForOnlyBars(_props: VerticalBarChartDataPoint): JSX.Element {\n return (\n <>\n <ChartPopover\n XValue={_props.xAxisCalloutData || (_props.x as string)}\n xCalloutValue={xCalloutValue}\n yCalloutValue={yCalloutValue}\n culture={props.culture ?? 'en-us'}\n clickPosition={clickPosition}\n isPopoverOpen={isPopoverOpen}\n legend={_props.legend!}\n YValue={_props.yAxisCalloutData || _props.y}\n color={!props.useSingleColor && _props.color ? _props.color : _createColors()(_props.y)}\n isCalloutForStack={false}\n />\n </>\n );\n }\n\n // eslint-disable-next-line @typescript-eslint/no-shadow\n function _renderCallout(props?: VerticalBarChartDataPoint): JSX.Element | null {\n return props ? (_isHavingLine ? _renderContentForBothLineAndBars(props) : _renderContentForOnlyBars(props)) : null;\n }\n\n function _getCustomizedCallout() {\n return props.onRenderCalloutPerDataPoint\n ? props.onRenderCalloutPerDataPoint(dataPointCalloutProps, _renderCallout)\n : null;\n }\n\n function _getGraphData(\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n xScale: any,\n yScale: NumericAxis,\n containerHeight: number,\n containerWidth: number,\n xElement?: SVGElement | null,\n ) {\n return (_bars =\n _xAxisType === XAxisTypes.NumericAxis\n ? _createNumericBars(containerHeight, containerWidth, xElement!)\n : _xAxisType === XAxisTypes.DateAxis\n ? _createDateBars(containerHeight, containerWidth, xElement!)\n : _createStringBars(containerHeight, containerWidth, xElement!));\n }\n\n function _createColors(): D3ScaleLinear<string, string> | ColorScale {\n const increment = _colors.length <= 1 ? 1 : 1 / (_colors.length - 1);\n const { useSingleColor = false } = props;\n if (useSingleColor) {\n return (_p?: number) => {\n const { colors } = props;\n return colors && colors.length > 0 ? colors[0] : tokens.colorPaletteBlueBackground2;\n };\n }\n const domainValues = [];\n for (let i = 0; i < _colors.length; i++) {\n domainValues.push(increment * i * _yMax);\n }\n const colorScale = d3ScaleLinear<string>().domain(domainValues).range(_colors);\n return colorScale;\n }\n\n function _refCallback(element: SVGRectElement, legendTitle: string): void {\n _refArray.push({ index: legendTitle, refElement: element });\n }\n\n function _getCalloutContentForLineAndBar(point: VerticalBarChartDataPoint): {\n YValueHover: YValueHover[];\n hoverXValue: string | number | undefined;\n } {\n // eslint-disable-next-line @typescript-eslint/no-shadow\n const YValueHover: YValueHover[] = [];\n const { useSingleColor = false } = props;\n const { data, lineLegendText, lineLegendColor = tokens.colorPaletteYellowBackground1 } = props;\n const selectedPoint = data!.filter((xDataPoint: VerticalBarChartDataPoint) => xDataPoint.x === point.x);\n // Check if the line legend is highlighted or no legend is highlighted\n if (\n _isHavingLine &&\n selectedPoint[0].lineData?.y !== undefined &&\n (_legendHighlighted(lineLegendText) || _noLegendHighlighted())\n ) {\n // Add callout data for the line\n YValueHover.push({\n legend: lineLegendText,\n color: lineLegendColor,\n y: selectedPoint[0].lineData?.y,\n data: selectedPoint[0].lineData?.yAxisCalloutData,\n yAxisCalloutData: selectedPoint[0].lineData?.yAxisCalloutData,\n });\n }\n // Check if the bar legend is highlighted or no legend is highlighted\n if (selectedPoint[0].legend && (selectedLegends.includes(selectedPoint[0].legend) || _noLegendHighlighted())) {\n // Add callout data for the bar\n YValueHover.push({\n legend: selectedPoint[0].legend,\n y: selectedPoint[0].y,\n color: !useSingleColor\n ? selectedPoint[0].color\n ? selectedPoint[0].color\n : _createColors()(selectedPoint[0].y)\n : _createColors()(1),\n data: selectedPoint[0].yAxisCalloutData,\n yAxisCalloutData: selectedPoint[0].yAxisCalloutData,\n });\n }\n // eslint-disable-next-line @typescript-eslint/no-shadow\n const hoverXValue = point.x instanceof Date ? point.x.toLocaleString() : point.x.toString();\n return {\n YValueHover,\n hoverXValue: point.xAxisCalloutData || hoverXValue,\n };\n }\n\n function _onBarHover(\n point: VerticalBarChartDataPoint,\n // eslint-disable-next-line @typescript-eslint/no-shadow\n color: string,\n mouseEvent: React.MouseEvent<SVGElement>,\n ): void {\n mouseEvent.persist();\n\n // eslint-disable-next-line @typescript-eslint/no-shadow\n const { YValueHover, hoverXValue } = _getCalloutContentForLineAndBar(point);\n if (_calloutAnchorPoint !== point) {\n _calloutAnchorPoint = point;\n /** Show the callout if highlighted bar is hovered and Hide it if unhighlighted bar is hovered */\n updatePosition(mouseEvent.clientX, mouseEvent.clientY);\n setPopoverOpen(_noLegendHighlighted() || _legendHighlighted(point.legend));\n setDataForHoverCard(point.y);\n setCalloutLegend(point.legend!);\n setColor(point.color || color);\n // To display callout value, if no callout value given, taking given point.x value as a string.\n setXCalloutValue(\n point.xAxisCalloutData || (point.x instanceof Date ? point.x.toLocaleDateString() : point.x.toString()),\n );\n setDataPointCalloutProps(point);\n // Hovering over a bar should highlight corresponding line points only when no legend is selected\n setActiveXDatapoint(_noLegendHighlighted() ? point.x : null);\n setYValueHover(YValueHover);\n setHoverXValue(hoverXValue);\n setCalloutAccessibilityData(point.callOutAccessibilityData);\n }\n }\n\n function _onBarLeave(): void {\n /**/\n }\n\n function _handleChartMouseLeave(): void {\n _calloutAnchorPoint = null;\n setPopoverOpen(false);\n setActiveXDatapoint(null);\n setYValueHover([]);\n setHoverXValue('');\n }\n\n // eslint-disable-next-line @typescript-eslint/no-shadow\n function _onBarFocus(point: VerticalBarChartDataPoint, refArrayIndexNumber: number, color: string): void {\n // eslint-disable-next-line @typescript-eslint/no-shadow\n const { YValueHover, hoverXValue } = _getCalloutContentForLineAndBar(point);\n _refArray.forEach((obj: RefArrayData, index: number) => {\n if (obj.index === point.legend! && refArrayIndexNumber === index) {\n /** Show the callout if highlighted bar is hovered and Hide it if unhighlighted bar is hovered */\n setPopoverOpen(_noLegendHighlighted() || _legendHighlighted(point.legend));\n setDataForHoverCard(point.y);\n setCalloutLegend(point.legend!);\n setColor(point.color || color);\n // To display callout value, if no callout value given, taking given point.x value as a string.\n setXCalloutValue(\n point.xAxisCalloutData || (point.x instanceof Date ? point.x.toLocaleDateString() : point.x.toString()),\n );\n setYCalloutValue(point.yAxisCalloutData!);\n setDataPointCalloutProps(point);\n // Hovering over a bar should highlight corresponding line points only when no legend is selected\n setActiveXDatapoint(point.x);\n setYValueHover(YValueHover);\n setHoverXValue(hoverXValue);\n setCalloutAccessibilityData(point.callOutAccessibilityData);\n }\n });\n }\n\n function _lineHover(point: VerticalBarChartDataPoint, mouseEvent: React.MouseEvent<SVGElement>) {\n mouseEvent.persist();\n _lineHoverFocus(point, mouseEvent);\n }\n\n function _lineFocus(point: VerticalBarChartDataPoint, ref: { refElement: SVGCircleElement | null }) {\n if (ref.refElement) {\n _lineHoverFocus(point, ref.refElement);\n }\n }\n\n function _lineHoverFocus(\n point: VerticalBarChartDataPoint,\n _refSelected: React.MouseEvent<SVGElement> | SVGCircleElement,\n ) {\n const { lineLegendText = '', lineLegendColor = tokens.colorPaletteYellowBackground1 } = props;\n setPopoverOpen(_noLegendHighlighted() || _legendHighlighted(lineLegendText));\n setCalloutLegend(lineLegendText);\n setDataForHoverCard(point.lineData!.y);\n setColor(lineLegendColor);\n setXCalloutValue(\n point.xAxisCalloutData || (point.x instanceof Date ? point.x.toLocaleDateString() : point.x.toString()),\n );\n setYCalloutValue(point.lineData!.yAxisCalloutData);\n setDataPointCalloutProps(point);\n setActiveXDatapoint(point.x);\n }\n\n function _getScales(\n containerHeight: number,\n containerWidth: number,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n ): { xBarScale: any; yBarScale: any } {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n let xBarScale: any;\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const yBarScale: any = d3ScaleLinear()\n .domain([_yMin, _yMax])\n .range([0, containerHeight - margins.bottom! - margins.top!]);\n\n if (_xAxisType === XAxisTypes.NumericAxis) {\n const xMax = d3Max(_points, (point: VerticalBarChartDataPoint) => point.x as number)!;\n const xMin = d3Min(_points, (point: VerticalBarChartDataPoint) => point.x as number)!;\n xBarScale = d3ScaleLinear()\n .domain(_useRtl ? [xMax, xMin] : [xMin, xMax])\n .nice()\n .range([margins.left! + _domainMargin, containerWidth - margins.right! - _domainMargin]);\n } else if (_xAxisType === XAxisTypes.DateAxis) {\n const sDate = d3Min(_points, (point: VerticalBarChartDataPoint) => point.x as Date)!;\n const lDate = d3Max(_points, (point: VerticalBarChartDataPoint) => point.x as Date)!;\n xBarScale = d3ScaleUtc()\n .domain([sDate, lDate])\n .range(\n _useRtl\n ? [containerWidth - margins.right! - _domainMargin, margins.left! + _domainMargin]\n : [margins.left! + _domainMargin, containerWidth - margins.right! - _domainMargin],\n );\n } else {\n xBarScale = d3ScaleBand()\n .domain(_xAxisLabels)\n .range(\n _useRtl\n ? [containerWidth - margins.right! - _domainMargin, margins.left! + _domainMargin]\n : [margins.left! + _domainMargin, containerWidth - margins.right! - _domainMargin],\n )\n .paddingInner(_xAxisInnerPadding)\n .paddingOuter(_xAxisOuterPadding);\n }\n\n return { xBarScale, yBarScale };\n }\n\n const classes = useVerticalBarChartStyles(props);\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n function _calculateMinBarHeight(yMin: number, yMax: number, yReferencePoint: number, yBarScale: any): number {\n const maxHeightFromBaseline =\n yMax < 0\n ? Math.abs(yMin - yReferencePoint)\n : Math.max(Math.abs(yMax - yReferencePoint), Math.abs(yMin - yReferencePoint));\n return Math.ceil(yBarScale(maxHeightFromBaseline) / 100.0);\n }\n\n function _createNumericBars(containerHeight: number, containerWidth: number, xElement: SVGElement): JSX.Element[] {\n const { useSingleColor = false } = props;\n const { xBarScale, yBarScale } = _getScales(containerHeight, containerWidth);\n const colorScale = _createColors();\n const yReferencePoint = _yMax < 0 ? _yMax : 0;\n const bars = _points.map((point: VerticalBarChartDataPoint, index: number) => {\n const shouldHighlight = _legendHighlighted(point.legend!) || _noLegendHighlighted() ? true : false;\n\n let barHeight: number = yBarScale(point.y) - yBarScale(yReferencePoint);\n const isHeightNegative = barHeight < 0;\n barHeight = Math.abs(barHeight);\n // Calculate threshold for minimum visible bar height\n const minBarHeight = _calculateMinBarHeight(_yMin, _yMax, yReferencePoint, yBarScale);\n let adjustedBarHeight = barHeight;\n\n if (barHeight === 0) {\n return <React.Fragment key={point.x as string}> </React.Fragment>;\n }\n // Adjust bar height if it's smaller than the threshold\n else if (barHeight <= minBarHeight) {\n adjustedBarHeight = minBarHeight;\n }\n const xPoint = xBarScale(point.x as number) - _barWidth / 2;\n const yPoint =\n containerHeight -\n margins.bottom! -\n (isHeightNegative ? -1 * adjustedBarHeight : adjustedBarHeight) -\n yBarScale(yReferencePoint);\n const baselineHeight = containerHeight - margins.bottom! - yBarScale(yReferencePoint);\n return (\n <g key={`${point.x}_${index}` as string}>\n <rect\n id={`${_vbcBarId}-${index}`}\n x={xPoint}\n y={!isHeightNegative ? yPoint : baselineHeight}\n width={_barWidth}\n data-is-focusable={!props.hideTooltip && shouldHighlight}\n height={adjustedBarHeight}\n ref={(e: SVGRectElement) => {\n _refCallback(e, point.legend!);\n }}\n onClick={point.onClick}\n onMouseOver={event => _onBarHover(point, colorScale(point.y), event)}\n aria-label={_getAriaLabel(point)}\n role=\"img\"\n onMouseLeave={_onBarLeave}\n onFocus={_onBarFocus.bind(point, index, colorScale(point.y))}\n onBlur={_onBarLeave}\n fill={point.color && !useSingleColor ? point.color : colorScale(point.y)}\n tabIndex={point.legend !== '' ? 0 : undefined}\n opacity={shouldHighlight ? 1 : 0.1}\n rx={props.roundCorners ? 3 : 0}\n />\n {_renderBarLabel(xPoint, yPoint, point.y, point.legend!, isHeightNegative)}\n </g>\n );\n });\n // Removing un wanted tooltip div from DOM, when prop not provided.\n if (!props.showXAxisLablesTooltip) {\n try {\n // eslint-disable-next-line no-restricted-globals\n document.getElementById(_tooltipId) && document.getElementById(_tooltipId)!.remove();\n // eslint-disable-next-line no-empty\n } catch (e) {}\n }\n // Used to display tooltip at x axis labels.\n if (!props.wrapXAxisLables && props.showXAxisLablesTooltip) {\n const xAxisElement = d3Select(xElement).call(xBarScale);\n try {\n // eslint-disable-next-line no-restricted-globals\n document.getElementById(_tooltipId) && document.getElementById(_tooltipId)!.remove();\n // eslint-disable-next-line no-empty\n } catch (e) {}\n const tooltipProps = {\n tooltipCls: classes.tooltip!,\n id: _tooltipId,\n xAxis: xAxisElement,\n };\n xAxisElement && tooltipOfXAxislabels(tooltipProps);\n }\n return bars;\n }\n\n function _createStringBars(containerHeight: number, containerWidth: number, xElement: SVGElement): JSX.Element[] {\n const { xBarScale, yBarScale } = _getScales(containerHeight, containerWidth);\n const colorScale = _createColors();\n const yReferencePoint = _yMax < 0 ? _yMax : 0;\n const bars = _points.map((point: VerticalBarChartDataPoint, index: number) => {\n const shouldHighlight = _legendHighlighted(point.legend!) || _noLegendHighlighted() ? true : false;\n let barHeight: number = yBarScale(point.y) - yBarScale(yReferencePoint);\n const isHeightNegative = barHeight < 0;\n barHeight = Math.abs(barHeight);\n // Calculate threshold for minimum visible bar height\n const minBarHeight = _calculateMinBarHeight(_yMin, _yMax, yReferencePoint, yBarScale);\n let adjustedBarHeight = barHeight;\n\n if (barHeight === 0) {\n return <React.Fragment key={point.x as string}> </React.Fragment>;\n }\n // Adjust bar height if it's smaller than the threshold\n else if (barHeight <= minBarHeight) {\n adjustedBarHeight = minBarHeight;\n }\n const xPoint = xBarScale(point.x);\n const yPoint =\n containerHeight -\n margins.bottom! -\n (isHeightNegative ? -1 * adjustedBarHeight : adjustedBarHeight) -\n yBarScale(yReferencePoint);\n const baselineHeight = containerHeight - margins.bottom! - yBarScale(yReferencePoint);\n // Setting the bar width here is safe because there are no dependencies earlier in the code\n // that rely on the width of bars in vertical bar charts with string x-axis.\n _barWidth = getBarWidth(props.barWidth, props.maxBarWidth, xBarScale.bandwidth());\n return (\n <g\n key={point.x instanceof Date ? `${point.x.getTime()}_${index}` : `${point.x}_${index}`}\n transform={`translate(${0.5 * (xBarScale.bandwidth() - _barWidth)}, 0)`}\n >\n <rect\n id={`${_vbcBarId}-${index}`}\n x={xPoint}\n y={!isHeightNegative ? yPoint : baselineHeight}\n width={_barWidth}\n height={adjustedBarHeight}\n aria-label={_getAriaLabel(point)}\n role=\"img\"\n ref={(e: SVGRectElement) => {\n _refCallback(e, point.legend!);\n }}\n onClick={point.onClick}\n onMouseOver={event => _onBarHover(point, colorScale(point.y), event)}\n onMouseLeave={_onBarLeave}\n onBlur={_onBarLeave}\n data-is-focusable={!props.hideTooltip && shouldHighlight}\n onFocus={_onBarFocus.bind(point, index, colorScale(point.y))}\n fill={point.color ? point.color : colorScale(point.y)}\n tabIndex={point.legend !== '' ? 0 : undefined}\n rx={props.roundCorners ? 3 : 0}\n opacity={shouldHighlight ? 1 : 0.1}\n />\n {_renderBarLabel(xPoint, yPoint, point.y, point.legend!, isHeightNegative)}\n </g>\n );\n });\n\n // Removing un wanted tooltip div from DOM, when prop not provided.\n if (!props.showXAxisLablesTooltip) {\n try {\n // eslint-disable-next-line no-restricted-globals\n document.getElementById(_tooltipId) && document.getElementById(_tooltipId)!.remove();\n // eslint-disable-next-line no-empty\n } catch (e) {}\n }\n // Used to display tooltip at x axis labels.\n if (!props.wrapXAxisLables && props.showXAxisLablesTooltip) {\n const xAxisElement = d3Select(xElement).call(xBarScale);\n try {\n // eslint-disable-next-line no-restricted-globals\n document.getElementById(_tooltipId) && document.getElementById(_tooltipId)!.remove();\n // eslint-disable-next-line no-empty\n } catch (e) {}\n const tooltipProps = {\n tooltipCls: classes.tooltip!,\n id: _tooltipId,\n xAxis: xAxisElement,\n showTooltip: props.showXAxisLablesTooltip,\n };\n xAxisElement && tooltipOfXAxislabels(tooltipProps);\n }\n return bars;\n }\n\n function _createDateBars(containerHeight: number, containerWidth: number, xElement: SVGElement): JSX.Element[] {\n const { useSingleColor = false } = props;\n const { xBarScale, yBarScale } = _getScales(containerHeight, containerWidth);\n const colorScale = _createColors();\n const yReferencePoint = _yMax < 0 ? _yMax : 0;\n const bars = _points.map((point: VerticalBarChartDataPoint, index: number) => {\n const shouldHighlight = _legendHighlighted(point.legend!) || _noLegendHighlighted() ? true : false;\n let barHeight: number = yBarScale(point.y) - yBarScale(yReferencePoint);\n const isHeightNegative = barHeight < 0;\n barHeight = Math.abs(barHeight);\n // Calculate threshold for minimum visible bar height\n const minBarHeight = _calculateMinBarHeight(_yMin, _yMax, yReferencePoint, yBarScale);\n let adjustedBarHeight = barHeight;\n\n if (barHeight === 0) {\n return <React.Fragment key={point.x as string}> </React.Fragment>;\n }\n // Adjust bar height if it's smaller than the threshold\n else if (barHeight <= minBarHeight) {\n adjustedBarHeight = minBarHeight;\n }\n const xPoint = xBarScale(point.x as number) - _barWidth / 2;\n const yPoint =\n containerHeight -\n margins.bottom! -\n (isHeightNegative ? -1 * adjustedBarHeight : adjustedBarHeight) -\n yBarScale(yReferencePoint);\n const baselineHeight = containerHeight - margins.bottom! - yBarScale(yReferencePoint);\n return (\n <g key={point.x instanceof Date ? `${point.x.getTime()}_${index}` : `${point.x}_${index}`}>\n <rect\n id={`${_vbcBarId}-${index}`}\n x={xPoint}\n className={classes.opacityChangeOnHover}\n y={!isHeightNegative ? yPoint : baselineHeight}\n width={_barWidth}\n data-is-focusable={!props.hideTooltip && shouldHighlight}\n height={adjustedBarHeight}\n ref={(e: SVGRectElement) => {\n _refCallback(e, point.legend!);\n }}\n onClick={point.onClick}\n onMouseOver={event => _onBarHover(point, colorScale(point.y), event)}\n aria-label={_getAriaLabel(point)}\n role=\"img\"\n onMouseLeave={_onBarLeave}\n onFocus={_onBarFocus.bind(point, index, colorScale(point.y))}\n onBlur={_onBarLeave}\n fill={point.color && !useSingleColor ? point.color : colorScale(point.y)}\n tabIndex={point.legend !== '' ? 0 : undefined}\n rx={props.roundCorners ? 3 : 0}\n opacity={shouldHighlight ? 1 : 0.1}\n />\n {_renderBarLabel(xPoint, yPoint, point.y, point.legend!, isHeightNegative)}\n </g>\n );\n });\n // Removing un wanted tooltip div from DOM, when prop not provided.\n if (!props.showXAxisLablesTooltip) {\n try {\n // eslint-disable-next-line no-restricted-globals\n document.getElementById(_tooltipId) && document.getElementById(_tooltipId)!.remove();\n // eslint-disable-next-line no-empty\n } catch (e) {}\n }\n // Used to display tooltip at x axis labels.\n if (!props.wrapXAxisLables && props.showXAxisLablesTooltip) {\n const xAxisElement = d3Select(xElement).call(xBarScale);\n try {\n // eslint-disable-next-line no-restricted-globals\n document.getElementById(_tooltipId) && document.getElementById(_tooltipId)!.remove();\n // eslint-disable-next-line no-empty\n } catch (e) {}\n const tooltipProps = {\n tooltipCls: classes.tooltip!,\n id: _tooltipId,\n xAxis: xAxisElement,\n };\n xAxisElement && tooltipOfXAxislabels(tooltipProps);\n }\n return bars;\n }\n\n function _onLegendHover(legendTitle: string): void {\n setActiveLegend(legendTitle);\n }\n\n function _onLegendLeave(): void {\n setActiveLegend(undefined);\n }\n\n function _getLegendData(data: VerticalBarChartDataPoint[]): JSX.Element {\n const { useSingleColor } = props;\n const { lineLegendText, lineLegendColor = tokens.colorPaletteYellowForeground1 } = props;\n const actions: Legend[] = [];\n const mapLegendToColor: Record<string, string> = {};\n data.forEach((point: VerticalBarChartDataPoint, _index: number) => {\n // eslint-disable-next-line @typescript-eslint/no-shadow\n const color: string = !useSingleColor ? point.color! : _createColors()(1);\n mapLegendToColor[point.legend!] = color;\n });\n Object.entries(mapLegendToColor).forEach(([legendTitle, color]) => {\n // mapping data to the format Legends component needs\n const legend: Legend = {\n title: legendTitle,\n color,\n hoverAction: () => {\n _handleChartMouseLeave();\n _onLegendHover(legendTitle);\n },\n onMouseOutAction: () => {\n _onLegendLeave();\n },\n };\n actions.push(legend);\n });\n if (_isHavingLine && lineLegendText && lineLegendColor) {\n const lineLegend: Legend = {\n title: lineLegendText,\n color: lineLegendColor,\n hoverAction: () => {\n _handleChartMouseLeave();\n _onLegendHover(lineLegendText);\n },\n onMouseOutAction: () => {\n _onLegendLeave();\n },\n isLineLegendInBarChart: true,\n };\n actions.unshift(lineLegend);\n }\n const legends = (\n <Legends\n legends={actions}\n enabledWrapLines={props.enabledLegendsWrapLines}\n overflowText={props.legendsOverflowText}\n {...props.legendProps}\n selectedLegends={selectedLegends}\n onChange={_onLegendSelectionChange}\n />\n );\n return legends;\n }\n\n function _onLegendSelectionChange(\n legendsSelected: string[],\n event: React.MouseEvent<HTMLButtonElement>,\n currentLegend?: Legend,\n ): void {\n if (props.legendProps?.canSelectMultipleLegends) {\n setSelectedLegends(legendsSelected);\n } else {\n setSelectedLegends(legendsSelected.slice(-1));\n }\n\n if (props.legendProps?.onChange) {\n props.legendProps.onChange(legendsSelected, event, currentLegend);\n }\n }\n\n function _getAxisData(yAxisData: IAxisData) {\n if (yAxisData && yAxisData.yAxisDomainValues.length) {\n const { yAxisDomainValues: domainValue } = yAxisData;\n _yMax = Math.max(domainValue[domainValue.length - 1], props.yMaxValue || 0);\n _yMin = Math.min(domainValue[0], props.yMinValue || 0);\n }\n }\n\n /**\n * This function checks if the given legend is highlighted or not.\n * A legend can be highlighted in 2 ways:\n * 1. selection: if the user clicks on it\n * 2. hovering: if there is no selected legend and the user hovers over it\n */\n function _legendHighlighted(legendTitle: string | undefined): boolean {\n return _getHighlightedLegend().includes(legendTitle!);\n }\n\n /**\n * This function checks if none of the legends is selected or hovered.\n */\n function _noLegendHighlighted(): boolean {\n return _getHighlightedLegend().length === 0;\n }\n\n function _getHighlightedLegend() {\n return selectedLegends.length > 0 ? selectedLegends : activeLegend ? [activeLegend] : [];\n }\n\n function _getAriaLabel(point: VerticalBarChartDataPoint): string {\n const xValue = point.xAxisCalloutData\n ? point.xAxisCalloutData\n : point.x instanceof Date\n ? point.x.toLocaleString()\n : point.x;\n const legend = point.legend;\n const yValue = point.yAxisCalloutData || point.y;\n const lineLegend = props.lineLegendText || 'Line';\n const lineYValue = point.lineData?.yAxisCalloutData || point.lineData?.y;\n return (\n point.callOutAccessibilityData?.ariaLabel ||\n `${xValue}. ` +\n (legend ? `${legend}, ` : '') +\n `${yValue}.` +\n (typeof lineYValue !== 'undefined' ? ` ${lineLegend}, ${lineYValue}.` : '')\n );\n }\n\n function _renderBarLabel(xPoint: number, yPoint: number, barValue: number, legend: string, isNegativeBar: boolean) {\n if (props.hideLabels || _barWidth < 16 || !(_legendHighlighted(legend) || _noLegendHighlighted())) {\n return null;\n }\n\n return (\n <text\n x={xPoint + _barWidth / 2}\n y={isNegativeBar ? yPoint + 12 : yPoint - 6}\n textAnchor=\"middle\"\n className={classes.barLabel}\n aria-hidden={true}\n >\n {formatValueWithSIPrefix(barValue)}\n </text>\n );\n }\n\n function _getDomainMargins(containerWidth: number): Margins {\n _domainMargin = MIN_DOMAIN_MARGIN;\n\n /** Total width available to render the bars */\n const totalWidth = containerWidth - (margins.left! + MIN_DOMAIN_MARGIN) - (margins.right! + MIN_DOMAIN_MARGIN);\n /** Rate at which the space between the bars changes wrt the bar width */\n const barGapRate = _xAxisInnerPadding / (1 - _xAxisInnerPadding);\n\n if (_xAxisType === XAxisTypes.StringAxis) {\n if (isScalePaddingDefined(props.xAxisOuterPadding, props.xAxisPadding)) {\n // Setting the domain margin for string x-axis to 0 because the xAxisOuterPadding prop is now available\n // to adjust the space before the first bar and after the last bar.\n _domainMargin = 0;\n } else if (props.barWidth !== 'auto') {\n // Update the bar width so that when CartesianChart rerenders,\n // the following calculations don't use the previous bar width.\n _barWidth = getBarWidth(props.barWidth, props.maxBarWidth);\n /** Total width required to render the bars. Directly proportional to bar width */\n const reqWidth = (_xAxisLabels.length + (_xAxisLabels.length - 1) * barGapRate) * _barWidth;\n\n if (totalWidth >= reqWidth) {\n // Center align the chart by setting equal left and right margins for domain\n _domainMargin = MIN_DOMAIN_MARGIN + (totalWidth - reqWidth) / 2;\n }\n } else if (props.mode === 'plotly' && _xAxisLabels.length > 1) {\n // Calculate the remaining width after rendering bars at their maximum allowable width\n const bandwidth = totalWidth / (_xAxisLabels.length + (_xAxisLabels.length - 1) * barGapRate);\n const barWidth = getBarWidth(props.barWidth, props.maxBarWidth, bandwidth);\n let reqWidth = (_xAxisLabels.length + (_xAxisLabels.length - 1) * barGapRate) * barWidth;\n const margin1 = (totalWidth - reqWidth) / 2;\n\n // Calculate the remaining width after accounting for the space required to render x-axis labels\n const step = calculateLongestLabelWidth(_xAxisLabels) + 20;\n reqWidth = (_xAxisLabels.length - _xAxisInnerPadding) * step;\n const margin2 = (totalWidth - reqWidth) / 2;\n\n _domainMargin = MIN_DOMAIN_MARGIN + Math.max(0, Math.min(margin1, margin2));\n }\n } else {\n const uniqueX: Record<number, number | Date> = {};\n props.data?.forEach(point => {\n if (point.x instanceof Date) {\n uniqueX[point.x.getTime()] = point.x;\n } else {\n uniqueX[point.x as number] = point.x as number;\n }\n });\n const data = Object.values(uniqueX) as number[] | Date[];\n _barWidth = getBarWidth(props.barWidth, props.maxBarWidth, calculateAppropriateBarWidth(data, totalWidth));\n _domainMargin = MIN_DOMAIN_MARGIN + _barWidth / 2;\n }\n\n return {\n ...margins,\n left: margins.left! + _domainMargin,\n right: margins.right! + _domainMargin,\n };\n }\n\n function _isChartEmpty(): boolean {\n return _points.length === 0 || (_points.every(point => point.y === 0) && !_isHavingLine);\n }\n\n function updatePosition(newX: number, newY: number) {\n const threshold = 1; // Set a threshold for movement\n const { x, y } = clickPosition;\n // Calculate the distance moved\n const distance = Math.sqrt(Math.pow(newX - x, 2) + Math.pow(newY - y, 2));\n // Update the position only if the distance moved is greater than the threshold\n if (distance > threshold) {\n setClickPosition({ x: newX, y: newY });\n setPopoverOpen(true);\n }\n }\n\n _adjustProps();\n _xAxisLabels = _points.map((point: VerticalBarChartDataPoint) => point.x as string);\n _yMax = Math.max(d3Max(_points, (point: VerticalBarChartDataPoint) => point.y)!, props.yMaxValue || 0);\n _yMin = Math.min(d3Min(_points, (point: VerticalBarChartDataPoint) => point.y)!, props.yMinValue || 0);\n const legendBars: JSX.Element = _getLegendData(_points);\n const calloutProps = {\n ...(_isHavingLine && {\n YValueHover: hoveredYValues,\n hoverXValue: hoverXValue,\n }),\n color: color,\n legend: calloutLegend,\n XValue: xCalloutValue,\n YValue: yCalloutValue ? yCalloutValue : dataForHoverCard,\n ...props.calloutProps,\n ...getAccessibleDataObject(callOutAccessibilityData),\n clickPosition: clickPosition,\n isPopoverOpen: isPopoverOpen,\n isCalloutForStack: _isHavingLine && (_noLegendHighlighted() || _getHighlightedLegend().length > 1),\n culture: props.culture ?? 'en-us',\n isCartesian: true,\n customCallout: {\n customizedCallout: _getCustomizedCallout() != null ? _getCustomizedCallout()! : undefined,\n customCalloutProps: props.calloutPropsPerDataPoint\n ? props.calloutPropsPerDataPoint(dataPointCalloutProps!)\n : undefined,\n },\n };\n\n const tickParams = {\n tickValues: props.tickValues,\n tickFormat: props.tickFormat,\n };\n return !_isChartEmpty() ? (\n <CartesianChart\n {...props}\n points={_points}\n chartType={ChartTypes.VerticalBarChart}\n xAxisType={_xAxisType}\n calloutProps={calloutProps}\n tickParams={tickParams}\n {...(_isHavingLine && _noLegendHighlighted() && { isCalloutForStack: true })}\n legendBars={legendBars}\n datasetForXAxisDomain={_xAxisLabels}\n barwidth={_barWidth}\n getmargins={_getMargins}\n getGraphData={_getGraphData}\n getAxisData={_getAxisData}\n onChartMouseLeave={_handleChartMouseLeave}\n getDomainMargins={_getDomainMargins}\n {...(_xAxisType === XAxisTypes.StringAxis && {\n xAxisInnerPadding: _xAxisInnerPadding,\n xAxisOuterPadding: _xAxisOuterPadding,\n })}\n componentRef={cartesianChartRef}\n /* eslint-disable react/jsx-no-bind */\n // eslint-disable-next-line react/no-children-prop\n children={(props: ChildProps) => {\n return (\n <>\n <g>{_bars}</g>\n {_isHavingLine && (\n <g>\n {_createLine(\n props.xScale!,\n props.yScale!,\n props.containerHeight,\n props.containerWidth,\n props.yScaleSecondary,\n )}\n </g>\n )}\n </>\n );\n }}\n />\n ) : (\n <div id={_emptyChartId} role={'alert'} style={{ opacity: '0' }} aria-label={'Graph has no data to display'} />\n );\n});\nVerticalBarChart.displayName = 'VerticalBarChart';\n"],"names":["React","useVerticalBarChartStyles","max","d3Max","min","d3Min","line","d3Line","select","d3Select","scaleLinear","d3ScaleLinear","scaleBand","d3ScaleBand","scaleUtc","d3ScaleUtc","useId","tokens","CartesianChart","Legends","ChartPopover","ChartTypes","getAccessibleDataObject","XAxisTypes","getTypeOfAxis","tooltipOfXAxislabels","formatValueWithSIPrefix","getBarWidth","getScalePadding","isScalePaddingDefined","calculateAppropriateBarWidth","useRtl","areArraysEqual","calculateLongestLabelWidth","CircleVisbility","MIN_DOMAIN_MARGIN","VerticalBarChart","forwardRef","props","forwardedRef","_points","_barWidth","_colors","_refArray","margins","_useRtl","_bars","_xAxisLabels","_yMax","_yMin","_isHavingLine","_checkForLine","_tooltipId","_xAxisType","data","length","x","StringAxis","_calloutAnchorPoint","_domainMargin","_emptyChartId","_vbcLineId","_vbcPointId","_vbcBarId","_xAxisInnerPadding","_xAxisOuterPadding","cartesianChartRef","useRef","color","setColor","useState","dataForHoverCard","setDataForHoverCard","activeLegend","setActiveLegend","undefined","xCalloutValue","setXCalloutValue","yCalloutValue","setYCalloutValue","activeXdataPoint","setActiveXDatapoint","hoveredYValues","setYValueHover","hoverXValue","setHoverXValue","calloutLegend","setCalloutLegend","callOutAccessibilityData","setCalloutAccessibilityData","dataPointCalloutProps","setDataPointCalloutProps","clickPosition","setClickPosition","y","isPopoverOpen","setPopoverOpen","selectedLegends","setSelectedLegends","legendProps","prevPropsRef","useImperativeHandle","componentRef","chartContainer","current","useEffect","prevProps","height","width","_adjustProps","_createLine","xScale","yScale","containerHeight","containerWidth","yScaleSecondary","isStringAxis","colorScale","_createColors","lineLegendColor","colorPaletteYellowBackground1","lineLegendText","lineData","forEach","item","index","push","useSecondaryYScale","point","linePath","d","bandwidth","shouldHighlight","_legendHighlighted","_noLegendHighlighted","lineBorderWidth","lineOptions","Number","parseFloat","toString","path","key","id","opacity","fill","strokeLinecap","strokeWidth","stroke","colorNeutralBackground1","dots","map","circleRef","refElement","circle","cx","cy","onMouseOver","event","_lineHover","_onBarHover","onMouseOut","_onBarLeave","r","_getCircleVisibilityAndRadius","radius","visibility","onClick","data-is-focusable","ref","e","onFocus","_lineFocus","bind","onBlur","_handleChartMouseLeave","xAxisPoint","legend","some","barWidth","maxBarWidth","defaultColors","colorPaletteBlueForeground2","colorPaletteCornflowerForeground2","colorPaletteDarkGreenForeground2","colorPaletteNavyForeground2","colorPaletteDarkOrangeForeground2","colors","xAxisInnerPadding","xAxisPadding","xAxisOuterPadding","_getMargins","_margins","_renderContentForBothLineAndBars","YValueHover","_getCalloutContentForLineAndBar","content","culture","XValue","YValue","isCalloutForStack","_renderContentForOnlyBars","_props","xAxisCalloutData","yAxisCalloutData","useSingleColor","_renderCallout","_getCustomizedCallout","onRenderCalloutPerDataPoint","_getGraphData","xElement","NumericAxis","_createNumericBars","DateAxis","_createDateBars","_createStringBars","increment","_p","colorPaletteBlueBackground2","domainValues","i","domain","range","_refCallback","element","legendTitle","selectedPoint","filter","xDataPoint","includes","Date","toLocaleString","mouseEvent","persist","updatePosition","clientX","clientY","toLocaleDateString","_onBarFocus","refArrayIndexNumber","obj","_lineHoverFocus","_refSelected","_getScales","xBarScale","yBarScale","bottom","top","xMax","xMin","nice","left","right","sDate","lDate","paddingInner","paddingOuter","classes","_calculateMinBarHeight","yMin","yMax","yReferencePoint","maxHeightFromBaseline","Math","abs","ceil","bars","barHeight","isHeightNegative","minBarHeight","adjustedBarHeight","Fragment","xPoint","yPoint","baselineHeight","g","rect","hideTooltip","aria-label","_getAriaLabel","role","onMouseLeave","tabIndex","rx","roundCorners","_renderBarLabel","showXAxisLablesTooltip","document","getElementById","remove","wrapXAxisLables","xAxisElement","call","tooltipProps","tooltipCls","tooltip","xAxis","getTime","transform","showTooltip","className","opacityChangeOnHover","_onLegendHover","_onLegendLeave","_getLegendData","colorPaletteYellowForeground1","actions","mapLegendToColor","_index","Object","entries","title","hoverAction","onMouseOutAction","lineLegend","isLineLegendInBarChart","unshift","legends","enabledWrapLines","enabledLegendsWrapLines","overflowText","legendsOverflowText","onChange","_onLegendSelectionChange","legendsSelected","currentLegend","canSelectMultipleLegends","slice","_getAxisData","yAxisData","yAxisDomainValues","domainValue","yMaxValue","yMinValue","_getHighlightedLegend","xValue","yValue","lineYValue","ariaLabel","barValue","isNegativeBar","hideLabels","text","textAnchor","barLabel","aria-hidden","_getDomainMargins","totalWidth","barGapRate","reqWidth","mode","margin1","step","margin2","uniqueX","values","_isChartEmpty","every","newX","newY","threshold","distance","sqrt","pow","legendBars","calloutProps","isCartesian","customCallout","customizedCallout","customCalloutProps","calloutPropsPerDataPoint","tickParams","tickValues","tickFormat","points","chartType","xAxisType","datasetForXAxisDomain","barwidth","getmargins","getGraphData","getAxisData","onChartMouseLeave","getDomainMargins","children","div","style","displayName"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":"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"}
1
+ {"version":3,"sources":["VerticalBarChart.tsx"],"sourcesContent":["import * as React from 'react';\nimport { useVerticalBarChartStyles } from './useVerticalBarChartStyles.styles';\nimport { max as d3Max, min as d3Min } from 'd3-array';\nimport { line as d3Line } from 'd3-shape';\nimport { select as d3Select } from 'd3-selection';\nimport {\n scaleLinear as d3ScaleLinear,\n ScaleLinear as D3ScaleLinear,\n scaleBand as d3ScaleBand,\n scaleUtc as d3ScaleUtc,\n} from 'd3-scale';\nimport { useId } from '@fluentui/react-utilities';\nimport { tokens } from '@fluentui/react-theme';\nimport {\n AccessibilityProps,\n CartesianChart,\n Margins,\n Legend,\n RefArrayData,\n VerticalBarChartProps,\n VerticalBarChartDataPoint,\n Legends,\n ChildProps,\n YValueHover,\n ChartPopover,\n Chart,\n} from '../../index';\nimport {\n ChartTypes,\n IAxisData,\n getAccessibleDataObject,\n XAxisTypes,\n NumericAxis,\n getTypeOfAxis,\n tooltipOfXAxislabels,\n formatScientificLimitWidth,\n getBarWidth,\n getScalePadding,\n isScalePaddingDefined,\n calculateAppropriateBarWidth,\n useRtl,\n areArraysEqual,\n calculateLongestLabelWidth,\n} from '../../utilities/index';\n\nenum CircleVisbility {\n show = 'visibility',\n hide = 'hidden',\n}\n\nconst MIN_DOMAIN_MARGIN = 8;\n\n// Create a VerticalBarChart variant which uses these default styles and this styled subcomponent.\n/**\n * VerticalBarchart component\n * {@docCategory VerticalBarChart}\n */\nexport const VerticalBarChart: React.FunctionComponent<VerticalBarChartProps> = React.forwardRef<\n HTMLDivElement,\n VerticalBarChartProps\n>((props, forwardedRef) => {\n let _points: VerticalBarChartDataPoint[] = [];\n let _barWidth: number = 0;\n let _colors: string[];\n const _refArray: RefArrayData[] = [];\n let margins: Margins;\n const _useRtl: boolean = useRtl();\n let _bars: JSX.Element[];\n let _xAxisLabels: string[];\n let _yMax: number;\n let _yMin: number;\n let _isHavingLine: boolean = _checkForLine();\n const _tooltipId: string = useId('VCTooltipID_');\n const _xAxisType: XAxisTypes =\n props.data! && props.data!.length > 0\n ? (getTypeOfAxis(props.data![0].x, true) as XAxisTypes)\n : XAxisTypes.StringAxis;\n let _calloutAnchorPoint: VerticalBarChartDataPoint | null;\n let _domainMargin: number;\n const _emptyChartId: string = useId('_VBC_empty');\n const _vbcLineId: string = useId('_VBC_line_');\n const _vbcPointId: string = useId('_VBC_point_');\n const _vbcBarId: string = useId('_VBC_bar_');\n let _xAxisInnerPadding: number = 0;\n let _xAxisOuterPadding: number = 0;\n type ColorScale = (_p?: number) => string;\n const cartesianChartRef = React.useRef<Chart>(null);\n\n const [color, setColor] = React.useState<string>('');\n const [dataForHoverCard, setDataForHoverCard] = React.useState<number>(0);\n const [activeLegend, setActiveLegend] = React.useState<string | undefined>(undefined);\n const [xCalloutValue, setXCalloutValue] = React.useState<string | undefined>('');\n const [yCalloutValue, setYCalloutValue] = React.useState<string | undefined>('');\n const [activeXdataPoint, setActiveXDatapoint] = React.useState<string | number | Date | null>(null);\n const [hoveredYValues, setYValueHover] = React.useState<YValueHover[]>();\n const [hoverXValue, setHoverXValue] = React.useState<string | number | undefined>('');\n const [calloutLegend, setCalloutLegend] = React.useState<string>('');\n const [callOutAccessibilityData, setCalloutAccessibilityData] = React.useState<AccessibilityProps>();\n const [dataPointCalloutProps, setDataPointCalloutProps] = React.useState<VerticalBarChartDataPoint>();\n const [clickPosition, setClickPosition] = React.useState({ x: 0, y: 0 });\n const [isPopoverOpen, setPopoverOpen] = React.useState(false);\n const [selectedLegends, setSelectedLegends] = React.useState<string[]>(props.legendProps?.selectedLegends || []);\n const prevPropsRef = React.useRef<VerticalBarChartProps | null>(null);\n\n React.useImperativeHandle(\n props.componentRef,\n () => ({\n chartContainer: cartesianChartRef.current?.chartContainer ?? null,\n }),\n [],\n );\n\n React.useEffect(() => {\n if (prevPropsRef.current) {\n const prevProps = prevPropsRef.current;\n if (!areArraysEqual(prevProps.legendProps?.selectedLegends, props.legendProps?.selectedLegends)) {\n setSelectedLegends(props.legendProps?.selectedLegends || []);\n }\n if (prevProps.height !== props.height || prevProps.width !== props.width) {\n _adjustProps();\n }\n }\n prevPropsRef.current = props;\n }, [props, prevPropsRef, _adjustProps]);\n\n function _createLine(\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n xScale: any,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n yScale: any,\n containerHeight: number = 0,\n containerWidth: number = 0,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n yScaleSecondary?: any,\n ): React.ReactNode {\n const isStringAxis = _xAxisType === XAxisTypes.StringAxis;\n const colorScale = _createColors();\n const { data, lineLegendColor = tokens.colorPaletteYellowBackground1, lineLegendText } = props;\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const lineData: Array<any> = [];\n const line: JSX.Element[] = [];\n data &&\n data.forEach((item: VerticalBarChartDataPoint, index: number) => {\n if (item.lineData && item.lineData.y) {\n lineData.push({\n x: item.x,\n y: item.lineData!.y,\n useSecondaryYScale: item.lineData!.useSecondaryYScale ?? false,\n point: item,\n index,\n });\n }\n });\n const linePath = d3Line()\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n .x((d: any) => (isStringAxis ? xScale(d.x) + 0.5 * xScale.bandwidth() : xScale(d.x)))\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n .y((d: any) => (d.useSecondaryYScale && yScaleSecondary ? yScaleSecondary(d.y) : yScale(d.y)));\n const shouldHighlight = _legendHighlighted(lineLegendText!) || _noLegendHighlighted() ? true : false;\n const lineBorderWidth = props.lineOptions?.lineBorderWidth\n ? Number.parseFloat(props.lineOptions!.lineBorderWidth!.toString())\n : 0;\n\n if (lineBorderWidth > 0) {\n line.push(\n <path\n key={_vbcLineId}\n id={_vbcLineId}\n opacity={shouldHighlight ? 1 : 0.1}\n d={linePath(lineData)!}\n fill=\"transparent\"\n strokeLinecap=\"square\"\n strokeWidth={3 + lineBorderWidth * 2}\n stroke={tokens.colorNeutralBackground1}\n />,\n );\n }\n line.push(\n <path\n key={_vbcLineId}\n id={_vbcLineId}\n opacity={shouldHighlight ? 1 : 0.1}\n d={linePath(lineData)!}\n fill=\"transparent\"\n strokeLinecap=\"square\"\n strokeWidth={3}\n stroke={lineLegendColor}\n />,\n );\n\n const dots: React.ReactNode[] = lineData.map(\n (\n item: {\n x: number | string;\n y: number;\n useSecondaryYScale: boolean;\n point: VerticalBarChartDataPoint;\n index: number;\n },\n index: number,\n ) => {\n // Create an object to store line point ref so that the object can be passed by reference to the focus handler\n const circleRef: { refElement: SVGCircleElement | null } = { refElement: null };\n return (\n <circle\n key={index}\n id={`${_vbcPointId}-${index}`}\n cx={isStringAxis ? xScale(item.x) + 0.5 * xScale.bandwidth() : xScale(item.x)}\n cy={item.useSecondaryYScale && yScaleSecondary ? yScaleSecondary(item.y) : yScale(item.y)}\n onMouseOver={event =>\n _legendHighlighted(lineLegendText!)\n ? _lineHover(item.point, event)\n : _onBarHover(item.point, colorScale(item.y), event)\n }\n onMouseOut={_onBarLeave}\n r={_getCircleVisibilityAndRadius(item.x, lineLegendText!).radius}\n stroke={lineLegendColor}\n fill={tokens.colorNeutralBackground1}\n strokeWidth={3}\n visibility={_getCircleVisibilityAndRadius(item.x, lineLegendText!).visibility}\n onClick={item.point.lineData?.onClick}\n // When no legend is highlighted: Line points are automatically displayed along with the bars\n // at the same x-axis point in the stack callout. So to prevent an increase in focusable elements\n // and avoid conveying duplicate info, make these line points non-focusable.\n data-is-focusable={_legendHighlighted(lineLegendText!)}\n ref={e => (circleRef.refElement = e)}\n onFocus={_lineFocus.bind(item.point, circleRef)}\n onBlur={_handleChartMouseLeave}\n />\n );\n },\n );\n\n return (\n <>\n {line}\n {dots}\n </>\n );\n }\n\n function _getCircleVisibilityAndRadius(\n xAxisPoint: string | number | Date,\n legend: string,\n ): { visibility: CircleVisbility; radius: number } {\n if (!_noLegendHighlighted()) {\n if (xAxisPoint === activeXdataPoint && _legendHighlighted(legend)) {\n return { visibility: CircleVisbility.show, radius: 8 };\n } else if (_legendHighlighted(legend)) {\n // Don't hide the circle to keep it focusable. For more information,\n // see https://fuzzbomb.github.io/accessibility-demos/visually-hidden-focus-test.html\n return { visibility: CircleVisbility.show, radius: 0.3 };\n } else {\n return { visibility: CircleVisbility.hide, radius: 0 };\n }\n } else {\n return {\n visibility: activeXdataPoint === xAxisPoint ? CircleVisbility.show : CircleVisbility.hide,\n radius: 8,\n };\n }\n }\n\n function _checkForLine(): boolean {\n const { data } = props;\n return data!.some((item: VerticalBarChartDataPoint) => item?.lineData?.y !== undefined);\n }\n\n function _adjustProps(): void {\n _points = props.data || [];\n _barWidth = getBarWidth(props.barWidth, props.maxBarWidth);\n const defaultColors: string[] = [\n tokens.colorPaletteBlueForeground2,\n tokens.colorPaletteCornflowerForeground2,\n tokens.colorPaletteDarkGreenForeground2,\n tokens.colorPaletteNavyForeground2,\n tokens.colorPaletteDarkOrangeForeground2,\n ];\n _colors = props.colors || defaultColors;\n _isHavingLine = _checkForLine();\n _xAxisInnerPadding = getScalePadding(props.xAxisInnerPadding, props.xAxisPadding, 2 / 3);\n _xAxisOuterPadding = getScalePadding(props.xAxisOuterPadding, props.xAxisPadding, 0);\n }\n\n function _getMargins(_margins: Margins) {\n margins = _margins;\n }\n\n function _renderContentForBothLineAndBars(point: VerticalBarChartDataPoint): JSX.Element {\n // eslint-disable-next-line @typescript-eslint/no-shadow\n const { YValueHover, hoverXValue } = _getCalloutContentForLineAndBar(point);\n const content: JSX.Element[] = YValueHover.map((item: YValueHover, index: number) => {\n return (\n <>\n <ChartPopover\n culture={props.culture ?? 'en-us'}\n clickPosition={clickPosition}\n isPopoverOpen={isPopoverOpen}\n legend={item.legend!}\n {...(index === 0 && { XValue: `${hoverXValue || item.data}` })}\n YValue={item.data || item.y}\n color={item.color}\n isCalloutForStack={false}\n />\n </>\n );\n });\n return <>{content}</>;\n }\n\n function _renderContentForOnlyBars(_props: VerticalBarChartDataPoint): JSX.Element {\n return (\n <>\n <ChartPopover\n XValue={_props.xAxisCalloutData || (_props.x as string)}\n xCalloutValue={xCalloutValue}\n yCalloutValue={yCalloutValue}\n culture={props.culture ?? 'en-us'}\n clickPosition={clickPosition}\n isPopoverOpen={isPopoverOpen}\n legend={_props.legend!}\n YValue={_props.yAxisCalloutData || _props.y}\n color={!props.useSingleColor && _props.color ? _props.color : _createColors()(_props.y)}\n isCalloutForStack={false}\n />\n </>\n );\n }\n\n // eslint-disable-next-line @typescript-eslint/no-shadow\n function _renderCallout(props?: VerticalBarChartDataPoint): JSX.Element | null {\n return props ? (_isHavingLine ? _renderContentForBothLineAndBars(props) : _renderContentForOnlyBars(props)) : null;\n }\n\n function _getCustomizedCallout() {\n return props.onRenderCalloutPerDataPoint\n ? props.onRenderCalloutPerDataPoint(dataPointCalloutProps, _renderCallout)\n : null;\n }\n\n function _getGraphData(\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n xScale: any,\n yScale: NumericAxis,\n containerHeight: number,\n containerWidth: number,\n xElement?: SVGElement | null,\n ) {\n return (_bars =\n _xAxisType === XAxisTypes.NumericAxis\n ? _createNumericBars(containerHeight, containerWidth, xElement!)\n : _xAxisType === XAxisTypes.DateAxis\n ? _createDateBars(containerHeight, containerWidth, xElement!)\n : _createStringBars(containerHeight, containerWidth, xElement!));\n }\n\n function _createColors(): D3ScaleLinear<string, string> | ColorScale {\n const increment = _colors.length <= 1 ? 1 : 1 / (_colors.length - 1);\n const { useSingleColor = false } = props;\n if (useSingleColor) {\n return (_p?: number) => {\n const { colors } = props;\n return colors && colors.length > 0 ? colors[0] : tokens.colorPaletteBlueBackground2;\n };\n }\n const domainValues = [];\n for (let i = 0; i < _colors.length; i++) {\n domainValues.push(increment * i * _yMax);\n }\n const colorScale = d3ScaleLinear<string>().domain(domainValues).range(_colors);\n return colorScale;\n }\n\n function _refCallback(element: SVGRectElement, legendTitle: string): void {\n _refArray.push({ index: legendTitle, refElement: element });\n }\n\n function _getCalloutContentForLineAndBar(point: VerticalBarChartDataPoint): {\n YValueHover: YValueHover[];\n hoverXValue: string | number | undefined;\n } {\n // eslint-disable-next-line @typescript-eslint/no-shadow\n const YValueHover: YValueHover[] = [];\n const { useSingleColor = false } = props;\n const { data, lineLegendText, lineLegendColor = tokens.colorPaletteYellowBackground1 } = props;\n const selectedPoint = data!.filter((xDataPoint: VerticalBarChartDataPoint) => xDataPoint.x === point.x);\n // Check if the line legend is highlighted or no legend is highlighted\n if (\n _isHavingLine &&\n selectedPoint[0].lineData?.y !== undefined &&\n (_legendHighlighted(lineLegendText) || _noLegendHighlighted())\n ) {\n // Add callout data for the line\n YValueHover.push({\n legend: lineLegendText,\n color: lineLegendColor,\n y: selectedPoint[0].lineData?.y,\n data: selectedPoint[0].lineData?.yAxisCalloutData,\n yAxisCalloutData: selectedPoint[0].lineData?.yAxisCalloutData,\n });\n }\n // Check if the bar legend is highlighted or no legend is highlighted\n if (selectedPoint[0].legend && (selectedLegends.includes(selectedPoint[0].legend) || _noLegendHighlighted())) {\n // Add callout data for the bar\n YValueHover.push({\n legend: selectedPoint[0].legend,\n y: selectedPoint[0].y,\n color: !useSingleColor\n ? selectedPoint[0].color\n ? selectedPoint[0].color\n : _createColors()(selectedPoint[0].y)\n : _createColors()(1),\n data: selectedPoint[0].yAxisCalloutData,\n yAxisCalloutData: selectedPoint[0].yAxisCalloutData,\n });\n }\n // eslint-disable-next-line @typescript-eslint/no-shadow\n const hoverXValue = point.x instanceof Date ? point.x.toLocaleString() : point.x.toString();\n return {\n YValueHover,\n hoverXValue: point.xAxisCalloutData || hoverXValue,\n };\n }\n\n function _onBarHover(\n point: VerticalBarChartDataPoint,\n // eslint-disable-next-line @typescript-eslint/no-shadow\n color: string,\n mouseEvent: React.MouseEvent<SVGElement>,\n ): void {\n mouseEvent.persist();\n\n // eslint-disable-next-line @typescript-eslint/no-shadow\n const { YValueHover, hoverXValue } = _getCalloutContentForLineAndBar(point);\n if (_calloutAnchorPoint !== point) {\n _calloutAnchorPoint = point;\n /** Show the callout if highlighted bar is hovered and Hide it if unhighlighted bar is hovered */\n updatePosition(mouseEvent.clientX, mouseEvent.clientY);\n setPopoverOpen(_noLegendHighlighted() || _legendHighlighted(point.legend));\n setDataForHoverCard(point.y);\n setCalloutLegend(point.legend!);\n setColor(point.color || color);\n // To display callout value, if no callout value given, taking given point.x value as a string.\n setXCalloutValue(\n point.xAxisCalloutData || (point.x instanceof Date ? point.x.toLocaleDateString() : point.x.toString()),\n );\n setDataPointCalloutProps(point);\n // Hovering over a bar should highlight corresponding line points only when no legend is selected\n setActiveXDatapoint(_noLegendHighlighted() ? point.x : null);\n setYValueHover(YValueHover);\n setHoverXValue(hoverXValue);\n setCalloutAccessibilityData(point.callOutAccessibilityData);\n }\n }\n\n function _onBarLeave(): void {\n /**/\n }\n\n function _handleChartMouseLeave(): void {\n _calloutAnchorPoint = null;\n setPopoverOpen(false);\n setActiveXDatapoint(null);\n setYValueHover([]);\n setHoverXValue('');\n }\n\n // eslint-disable-next-line @typescript-eslint/no-shadow\n function _onBarFocus(point: VerticalBarChartDataPoint, refArrayIndexNumber: number, color: string): void {\n // eslint-disable-next-line @typescript-eslint/no-shadow\n const { YValueHover, hoverXValue } = _getCalloutContentForLineAndBar(point);\n _refArray.forEach((obj: RefArrayData, index: number) => {\n if (obj.index === point.legend! && refArrayIndexNumber === index) {\n /** Show the callout if highlighted bar is hovered and Hide it if unhighlighted bar is hovered */\n setPopoverOpen(_noLegendHighlighted() || _legendHighlighted(point.legend));\n setDataForHoverCard(point.y);\n setCalloutLegend(point.legend!);\n setColor(point.color || color);\n // To display callout value, if no callout value given, taking given point.x value as a string.\n setXCalloutValue(\n point.xAxisCalloutData || (point.x instanceof Date ? point.x.toLocaleDateString() : point.x.toString()),\n );\n setYCalloutValue(point.yAxisCalloutData!);\n setDataPointCalloutProps(point);\n // Hovering over a bar should highlight corresponding line points only when no legend is selected\n setActiveXDatapoint(point.x);\n setYValueHover(YValueHover);\n setHoverXValue(hoverXValue);\n setCalloutAccessibilityData(point.callOutAccessibilityData);\n }\n });\n }\n\n function _lineHover(point: VerticalBarChartDataPoint, mouseEvent: React.MouseEvent<SVGElement>) {\n mouseEvent.persist();\n _lineHoverFocus(point, mouseEvent);\n }\n\n function _lineFocus(point: VerticalBarChartDataPoint, ref: { refElement: SVGCircleElement | null }) {\n if (ref.refElement) {\n _lineHoverFocus(point, ref.refElement);\n }\n }\n\n function _lineHoverFocus(\n point: VerticalBarChartDataPoint,\n _refSelected: React.MouseEvent<SVGElement> | SVGCircleElement,\n ) {\n const { lineLegendText = '', lineLegendColor = tokens.colorPaletteYellowBackground1 } = props;\n setPopoverOpen(_noLegendHighlighted() || _legendHighlighted(lineLegendText));\n setCalloutLegend(lineLegendText);\n setDataForHoverCard(point.lineData!.y);\n setColor(lineLegendColor);\n setXCalloutValue(\n point.xAxisCalloutData || (point.x instanceof Date ? point.x.toLocaleDateString() : point.x.toString()),\n );\n setYCalloutValue(point.lineData!.yAxisCalloutData);\n setDataPointCalloutProps(point);\n setActiveXDatapoint(point.x);\n }\n\n function _getScales(\n containerHeight: number,\n containerWidth: number,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n ): { xBarScale: any; yBarScale: any } {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n let xBarScale: any;\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const yBarScale: any = d3ScaleLinear()\n .domain([_yMin, _yMax])\n .range([0, containerHeight - margins.bottom! - margins.top!]);\n\n if (_xAxisType === XAxisTypes.NumericAxis) {\n const xMax = d3Max(_points, (point: VerticalBarChartDataPoint) => point.x as number)!;\n const xMin = d3Min(_points, (point: VerticalBarChartDataPoint) => point.x as number)!;\n xBarScale = d3ScaleLinear()\n .domain(_useRtl ? [xMax, xMin] : [xMin, xMax])\n .nice()\n .range([margins.left! + _domainMargin, containerWidth - margins.right! - _domainMargin]);\n } else if (_xAxisType === XAxisTypes.DateAxis) {\n const sDate = d3Min(_points, (point: VerticalBarChartDataPoint) => point.x as Date)!;\n const lDate = d3Max(_points, (point: VerticalBarChartDataPoint) => point.x as Date)!;\n xBarScale = d3ScaleUtc()\n .domain([sDate, lDate])\n .range(\n _useRtl\n ? [containerWidth - margins.right! - _domainMargin, margins.left! + _domainMargin]\n : [margins.left! + _domainMargin, containerWidth - margins.right! - _domainMargin],\n );\n } else {\n xBarScale = d3ScaleBand()\n .domain(_xAxisLabels)\n .range(\n _useRtl\n ? [containerWidth - margins.right! - _domainMargin, margins.left! + _domainMargin]\n : [margins.left! + _domainMargin, containerWidth - margins.right! - _domainMargin],\n )\n .paddingInner(_xAxisInnerPadding)\n .paddingOuter(_xAxisOuterPadding);\n }\n\n return { xBarScale, yBarScale };\n }\n\n const classes = useVerticalBarChartStyles(props);\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n function _calculateMinBarHeight(yMin: number, yMax: number, yReferencePoint: number, yBarScale: any): number {\n const maxHeightFromBaseline =\n yMax < 0\n ? Math.abs(yMin - yReferencePoint)\n : Math.max(Math.abs(yMax - yReferencePoint), Math.abs(yMin - yReferencePoint));\n return Math.ceil(yBarScale(maxHeightFromBaseline) / 100.0);\n }\n\n function _createNumericBars(containerHeight: number, containerWidth: number, xElement: SVGElement): JSX.Element[] {\n const { useSingleColor = false } = props;\n const { xBarScale, yBarScale } = _getScales(containerHeight, containerWidth);\n const colorScale = _createColors();\n const yReferencePoint = _yMax < 0 ? _yMax : 0;\n const bars = _points.map((point: VerticalBarChartDataPoint, index: number) => {\n const shouldHighlight = _legendHighlighted(point.legend!) || _noLegendHighlighted() ? true : false;\n\n let barHeight: number = yBarScale(point.y) - yBarScale(yReferencePoint);\n const isHeightNegative = barHeight < 0;\n barHeight = Math.abs(barHeight);\n // Calculate threshold for minimum visible bar height\n const minBarHeight = _calculateMinBarHeight(_yMin, _yMax, yReferencePoint, yBarScale);\n let adjustedBarHeight = barHeight;\n\n if (barHeight === 0) {\n return <React.Fragment key={point.x as string}> </React.Fragment>;\n }\n // Adjust bar height if it's smaller than the threshold\n else if (barHeight <= minBarHeight) {\n adjustedBarHeight = minBarHeight;\n }\n const xPoint = xBarScale(point.x as number) - _barWidth / 2;\n const yPoint =\n containerHeight -\n margins.bottom! -\n (isHeightNegative ? -1 * adjustedBarHeight : adjustedBarHeight) -\n yBarScale(yReferencePoint);\n const baselineHeight = containerHeight - margins.bottom! - yBarScale(yReferencePoint);\n return (\n <g key={`${point.x}_${index}` as string}>\n <rect\n id={`${_vbcBarId}-${index}`}\n x={xPoint}\n y={!isHeightNegative ? yPoint : baselineHeight}\n width={_barWidth}\n data-is-focusable={!props.hideTooltip && shouldHighlight}\n height={adjustedBarHeight}\n ref={(e: SVGRectElement) => {\n _refCallback(e, point.legend!);\n }}\n onClick={point.onClick}\n onMouseOver={event => _onBarHover(point, colorScale(point.y), event)}\n aria-label={_getAriaLabel(point)}\n role=\"img\"\n onMouseLeave={_onBarLeave}\n onFocus={_onBarFocus.bind(point, index, colorScale(point.y))}\n onBlur={_onBarLeave}\n fill={point.color && !useSingleColor ? point.color : colorScale(point.y)}\n tabIndex={point.legend !== '' ? 0 : undefined}\n opacity={shouldHighlight ? 1 : 0.1}\n rx={props.roundCorners ? 3 : 0}\n />\n {_renderBarLabel(xPoint, yPoint, point.y, point.legend!, isHeightNegative)}\n </g>\n );\n });\n // Removing un wanted tooltip div from DOM, when prop not provided.\n if (!props.showXAxisLablesTooltip) {\n try {\n // eslint-disable-next-line no-restricted-globals\n document.getElementById(_tooltipId) && document.getElementById(_tooltipId)!.remove();\n // eslint-disable-next-line no-empty\n } catch (e) {}\n }\n // Used to display tooltip at x axis labels.\n if (!props.wrapXAxisLables && props.showXAxisLablesTooltip) {\n const xAxisElement = d3Select(xElement).call(xBarScale);\n try {\n // eslint-disable-next-line no-restricted-globals\n document.getElementById(_tooltipId) && document.getElementById(_tooltipId)!.remove();\n // eslint-disable-next-line no-empty\n } catch (e) {}\n const tooltipProps = {\n tooltipCls: classes.tooltip!,\n id: _tooltipId,\n xAxis: xAxisElement,\n };\n xAxisElement && tooltipOfXAxislabels(tooltipProps);\n }\n return bars;\n }\n\n function _createStringBars(containerHeight: number, containerWidth: number, xElement: SVGElement): JSX.Element[] {\n const { xBarScale, yBarScale } = _getScales(containerHeight, containerWidth);\n const colorScale = _createColors();\n const yReferencePoint = _yMax < 0 ? _yMax : 0;\n const bars = _points.map((point: VerticalBarChartDataPoint, index: number) => {\n const shouldHighlight = _legendHighlighted(point.legend!) || _noLegendHighlighted() ? true : false;\n let barHeight: number = yBarScale(point.y) - yBarScale(yReferencePoint);\n const isHeightNegative = barHeight < 0;\n barHeight = Math.abs(barHeight);\n // Calculate threshold for minimum visible bar height\n const minBarHeight = _calculateMinBarHeight(_yMin, _yMax, yReferencePoint, yBarScale);\n let adjustedBarHeight = barHeight;\n\n if (barHeight === 0) {\n return <React.Fragment key={point.x as string}> </React.Fragment>;\n }\n // Adjust bar height if it's smaller than the threshold\n else if (barHeight <= minBarHeight) {\n adjustedBarHeight = minBarHeight;\n }\n const xPoint = xBarScale(point.x);\n const yPoint =\n containerHeight -\n margins.bottom! -\n (isHeightNegative ? -1 * adjustedBarHeight : adjustedBarHeight) -\n yBarScale(yReferencePoint);\n const baselineHeight = containerHeight - margins.bottom! - yBarScale(yReferencePoint);\n // Setting the bar width here is safe because there are no dependencies earlier in the code\n // that rely on the width of bars in vertical bar charts with string x-axis.\n _barWidth = getBarWidth(props.barWidth, props.maxBarWidth, xBarScale.bandwidth());\n return (\n <g\n key={point.x instanceof Date ? `${point.x.getTime()}_${index}` : `${point.x}_${index}`}\n transform={`translate(${0.5 * (xBarScale.bandwidth() - _barWidth)}, 0)`}\n >\n <rect\n id={`${_vbcBarId}-${index}`}\n x={xPoint}\n y={!isHeightNegative ? yPoint : baselineHeight}\n width={_barWidth}\n height={adjustedBarHeight}\n aria-label={_getAriaLabel(point)}\n role=\"img\"\n ref={(e: SVGRectElement) => {\n _refCallback(e, point.legend!);\n }}\n onClick={point.onClick}\n onMouseOver={event => _onBarHover(point, colorScale(point.y), event)}\n onMouseLeave={_onBarLeave}\n onBlur={_onBarLeave}\n data-is-focusable={!props.hideTooltip && shouldHighlight}\n onFocus={_onBarFocus.bind(point, index, colorScale(point.y))}\n fill={point.color ? point.color : colorScale(point.y)}\n tabIndex={point.legend !== '' ? 0 : undefined}\n rx={props.roundCorners ? 3 : 0}\n opacity={shouldHighlight ? 1 : 0.1}\n />\n {_renderBarLabel(xPoint, yPoint, point.y, point.legend!, isHeightNegative)}\n </g>\n );\n });\n\n // Removing un wanted tooltip div from DOM, when prop not provided.\n if (!props.showXAxisLablesTooltip) {\n try {\n // eslint-disable-next-line no-restricted-globals\n document.getElementById(_tooltipId) && document.getElementById(_tooltipId)!.remove();\n // eslint-disable-next-line no-empty\n } catch (e) {}\n }\n // Used to display tooltip at x axis labels.\n if (!props.wrapXAxisLables && props.showXAxisLablesTooltip) {\n const xAxisElement = d3Select(xElement).call(xBarScale);\n try {\n // eslint-disable-next-line no-restricted-globals\n document.getElementById(_tooltipId) && document.getElementById(_tooltipId)!.remove();\n // eslint-disable-next-line no-empty\n } catch (e) {}\n const tooltipProps = {\n tooltipCls: classes.tooltip!,\n id: _tooltipId,\n xAxis: xAxisElement,\n showTooltip: props.showXAxisLablesTooltip,\n };\n xAxisElement && tooltipOfXAxislabels(tooltipProps);\n }\n return bars;\n }\n\n function _createDateBars(containerHeight: number, containerWidth: number, xElement: SVGElement): JSX.Element[] {\n const { useSingleColor = false } = props;\n const { xBarScale, yBarScale } = _getScales(containerHeight, containerWidth);\n const colorScale = _createColors();\n const yReferencePoint = _yMax < 0 ? _yMax : 0;\n const bars = _points.map((point: VerticalBarChartDataPoint, index: number) => {\n const shouldHighlight = _legendHighlighted(point.legend!) || _noLegendHighlighted() ? true : false;\n let barHeight: number = yBarScale(point.y) - yBarScale(yReferencePoint);\n const isHeightNegative = barHeight < 0;\n barHeight = Math.abs(barHeight);\n // Calculate threshold for minimum visible bar height\n const minBarHeight = _calculateMinBarHeight(_yMin, _yMax, yReferencePoint, yBarScale);\n let adjustedBarHeight = barHeight;\n\n if (barHeight === 0) {\n return <React.Fragment key={point.x as string}> </React.Fragment>;\n }\n // Adjust bar height if it's smaller than the threshold\n else if (barHeight <= minBarHeight) {\n adjustedBarHeight = minBarHeight;\n }\n const xPoint = xBarScale(point.x as number) - _barWidth / 2;\n const yPoint =\n containerHeight -\n margins.bottom! -\n (isHeightNegative ? -1 * adjustedBarHeight : adjustedBarHeight) -\n yBarScale(yReferencePoint);\n const baselineHeight = containerHeight - margins.bottom! - yBarScale(yReferencePoint);\n return (\n <g key={point.x instanceof Date ? `${point.x.getTime()}_${index}` : `${point.x}_${index}`}>\n <rect\n id={`${_vbcBarId}-${index}`}\n x={xPoint}\n className={classes.opacityChangeOnHover}\n y={!isHeightNegative ? yPoint : baselineHeight}\n width={_barWidth}\n data-is-focusable={!props.hideTooltip && shouldHighlight}\n height={adjustedBarHeight}\n ref={(e: SVGRectElement) => {\n _refCallback(e, point.legend!);\n }}\n onClick={point.onClick}\n onMouseOver={event => _onBarHover(point, colorScale(point.y), event)}\n aria-label={_getAriaLabel(point)}\n role=\"img\"\n onMouseLeave={_onBarLeave}\n onFocus={_onBarFocus.bind(point, index, colorScale(point.y))}\n onBlur={_onBarLeave}\n fill={point.color && !useSingleColor ? point.color : colorScale(point.y)}\n tabIndex={point.legend !== '' ? 0 : undefined}\n rx={props.roundCorners ? 3 : 0}\n opacity={shouldHighlight ? 1 : 0.1}\n />\n {_renderBarLabel(xPoint, yPoint, point.y, point.legend!, isHeightNegative)}\n </g>\n );\n });\n // Removing un wanted tooltip div from DOM, when prop not provided.\n if (!props.showXAxisLablesTooltip) {\n try {\n // eslint-disable-next-line no-restricted-globals\n document.getElementById(_tooltipId) && document.getElementById(_tooltipId)!.remove();\n // eslint-disable-next-line no-empty\n } catch (e) {}\n }\n // Used to display tooltip at x axis labels.\n if (!props.wrapXAxisLables && props.showXAxisLablesTooltip) {\n const xAxisElement = d3Select(xElement).call(xBarScale);\n try {\n // eslint-disable-next-line no-restricted-globals\n document.getElementById(_tooltipId) && document.getElementById(_tooltipId)!.remove();\n // eslint-disable-next-line no-empty\n } catch (e) {}\n const tooltipProps = {\n tooltipCls: classes.tooltip!,\n id: _tooltipId,\n xAxis: xAxisElement,\n };\n xAxisElement && tooltipOfXAxislabels(tooltipProps);\n }\n return bars;\n }\n\n function _onLegendHover(legendTitle: string): void {\n setActiveLegend(legendTitle);\n }\n\n function _onLegendLeave(): void {\n setActiveLegend(undefined);\n }\n\n function _getLegendData(data: VerticalBarChartDataPoint[]): JSX.Element {\n const { useSingleColor } = props;\n const { lineLegendText, lineLegendColor = tokens.colorPaletteYellowForeground1 } = props;\n const actions: Legend[] = [];\n const mapLegendToColor: Record<string, string> = {};\n data.forEach((point: VerticalBarChartDataPoint, _index: number) => {\n // eslint-disable-next-line @typescript-eslint/no-shadow\n const color: string = !useSingleColor ? point.color! : _createColors()(1);\n mapLegendToColor[point.legend!] = color;\n });\n Object.entries(mapLegendToColor).forEach(([legendTitle, color]) => {\n // mapping data to the format Legends component needs\n const legend: Legend = {\n title: legendTitle,\n color,\n hoverAction: () => {\n _handleChartMouseLeave();\n _onLegendHover(legendTitle);\n },\n onMouseOutAction: () => {\n _onLegendLeave();\n },\n };\n actions.push(legend);\n });\n if (_isHavingLine && lineLegendText && lineLegendColor) {\n const lineLegend: Legend = {\n title: lineLegendText,\n color: lineLegendColor,\n hoverAction: () => {\n _handleChartMouseLeave();\n _onLegendHover(lineLegendText);\n },\n onMouseOutAction: () => {\n _onLegendLeave();\n },\n isLineLegendInBarChart: true,\n };\n actions.unshift(lineLegend);\n }\n const legends = (\n <Legends\n legends={actions}\n enabledWrapLines={props.enabledLegendsWrapLines}\n overflowText={props.legendsOverflowText}\n {...props.legendProps}\n selectedLegends={selectedLegends}\n onChange={_onLegendSelectionChange}\n />\n );\n return legends;\n }\n\n function _onLegendSelectionChange(\n legendsSelected: string[],\n event: React.MouseEvent<HTMLButtonElement>,\n currentLegend?: Legend,\n ): void {\n if (props.legendProps?.canSelectMultipleLegends) {\n setSelectedLegends(legendsSelected);\n } else {\n setSelectedLegends(legendsSelected.slice(-1));\n }\n\n if (props.legendProps?.onChange) {\n props.legendProps.onChange(legendsSelected, event, currentLegend);\n }\n }\n\n function _getAxisData(yAxisData: IAxisData) {\n if (yAxisData && yAxisData.yAxisDomainValues.length) {\n const { yAxisDomainValues: domainValue } = yAxisData;\n _yMax = Math.max(domainValue[domainValue.length - 1], props.yMaxValue || 0);\n _yMin = Math.min(domainValue[0], props.yMinValue || 0);\n }\n }\n\n /**\n * This function checks if the given legend is highlighted or not.\n * A legend can be highlighted in 2 ways:\n * 1. selection: if the user clicks on it\n * 2. hovering: if there is no selected legend and the user hovers over it\n */\n function _legendHighlighted(legendTitle: string | undefined): boolean {\n return _getHighlightedLegend().includes(legendTitle!);\n }\n\n /**\n * This function checks if none of the legends is selected or hovered.\n */\n function _noLegendHighlighted(): boolean {\n return _getHighlightedLegend().length === 0;\n }\n\n function _getHighlightedLegend() {\n return selectedLegends.length > 0 ? selectedLegends : activeLegend ? [activeLegend] : [];\n }\n\n function _getAriaLabel(point: VerticalBarChartDataPoint): string {\n const xValue = point.xAxisCalloutData\n ? point.xAxisCalloutData\n : point.x instanceof Date\n ? point.x.toLocaleString()\n : point.x;\n const legend = point.legend;\n const yValue = point.yAxisCalloutData || point.y;\n const lineLegend = props.lineLegendText || 'Line';\n const lineYValue = point.lineData?.yAxisCalloutData || point.lineData?.y;\n return (\n point.callOutAccessibilityData?.ariaLabel ||\n `${xValue}. ` +\n (legend ? `${legend}, ` : '') +\n `${yValue}.` +\n (typeof lineYValue !== 'undefined' ? ` ${lineLegend}, ${lineYValue}.` : '')\n );\n }\n\n function _renderBarLabel(xPoint: number, yPoint: number, barValue: number, legend: string, isNegativeBar: boolean) {\n if (props.hideLabels || _barWidth < 16 || !(_legendHighlighted(legend) || _noLegendHighlighted())) {\n return null;\n }\n\n return (\n <text\n x={xPoint + _barWidth / 2}\n y={isNegativeBar ? yPoint + 12 : yPoint - 6}\n textAnchor=\"middle\"\n className={classes.barLabel}\n aria-hidden={true}\n >\n {formatScientificLimitWidth(barValue)}\n </text>\n );\n }\n\n function _getDomainMargins(containerWidth: number): Margins {\n _domainMargin = MIN_DOMAIN_MARGIN;\n\n /** Total width available to render the bars */\n const totalWidth = containerWidth - (margins.left! + MIN_DOMAIN_MARGIN) - (margins.right! + MIN_DOMAIN_MARGIN);\n /** Rate at which the space between the bars changes wrt the bar width */\n const barGapRate = _xAxisInnerPadding / (1 - _xAxisInnerPadding);\n\n if (_xAxisType === XAxisTypes.StringAxis) {\n if (isScalePaddingDefined(props.xAxisOuterPadding, props.xAxisPadding)) {\n // Setting the domain margin for string x-axis to 0 because the xAxisOuterPadding prop is now available\n // to adjust the space before the first bar and after the last bar.\n _domainMargin = 0;\n } else if (props.barWidth !== 'auto') {\n // Update the bar width so that when CartesianChart rerenders,\n // the following calculations don't use the previous bar width.\n _barWidth = getBarWidth(props.barWidth, props.maxBarWidth);\n /** Total width required to render the bars. Directly proportional to bar width */\n const reqWidth = (_xAxisLabels.length + (_xAxisLabels.length - 1) * barGapRate) * _barWidth;\n\n if (totalWidth >= reqWidth) {\n // Center align the chart by setting equal left and right margins for domain\n _domainMargin = MIN_DOMAIN_MARGIN + (totalWidth - reqWidth) / 2;\n }\n } else if (props.mode === 'plotly' && _xAxisLabels.length > 1) {\n // Calculate the remaining width after rendering bars at their maximum allowable width\n const bandwidth = totalWidth / (_xAxisLabels.length + (_xAxisLabels.length - 1) * barGapRate);\n const barWidth = getBarWidth(props.barWidth, props.maxBarWidth, bandwidth);\n let reqWidth = (_xAxisLabels.length + (_xAxisLabels.length - 1) * barGapRate) * barWidth;\n const margin1 = (totalWidth - reqWidth) / 2;\n\n // Calculate the remaining width after accounting for the space required to render x-axis labels\n const step = calculateLongestLabelWidth(_xAxisLabels) + 20;\n reqWidth = (_xAxisLabels.length - _xAxisInnerPadding) * step;\n const margin2 = (totalWidth - reqWidth) / 2;\n\n _domainMargin = MIN_DOMAIN_MARGIN + Math.max(0, Math.min(margin1, margin2));\n }\n } else {\n const uniqueX: Record<number, number | Date> = {};\n props.data?.forEach(point => {\n if (point.x instanceof Date) {\n uniqueX[point.x.getTime()] = point.x;\n } else {\n uniqueX[point.x as number] = point.x as number;\n }\n });\n const data = Object.values(uniqueX) as number[] | Date[];\n _barWidth = getBarWidth(props.barWidth, props.maxBarWidth, calculateAppropriateBarWidth(data, totalWidth));\n _domainMargin = MIN_DOMAIN_MARGIN + _barWidth / 2;\n }\n\n return {\n ...margins,\n left: margins.left! + _domainMargin,\n right: margins.right! + _domainMargin,\n };\n }\n\n function _isChartEmpty(): boolean {\n return _points.length === 0 || (_points.every(point => point.y === 0) && !_isHavingLine);\n }\n\n function updatePosition(newX: number, newY: number) {\n const threshold = 1; // Set a threshold for movement\n const { x, y } = clickPosition;\n // Calculate the distance moved\n const distance = Math.sqrt(Math.pow(newX - x, 2) + Math.pow(newY - y, 2));\n // Update the position only if the distance moved is greater than the threshold\n if (distance > threshold) {\n setClickPosition({ x: newX, y: newY });\n setPopoverOpen(true);\n }\n }\n\n _adjustProps();\n _xAxisLabels = _points.map((point: VerticalBarChartDataPoint) => point.x as string);\n _yMax = Math.max(d3Max(_points, (point: VerticalBarChartDataPoint) => point.y)!, props.yMaxValue || 0);\n _yMin = Math.min(d3Min(_points, (point: VerticalBarChartDataPoint) => point.y)!, props.yMinValue || 0);\n const legendBars: JSX.Element = _getLegendData(_points);\n const calloutProps = {\n ...(_isHavingLine && {\n YValueHover: hoveredYValues,\n hoverXValue: hoverXValue,\n }),\n color: color,\n legend: calloutLegend,\n XValue: xCalloutValue,\n YValue: yCalloutValue ? yCalloutValue : dataForHoverCard,\n ...props.calloutProps,\n ...getAccessibleDataObject(callOutAccessibilityData),\n clickPosition: clickPosition,\n isPopoverOpen: isPopoverOpen,\n isCalloutForStack: _isHavingLine && (_noLegendHighlighted() || _getHighlightedLegend().length > 1),\n culture: props.culture ?? 'en-us',\n isCartesian: true,\n customCallout: {\n customizedCallout: _getCustomizedCallout() != null ? _getCustomizedCallout()! : undefined,\n customCalloutProps: props.calloutPropsPerDataPoint\n ? props.calloutPropsPerDataPoint(dataPointCalloutProps!)\n : undefined,\n },\n };\n\n const tickParams = {\n tickValues: props.tickValues,\n tickFormat: props.tickFormat,\n };\n return !_isChartEmpty() ? (\n <CartesianChart\n {...props}\n points={_points}\n chartType={ChartTypes.VerticalBarChart}\n xAxisType={_xAxisType}\n calloutProps={calloutProps}\n tickParams={tickParams}\n {...(_isHavingLine && _noLegendHighlighted() && { isCalloutForStack: true })}\n legendBars={legendBars}\n datasetForXAxisDomain={_xAxisLabels}\n barwidth={_barWidth}\n getmargins={_getMargins}\n getGraphData={_getGraphData}\n getAxisData={_getAxisData}\n onChartMouseLeave={_handleChartMouseLeave}\n getDomainMargins={_getDomainMargins}\n {...(_xAxisType === XAxisTypes.StringAxis && {\n xAxisInnerPadding: _xAxisInnerPadding,\n xAxisOuterPadding: _xAxisOuterPadding,\n })}\n componentRef={cartesianChartRef}\n /* eslint-disable react/jsx-no-bind */\n // eslint-disable-next-line react/no-children-prop\n children={(props: ChildProps) => {\n return (\n <>\n <g>{_bars}</g>\n {_isHavingLine && (\n <g>\n {_createLine(\n props.xScale!,\n props.yScale!,\n props.containerHeight,\n props.containerWidth,\n props.yScaleSecondary,\n )}\n </g>\n )}\n </>\n );\n }}\n />\n ) : (\n <div id={_emptyChartId} role={'alert'} style={{ opacity: '0' }} aria-label={'Graph has no data to display'} />\n );\n});\nVerticalBarChart.displayName = 'VerticalBarChart';\n"],"names":["React","useVerticalBarChartStyles","max","d3Max","min","d3Min","line","d3Line","select","d3Select","scaleLinear","d3ScaleLinear","scaleBand","d3ScaleBand","scaleUtc","d3ScaleUtc","useId","tokens","CartesianChart","Legends","ChartPopover","ChartTypes","getAccessibleDataObject","XAxisTypes","getTypeOfAxis","tooltipOfXAxislabels","formatScientificLimitWidth","getBarWidth","getScalePadding","isScalePaddingDefined","calculateAppropriateBarWidth","useRtl","areArraysEqual","calculateLongestLabelWidth","CircleVisbility","MIN_DOMAIN_MARGIN","VerticalBarChart","forwardRef","props","forwardedRef","_points","_barWidth","_colors","_refArray","margins","_useRtl","_bars","_xAxisLabels","_yMax","_yMin","_isHavingLine","_checkForLine","_tooltipId","_xAxisType","data","length","x","StringAxis","_calloutAnchorPoint","_domainMargin","_emptyChartId","_vbcLineId","_vbcPointId","_vbcBarId","_xAxisInnerPadding","_xAxisOuterPadding","cartesianChartRef","useRef","color","setColor","useState","dataForHoverCard","setDataForHoverCard","activeLegend","setActiveLegend","undefined","xCalloutValue","setXCalloutValue","yCalloutValue","setYCalloutValue","activeXdataPoint","setActiveXDatapoint","hoveredYValues","setYValueHover","hoverXValue","setHoverXValue","calloutLegend","setCalloutLegend","callOutAccessibilityData","setCalloutAccessibilityData","dataPointCalloutProps","setDataPointCalloutProps","clickPosition","setClickPosition","y","isPopoverOpen","setPopoverOpen","selectedLegends","setSelectedLegends","legendProps","prevPropsRef","useImperativeHandle","componentRef","chartContainer","current","useEffect","prevProps","height","width","_adjustProps","_createLine","xScale","yScale","containerHeight","containerWidth","yScaleSecondary","isStringAxis","colorScale","_createColors","lineLegendColor","colorPaletteYellowBackground1","lineLegendText","lineData","forEach","item","index","push","useSecondaryYScale","point","linePath","d","bandwidth","shouldHighlight","_legendHighlighted","_noLegendHighlighted","lineBorderWidth","lineOptions","Number","parseFloat","toString","path","key","id","opacity","fill","strokeLinecap","strokeWidth","stroke","colorNeutralBackground1","dots","map","circleRef","refElement","circle","cx","cy","onMouseOver","event","_lineHover","_onBarHover","onMouseOut","_onBarLeave","r","_getCircleVisibilityAndRadius","radius","visibility","onClick","data-is-focusable","ref","e","onFocus","_lineFocus","bind","onBlur","_handleChartMouseLeave","xAxisPoint","legend","some","barWidth","maxBarWidth","defaultColors","colorPaletteBlueForeground2","colorPaletteCornflowerForeground2","colorPaletteDarkGreenForeground2","colorPaletteNavyForeground2","colorPaletteDarkOrangeForeground2","colors","xAxisInnerPadding","xAxisPadding","xAxisOuterPadding","_getMargins","_margins","_renderContentForBothLineAndBars","YValueHover","_getCalloutContentForLineAndBar","content","culture","XValue","YValue","isCalloutForStack","_renderContentForOnlyBars","_props","xAxisCalloutData","yAxisCalloutData","useSingleColor","_renderCallout","_getCustomizedCallout","onRenderCalloutPerDataPoint","_getGraphData","xElement","NumericAxis","_createNumericBars","DateAxis","_createDateBars","_createStringBars","increment","_p","colorPaletteBlueBackground2","domainValues","i","domain","range","_refCallback","element","legendTitle","selectedPoint","filter","xDataPoint","includes","Date","toLocaleString","mouseEvent","persist","updatePosition","clientX","clientY","toLocaleDateString","_onBarFocus","refArrayIndexNumber","obj","_lineHoverFocus","_refSelected","_getScales","xBarScale","yBarScale","bottom","top","xMax","xMin","nice","left","right","sDate","lDate","paddingInner","paddingOuter","classes","_calculateMinBarHeight","yMin","yMax","yReferencePoint","maxHeightFromBaseline","Math","abs","ceil","bars","barHeight","isHeightNegative","minBarHeight","adjustedBarHeight","Fragment","xPoint","yPoint","baselineHeight","g","rect","hideTooltip","aria-label","_getAriaLabel","role","onMouseLeave","tabIndex","rx","roundCorners","_renderBarLabel","showXAxisLablesTooltip","document","getElementById","remove","wrapXAxisLables","xAxisElement","call","tooltipProps","tooltipCls","tooltip","xAxis","getTime","transform","showTooltip","className","opacityChangeOnHover","_onLegendHover","_onLegendLeave","_getLegendData","colorPaletteYellowForeground1","actions","mapLegendToColor","_index","Object","entries","title","hoverAction","onMouseOutAction","lineLegend","isLineLegendInBarChart","unshift","legends","enabledWrapLines","enabledLegendsWrapLines","overflowText","legendsOverflowText","onChange","_onLegendSelectionChange","legendsSelected","currentLegend","canSelectMultipleLegends","slice","_getAxisData","yAxisData","yAxisDomainValues","domainValue","yMaxValue","yMinValue","_getHighlightedLegend","xValue","yValue","lineYValue","ariaLabel","barValue","isNegativeBar","hideLabels","text","textAnchor","barLabel","aria-hidden","_getDomainMargins","totalWidth","barGapRate","reqWidth","mode","margin1","step","margin2","uniqueX","values","_isChartEmpty","every","newX","newY","threshold","distance","sqrt","pow","legendBars","calloutProps","isCartesian","customCallout","customizedCallout","customCalloutProps","calloutPropsPerDataPoint","tickParams","tickValues","tickFormat","points","chartType","xAxisType","datasetForXAxisDomain","barwidth","getmargins","getGraphData","getAxisData","onChartMouseLeave","getDomainMargins","children","div","style","displayName"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":"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"}