@fluentui/react-charts 9.1.7 → 9.1.8

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 (53) hide show
  1. package/CHANGELOG.md +12 -2
  2. package/dist/index.d.ts +60 -3
  3. package/lib/components/AreaChart/AreaChart.js +21 -1
  4. package/lib/components/AreaChart/AreaChart.js.map +1 -1
  5. package/lib/components/CommonComponents/CartesianChart.js +8 -9
  6. package/lib/components/CommonComponents/CartesianChart.js.map +1 -1
  7. package/lib/components/CommonComponents/CartesianChart.types.js.map +1 -1
  8. package/lib/components/GroupedVerticalBarChart/GroupedVerticalBarChart.js +18 -1
  9. package/lib/components/GroupedVerticalBarChart/GroupedVerticalBarChart.js.map +1 -1
  10. package/lib/components/HeatMapChart/HeatMapChart.js +25 -1
  11. package/lib/components/HeatMapChart/HeatMapChart.js.map +1 -1
  12. package/lib/components/HorizontalBarChart/HorizontalBarChart.js +1 -2
  13. package/lib/components/HorizontalBarChart/HorizontalBarChart.js.map +1 -1
  14. package/lib/components/HorizontalBarChartWithAxis/HorizontalBarChartWithAxis.js +4 -1
  15. package/lib/components/HorizontalBarChartWithAxis/HorizontalBarChartWithAxis.js.map +1 -1
  16. package/lib/components/LineChart/LineChart.js +22 -2
  17. package/lib/components/LineChart/LineChart.js.map +1 -1
  18. package/lib/components/ScatterChart/ScatterChart.js +26 -1
  19. package/lib/components/ScatterChart/ScatterChart.js.map +1 -1
  20. package/lib/components/VerticalBarChart/VerticalBarChart.js +16 -1
  21. package/lib/components/VerticalBarChart/VerticalBarChart.js.map +1 -1
  22. package/lib/components/VerticalStackedBarChart/VerticalStackedBarChart.js +15 -1
  23. package/lib/components/VerticalStackedBarChart/VerticalStackedBarChart.js.map +1 -1
  24. package/lib/utilities/FocusableTooltipText.js +1 -2
  25. package/lib/utilities/FocusableTooltipText.js.map +1 -1
  26. package/lib/utilities/utilities.js +6 -144
  27. package/lib/utilities/utilities.js.map +1 -1
  28. package/lib-commonjs/components/AreaChart/AreaChart.js +20 -0
  29. package/lib-commonjs/components/AreaChart/AreaChart.js.map +1 -1
  30. package/lib-commonjs/components/CommonComponents/CartesianChart.js +7 -7
  31. package/lib-commonjs/components/CommonComponents/CartesianChart.js.map +1 -1
  32. package/lib-commonjs/components/CommonComponents/CartesianChart.types.js.map +1 -1
  33. package/lib-commonjs/components/GroupedVerticalBarChart/GroupedVerticalBarChart.js +17 -0
  34. package/lib-commonjs/components/GroupedVerticalBarChart/GroupedVerticalBarChart.js.map +1 -1
  35. package/lib-commonjs/components/HeatMapChart/HeatMapChart.js +24 -0
  36. package/lib-commonjs/components/HeatMapChart/HeatMapChart.js.map +1 -1
  37. package/lib-commonjs/components/HorizontalBarChart/HorizontalBarChart.js +1 -2
  38. package/lib-commonjs/components/HorizontalBarChart/HorizontalBarChart.js.map +1 -1
  39. package/lib-commonjs/components/HorizontalBarChartWithAxis/HorizontalBarChartWithAxis.js +3 -0
  40. package/lib-commonjs/components/HorizontalBarChartWithAxis/HorizontalBarChartWithAxis.js.map +1 -1
  41. package/lib-commonjs/components/LineChart/LineChart.js +21 -1
  42. package/lib-commonjs/components/LineChart/LineChart.js.map +1 -1
  43. package/lib-commonjs/components/ScatterChart/ScatterChart.js +25 -0
  44. package/lib-commonjs/components/ScatterChart/ScatterChart.js.map +1 -1
  45. package/lib-commonjs/components/VerticalBarChart/VerticalBarChart.js +15 -0
  46. package/lib-commonjs/components/VerticalBarChart/VerticalBarChart.js.map +1 -1
  47. package/lib-commonjs/components/VerticalStackedBarChart/VerticalStackedBarChart.js +14 -0
  48. package/lib-commonjs/components/VerticalStackedBarChart/VerticalStackedBarChart.js.map +1 -1
  49. package/lib-commonjs/utilities/FocusableTooltipText.js +1 -2
  50. package/lib-commonjs/utilities/FocusableTooltipText.js.map +1 -1
  51. package/lib-commonjs/utilities/utilities.js +11 -132
  52. package/lib-commonjs/utilities/utilities.js.map +1 -1
  53. package/package.json +2 -2
@@ -1 +1 @@
1
- {"version":3,"sources":["VerticalStackedBarChart.tsx"],"sourcesContent":["import * as React from 'react';\nimport { max as d3Max, min as d3Min } from 'd3-array';\nimport { Axis as D3Axis } from 'd3-axis';\nimport { select as d3Select } from 'd3-selection';\nimport { useVerticalStackedBarChartStyles } from './useVerticalStackedBarChartStyles.styles';\nimport {\n scaleLinear as d3ScaleLinear,\n ScaleLinear as D3ScaleLinear,\n scaleBand as d3ScaleBand,\n scaleUtc as d3ScaleUtc,\n scaleTime as d3ScaleTime,\n} from 'd3-scale';\nimport { useId } from '@fluentui/react-utilities';\nimport { tokens } from '@fluentui/react-theme';\nimport {\n AccessibilityProps,\n CartesianChart,\n ChildProps,\n VerticalStackedBarDataPoint,\n Margins,\n VerticalStackedBarChartProps,\n VerticalStackedChartProps,\n VSChartDataPoint,\n LineDataInVerticalStackedBarChart,\n ModifiedCartesianChartProps,\n Legend,\n ChartPopover,\n Legends,\n Chart,\n DataPoint,\n} from '../../index';\nimport {\n ChartTypes,\n IAxisData,\n getAccessibleDataObject,\n XAxisTypes,\n getTypeOfAxis,\n tooltipOfAxislabels,\n formatScientificLimitWidth,\n getBarWidth,\n getScalePadding,\n isScalePaddingDefined,\n calculateAppropriateBarWidth,\n formatDate,\n areArraysEqual,\n calculateLongestLabelWidth,\n useRtl,\n DataVizPalette,\n getColorFromToken,\n findVSBCNumericMinMaxOfY,\n YAxisType,\n} from '../../utilities/index';\n\ntype NumericAxis = D3Axis<number | { valueOf(): number }>;\ntype NumericScale = D3ScaleLinear<number, number>;\nconst barGapMultiplier = 0.2;\nconst barGapMin = 1;\nconst MIN_DOMAIN_MARGIN = 8;\n\ninterface RefArrayData {\n refElement?: SVGGElement | null;\n}\n\ntype LinePoint = LineDataInVerticalStackedBarChart & { index: number; xItem: VerticalStackedChartProps };\ntype LineObject = { [key: string]: LinePoint[] };\ntype LineLegends = {\n title: string;\n color: string;\n};\nenum CircleVisbility {\n show = 'visibility',\n hide = 'hidden',\n}\ntype CalloutAnchorPointData = {\n xAxisDataPoint: string;\n chartDataPoint: VSChartDataPoint;\n};\n\nexport const VerticalStackedBarChart: React.FunctionComponent<VerticalStackedBarChartProps> = props => {\n const _isRtl: boolean = useRtl();\n const _createLegendsForLine: (data: VerticalStackedChartProps[]) => LineLegends[] = (\n data: VerticalStackedChartProps[],\n ) => _getLineLegends(data);\n const _tooltipId: string = useId('VSBCTooltipId_');\n const _emptyChartId: string = useId('_VSBC_empty');\n let _points: VerticalStackedChartProps[] = [];\n let _dataset: VerticalStackedBarDataPoint[];\n let _xAxisLabels: string[] = [];\n let _bars: JSX.Element[];\n let _xAxisType: XAxisTypes =\n props.data! && props.data!.length > 0\n ? (getTypeOfAxis(props.data[0]!.xAxisPoint, true) as XAxisTypes)\n : XAxisTypes.StringAxis;\n let _barWidth: number = 0;\n let _colors: string[];\n let _margins: Margins;\n let _lineObject: LineObject;\n let _yMax: number;\n let _yMin: number;\n let _calloutAnchorPoint: CalloutAnchorPointData | null;\n let _domainMargin: number = MIN_DOMAIN_MARGIN;\n let _xAxisInnerPadding: number = 0;\n let _xAxisOuterPadding: number = 0;\n const cartesianChartRef = React.useRef<Chart>(null);\n const Y_ORIGIN: number = 0;\n\n const [selectedLegends, setSelectedLegends] = React.useState(props.legendProps?.selectedLegends || []);\n const [activeLegend, setActiveLegend] = React.useState<string | undefined>(undefined);\n const [dataForHoverCard, setDataForHoverCard] = React.useState(0);\n const [color, setColor] = React.useState('');\n const [hoverXValue, setHoverXValue] = React.useState<string | number>('');\n const [YValueHover, setYValueHover] = React.useState<(LineDataInVerticalStackedBarChart | VSChartDataPoint)[]>([]);\n const [xCalloutValue, setXCalloutValue] = React.useState('');\n const [yCalloutValue, setYCalloutValue] = React.useState('');\n const [activeXAxisDataPoint, setActiveXAxisDataPoint] = React.useState<number | string | Date>('');\n const [calloutLegend, setCalloutLegend] = React.useState('');\n const [stackCalloutProps, setStackCalloutProps] = React.useState<VerticalStackedChartProps>();\n const [dataPointCalloutProps, setDataPointCalloutProps] = React.useState<VSChartDataPoint>();\n const [callOutAccessibilityData, setCallOutAccessibilityData] = React.useState<AccessibilityProps>();\n const [clickPosition, setClickPosition] = React.useState({ x: 0, y: 0 });\n const [isPopoverOpen, setPopoverOpen] = React.useState(false);\n const prevPropsRef = React.useRef<VerticalStackedBarChartProps | null>(null);\n React.useEffect(() => {\n if (prevPropsRef.current) {\n const prevProps = prevPropsRef.current;\n if (!areArraysEqual(prevProps.legendProps?.selectedLegends, props.legendProps?.selectedLegends)) {\n setSelectedLegends(props.legendProps?.selectedLegends || []);\n }\n if (prevProps.height !== props.height || prevProps.width !== props.width || prevProps.data !== props.data) {\n _adjustProps();\n _dataset = _createDataSetLayer();\n }\n }\n prevPropsRef.current = props;\n }, [props]);\n\n React.useImperativeHandle(\n props.componentRef,\n () => ({\n chartContainer: cartesianChartRef.current?.chartContainer ?? null,\n }),\n [],\n );\n\n function _getLegendData(data: VerticalStackedChartProps[], lineLegends: LineLegends[]): JSX.Element {\n if (props.hideLegend) {\n return <></>;\n }\n const defaultPalette: string[] = [\n getColorFromToken(DataVizPalette.color6),\n getColorFromToken(DataVizPalette.color1),\n getColorFromToken(DataVizPalette.color5),\n getColorFromToken(DataVizPalette.color7),\n getColorFromToken(DataVizPalette.color10),\n ];\n const actions: Legend[] = [];\n const { allowHoverOnLegend = true } = props;\n\n data.forEach((singleChartData: VerticalStackedChartProps) => {\n singleChartData.chartData.forEach((point: VSChartDataPoint) => {\n const color: string = point.color ? point.color : defaultPalette[Math.floor(Math.random() * 4 + 1)];\n const checkSimilarLegends = actions.filter((leg: Legend) => leg.title === point.legend && leg.color === color);\n if (checkSimilarLegends!.length > 0) {\n return;\n }\n\n const legend: Legend = {\n title: point.legend,\n color,\n hoverAction: allowHoverOnLegend\n ? () => {\n _handleChartMouseLeave();\n _onLegendHover(point.legend);\n }\n : undefined,\n onMouseOutAction: allowHoverOnLegend ? () => _onLegendLeave() : undefined,\n };\n\n actions.push(legend);\n });\n });\n const legendsOfLine: Legend[] = [];\n if (lineLegends && lineLegends.length > 0) {\n lineLegends.forEach((point: LineLegends) => {\n const legend: Legend = {\n title: point.title,\n color: point.color,\n isLineLegendInBarChart: true,\n hoverAction: allowHoverOnLegend\n ? () => {\n _handleChartMouseLeave();\n _onLegendHover(point.title);\n }\n : undefined,\n onMouseOutAction: allowHoverOnLegend ? () => _onLegendLeave() : undefined,\n };\n legendsOfLine.push(legend);\n });\n }\n const totalLegends: Legend[] = legendsOfLine.concat(actions);\n return (\n <Legends\n legends={totalLegends}\n enabledWrapLines={props.enabledLegendsWrapLines}\n overflowText={props.legendsOverflowText}\n {...props.legendProps}\n onChange={_onLegendSelectionChange}\n />\n );\n }\n\n function _getHighlightedLegend() {\n return selectedLegends.length > 0 ? selectedLegends : activeLegend ? [activeLegend] : [];\n }\n\n function _lineHoverOut() {\n setPopoverOpen(false);\n setXCalloutValue('');\n setYCalloutValue('');\n setActiveXAxisDataPoint('');\n setColor('');\n }\n\n function _lineHoverFocus(lineData: LinePoint) {\n setPopoverOpen(true);\n setXCalloutValue(`${lineData.xItem.xAxisPoint}`);\n setYCalloutValue(`${lineData.yAxisCalloutData || lineData.data || lineData.y}`);\n setActiveXAxisDataPoint(lineData.xItem.xAxisPoint);\n setColor(lineData.color);\n }\n\n function _onStackHoverFocus(\n stack: VerticalStackedChartProps,\n mouseEvent: React.MouseEvent<SVGElement> | SVGGElement,\n ): void {\n let clientX = 0;\n let clientY = 0;\n if ('clientX' in mouseEvent) {\n clientX = mouseEvent.clientX;\n clientY = mouseEvent.clientY;\n } else {\n // Handle case where mouseEvent is an SVGGElement\n const boundingRect = mouseEvent.getBoundingClientRect();\n clientX = boundingRect.left + boundingRect.width / 2;\n clientY = boundingRect.top + boundingRect.height / 2;\n }\n if (!_noLegendHighlighted()) {\n stack = {\n ...stack,\n chartData: stack.chartData.filter((dataPoint: { legend: any }) => _isLegendHighlighted(dataPoint.legend)),\n lineData: stack.lineData?.filter((dataPoint: { legend: any }) => _isLegendHighlighted(dataPoint.legend)),\n };\n }\n const lineData = stack.lineData;\n const isLinesPresent: boolean = lineData !== undefined && lineData.length > 0;\n if (isLinesPresent) {\n lineData!.forEach((item: LineDataInVerticalStackedBarChart & { shouldDrawBorderBottom?: boolean }) => {\n item.data = item.data || item.y;\n item.shouldDrawBorderBottom = true;\n });\n }\n _updatePosition(clientX, clientY);\n setPopoverOpen(stack.chartData.length > 0 || (stack.lineData?.length ?? 0) > 0);\n setYValueHover(\n isLinesPresent\n ? [...lineData!.sort((a, b) => (a.data! < b.data! ? 1 : -1)), ...stack.chartData.slice().reverse()]\n : stack.chartData.slice().reverse(),\n );\n setHoverXValue(stack.xAxisPoint instanceof Date ? formatDate(stack.xAxisPoint, props.useUTC) : stack.xAxisPoint);\n setStackCalloutProps(stack);\n setActiveXAxisDataPoint(stack.xAxisPoint);\n setCallOutAccessibilityData(stack.stackCallOutAccessibilityData);\n }\n\n function _handleChartMouseLeave(): void {\n _calloutAnchorPoint = null;\n setPopoverOpen(false);\n setActiveXAxisDataPoint('');\n }\n\n const _onClick = (\n data: VerticalStackedChartProps | VSChartDataPoint,\n mouseEvent: React.MouseEvent<SVGElement>,\n ): void => {\n props.onBarClick?.(mouseEvent, data);\n props.href ? (window.location.href = props.href) : '';\n };\n\n function _adjustProps(): void {\n _points = props.data || [];\n _barWidth = getBarWidth(props.barWidth, props.maxBarWidth);\n const defaultColors: string[] = [\n getColorFromToken(DataVizPalette.color6),\n getColorFromToken(DataVizPalette.color1),\n getColorFromToken(DataVizPalette.color5),\n getColorFromToken(DataVizPalette.color7),\n getColorFromToken(DataVizPalette.color10),\n ];\n _colors = defaultColors;\n _xAxisType = getTypeOfAxis(props.data[0].xAxisPoint, true) as XAxisTypes;\n _lineObject = _getFormattedLineData(props.data);\n _xAxisInnerPadding = getScalePadding(props.xAxisInnerPadding, props.xAxisPadding, 2 / 3);\n _xAxisOuterPadding = getScalePadding(props.xAxisOuterPadding, props.xAxisPadding, 0);\n }\n\n function _createDataSetLayer(): VerticalStackedBarDataPoint[] {\n const tempArr: string[] = [];\n const dataset: VerticalStackedBarDataPoint[] = _points.map(singlePointData => {\n let total: number = 0;\n singlePointData.chartData!.forEach((point: VSChartDataPoint) => {\n total = total + point.data;\n });\n tempArr.push(singlePointData.xAxisPoint as string);\n return {\n x: singlePointData.xAxisPoint,\n y: total,\n };\n });\n _xAxisLabels = tempArr;\n return dataset;\n }\n\n function _onLegendHover(legendTitle: string): void {\n setActiveLegend(legendTitle);\n }\n\n function _onLegendLeave(): void {\n setActiveLegend(undefined);\n }\n\n function _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 function _getMargins(margins: Margins) {\n _margins = margins;\n }\n\n function _getGraphData(\n xScale: any,\n yScale: NumericAxis,\n containerHeight: number,\n containerWidth: number,\n xElement: SVGElement | null,\n ) {\n const { xBarScale, yBarScale } = _getScales(containerHeight, containerWidth);\n return (_bars = _createBar(xBarScale, yBarScale, containerHeight, xElement!));\n }\n\n function _getAxisData(yAxisData: IAxisData) {\n if (yAxisData && yAxisData.yAxisDomainValues.length) {\n const { yAxisDomainValues: domainValue } = yAxisData;\n _yMax = Math.max(domainValue[domainValue.length - 1], props.yMaxValue || Y_ORIGIN);\n _yMin = Math.min(domainValue[0], props.yMinValue || Y_ORIGIN);\n }\n }\n\n /**\n * This function checks if the given legend is highlighted or not.\n * A legend can be highlighted in 2 ways:\n * 1. selection: if the user clicks on it\n * 2. hovering: if there is no selected legend and the user hovers over it\n */\n function _isLegendHighlighted(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 function _noLegendHighlighted() {\n return _getHighlightedLegend().length === 0;\n }\n\n function _getAriaLabel(singleChartData: VerticalStackedChartProps, point?: VSChartDataPoint): string {\n if (!point) {\n /** if shouldFocusWholeStack is true */\n const xValue =\n singleChartData.xAxisCalloutData ||\n (singleChartData.xAxisPoint instanceof Date\n ? formatDate(singleChartData.xAxisPoint)\n : singleChartData.xAxisPoint);\n const pointValues = singleChartData.chartData\n .map(pt => {\n const legend = pt.legend;\n const yValue = pt.yAxisCalloutData || pt.data;\n return `${legend}, ${yValue}.`;\n })\n .join(' ');\n const lineValues = singleChartData.lineData\n ?.map(ln => {\n const legend = ln.legend;\n const yValue = ln.yAxisCalloutData || ln.data || ln.y;\n return `${legend}, ${yValue}.`;\n })\n .join(' ');\n return (\n singleChartData.stackCallOutAccessibilityData?.ariaLabel ||\n `${xValue}. ${pointValues}` + (lineValues ? ` ${lineValues}` : '')\n );\n }\n /** if shouldFocusWholeStack is false */\n const xValue =\n singleChartData.xAxisCalloutData ||\n point.xAxisCalloutData ||\n (singleChartData.xAxisPoint instanceof Date\n ? formatDate(singleChartData.xAxisPoint)\n : singleChartData.xAxisPoint);\n const legend = point.legend;\n const yValue = point.yAxisCalloutData || point.data;\n return point.callOutAccessibilityData?.ariaLabel || `${xValue}. ${legend}, ${yValue}.`;\n }\n\n function _getCustomizedCallout() {\n const _isHavingLines = props.data.some(\n (item: VerticalStackedChartProps) => item.lineData && item.lineData.length > 0,\n );\n return props.onRenderCalloutPerStack\n ? props.onRenderCalloutPerStack(stackCalloutProps)\n : props.onRenderCalloutPerDataPoint && !_isHavingLines\n ? props.onRenderCalloutPerDataPoint(dataPointCalloutProps, _renderCallout)\n : null;\n }\n\n function _toFocusWholeStack(_isHavingLines: boolean): boolean {\n const { isCalloutForStack = false } = props;\n let shouldFocusStackOnly: boolean = false;\n if (_isHavingLines) {\n if (_getHighlightedLegend().length === 1) {\n shouldFocusStackOnly = false;\n } else {\n shouldFocusStackOnly = true;\n }\n } else {\n shouldFocusStackOnly = isCalloutForStack;\n }\n return shouldFocusStackOnly;\n }\n\n function _getFormattedLineData(data: VerticalStackedChartProps[]): LineObject {\n const linesData: LinePoint[] = [];\n const formattedLineData: LineObject = {};\n data.forEach((item: VerticalStackedChartProps, index: number) => {\n if (item.lineData) {\n item.lineData.forEach((line: any) => {\n linesData.push({\n ...line,\n index,\n xItem: item,\n });\n });\n }\n });\n linesData.forEach(item => {\n if (formattedLineData[item.legend]) {\n formattedLineData[item.legend].push(item);\n } else {\n formattedLineData[item.legend] = [item];\n }\n });\n return formattedLineData;\n }\n\n function _getLineLegends(data: VerticalStackedChartProps[]): LineLegends[] {\n const lineObject: LineObject = _lineObject;\n const lineLegends: LineLegends[] = [];\n Object.keys(lineObject).forEach((item: string) => {\n lineLegends.push({\n title: item,\n color: lineObject[item][0].color,\n });\n });\n return lineLegends;\n }\n\n function _createLines(\n xScale: any,\n yScalePrimary: NumericScale,\n containerHeight: number,\n containerWidth: number,\n yScaleSecondary?: NumericScale,\n ): JSX.Element {\n const lineObject: LineObject = _getFormattedLineData(props.data);\n const lines: React.ReactNode[] = [];\n const borderForLines: React.ReactNode[] = [];\n const dots: React.ReactNode[] = [];\n //const { theme } = props;\n const lineBorderWidth = props.lineOptions?.lineBorderWidth\n ? Number.parseFloat(props.lineOptions!.lineBorderWidth!.toString())\n : 0;\n const xScaleBandwidthTranslate = _xAxisType !== XAxisTypes.StringAxis ? 0 : xScale.bandwidth() / 2;\n Object.keys(lineObject).forEach((item: string, index: number) => {\n const shouldHighlight = _isLegendHighlighted(item) || _noLegendHighlighted();\n for (let i = 1; i < lineObject[item].length; i++) {\n const x1 = xScale(lineObject[item][i - 1].xItem.xAxisPoint);\n const useSecondaryYScale =\n lineObject[item][i - 1].useSecondaryYScale && lineObject[item][i].useSecondaryYScale && yScaleSecondary;\n const y1 = useSecondaryYScale\n ? yScaleSecondary!(lineObject[item][i - 1].y)\n : yScalePrimary(lineObject[item][i - 1].y);\n const x2 = xScale(lineObject[item][i].xItem.xAxisPoint);\n const y2 = useSecondaryYScale ? yScaleSecondary!(lineObject[item][i].y) : yScalePrimary(lineObject[item][i].y);\n if (lineBorderWidth > 0) {\n borderForLines.push(\n <line\n key={`${index}-${i}-BorderLine`}\n x1={x1}\n y1={y1}\n x2={x2}\n y2={y2}\n opacity={shouldHighlight ? 1 : 0.1}\n strokeWidth={3 + lineBorderWidth * 2}\n fill=\"transparent\"\n strokeLinecap=\"round\"\n stroke={tokens.colorNeutralBackground1}\n transform={`translate(${xScaleBandwidthTranslate}, 0)`}\n />,\n );\n }\n lines.push(\n <line\n key={`${index}-${i}-line`}\n x1={x1}\n y1={y1}\n x2={x2}\n y2={y2}\n opacity={shouldHighlight ? 1 : 0.1}\n strokeWidth={lineObject[item][0].lineOptions?.strokeWidth ?? 3}\n strokeLinecap={lineObject[item][0].lineOptions?.strokeLinecap ?? 'round'}\n strokeDasharray={lineObject[item][0].lineOptions?.strokeDasharray}\n stroke={lineObject[item][i].color}\n transform={`translate(${xScaleBandwidthTranslate}, 0)`}\n {...(_isLegendHighlighted(item) && {\n onMouseOver: _lineHover.bind(lineObject[item][i - 1]),\n onMouseLeave: _lineHoverOut,\n })}\n />,\n );\n }\n });\n Object.keys(lineObject).forEach((item: string, index: number) => {\n lineObject[item].forEach((circlePoint: LinePoint, subIndex: number) => {\n const circleRef: { refElement: SVGCircleElement | null } = { refElement: null };\n const noBarsAndLinesActive =\n circlePoint.xItem.chartData.filter(\n dataPoint => _noLegendHighlighted() || _isLegendHighlighted(dataPoint.legend),\n ).length === 0;\n dots.push(\n <circle\n key={`${index}-${subIndex}-dot`}\n cx={xScale(circlePoint.xItem.xAxisPoint)}\n cy={\n circlePoint.useSecondaryYScale && yScaleSecondary\n ? yScaleSecondary(circlePoint.y)\n : yScalePrimary(circlePoint.y)\n }\n onMouseOver={\n _isLegendHighlighted(item)\n ? (event: React.MouseEvent<SVGElement, MouseEvent>) => _lineHover(circlePoint, event)\n : (event: React.MouseEvent<SVGElement, MouseEvent>) => _onStackHover(circlePoint.xItem, event)\n }\n {...(_isLegendHighlighted(item) && {\n onMouseLeave: _lineHoverOut,\n })}\n r={_getCircleVisibilityAndRadius(circlePoint.xItem.xAxisPoint, circlePoint.legend).radius}\n stroke={circlePoint.color}\n fill={tokens.colorNeutralBackground1}\n strokeWidth={3}\n visibility={_getCircleVisibilityAndRadius(circlePoint.xItem.xAxisPoint, circlePoint.legend).visibility}\n transform={`translate(${xScaleBandwidthTranslate}, 0)`}\n ref={e => (circleRef.refElement = e)}\n {...(noBarsAndLinesActive\n ? {\n tabIndex: !props.hideTooltip ? 0 : undefined,\n onFocus: event => _lineFocus(event, circlePoint, circleRef),\n onBlur: _handleMouseOut,\n role: 'img',\n 'aria-label': _getAriaLabel(circlePoint.xItem, circlePoint as VSChartDataPoint),\n }\n : {})}\n />,\n );\n });\n });\n return (\n <>\n {borderForLines}\n {lines}\n {dots}\n </>\n );\n }\n\n function _getCircleVisibilityAndRadius(\n xAxisPoint: string | number | Date,\n legend: string,\n ): { visibility: CircleVisbility; radius: number } {\n if (!_noLegendHighlighted()) {\n if (xAxisPoint === activeXAxisDataPoint && _isLegendHighlighted(legend)) {\n return { visibility: CircleVisbility.show, radius: 8 };\n } else if (_isLegendHighlighted(legend)) {\n return { visibility: CircleVisbility.show, radius: 0.3 };\n } else {\n return { visibility: CircleVisbility.hide, radius: 0 };\n }\n } else {\n return {\n visibility: activeXAxisDataPoint === xAxisPoint ? CircleVisbility.show : CircleVisbility.hide,\n radius: 8,\n };\n }\n }\n\n function _renderCallout(props?: VSChartDataPoint): JSX.Element | null {\n return props ? (\n <ChartPopover\n culture={props.culture ?? 'en-us'}\n XValue={props.xAxisCalloutData}\n xCalloutValue={xCalloutValue}\n yCalloutValue={yCalloutValue}\n clickPosition={clickPosition}\n isPopoverOpen={isPopoverOpen}\n legend={props.legend}\n YValue={props.yAxisCalloutData}\n color={props.color}\n />\n ) : null;\n }\n\n function _onRectHover(\n xAxisPoint: string | number | Date,\n point: VSChartDataPoint,\n color: string,\n mouseEvent: React.MouseEvent<SVGElement>,\n ): void {\n mouseEvent.persist();\n _onRectFocusHover(xAxisPoint, point, color, mouseEvent);\n }\n\n function _onRectFocusHover(\n xAxisPoint: string | number | Date,\n point: VSChartDataPoint,\n color: string,\n mouseEvent: React.MouseEvent<SVGElement> | SVGGElement,\n ) {\n let clientX = 0;\n let clientY = 0;\n if ('clientX' in mouseEvent) {\n clientX = mouseEvent.clientX;\n clientY = mouseEvent.clientY;\n } else {\n // Handle case where mouseEvent is an SVGGElement\n const boundingRect = mouseEvent.getBoundingClientRect();\n clientX = boundingRect.left + boundingRect.width / 2;\n clientY = boundingRect.top + boundingRect.height / 2;\n }\n if (_calloutAnchorPoint?.chartDataPoint !== point || _calloutAnchorPoint?.xAxisDataPoint !== xAxisPoint) {\n _calloutAnchorPoint = {\n chartDataPoint: point,\n xAxisDataPoint: `${xAxisPoint}`,\n };\n _updatePosition(clientX, clientY);\n setPopoverOpen(_noLegendHighlighted() || _isLegendHighlighted(point.legend));\n setCalloutLegend(point.legend);\n setDataForHoverCard(point.data);\n setColor(color);\n setXCalloutValue(point.xAxisCalloutData ? point.xAxisCalloutData : `${xAxisPoint}`);\n setYCalloutValue(point.yAxisCalloutData!);\n setDataPointCalloutProps(point);\n setCallOutAccessibilityData(point.callOutAccessibilityData);\n }\n }\n\n function _lineHover(lineData: LinePoint, mouseEvent: React.MouseEvent<SVGElement>) {\n mouseEvent.persist();\n _lineHoverFocus(lineData);\n }\n\n function _lineFocus(\n event: React.FocusEvent<SVGCircleElement, Element>,\n lineData: LinePoint,\n ref: { refElement: SVGCircleElement | null },\n ) {\n if (ref.refElement) {\n _lineHoverFocus(lineData);\n }\n }\n\n function _onStackHover(stack: VerticalStackedChartProps, mouseEvent: React.MouseEvent<SVGElement>): void {\n mouseEvent.persist();\n _onStackHoverFocus(stack, mouseEvent);\n }\n\n function _onRectFocus(point: VSChartDataPoint, xAxisPoint: string, color: string, ref: RefArrayData): void {\n if (ref.refElement) {\n _onRectFocusHover(xAxisPoint, point, color, ref.refElement);\n }\n }\n\n function _onStackFocus(stack: VerticalStackedChartProps, groupRef: RefArrayData): void {\n if (groupRef.refElement) {\n _onStackHoverFocus(stack, groupRef.refElement);\n }\n }\n\n function _handleMouseOut(): void {\n setPopoverOpen(false);\n }\n\n function _getBarGapAndScale(\n bars: VSChartDataPoint[],\n yBarScale: NumericScale,\n defaultTotalHeight?: number,\n ): {\n readonly gapHeight: number;\n readonly heightValueScale: number;\n readonly absStackTotal: number;\n } {\n const { barGapMax = 0 } = props;\n // When displaying gaps between the bars, the height of each bar is\n // adjusted so that the total of all bars is not changed by the gaps\n const totalData = bars.reduce((iter, value) => iter + Math.abs(value.data), 0);\n const totalHeight = defaultTotalHeight ?? Math.abs(yBarScale(totalData) - yBarScale(Y_ORIGIN));\n let sumOfPercent = 0;\n bars.forEach(point => {\n let value = (Math.abs(point.data) / totalData) * 100;\n if (value < 1 && value !== 0) {\n value = 1;\n }\n sumOfPercent += value;\n });\n const scalingRatio = sumOfPercent !== 0 ? sumOfPercent / 100 : 1;\n const gaps = barGapMax && bars.length - 1;\n const gapHeight = gaps && Math.max(barGapMin, Math.min(barGapMax, (totalHeight * barGapMultiplier) / gaps));\n const heightValueScale = (totalHeight - gapHeight * gaps) / (totalData * scalingRatio);\n return {\n gapHeight,\n heightValueScale,\n absStackTotal: totalData,\n } as const;\n }\n\n function _getScales(containerHeight: number, containerWidth: number) {\n const yDomain = [Math.min(Y_ORIGIN, _yMin), Math.max(Y_ORIGIN, _yMax)];\n const yBarScale = d3ScaleLinear()\n .domain(yDomain)\n .range([0, containerHeight - _margins.bottom! - _margins.top!]);\n if (_xAxisType === XAxisTypes.NumericAxis) {\n const xMax = d3Max(_dataset, (point: VerticalStackedBarDataPoint) => point.x as number)!;\n const xMin = d3Min(_dataset, (point: VerticalStackedBarDataPoint) => point.x as number)!;\n\n const xBarScale = d3ScaleLinear()\n .domain(_isRtl ? [xMax, xMin] : [xMin, xMax])\n .nice()\n .range([_margins.left! + _domainMargin, containerWidth - _margins.right! - _domainMargin]);\n\n return { xBarScale, yBarScale };\n }\n if (_xAxisType === XAxisTypes.DateAxis) {\n const sDate = d3Min(_dataset, (point: VerticalStackedBarDataPoint) => {\n return point.x as Date;\n })!;\n const lDate = d3Max(_dataset, (point: VerticalStackedBarDataPoint) => {\n return point.x as Date;\n })!;\n const xBarScale = props.useUTC ? d3ScaleUtc() : d3ScaleTime();\n xBarScale\n .domain(_isRtl ? [lDate, sDate] : [sDate, lDate])\n .range([_margins.left! + _domainMargin, containerWidth - _margins.right! - _domainMargin]);\n\n return { xBarScale, yBarScale };\n }\n const xBarScale = d3ScaleBand()\n .domain(_xAxisLabels)\n .range(\n _isRtl\n ? [containerWidth - _margins.right! - _domainMargin, _margins.left! + _domainMargin]\n : [_margins.left! + _domainMargin, containerWidth - _margins.right! - _domainMargin],\n )\n .paddingInner(_xAxisInnerPadding)\n .paddingOuter(_xAxisOuterPadding);\n\n return { xBarScale, yBarScale };\n }\n\n const _isChartEmpty = (): boolean => {\n return !(\n props.data &&\n props.data.length > 0 &&\n props.data.some(item => item.chartData.length > 0 || (item.lineData && item.lineData.length > 0))\n );\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 function _getDomainMargins(containerWidth: number): Margins {\n _domainMargin = MIN_DOMAIN_MARGIN;\n\n /** Total width available to render the bars */\n const totalWidth = containerWidth - (_margins.left! + MIN_DOMAIN_MARGIN) - (_margins.right! + MIN_DOMAIN_MARGIN);\n /** Rate at which the space between the bars changes wrt the bar width */\n const barGapRate = _xAxisInnerPadding / (1 - _xAxisInnerPadding);\n\n if (_xAxisType === XAxisTypes.StringAxis) {\n if (isScalePaddingDefined(props.xAxisOuterPadding, props.xAxisPadding)) {\n // Setting the domain margin for string x-axis to 0 because the xAxisOuterPadding prop is now available\n // to adjust the space before the first bar and after the last bar.\n _domainMargin = 0;\n } else if (props.barWidth !== 'auto') {\n // Update the bar width so that when CartesianChart rerenders,\n // the following calculations don't use the previous bar width.\n _barWidth = getBarWidth(props.barWidth, props.maxBarWidth);\n /** Total width required to render the bars. Directly proportional to bar width */\n const reqWidth = (_xAxisLabels.length + (_xAxisLabels.length - 1) * barGapRate) * _barWidth;\n\n if (totalWidth >= reqWidth) {\n // Center align the chart by setting equal left and right margins for domain\n _domainMargin = MIN_DOMAIN_MARGIN + (totalWidth - reqWidth) / 2;\n }\n } else if (props.mode === 'plotly' && _xAxisLabels.length > 1) {\n // Calculate the remaining width after rendering bars at their maximum allowable width\n const bandwidth = totalWidth / (_xAxisLabels.length + (_xAxisLabels.length - 1) * barGapRate);\n const barWidth = getBarWidth(props.barWidth, props.maxBarWidth, bandwidth);\n let reqWidth = (_xAxisLabels.length + (_xAxisLabels.length - 1) * barGapRate) * barWidth;\n const margin1 = (totalWidth - reqWidth) / 2;\n\n // Calculate the remaining width after accounting for the space required to render x-axis labels\n const step = calculateLongestLabelWidth(_xAxisLabels) + 20;\n reqWidth = (_xAxisLabels.length - _xAxisInnerPadding) * step;\n const margin2 = (totalWidth - reqWidth) / 2;\n\n _domainMargin = MIN_DOMAIN_MARGIN + Math.max(0, Math.min(margin1, margin2));\n }\n } else {\n const data = (props.data?.map(point => point.xAxisPoint) as number[] | Date[] | undefined) || [];\n _barWidth = getBarWidth(props.barWidth, props.maxBarWidth, calculateAppropriateBarWidth(data, totalWidth));\n _domainMargin = MIN_DOMAIN_MARGIN + _barWidth / 2;\n }\n\n return {\n ..._margins,\n left: _margins.left! + _domainMargin,\n right: _margins.right! + _domainMargin,\n };\n }\n\n function _getChartTitle(): string {\n const { chartTitle, data } = props;\n const numLines = Object.keys(_lineObject).length;\n return (\n (chartTitle ? `${chartTitle}. ` : '') +\n `Vertical bar chart with ${data?.length || 0} stacked bars` +\n (numLines > 0 ? ` and ${numLines} lines` : '') +\n '. '\n );\n }\n\n const classes = useVerticalStackedBarChartStyles(props);\n function _createBar(\n xBarScale: any,\n yBarScale: NumericScale,\n containerHeight: number,\n xElement: SVGElement,\n ): JSX.Element[] {\n const { barCornerRadius = 0, barMinimumHeight = 0 } = props;\n const _isHavingLines = props.data.some(\n (item: VerticalStackedChartProps) => item.lineData && item.lineData.length > 0,\n );\n const shouldFocusWholeStack = _toFocusWholeStack(_isHavingLines);\n\n if (_xAxisType === XAxisTypes.StringAxis) {\n _barWidth = getBarWidth(props.barWidth, props.maxBarWidth, xBarScale.bandwidth());\n }\n\n const bars = _points.map((singleChartData: VerticalStackedChartProps, indexNumber: number) => {\n const xPoint = xBarScale(\n _xAxisType === XAxisTypes.NumericAxis\n ? (singleChartData.xAxisPoint as number)\n : _xAxisType === XAxisTypes.DateAxis\n ? (singleChartData.xAxisPoint as Date)\n : (singleChartData.xAxisPoint as string),\n );\n const xScaleBandwidthTranslate =\n _xAxisType !== XAxisTypes.StringAxis ? -_barWidth / 2 : (xBarScale.bandwidth() - _barWidth) / 2;\n\n let barTotalValue = 0;\n\n const barsToDisplay = singleChartData.chartData.filter(point => point.data !== 0);\n\n if (!barsToDisplay.length) {\n return undefined;\n }\n\n const { gapHeight, heightValueScale, absStackTotal } = _getBarGapAndScale(barsToDisplay, yBarScale);\n\n if (heightValueScale < 0) {\n return undefined;\n }\n\n const yBaseline = containerHeight - _margins.bottom! - yBarScale(Y_ORIGIN);\n let yPositiveStart = yBaseline;\n let yNegativeStart = yBaseline;\n let yPoint = 0;\n let heightOfLastBar = 0;\n\n const singleBar = barsToDisplay.map((point: VSChartDataPoint, index: number) => {\n const startColor = point.color ? point.color : _colors[index];\n const ref: RefArrayData = {};\n const shouldHighlight = _isLegendHighlighted(point.legend) || _noLegendHighlighted() ? true : false;\n const rectFocusProps = !shouldFocusWholeStack && {\n 'aria-label': _getAriaLabel(singleChartData, point),\n onMouseOver: (event: React.MouseEvent<SVGElement, MouseEvent>) =>\n _onRectHover(singleChartData.xAxisPoint, point, startColor, event),\n onMouseMove: (event: React.MouseEvent<SVGElement, MouseEvent>) =>\n _onRectHover(singleChartData.xAxisPoint, point, startColor, event),\n onMouseLeave: _handleMouseOut,\n onFocus: () => _onRectFocus(point, singleChartData.xAxisPoint as string, startColor, ref),\n onBlur: _handleMouseOut,\n onClick: (event: React.MouseEvent<SVGElement, MouseEvent>) => _onClick(point, event),\n role: 'img',\n tabIndex: !props.hideTooltip && shouldHighlight ? 0 : undefined,\n };\n\n let barHeight = Math.abs(heightValueScale * point.data);\n // FIXME: The current scaling logic may produce different min and gap heights for each bar stack.\n const minHeight = Math.max((heightValueScale * absStackTotal) / 100.0, barMinimumHeight);\n if (barHeight < minHeight) {\n barHeight = minHeight;\n }\n const gapOffset = index ? gapHeight : 0;\n if (point.data >= Y_ORIGIN) {\n yPositiveStart -= barHeight + gapOffset;\n yPoint = yPositiveStart;\n } else {\n yPoint = yNegativeStart + gapOffset;\n yNegativeStart = yPoint + barHeight;\n }\n\n barTotalValue += point.data;\n heightOfLastBar = index === barsToDisplay.length - 1 ? barHeight : 0;\n\n if (barCornerRadius && barHeight > barCornerRadius && index === barsToDisplay.length - 1) {\n return (\n <React.Fragment key={index + indexNumber + `${shouldFocusWholeStack}`}>\n <path\n className={classes.opacityChangeOnHover}\n d={`\n M ${xPoint} ${yPoint + barCornerRadius}\n a ${barCornerRadius} ${barCornerRadius} 0 0 1 ${barCornerRadius} ${-barCornerRadius}\n h ${_barWidth - 2 * barCornerRadius}\n a ${barCornerRadius} ${barCornerRadius} 0 0 1 ${barCornerRadius} ${barCornerRadius}\n v ${barHeight - barCornerRadius}\n h ${-_barWidth}\n z\n `}\n fill={startColor}\n rx={props.roundCorners ? 3 : 0}\n ref={e => (ref.refElement = e)}\n transform={`translate(${xScaleBandwidthTranslate}, 0)`}\n cursor={props.href ? 'pointer' : 'default'}\n {...rectFocusProps}\n />\n </React.Fragment>\n );\n }\n if (barHeight < 0) {\n return <React.Fragment key={index + indexNumber}> </React.Fragment>;\n }\n return (\n <React.Fragment key={index + indexNumber}>\n <rect\n className={classes.opacityChangeOnHover}\n x={xPoint}\n y={yPoint}\n width={_barWidth}\n height={barHeight}\n fill={startColor}\n opacity={shouldHighlight ? 1 : 0.1}\n cursor={props.href ? 'pointer' : 'default'}\n rx={props.roundCorners ? 3 : 0}\n ref={e => (ref.refElement = e)}\n {...rectFocusProps}\n transform={`translate(${xScaleBandwidthTranslate}, 0)`}\n />\n </React.Fragment>\n );\n });\n const groupRef: RefArrayData = {};\n const stackFocusProps = shouldFocusWholeStack && {\n 'aria-label': _getAriaLabel(singleChartData),\n onMouseOver: (event: any) => _onStackHover(singleChartData, event),\n onMouseMove: (event: any) => _onStackHover(singleChartData, event),\n onMouseLeave: _handleMouseOut,\n onFocus: () => _onStackFocus(singleChartData, groupRef),\n onBlur: _handleMouseOut,\n onClick: (event: any) => _onClick(singleChartData, event),\n role: 'img',\n tabIndex: !props.hideTooltip ? 0 : undefined,\n };\n let showLabel = false;\n let barLabel = 0;\n if (!props.hideLabels) {\n if (_noLegendHighlighted()) {\n showLabel = true;\n barLabel = barTotalValue;\n } else {\n barsToDisplay.forEach(point => {\n if (_isLegendHighlighted(point.legend)) {\n showLabel = true;\n barLabel += point.data;\n }\n });\n }\n }\n return (\n <g key={indexNumber + `${shouldFocusWholeStack}`}>\n <g id={`${indexNumber}-singleBar`} ref={e => (groupRef.refElement = e)} {...stackFocusProps}>\n {singleBar}\n </g>\n {!props.hideLabels && _barWidth >= 16 && showLabel && (\n <text\n x={xPoint + _barWidth / 2}\n //if total bar value >=0, show label above top bar, otherwise below bottom bar\n y={barLabel >= Y_ORIGIN ? yPoint - 6 : yPoint + heightOfLastBar + 12}\n textAnchor=\"middle\"\n className={classes.barLabel}\n aria-label={`Total: ${barLabel}`}\n role=\"img\"\n transform={`translate(${xScaleBandwidthTranslate}, 0)`}\n >\n {typeof props.yAxisTickFormat === 'function'\n ? props.yAxisTickFormat(barLabel)\n : formatScientificLimitWidth(barLabel)}\n </text>\n )}\n </g>\n );\n });\n if (!props.showXAxisLablesTooltip) {\n try {\n document.getElementById(_tooltipId) && document.getElementById(_tooltipId)!.remove();\n // eslint-disable-next-line no-empty\n } catch (e) {}\n }\n if (!props.wrapXAxisLables && props.showXAxisLablesTooltip) {\n const xAxisElement = d3Select(xElement).call(xBarScale);\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 bars.filter((bar): bar is JSX.Element => !!bar);\n }\n\n function _getMinMaxOfYAxis(\n dataset: DataPoint[],\n yAxisType?: YAxisType,\n useSecondaryYScale?: boolean,\n ): { startValue: number; endValue: number } {\n if (!useSecondaryYScale) {\n return findVSBCNumericMinMaxOfY(dataset);\n }\n\n const values: number[] = [];\n props.data.forEach(xPoint => {\n xPoint.lineData?.forEach(point => {\n // useSecondaryYScale is applicable only for lines in VSBC\n if (point.useSecondaryYScale) {\n values.push(point.y);\n }\n });\n });\n\n return { startValue: d3Min(values)!, endValue: d3Max(values)! };\n }\n\n if (!_isChartEmpty()) {\n _adjustProps();\n const _isHavingLines = props.data.some(\n (item: VerticalStackedChartProps) => item.lineData && item.lineData.length > 0,\n );\n const shouldFocusWholeStack = _toFocusWholeStack(_isHavingLines);\n _dataset = _createDataSetLayer();\n const legendBars: JSX.Element = _getLegendData(_points, _createLegendsForLine(props.data));\n const calloutProps: ModifiedCartesianChartProps['calloutProps'] = {\n color: color,\n legend: calloutLegend,\n XValue: xCalloutValue!,\n YValue: yCalloutValue ? yCalloutValue : dataForHoverCard,\n YValueHover: YValueHover,\n hoverXValue: hoverXValue,\n ...props.calloutProps,\n ...getAccessibleDataObject(callOutAccessibilityData),\n clickPosition: clickPosition,\n isPopoverOpen: isPopoverOpen,\n isCalloutForStack:\n props.isCalloutForStack || (_isHavingLines && (_noLegendHighlighted() || _getHighlightedLegend().length > 1)),\n isCartesian: true,\n customCallout: {\n customizedCallout: _getCustomizedCallout() !== null ? _getCustomizedCallout()! : undefined,\n customCalloutProps: props.calloutPropsPerDataPoint\n ? props.calloutPropsPerDataPoint(dataPointCalloutProps!)\n : undefined,\n },\n };\n const tickParams = {\n tickValues: props.tickValues,\n tickFormat: props.tickFormat,\n };\n return (\n <CartesianChart\n {...props}\n chartTitle={_getChartTitle()}\n points={_dataset}\n chartType={ChartTypes.VerticalStackedBarChart}\n xAxisType={_xAxisType}\n getMinMaxOfYAxis={_getMinMaxOfYAxis}\n calloutProps={calloutProps}\n tickParams={tickParams}\n legendBars={legendBars}\n datasetForXAxisDomain={_xAxisLabels}\n isCalloutForStack={shouldFocusWholeStack}\n barwidth={_barWidth}\n getmargins={_getMargins}\n getGraphData={_getGraphData}\n getAxisData={_getAxisData}\n onChartMouseLeave={_handleChartMouseLeave}\n getDomainMargins={_getDomainMargins}\n {...(_xAxisType === XAxisTypes.StringAxis && {\n xAxisInnerPadding: _xAxisInnerPadding,\n xAxisOuterPadding: _xAxisOuterPadding,\n })}\n componentRef={cartesianChartRef}\n /* eslint-disable react/jsx-no-bind */\n children={(props: ChildProps) => {\n return (\n <>\n <g>{_bars}</g>\n <g>\n {_isHavingLines &&\n _createLines(\n props.xScale!,\n props.yScalePrimary!,\n props.containerHeight!,\n props.containerWidth!,\n props.yScaleSecondary,\n )}\n </g>\n </>\n );\n }}\n />\n );\n }\n return <div id={_emptyChartId} role={'alert'} style={{ opacity: '0' }} aria-label={'Graph has no data to display'} />;\n};\nVerticalStackedBarChart.displayName = 'VerticalStackedBarChart';\n"],"names":["React","max","d3Max","min","d3Min","select","d3Select","useVerticalStackedBarChartStyles","scaleLinear","d3ScaleLinear","scaleBand","d3ScaleBand","scaleUtc","d3ScaleUtc","scaleTime","d3ScaleTime","useId","tokens","CartesianChart","ChartPopover","Legends","ChartTypes","getAccessibleDataObject","XAxisTypes","getTypeOfAxis","tooltipOfAxislabels","formatScientificLimitWidth","getBarWidth","getScalePadding","isScalePaddingDefined","calculateAppropriateBarWidth","formatDate","areArraysEqual","calculateLongestLabelWidth","useRtl","DataVizPalette","getColorFromToken","findVSBCNumericMinMaxOfY","barGapMultiplier","barGapMin","MIN_DOMAIN_MARGIN","CircleVisbility","VerticalStackedBarChart","props","_isRtl","_createLegendsForLine","data","_getLineLegends","_tooltipId","_emptyChartId","_points","_dataset","_xAxisLabels","_bars","_xAxisType","length","xAxisPoint","StringAxis","_barWidth","_colors","_margins","_lineObject","_yMax","_yMin","_calloutAnchorPoint","_domainMargin","_xAxisInnerPadding","_xAxisOuterPadding","cartesianChartRef","useRef","Y_ORIGIN","selectedLegends","setSelectedLegends","useState","legendProps","activeLegend","setActiveLegend","undefined","dataForHoverCard","setDataForHoverCard","color","setColor","hoverXValue","setHoverXValue","YValueHover","setYValueHover","xCalloutValue","setXCalloutValue","yCalloutValue","setYCalloutValue","activeXAxisDataPoint","setActiveXAxisDataPoint","calloutLegend","setCalloutLegend","stackCalloutProps","setStackCalloutProps","dataPointCalloutProps","setDataPointCalloutProps","callOutAccessibilityData","setCallOutAccessibilityData","clickPosition","setClickPosition","x","y","isPopoverOpen","setPopoverOpen","prevPropsRef","useEffect","current","prevProps","height","width","_adjustProps","_createDataSetLayer","useImperativeHandle","componentRef","chartContainer","_getLegendData","lineLegends","hideLegend","defaultPalette","color6","color1","color5","color7","color10","actions","allowHoverOnLegend","forEach","singleChartData","chartData","point","Math","floor","random","checkSimilarLegends","filter","leg","title","legend","hoverAction","_handleChartMouseLeave","_onLegendHover","onMouseOutAction","_onLegendLeave","push","legendsOfLine","isLineLegendInBarChart","totalLegends","concat","legends","enabledWrapLines","enabledLegendsWrapLines","overflowText","legendsOverflowText","onChange","_onLegendSelectionChange","_getHighlightedLegend","_lineHoverOut","_lineHoverFocus","lineData","xItem","yAxisCalloutData","_onStackHoverFocus","stack","mouseEvent","clientX","clientY","boundingRect","getBoundingClientRect","left","top","_noLegendHighlighted","dataPoint","_isLegendHighlighted","isLinesPresent","item","shouldDrawBorderBottom","_updatePosition","sort","a","b","slice","reverse","Date","useUTC","stackCallOutAccessibilityData","_onClick","onBarClick","href","window","location","barWidth","maxBarWidth","defaultColors","_getFormattedLineData","xAxisInnerPadding","xAxisPadding","xAxisOuterPadding","tempArr","dataset","map","singlePointData","total","legendTitle","_selectedLegends","event","currentLegend","canSelectMultipleLegends","_getMargins","margins","_getGraphData","xScale","yScale","containerHeight","containerWidth","xElement","xBarScale","yBarScale","_getScales","_createBar","_getAxisData","yAxisData","yAxisDomainValues","domainValue","yMaxValue","yMinValue","includes","_getAriaLabel","xValue","xAxisCalloutData","pointValues","pt","yValue","join","lineValues","ln","ariaLabel","_getCustomizedCallout","_isHavingLines","some","onRenderCalloutPerStack","onRenderCalloutPerDataPoint","_renderCallout","_toFocusWholeStack","isCalloutForStack","shouldFocusStackOnly","linesData","formattedLineData","index","line","lineObject","Object","keys","_createLines","yScalePrimary","yScaleSecondary","lines","borderForLines","dots","lineBorderWidth","lineOptions","Number","parseFloat","toString","xScaleBandwidthTranslate","bandwidth","shouldHighlight","i","x1","useSecondaryYScale","y1","x2","y2","key","opacity","strokeWidth","fill","strokeLinecap","stroke","colorNeutralBackground1","transform","strokeDasharray","onMouseOver","_lineHover","bind","onMouseLeave","circlePoint","subIndex","circleRef","refElement","noBarsAndLinesActive","circle","cx","cy","_onStackHover","r","_getCircleVisibilityAndRadius","radius","visibility","ref","e","tabIndex","hideTooltip","onFocus","_lineFocus","onBlur","_handleMouseOut","role","culture","XValue","YValue","_onRectHover","persist","_onRectFocusHover","chartDataPoint","xAxisDataPoint","_onRectFocus","_onStackFocus","groupRef","_getBarGapAndScale","bars","defaultTotalHeight","barGapMax","totalData","reduce","iter","value","abs","totalHeight","sumOfPercent","scalingRatio","gaps","gapHeight","heightValueScale","absStackTotal","yDomain","domain","range","bottom","NumericAxis","xMax","xMin","nice","right","DateAxis","sDate","lDate","paddingInner","paddingOuter","_isChartEmpty","newX","newY","threshold","distance","sqrt","pow","_getDomainMargins","totalWidth","barGapRate","reqWidth","mode","margin1","step","margin2","_getChartTitle","chartTitle","numLines","classes","barCornerRadius","barMinimumHeight","shouldFocusWholeStack","indexNumber","xPoint","barTotalValue","barsToDisplay","yBaseline","yPositiveStart","yNegativeStart","yPoint","heightOfLastBar","singleBar","startColor","rectFocusProps","onMouseMove","onClick","barHeight","minHeight","gapOffset","Fragment","path","className","opacityChangeOnHover","d","rx","roundCorners","cursor","rect","stackFocusProps","showLabel","barLabel","hideLabels","g","id","text","textAnchor","aria-label","yAxisTickFormat","showXAxisLablesTooltip","document","getElementById","remove","wrapXAxisLables","xAxisElement","call","tooltipProps","tooltipCls","tooltip","axis","bar","_getMinMaxOfYAxis","yAxisType","values","startValue","endValue","legendBars","calloutProps","isCartesian","customCallout","customizedCallout","customCalloutProps","calloutPropsPerDataPoint","tickParams","tickValues","tickFormat","points","chartType","xAxisType","getMinMaxOfYAxis","datasetForXAxisDomain","barwidth","getmargins","getGraphData","getAxisData","onChartMouseLeave","getDomainMargins","children","div","style","displayName"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":"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"}
1
+ {"version":3,"sources":["VerticalStackedBarChart.tsx"],"sourcesContent":["import * as React from 'react';\nimport { max as d3Max, min as d3Min } from 'd3-array';\nimport { Axis as D3Axis } from 'd3-axis';\nimport { select as d3Select } from 'd3-selection';\nimport { useVerticalStackedBarChartStyles } from './useVerticalStackedBarChartStyles.styles';\nimport {\n scaleLinear as d3ScaleLinear,\n ScaleLinear as D3ScaleLinear,\n scaleBand as d3ScaleBand,\n scaleUtc as d3ScaleUtc,\n scaleTime as d3ScaleTime,\n} from 'd3-scale';\nimport { useId } from '@fluentui/react-utilities';\nimport { tokens } from '@fluentui/react-theme';\nimport {\n AccessibilityProps,\n CartesianChart,\n ChildProps,\n VerticalStackedBarDataPoint,\n Margins,\n VerticalStackedBarChartProps,\n VerticalStackedChartProps,\n VSChartDataPoint,\n LineDataInVerticalStackedBarChart,\n ModifiedCartesianChartProps,\n Legend,\n ChartPopover,\n Legends,\n Chart,\n DataPoint,\n} from '../../index';\nimport {\n ChartTypes,\n IAxisData,\n getAccessibleDataObject,\n XAxisTypes,\n getTypeOfAxis,\n tooltipOfAxislabels,\n formatScientificLimitWidth,\n getBarWidth,\n getScalePadding,\n isScalePaddingDefined,\n calculateAppropriateBarWidth,\n formatDate,\n areArraysEqual,\n calculateLongestLabelWidth,\n useRtl,\n DataVizPalette,\n getColorFromToken,\n findVSBCNumericMinMaxOfY,\n YAxisType,\n createNumericYAxis,\n IDomainNRange,\n domainRangeOfDateForAreaLineVerticalBarChart,\n domainRangeOfVSBCNumeric,\n domainRangeOfXStringAxis,\n createStringYAxis,\n} from '../../utilities/index';\n\ntype NumericAxis = D3Axis<number | { valueOf(): number }>;\ntype NumericScale = D3ScaleLinear<number, number>;\nconst barGapMultiplier = 0.2;\nconst barGapMin = 1;\nconst MIN_DOMAIN_MARGIN = 8;\n\ninterface RefArrayData {\n refElement?: SVGGElement | null;\n}\n\ntype LinePoint = LineDataInVerticalStackedBarChart & { index: number; xItem: VerticalStackedChartProps };\ntype LineObject = { [key: string]: LinePoint[] };\ntype LineLegends = {\n title: string;\n color: string;\n};\nenum CircleVisbility {\n show = 'visibility',\n hide = 'hidden',\n}\ntype CalloutAnchorPointData = {\n xAxisDataPoint: string;\n chartDataPoint: VSChartDataPoint;\n};\n\nexport const VerticalStackedBarChart: React.FunctionComponent<VerticalStackedBarChartProps> = props => {\n const _isRtl: boolean = useRtl();\n const _createLegendsForLine: (data: VerticalStackedChartProps[]) => LineLegends[] = (\n data: VerticalStackedChartProps[],\n ) => _getLineLegends(data);\n const _tooltipId: string = useId('VSBCTooltipId_');\n const _emptyChartId: string = useId('_VSBC_empty');\n let _points: VerticalStackedChartProps[] = [];\n let _dataset: VerticalStackedBarDataPoint[];\n let _xAxisLabels: string[] = [];\n let _bars: JSX.Element[];\n let _xAxisType: XAxisTypes =\n props.data! && props.data!.length > 0\n ? (getTypeOfAxis(props.data[0]!.xAxisPoint, true) as XAxisTypes)\n : XAxisTypes.StringAxis;\n let _barWidth: number = 0;\n let _colors: string[];\n let _margins: Margins;\n let _lineObject: LineObject;\n let _yMax: number;\n let _yMin: number;\n let _calloutAnchorPoint: CalloutAnchorPointData | null;\n let _domainMargin: number = MIN_DOMAIN_MARGIN;\n let _xAxisInnerPadding: number = 0;\n let _xAxisOuterPadding: number = 0;\n const cartesianChartRef = React.useRef<Chart>(null);\n const Y_ORIGIN: number = 0;\n\n const [selectedLegends, setSelectedLegends] = React.useState(props.legendProps?.selectedLegends || []);\n const [activeLegend, setActiveLegend] = React.useState<string | undefined>(undefined);\n const [dataForHoverCard, setDataForHoverCard] = React.useState(0);\n const [color, setColor] = React.useState('');\n const [hoverXValue, setHoverXValue] = React.useState<string | number>('');\n const [YValueHover, setYValueHover] = React.useState<(LineDataInVerticalStackedBarChart | VSChartDataPoint)[]>([]);\n const [xCalloutValue, setXCalloutValue] = React.useState('');\n const [yCalloutValue, setYCalloutValue] = React.useState('');\n const [activeXAxisDataPoint, setActiveXAxisDataPoint] = React.useState<number | string | Date>('');\n const [calloutLegend, setCalloutLegend] = React.useState('');\n const [stackCalloutProps, setStackCalloutProps] = React.useState<VerticalStackedChartProps>();\n const [dataPointCalloutProps, setDataPointCalloutProps] = React.useState<VSChartDataPoint>();\n const [callOutAccessibilityData, setCallOutAccessibilityData] = React.useState<AccessibilityProps>();\n const [clickPosition, setClickPosition] = React.useState({ x: 0, y: 0 });\n const [isPopoverOpen, setPopoverOpen] = React.useState(false);\n const prevPropsRef = React.useRef<VerticalStackedBarChartProps | null>(null);\n React.useEffect(() => {\n if (prevPropsRef.current) {\n const prevProps = prevPropsRef.current;\n if (!areArraysEqual(prevProps.legendProps?.selectedLegends, props.legendProps?.selectedLegends)) {\n setSelectedLegends(props.legendProps?.selectedLegends || []);\n }\n if (prevProps.height !== props.height || prevProps.width !== props.width || prevProps.data !== props.data) {\n _adjustProps();\n _dataset = _createDataSetLayer();\n }\n }\n prevPropsRef.current = props;\n }, [props]);\n\n React.useImperativeHandle(\n props.componentRef,\n () => ({\n chartContainer: cartesianChartRef.current?.chartContainer ?? null,\n }),\n [],\n );\n\n function _getLegendData(data: VerticalStackedChartProps[], lineLegends: LineLegends[]): JSX.Element {\n if (props.hideLegend) {\n return <></>;\n }\n const defaultPalette: string[] = [\n getColorFromToken(DataVizPalette.color6),\n getColorFromToken(DataVizPalette.color1),\n getColorFromToken(DataVizPalette.color5),\n getColorFromToken(DataVizPalette.color7),\n getColorFromToken(DataVizPalette.color10),\n ];\n const actions: Legend[] = [];\n const { allowHoverOnLegend = true } = props;\n\n data.forEach((singleChartData: VerticalStackedChartProps) => {\n singleChartData.chartData.forEach((point: VSChartDataPoint) => {\n const color: string = point.color ? point.color : defaultPalette[Math.floor(Math.random() * 4 + 1)];\n const checkSimilarLegends = actions.filter((leg: Legend) => leg.title === point.legend && leg.color === color);\n if (checkSimilarLegends!.length > 0) {\n return;\n }\n\n const legend: Legend = {\n title: point.legend,\n color,\n hoverAction: allowHoverOnLegend\n ? () => {\n _handleChartMouseLeave();\n _onLegendHover(point.legend);\n }\n : undefined,\n onMouseOutAction: allowHoverOnLegend ? () => _onLegendLeave() : undefined,\n };\n\n actions.push(legend);\n });\n });\n const legendsOfLine: Legend[] = [];\n if (lineLegends && lineLegends.length > 0) {\n lineLegends.forEach((point: LineLegends) => {\n const legend: Legend = {\n title: point.title,\n color: point.color,\n isLineLegendInBarChart: true,\n hoverAction: allowHoverOnLegend\n ? () => {\n _handleChartMouseLeave();\n _onLegendHover(point.title);\n }\n : undefined,\n onMouseOutAction: allowHoverOnLegend ? () => _onLegendLeave() : undefined,\n };\n legendsOfLine.push(legend);\n });\n }\n const totalLegends: Legend[] = legendsOfLine.concat(actions);\n return (\n <Legends\n legends={totalLegends}\n enabledWrapLines={props.enabledLegendsWrapLines}\n overflowText={props.legendsOverflowText}\n {...props.legendProps}\n onChange={_onLegendSelectionChange}\n />\n );\n }\n\n function _getHighlightedLegend() {\n return selectedLegends.length > 0 ? selectedLegends : activeLegend ? [activeLegend] : [];\n }\n\n function _lineHoverOut() {\n setPopoverOpen(false);\n setXCalloutValue('');\n setYCalloutValue('');\n setActiveXAxisDataPoint('');\n setColor('');\n }\n\n function _lineHoverFocus(lineData: LinePoint) {\n setPopoverOpen(true);\n setXCalloutValue(`${lineData.xItem.xAxisPoint}`);\n setYCalloutValue(`${lineData.yAxisCalloutData || lineData.data || lineData.y}`);\n setActiveXAxisDataPoint(lineData.xItem.xAxisPoint);\n setColor(lineData.color);\n }\n\n function _onStackHoverFocus(\n stack: VerticalStackedChartProps,\n mouseEvent: React.MouseEvent<SVGElement> | SVGGElement,\n ): void {\n let clientX = 0;\n let clientY = 0;\n if ('clientX' in mouseEvent) {\n clientX = mouseEvent.clientX;\n clientY = mouseEvent.clientY;\n } else {\n // Handle case where mouseEvent is an SVGGElement\n const boundingRect = mouseEvent.getBoundingClientRect();\n clientX = boundingRect.left + boundingRect.width / 2;\n clientY = boundingRect.top + boundingRect.height / 2;\n }\n if (!_noLegendHighlighted()) {\n stack = {\n ...stack,\n chartData: stack.chartData.filter((dataPoint: { legend: any }) => _isLegendHighlighted(dataPoint.legend)),\n lineData: stack.lineData?.filter((dataPoint: { legend: any }) => _isLegendHighlighted(dataPoint.legend)),\n };\n }\n const lineData = stack.lineData;\n const isLinesPresent: boolean = lineData !== undefined && lineData.length > 0;\n if (isLinesPresent) {\n lineData!.forEach((item: LineDataInVerticalStackedBarChart & { shouldDrawBorderBottom?: boolean }) => {\n item.data = item.data || item.y;\n item.shouldDrawBorderBottom = true;\n });\n }\n _updatePosition(clientX, clientY);\n setPopoverOpen(stack.chartData.length > 0 || (stack.lineData?.length ?? 0) > 0);\n setYValueHover(\n isLinesPresent\n ? [...lineData!.sort((a, b) => (a.data! < b.data! ? 1 : -1)), ...stack.chartData.slice().reverse()]\n : stack.chartData.slice().reverse(),\n );\n setHoverXValue(stack.xAxisPoint instanceof Date ? formatDate(stack.xAxisPoint, props.useUTC) : stack.xAxisPoint);\n setStackCalloutProps(stack);\n setActiveXAxisDataPoint(stack.xAxisPoint);\n setCallOutAccessibilityData(stack.stackCallOutAccessibilityData);\n }\n\n function _handleChartMouseLeave(): void {\n _calloutAnchorPoint = null;\n setPopoverOpen(false);\n setActiveXAxisDataPoint('');\n }\n\n const _onClick = (\n data: VerticalStackedChartProps | VSChartDataPoint,\n mouseEvent: React.MouseEvent<SVGElement>,\n ): void => {\n props.onBarClick?.(mouseEvent, data);\n props.href ? (window.location.href = props.href) : '';\n };\n\n function _adjustProps(): void {\n _points = props.data || [];\n _barWidth = getBarWidth(props.barWidth, props.maxBarWidth);\n const defaultColors: string[] = [\n getColorFromToken(DataVizPalette.color6),\n getColorFromToken(DataVizPalette.color1),\n getColorFromToken(DataVizPalette.color5),\n getColorFromToken(DataVizPalette.color7),\n getColorFromToken(DataVizPalette.color10),\n ];\n _colors = defaultColors;\n _xAxisType = getTypeOfAxis(props.data[0].xAxisPoint, true) as XAxisTypes;\n _lineObject = _getFormattedLineData(props.data);\n _xAxisInnerPadding = getScalePadding(props.xAxisInnerPadding, props.xAxisPadding, 2 / 3);\n _xAxisOuterPadding = getScalePadding(props.xAxisOuterPadding, props.xAxisPadding, 0);\n }\n\n function _createDataSetLayer(): VerticalStackedBarDataPoint[] {\n const tempArr: string[] = [];\n const dataset: VerticalStackedBarDataPoint[] = _points.map(singlePointData => {\n let total: number = 0;\n singlePointData.chartData!.forEach((point: VSChartDataPoint) => {\n total = total + point.data;\n });\n tempArr.push(singlePointData.xAxisPoint as string);\n return {\n x: singlePointData.xAxisPoint,\n y: total,\n };\n });\n _xAxisLabels = tempArr;\n return dataset;\n }\n\n function _onLegendHover(legendTitle: string): void {\n setActiveLegend(legendTitle);\n }\n\n function _onLegendLeave(): void {\n setActiveLegend(undefined);\n }\n\n function _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 function _getMargins(margins: Margins) {\n _margins = margins;\n }\n\n function _getGraphData(\n xScale: any,\n yScale: NumericAxis,\n containerHeight: number,\n containerWidth: number,\n xElement: SVGElement | null,\n ) {\n const { xBarScale, yBarScale } = _getScales(containerHeight, containerWidth);\n return (_bars = _createBar(xBarScale, yBarScale, containerHeight, xElement!));\n }\n\n function _getAxisData(yAxisData: IAxisData) {\n if (yAxisData && yAxisData.yAxisDomainValues.length) {\n const { yAxisDomainValues: domainValue } = yAxisData;\n _yMax = Math.max(domainValue[domainValue.length - 1], props.yMaxValue || Y_ORIGIN);\n _yMin = Math.min(domainValue[0], props.yMinValue || Y_ORIGIN);\n }\n }\n\n /**\n * This function checks if the given legend is highlighted or not.\n * A legend can be highlighted in 2 ways:\n * 1. selection: if the user clicks on it\n * 2. hovering: if there is no selected legend and the user hovers over it\n */\n function _isLegendHighlighted(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 function _noLegendHighlighted() {\n return _getHighlightedLegend().length === 0;\n }\n\n function _getAriaLabel(singleChartData: VerticalStackedChartProps, point?: VSChartDataPoint): string {\n if (!point) {\n /** if shouldFocusWholeStack is true */\n const xValue =\n singleChartData.xAxisCalloutData ||\n (singleChartData.xAxisPoint instanceof Date\n ? formatDate(singleChartData.xAxisPoint)\n : singleChartData.xAxisPoint);\n const pointValues = singleChartData.chartData\n .map(pt => {\n const legend = pt.legend;\n const yValue = pt.yAxisCalloutData || pt.data;\n return `${legend}, ${yValue}.`;\n })\n .join(' ');\n const lineValues = singleChartData.lineData\n ?.map(ln => {\n const legend = ln.legend;\n const yValue = ln.yAxisCalloutData || ln.data || ln.y;\n return `${legend}, ${yValue}.`;\n })\n .join(' ');\n return (\n singleChartData.stackCallOutAccessibilityData?.ariaLabel ||\n `${xValue}. ${pointValues}` + (lineValues ? ` ${lineValues}` : '')\n );\n }\n /** if shouldFocusWholeStack is false */\n const xValue =\n singleChartData.xAxisCalloutData ||\n point.xAxisCalloutData ||\n (singleChartData.xAxisPoint instanceof Date\n ? formatDate(singleChartData.xAxisPoint)\n : singleChartData.xAxisPoint);\n const legend = point.legend;\n const yValue = point.yAxisCalloutData || point.data;\n return point.callOutAccessibilityData?.ariaLabel || `${xValue}. ${legend}, ${yValue}.`;\n }\n\n function _getCustomizedCallout() {\n const _isHavingLines = props.data.some(\n (item: VerticalStackedChartProps) => item.lineData && item.lineData.length > 0,\n );\n return props.onRenderCalloutPerStack\n ? props.onRenderCalloutPerStack(stackCalloutProps)\n : props.onRenderCalloutPerDataPoint && !_isHavingLines\n ? props.onRenderCalloutPerDataPoint(dataPointCalloutProps, _renderCallout)\n : null;\n }\n\n function _toFocusWholeStack(_isHavingLines: boolean): boolean {\n const { isCalloutForStack = false } = props;\n let shouldFocusStackOnly: boolean = false;\n if (_isHavingLines) {\n if (_getHighlightedLegend().length === 1) {\n shouldFocusStackOnly = false;\n } else {\n shouldFocusStackOnly = true;\n }\n } else {\n shouldFocusStackOnly = isCalloutForStack;\n }\n return shouldFocusStackOnly;\n }\n\n function _getDomainNRangeValues(\n points: DataPoint[],\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) {\n domainNRangeValue = domainRangeOfVSBCNumeric(points, margins, width, isRTL, barWidth!);\n } else if (xAxisType === XAxisTypes.DateAxis) {\n domainNRangeValue = domainRangeOfDateForAreaLineVerticalBarChart(\n points,\n margins,\n width,\n isRTL,\n tickValues! as Date[],\n chartType,\n barWidth,\n );\n } else {\n domainNRangeValue = domainRangeOfXStringAxis(margins, width, isRTL);\n }\n return domainNRangeValue;\n }\n\n function _getFormattedLineData(data: VerticalStackedChartProps[]): LineObject {\n const linesData: LinePoint[] = [];\n const formattedLineData: LineObject = {};\n data.forEach((item: VerticalStackedChartProps, index: number) => {\n if (item.lineData) {\n item.lineData.forEach((line: any) => {\n linesData.push({\n ...line,\n index,\n xItem: item,\n });\n });\n }\n });\n linesData.forEach(item => {\n if (formattedLineData[item.legend]) {\n formattedLineData[item.legend].push(item);\n } else {\n formattedLineData[item.legend] = [item];\n }\n });\n return formattedLineData;\n }\n\n function _getLineLegends(data: VerticalStackedChartProps[]): LineLegends[] {\n const lineObject: LineObject = _lineObject;\n const lineLegends: LineLegends[] = [];\n Object.keys(lineObject).forEach((item: string) => {\n lineLegends.push({\n title: item,\n color: lineObject[item][0].color,\n });\n });\n return lineLegends;\n }\n\n function _createLines(\n xScale: any,\n yScalePrimary: NumericScale,\n containerHeight: number,\n containerWidth: number,\n yScaleSecondary?: NumericScale,\n ): JSX.Element {\n const lineObject: LineObject = _getFormattedLineData(props.data);\n const lines: React.ReactNode[] = [];\n const borderForLines: React.ReactNode[] = [];\n const dots: React.ReactNode[] = [];\n //const { theme } = props;\n const lineBorderWidth = props.lineOptions?.lineBorderWidth\n ? Number.parseFloat(props.lineOptions!.lineBorderWidth!.toString())\n : 0;\n const xScaleBandwidthTranslate = _xAxisType !== XAxisTypes.StringAxis ? 0 : xScale.bandwidth() / 2;\n Object.keys(lineObject).forEach((item: string, index: number) => {\n const shouldHighlight = _isLegendHighlighted(item) || _noLegendHighlighted();\n for (let i = 1; i < lineObject[item].length; i++) {\n const x1 = xScale(lineObject[item][i - 1].xItem.xAxisPoint);\n const useSecondaryYScale =\n lineObject[item][i - 1].useSecondaryYScale && lineObject[item][i].useSecondaryYScale && yScaleSecondary;\n const y1 = useSecondaryYScale\n ? yScaleSecondary!(lineObject[item][i - 1].y)\n : yScalePrimary(lineObject[item][i - 1].y);\n const x2 = xScale(lineObject[item][i].xItem.xAxisPoint);\n const y2 = useSecondaryYScale ? yScaleSecondary!(lineObject[item][i].y) : yScalePrimary(lineObject[item][i].y);\n if (lineBorderWidth > 0) {\n borderForLines.push(\n <line\n key={`${index}-${i}-BorderLine`}\n x1={x1}\n y1={y1}\n x2={x2}\n y2={y2}\n opacity={shouldHighlight ? 1 : 0.1}\n strokeWidth={3 + lineBorderWidth * 2}\n fill=\"transparent\"\n strokeLinecap=\"round\"\n stroke={tokens.colorNeutralBackground1}\n transform={`translate(${xScaleBandwidthTranslate}, 0)`}\n />,\n );\n }\n lines.push(\n <line\n key={`${index}-${i}-line`}\n x1={x1}\n y1={y1}\n x2={x2}\n y2={y2}\n opacity={shouldHighlight ? 1 : 0.1}\n strokeWidth={lineObject[item][0].lineOptions?.strokeWidth ?? 3}\n strokeLinecap={lineObject[item][0].lineOptions?.strokeLinecap ?? 'round'}\n strokeDasharray={lineObject[item][0].lineOptions?.strokeDasharray}\n stroke={lineObject[item][i].color}\n transform={`translate(${xScaleBandwidthTranslate}, 0)`}\n {...(_isLegendHighlighted(item) && {\n onMouseOver: _lineHover.bind(lineObject[item][i - 1]),\n onMouseLeave: _lineHoverOut,\n })}\n />,\n );\n }\n });\n Object.keys(lineObject).forEach((item: string, index: number) => {\n lineObject[item].forEach((circlePoint: LinePoint, subIndex: number) => {\n const circleRef: { refElement: SVGCircleElement | null } = { refElement: null };\n const noBarsAndLinesActive =\n circlePoint.xItem.chartData.filter(\n dataPoint => _noLegendHighlighted() || _isLegendHighlighted(dataPoint.legend),\n ).length === 0;\n dots.push(\n <circle\n key={`${index}-${subIndex}-dot`}\n cx={xScale(circlePoint.xItem.xAxisPoint)}\n cy={\n circlePoint.useSecondaryYScale && yScaleSecondary\n ? yScaleSecondary(circlePoint.y)\n : yScalePrimary(circlePoint.y)\n }\n onMouseOver={\n _isLegendHighlighted(item)\n ? (event: React.MouseEvent<SVGElement, MouseEvent>) => _lineHover(circlePoint, event)\n : (event: React.MouseEvent<SVGElement, MouseEvent>) => _onStackHover(circlePoint.xItem, event)\n }\n {...(_isLegendHighlighted(item) && {\n onMouseLeave: _lineHoverOut,\n })}\n r={_getCircleVisibilityAndRadius(circlePoint.xItem.xAxisPoint, circlePoint.legend).radius}\n stroke={circlePoint.color}\n fill={tokens.colorNeutralBackground1}\n strokeWidth={3}\n visibility={_getCircleVisibilityAndRadius(circlePoint.xItem.xAxisPoint, circlePoint.legend).visibility}\n transform={`translate(${xScaleBandwidthTranslate}, 0)`}\n ref={e => (circleRef.refElement = e)}\n {...(noBarsAndLinesActive\n ? {\n tabIndex: !props.hideTooltip ? 0 : undefined,\n onFocus: event => _lineFocus(event, circlePoint, circleRef),\n onBlur: _handleMouseOut,\n role: 'img',\n 'aria-label': _getAriaLabel(circlePoint.xItem, circlePoint as VSChartDataPoint),\n }\n : {})}\n />,\n );\n });\n });\n return (\n <>\n {borderForLines}\n {lines}\n {dots}\n </>\n );\n }\n\n function _getCircleVisibilityAndRadius(\n xAxisPoint: string | number | Date,\n legend: string,\n ): { visibility: CircleVisbility; radius: number } {\n if (!_noLegendHighlighted()) {\n if (xAxisPoint === activeXAxisDataPoint && _isLegendHighlighted(legend)) {\n return { visibility: CircleVisbility.show, radius: 8 };\n } else if (_isLegendHighlighted(legend)) {\n return { visibility: CircleVisbility.show, radius: 0.3 };\n } else {\n return { visibility: CircleVisbility.hide, radius: 0 };\n }\n } else {\n return {\n visibility: activeXAxisDataPoint === xAxisPoint ? CircleVisbility.show : CircleVisbility.hide,\n radius: 8,\n };\n }\n }\n\n function _renderCallout(props?: VSChartDataPoint): JSX.Element | null {\n return props ? (\n <ChartPopover\n culture={props.culture ?? 'en-us'}\n XValue={props.xAxisCalloutData}\n xCalloutValue={xCalloutValue}\n yCalloutValue={yCalloutValue}\n clickPosition={clickPosition}\n isPopoverOpen={isPopoverOpen}\n legend={props.legend}\n YValue={props.yAxisCalloutData}\n color={props.color}\n />\n ) : null;\n }\n\n function _onRectHover(\n xAxisPoint: string | number | Date,\n point: VSChartDataPoint,\n color: string,\n mouseEvent: React.MouseEvent<SVGElement>,\n ): void {\n mouseEvent.persist();\n _onRectFocusHover(xAxisPoint, point, color, mouseEvent);\n }\n\n function _onRectFocusHover(\n xAxisPoint: string | number | Date,\n point: VSChartDataPoint,\n color: string,\n mouseEvent: React.MouseEvent<SVGElement> | SVGGElement,\n ) {\n let clientX = 0;\n let clientY = 0;\n if ('clientX' in mouseEvent) {\n clientX = mouseEvent.clientX;\n clientY = mouseEvent.clientY;\n } else {\n // Handle case where mouseEvent is an SVGGElement\n const boundingRect = mouseEvent.getBoundingClientRect();\n clientX = boundingRect.left + boundingRect.width / 2;\n clientY = boundingRect.top + boundingRect.height / 2;\n }\n if (_calloutAnchorPoint?.chartDataPoint !== point || _calloutAnchorPoint?.xAxisDataPoint !== xAxisPoint) {\n _calloutAnchorPoint = {\n chartDataPoint: point,\n xAxisDataPoint: `${xAxisPoint}`,\n };\n _updatePosition(clientX, clientY);\n setPopoverOpen(_noLegendHighlighted() || _isLegendHighlighted(point.legend));\n setCalloutLegend(point.legend);\n setDataForHoverCard(point.data);\n setColor(color);\n setXCalloutValue(point.xAxisCalloutData ? point.xAxisCalloutData : `${xAxisPoint}`);\n setYCalloutValue(point.yAxisCalloutData!);\n setDataPointCalloutProps(point);\n setCallOutAccessibilityData(point.callOutAccessibilityData);\n }\n }\n\n function _lineHover(lineData: LinePoint, mouseEvent: React.MouseEvent<SVGElement>) {\n mouseEvent.persist();\n _lineHoverFocus(lineData);\n }\n\n function _lineFocus(\n event: React.FocusEvent<SVGCircleElement, Element>,\n lineData: LinePoint,\n ref: { refElement: SVGCircleElement | null },\n ) {\n if (ref.refElement) {\n _lineHoverFocus(lineData);\n }\n }\n\n function _onStackHover(stack: VerticalStackedChartProps, mouseEvent: React.MouseEvent<SVGElement>): void {\n mouseEvent.persist();\n _onStackHoverFocus(stack, mouseEvent);\n }\n\n function _onRectFocus(point: VSChartDataPoint, xAxisPoint: string, color: string, ref: RefArrayData): void {\n if (ref.refElement) {\n _onRectFocusHover(xAxisPoint, point, color, ref.refElement);\n }\n }\n\n function _onStackFocus(stack: VerticalStackedChartProps, groupRef: RefArrayData): void {\n if (groupRef.refElement) {\n _onStackHoverFocus(stack, groupRef.refElement);\n }\n }\n\n function _handleMouseOut(): void {\n setPopoverOpen(false);\n }\n\n function _getBarGapAndScale(\n bars: VSChartDataPoint[],\n yBarScale: NumericScale,\n defaultTotalHeight?: number,\n ): {\n readonly gapHeight: number;\n readonly heightValueScale: number;\n readonly absStackTotal: number;\n } {\n const { barGapMax = 0 } = props;\n // When displaying gaps between the bars, the height of each bar is\n // adjusted so that the total of all bars is not changed by the gaps\n const totalData = bars.reduce((iter, value) => iter + Math.abs(value.data), 0);\n const totalHeight = defaultTotalHeight ?? Math.abs(yBarScale(totalData) - yBarScale(Y_ORIGIN));\n let sumOfPercent = 0;\n bars.forEach(point => {\n let value = (Math.abs(point.data) / totalData) * 100;\n if (value < 1 && value !== 0) {\n value = 1;\n }\n sumOfPercent += value;\n });\n const scalingRatio = sumOfPercent !== 0 ? sumOfPercent / 100 : 1;\n const gaps = barGapMax && bars.length - 1;\n const gapHeight = gaps && Math.max(barGapMin, Math.min(barGapMax, (totalHeight * barGapMultiplier) / gaps));\n const heightValueScale = (totalHeight - gapHeight * gaps) / (totalData * scalingRatio);\n return {\n gapHeight,\n heightValueScale,\n absStackTotal: totalData,\n } as const;\n }\n\n function _getScales(containerHeight: number, containerWidth: number) {\n const yDomain = [Math.min(Y_ORIGIN, _yMin), Math.max(Y_ORIGIN, _yMax)];\n const yBarScale = d3ScaleLinear()\n .domain(yDomain)\n .range([0, containerHeight - _margins.bottom! - _margins.top!]);\n if (_xAxisType === XAxisTypes.NumericAxis) {\n const xMax = d3Max(_dataset, (point: VerticalStackedBarDataPoint) => point.x as number)!;\n const xMin = d3Min(_dataset, (point: VerticalStackedBarDataPoint) => point.x as number)!;\n\n const xBarScale = d3ScaleLinear()\n .domain(_isRtl ? [xMax, xMin] : [xMin, xMax])\n .nice()\n .range([_margins.left! + _domainMargin, containerWidth - _margins.right! - _domainMargin]);\n\n return { xBarScale, yBarScale };\n }\n if (_xAxisType === XAxisTypes.DateAxis) {\n const sDate = d3Min(_dataset, (point: VerticalStackedBarDataPoint) => {\n return point.x as Date;\n })!;\n const lDate = d3Max(_dataset, (point: VerticalStackedBarDataPoint) => {\n return point.x as Date;\n })!;\n const xBarScale = props.useUTC ? d3ScaleUtc() : d3ScaleTime();\n xBarScale\n .domain(_isRtl ? [lDate, sDate] : [sDate, lDate])\n .range([_margins.left! + _domainMargin, containerWidth - _margins.right! - _domainMargin]);\n\n return { xBarScale, yBarScale };\n }\n const xBarScale = d3ScaleBand()\n .domain(_xAxisLabels)\n .range(\n _isRtl\n ? [containerWidth - _margins.right! - _domainMargin, _margins.left! + _domainMargin]\n : [_margins.left! + _domainMargin, containerWidth - _margins.right! - _domainMargin],\n )\n .paddingInner(_xAxisInnerPadding)\n .paddingOuter(_xAxisOuterPadding);\n\n return { xBarScale, yBarScale };\n }\n\n const _isChartEmpty = (): boolean => {\n return !(\n props.data &&\n props.data.length > 0 &&\n props.data.some(item => item.chartData.length > 0 || (item.lineData && item.lineData.length > 0))\n );\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 function _getDomainMargins(containerWidth: number): Margins {\n _domainMargin = MIN_DOMAIN_MARGIN;\n\n /** Total width available to render the bars */\n const totalWidth = containerWidth - (_margins.left! + MIN_DOMAIN_MARGIN) - (_margins.right! + MIN_DOMAIN_MARGIN);\n /** Rate at which the space between the bars changes wrt the bar width */\n const barGapRate = _xAxisInnerPadding / (1 - _xAxisInnerPadding);\n\n if (_xAxisType === XAxisTypes.StringAxis) {\n if (isScalePaddingDefined(props.xAxisOuterPadding, props.xAxisPadding)) {\n // Setting the domain margin for string x-axis to 0 because the xAxisOuterPadding prop is now available\n // to adjust the space before the first bar and after the last bar.\n _domainMargin = 0;\n } else if (props.barWidth !== 'auto') {\n // Update the bar width so that when CartesianChart rerenders,\n // the following calculations don't use the previous bar width.\n _barWidth = getBarWidth(props.barWidth, props.maxBarWidth);\n /** Total width required to render the bars. Directly proportional to bar width */\n const reqWidth = (_xAxisLabels.length + (_xAxisLabels.length - 1) * barGapRate) * _barWidth;\n\n if (totalWidth >= reqWidth) {\n // Center align the chart by setting equal left and right margins for domain\n _domainMargin = MIN_DOMAIN_MARGIN + (totalWidth - reqWidth) / 2;\n }\n } else if (props.mode === 'plotly' && _xAxisLabels.length > 1) {\n // Calculate the remaining width after rendering bars at their maximum allowable width\n const bandwidth = totalWidth / (_xAxisLabels.length + (_xAxisLabels.length - 1) * barGapRate);\n const barWidth = getBarWidth(props.barWidth, props.maxBarWidth, bandwidth);\n let reqWidth = (_xAxisLabels.length + (_xAxisLabels.length - 1) * barGapRate) * barWidth;\n const margin1 = (totalWidth - reqWidth) / 2;\n\n // Calculate the remaining width after accounting for the space required to render x-axis labels\n const step = calculateLongestLabelWidth(_xAxisLabels) + 20;\n reqWidth = (_xAxisLabels.length - _xAxisInnerPadding) * step;\n const margin2 = (totalWidth - reqWidth) / 2;\n\n _domainMargin = MIN_DOMAIN_MARGIN + Math.max(0, Math.min(margin1, margin2));\n }\n } else {\n const data = (props.data?.map(point => point.xAxisPoint) as number[] | Date[] | undefined) || [];\n _barWidth = getBarWidth(props.barWidth, props.maxBarWidth, calculateAppropriateBarWidth(data, totalWidth));\n _domainMargin = MIN_DOMAIN_MARGIN + _barWidth / 2;\n }\n\n return {\n ..._margins,\n left: _margins.left! + _domainMargin,\n right: _margins.right! + _domainMargin,\n };\n }\n\n function _getChartTitle(): string {\n const { chartTitle, data } = props;\n const numLines = Object.keys(_lineObject).length;\n return (\n (chartTitle ? `${chartTitle}. ` : '') +\n `Vertical bar chart with ${data?.length || 0} stacked bars` +\n (numLines > 0 ? ` and ${numLines} lines` : '') +\n '. '\n );\n }\n\n const classes = useVerticalStackedBarChartStyles(props);\n function _createBar(\n xBarScale: any,\n yBarScale: NumericScale,\n containerHeight: number,\n xElement: SVGElement,\n ): JSX.Element[] {\n const { barCornerRadius = 0, barMinimumHeight = 0 } = props;\n const _isHavingLines = props.data.some(\n (item: VerticalStackedChartProps) => item.lineData && item.lineData.length > 0,\n );\n const shouldFocusWholeStack = _toFocusWholeStack(_isHavingLines);\n\n if (_xAxisType === XAxisTypes.StringAxis) {\n _barWidth = getBarWidth(props.barWidth, props.maxBarWidth, xBarScale.bandwidth());\n }\n\n const bars = _points.map((singleChartData: VerticalStackedChartProps, indexNumber: number) => {\n const xPoint = xBarScale(\n _xAxisType === XAxisTypes.NumericAxis\n ? (singleChartData.xAxisPoint as number)\n : _xAxisType === XAxisTypes.DateAxis\n ? (singleChartData.xAxisPoint as Date)\n : (singleChartData.xAxisPoint as string),\n );\n const xScaleBandwidthTranslate =\n _xAxisType !== XAxisTypes.StringAxis ? -_barWidth / 2 : (xBarScale.bandwidth() - _barWidth) / 2;\n\n let barTotalValue = 0;\n\n const barsToDisplay = singleChartData.chartData.filter(point => point.data !== 0);\n\n if (!barsToDisplay.length) {\n return undefined;\n }\n\n const { gapHeight, heightValueScale, absStackTotal } = _getBarGapAndScale(barsToDisplay, yBarScale);\n\n if (heightValueScale < 0) {\n return undefined;\n }\n\n const yBaseline = containerHeight - _margins.bottom! - yBarScale(Y_ORIGIN);\n let yPositiveStart = yBaseline;\n let yNegativeStart = yBaseline;\n let yPoint = 0;\n let heightOfLastBar = 0;\n\n const singleBar = barsToDisplay.map((point: VSChartDataPoint, index: number) => {\n const startColor = point.color ? point.color : _colors[index];\n const ref: RefArrayData = {};\n const shouldHighlight = _isLegendHighlighted(point.legend) || _noLegendHighlighted() ? true : false;\n const rectFocusProps = !shouldFocusWholeStack && {\n 'aria-label': _getAriaLabel(singleChartData, point),\n onMouseOver: (event: React.MouseEvent<SVGElement, MouseEvent>) =>\n _onRectHover(singleChartData.xAxisPoint, point, startColor, event),\n onMouseMove: (event: React.MouseEvent<SVGElement, MouseEvent>) =>\n _onRectHover(singleChartData.xAxisPoint, point, startColor, event),\n onMouseLeave: _handleMouseOut,\n onFocus: () => _onRectFocus(point, singleChartData.xAxisPoint as string, startColor, ref),\n onBlur: _handleMouseOut,\n onClick: (event: React.MouseEvent<SVGElement, MouseEvent>) => _onClick(point, event),\n role: 'img',\n tabIndex: !props.hideTooltip && shouldHighlight ? 0 : undefined,\n };\n\n let barHeight = Math.abs(heightValueScale * point.data);\n // FIXME: The current scaling logic may produce different min and gap heights for each bar stack.\n const minHeight = Math.max((heightValueScale * absStackTotal) / 100.0, barMinimumHeight);\n if (barHeight < minHeight) {\n barHeight = minHeight;\n }\n const gapOffset = index ? gapHeight : 0;\n if (point.data >= Y_ORIGIN) {\n yPositiveStart -= barHeight + gapOffset;\n yPoint = yPositiveStart;\n } else {\n yPoint = yNegativeStart + gapOffset;\n yNegativeStart = yPoint + barHeight;\n }\n\n barTotalValue += point.data;\n heightOfLastBar = index === barsToDisplay.length - 1 ? barHeight : 0;\n\n if (barCornerRadius && barHeight > barCornerRadius && index === barsToDisplay.length - 1) {\n return (\n <React.Fragment key={index + indexNumber + `${shouldFocusWholeStack}`}>\n <path\n className={classes.opacityChangeOnHover}\n d={`\n M ${xPoint} ${yPoint + barCornerRadius}\n a ${barCornerRadius} ${barCornerRadius} 0 0 1 ${barCornerRadius} ${-barCornerRadius}\n h ${_barWidth - 2 * barCornerRadius}\n a ${barCornerRadius} ${barCornerRadius} 0 0 1 ${barCornerRadius} ${barCornerRadius}\n v ${barHeight - barCornerRadius}\n h ${-_barWidth}\n z\n `}\n fill={startColor}\n rx={props.roundCorners ? 3 : 0}\n ref={e => (ref.refElement = e)}\n transform={`translate(${xScaleBandwidthTranslate}, 0)`}\n cursor={props.href ? 'pointer' : 'default'}\n {...rectFocusProps}\n />\n </React.Fragment>\n );\n }\n if (barHeight < 0) {\n return <React.Fragment key={index + indexNumber}> </React.Fragment>;\n }\n return (\n <React.Fragment key={index + indexNumber}>\n <rect\n className={classes.opacityChangeOnHover}\n x={xPoint}\n y={yPoint}\n width={_barWidth}\n height={barHeight}\n fill={startColor}\n opacity={shouldHighlight ? 1 : 0.1}\n cursor={props.href ? 'pointer' : 'default'}\n rx={props.roundCorners ? 3 : 0}\n ref={e => (ref.refElement = e)}\n {...rectFocusProps}\n transform={`translate(${xScaleBandwidthTranslate}, 0)`}\n />\n </React.Fragment>\n );\n });\n const groupRef: RefArrayData = {};\n const stackFocusProps = shouldFocusWholeStack && {\n 'aria-label': _getAriaLabel(singleChartData),\n onMouseOver: (event: any) => _onStackHover(singleChartData, event),\n onMouseMove: (event: any) => _onStackHover(singleChartData, event),\n onMouseLeave: _handleMouseOut,\n onFocus: () => _onStackFocus(singleChartData, groupRef),\n onBlur: _handleMouseOut,\n onClick: (event: any) => _onClick(singleChartData, event),\n role: 'img',\n tabIndex: !props.hideTooltip ? 0 : undefined,\n };\n let showLabel = false;\n let barLabel = 0;\n if (!props.hideLabels) {\n if (_noLegendHighlighted()) {\n showLabel = true;\n barLabel = barTotalValue;\n } else {\n barsToDisplay.forEach(point => {\n if (_isLegendHighlighted(point.legend)) {\n showLabel = true;\n barLabel += point.data;\n }\n });\n }\n }\n return (\n <g key={indexNumber + `${shouldFocusWholeStack}`}>\n <g id={`${indexNumber}-singleBar`} ref={e => (groupRef.refElement = e)} {...stackFocusProps}>\n {singleBar}\n </g>\n {!props.hideLabels && _barWidth >= 16 && showLabel && (\n <text\n x={xPoint + _barWidth / 2}\n //if total bar value >=0, show label above top bar, otherwise below bottom bar\n y={barLabel >= Y_ORIGIN ? yPoint - 6 : yPoint + heightOfLastBar + 12}\n textAnchor=\"middle\"\n className={classes.barLabel}\n aria-label={`Total: ${barLabel}`}\n role=\"img\"\n transform={`translate(${xScaleBandwidthTranslate}, 0)`}\n >\n {typeof props.yAxisTickFormat === 'function'\n ? props.yAxisTickFormat(barLabel)\n : formatScientificLimitWidth(barLabel)}\n </text>\n )}\n </g>\n );\n });\n if (!props.showXAxisLablesTooltip) {\n try {\n document.getElementById(_tooltipId) && document.getElementById(_tooltipId)!.remove();\n // eslint-disable-next-line no-empty\n } catch (e) {}\n }\n if (!props.wrapXAxisLables && props.showXAxisLablesTooltip) {\n const xAxisElement = d3Select(xElement).call(xBarScale);\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 bars.filter((bar): bar is JSX.Element => !!bar);\n }\n\n function _getMinMaxOfYAxis(\n dataset: DataPoint[],\n yAxisType?: YAxisType,\n useSecondaryYScale?: boolean,\n ): { startValue: number; endValue: number } {\n if (!useSecondaryYScale) {\n return findVSBCNumericMinMaxOfY(dataset);\n }\n\n const values: number[] = [];\n props.data.forEach(xPoint => {\n xPoint.lineData?.forEach(point => {\n // useSecondaryYScale is applicable only for lines in VSBC\n if (point.useSecondaryYScale) {\n values.push(point.y);\n }\n });\n });\n\n return { startValue: d3Min(values)!, endValue: d3Max(values)! };\n }\n\n if (!_isChartEmpty()) {\n _adjustProps();\n const _isHavingLines = props.data.some(\n (item: VerticalStackedChartProps) => item.lineData && item.lineData.length > 0,\n );\n const shouldFocusWholeStack = _toFocusWholeStack(_isHavingLines);\n _dataset = _createDataSetLayer();\n const legendBars: JSX.Element = _getLegendData(_points, _createLegendsForLine(props.data));\n const calloutProps: ModifiedCartesianChartProps['calloutProps'] = {\n color: color,\n legend: calloutLegend,\n XValue: xCalloutValue!,\n YValue: yCalloutValue ? yCalloutValue : dataForHoverCard,\n YValueHover: YValueHover,\n hoverXValue: hoverXValue,\n ...props.calloutProps,\n ...getAccessibleDataObject(callOutAccessibilityData),\n clickPosition: clickPosition,\n isPopoverOpen: isPopoverOpen,\n isCalloutForStack:\n props.isCalloutForStack || (_isHavingLines && (_noLegendHighlighted() || _getHighlightedLegend().length > 1)),\n isCartesian: true,\n customCallout: {\n customizedCallout: _getCustomizedCallout() !== null ? _getCustomizedCallout()! : undefined,\n customCalloutProps: props.calloutPropsPerDataPoint\n ? props.calloutPropsPerDataPoint(dataPointCalloutProps!)\n : undefined,\n },\n };\n const tickParams = {\n tickValues: props.tickValues,\n tickFormat: props.tickFormat,\n };\n return (\n <CartesianChart\n {...props}\n chartTitle={_getChartTitle()}\n points={_dataset}\n chartType={ChartTypes.VerticalStackedBarChart}\n xAxisType={_xAxisType}\n getMinMaxOfYAxis={_getMinMaxOfYAxis}\n calloutProps={calloutProps}\n createYAxis={createNumericYAxis}\n tickParams={tickParams}\n legendBars={legendBars}\n datasetForXAxisDomain={_xAxisLabels}\n isCalloutForStack={shouldFocusWholeStack}\n getDomainNRangeValues={_getDomainNRangeValues}\n createStringYAxis={createStringYAxis}\n barwidth={_barWidth}\n getmargins={_getMargins}\n getGraphData={_getGraphData}\n getAxisData={_getAxisData}\n onChartMouseLeave={_handleChartMouseLeave}\n getDomainMargins={_getDomainMargins}\n {...(_xAxisType === XAxisTypes.StringAxis && {\n xAxisInnerPadding: _xAxisInnerPadding,\n xAxisOuterPadding: _xAxisOuterPadding,\n })}\n componentRef={cartesianChartRef}\n /* eslint-disable react/jsx-no-bind */\n children={(props: ChildProps) => {\n return (\n <>\n <g>{_bars}</g>\n <g>\n {_isHavingLines &&\n _createLines(\n props.xScale!,\n props.yScalePrimary!,\n props.containerHeight!,\n props.containerWidth!,\n props.yScaleSecondary,\n )}\n </g>\n </>\n );\n }}\n />\n );\n }\n return <div id={_emptyChartId} role={'alert'} style={{ opacity: '0' }} aria-label={'Graph has no data to display'} />;\n};\nVerticalStackedBarChart.displayName = 'VerticalStackedBarChart';\n"],"names":["React","max","d3Max","min","d3Min","select","d3Select","useVerticalStackedBarChartStyles","scaleLinear","d3ScaleLinear","scaleBand","d3ScaleBand","scaleUtc","d3ScaleUtc","scaleTime","d3ScaleTime","useId","tokens","CartesianChart","ChartPopover","Legends","ChartTypes","getAccessibleDataObject","XAxisTypes","getTypeOfAxis","tooltipOfAxislabels","formatScientificLimitWidth","getBarWidth","getScalePadding","isScalePaddingDefined","calculateAppropriateBarWidth","formatDate","areArraysEqual","calculateLongestLabelWidth","useRtl","DataVizPalette","getColorFromToken","findVSBCNumericMinMaxOfY","createNumericYAxis","domainRangeOfDateForAreaLineVerticalBarChart","domainRangeOfVSBCNumeric","domainRangeOfXStringAxis","createStringYAxis","barGapMultiplier","barGapMin","MIN_DOMAIN_MARGIN","CircleVisbility","VerticalStackedBarChart","props","_isRtl","_createLegendsForLine","data","_getLineLegends","_tooltipId","_emptyChartId","_points","_dataset","_xAxisLabels","_bars","_xAxisType","length","xAxisPoint","StringAxis","_barWidth","_colors","_margins","_lineObject","_yMax","_yMin","_calloutAnchorPoint","_domainMargin","_xAxisInnerPadding","_xAxisOuterPadding","cartesianChartRef","useRef","Y_ORIGIN","selectedLegends","setSelectedLegends","useState","legendProps","activeLegend","setActiveLegend","undefined","dataForHoverCard","setDataForHoverCard","color","setColor","hoverXValue","setHoverXValue","YValueHover","setYValueHover","xCalloutValue","setXCalloutValue","yCalloutValue","setYCalloutValue","activeXAxisDataPoint","setActiveXAxisDataPoint","calloutLegend","setCalloutLegend","stackCalloutProps","setStackCalloutProps","dataPointCalloutProps","setDataPointCalloutProps","callOutAccessibilityData","setCallOutAccessibilityData","clickPosition","setClickPosition","x","y","isPopoverOpen","setPopoverOpen","prevPropsRef","useEffect","current","prevProps","height","width","_adjustProps","_createDataSetLayer","useImperativeHandle","componentRef","chartContainer","_getLegendData","lineLegends","hideLegend","defaultPalette","color6","color1","color5","color7","color10","actions","allowHoverOnLegend","forEach","singleChartData","chartData","point","Math","floor","random","checkSimilarLegends","filter","leg","title","legend","hoverAction","_handleChartMouseLeave","_onLegendHover","onMouseOutAction","_onLegendLeave","push","legendsOfLine","isLineLegendInBarChart","totalLegends","concat","legends","enabledWrapLines","enabledLegendsWrapLines","overflowText","legendsOverflowText","onChange","_onLegendSelectionChange","_getHighlightedLegend","_lineHoverOut","_lineHoverFocus","lineData","xItem","yAxisCalloutData","_onStackHoverFocus","stack","mouseEvent","clientX","clientY","boundingRect","getBoundingClientRect","left","top","_noLegendHighlighted","dataPoint","_isLegendHighlighted","isLinesPresent","item","shouldDrawBorderBottom","_updatePosition","sort","a","b","slice","reverse","Date","useUTC","stackCallOutAccessibilityData","_onClick","onBarClick","href","window","location","barWidth","maxBarWidth","defaultColors","_getFormattedLineData","xAxisInnerPadding","xAxisPadding","xAxisOuterPadding","tempArr","dataset","map","singlePointData","total","legendTitle","_selectedLegends","event","currentLegend","canSelectMultipleLegends","_getMargins","margins","_getGraphData","xScale","yScale","containerHeight","containerWidth","xElement","xBarScale","yBarScale","_getScales","_createBar","_getAxisData","yAxisData","yAxisDomainValues","domainValue","yMaxValue","yMinValue","includes","_getAriaLabel","xValue","xAxisCalloutData","pointValues","pt","yValue","join","lineValues","ln","ariaLabel","_getCustomizedCallout","_isHavingLines","some","onRenderCalloutPerStack","onRenderCalloutPerDataPoint","_renderCallout","_toFocusWholeStack","isCalloutForStack","shouldFocusStackOnly","_getDomainNRangeValues","points","chartType","isRTL","xAxisType","tickValues","shiftX","domainNRangeValue","NumericAxis","DateAxis","linesData","formattedLineData","index","line","lineObject","Object","keys","_createLines","yScalePrimary","yScaleSecondary","lines","borderForLines","dots","lineBorderWidth","lineOptions","Number","parseFloat","toString","xScaleBandwidthTranslate","bandwidth","shouldHighlight","i","x1","useSecondaryYScale","y1","x2","y2","key","opacity","strokeWidth","fill","strokeLinecap","stroke","colorNeutralBackground1","transform","strokeDasharray","onMouseOver","_lineHover","bind","onMouseLeave","circlePoint","subIndex","circleRef","refElement","noBarsAndLinesActive","circle","cx","cy","_onStackHover","r","_getCircleVisibilityAndRadius","radius","visibility","ref","e","tabIndex","hideTooltip","onFocus","_lineFocus","onBlur","_handleMouseOut","role","culture","XValue","YValue","_onRectHover","persist","_onRectFocusHover","chartDataPoint","xAxisDataPoint","_onRectFocus","_onStackFocus","groupRef","_getBarGapAndScale","bars","defaultTotalHeight","barGapMax","totalData","reduce","iter","value","abs","totalHeight","sumOfPercent","scalingRatio","gaps","gapHeight","heightValueScale","absStackTotal","yDomain","domain","range","bottom","xMax","xMin","nice","right","sDate","lDate","paddingInner","paddingOuter","_isChartEmpty","newX","newY","threshold","distance","sqrt","pow","_getDomainMargins","totalWidth","barGapRate","reqWidth","mode","margin1","step","margin2","_getChartTitle","chartTitle","numLines","classes","barCornerRadius","barMinimumHeight","shouldFocusWholeStack","indexNumber","xPoint","barTotalValue","barsToDisplay","yBaseline","yPositiveStart","yNegativeStart","yPoint","heightOfLastBar","singleBar","startColor","rectFocusProps","onMouseMove","onClick","barHeight","minHeight","gapOffset","Fragment","path","className","opacityChangeOnHover","d","rx","roundCorners","cursor","rect","stackFocusProps","showLabel","barLabel","hideLabels","g","id","text","textAnchor","aria-label","yAxisTickFormat","showXAxisLablesTooltip","document","getElementById","remove","wrapXAxisLables","xAxisElement","call","tooltipProps","tooltipCls","tooltip","axis","bar","_getMinMaxOfYAxis","yAxisType","values","startValue","endValue","legendBars","calloutProps","isCartesian","customCallout","customizedCallout","customCalloutProps","calloutPropsPerDataPoint","tickParams","tickFormat","getMinMaxOfYAxis","createYAxis","datasetForXAxisDomain","getDomainNRangeValues","barwidth","getmargins","getGraphData","getAxisData","onChartMouseLeave","getDomainMargins","children","div","style","displayName"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":"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"}
@@ -52,8 +52,7 @@ export const FocusableTooltipText = /*#__PURE__*/ React.forwardRef((props, forwa
52
52
  getTargetElement
53
53
  ]);
54
54
  return /*#__PURE__*/ React.createElement("div", {
55
- className: props.className,
56
- tabIndex: 0
55
+ className: props.className
57
56
  }, /*#__PURE__*/ React.createElement(Tooltip, {
58
57
  content: props.content,
59
58
  relationship: "description"
@@ -1 +1 @@
1
- {"version":3,"sources":["FocusableTooltipText.tsx"],"sourcesContent":["/* eslint-disable no-restricted-globals */\nimport * as React from 'react';\nimport { useCallback, useState, useEffect, useRef } from 'react';\nimport { Tooltip } from '@fluentui/react-tooltip';\nimport { hasOverflow } from './overflow-utils';\nimport { getAccessibleDataObject } from './index';\nimport { AccessibilityProps } from '../types/index';\nimport { Async } from './async-utils';\n\ninterface IFocusableTooltipTextProps {\n className?: string;\n content: string | JSX.Element | JSX.Element[];\n accessibilityData?: AccessibilityProps;\n}\n\nexport const FocusableTooltipText: React.FunctionComponent<IFocusableTooltipTextProps> = React.forwardRef<\n HTMLDivElement,\n IFocusableTooltipTextProps\n>((props, forwardedRef) => {\n const [textOverflow, setTextOverflow] = useState(false);\n const tooltipChild = useRef<HTMLSpanElement>(null);\n const async = useRef(new Async()).current;\n const resizeObserver = useRef<ResizeObserver>();\n\n const getTargetElement = useCallback((): HTMLElement | undefined => {\n if (!tooltipChild.current || !tooltipChild.current.parentElement) {\n return undefined;\n }\n return tooltipChild.current.parentElement;\n }, [tooltipChild]);\n\n const checkTextOverflow = useCallback(() => {\n const overflowElement = getTargetElement();\n const isTextOverflow = !!overflowElement && hasOverflow(overflowElement);\n if (isTextOverflow !== textOverflow) {\n setTextOverflow(isTextOverflow);\n }\n }, [getTargetElement, textOverflow, setTextOverflow]);\n\n useEffect(() => {\n checkTextOverflow();\n }, [checkTextOverflow]);\n\n useEffect(() => {\n // setup part executed only when the component mounts/updates\n const overflowElement = getTargetElement();\n if (window.ResizeObserver && overflowElement) {\n resizeObserver.current = new window.ResizeObserver(async.debounce(checkTextOverflow, 500));\n resizeObserver.current.observe(overflowElement);\n }\n // cleanup part executed only when the component unmounts\n return () => {\n resizeObserver.current?.disconnect();\n async.dispose();\n };\n }, [async, checkTextOverflow, getTargetElement]);\n\n return (\n <div className={props.className} tabIndex={0}>\n <Tooltip content={props.content} relationship=\"description\">\n <span {...getAccessibleDataObject(props.accessibilityData)} ref={tooltipChild} data-is-focusable={textOverflow}>\n {props.content}\n </span>\n </Tooltip>\n </div>\n );\n});\n"],"names":["React","useCallback","useState","useEffect","useRef","Tooltip","hasOverflow","getAccessibleDataObject","Async","FocusableTooltipText","forwardRef","props","forwardedRef","textOverflow","setTextOverflow","tooltipChild","async","current","resizeObserver","getTargetElement","parentElement","undefined","checkTextOverflow","overflowElement","isTextOverflow","window","ResizeObserver","debounce","observe","disconnect","dispose","div","className","tabIndex","content","relationship","span","accessibilityData","ref","data-is-focusable"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":"AAAA,wCAAwC,GACxC,YAAYA,WAAW,QAAQ;AAC/B,SAASC,WAAW,EAAEC,QAAQ,EAAEC,SAAS,EAAEC,MAAM,QAAQ,QAAQ;AACjE,SAASC,OAAO,QAAQ,0BAA0B;AAClD,SAASC,WAAW,QAAQ,mBAAmB;AAC/C,SAASC,uBAAuB,QAAQ,UAAU;AAElD,SAASC,KAAK,QAAQ,gBAAgB;AAQtC,OAAO,MAAMC,qCAA4ET,MAAMU,UAAU,CAGvG,CAACC,OAAOC;IACR,MAAM,CAACC,cAAcC,gBAAgB,GAAGZ,SAAS;IACjD,MAAMa,eAAeX,OAAwB;IAC7C,MAAMY,QAAQZ,OAAO,IAAII,SAASS,OAAO;IACzC,MAAMC,iBAAiBd;IAEvB,MAAMe,mBAAmBlB,YAAY;QACnC,IAAI,CAACc,aAAaE,OAAO,IAAI,CAACF,aAAaE,OAAO,CAACG,aAAa,EAAE;YAChE,OAAOC;QACT;QACA,OAAON,aAAaE,OAAO,CAACG,aAAa;IAC3C,GAAG;QAACL;KAAa;IAEjB,MAAMO,oBAAoBrB,YAAY;QACpC,MAAMsB,kBAAkBJ;QACxB,MAAMK,iBAAiB,CAAC,CAACD,mBAAmBjB,YAAYiB;QACxD,IAAIC,mBAAmBX,cAAc;YACnCC,gBAAgBU;QAClB;IACF,GAAG;QAACL;QAAkBN;QAAcC;KAAgB;IAEpDX,UAAU;QACRmB;IACF,GAAG;QAACA;KAAkB;IAEtBnB,UAAU;QACR,6DAA6D;QAC7D,MAAMoB,kBAAkBJ;QACxB,IAAIM,OAAOC,cAAc,IAAIH,iBAAiB;YAC5CL,eAAeD,OAAO,GAAG,IAAIQ,OAAOC,cAAc,CAACV,MAAMW,QAAQ,CAACL,mBAAmB;YACrFJ,eAAeD,OAAO,CAACW,OAAO,CAACL;QACjC;QACA,yDAAyD;QACzD,OAAO;gBACLL;aAAAA,0BAAAA,eAAeD,OAAO,cAAtBC,8CAAAA,wBAAwBW,UAAU;YAClCb,MAAMc,OAAO;QACf;IACF,GAAG;QAACd;QAAOM;QAAmBH;KAAiB;IAE/C,qBACE,oBAACY;QAAIC,WAAWrB,MAAMqB,SAAS;QAAEC,UAAU;qBACzC,oBAAC5B;QAAQ6B,SAASvB,MAAMuB,OAAO;QAAEC,cAAa;qBAC5C,oBAACC;QAAM,GAAG7B,wBAAwBI,MAAM0B,iBAAiB,CAAC;QAAEC,KAAKvB;QAAcwB,qBAAmB1B;OAC/FF,MAAMuB,OAAO;AAKxB,GAAG"}
1
+ {"version":3,"sources":["FocusableTooltipText.tsx"],"sourcesContent":["/* eslint-disable no-restricted-globals */\nimport * as React from 'react';\nimport { useCallback, useState, useEffect, useRef } from 'react';\nimport { Tooltip } from '@fluentui/react-tooltip';\nimport { hasOverflow } from './overflow-utils';\nimport { getAccessibleDataObject } from './index';\nimport { AccessibilityProps } from '../types/index';\nimport { Async } from './async-utils';\n\ninterface IFocusableTooltipTextProps {\n className?: string;\n content: string | JSX.Element | JSX.Element[];\n accessibilityData?: AccessibilityProps;\n}\n\nexport const FocusableTooltipText: React.FunctionComponent<IFocusableTooltipTextProps> = React.forwardRef<\n HTMLDivElement,\n IFocusableTooltipTextProps\n>((props, forwardedRef) => {\n const [textOverflow, setTextOverflow] = useState(false);\n const tooltipChild = useRef<HTMLSpanElement>(null);\n const async = useRef(new Async()).current;\n const resizeObserver = useRef<ResizeObserver>();\n\n const getTargetElement = useCallback((): HTMLElement | undefined => {\n if (!tooltipChild.current || !tooltipChild.current.parentElement) {\n return undefined;\n }\n return tooltipChild.current.parentElement;\n }, [tooltipChild]);\n\n const checkTextOverflow = useCallback(() => {\n const overflowElement = getTargetElement();\n const isTextOverflow = !!overflowElement && hasOverflow(overflowElement);\n if (isTextOverflow !== textOverflow) {\n setTextOverflow(isTextOverflow);\n }\n }, [getTargetElement, textOverflow, setTextOverflow]);\n\n useEffect(() => {\n checkTextOverflow();\n }, [checkTextOverflow]);\n\n useEffect(() => {\n // setup part executed only when the component mounts/updates\n const overflowElement = getTargetElement();\n if (window.ResizeObserver && overflowElement) {\n resizeObserver.current = new window.ResizeObserver(async.debounce(checkTextOverflow, 500));\n resizeObserver.current.observe(overflowElement);\n }\n // cleanup part executed only when the component unmounts\n return () => {\n resizeObserver.current?.disconnect();\n async.dispose();\n };\n }, [async, checkTextOverflow, getTargetElement]);\n\n return (\n <div className={props.className}>\n <Tooltip content={props.content} relationship=\"description\">\n <span {...getAccessibleDataObject(props.accessibilityData)} ref={tooltipChild} data-is-focusable={textOverflow}>\n {props.content}\n </span>\n </Tooltip>\n </div>\n );\n});\n"],"names":["React","useCallback","useState","useEffect","useRef","Tooltip","hasOverflow","getAccessibleDataObject","Async","FocusableTooltipText","forwardRef","props","forwardedRef","textOverflow","setTextOverflow","tooltipChild","async","current","resizeObserver","getTargetElement","parentElement","undefined","checkTextOverflow","overflowElement","isTextOverflow","window","ResizeObserver","debounce","observe","disconnect","dispose","div","className","content","relationship","span","accessibilityData","ref","data-is-focusable"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":"AAAA,wCAAwC,GACxC,YAAYA,WAAW,QAAQ;AAC/B,SAASC,WAAW,EAAEC,QAAQ,EAAEC,SAAS,EAAEC,MAAM,QAAQ,QAAQ;AACjE,SAASC,OAAO,QAAQ,0BAA0B;AAClD,SAASC,WAAW,QAAQ,mBAAmB;AAC/C,SAASC,uBAAuB,QAAQ,UAAU;AAElD,SAASC,KAAK,QAAQ,gBAAgB;AAQtC,OAAO,MAAMC,qCAA4ET,MAAMU,UAAU,CAGvG,CAACC,OAAOC;IACR,MAAM,CAACC,cAAcC,gBAAgB,GAAGZ,SAAS;IACjD,MAAMa,eAAeX,OAAwB;IAC7C,MAAMY,QAAQZ,OAAO,IAAII,SAASS,OAAO;IACzC,MAAMC,iBAAiBd;IAEvB,MAAMe,mBAAmBlB,YAAY;QACnC,IAAI,CAACc,aAAaE,OAAO,IAAI,CAACF,aAAaE,OAAO,CAACG,aAAa,EAAE;YAChE,OAAOC;QACT;QACA,OAAON,aAAaE,OAAO,CAACG,aAAa;IAC3C,GAAG;QAACL;KAAa;IAEjB,MAAMO,oBAAoBrB,YAAY;QACpC,MAAMsB,kBAAkBJ;QACxB,MAAMK,iBAAiB,CAAC,CAACD,mBAAmBjB,YAAYiB;QACxD,IAAIC,mBAAmBX,cAAc;YACnCC,gBAAgBU;QAClB;IACF,GAAG;QAACL;QAAkBN;QAAcC;KAAgB;IAEpDX,UAAU;QACRmB;IACF,GAAG;QAACA;KAAkB;IAEtBnB,UAAU;QACR,6DAA6D;QAC7D,MAAMoB,kBAAkBJ;QACxB,IAAIM,OAAOC,cAAc,IAAIH,iBAAiB;YAC5CL,eAAeD,OAAO,GAAG,IAAIQ,OAAOC,cAAc,CAACV,MAAMW,QAAQ,CAACL,mBAAmB;YACrFJ,eAAeD,OAAO,CAACW,OAAO,CAACL;QACjC;QACA,yDAAyD;QACzD,OAAO;gBACLL;aAAAA,0BAAAA,eAAeD,OAAO,cAAtBC,8CAAAA,wBAAwBW,UAAU;YAClCb,MAAMc,OAAO;QACf;IACF,GAAG;QAACd;QAAOM;QAAmBH;KAAiB;IAE/C,qBACE,oBAACY;QAAIC,WAAWrB,MAAMqB,SAAS;qBAC7B,oBAAC3B;QAAQ4B,SAAStB,MAAMsB,OAAO;QAAEC,cAAa;qBAC5C,oBAACC;QAAM,GAAG5B,wBAAwBI,MAAMyB,iBAAiB,CAAC;QAAEC,KAAKtB;QAAcuB,qBAAmBzB;OAC/FF,MAAMsB,OAAO;AAKxB,GAAG"}