@fluentui/react-charts 0.0.0-nightly-20250911-0406.1 → 0.0.0-nightly-20250915-0408.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 (30) hide show
  1. package/CHANGELOG.md +15 -15
  2. package/lib/components/CommonComponents/CartesianChart.js +5 -7
  3. package/lib/components/CommonComponents/CartesianChart.js.map +1 -1
  4. package/lib/components/GroupedVerticalBarChart/GroupedVerticalBarChart.js +6 -4
  5. package/lib/components/GroupedVerticalBarChart/GroupedVerticalBarChart.js.map +1 -1
  6. package/lib/components/HeatMapChart/HeatMapChart.js +1 -1
  7. package/lib/components/HeatMapChart/HeatMapChart.js.map +1 -1
  8. package/lib/components/LineChart/LineChart.js +34 -32
  9. package/lib/components/LineChart/LineChart.js.map +1 -1
  10. package/lib/components/VerticalBarChart/VerticalBarChart.js +6 -3
  11. package/lib/components/VerticalBarChart/VerticalBarChart.js.map +1 -1
  12. package/lib/components/VerticalStackedBarChart/VerticalStackedBarChart.js +17 -15
  13. package/lib/components/VerticalStackedBarChart/VerticalStackedBarChart.js.map +1 -1
  14. package/lib/utilities/utilities.js +5 -5
  15. package/lib/utilities/utilities.js.map +1 -1
  16. package/lib-commonjs/components/CommonComponents/CartesianChart.js +5 -7
  17. package/lib-commonjs/components/CommonComponents/CartesianChart.js.map +1 -1
  18. package/lib-commonjs/components/GroupedVerticalBarChart/GroupedVerticalBarChart.js +6 -4
  19. package/lib-commonjs/components/GroupedVerticalBarChart/GroupedVerticalBarChart.js.map +1 -1
  20. package/lib-commonjs/components/HeatMapChart/HeatMapChart.js +1 -1
  21. package/lib-commonjs/components/HeatMapChart/HeatMapChart.js.map +1 -1
  22. package/lib-commonjs/components/LineChart/LineChart.js +34 -32
  23. package/lib-commonjs/components/LineChart/LineChart.js.map +1 -1
  24. package/lib-commonjs/components/VerticalBarChart/VerticalBarChart.js +6 -3
  25. package/lib-commonjs/components/VerticalBarChart/VerticalBarChart.js.map +1 -1
  26. package/lib-commonjs/components/VerticalStackedBarChart/VerticalStackedBarChart.js +17 -15
  27. package/lib-commonjs/components/VerticalStackedBarChart/VerticalStackedBarChart.js.map +1 -1
  28. package/lib-commonjs/utilities/utilities.js +5 -5
  29. package/lib-commonjs/utilities/utilities.js.map +1 -1
  30. package/package.json +13 -13
@@ -34,7 +34,11 @@ const CartesianChart = /*#__PURE__*/ _react.forwardRef((props, forwardedRef)=>{
34
34
  const _isFirstRender = _react.useRef(true);
35
35
  // eslint-disable-next-line @typescript-eslint/no-explicit-any
36
36
  let _xScale;
37
- let isIntegralDataset = true;
37
+ const isIntegralDataset = _react.useMemo(()=>{
38
+ return !props.points.some((point)=>point.y % 1 !== 0);
39
+ }, [
40
+ props.points
41
+ ]);
38
42
  let _tooltipId = (0, _reactutilities.useId)('tooltip_');
39
43
  /* Used for when WrapXAxisLabels props appeared.
40
44
  * To display the total word (space separated words), Need to have more space than usual.
@@ -115,8 +119,6 @@ const CartesianChart = /*#__PURE__*/ _react.forwardRef((props, forwardedRef)=>{
115
119
  } else if (startFromX !== 0) {
116
120
  setStartFromX(0);
117
121
  }
118
- // eslint-disable-next-line react-hooks/exhaustive-deps
119
- isIntegralDataset = !props.points.some((point)=>point.y % 1 !== 0);
120
122
  return ()=>{
121
123
  cancelAnimationFrame(_reqID);
122
124
  };
@@ -138,10 +140,6 @@ const CartesianChart = /*#__PURE__*/ _react.forwardRef((props, forwardedRef)=>{
138
140
  } else if (startFromX !== 0) {
139
141
  setStartFromX(0);
140
142
  }
141
- if (prevProps !== null && prevProps.points !== props.points) {
142
- // eslint-disable-next-line react-hooks/exhaustive-deps
143
- isIntegralDataset = !props.points.some((point)=>point.y % 1 !== 0);
144
- }
145
143
  }, [
146
144
  props,
147
145
  prevProps
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/components/CommonComponents/CartesianChart.tsx"],"sourcesContent":["import * as React from 'react';\n// eslint-disable-next-line import/no-extraneous-dependencies\nimport { ModifiedCartesianChartProps } from '../../index';\nimport { useCartesianChartStyles } from './useCartesianChartStyles.styles';\nimport { select as d3Select } from 'd3-selection';\nimport {\n createNumericXAxis,\n createStringXAxis,\n IAxisData,\n createDateXAxis,\n IMargins,\n XAxisTypes,\n YAxisType,\n createWrapOfXLabels,\n rotateXAxisLabels,\n calculateLongestLabelWidth,\n createYAxisLabels,\n ChartTypes,\n wrapContent,\n useRtl,\n truncateString,\n tooltipOfAxislabels,\n getSecureProps,\n DEFAULT_WRAP_WIDTH,\n} from '../../utilities/index';\nimport { useId } from '@fluentui/react-utilities';\nimport type { JSXElement } from '@fluentui/react-utilities';\nimport { SVGTooltipText, SVGTooltipTextProps } from '../../utilities/SVGTooltipText';\nimport { ChartPopover } from './ChartPopover';\nimport { useFocusableGroup, useArrowNavigationGroup } from '@fluentui/react-tabster';\n\n/**\n * Cartesian Chart component\n * {@docCategory CartesianChart}\n */\nexport const CartesianChart: React.FunctionComponent<ModifiedCartesianChartProps> = React.forwardRef<\n HTMLDivElement,\n ModifiedCartesianChartProps\n>((props, forwardedRef) => {\n const chartContainer = React.useRef<HTMLDivElement>();\n let legendContainer: HTMLDivElement;\n const minLegendContainerHeight: number = 40;\n const xAxisElement = React.useRef<SVGSVGElement>();\n const yAxisElement = React.useRef<SVGSVGElement>();\n const yAxisElementSecondary = React.useRef<SVGSVGElement>();\n let margins: IMargins;\n const idForGraph: string = 'chart_';\n let _reqID: number;\n const _useRtl: boolean = useRtl();\n let _tickValues: (string | number)[];\n const titleMargin: number = 8;\n const _isFirstRender = React.useRef<boolean>(true);\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n let _xScale: any;\n let isIntegralDataset: boolean = true;\n let _tooltipId: string = useId('tooltip_');\n /* Used for when WrapXAxisLabels props appeared.\n * To display the total word (space separated words), Need to have more space than usual.\n * This height will get total height need to disaply total word.\n * These value need to be removed from actual svg height/graph height.\n * Defalut value is 0. And this values calculted when 'wrapXAxisLables' or 'showXAxisLablesTooltip' is true.\n */\n let _removalValueForTextTuncate: number = 0;\n\n const [containerWidth, setContainerWidth] = React.useState<number>(0);\n const [containerHeight, setContainerHeight] = React.useState<number>(0);\n const [startFromX, setStartFromX] = React.useState<number>(0);\n const [prevProps, setPrevProps] = React.useState<ModifiedCartesianChartProps | null>(null);\n\n const chartTypesWithStringYAxis = [\n ChartTypes.HorizontalBarChartWithAxis,\n ChartTypes.HeatMapChart,\n ChartTypes.VerticalStackedBarChart,\n ChartTypes.GanttChart,\n ChartTypes.ScatterChart,\n ];\n /**\n * In RTL mode, Only graph will be rendered left/right. We need to provide left and right margins manually.\n * So that, in RTL, left margins becomes right margins and viceversa.\n * As graph needs to be drawn perfecty, these values consider as default values.\n * Same margins using for all other cartesian charts. Can be accessible through 'getMargins' call back method.\n */\n // eslint-disable-next-line prefer-const\n margins = {\n top: props.margins?.top ?? 20,\n bottom: props.margins?.bottom ?? 35,\n right: _useRtl ? props.margins?.left ?? 40 : props.margins?.right ?? props?.secondaryYScaleOptions ? 40 : 20,\n left: _useRtl ? (props.margins?.right ?? props?.secondaryYScaleOptions ? 40 : 20) : props.margins?.left ?? 40,\n };\n const TITLE_MARGIN_HORIZONTAL = 24;\n const TITLE_MARGIN_VERTICAL = 20;\n if (props.xAxisTitle !== undefined && props.xAxisTitle !== '') {\n margins.bottom! = props.margins?.bottom ?? margins.bottom! + TITLE_MARGIN_VERTICAL;\n }\n if (props.yAxisTitle !== undefined && props.yAxisTitle !== '') {\n margins.left! = _useRtl\n ? props.margins?.right ?? props?.secondaryYAxistitle\n ? margins.right! + 2 * TITLE_MARGIN_HORIZONTAL\n : margins.right! + TITLE_MARGIN_HORIZONTAL\n : props.margins?.left ?? margins.left! + TITLE_MARGIN_HORIZONTAL;\n margins.right! = _useRtl\n ? props.margins?.left ?? margins.left! + TITLE_MARGIN_HORIZONTAL\n : props.margins?.right ?? props?.secondaryYAxistitle\n ? margins.right! + 2 * TITLE_MARGIN_HORIZONTAL\n : margins.right! + TITLE_MARGIN_HORIZONTAL;\n }\n if (props.xAxisAnnotation !== undefined && props.xAxisAnnotation !== '') {\n margins.top! = props.margins?.top ?? margins.top! + TITLE_MARGIN_VERTICAL;\n }\n if (\n props.yAxisAnnotation !== undefined &&\n props.yAxisAnnotation !== '' &&\n (props.secondaryYAxistitle === undefined || props.secondaryYAxistitle === '')\n ) {\n if (_useRtl) {\n margins.left! = props.margins?.right ?? margins.right! + TITLE_MARGIN_HORIZONTAL;\n } else {\n margins.right! = props.margins?.right ?? margins.right! + TITLE_MARGIN_HORIZONTAL;\n }\n }\n\n const classes = useCartesianChartStyles(props);\n const focusAttributes = useFocusableGroup();\n const arrowAttributes = useArrowNavigationGroup({ axis: 'horizontal' });\n // ComponentdidMount and Componentwillunmount logic\n React.useEffect(() => {\n _fitParentContainer();\n if (props !== null) {\n setPrevProps(props);\n }\n if (\n chartTypesWithStringYAxis.includes(props.chartType) &&\n props.showYAxisLables &&\n yAxisElement &&\n props.yAxisType === YAxisType.StringAxis\n ) {\n const maxYAxisLabelLength = calculateMaxYAxisLabelLength(classes.yAxis!);\n if (startFromX !== maxYAxisLabelLength) {\n setStartFromX(maxYAxisLabelLength);\n }\n } else if (startFromX !== 0) {\n setStartFromX(0);\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n isIntegralDataset = !props.points.some((point: { y: number }) => point.y % 1 !== 0);\n return () => {\n cancelAnimationFrame(_reqID);\n };\n }, [props]);\n\n // ComponentDidUpdate logic\n React.useEffect(() => {\n if (prevProps) {\n if (prevProps.height !== props.height || prevProps.width !== props.width) {\n _fitParentContainer();\n }\n }\n if (\n chartTypesWithStringYAxis.includes(props.chartType) &&\n props.showYAxisLables &&\n yAxisElement &&\n props.yAxisType === YAxisType.StringAxis\n ) {\n const maxYAxisLabelLength = calculateMaxYAxisLabelLength(classes.yAxis!);\n if (startFromX !== maxYAxisLabelLength) {\n setStartFromX(maxYAxisLabelLength);\n }\n } else if (startFromX !== 0) {\n setStartFromX(0);\n }\n if (prevProps !== null && prevProps.points !== props.points) {\n // eslint-disable-next-line react-hooks/exhaustive-deps\n isIntegralDataset = !props.points.some((point: { y: number }) => point.y % 1 !== 0);\n }\n }, [props, prevProps]);\n\n React.useImperativeHandle(\n props.componentRef,\n () => ({\n chartContainer: chartContainer.current ?? null,\n }),\n [],\n );\n\n /**\n * Dedicated function to return the Callout JSX Element , which can further be used to only call this when\n * only the calloutprops and charthover props changes.\n * @param calloutProps\n * @param chartHoverProps\n * @returns\n */\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n function _generateCallout(calloutProps: any): JSXElement {\n return <ChartPopover {...calloutProps} />;\n }\n\n function calculateMaxYAxisLabelLength(className: string): number {\n const formatTickLabel = (str: string) => {\n if (props.showYAxisLablesTooltip) {\n return truncateString(str, props.noOfCharsToTruncate || 4);\n }\n\n return str;\n };\n return calculateLongestLabelWidth(\n props.stringDatasetForYAxisDomain!.map(label => formatTickLabel(label)),\n `.${className} text`,\n );\n }\n\n const {\n calloutProps,\n points,\n chartType,\n svgProps,\n culture,\n dateLocalizeOptions,\n timeFormatLocale,\n customDateTimeFormatter,\n } = props;\n if (props.parentRef) {\n _fitParentContainer();\n }\n const margin = { ...margins };\n // Note: This check is unnecessary since startFromX is only set for charts with string y-axis.\n if (chartTypesWithStringYAxis.includes(props.chartType)) {\n if (!_useRtl) {\n margin.left! += startFromX;\n } else {\n margin.right! += startFromX;\n }\n }\n // Callback for margins to the chart\n props.getmargins && props.getmargins(margin);\n\n let callout: JSXElement | null = null;\n\n let children = null;\n if ((props.enableFirstRenderOptimization && chartContainer.current) || !props.enableFirstRenderOptimization) {\n _isFirstRender.current = false;\n const XAxisParams = {\n domainNRangeValues: props.getDomainNRangeValues(\n points,\n props.getDomainMargins ? props.getDomainMargins(containerWidth) : margins,\n containerWidth,\n chartType,\n _useRtl,\n props.xAxisType,\n props.barwidth!,\n props.tickValues!,\n // This is only used for Horizontal Bar Chart with Axis for y as string axis\n startFromX,\n ),\n // FIXME: In XAxisParams, containerHeight is used by HBWA to generate vertical gridlines.\n // Since the x-axis in HBWA is numeric, it typically doesn't require transformation.\n // However, if transformation props are enabled, the updated _removalValueForTextTuncate\n // will only be available in the next render, as it's set after the axis is created.\n // Solution: Delay the creation of gridlines until after the transformation has been applied,\n // or precompute the required height for transformed labels (_removalValueForTextTuncate).\n containerHeight: containerHeight - _removalValueForTextTuncate,\n margins: margins,\n xAxisElement: xAxisElement.current!,\n showRoundOffXTickValues: props.showRoundOffXTickValues ?? true,\n xAxisCount: props.xAxisTickCount,\n xAxistickSize: props.xAxistickSize,\n tickPadding: props.tickPadding || props.showXAxisLablesTooltip ? 5 : 10,\n xAxisPadding: props.xAxisPadding,\n xAxisInnerPadding: props.xAxisInnerPadding,\n xAxisOuterPadding: props.xAxisOuterPadding,\n containerWidth: containerWidth,\n hideTickOverlap: props.rotateXAxisLables ? false : props.hideTickOverlap,\n calcMaxLabelWidth: _calcMaxLabelWidthWithTransform,\n tickStep: props.xAxis?.tickStep,\n tick0: props.xAxis?.tick0,\n };\n\n /**\n * These scales used for 2 purposes.\n * 1. To create x and y axis\n * 2. To draw the graph.\n * For area/line chart using same scales. For other charts, creating their own scales to draw the graph.\n */\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n let xScale: any;\n let tickValues: (string | number)[];\n switch (props.xAxisType!) {\n case XAxisTypes.NumericAxis:\n ({ xScale, tickValues } = createNumericXAxis(\n XAxisParams,\n props.tickParams!,\n props.chartType,\n culture,\n props.xScaleType,\n _useRtl,\n ));\n break;\n case XAxisTypes.DateAxis:\n ({ xScale, tickValues } = createDateXAxis(\n XAxisParams,\n props.tickParams!,\n culture,\n dateLocalizeOptions,\n timeFormatLocale,\n customDateTimeFormatter,\n props.useUTC,\n props.chartType,\n ));\n break;\n case XAxisTypes.StringAxis:\n ({ xScale, tickValues } = createStringXAxis(\n XAxisParams,\n props.tickParams!,\n props.datasetForXAxisDomain!,\n culture,\n _useRtl,\n ));\n break;\n default:\n ({ xScale, tickValues } = createNumericXAxis(\n XAxisParams,\n props.tickParams!,\n props.chartType,\n culture,\n props.xScaleType,\n _useRtl,\n ));\n }\n _xScale = xScale;\n _tickValues = tickValues;\n\n _transformXAxisLabels();\n\n const YAxisParams = {\n margins: props.getYDomainMargins ? props.getYDomainMargins(containerHeight) : margins,\n containerWidth: containerWidth,\n containerHeight: containerHeight - _removalValueForTextTuncate,\n yAxisElement: yAxisElement.current!,\n yAxisTickFormat: props.yAxisTickFormat!,\n yAxisTickCount: props.yAxisTickCount!,\n yMinValue: props.yMinValue || 0,\n yMaxValue: props.yMaxValue || 0,\n tickPadding: 10,\n maxOfYVal: props.maxOfYVal,\n yMinMaxValues: props.getMinMaxOfYAxis(points, props.yAxisType),\n // please note these padding default values must be consistent in here\n // and the parent chart(HBWA/Vertical etc..) for more details refer example\n // http://using-d3js.com/04_07_ordinal_scales.html\n yAxisPadding: props.yAxisPadding || 0,\n tickValues: props.yAxisTickValues,\n tickStep: props.yAxis?.tickStep,\n tick0: props.yAxis?.tick0,\n };\n /**\n * These scales used for 2 purposes.\n * 1. To create x and y axis\n * 2. To draw the graph.\n * For area/line chart using same scales. For other charts, creating their own scales to draw the graph.\n */\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n let yScalePrimary: any;\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n let yScaleSecondary: any;\n const axisData: IAxisData = { yAxisDomainValues: [] };\n if (props.yAxisType && props.yAxisType === YAxisType.StringAxis) {\n yScalePrimary = props.createStringYAxis(\n YAxisParams,\n props.stringDatasetForYAxisDomain!,\n _useRtl,\n props.barwidth,\n props.chartType,\n );\n } else {\n // TODO: Since the scale domain values are now computed independently for both the primary and\n // secondary y-axes, the yMinValue and yMaxValue props are no longer necessary for accurately\n // rendering the secondary y-axis. Therefore, rather than checking the secondaryYScaleOptions\n // prop to determine whether to create a secondary y-axis, it's more appropriate to check if any\n // data points are assigned to use the secondary y-scale.\n if (props?.secondaryYScaleOptions) {\n const YAxisParamsSecondary = {\n margins: margins,\n containerWidth: containerWidth,\n containerHeight: containerHeight - _removalValueForTextTuncate!,\n yAxisElement: yAxisElementSecondary.current,\n yAxisTickFormat: props.yAxisTickFormat!,\n yAxisTickCount: props.yAxisTickCount!,\n yMinValue: props.secondaryYScaleOptions?.yMinValue || 0,\n yMaxValue: props.secondaryYScaleOptions?.yMaxValue ?? 100,\n tickPadding: 10,\n yMinMaxValues: props.getMinMaxOfYAxis(points, props.yAxisType, true),\n yAxisPadding: props.yAxisPadding,\n };\n\n yScaleSecondary = props.createYAxis(\n YAxisParamsSecondary,\n _useRtl,\n axisData,\n isIntegralDataset,\n chartType,\n true,\n props.roundedTicks!,\n props.secondaryYScaleType,\n _useRtl,\n );\n }\n yScalePrimary = props.createYAxis(\n YAxisParams,\n _useRtl,\n axisData,\n isIntegralDataset,\n chartType,\n false,\n props.roundedTicks!,\n props.yScaleType,\n _useRtl,\n );\n }\n\n if (chartTypesWithStringYAxis.includes(props.chartType) && props.yAxisType === YAxisType.StringAxis) {\n // Removing un wanted tooltip div from DOM, when prop not provided, for proper cleanup\n // of unwanted DOM elements, to prevent flacky behaviour in tooltips , that might occur\n // in creating tooltips when tooltips are enabled( as we try to recreate a tspan with _tooltipId)\n if (!props.showYAxisLablesTooltip) {\n try {\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 y axis labels.\n if (props.showYAxisLablesTooltip) {\n // To create y axis tick values by if specified truncating the rest of the text\n // and showing elipsis or showing the whole string,\n yScalePrimary &&\n // Note: This function should be invoked within the showYAxisLablesTooltip check,\n // as its sole purpose is to truncate labels that exceed the noOfCharsToTruncate limit.\n createYAxisLabels(\n yAxisElement.current!,\n yScalePrimary,\n props.noOfCharsToTruncate || 4,\n props.showYAxisLablesTooltip || false,\n _useRtl,\n );\n const _yAxisElement = d3Select(yAxisElement.current!).call(yScalePrimary);\n try {\n document.getElementById(_tooltipId) && document.getElementById(_tooltipId)!.remove();\n //eslint-disable-next-line no-empty\n } catch (e) {}\n const ytooltipProps = {\n tooltipCls: classes.tooltip!,\n id: _tooltipId,\n axis: _yAxisElement,\n };\n _yAxisElement && tooltipOfAxislabels(ytooltipProps);\n }\n }\n\n // Call back to the chart.\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const _getData = (xScale: any, yScalePrimary: any, yScaleSecondary: any) => {\n props.getGraphData &&\n props.getGraphData(\n xScale,\n yScalePrimary,\n containerHeight - _removalValueForTextTuncate!,\n containerWidth,\n xAxisElement.current,\n yAxisElement.current,\n yScaleSecondary,\n );\n };\n\n props.getAxisData && props.getAxisData(axisData);\n // Callback function for chart, returns axis\n _getData(xScale, yScalePrimary, yScaleSecondary);\n\n children = props.children({\n xScale,\n yScalePrimary,\n yScaleSecondary,\n containerHeight,\n containerWidth,\n });\n\n if (!props.hideTooltip && calloutProps!.isPopoverOpen) {\n callout = _generateCallout(calloutProps);\n }\n }\n const svgDimensions = {\n width: containerWidth,\n height: containerHeight,\n };\n\n const xAxisTitleMaximumAllowedWidth = svgDimensions.width - margins.left! - margins.right! - startFromX!;\n const yAxisTitleMaximumAllowedHeight =\n svgDimensions.height - margins.bottom! - margins.top! - _removalValueForTextTuncate! - titleMargin;\n\n const commonSvgToolTipProps: SVGTooltipTextProps = {\n wrapContent,\n showBackground: true,\n className: classes.svgTooltip,\n content: '',\n };\n /**\n * When screen resizes, along with screen, chart also auto adjusted.\n * This method used to adjust height and width of the charts.\n */\n function _fitParentContainer(): void {\n //_reqID = requestAnimationFrame(() => {\n let legendContainerHeight;\n if (props.hideLegend) {\n // If there is no legend, need not to allocate some space from total chart space.\n legendContainerHeight = 0;\n } else {\n const legendContainerComputedStyles = legendContainer && getComputedStyle(legendContainer);\n legendContainerHeight =\n ((legendContainer && legendContainer.getBoundingClientRect().height) || minLegendContainerHeight) +\n parseFloat((legendContainerComputedStyles && legendContainerComputedStyles.marginTop) || '0') +\n parseFloat((legendContainerComputedStyles && legendContainerComputedStyles.marginBottom) || '0');\n }\n if (props.parentRef || chartContainer.current) {\n const container = props.parentRef ? props.parentRef : chartContainer.current!;\n const currentContainerWidth =\n props.reflowProps?.mode === 'min-width' && !_isFirstRender.current\n ? Math.max(container.getBoundingClientRect().width, _calculateChartMinWidth())\n : container.getBoundingClientRect().width;\n const currentContainerHeight =\n container.getBoundingClientRect().height > legendContainerHeight\n ? container.getBoundingClientRect().height\n : 350;\n const shouldResize =\n containerWidth !== currentContainerWidth || containerHeight !== currentContainerHeight - legendContainerHeight;\n if (shouldResize) {\n setContainerWidth(currentContainerWidth);\n setContainerHeight(currentContainerHeight - legendContainerHeight);\n }\n }\n //});\n }\n\n function _onChartLeave(): void {\n props.onChartMouseLeave && props.onChartMouseLeave();\n }\n\n function _calculateChartMinWidth(): number {\n // Adding 10px for padding on both sides\n const labelWidth = _calcMaxLabelWidthWithTransform(_tickValues) + 10;\n\n let minChartWidth = margins.left! + margins.right! + labelWidth * (_tickValues.length - 1);\n\n if (\n [ChartTypes.GroupedVerticalBarChart, ChartTypes.VerticalBarChart, ChartTypes.VerticalStackedBarChart].includes(\n props.chartType,\n )\n ) {\n const minDomainMargin = 8;\n minChartWidth += minDomainMargin * 2;\n }\n\n return minChartWidth;\n }\n\n function _calcMaxLabelWidthWithTransform(x: (string | number)[]) {\n // Case: rotated labels\n if (!props.wrapXAxisLables && props.rotateXAxisLables && props.xAxisType! === XAxisTypes.StringAxis) {\n const longestLabelWidth = calculateLongestLabelWidth(x, `.${classes.xAxis} text`);\n return Math.ceil(longestLabelWidth * Math.cos(Math.PI / 4));\n }\n\n // Case: truncated labels\n if (props.showXAxisLablesTooltip) {\n const tickValues = x.map(val => {\n const numChars = props.noOfCharsToTruncate || 4;\n return val.toString().length > numChars ? `${val.toString().slice(0, numChars)}...` : val;\n });\n\n const longestLabelWidth = calculateLongestLabelWidth(tickValues, `.${classes.xAxis} text`);\n return Math.ceil(longestLabelWidth);\n }\n\n // Case: wrapped labels\n if (props.wrapXAxisLables) {\n // FIXME: Calculate the max width of lines instead of words. This requires applying\n // the wrapping transformation earlier to obtain the actual rendered lines.\n const words: string[] = [];\n x.forEach((val: string) => {\n words.push(...val.toString().split(/\\s+/));\n });\n\n // This approach works well in most cases, since overflow typically occurs only when\n // a single word exceeds the specified width — otherwise, the text will wrap as expected.\n const longestLabelWidth = calculateLongestLabelWidth(words, `.${classes.xAxis} text`);\n return Math.max(Math.ceil(longestLabelWidth), DEFAULT_WRAP_WIDTH);\n }\n\n // Default case\n const longestLabelWidth = calculateLongestLabelWidth(x, `.${classes.xAxis} text`);\n return Math.ceil(longestLabelWidth);\n }\n\n function _transformXAxisLabels() {\n _removalValueForTextTuncate = 0;\n\n /*\n * To enable wrapping of x axis tick values or to display complete x axis tick values,\n * we need to calculate how much space it needed to render the text.\n * No need to re-calculate every time the chart renders and same time need to get an update. So using setState.\n * Required space will be calculated first time chart rendering and if any width/height of chart updated.\n * */\n if (props.wrapXAxisLables || props.showXAxisLablesTooltip) {\n let maxXAxisLabelWidth: number | undefined;\n if (props.xAxisType === XAxisTypes.StringAxis) {\n if ((props.datasetForXAxisDomain?.length || 0) > 1) {\n maxXAxisLabelWidth = _xScale.step();\n } else {\n maxXAxisLabelWidth = containerWidth;\n }\n }\n\n const wrapLabelProps = {\n node: xAxisElement.current!,\n xAxis: _xScale,\n showXAxisLablesTooltip: props.showXAxisLablesTooltip || false,\n noOfCharsToTruncate: props.noOfCharsToTruncate || 4,\n width: maxXAxisLabelWidth,\n };\n _removalValueForTextTuncate = createWrapOfXLabels(wrapLabelProps) ?? 0;\n }\n\n if (!props.wrapXAxisLables && props.rotateXAxisLables && props.xAxisType! === XAxisTypes.StringAxis) {\n const rotateLabelProps = {\n node: xAxisElement.current!,\n xAxis: _xScale,\n };\n const rotatedHeight = rotateXAxisLabels(rotateLabelProps) ?? 0;\n // margins.bottom is used as padding here\n _removalValueForTextTuncate = rotatedHeight + margins.bottom!;\n }\n }\n\n /**\n * We have use the {@link defaultTabbableElement } to fix\n * the Focus not landing on chart while tabbing, instead goes to legend.\n * This issue is observed in Area, line chart after performance optimization done in the PR {@link https://github.com/microsoft/fluentui/pull/27721 }\n * This issue is observed in Bar charts after the changes done by FocusZone team in the PR: {@link https://github.com/microsoft/fluentui/pull/24175 }\n * The issue in Bar Charts(VB and VSB) is due to a {@link FocusZone } update where previously an event listener was\n * attached on keydown to the window, so that whenever the tab key is pressed all outer FocusZone's\n * tab-indexes are updated (an outer FocusZone is a FocusZone that is not within another one).\n * But now after the above PR : they are attaching the\n * listeners to the FocusZone elements instead of the window. So in the first render cycle in Bar charts\n * bars are not created as in the first render cycle the size of the chart container is not known( or is 0)\n * which creates bars of height 0 so instead we do not create any bars and instead return empty fragments.\n *\n * We have tried 2 Approaches to fix the issue:\n * 1. Using the {@link elementRef} property of FocusZone where we dispatch event for tab keydown\n * after the second render cycle which triggers an update of the tab index in FocusZone.\n * But this is a hacky solution and not a proper fix and also elementRef is deprecated.\n * 2. Using the default tabbable element to fix the issue.\n */\n\n return (\n <div\n id={idForGraph}\n className={classes.root}\n role={'presentation'}\n ref={(rootElem: HTMLDivElement) => (chartContainer.current = rootElem)}\n onMouseLeave={_onChartLeave}\n >\n <div className={classes.chartWrapper} {...focusAttributes} {...arrowAttributes}>\n {_isFirstRender.current}\n <svg\n width={svgDimensions.width}\n height={svgDimensions.height}\n aria-label={props.chartTitle}\n style={{ display: 'block' }}\n className={classes.chart}\n {...getSecureProps(svgProps)}\n >\n <g\n ref={(e: SVGSVGElement | null) => {\n xAxisElement.current = e!;\n }}\n id={`xAxisGElement${idForGraph}`}\n // To add wrap of x axis lables feature, need to remove word height from svg height.\n transform={`translate(0, ${svgDimensions.height - margins.bottom! - _removalValueForTextTuncate!})`}\n className={classes.xAxis}\n />\n {props.xAxisTitle !== undefined && props.xAxisTitle !== '' && (\n <SVGTooltipText\n {...commonSvgToolTipProps}\n content={props.xAxisTitle}\n textProps={{\n x: margins.left! + startFromX + xAxisTitleMaximumAllowedWidth / 2,\n y: svgDimensions.height - titleMargin,\n className: classes.axisTitle!,\n textAnchor: 'middle',\n }}\n maxWidth={xAxisTitleMaximumAllowedWidth}\n />\n )}\n {props.xAxisAnnotation !== undefined && props.xAxisAnnotation !== '' && (\n <SVGTooltipText\n {...commonSvgToolTipProps}\n content={props.xAxisAnnotation}\n textProps={{\n x: margins.left! + startFromX + xAxisTitleMaximumAllowedWidth / 2,\n y: titleMargin + 3,\n className: classes.axisAnnotation!,\n textAnchor: 'middle',\n 'aria-hidden': true,\n }}\n maxWidth={xAxisTitleMaximumAllowedWidth}\n />\n )}\n <g\n ref={(e: SVGSVGElement | null) => {\n yAxisElement.current = e!;\n }}\n id={`yAxisGElement${idForGraph}`}\n transform={`translate(${\n _useRtl ? svgDimensions.width - margins.right! - startFromX : margins.left! + startFromX\n }, 0)`}\n className={classes.yAxis}\n />\n {props.secondaryYScaleOptions && (\n <g>\n <g\n ref={(e: SVGSVGElement | null) => {\n yAxisElementSecondary.current = e!;\n }}\n id={`yAxisGElementSecondary${idForGraph}`}\n transform={`translate(${\n _useRtl ? margins.left! + startFromX : svgDimensions.width - margins.right! - startFromX\n }, 0)`}\n className={classes.yAxis}\n />\n {props.secondaryYAxistitle !== undefined && props.secondaryYAxistitle !== '' && (\n <SVGTooltipText\n {...commonSvgToolTipProps}\n content={props.secondaryYAxistitle}\n textProps={{\n x: (yAxisTitleMaximumAllowedHeight - margins.bottom!) / 2 + _removalValueForTextTuncate!,\n y: _useRtl ? startFromX - titleMargin : svgDimensions.width - margins.right!,\n textAnchor: 'middle',\n transform: `translate(${\n _useRtl ? margins.right! / 2 - titleMargin : margins.right! / 2 + titleMargin\n },\n ${svgDimensions.height - margins.bottom! - margins.top! - titleMargin})rotate(-90)`,\n className: classes.axisTitle!,\n }}\n maxWidth={yAxisTitleMaximumAllowedHeight}\n />\n )}\n </g>\n )}\n {children}\n {props.yAxisTitle !== undefined && props.yAxisTitle !== '' && (\n <SVGTooltipText\n {...commonSvgToolTipProps}\n content={props.yAxisTitle}\n textProps={{\n x: (yAxisTitleMaximumAllowedHeight - margins.bottom!) / 2 + _removalValueForTextTuncate!,\n y: _useRtl ? svgDimensions.width - margins.right! / 2 + titleMargin : margins.left! / 2 - titleMargin,\n textAnchor: 'middle',\n transform: `translate(0,\n ${svgDimensions.height - margins.bottom! - margins.top! - titleMargin})rotate(-90)`,\n className: classes.axisTitle!,\n }}\n maxWidth={yAxisTitleMaximumAllowedHeight}\n />\n )}\n {props.yAxisAnnotation !== undefined &&\n props.yAxisAnnotation !== '' &&\n (props.secondaryYAxistitle === undefined || props.secondaryYAxistitle === '') && (\n <SVGTooltipText\n {...commonSvgToolTipProps}\n content={props.yAxisAnnotation}\n textProps={{\n x: (yAxisTitleMaximumAllowedHeight - margins.bottom!) / 2 + _removalValueForTextTuncate!,\n y: _useRtl ? startFromX - titleMargin : svgDimensions.width - margins.right!,\n textAnchor: 'middle',\n transform: `translate(${\n _useRtl ? margins.right! / 2 - titleMargin : margins.right! / 2 + titleMargin\n },\n ${svgDimensions.height - margins.bottom! - margins.top! - titleMargin})rotate(-90)`,\n className: classes.axisAnnotation!,\n 'aria-hidden': true,\n }}\n maxWidth={yAxisTitleMaximumAllowedHeight}\n />\n )}\n </svg>\n </div>\n\n {!props.hideLegend && (\n <div ref={(e: HTMLDivElement) => (legendContainer = e)} className={classes.legendContainer}>\n {props.legendBars}\n </div>\n )}\n {/** The callout is used for narration, so keep it mounted on the DOM */}\n {callout && <React.Suspense fallback={<div>Loading...</div>}>{callout}</React.Suspense>}\n </div>\n );\n});\nCartesianChart.displayName = 'CartesianChart';\nCartesianChart.defaultProps = {\n hideTickOverlap: true,\n};\n"],"names":["React","useCartesianChartStyles","select","d3Select","createNumericXAxis","createStringXAxis","createDateXAxis","XAxisTypes","YAxisType","createWrapOfXLabels","rotateXAxisLabels","calculateLongestLabelWidth","createYAxisLabels","ChartTypes","wrapContent","useRtl","truncateString","tooltipOfAxislabels","getSecureProps","DEFAULT_WRAP_WIDTH","useId","SVGTooltipText","ChartPopover","useFocusableGroup","useArrowNavigationGroup","CartesianChart","forwardRef","props","forwardedRef","chartContainer","useRef","legendContainer","minLegendContainerHeight","xAxisElement","yAxisElement","yAxisElementSecondary","margins","idForGraph","_reqID","_useRtl","_tickValues","titleMargin","_isFirstRender","_xScale","isIntegralDataset","_tooltipId","_removalValueForTextTuncate","containerWidth","setContainerWidth","useState","containerHeight","setContainerHeight","startFromX","setStartFromX","prevProps","setPrevProps","chartTypesWithStringYAxis","HorizontalBarChartWithAxis","HeatMapChart","VerticalStackedBarChart","GanttChart","ScatterChart","top","bottom","right","left","secondaryYScaleOptions","TITLE_MARGIN_HORIZONTAL","TITLE_MARGIN_VERTICAL","xAxisTitle","undefined","yAxisTitle","secondaryYAxistitle","xAxisAnnotation","yAxisAnnotation","classes","focusAttributes","arrowAttributes","axis","useEffect","_fitParentContainer","includes","chartType","showYAxisLables","yAxisType","StringAxis","maxYAxisLabelLength","calculateMaxYAxisLabelLength","yAxis","points","some","point","y","cancelAnimationFrame","height","width","useImperativeHandle","componentRef","current","_generateCallout","calloutProps","className","formatTickLabel","str","showYAxisLablesTooltip","noOfCharsToTruncate","stringDatasetForYAxisDomain","map","label","svgProps","culture","dateLocalizeOptions","timeFormatLocale","customDateTimeFormatter","parentRef","margin","getmargins","callout","children","enableFirstRenderOptimization","XAxisParams","domainNRangeValues","getDomainNRangeValues","getDomainMargins","xAxisType","barwidth","tickValues","showRoundOffXTickValues","xAxisCount","xAxisTickCount","xAxistickSize","tickPadding","showXAxisLablesTooltip","xAxisPadding","xAxisInnerPadding","xAxisOuterPadding","hideTickOverlap","rotateXAxisLables","calcMaxLabelWidth","_calcMaxLabelWidthWithTransform","tickStep","xAxis","tick0","xScale","NumericAxis","tickParams","xScaleType","DateAxis","useUTC","datasetForXAxisDomain","_transformXAxisLabels","YAxisParams","getYDomainMargins","yAxisTickFormat","yAxisTickCount","yMinValue","yMaxValue","maxOfYVal","yMinMaxValues","getMinMaxOfYAxis","yAxisPadding","yAxisTickValues","yScalePrimary","yScaleSecondary","axisData","yAxisDomainValues","createStringYAxis","YAxisParamsSecondary","createYAxis","roundedTicks","secondaryYScaleType","yScaleType","document","getElementById","remove","e","_yAxisElement","call","ytooltipProps","tooltipCls","tooltip","id","_getData","getGraphData","getAxisData","hideTooltip","isPopoverOpen","svgDimensions","xAxisTitleMaximumAllowedWidth","yAxisTitleMaximumAllowedHeight","commonSvgToolTipProps","showBackground","svgTooltip","content","legendContainerHeight","hideLegend","legendContainerComputedStyles","getComputedStyle","getBoundingClientRect","parseFloat","marginTop","marginBottom","container","currentContainerWidth","reflowProps","mode","Math","max","_calculateChartMinWidth","currentContainerHeight","shouldResize","_onChartLeave","onChartMouseLeave","labelWidth","minChartWidth","length","GroupedVerticalBarChart","VerticalBarChart","minDomainMargin","x","wrapXAxisLables","longestLabelWidth","ceil","cos","PI","val","numChars","toString","slice","words","forEach","push","split","maxXAxisLabelWidth","step","wrapLabelProps","node","rotateLabelProps","rotatedHeight","div","root","role","ref","rootElem","onMouseLeave","chartWrapper","svg","aria-label","chartTitle","style","display","chart","g","transform","textProps","axisTitle","textAnchor","maxWidth","axisAnnotation","legendBars","Suspense","fallback","displayName","defaultProps"],"mappings":"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"}
1
+ {"version":3,"sources":["../src/components/CommonComponents/CartesianChart.tsx"],"sourcesContent":["import * as React from 'react';\n// eslint-disable-next-line import/no-extraneous-dependencies\nimport { ModifiedCartesianChartProps } from '../../index';\nimport { useCartesianChartStyles } from './useCartesianChartStyles.styles';\nimport { select as d3Select } from 'd3-selection';\nimport {\n createNumericXAxis,\n createStringXAxis,\n IAxisData,\n createDateXAxis,\n IMargins,\n XAxisTypes,\n YAxisType,\n createWrapOfXLabels,\n rotateXAxisLabels,\n calculateLongestLabelWidth,\n createYAxisLabels,\n ChartTypes,\n wrapContent,\n useRtl,\n truncateString,\n tooltipOfAxislabels,\n getSecureProps,\n DEFAULT_WRAP_WIDTH,\n} from '../../utilities/index';\nimport { useId } from '@fluentui/react-utilities';\nimport type { JSXElement } from '@fluentui/react-utilities';\nimport { SVGTooltipText, SVGTooltipTextProps } from '../../utilities/SVGTooltipText';\nimport { ChartPopover } from './ChartPopover';\nimport { useFocusableGroup, useArrowNavigationGroup } from '@fluentui/react-tabster';\n\n/**\n * Cartesian Chart component\n * {@docCategory CartesianChart}\n */\nexport const CartesianChart: React.FunctionComponent<ModifiedCartesianChartProps> = React.forwardRef<\n HTMLDivElement,\n ModifiedCartesianChartProps\n>((props, forwardedRef) => {\n const chartContainer = React.useRef<HTMLDivElement>();\n let legendContainer: HTMLDivElement;\n const minLegendContainerHeight: number = 40;\n const xAxisElement = React.useRef<SVGSVGElement>();\n const yAxisElement = React.useRef<SVGSVGElement>();\n const yAxisElementSecondary = React.useRef<SVGSVGElement>();\n let margins: IMargins;\n const idForGraph: string = 'chart_';\n let _reqID: number;\n const _useRtl: boolean = useRtl();\n let _tickValues: (string | number)[];\n const titleMargin: number = 8;\n const _isFirstRender = React.useRef<boolean>(true);\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n let _xScale: any;\n const isIntegralDataset = React.useMemo(() => {\n return !props.points.some((point: { y: number }) => point.y % 1 !== 0);\n }, [props.points]);\n let _tooltipId: string = useId('tooltip_');\n /* Used for when WrapXAxisLabels props appeared.\n * To display the total word (space separated words), Need to have more space than usual.\n * This height will get total height need to disaply total word.\n * These value need to be removed from actual svg height/graph height.\n * Defalut value is 0. And this values calculted when 'wrapXAxisLables' or 'showXAxisLablesTooltip' is true.\n */\n let _removalValueForTextTuncate: number = 0;\n\n const [containerWidth, setContainerWidth] = React.useState<number>(0);\n const [containerHeight, setContainerHeight] = React.useState<number>(0);\n const [startFromX, setStartFromX] = React.useState<number>(0);\n const [prevProps, setPrevProps] = React.useState<ModifiedCartesianChartProps | null>(null);\n\n const chartTypesWithStringYAxis = [\n ChartTypes.HorizontalBarChartWithAxis,\n ChartTypes.HeatMapChart,\n ChartTypes.VerticalStackedBarChart,\n ChartTypes.GanttChart,\n ChartTypes.ScatterChart,\n ];\n /**\n * In RTL mode, Only graph will be rendered left/right. We need to provide left and right margins manually.\n * So that, in RTL, left margins becomes right margins and viceversa.\n * As graph needs to be drawn perfecty, these values consider as default values.\n * Same margins using for all other cartesian charts. Can be accessible through 'getMargins' call back method.\n */\n // eslint-disable-next-line prefer-const\n margins = {\n top: props.margins?.top ?? 20,\n bottom: props.margins?.bottom ?? 35,\n right: _useRtl ? props.margins?.left ?? 40 : props.margins?.right ?? props?.secondaryYScaleOptions ? 40 : 20,\n left: _useRtl ? (props.margins?.right ?? props?.secondaryYScaleOptions ? 40 : 20) : props.margins?.left ?? 40,\n };\n const TITLE_MARGIN_HORIZONTAL = 24;\n const TITLE_MARGIN_VERTICAL = 20;\n if (props.xAxisTitle !== undefined && props.xAxisTitle !== '') {\n margins.bottom! = props.margins?.bottom ?? margins.bottom! + TITLE_MARGIN_VERTICAL;\n }\n if (props.yAxisTitle !== undefined && props.yAxisTitle !== '') {\n margins.left! = _useRtl\n ? props.margins?.right ?? props?.secondaryYAxistitle\n ? margins.right! + 2 * TITLE_MARGIN_HORIZONTAL\n : margins.right! + TITLE_MARGIN_HORIZONTAL\n : props.margins?.left ?? margins.left! + TITLE_MARGIN_HORIZONTAL;\n margins.right! = _useRtl\n ? props.margins?.left ?? margins.left! + TITLE_MARGIN_HORIZONTAL\n : props.margins?.right ?? props?.secondaryYAxistitle\n ? margins.right! + 2 * TITLE_MARGIN_HORIZONTAL\n : margins.right! + TITLE_MARGIN_HORIZONTAL;\n }\n if (props.xAxisAnnotation !== undefined && props.xAxisAnnotation !== '') {\n margins.top! = props.margins?.top ?? margins.top! + TITLE_MARGIN_VERTICAL;\n }\n if (\n props.yAxisAnnotation !== undefined &&\n props.yAxisAnnotation !== '' &&\n (props.secondaryYAxistitle === undefined || props.secondaryYAxistitle === '')\n ) {\n if (_useRtl) {\n margins.left! = props.margins?.right ?? margins.right! + TITLE_MARGIN_HORIZONTAL;\n } else {\n margins.right! = props.margins?.right ?? margins.right! + TITLE_MARGIN_HORIZONTAL;\n }\n }\n\n const classes = useCartesianChartStyles(props);\n const focusAttributes = useFocusableGroup();\n const arrowAttributes = useArrowNavigationGroup({ axis: 'horizontal' });\n // ComponentdidMount and Componentwillunmount logic\n React.useEffect(() => {\n _fitParentContainer();\n if (props !== null) {\n setPrevProps(props);\n }\n if (\n chartTypesWithStringYAxis.includes(props.chartType) &&\n props.showYAxisLables &&\n yAxisElement &&\n props.yAxisType === YAxisType.StringAxis\n ) {\n const maxYAxisLabelLength = calculateMaxYAxisLabelLength(classes.yAxis!);\n if (startFromX !== maxYAxisLabelLength) {\n setStartFromX(maxYAxisLabelLength);\n }\n } else if (startFromX !== 0) {\n setStartFromX(0);\n }\n return () => {\n cancelAnimationFrame(_reqID);\n };\n }, [props]);\n\n // ComponentDidUpdate logic\n React.useEffect(() => {\n if (prevProps) {\n if (prevProps.height !== props.height || prevProps.width !== props.width) {\n _fitParentContainer();\n }\n }\n if (\n chartTypesWithStringYAxis.includes(props.chartType) &&\n props.showYAxisLables &&\n yAxisElement &&\n props.yAxisType === YAxisType.StringAxis\n ) {\n const maxYAxisLabelLength = calculateMaxYAxisLabelLength(classes.yAxis!);\n if (startFromX !== maxYAxisLabelLength) {\n setStartFromX(maxYAxisLabelLength);\n }\n } else if (startFromX !== 0) {\n setStartFromX(0);\n }\n }, [props, prevProps]);\n\n React.useImperativeHandle(\n props.componentRef,\n () => ({\n chartContainer: chartContainer.current ?? null,\n }),\n [],\n );\n\n /**\n * Dedicated function to return the Callout JSX Element , which can further be used to only call this when\n * only the calloutprops and charthover props changes.\n * @param calloutProps\n * @param chartHoverProps\n * @returns\n */\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n function _generateCallout(calloutProps: any): JSXElement {\n return <ChartPopover {...calloutProps} />;\n }\n\n function calculateMaxYAxisLabelLength(className: string): number {\n const formatTickLabel = (str: string) => {\n if (props.showYAxisLablesTooltip) {\n return truncateString(str, props.noOfCharsToTruncate || 4);\n }\n\n return str;\n };\n return calculateLongestLabelWidth(\n props.stringDatasetForYAxisDomain!.map(label => formatTickLabel(label)),\n `.${className} text`,\n );\n }\n\n const {\n calloutProps,\n points,\n chartType,\n svgProps,\n culture,\n dateLocalizeOptions,\n timeFormatLocale,\n customDateTimeFormatter,\n } = props;\n if (props.parentRef) {\n _fitParentContainer();\n }\n const margin = { ...margins };\n // Note: This check is unnecessary since startFromX is only set for charts with string y-axis.\n if (chartTypesWithStringYAxis.includes(props.chartType)) {\n if (!_useRtl) {\n margin.left! += startFromX;\n } else {\n margin.right! += startFromX;\n }\n }\n // Callback for margins to the chart\n props.getmargins && props.getmargins(margin);\n\n let callout: JSXElement | null = null;\n\n let children = null;\n if ((props.enableFirstRenderOptimization && chartContainer.current) || !props.enableFirstRenderOptimization) {\n _isFirstRender.current = false;\n const XAxisParams = {\n domainNRangeValues: props.getDomainNRangeValues(\n points,\n props.getDomainMargins ? props.getDomainMargins(containerWidth) : margins,\n containerWidth,\n chartType,\n _useRtl,\n props.xAxisType,\n props.barwidth!,\n props.tickValues!,\n // This is only used for Horizontal Bar Chart with Axis for y as string axis\n startFromX,\n ),\n // FIXME: In XAxisParams, containerHeight is used by HBWA to generate vertical gridlines.\n // Since the x-axis in HBWA is numeric, it typically doesn't require transformation.\n // However, if transformation props are enabled, the updated _removalValueForTextTuncate\n // will only be available in the next render, as it's set after the axis is created.\n // Solution: Delay the creation of gridlines until after the transformation has been applied,\n // or precompute the required height for transformed labels (_removalValueForTextTuncate).\n containerHeight: containerHeight - _removalValueForTextTuncate,\n margins: margins,\n xAxisElement: xAxisElement.current!,\n showRoundOffXTickValues: props.showRoundOffXTickValues ?? true,\n xAxisCount: props.xAxisTickCount,\n xAxistickSize: props.xAxistickSize,\n tickPadding: props.tickPadding || props.showXAxisLablesTooltip ? 5 : 10,\n xAxisPadding: props.xAxisPadding,\n xAxisInnerPadding: props.xAxisInnerPadding,\n xAxisOuterPadding: props.xAxisOuterPadding,\n containerWidth: containerWidth,\n hideTickOverlap: props.rotateXAxisLables ? false : props.hideTickOverlap,\n calcMaxLabelWidth: _calcMaxLabelWidthWithTransform,\n tickStep: props.xAxis?.tickStep,\n tick0: props.xAxis?.tick0,\n };\n\n /**\n * These scales used for 2 purposes.\n * 1. To create x and y axis\n * 2. To draw the graph.\n * For area/line chart using same scales. For other charts, creating their own scales to draw the graph.\n */\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n let xScale: any;\n let tickValues: (string | number)[];\n switch (props.xAxisType!) {\n case XAxisTypes.NumericAxis:\n ({ xScale, tickValues } = createNumericXAxis(\n XAxisParams,\n props.tickParams!,\n props.chartType,\n culture,\n props.xScaleType,\n _useRtl,\n ));\n break;\n case XAxisTypes.DateAxis:\n ({ xScale, tickValues } = createDateXAxis(\n XAxisParams,\n props.tickParams!,\n culture,\n dateLocalizeOptions,\n timeFormatLocale,\n customDateTimeFormatter,\n props.useUTC,\n props.chartType,\n ));\n break;\n case XAxisTypes.StringAxis:\n ({ xScale, tickValues } = createStringXAxis(\n XAxisParams,\n props.tickParams!,\n props.datasetForXAxisDomain!,\n culture,\n _useRtl,\n ));\n break;\n default:\n ({ xScale, tickValues } = createNumericXAxis(\n XAxisParams,\n props.tickParams!,\n props.chartType,\n culture,\n props.xScaleType,\n _useRtl,\n ));\n }\n _xScale = xScale;\n _tickValues = tickValues;\n\n _transformXAxisLabels();\n\n const YAxisParams = {\n margins: props.getYDomainMargins ? props.getYDomainMargins(containerHeight) : margins,\n containerWidth: containerWidth,\n containerHeight: containerHeight - _removalValueForTextTuncate,\n yAxisElement: yAxisElement.current!,\n yAxisTickFormat: props.yAxisTickFormat!,\n yAxisTickCount: props.yAxisTickCount!,\n yMinValue: props.yMinValue || 0,\n yMaxValue: props.yMaxValue || 0,\n tickPadding: 10,\n maxOfYVal: props.maxOfYVal,\n yMinMaxValues: props.getMinMaxOfYAxis(points, props.yAxisType),\n // please note these padding default values must be consistent in here\n // and the parent chart(HBWA/Vertical etc..) for more details refer example\n // http://using-d3js.com/04_07_ordinal_scales.html\n yAxisPadding: props.yAxisPadding || 0,\n tickValues: props.yAxisTickValues,\n tickStep: props.yAxis?.tickStep,\n tick0: props.yAxis?.tick0,\n };\n /**\n * These scales used for 2 purposes.\n * 1. To create x and y axis\n * 2. To draw the graph.\n * For area/line chart using same scales. For other charts, creating their own scales to draw the graph.\n */\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n let yScalePrimary: any;\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n let yScaleSecondary: any;\n const axisData: IAxisData = { yAxisDomainValues: [] };\n if (props.yAxisType && props.yAxisType === YAxisType.StringAxis) {\n yScalePrimary = props.createStringYAxis(\n YAxisParams,\n props.stringDatasetForYAxisDomain!,\n _useRtl,\n props.barwidth,\n props.chartType,\n );\n } else {\n // TODO: Since the scale domain values are now computed independently for both the primary and\n // secondary y-axes, the yMinValue and yMaxValue props are no longer necessary for accurately\n // rendering the secondary y-axis. Therefore, rather than checking the secondaryYScaleOptions\n // prop to determine whether to create a secondary y-axis, it's more appropriate to check if any\n // data points are assigned to use the secondary y-scale.\n if (props?.secondaryYScaleOptions) {\n const YAxisParamsSecondary = {\n margins: margins,\n containerWidth: containerWidth,\n containerHeight: containerHeight - _removalValueForTextTuncate!,\n yAxisElement: yAxisElementSecondary.current,\n yAxisTickFormat: props.yAxisTickFormat!,\n yAxisTickCount: props.yAxisTickCount!,\n yMinValue: props.secondaryYScaleOptions?.yMinValue || 0,\n yMaxValue: props.secondaryYScaleOptions?.yMaxValue ?? 100,\n tickPadding: 10,\n yMinMaxValues: props.getMinMaxOfYAxis(points, props.yAxisType, true),\n yAxisPadding: props.yAxisPadding,\n };\n\n yScaleSecondary = props.createYAxis(\n YAxisParamsSecondary,\n _useRtl,\n axisData,\n isIntegralDataset,\n chartType,\n true,\n props.roundedTicks!,\n props.secondaryYScaleType,\n _useRtl,\n );\n }\n yScalePrimary = props.createYAxis(\n YAxisParams,\n _useRtl,\n axisData,\n isIntegralDataset,\n chartType,\n false,\n props.roundedTicks!,\n props.yScaleType,\n _useRtl,\n );\n }\n\n if (chartTypesWithStringYAxis.includes(props.chartType) && props.yAxisType === YAxisType.StringAxis) {\n // Removing un wanted tooltip div from DOM, when prop not provided, for proper cleanup\n // of unwanted DOM elements, to prevent flacky behaviour in tooltips , that might occur\n // in creating tooltips when tooltips are enabled( as we try to recreate a tspan with _tooltipId)\n if (!props.showYAxisLablesTooltip) {\n try {\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 y axis labels.\n if (props.showYAxisLablesTooltip) {\n // To create y axis tick values by if specified truncating the rest of the text\n // and showing elipsis or showing the whole string,\n yScalePrimary &&\n // Note: This function should be invoked within the showYAxisLablesTooltip check,\n // as its sole purpose is to truncate labels that exceed the noOfCharsToTruncate limit.\n createYAxisLabels(\n yAxisElement.current!,\n yScalePrimary,\n props.noOfCharsToTruncate || 4,\n props.showYAxisLablesTooltip || false,\n _useRtl,\n );\n const _yAxisElement = d3Select(yAxisElement.current!).call(yScalePrimary);\n try {\n document.getElementById(_tooltipId) && document.getElementById(_tooltipId)!.remove();\n //eslint-disable-next-line no-empty\n } catch (e) {}\n const ytooltipProps = {\n tooltipCls: classes.tooltip!,\n id: _tooltipId,\n axis: _yAxisElement,\n };\n _yAxisElement && tooltipOfAxislabels(ytooltipProps);\n }\n }\n\n // Call back to the chart.\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const _getData = (xScale: any, yScalePrimary: any, yScaleSecondary: any) => {\n props.getGraphData &&\n props.getGraphData(\n xScale,\n yScalePrimary,\n containerHeight - _removalValueForTextTuncate!,\n containerWidth,\n xAxisElement.current,\n yAxisElement.current,\n yScaleSecondary,\n );\n };\n\n props.getAxisData && props.getAxisData(axisData);\n // Callback function for chart, returns axis\n _getData(xScale, yScalePrimary, yScaleSecondary);\n\n children = props.children({\n xScale,\n yScalePrimary,\n yScaleSecondary,\n containerHeight,\n containerWidth,\n });\n\n if (!props.hideTooltip && calloutProps!.isPopoverOpen) {\n callout = _generateCallout(calloutProps);\n }\n }\n const svgDimensions = {\n width: containerWidth,\n height: containerHeight,\n };\n\n const xAxisTitleMaximumAllowedWidth = svgDimensions.width - margins.left! - margins.right! - startFromX!;\n const yAxisTitleMaximumAllowedHeight =\n svgDimensions.height - margins.bottom! - margins.top! - _removalValueForTextTuncate! - titleMargin;\n\n const commonSvgToolTipProps: SVGTooltipTextProps = {\n wrapContent,\n showBackground: true,\n className: classes.svgTooltip,\n content: '',\n };\n /**\n * When screen resizes, along with screen, chart also auto adjusted.\n * This method used to adjust height and width of the charts.\n */\n function _fitParentContainer(): void {\n //_reqID = requestAnimationFrame(() => {\n let legendContainerHeight;\n if (props.hideLegend) {\n // If there is no legend, need not to allocate some space from total chart space.\n legendContainerHeight = 0;\n } else {\n const legendContainerComputedStyles = legendContainer && getComputedStyle(legendContainer);\n legendContainerHeight =\n ((legendContainer && legendContainer.getBoundingClientRect().height) || minLegendContainerHeight) +\n parseFloat((legendContainerComputedStyles && legendContainerComputedStyles.marginTop) || '0') +\n parseFloat((legendContainerComputedStyles && legendContainerComputedStyles.marginBottom) || '0');\n }\n if (props.parentRef || chartContainer.current) {\n const container = props.parentRef ? props.parentRef : chartContainer.current!;\n const currentContainerWidth =\n props.reflowProps?.mode === 'min-width' && !_isFirstRender.current\n ? Math.max(container.getBoundingClientRect().width, _calculateChartMinWidth())\n : container.getBoundingClientRect().width;\n const currentContainerHeight =\n container.getBoundingClientRect().height > legendContainerHeight\n ? container.getBoundingClientRect().height\n : 350;\n const shouldResize =\n containerWidth !== currentContainerWidth || containerHeight !== currentContainerHeight - legendContainerHeight;\n if (shouldResize) {\n setContainerWidth(currentContainerWidth);\n setContainerHeight(currentContainerHeight - legendContainerHeight);\n }\n }\n //});\n }\n\n function _onChartLeave(): void {\n props.onChartMouseLeave && props.onChartMouseLeave();\n }\n\n function _calculateChartMinWidth(): number {\n // Adding 10px for padding on both sides\n const labelWidth = _calcMaxLabelWidthWithTransform(_tickValues) + 10;\n\n let minChartWidth = margins.left! + margins.right! + labelWidth * (_tickValues.length - 1);\n\n if (\n [ChartTypes.GroupedVerticalBarChart, ChartTypes.VerticalBarChart, ChartTypes.VerticalStackedBarChart].includes(\n props.chartType,\n )\n ) {\n const minDomainMargin = 8;\n minChartWidth += minDomainMargin * 2;\n }\n\n return minChartWidth;\n }\n\n function _calcMaxLabelWidthWithTransform(x: (string | number)[]) {\n // Case: rotated labels\n if (!props.wrapXAxisLables && props.rotateXAxisLables && props.xAxisType! === XAxisTypes.StringAxis) {\n const longestLabelWidth = calculateLongestLabelWidth(x, `.${classes.xAxis} text`);\n return Math.ceil(longestLabelWidth * Math.cos(Math.PI / 4));\n }\n\n // Case: truncated labels\n if (props.showXAxisLablesTooltip) {\n const tickValues = x.map(val => {\n const numChars = props.noOfCharsToTruncate || 4;\n return val.toString().length > numChars ? `${val.toString().slice(0, numChars)}...` : val;\n });\n\n const longestLabelWidth = calculateLongestLabelWidth(tickValues, `.${classes.xAxis} text`);\n return Math.ceil(longestLabelWidth);\n }\n\n // Case: wrapped labels\n if (props.wrapXAxisLables) {\n // FIXME: Calculate the max width of lines instead of words. This requires applying\n // the wrapping transformation earlier to obtain the actual rendered lines.\n const words: string[] = [];\n x.forEach((val: string) => {\n words.push(...val.toString().split(/\\s+/));\n });\n\n // This approach works well in most cases, since overflow typically occurs only when\n // a single word exceeds the specified width — otherwise, the text will wrap as expected.\n const longestLabelWidth = calculateLongestLabelWidth(words, `.${classes.xAxis} text`);\n return Math.max(Math.ceil(longestLabelWidth), DEFAULT_WRAP_WIDTH);\n }\n\n // Default case\n const longestLabelWidth = calculateLongestLabelWidth(x, `.${classes.xAxis} text`);\n return Math.ceil(longestLabelWidth);\n }\n\n function _transformXAxisLabels() {\n _removalValueForTextTuncate = 0;\n\n /*\n * To enable wrapping of x axis tick values or to display complete x axis tick values,\n * we need to calculate how much space it needed to render the text.\n * No need to re-calculate every time the chart renders and same time need to get an update. So using setState.\n * Required space will be calculated first time chart rendering and if any width/height of chart updated.\n * */\n if (props.wrapXAxisLables || props.showXAxisLablesTooltip) {\n let maxXAxisLabelWidth: number | undefined;\n if (props.xAxisType === XAxisTypes.StringAxis) {\n if ((props.datasetForXAxisDomain?.length || 0) > 1) {\n maxXAxisLabelWidth = _xScale.step();\n } else {\n maxXAxisLabelWidth = containerWidth;\n }\n }\n\n const wrapLabelProps = {\n node: xAxisElement.current!,\n xAxis: _xScale,\n showXAxisLablesTooltip: props.showXAxisLablesTooltip || false,\n noOfCharsToTruncate: props.noOfCharsToTruncate || 4,\n width: maxXAxisLabelWidth,\n };\n _removalValueForTextTuncate = createWrapOfXLabels(wrapLabelProps) ?? 0;\n }\n\n if (!props.wrapXAxisLables && props.rotateXAxisLables && props.xAxisType! === XAxisTypes.StringAxis) {\n const rotateLabelProps = {\n node: xAxisElement.current!,\n xAxis: _xScale,\n };\n const rotatedHeight = rotateXAxisLabels(rotateLabelProps) ?? 0;\n // margins.bottom is used as padding here\n _removalValueForTextTuncate = rotatedHeight + margins.bottom!;\n }\n }\n\n /**\n * We have use the {@link defaultTabbableElement } to fix\n * the Focus not landing on chart while tabbing, instead goes to legend.\n * This issue is observed in Area, line chart after performance optimization done in the PR {@link https://github.com/microsoft/fluentui/pull/27721 }\n * This issue is observed in Bar charts after the changes done by FocusZone team in the PR: {@link https://github.com/microsoft/fluentui/pull/24175 }\n * The issue in Bar Charts(VB and VSB) is due to a {@link FocusZone } update where previously an event listener was\n * attached on keydown to the window, so that whenever the tab key is pressed all outer FocusZone's\n * tab-indexes are updated (an outer FocusZone is a FocusZone that is not within another one).\n * But now after the above PR : they are attaching the\n * listeners to the FocusZone elements instead of the window. So in the first render cycle in Bar charts\n * bars are not created as in the first render cycle the size of the chart container is not known( or is 0)\n * which creates bars of height 0 so instead we do not create any bars and instead return empty fragments.\n *\n * We have tried 2 Approaches to fix the issue:\n * 1. Using the {@link elementRef} property of FocusZone where we dispatch event for tab keydown\n * after the second render cycle which triggers an update of the tab index in FocusZone.\n * But this is a hacky solution and not a proper fix and also elementRef is deprecated.\n * 2. Using the default tabbable element to fix the issue.\n */\n\n return (\n <div\n id={idForGraph}\n className={classes.root}\n role={'presentation'}\n ref={(rootElem: HTMLDivElement) => (chartContainer.current = rootElem)}\n onMouseLeave={_onChartLeave}\n >\n <div className={classes.chartWrapper} {...focusAttributes} {...arrowAttributes}>\n {_isFirstRender.current}\n <svg\n width={svgDimensions.width}\n height={svgDimensions.height}\n aria-label={props.chartTitle}\n style={{ display: 'block' }}\n className={classes.chart}\n {...getSecureProps(svgProps)}\n >\n <g\n ref={(e: SVGSVGElement | null) => {\n xAxisElement.current = e!;\n }}\n id={`xAxisGElement${idForGraph}`}\n // To add wrap of x axis lables feature, need to remove word height from svg height.\n transform={`translate(0, ${svgDimensions.height - margins.bottom! - _removalValueForTextTuncate!})`}\n className={classes.xAxis}\n />\n {props.xAxisTitle !== undefined && props.xAxisTitle !== '' && (\n <SVGTooltipText\n {...commonSvgToolTipProps}\n content={props.xAxisTitle}\n textProps={{\n x: margins.left! + startFromX + xAxisTitleMaximumAllowedWidth / 2,\n y: svgDimensions.height - titleMargin,\n className: classes.axisTitle!,\n textAnchor: 'middle',\n }}\n maxWidth={xAxisTitleMaximumAllowedWidth}\n />\n )}\n {props.xAxisAnnotation !== undefined && props.xAxisAnnotation !== '' && (\n <SVGTooltipText\n {...commonSvgToolTipProps}\n content={props.xAxisAnnotation}\n textProps={{\n x: margins.left! + startFromX + xAxisTitleMaximumAllowedWidth / 2,\n y: titleMargin + 3,\n className: classes.axisAnnotation!,\n textAnchor: 'middle',\n 'aria-hidden': true,\n }}\n maxWidth={xAxisTitleMaximumAllowedWidth}\n />\n )}\n <g\n ref={(e: SVGSVGElement | null) => {\n yAxisElement.current = e!;\n }}\n id={`yAxisGElement${idForGraph}`}\n transform={`translate(${\n _useRtl ? svgDimensions.width - margins.right! - startFromX : margins.left! + startFromX\n }, 0)`}\n className={classes.yAxis}\n />\n {props.secondaryYScaleOptions && (\n <g>\n <g\n ref={(e: SVGSVGElement | null) => {\n yAxisElementSecondary.current = e!;\n }}\n id={`yAxisGElementSecondary${idForGraph}`}\n transform={`translate(${\n _useRtl ? margins.left! + startFromX : svgDimensions.width - margins.right! - startFromX\n }, 0)`}\n className={classes.yAxis}\n />\n {props.secondaryYAxistitle !== undefined && props.secondaryYAxistitle !== '' && (\n <SVGTooltipText\n {...commonSvgToolTipProps}\n content={props.secondaryYAxistitle}\n textProps={{\n x: (yAxisTitleMaximumAllowedHeight - margins.bottom!) / 2 + _removalValueForTextTuncate!,\n y: _useRtl ? startFromX - titleMargin : svgDimensions.width - margins.right!,\n textAnchor: 'middle',\n transform: `translate(${\n _useRtl ? margins.right! / 2 - titleMargin : margins.right! / 2 + titleMargin\n },\n ${svgDimensions.height - margins.bottom! - margins.top! - titleMargin})rotate(-90)`,\n className: classes.axisTitle!,\n }}\n maxWidth={yAxisTitleMaximumAllowedHeight}\n />\n )}\n </g>\n )}\n {children}\n {props.yAxisTitle !== undefined && props.yAxisTitle !== '' && (\n <SVGTooltipText\n {...commonSvgToolTipProps}\n content={props.yAxisTitle}\n textProps={{\n x: (yAxisTitleMaximumAllowedHeight - margins.bottom!) / 2 + _removalValueForTextTuncate!,\n y: _useRtl ? svgDimensions.width - margins.right! / 2 + titleMargin : margins.left! / 2 - titleMargin,\n textAnchor: 'middle',\n transform: `translate(0,\n ${svgDimensions.height - margins.bottom! - margins.top! - titleMargin})rotate(-90)`,\n className: classes.axisTitle!,\n }}\n maxWidth={yAxisTitleMaximumAllowedHeight}\n />\n )}\n {props.yAxisAnnotation !== undefined &&\n props.yAxisAnnotation !== '' &&\n (props.secondaryYAxistitle === undefined || props.secondaryYAxistitle === '') && (\n <SVGTooltipText\n {...commonSvgToolTipProps}\n content={props.yAxisAnnotation}\n textProps={{\n x: (yAxisTitleMaximumAllowedHeight - margins.bottom!) / 2 + _removalValueForTextTuncate!,\n y: _useRtl ? startFromX - titleMargin : svgDimensions.width - margins.right!,\n textAnchor: 'middle',\n transform: `translate(${\n _useRtl ? margins.right! / 2 - titleMargin : margins.right! / 2 + titleMargin\n },\n ${svgDimensions.height - margins.bottom! - margins.top! - titleMargin})rotate(-90)`,\n className: classes.axisAnnotation!,\n 'aria-hidden': true,\n }}\n maxWidth={yAxisTitleMaximumAllowedHeight}\n />\n )}\n </svg>\n </div>\n\n {!props.hideLegend && (\n <div ref={(e: HTMLDivElement) => (legendContainer = e)} className={classes.legendContainer}>\n {props.legendBars}\n </div>\n )}\n {/** The callout is used for narration, so keep it mounted on the DOM */}\n {callout && <React.Suspense fallback={<div>Loading...</div>}>{callout}</React.Suspense>}\n </div>\n );\n});\nCartesianChart.displayName = 'CartesianChart';\nCartesianChart.defaultProps = {\n hideTickOverlap: true,\n};\n"],"names":["React","useCartesianChartStyles","select","d3Select","createNumericXAxis","createStringXAxis","createDateXAxis","XAxisTypes","YAxisType","createWrapOfXLabels","rotateXAxisLabels","calculateLongestLabelWidth","createYAxisLabels","ChartTypes","wrapContent","useRtl","truncateString","tooltipOfAxislabels","getSecureProps","DEFAULT_WRAP_WIDTH","useId","SVGTooltipText","ChartPopover","useFocusableGroup","useArrowNavigationGroup","CartesianChart","forwardRef","props","forwardedRef","chartContainer","useRef","legendContainer","minLegendContainerHeight","xAxisElement","yAxisElement","yAxisElementSecondary","margins","idForGraph","_reqID","_useRtl","_tickValues","titleMargin","_isFirstRender","_xScale","isIntegralDataset","useMemo","points","some","point","y","_tooltipId","_removalValueForTextTuncate","containerWidth","setContainerWidth","useState","containerHeight","setContainerHeight","startFromX","setStartFromX","prevProps","setPrevProps","chartTypesWithStringYAxis","HorizontalBarChartWithAxis","HeatMapChart","VerticalStackedBarChart","GanttChart","ScatterChart","top","bottom","right","left","secondaryYScaleOptions","TITLE_MARGIN_HORIZONTAL","TITLE_MARGIN_VERTICAL","xAxisTitle","undefined","yAxisTitle","secondaryYAxistitle","xAxisAnnotation","yAxisAnnotation","classes","focusAttributes","arrowAttributes","axis","useEffect","_fitParentContainer","includes","chartType","showYAxisLables","yAxisType","StringAxis","maxYAxisLabelLength","calculateMaxYAxisLabelLength","yAxis","cancelAnimationFrame","height","width","useImperativeHandle","componentRef","current","_generateCallout","calloutProps","className","formatTickLabel","str","showYAxisLablesTooltip","noOfCharsToTruncate","stringDatasetForYAxisDomain","map","label","svgProps","culture","dateLocalizeOptions","timeFormatLocale","customDateTimeFormatter","parentRef","margin","getmargins","callout","children","enableFirstRenderOptimization","XAxisParams","domainNRangeValues","getDomainNRangeValues","getDomainMargins","xAxisType","barwidth","tickValues","showRoundOffXTickValues","xAxisCount","xAxisTickCount","xAxistickSize","tickPadding","showXAxisLablesTooltip","xAxisPadding","xAxisInnerPadding","xAxisOuterPadding","hideTickOverlap","rotateXAxisLables","calcMaxLabelWidth","_calcMaxLabelWidthWithTransform","tickStep","xAxis","tick0","xScale","NumericAxis","tickParams","xScaleType","DateAxis","useUTC","datasetForXAxisDomain","_transformXAxisLabels","YAxisParams","getYDomainMargins","yAxisTickFormat","yAxisTickCount","yMinValue","yMaxValue","maxOfYVal","yMinMaxValues","getMinMaxOfYAxis","yAxisPadding","yAxisTickValues","yScalePrimary","yScaleSecondary","axisData","yAxisDomainValues","createStringYAxis","YAxisParamsSecondary","createYAxis","roundedTicks","secondaryYScaleType","yScaleType","document","getElementById","remove","e","_yAxisElement","call","ytooltipProps","tooltipCls","tooltip","id","_getData","getGraphData","getAxisData","hideTooltip","isPopoverOpen","svgDimensions","xAxisTitleMaximumAllowedWidth","yAxisTitleMaximumAllowedHeight","commonSvgToolTipProps","showBackground","svgTooltip","content","legendContainerHeight","hideLegend","legendContainerComputedStyles","getComputedStyle","getBoundingClientRect","parseFloat","marginTop","marginBottom","container","currentContainerWidth","reflowProps","mode","Math","max","_calculateChartMinWidth","currentContainerHeight","shouldResize","_onChartLeave","onChartMouseLeave","labelWidth","minChartWidth","length","GroupedVerticalBarChart","VerticalBarChart","minDomainMargin","x","wrapXAxisLables","longestLabelWidth","ceil","cos","PI","val","numChars","toString","slice","words","forEach","push","split","maxXAxisLabelWidth","step","wrapLabelProps","node","rotateLabelProps","rotatedHeight","div","root","role","ref","rootElem","onMouseLeave","chartWrapper","svg","aria-label","chartTitle","style","display","chart","g","transform","textProps","axisTitle","textAnchor","maxWidth","axisAnnotation","legendBars","Suspense","fallback","displayName","defaultProps"],"mappings":"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"}
@@ -22,11 +22,13 @@ const MIN_DOMAIN_MARGIN = 8;
22
22
  const X1_INNER_PADDING = 0.1;
23
23
  const VERTICAL_BAR_GAP = 1;
24
24
  const MIN_BAR_HEIGHT = 1;
25
- const GroupedVerticalBarChart = /*#__PURE__*/ _react.forwardRef((props = {
26
- maxBarWidth: 24,
27
- xAxisCategoryOrder: 'default'
28
- }, forwardedRef)=>{
25
+ const GroupedVerticalBarChart = /*#__PURE__*/ _react.forwardRef((_props, forwardedRef)=>{
29
26
  var _props_legendProps, _props_legendProps1;
27
+ const props = {
28
+ xAxisCategoryOrder: 'default',
29
+ maxBarWidth: 24,
30
+ ..._props
31
+ };
30
32
  const _tooltipId = (0, _reactutilities.useId)('GVBCTooltipId_');
31
33
  const _emptyChartId = (0, _reactutilities.useId)('_GVBC_empty');
32
34
  const _useRtl = (0, _index.useRtl)();
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/components/GroupedVerticalBarChart/GroupedVerticalBarChart.tsx"],"sourcesContent":["import * as React from 'react';\nimport { useGroupedVerticalBarChartStyles_unstable } from './useGroupedVerticalBarChartStyles.styles';\nimport { select as d3Select } from 'd3-selection';\nimport { Axis as D3Axis } from 'd3-axis';\nimport { max as d3Max, min as d3Min } from 'd3-array';\nimport { ScaleLinear, scaleBand as d3ScaleBand } from 'd3-scale';\n\nimport { useId, JSXElement } from '@fluentui/react-utilities';\nimport {\n ChartTypes,\n IAxisData,\n getAccessibleDataObject,\n tooltipOfAxislabels,\n XAxisTypes,\n getTypeOfAxis,\n formatScientificLimitWidth,\n getScalePadding,\n getBarWidth,\n isScalePaddingDefined,\n createNumericYAxis,\n IDomainNRange,\n domainRangeOfXStringAxis,\n createStringYAxis,\n getNextColor,\n areArraysEqual,\n calculateLongestLabelWidth,\n useRtl,\n YAxisType,\n calcRequiredWidth,\n calcTotalWidth,\n calcBandwidth,\n calcTotalBandUnits,\n sortAxisCategories,\n} from '../../utilities/index';\n\nimport {\n AccessibilityProps,\n CartesianChart,\n Margins,\n Legend,\n GroupedVerticalBarChartProps,\n GroupedVerticalBarChartData,\n GVBarChartSeriesPoint,\n Legends,\n YValueHover,\n ChartPopoverProps,\n Chart,\n ImageExportOptions,\n LegendContainer,\n} from '../../index';\nimport { toImage } from '../../utilities/image-export-utils';\n\ntype StringAxis = D3Axis<string>;\ntype NumericAxis = D3Axis<number | { valueOf(): number }>;\n\nconst MIN_DOMAIN_MARGIN = 8;\nconst X1_INNER_PADDING = 0.1;\nconst VERTICAL_BAR_GAP = 1;\nconst MIN_BAR_HEIGHT = 1;\n\n// This interface used for - While forming datapoints from given prop \"data\" in code\ninterface GVDataPoint {\n [key: string]: number | string;\n}\n\n// While forming datapoints from given prop \"data\" in code. These datapoints are used for to draw graph easily.\ninterface GVSingleDataPoint {\n [key: string]: GVDataPoint;\n}\n\nexport const GroupedVerticalBarChart: React.FC<GroupedVerticalBarChartProps> = React.forwardRef<\n HTMLDivElement,\n GroupedVerticalBarChartProps\n>((props = { maxBarWidth: 24, xAxisCategoryOrder: 'default' }, forwardedRef) => {\n const _tooltipId: string = useId('GVBCTooltipId_');\n const _emptyChartId: string = useId('_GVBC_empty');\n const _useRtl: boolean = useRtl();\n let _domainMargin: number = MIN_DOMAIN_MARGIN;\n let _xAxisLabels: string[] = [];\n let _datasetForBars: any[] = [];\n let _margins: Margins = { top: 0, right: 0, bottom: 0, left: 0 };\n let _groupedVerticalBarGraph: JSXElement[] = [];\n let _yMax: number = 0;\n let _calloutAnchorPoint: GVBarChartSeriesPoint | null = null;\n let _barWidth: number = 0;\n let _groupWidth: number = 0;\n let _xAxisInnerPadding: number = 0;\n let _xAxisOuterPadding: number = 0;\n let _legends: string[] = [];\n let _legendColorMap: Record<string, [string, string]> = {};\n const cartesianChartRef = React.useRef<Chart>(null);\n const Y_ORIGIN: number = 0;\n const _legendsRef = React.useRef<LegendContainer>(null);\n\n const [color, setColor] = React.useState<string>('');\n const [dataForHoverCard, setDataForHoverCard] = React.useState<number>(0);\n const [selectedLegends, setSelectedLegends] = React.useState<string[]>(props.legendProps?.selectedLegends || []);\n const [xCalloutValue, setXCalloutValue] = React.useState<string>('');\n const [yCalloutValue, setYCalloutValue] = React.useState<string>('');\n const [YValueHover, setYValueHover] = React.useState<YValueHover[]>([]);\n const [hoverXValue, setHoverXValue] = React.useState<string>('');\n const [calloutLegend, setCalloutLegend] = React.useState<string>('');\n const [activeLegend, setActiveLegend] = React.useState<string>('');\n const [callOutAccessibilityData, setCallOutAccessibilityData] = React.useState<AccessibilityProps | undefined>(\n undefined,\n );\n const [clickPosition, setClickPosition] = React.useState({ x: 0, y: 0 });\n const [isPopoverOpen, setPopoverOpen] = React.useState<boolean>(false);\n const classes = useGroupedVerticalBarChartStyles_unstable(props);\n\n React.useEffect(() => {\n if (!areArraysEqual(props.legendProps?.selectedLegends, selectedLegends)) {\n setSelectedLegends(props.legendProps?.selectedLegends || []);\n }\n }, [props.legendProps?.selectedLegends]);\n\n React.useImperativeHandle(\n props.componentRef,\n () => ({\n chartContainer: cartesianChartRef.current?.chartContainer ?? null,\n toImage: (opts?: ImageExportOptions): Promise<string> => {\n return toImage(cartesianChartRef.current?.chartContainer, _legendsRef.current?.toSVG, _useRtl, opts);\n },\n }),\n [],\n );\n\n const _adjustProps = () => {\n _barWidth = getBarWidth(props.barWidth, props.maxBarWidth);\n // x0_inner_padding = space_between_groups / (space_between_groups + group_width)\n // space_between_groups = 2 * bar_width\n // group_width = _legends.length * bar_width + (_legends.length - 1) * space_between_bars\n _xAxisInnerPadding = getScalePadding(\n props.xAxisInnerPadding,\n undefined,\n 2 / (2 + calcTotalBandUnits(_legends.length, X1_INNER_PADDING)),\n );\n _xAxisOuterPadding = getScalePadding(props.xAxisOuterPadding);\n };\n\n const _createDataset = (points: GroupedVerticalBarChartData[]) => {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const datasetForBars: any = [];\n\n points.forEach((point: GroupedVerticalBarChartData, index: number) => {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const singleDatasetPointForBars: any = {};\n const legendToBarPoint: Record<string, GVBarChartSeriesPoint> = {};\n\n point.series.forEach((seriesPoint: GVBarChartSeriesPoint) => {\n if (!singleDatasetPointForBars[seriesPoint.legend]) {\n singleDatasetPointForBars[seriesPoint.legend] = [{ ...seriesPoint }];\n legendToBarPoint[seriesPoint.legend] = { ...seriesPoint };\n } else {\n singleDatasetPointForBars[seriesPoint.legend].push({ ...seriesPoint });\n legendToBarPoint[seriesPoint.legend].data += seriesPoint.data;\n }\n });\n\n singleDatasetPointForBars.xAxisPoint = point.name;\n singleDatasetPointForBars.indexNum = index;\n singleDatasetPointForBars.groupSeries = Object.values(legendToBarPoint);\n singleDatasetPointForBars.stackCallOutAccessibilityData = point.stackCallOutAccessibilityData;\n datasetForBars.push(singleDatasetPointForBars);\n });\n return datasetForBars;\n };\n\n const _createDataSetOfGVBC = (points: GroupedVerticalBarChartData[]) => {\n const legends = new Set<string>();\n const xAxisLabels: string[] = _getOrderedXAxisLabels(points);\n points.forEach((point: GroupedVerticalBarChartData) => {\n point.series.forEach((seriesPoint: GVBarChartSeriesPoint) => {\n legends.add(seriesPoint.legend);\n });\n });\n const datasetForBars = _createDataset(points);\n return {\n legends: Array.from(legends),\n xAxisLabels,\n datasetForBars,\n };\n };\n\n const onLegendSelectionChange = (\n selectedLegends: string[],\n event: React.MouseEvent<HTMLButtonElement>,\n currentLegend?: Legend,\n ): void => {\n if (props.legendProps?.canSelectMultipleLegends) {\n setSelectedLegends(selectedLegends);\n } else {\n setSelectedLegends(selectedLegends.slice(-1));\n }\n if (props.legendProps?.onChange) {\n props.legendProps.onChange(selectedLegends, event, currentLegend);\n }\n };\n\n // eslint-disable-next-line @typescript-eslint/no-deprecated\n const _getLegendData = (points: GroupedVerticalBarChartData[]): JSXElement => {\n const actions: Legend[] = [];\n\n _legends.forEach((legendTitle: string) => {\n const legend: Legend = {\n title: legendTitle,\n color: _legendColorMap[legendTitle][0],\n hoverAction: () => {\n _handleChartMouseLeave();\n _onLegendHover(legendTitle);\n },\n onMouseOutAction: () => {\n _onLegendLeave();\n },\n };\n\n actions.push(legend);\n });\n return (\n <Legends\n legends={actions}\n enabledWrapLines={props.enabledLegendsWrapLines}\n overflowText={props.legendsOverflowText}\n {...props.legendProps}\n onChange={onLegendSelectionChange}\n legendRef={_legendsRef}\n />\n );\n };\n\n const _addDefaultColors = (data?: GroupedVerticalBarChartData[]): GroupedVerticalBarChartData[] => {\n _legendColorMap = {};\n let colorIndex = 0;\n\n return (\n data?.map(point => {\n return {\n ...point,\n series:\n point.series?.map(seriesPoint => {\n // TODO: Add support for gradient colors\n let startColor = seriesPoint.color ? seriesPoint.color : getNextColor(colorIndex, 0);\n let endColor = startColor;\n if (!_legendColorMap[seriesPoint.legend]) {\n _legendColorMap[seriesPoint.legend] = [startColor, endColor];\n }\n colorIndex += 1;\n\n return {\n ...seriesPoint,\n color: seriesPoint.color ?? _legendColorMap[seriesPoint.legend][0],\n };\n }) ?? [],\n };\n }) ?? []\n );\n };\n\n const _getOrderedXAxisLabels = (points: GroupedVerticalBarChartData[]) => {\n if (_xAxisType !== XAxisTypes.StringAxis) {\n return [];\n }\n\n return sortAxisCategories(_mapCategoryToValues(points), props.xAxisCategoryOrder);\n };\n\n const _mapCategoryToValues = (points: GroupedVerticalBarChartData[]) => {\n const categoryToValues: Record<string, number[]> = {};\n points.forEach(point => {\n if (!categoryToValues[point.name]) {\n categoryToValues[point.name] = [];\n }\n point.series.forEach(seriesPoint => {\n categoryToValues[point.name].push(seriesPoint.data);\n });\n });\n return categoryToValues;\n };\n\n const points = _addDefaultColors(props.data);\n const _xAxisType: XAxisTypes = getTypeOfAxis(points![0].name, true) as XAxisTypes;\n const { legends, xAxisLabels, datasetForBars } = _createDataSetOfGVBC(points!);\n _legends = legends;\n _xAxisLabels = xAxisLabels;\n _datasetForBars = datasetForBars;\n const legendBars: JSXElement = _getLegendData(points);\n _adjustProps();\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any -- Add commentMore actions\n function _getMinMaxOfYAxis(datasetForBars: any, yAxisType?: YAxisType, useSecondaryYScale?: boolean) {\n const values: number[] = [];\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n datasetForBars.forEach((data: any) => {\n data.groupSeries.forEach((point: GVBarChartSeriesPoint) => {\n if (!useSecondaryYScale === !point.useSecondaryYScale) {\n values.push(point.data);\n }\n });\n });\n\n return { startValue: d3Min(values)!, endValue: d3Max(values)! };\n }\n\n function _getDomainNRangeValues(\n points: GroupedVerticalBarChartData[],\n margins: Margins,\n width: number,\n chartType: ChartTypes,\n isRTL: boolean,\n xAxisType: XAxisTypes,\n barWidth: number,\n tickValues: Date[] | number[] | undefined,\n shiftX: number,\n ) {\n let domainNRangeValue: IDomainNRange;\n if (xAxisType === XAxisTypes.NumericAxis || xAxisType === XAxisTypes.DateAxis) {\n domainNRangeValue = { dStartValue: 0, dEndValue: 0, rStartValue: 0, rEndValue: 0 };\n } else {\n domainNRangeValue = domainRangeOfXStringAxis(margins, width, isRTL);\n }\n return domainNRangeValue;\n }\n\n // The maxOfYVal prop is only required for the primary y-axis, so yMax should be calculated\n // using only the data points associated with the primary y-axis.\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const yMax = _getMinMaxOfYAxis(_datasetForBars).endValue;\n _yMax = Math.max(yMax, props.yMaxValue || 0);\n\n const calloutProps: ChartPopoverProps = {\n clickPosition,\n isPopoverOpen,\n color,\n legend: calloutLegend,\n XValue: xCalloutValue,\n YValue: yCalloutValue ? yCalloutValue : dataForHoverCard,\n YValueHover,\n hoverXValue,\n culture: props.culture,\n isCartesian: true,\n ...props.calloutProps,\n ...getAccessibleDataObject(callOutAccessibilityData, 'text', false),\n };\n const tickParams = {\n tickValues: props.tickValues!,\n tickFormat: props.tickFormat!,\n };\n\n const _getGraphData = (\n xScale: StringAxis | NumericAxis,\n yScalePrimary: ScaleLinear<number, number>,\n containerHeight: number,\n containerWidth: number,\n xElement?: SVGElement | null,\n yAxisElement?: SVGElement | null,\n yScaleSecondary?: ScaleLinear<number, number>,\n ) => {\n const xScale0 = _createX0Scale(containerWidth);\n\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(\n props.barWidth,\n props.maxBarWidth,\n calcBandwidth(xScale0.bandwidth(), _legends.length, X1_INNER_PADDING),\n );\n _groupWidth = calcRequiredWidth(_barWidth, _legends.length, X1_INNER_PADDING);\n\n const xScale1 = _createX1Scale();\n const allGroupsBars: JSXElement[] = [];\n _datasetForBars.forEach((singleSet: GVSingleDataPoint) => {\n allGroupsBars.push(\n _buildGraph(singleSet, xScale0, xScale1, yScalePrimary, yScaleSecondary, containerHeight, xElement!),\n );\n });\n _groupedVerticalBarGraph = allGroupsBars;\n };\n\n const _getMargins = (margins: Margins) => {\n _margins = margins;\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 const onBarHover = (\n pointData: GVBarChartSeriesPoint,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n groupData: any,\n mouseEvent: React.MouseEvent<SVGElement>,\n ): void => {\n mouseEvent.persist();\n if (_calloutAnchorPoint !== pointData) {\n _calloutAnchorPoint = pointData;\n updatePosition(mouseEvent.clientX, mouseEvent.clientY);\n setPopoverOpen(_noLegendHighlighted() || _legendHighlighted(pointData.legend));\n setCalloutLegend(pointData.legend);\n setDataForHoverCard(pointData.data);\n setColor(pointData.color);\n setXCalloutValue(pointData.xAxisCalloutData!);\n setYCalloutValue(pointData.yAxisCalloutData!);\n setCallOutAccessibilityData(\n props.isCalloutForStack ? groupData.stackCallOutAccessibilityData : pointData.callOutAccessibilityData,\n );\n setYValueHover(groupData.groupSeries);\n setHoverXValue(pointData.xAxisCalloutData!);\n }\n };\n\n const _onBarLeave = (): void => {\n /**/\n };\n\n const _handleChartMouseLeave = (): void => {\n _calloutAnchorPoint = null;\n setPopoverOpen(false);\n };\n\n const onBarFocus = (\n event: React.FocusEvent<SVGRectElement, Element>,\n pointData: GVBarChartSeriesPoint,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n groupData: any,\n ): void => {\n let x = 0;\n let y = 0;\n\n const targetRect = (event.target as SVGRectElement).getBoundingClientRect();\n x = targetRect.left + targetRect.width / 2;\n y = targetRect.top + targetRect.height / 2;\n updatePosition(x, y);\n setPopoverOpen(_noLegendHighlighted() || _legendHighlighted(pointData.legend));\n setCalloutLegend(pointData.legend);\n setDataForHoverCard(pointData.data);\n setColor(pointData.color);\n setXCalloutValue(pointData.xAxisCalloutData!);\n setYCalloutValue(pointData.yAxisCalloutData!);\n setCallOutAccessibilityData(\n props.isCalloutForStack ? groupData.stackCallOutAccessibilityData : pointData.callOutAccessibilityData,\n );\n setYValueHover(groupData.groupSeries);\n setHoverXValue(pointData.xAxisCalloutData!);\n };\n\n const _buildGraph = (\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n singleSet: any,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n xScale0: any,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n xScale1: any,\n yScalePrimary: ScaleLinear<number, number>,\n yScaleSecondary: ScaleLinear<number, number> | undefined,\n containerHeight: number,\n xElement: SVGElement,\n // eslint-disable-next-line @typescript-eslint/no-deprecated\n ): JSXElement => {\n // eslint-disable-next-line @typescript-eslint/no-deprecated\n const singleGroup: JSXElement[] = [];\n // eslint-disable-next-line @typescript-eslint/no-deprecated\n const barLabelsForGroup: JSXElement[] = [];\n\n // Get the actual legends present at this x-axis point\n const presentLegends = Object.keys(singleSet).filter(key => key in _legendColorMap);\n const effectiveGroupWidth = calcRequiredWidth(_barWidth, presentLegends.length, X1_INNER_PADDING);\n\n // For stacked bars, center the single bar group in the available space\n // Instead of using the global legend position, use the local position within present legends\n const localScale = d3ScaleBand()\n .domain(presentLegends)\n .range(_useRtl ? [effectiveGroupWidth, 0] : [0, effectiveGroupWidth])\n .paddingInner(X1_INNER_PADDING);\n _legends.forEach((legendTitle: string, legendIndex: number) => {\n const barPoints = singleSet[legendTitle];\n if (barPoints) {\n const yBarScale = barPoints[0].useSecondaryYScale && yScaleSecondary ? yScaleSecondary : yScalePrimary;\n\n const xPoint = (localScale(legendTitle) ?? 0) + (localScale.bandwidth() - _barWidth) / 2;\n const isLegendActive = _legendHighlighted(legendTitle) || _noLegendHighlighted();\n const barOpacity = isLegendActive ? '' : '0.1';\n\n let barTotalValue = 0;\n const yBaseline = yBarScale(Y_ORIGIN);\n let yPositiveStart = yBaseline;\n let yNegativeStart = yBaseline;\n let yPoint = Y_ORIGIN;\n\n barPoints.forEach((pointData: GVBarChartSeriesPoint, pointIndex: number) => {\n if (!pointData.data) {\n // Not rendering data with 0.\n return;\n }\n const barGap = (VERTICAL_BAR_GAP / 2) * (pointIndex > 0 ? 2 : 0);\n const height = Math.max(yBarScale(Y_ORIGIN) - yBarScale(Math.abs(pointData.data)), MIN_BAR_HEIGHT);\n const pointColor = pointData.color; // Use the color of the current point\n\n if (pointData.data >= Y_ORIGIN) {\n yPositiveStart -= height + barGap;\n yPoint = yPositiveStart;\n } else {\n yPoint = yNegativeStart + barGap;\n yNegativeStart = yPoint + height;\n }\n\n singleGroup.push(\n <rect\n key={`${singleSet.indexNum}-${legendIndex}-${pointIndex}`}\n className={classes.opacityChangeOnHover}\n height={height}\n width={_barWidth}\n x={xPoint}\n y={yPoint}\n opacity={barOpacity}\n fill={pointColor}\n rx={props.roundCorners ? 3 : 0}\n onMouseOver={event => onBarHover(pointData, singleSet, event)}\n onMouseMove={event => onBarHover(pointData, singleSet, event)}\n onMouseOut={_onBarLeave}\n onFocus={event => onBarFocus(event, pointData, singleSet)}\n onBlur={_onBarLeave}\n onClick={pointData.onClick}\n aria-label={getAriaLabel(pointData, singleSet.xAxisPoint)}\n tabIndex={_legendHighlighted(pointData.legend) || _noLegendHighlighted() ? 0 : undefined}\n role=\"img\"\n />,\n );\n\n barTotalValue += pointData.data;\n });\n if (barTotalValue !== null && !props.hideLabels && Math.ceil(_barWidth) >= 16 && isLegendActive) {\n barLabelsForGroup.push(\n <text\n key={`${singleSet.indexNum}-${legendIndex}`}\n x={xPoint + _barWidth / 2}\n y={barTotalValue >= Y_ORIGIN ? yPositiveStart - 6 : yNegativeStart + 12}\n textAnchor=\"middle\"\n className={classes.barLabel}\n aria-hidden={true}\n style={{ direction: 'ltr', unicodeBidi: 'isolate' }}\n >\n {typeof props.yAxisTickFormat === 'function'\n ? props.yAxisTickFormat(barTotalValue)\n : formatScientificLimitWidth(barTotalValue)}\n </text>,\n );\n }\n }\n });\n // Used to display tooltip at x axis labels.\n if (!props.wrapXAxisLables && props.showXAxisLablesTooltip) {\n const xAxisElement = d3Select(xElement).call(xScale0);\n try {\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 axis: xAxisElement,\n };\n xAxisElement && tooltipOfAxislabels(tooltipProps);\n }\n return (\n <g\n key={singleSet.indexNum}\n transform={`translate(${xScale0(singleSet.xAxisPoint) + (xScale0.bandwidth() - effectiveGroupWidth) / 2}, 0)`}\n >\n {singleGroup}\n {barLabelsForGroup}\n </g>\n );\n };\n\n // For grouped vertical bar chart, First need to define total scale (from start to end)\n // From that need to define scale for single group of bars - done by createX1Scale\n const _createX0Scale = (containerWidth: number) => {\n const x0Axis = 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 return x0Axis;\n };\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const _createX1Scale = (): any => {\n return (\n d3ScaleBand()\n .domain(_legends)\n // When there is only one group, xScale0 adds padding around it,\n // causing the bandwidth to become smaller than the actual group width.\n // So to render bars in the group correctly, use groupWidth instead of the generated scale bandwidth.\n .range(_useRtl ? [_groupWidth, 0] : [0, _groupWidth])\n .paddingInner(X1_INNER_PADDING)\n );\n };\n\n const _onLegendHover = (legendTitle: string): void => {\n setActiveLegend(legendTitle);\n };\n\n const _onLegendLeave = (): void => {\n setActiveLegend('');\n };\n\n const _getAxisData = React.useCallback(\n (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 }\n },\n [props.yMaxValue],\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 const _legendHighlighted = (legendTitle: string) => {\n return _getHighlightedLegend().includes(legendTitle!);\n };\n\n /**\n * This function checks if none of the legends is selected or hovered.\n */\n const _noLegendHighlighted = () => {\n return _getHighlightedLegend().length === 0;\n };\n\n const _getHighlightedLegend = () => {\n return selectedLegends.length > 0 ? selectedLegends : activeLegend ? [activeLegend] : [];\n };\n\n const getAriaLabel = (point: GVBarChartSeriesPoint, xAxisPoint: string): string => {\n const xValue = point.xAxisCalloutData || xAxisPoint;\n const legend = point.legend;\n const yValue = point.yAxisCalloutData || point.data;\n return point.callOutAccessibilityData?.ariaLabel || `${xValue}. ${legend}, ${yValue}.`;\n };\n\n const _getDomainMargins = (containerWidth: number): Margins => {\n /** Total width available to render the bars */\n const totalWidth = calcTotalWidth(containerWidth, _margins, MIN_DOMAIN_MARGIN);\n\n if (_xAxisType === XAxisTypes.StringAxis) {\n if (isScalePaddingDefined(props.xAxisOuterPadding)) {\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 group and after the last group.\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 const groupWidth = calcRequiredWidth(_barWidth, _legends.length, X1_INNER_PADDING);\n /** Total width required to render the groups. Directly proportional to group width */\n const reqWidth = calcRequiredWidth(groupWidth, _xAxisLabels.length, _xAxisInnerPadding);\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 groups at their maximum allowable width\n const groupBandwidth = calcBandwidth(totalWidth, _xAxisLabels.length, _xAxisInnerPadding);\n const barBandwidth = calcBandwidth(groupBandwidth, _legends.length, X1_INNER_PADDING);\n const barWidth = getBarWidth(props.barWidth, props.maxBarWidth, barBandwidth);\n const groupWidth = calcRequiredWidth(barWidth, _legends.length, X1_INNER_PADDING);\n let reqWidth = calcRequiredWidth(groupWidth, _xAxisLabels.length, _xAxisInnerPadding);\n const margin1 = (totalWidth - reqWidth) / 2;\n\n let margin2 = Number.POSITIVE_INFINITY;\n if (!props.hideTickOverlap) {\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 margin2 = (totalWidth - reqWidth) / 2;\n }\n\n _domainMargin = MIN_DOMAIN_MARGIN + Math.max(0, Math.min(margin1, margin2));\n }\n }\n\n return {\n ..._margins,\n left: _margins.left! + _domainMargin,\n right: _margins.right! + _domainMargin,\n };\n };\n\n const _isChartEmpty = (): boolean => {\n return !(\n props.data &&\n props.data.length > 0 &&\n props.data.filter((item: GroupedVerticalBarChartData) => item.series.length).length > 0\n );\n };\n\n const _getChartTitle = (): string => {\n return (\n (props.chartTitle ? `${props.chartTitle}. ` : '') +\n `Vertical bar chart with ${_xAxisLabels.length} groups of ${_legends.length} bars each. `\n );\n };\n\n return !_isChartEmpty() ? (\n <CartesianChart\n {...props}\n chartTitle={_getChartTitle()}\n points={_datasetForBars}\n chartType={ChartTypes.GroupedVerticalBarChart}\n getDomainNRangeValues={_getDomainNRangeValues}\n getMinMaxOfYAxis={_getMinMaxOfYAxis}\n createStringYAxis={createStringYAxis}\n calloutProps={calloutProps}\n legendBars={legendBars}\n xAxisType={_xAxisType}\n createYAxis={createNumericYAxis}\n datasetForXAxisDomain={_xAxisLabels}\n tickParams={tickParams}\n tickPadding={props.tickPadding || 5}\n maxOfYVal={_yMax}\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 barwidth={_barWidth}\n componentRef={cartesianChartRef}\n /* eslint-disable react/jsx-no-bind */\n children={() => {\n return <g>{_groupedVerticalBarGraph}</g>;\n }}\n />\n ) : (\n <div id={_emptyChartId} role={'alert'} style={{ opacity: '0' }} aria-label={'Graph has no data to display'} />\n );\n});\nGroupedVerticalBarChart.displayName = 'GroupedVerticalBarChart';\n"],"names":["React","useGroupedVerticalBarChartStyles_unstable","select","d3Select","max","d3Max","min","d3Min","scaleBand","d3ScaleBand","useId","ChartTypes","getAccessibleDataObject","tooltipOfAxislabels","XAxisTypes","getTypeOfAxis","formatScientificLimitWidth","getScalePadding","getBarWidth","isScalePaddingDefined","createNumericYAxis","domainRangeOfXStringAxis","createStringYAxis","getNextColor","areArraysEqual","calculateLongestLabelWidth","useRtl","calcRequiredWidth","calcTotalWidth","calcBandwidth","calcTotalBandUnits","sortAxisCategories","CartesianChart","Legends","toImage","MIN_DOMAIN_MARGIN","X1_INNER_PADDING","VERTICAL_BAR_GAP","MIN_BAR_HEIGHT","GroupedVerticalBarChart","forwardRef","props","maxBarWidth","xAxisCategoryOrder","forwardedRef","_tooltipId","_emptyChartId","_useRtl","_domainMargin","_xAxisLabels","_datasetForBars","_margins","top","right","bottom","left","_groupedVerticalBarGraph","_yMax","_calloutAnchorPoint","_barWidth","_groupWidth","_xAxisInnerPadding","_xAxisOuterPadding","_legends","_legendColorMap","cartesianChartRef","useRef","Y_ORIGIN","_legendsRef","color","setColor","useState","dataForHoverCard","setDataForHoverCard","selectedLegends","setSelectedLegends","legendProps","xCalloutValue","setXCalloutValue","yCalloutValue","setYCalloutValue","YValueHover","setYValueHover","hoverXValue","setHoverXValue","calloutLegend","setCalloutLegend","activeLegend","setActiveLegend","callOutAccessibilityData","setCallOutAccessibilityData","undefined","clickPosition","setClickPosition","x","y","isPopoverOpen","setPopoverOpen","classes","useEffect","useImperativeHandle","componentRef","chartContainer","current","opts","toSVG","_adjustProps","barWidth","xAxisInnerPadding","length","xAxisOuterPadding","_createDataset","points","datasetForBars","forEach","point","index","singleDatasetPointForBars","legendToBarPoint","series","seriesPoint","legend","push","data","xAxisPoint","name","indexNum","groupSeries","Object","values","stackCallOutAccessibilityData","_createDataSetOfGVBC","legends","Set","xAxisLabels","_getOrderedXAxisLabels","add","Array","from","onLegendSelectionChange","event","currentLegend","canSelectMultipleLegends","slice","onChange","_getLegendData","actions","legendTitle","title","hoverAction","_handleChartMouseLeave","_onLegendHover","onMouseOutAction","_onLegendLeave","enabledWrapLines","enabledLegendsWrapLines","overflowText","legendsOverflowText","legendRef","_addDefaultColors","colorIndex","map","startColor","endColor","_xAxisType","StringAxis","_mapCategoryToValues","categoryToValues","legendBars","_getMinMaxOfYAxis","yAxisType","useSecondaryYScale","startValue","endValue","_getDomainNRangeValues","margins","width","chartType","isRTL","xAxisType","tickValues","shiftX","domainNRangeValue","NumericAxis","DateAxis","dStartValue","dEndValue","rStartValue","rEndValue","yMax","Math","yMaxValue","calloutProps","XValue","YValue","culture","isCartesian","tickParams","tickFormat","_getGraphData","xScale","yScalePrimary","containerHeight","containerWidth","xElement","yAxisElement","yScaleSecondary","xScale0","_createX0Scale","bandwidth","xScale1","_createX1Scale","allGroupsBars","singleSet","_buildGraph","_getMargins","updatePosition","newX","newY","threshold","distance","sqrt","pow","onBarHover","pointData","groupData","mouseEvent","persist","clientX","clientY","_noLegendHighlighted","_legendHighlighted","xAxisCalloutData","yAxisCalloutData","isCalloutForStack","_onBarLeave","onBarFocus","targetRect","target","getBoundingClientRect","height","singleGroup","barLabelsForGroup","presentLegends","keys","filter","key","effectiveGroupWidth","localScale","domain","range","paddingInner","legendIndex","barPoints","yBarScale","xPoint","isLegendActive","barOpacity","barTotalValue","yBaseline","yPositiveStart","yNegativeStart","yPoint","pointIndex","barGap","abs","pointColor","rect","className","opacityChangeOnHover","opacity","fill","rx","roundCorners","onMouseOver","onMouseMove","onMouseOut","onFocus","onBlur","onClick","aria-label","getAriaLabel","tabIndex","role","hideLabels","ceil","text","textAnchor","barLabel","aria-hidden","style","direction","unicodeBidi","yAxisTickFormat","wrapXAxisLables","showXAxisLablesTooltip","xAxisElement","call","document","getElementById","remove","e","tooltipProps","tooltipCls","tooltip","id","axis","g","transform","x0Axis","paddingOuter","_getAxisData","useCallback","yAxisData","yAxisDomainValues","domainValue","_getHighlightedLegend","includes","xValue","yValue","ariaLabel","_getDomainMargins","totalWidth","groupWidth","reqWidth","mode","groupBandwidth","barBandwidth","margin1","margin2","Number","POSITIVE_INFINITY","hideTickOverlap","step","_isChartEmpty","item","_getChartTitle","chartTitle","getDomainNRangeValues","getMinMaxOfYAxis","createYAxis","datasetForXAxisDomain","tickPadding","maxOfYVal","getmargins","getGraphData","getAxisData","onChartMouseLeave","getDomainMargins","barwidth","children","div","displayName"],"mappings":"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"}
1
+ {"version":3,"sources":["../src/components/GroupedVerticalBarChart/GroupedVerticalBarChart.tsx"],"sourcesContent":["import * as React from 'react';\nimport { useGroupedVerticalBarChartStyles_unstable } from './useGroupedVerticalBarChartStyles.styles';\nimport { select as d3Select } from 'd3-selection';\nimport { Axis as D3Axis } from 'd3-axis';\nimport { max as d3Max, min as d3Min } from 'd3-array';\nimport { ScaleLinear, scaleBand as d3ScaleBand } from 'd3-scale';\n\nimport { useId, JSXElement } from '@fluentui/react-utilities';\nimport {\n ChartTypes,\n IAxisData,\n getAccessibleDataObject,\n tooltipOfAxislabels,\n XAxisTypes,\n getTypeOfAxis,\n formatScientificLimitWidth,\n getScalePadding,\n getBarWidth,\n isScalePaddingDefined,\n createNumericYAxis,\n IDomainNRange,\n domainRangeOfXStringAxis,\n createStringYAxis,\n getNextColor,\n areArraysEqual,\n calculateLongestLabelWidth,\n useRtl,\n YAxisType,\n calcRequiredWidth,\n calcTotalWidth,\n calcBandwidth,\n calcTotalBandUnits,\n sortAxisCategories,\n} from '../../utilities/index';\n\nimport {\n AccessibilityProps,\n CartesianChart,\n Margins,\n Legend,\n GroupedVerticalBarChartProps,\n GroupedVerticalBarChartData,\n GVBarChartSeriesPoint,\n Legends,\n YValueHover,\n ChartPopoverProps,\n Chart,\n ImageExportOptions,\n LegendContainer,\n} from '../../index';\nimport { toImage } from '../../utilities/image-export-utils';\n\ntype StringAxis = D3Axis<string>;\ntype NumericAxis = D3Axis<number | { valueOf(): number }>;\n\nconst MIN_DOMAIN_MARGIN = 8;\nconst X1_INNER_PADDING = 0.1;\nconst VERTICAL_BAR_GAP = 1;\nconst MIN_BAR_HEIGHT = 1;\n\n// This interface used for - While forming datapoints from given prop \"data\" in code\ninterface GVDataPoint {\n [key: string]: number | string;\n}\n\n// While forming datapoints from given prop \"data\" in code. These datapoints are used for to draw graph easily.\ninterface GVSingleDataPoint {\n [key: string]: GVDataPoint;\n}\n\nexport const GroupedVerticalBarChart: React.FC<GroupedVerticalBarChartProps> = React.forwardRef<\n HTMLDivElement,\n GroupedVerticalBarChartProps\n>((_props, forwardedRef) => {\n const props: GroupedVerticalBarChartProps = {\n xAxisCategoryOrder: 'default',\n maxBarWidth: 24,\n ..._props,\n };\n const _tooltipId: string = useId('GVBCTooltipId_');\n const _emptyChartId: string = useId('_GVBC_empty');\n const _useRtl: boolean = useRtl();\n let _domainMargin: number = MIN_DOMAIN_MARGIN;\n let _xAxisLabels: string[] = [];\n let _datasetForBars: any[] = [];\n let _margins: Margins = { top: 0, right: 0, bottom: 0, left: 0 };\n let _groupedVerticalBarGraph: JSXElement[] = [];\n let _yMax: number = 0;\n let _calloutAnchorPoint: GVBarChartSeriesPoint | null = null;\n let _barWidth: number = 0;\n let _groupWidth: number = 0;\n let _xAxisInnerPadding: number = 0;\n let _xAxisOuterPadding: number = 0;\n let _legends: string[] = [];\n let _legendColorMap: Record<string, [string, string]> = {};\n const cartesianChartRef = React.useRef<Chart>(null);\n const Y_ORIGIN: number = 0;\n const _legendsRef = React.useRef<LegendContainer>(null);\n\n const [color, setColor] = React.useState<string>('');\n const [dataForHoverCard, setDataForHoverCard] = React.useState<number>(0);\n const [selectedLegends, setSelectedLegends] = React.useState<string[]>(props.legendProps?.selectedLegends || []);\n const [xCalloutValue, setXCalloutValue] = React.useState<string>('');\n const [yCalloutValue, setYCalloutValue] = React.useState<string>('');\n const [YValueHover, setYValueHover] = React.useState<YValueHover[]>([]);\n const [hoverXValue, setHoverXValue] = React.useState<string>('');\n const [calloutLegend, setCalloutLegend] = React.useState<string>('');\n const [activeLegend, setActiveLegend] = React.useState<string>('');\n const [callOutAccessibilityData, setCallOutAccessibilityData] = React.useState<AccessibilityProps | undefined>(\n undefined,\n );\n const [clickPosition, setClickPosition] = React.useState({ x: 0, y: 0 });\n const [isPopoverOpen, setPopoverOpen] = React.useState<boolean>(false);\n const classes = useGroupedVerticalBarChartStyles_unstable(props);\n\n React.useEffect(() => {\n if (!areArraysEqual(props.legendProps?.selectedLegends, selectedLegends)) {\n setSelectedLegends(props.legendProps?.selectedLegends || []);\n }\n }, [props.legendProps?.selectedLegends]);\n\n React.useImperativeHandle(\n props.componentRef,\n () => ({\n chartContainer: cartesianChartRef.current?.chartContainer ?? null,\n toImage: (opts?: ImageExportOptions): Promise<string> => {\n return toImage(cartesianChartRef.current?.chartContainer, _legendsRef.current?.toSVG, _useRtl, opts);\n },\n }),\n [],\n );\n\n const _adjustProps = () => {\n _barWidth = getBarWidth(props.barWidth, props.maxBarWidth);\n // x0_inner_padding = space_between_groups / (space_between_groups + group_width)\n // space_between_groups = 2 * bar_width\n // group_width = _legends.length * bar_width + (_legends.length - 1) * space_between_bars\n _xAxisInnerPadding = getScalePadding(\n props.xAxisInnerPadding,\n undefined,\n 2 / (2 + calcTotalBandUnits(_legends.length, X1_INNER_PADDING)),\n );\n _xAxisOuterPadding = getScalePadding(props.xAxisOuterPadding);\n };\n\n const _createDataset = (points: GroupedVerticalBarChartData[]) => {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const datasetForBars: any = [];\n\n points.forEach((point: GroupedVerticalBarChartData, index: number) => {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const singleDatasetPointForBars: any = {};\n const legendToBarPoint: Record<string, GVBarChartSeriesPoint> = {};\n\n point.series.forEach((seriesPoint: GVBarChartSeriesPoint) => {\n if (!singleDatasetPointForBars[seriesPoint.legend]) {\n singleDatasetPointForBars[seriesPoint.legend] = [{ ...seriesPoint }];\n legendToBarPoint[seriesPoint.legend] = { ...seriesPoint };\n } else {\n singleDatasetPointForBars[seriesPoint.legend].push({ ...seriesPoint });\n legendToBarPoint[seriesPoint.legend].data += seriesPoint.data;\n }\n });\n\n singleDatasetPointForBars.xAxisPoint = point.name;\n singleDatasetPointForBars.indexNum = index;\n singleDatasetPointForBars.groupSeries = Object.values(legendToBarPoint);\n singleDatasetPointForBars.stackCallOutAccessibilityData = point.stackCallOutAccessibilityData;\n datasetForBars.push(singleDatasetPointForBars);\n });\n return datasetForBars;\n };\n\n const _createDataSetOfGVBC = (points: GroupedVerticalBarChartData[]) => {\n const legends = new Set<string>();\n const xAxisLabels: string[] = _getOrderedXAxisLabels(points);\n points.forEach((point: GroupedVerticalBarChartData) => {\n point.series.forEach((seriesPoint: GVBarChartSeriesPoint) => {\n legends.add(seriesPoint.legend);\n });\n });\n const datasetForBars = _createDataset(points);\n return {\n legends: Array.from(legends),\n xAxisLabels,\n datasetForBars,\n };\n };\n\n const onLegendSelectionChange = (\n selectedLegends: string[],\n event: React.MouseEvent<HTMLButtonElement>,\n currentLegend?: Legend,\n ): void => {\n if (props.legendProps?.canSelectMultipleLegends) {\n setSelectedLegends(selectedLegends);\n } else {\n setSelectedLegends(selectedLegends.slice(-1));\n }\n if (props.legendProps?.onChange) {\n props.legendProps.onChange(selectedLegends, event, currentLegend);\n }\n };\n\n // eslint-disable-next-line @typescript-eslint/no-deprecated\n const _getLegendData = (points: GroupedVerticalBarChartData[]): JSXElement => {\n const actions: Legend[] = [];\n\n _legends.forEach((legendTitle: string) => {\n const legend: Legend = {\n title: legendTitle,\n color: _legendColorMap[legendTitle][0],\n hoverAction: () => {\n _handleChartMouseLeave();\n _onLegendHover(legendTitle);\n },\n onMouseOutAction: () => {\n _onLegendLeave();\n },\n };\n\n actions.push(legend);\n });\n return (\n <Legends\n legends={actions}\n enabledWrapLines={props.enabledLegendsWrapLines}\n overflowText={props.legendsOverflowText}\n {...props.legendProps}\n onChange={onLegendSelectionChange}\n legendRef={_legendsRef}\n />\n );\n };\n\n const _addDefaultColors = (data?: GroupedVerticalBarChartData[]): GroupedVerticalBarChartData[] => {\n _legendColorMap = {};\n let colorIndex = 0;\n\n return (\n data?.map(point => {\n return {\n ...point,\n series:\n point.series?.map(seriesPoint => {\n // TODO: Add support for gradient colors\n let startColor = seriesPoint.color ? seriesPoint.color : getNextColor(colorIndex, 0);\n let endColor = startColor;\n if (!_legendColorMap[seriesPoint.legend]) {\n _legendColorMap[seriesPoint.legend] = [startColor, endColor];\n }\n colorIndex += 1;\n\n return {\n ...seriesPoint,\n color: seriesPoint.color ?? _legendColorMap[seriesPoint.legend][0],\n };\n }) ?? [],\n };\n }) ?? []\n );\n };\n\n const _getOrderedXAxisLabels = (points: GroupedVerticalBarChartData[]) => {\n if (_xAxisType !== XAxisTypes.StringAxis) {\n return [];\n }\n\n return sortAxisCategories(_mapCategoryToValues(points), props.xAxisCategoryOrder);\n };\n\n const _mapCategoryToValues = (points: GroupedVerticalBarChartData[]) => {\n const categoryToValues: Record<string, number[]> = {};\n points.forEach(point => {\n if (!categoryToValues[point.name]) {\n categoryToValues[point.name] = [];\n }\n point.series.forEach(seriesPoint => {\n categoryToValues[point.name].push(seriesPoint.data);\n });\n });\n return categoryToValues;\n };\n\n const points = _addDefaultColors(props.data);\n const _xAxisType: XAxisTypes = getTypeOfAxis(points![0].name, true) as XAxisTypes;\n const { legends, xAxisLabels, datasetForBars } = _createDataSetOfGVBC(points!);\n _legends = legends;\n _xAxisLabels = xAxisLabels;\n _datasetForBars = datasetForBars;\n const legendBars: JSXElement = _getLegendData(points);\n _adjustProps();\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any -- Add commentMore actions\n function _getMinMaxOfYAxis(datasetForBars: any, yAxisType?: YAxisType, useSecondaryYScale?: boolean) {\n const values: number[] = [];\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n datasetForBars.forEach((data: any) => {\n data.groupSeries.forEach((point: GVBarChartSeriesPoint) => {\n if (!useSecondaryYScale === !point.useSecondaryYScale) {\n values.push(point.data);\n }\n });\n });\n\n return { startValue: d3Min(values)!, endValue: d3Max(values)! };\n }\n\n function _getDomainNRangeValues(\n points: GroupedVerticalBarChartData[],\n margins: Margins,\n width: number,\n chartType: ChartTypes,\n isRTL: boolean,\n xAxisType: XAxisTypes,\n barWidth: number,\n tickValues: Date[] | number[] | undefined,\n shiftX: number,\n ) {\n let domainNRangeValue: IDomainNRange;\n if (xAxisType === XAxisTypes.NumericAxis || xAxisType === XAxisTypes.DateAxis) {\n domainNRangeValue = { dStartValue: 0, dEndValue: 0, rStartValue: 0, rEndValue: 0 };\n } else {\n domainNRangeValue = domainRangeOfXStringAxis(margins, width, isRTL);\n }\n return domainNRangeValue;\n }\n\n // The maxOfYVal prop is only required for the primary y-axis, so yMax should be calculated\n // using only the data points associated with the primary y-axis.\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const yMax = _getMinMaxOfYAxis(_datasetForBars).endValue;\n _yMax = Math.max(yMax, props.yMaxValue || 0);\n\n const calloutProps: ChartPopoverProps = {\n clickPosition,\n isPopoverOpen,\n color,\n legend: calloutLegend,\n XValue: xCalloutValue,\n YValue: yCalloutValue ? yCalloutValue : dataForHoverCard,\n YValueHover,\n hoverXValue,\n culture: props.culture,\n isCartesian: true,\n ...props.calloutProps,\n ...getAccessibleDataObject(callOutAccessibilityData, 'text', false),\n };\n const tickParams = {\n tickValues: props.tickValues!,\n tickFormat: props.tickFormat!,\n };\n\n const _getGraphData = (\n xScale: StringAxis | NumericAxis,\n yScalePrimary: ScaleLinear<number, number>,\n containerHeight: number,\n containerWidth: number,\n xElement?: SVGElement | null,\n yAxisElement?: SVGElement | null,\n yScaleSecondary?: ScaleLinear<number, number>,\n ) => {\n const xScale0 = _createX0Scale(containerWidth);\n\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(\n props.barWidth,\n props.maxBarWidth,\n calcBandwidth(xScale0.bandwidth(), _legends.length, X1_INNER_PADDING),\n );\n _groupWidth = calcRequiredWidth(_barWidth, _legends.length, X1_INNER_PADDING);\n\n const xScale1 = _createX1Scale();\n const allGroupsBars: JSXElement[] = [];\n _datasetForBars.forEach((singleSet: GVSingleDataPoint) => {\n allGroupsBars.push(\n _buildGraph(singleSet, xScale0, xScale1, yScalePrimary, yScaleSecondary, containerHeight, xElement!),\n );\n });\n _groupedVerticalBarGraph = allGroupsBars;\n };\n\n const _getMargins = (margins: Margins) => {\n _margins = margins;\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 const onBarHover = (\n pointData: GVBarChartSeriesPoint,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n groupData: any,\n mouseEvent: React.MouseEvent<SVGElement>,\n ): void => {\n mouseEvent.persist();\n if (_calloutAnchorPoint !== pointData) {\n _calloutAnchorPoint = pointData;\n updatePosition(mouseEvent.clientX, mouseEvent.clientY);\n setPopoverOpen(_noLegendHighlighted() || _legendHighlighted(pointData.legend));\n setCalloutLegend(pointData.legend);\n setDataForHoverCard(pointData.data);\n setColor(pointData.color);\n setXCalloutValue(pointData.xAxisCalloutData!);\n setYCalloutValue(pointData.yAxisCalloutData!);\n setCallOutAccessibilityData(\n props.isCalloutForStack ? groupData.stackCallOutAccessibilityData : pointData.callOutAccessibilityData,\n );\n setYValueHover(groupData.groupSeries);\n setHoverXValue(pointData.xAxisCalloutData!);\n }\n };\n\n const _onBarLeave = (): void => {\n /**/\n };\n\n const _handleChartMouseLeave = (): void => {\n _calloutAnchorPoint = null;\n setPopoverOpen(false);\n };\n\n const onBarFocus = (\n event: React.FocusEvent<SVGRectElement, Element>,\n pointData: GVBarChartSeriesPoint,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n groupData: any,\n ): void => {\n let x = 0;\n let y = 0;\n\n const targetRect = (event.target as SVGRectElement).getBoundingClientRect();\n x = targetRect.left + targetRect.width / 2;\n y = targetRect.top + targetRect.height / 2;\n updatePosition(x, y);\n setPopoverOpen(_noLegendHighlighted() || _legendHighlighted(pointData.legend));\n setCalloutLegend(pointData.legend);\n setDataForHoverCard(pointData.data);\n setColor(pointData.color);\n setXCalloutValue(pointData.xAxisCalloutData!);\n setYCalloutValue(pointData.yAxisCalloutData!);\n setCallOutAccessibilityData(\n props.isCalloutForStack ? groupData.stackCallOutAccessibilityData : pointData.callOutAccessibilityData,\n );\n setYValueHover(groupData.groupSeries);\n setHoverXValue(pointData.xAxisCalloutData!);\n };\n\n const _buildGraph = (\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n singleSet: any,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n xScale0: any,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n xScale1: any,\n yScalePrimary: ScaleLinear<number, number>,\n yScaleSecondary: ScaleLinear<number, number> | undefined,\n containerHeight: number,\n xElement: SVGElement,\n // eslint-disable-next-line @typescript-eslint/no-deprecated\n ): JSXElement => {\n // eslint-disable-next-line @typescript-eslint/no-deprecated\n const singleGroup: JSXElement[] = [];\n // eslint-disable-next-line @typescript-eslint/no-deprecated\n const barLabelsForGroup: JSXElement[] = [];\n\n // Get the actual legends present at this x-axis point\n const presentLegends = Object.keys(singleSet).filter(key => key in _legendColorMap);\n const effectiveGroupWidth = calcRequiredWidth(_barWidth, presentLegends.length, X1_INNER_PADDING);\n\n // For stacked bars, center the single bar group in the available space\n // Instead of using the global legend position, use the local position within present legends\n const localScale = d3ScaleBand()\n .domain(presentLegends)\n .range(_useRtl ? [effectiveGroupWidth, 0] : [0, effectiveGroupWidth])\n .paddingInner(X1_INNER_PADDING);\n _legends.forEach((legendTitle: string, legendIndex: number) => {\n const barPoints = singleSet[legendTitle];\n if (barPoints) {\n const yBarScale = barPoints[0].useSecondaryYScale && yScaleSecondary ? yScaleSecondary : yScalePrimary;\n\n const xPoint = (localScale(legendTitle) ?? 0) + (localScale.bandwidth() - _barWidth) / 2;\n const isLegendActive = _legendHighlighted(legendTitle) || _noLegendHighlighted();\n const barOpacity = isLegendActive ? '' : '0.1';\n\n let barTotalValue = 0;\n const yBaseline = yBarScale(Y_ORIGIN);\n let yPositiveStart = yBaseline;\n let yNegativeStart = yBaseline;\n let yPoint = Y_ORIGIN;\n\n barPoints.forEach((pointData: GVBarChartSeriesPoint, pointIndex: number) => {\n if (!pointData.data) {\n // Not rendering data with 0.\n return;\n }\n const barGap = (VERTICAL_BAR_GAP / 2) * (pointIndex > 0 ? 2 : 0);\n const height = Math.max(yBarScale(Y_ORIGIN) - yBarScale(Math.abs(pointData.data)), MIN_BAR_HEIGHT);\n const pointColor = pointData.color; // Use the color of the current point\n\n if (pointData.data >= Y_ORIGIN) {\n yPositiveStart -= height + barGap;\n yPoint = yPositiveStart;\n } else {\n yPoint = yNegativeStart + barGap;\n yNegativeStart = yPoint + height;\n }\n\n singleGroup.push(\n <rect\n key={`${singleSet.indexNum}-${legendIndex}-${pointIndex}`}\n className={classes.opacityChangeOnHover}\n height={height}\n width={_barWidth}\n x={xPoint}\n y={yPoint}\n opacity={barOpacity}\n fill={pointColor}\n rx={props.roundCorners ? 3 : 0}\n onMouseOver={event => onBarHover(pointData, singleSet, event)}\n onMouseMove={event => onBarHover(pointData, singleSet, event)}\n onMouseOut={_onBarLeave}\n onFocus={event => onBarFocus(event, pointData, singleSet)}\n onBlur={_onBarLeave}\n onClick={pointData.onClick}\n aria-label={getAriaLabel(pointData, singleSet.xAxisPoint)}\n tabIndex={_legendHighlighted(pointData.legend) || _noLegendHighlighted() ? 0 : undefined}\n role=\"img\"\n />,\n );\n\n barTotalValue += pointData.data;\n });\n if (barTotalValue !== null && !props.hideLabels && Math.ceil(_barWidth) >= 16 && isLegendActive) {\n barLabelsForGroup.push(\n <text\n key={`${singleSet.indexNum}-${legendIndex}`}\n x={xPoint + _barWidth / 2}\n y={barTotalValue >= Y_ORIGIN ? yPositiveStart - 6 : yNegativeStart + 12}\n textAnchor=\"middle\"\n className={classes.barLabel}\n aria-hidden={true}\n style={{ direction: 'ltr', unicodeBidi: 'isolate' }}\n >\n {typeof props.yAxisTickFormat === 'function'\n ? props.yAxisTickFormat(barTotalValue)\n : formatScientificLimitWidth(barTotalValue)}\n </text>,\n );\n }\n }\n });\n // Used to display tooltip at x axis labels.\n if (!props.wrapXAxisLables && props.showXAxisLablesTooltip) {\n const xAxisElement = d3Select(xElement).call(xScale0);\n try {\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 axis: xAxisElement,\n };\n xAxisElement && tooltipOfAxislabels(tooltipProps);\n }\n return (\n <g\n key={singleSet.indexNum}\n transform={`translate(${xScale0(singleSet.xAxisPoint) + (xScale0.bandwidth() - effectiveGroupWidth) / 2}, 0)`}\n >\n {singleGroup}\n {barLabelsForGroup}\n </g>\n );\n };\n\n // For grouped vertical bar chart, First need to define total scale (from start to end)\n // From that need to define scale for single group of bars - done by createX1Scale\n const _createX0Scale = (containerWidth: number) => {\n const x0Axis = 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 return x0Axis;\n };\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const _createX1Scale = (): any => {\n return (\n d3ScaleBand()\n .domain(_legends)\n // When there is only one group, xScale0 adds padding around it,\n // causing the bandwidth to become smaller than the actual group width.\n // So to render bars in the group correctly, use groupWidth instead of the generated scale bandwidth.\n .range(_useRtl ? [_groupWidth, 0] : [0, _groupWidth])\n .paddingInner(X1_INNER_PADDING)\n );\n };\n\n const _onLegendHover = (legendTitle: string): void => {\n setActiveLegend(legendTitle);\n };\n\n const _onLegendLeave = (): void => {\n setActiveLegend('');\n };\n\n const _getAxisData = React.useCallback(\n (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 }\n },\n [props.yMaxValue],\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 const _legendHighlighted = (legendTitle: string) => {\n return _getHighlightedLegend().includes(legendTitle!);\n };\n\n /**\n * This function checks if none of the legends is selected or hovered.\n */\n const _noLegendHighlighted = () => {\n return _getHighlightedLegend().length === 0;\n };\n\n const _getHighlightedLegend = () => {\n return selectedLegends.length > 0 ? selectedLegends : activeLegend ? [activeLegend] : [];\n };\n\n const getAriaLabel = (point: GVBarChartSeriesPoint, xAxisPoint: string): string => {\n const xValue = point.xAxisCalloutData || xAxisPoint;\n const legend = point.legend;\n const yValue = point.yAxisCalloutData || point.data;\n return point.callOutAccessibilityData?.ariaLabel || `${xValue}. ${legend}, ${yValue}.`;\n };\n\n const _getDomainMargins = (containerWidth: number): Margins => {\n /** Total width available to render the bars */\n const totalWidth = calcTotalWidth(containerWidth, _margins, MIN_DOMAIN_MARGIN);\n\n if (_xAxisType === XAxisTypes.StringAxis) {\n if (isScalePaddingDefined(props.xAxisOuterPadding)) {\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 group and after the last group.\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 const groupWidth = calcRequiredWidth(_barWidth, _legends.length, X1_INNER_PADDING);\n /** Total width required to render the groups. Directly proportional to group width */\n const reqWidth = calcRequiredWidth(groupWidth, _xAxisLabels.length, _xAxisInnerPadding);\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 groups at their maximum allowable width\n const groupBandwidth = calcBandwidth(totalWidth, _xAxisLabels.length, _xAxisInnerPadding);\n const barBandwidth = calcBandwidth(groupBandwidth, _legends.length, X1_INNER_PADDING);\n const barWidth = getBarWidth(props.barWidth, props.maxBarWidth, barBandwidth);\n const groupWidth = calcRequiredWidth(barWidth, _legends.length, X1_INNER_PADDING);\n let reqWidth = calcRequiredWidth(groupWidth, _xAxisLabels.length, _xAxisInnerPadding);\n const margin1 = (totalWidth - reqWidth) / 2;\n\n let margin2 = Number.POSITIVE_INFINITY;\n if (!props.hideTickOverlap) {\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 margin2 = (totalWidth - reqWidth) / 2;\n }\n\n _domainMargin = MIN_DOMAIN_MARGIN + Math.max(0, Math.min(margin1, margin2));\n }\n }\n\n return {\n ..._margins,\n left: _margins.left! + _domainMargin,\n right: _margins.right! + _domainMargin,\n };\n };\n\n const _isChartEmpty = (): boolean => {\n return !(\n props.data &&\n props.data.length > 0 &&\n props.data.filter((item: GroupedVerticalBarChartData) => item.series.length).length > 0\n );\n };\n\n const _getChartTitle = (): string => {\n return (\n (props.chartTitle ? `${props.chartTitle}. ` : '') +\n `Vertical bar chart with ${_xAxisLabels.length} groups of ${_legends.length} bars each. `\n );\n };\n\n return !_isChartEmpty() ? (\n <CartesianChart\n {...props}\n chartTitle={_getChartTitle()}\n points={_datasetForBars}\n chartType={ChartTypes.GroupedVerticalBarChart}\n getDomainNRangeValues={_getDomainNRangeValues}\n getMinMaxOfYAxis={_getMinMaxOfYAxis}\n createStringYAxis={createStringYAxis}\n calloutProps={calloutProps}\n legendBars={legendBars}\n xAxisType={_xAxisType}\n createYAxis={createNumericYAxis}\n datasetForXAxisDomain={_xAxisLabels}\n tickParams={tickParams}\n tickPadding={props.tickPadding || 5}\n maxOfYVal={_yMax}\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 barwidth={_barWidth}\n componentRef={cartesianChartRef}\n /* eslint-disable react/jsx-no-bind */\n children={() => {\n return <g>{_groupedVerticalBarGraph}</g>;\n }}\n />\n ) : (\n <div id={_emptyChartId} role={'alert'} style={{ opacity: '0' }} aria-label={'Graph has no data to display'} />\n );\n});\nGroupedVerticalBarChart.displayName = 'GroupedVerticalBarChart';\n"],"names":["React","useGroupedVerticalBarChartStyles_unstable","select","d3Select","max","d3Max","min","d3Min","scaleBand","d3ScaleBand","useId","ChartTypes","getAccessibleDataObject","tooltipOfAxislabels","XAxisTypes","getTypeOfAxis","formatScientificLimitWidth","getScalePadding","getBarWidth","isScalePaddingDefined","createNumericYAxis","domainRangeOfXStringAxis","createStringYAxis","getNextColor","areArraysEqual","calculateLongestLabelWidth","useRtl","calcRequiredWidth","calcTotalWidth","calcBandwidth","calcTotalBandUnits","sortAxisCategories","CartesianChart","Legends","toImage","MIN_DOMAIN_MARGIN","X1_INNER_PADDING","VERTICAL_BAR_GAP","MIN_BAR_HEIGHT","GroupedVerticalBarChart","forwardRef","_props","forwardedRef","props","xAxisCategoryOrder","maxBarWidth","_tooltipId","_emptyChartId","_useRtl","_domainMargin","_xAxisLabels","_datasetForBars","_margins","top","right","bottom","left","_groupedVerticalBarGraph","_yMax","_calloutAnchorPoint","_barWidth","_groupWidth","_xAxisInnerPadding","_xAxisOuterPadding","_legends","_legendColorMap","cartesianChartRef","useRef","Y_ORIGIN","_legendsRef","color","setColor","useState","dataForHoverCard","setDataForHoverCard","selectedLegends","setSelectedLegends","legendProps","xCalloutValue","setXCalloutValue","yCalloutValue","setYCalloutValue","YValueHover","setYValueHover","hoverXValue","setHoverXValue","calloutLegend","setCalloutLegend","activeLegend","setActiveLegend","callOutAccessibilityData","setCallOutAccessibilityData","undefined","clickPosition","setClickPosition","x","y","isPopoverOpen","setPopoverOpen","classes","useEffect","useImperativeHandle","componentRef","chartContainer","current","opts","toSVG","_adjustProps","barWidth","xAxisInnerPadding","length","xAxisOuterPadding","_createDataset","points","datasetForBars","forEach","point","index","singleDatasetPointForBars","legendToBarPoint","series","seriesPoint","legend","push","data","xAxisPoint","name","indexNum","groupSeries","Object","values","stackCallOutAccessibilityData","_createDataSetOfGVBC","legends","Set","xAxisLabels","_getOrderedXAxisLabels","add","Array","from","onLegendSelectionChange","event","currentLegend","canSelectMultipleLegends","slice","onChange","_getLegendData","actions","legendTitle","title","hoverAction","_handleChartMouseLeave","_onLegendHover","onMouseOutAction","_onLegendLeave","enabledWrapLines","enabledLegendsWrapLines","overflowText","legendsOverflowText","legendRef","_addDefaultColors","colorIndex","map","startColor","endColor","_xAxisType","StringAxis","_mapCategoryToValues","categoryToValues","legendBars","_getMinMaxOfYAxis","yAxisType","useSecondaryYScale","startValue","endValue","_getDomainNRangeValues","margins","width","chartType","isRTL","xAxisType","tickValues","shiftX","domainNRangeValue","NumericAxis","DateAxis","dStartValue","dEndValue","rStartValue","rEndValue","yMax","Math","yMaxValue","calloutProps","XValue","YValue","culture","isCartesian","tickParams","tickFormat","_getGraphData","xScale","yScalePrimary","containerHeight","containerWidth","xElement","yAxisElement","yScaleSecondary","xScale0","_createX0Scale","bandwidth","xScale1","_createX1Scale","allGroupsBars","singleSet","_buildGraph","_getMargins","updatePosition","newX","newY","threshold","distance","sqrt","pow","onBarHover","pointData","groupData","mouseEvent","persist","clientX","clientY","_noLegendHighlighted","_legendHighlighted","xAxisCalloutData","yAxisCalloutData","isCalloutForStack","_onBarLeave","onBarFocus","targetRect","target","getBoundingClientRect","height","singleGroup","barLabelsForGroup","presentLegends","keys","filter","key","effectiveGroupWidth","localScale","domain","range","paddingInner","legendIndex","barPoints","yBarScale","xPoint","isLegendActive","barOpacity","barTotalValue","yBaseline","yPositiveStart","yNegativeStart","yPoint","pointIndex","barGap","abs","pointColor","rect","className","opacityChangeOnHover","opacity","fill","rx","roundCorners","onMouseOver","onMouseMove","onMouseOut","onFocus","onBlur","onClick","aria-label","getAriaLabel","tabIndex","role","hideLabels","ceil","text","textAnchor","barLabel","aria-hidden","style","direction","unicodeBidi","yAxisTickFormat","wrapXAxisLables","showXAxisLablesTooltip","xAxisElement","call","document","getElementById","remove","e","tooltipProps","tooltipCls","tooltip","id","axis","g","transform","x0Axis","paddingOuter","_getAxisData","useCallback","yAxisData","yAxisDomainValues","domainValue","_getHighlightedLegend","includes","xValue","yValue","ariaLabel","_getDomainMargins","totalWidth","groupWidth","reqWidth","mode","groupBandwidth","barBandwidth","margin1","margin2","Number","POSITIVE_INFINITY","hideTickOverlap","step","_isChartEmpty","item","_getChartTitle","chartTitle","getDomainNRangeValues","getMinMaxOfYAxis","createYAxis","datasetForXAxisDomain","tickPadding","maxOfYVal","getmargins","getGraphData","getAxisData","onChartMouseLeave","getDomainMargins","barwidth","children","div","displayName"],"mappings":"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"}