@fluentui/react-charts 0.0.0-nightly-20250624-0406.1 → 0.0.0-nightly-20250626-0405.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1 +1 @@
1
- {"version":3,"sources":["HorizontalBarChartWithAxis.tsx"],"sourcesContent":["import * as React from 'react';\nimport { max as d3Max } from 'd3-array';\nimport { select as d3Select } from 'd3-selection';\nimport { scaleLinear as d3ScaleLinear, ScaleLinear as D3ScaleLinear, scaleBand as d3ScaleBand } from 'd3-scale';\nimport { Legend } from '../../components/Legends/Legends.types';\nimport { Legends } from '../../components/Legends/Legends';\nimport { useId } from '@fluentui/react-utilities';\nimport { useHorizontalBarChartWithAxisStyles } from './useHorizontalBarChartWithAxisStyles.styles';\nimport {\n AccessibilityProps,\n HorizontalBarChartWithAxisDataPoint,\n RefArrayData,\n Margins,\n ChartPopoverProps,\n Chart,\n} from '../../index';\nimport { ChildProps } from '../CommonComponents/CartesianChart.types';\nimport { CartesianChart } from '../CommonComponents/CartesianChart';\nimport { HorizontalBarChartWithAxisProps } from './HorizontalBarChartWithAxis.types';\nimport { ChartPopover } from '../CommonComponents/ChartPopover';\nimport {\n ChartTypes,\n IAxisData,\n getAccessibleDataObject,\n YAxisType,\n XAxisTypes,\n NumericAxis,\n StringAxis,\n getTypeOfAxis,\n getNextColor,\n areArraysEqual,\n useRtl,\n DataVizPalette,\n getColorFromToken,\n} from '../../utilities/index';\ntype ColorScale = (_p?: number) => string;\n\nexport const HorizontalBarChartWithAxis: React.FunctionComponent<HorizontalBarChartWithAxisProps> = React.forwardRef<\n HTMLDivElement,\n HorizontalBarChartWithAxisProps\n>((props, forwardedRef) => {\n const _refArray: RefArrayData[] = [];\n const _calloutId: string = useId('callout');\n const _isRtl: boolean = useRtl();\n const _tooltipId: string = useId('HBCWATooltipID_');\n const _xAxisType: XAxisTypes =\n props.data! && props.data!.length > 0\n ? (getTypeOfAxis(props.data![0].x, true) as XAxisTypes)\n : XAxisTypes.NumericAxis;\n const _yAxisType: YAxisType =\n props.data! && props.data!.length > 0\n ? (getTypeOfAxis(props.data![0].y, false) as YAxisType)\n : YAxisType.StringAxis;\n const _emptyChartId: string = useId('_HBCWithAxis_empty');\n let _points: HorizontalBarChartWithAxisDataPoint[] = [];\n let _barHeight: number = 0;\n let _colors: string[] = [];\n let _margins: Margins;\n let _bars: JSX.Element[];\n let _yAxisLabels: string[];\n let _xMax: number;\n let _calloutAnchorPoint: HorizontalBarChartWithAxisDataPoint | null;\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n let tooltipElement: any;\n const cartesianChartRef = React.useRef<Chart>(null);\n\n const [color, setColor] = React.useState<string>('');\n const [dataForHoverCard, setDataForHoverCard] = React.useState<number>(0);\n const [isLegendSelected, setIsLegendSelected] = React.useState<boolean>(\n (props.legendProps?.selectedLegends && props.legendProps.selectedLegends.length > 0) ||\n props.legendProps?.selectedLegend !== undefined,\n );\n const [isLegendHovered, setIsLegendHovered] = React.useState<boolean>(false);\n const [selectedLegendTitle, setSelectedLegendTitle] = React.useState<string>(props.legendProps?.selectedLegend ?? '');\n const [xCalloutValue, setXCalloutValue] = React.useState<string>('');\n const [yCalloutValue, setYCalloutValue] = React.useState<string>('');\n const [selectedLegends, setSelectedLegends] = React.useState<string[]>(props.legendProps?.selectedLegends || []);\n const [dataPointCalloutProps, setDataPointCalloutProps] = React.useState<HorizontalBarChartWithAxisDataPoint>();\n const [callOutAccessibilityData, setCallOutAccessibilityData] = React.useState<AccessibilityProps>();\n const [isPopoverOpen, setPopoverOpen] = React.useState<boolean>(false);\n const [clickPosition, setClickPosition] = React.useState({ x: 0, y: 0 });\n const prevPropsRef = React.useRef<HorizontalBarChartWithAxisProps | null>(null);\n\n React.useEffect(() => {\n if (prevPropsRef.current) {\n const prevProps = prevPropsRef.current;\n if (!areArraysEqual(prevProps.legendProps?.selectedLegends, props.legendProps?.selectedLegends)) {\n setSelectedLegends(props.legendProps?.selectedLegends || []);\n }\n }\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 const classes = useHorizontalBarChartWithAxisStyles(props);\n function _adjustProps(): void {\n _points = props.data || [];\n _barHeight = props.barHeight || 32;\n const defaultPalette: string[] = [\n getColorFromToken(DataVizPalette.color6),\n getColorFromToken(DataVizPalette.color1),\n getColorFromToken(DataVizPalette.color5),\n getColorFromToken(DataVizPalette.color7),\n ];\n _colors = props.colors! || defaultPalette;\n }\n\n function _getMargins(margins: Margins) {\n _margins = margins;\n }\n\n function _renderContentForOnlyBars(point: HorizontalBarChartWithAxisDataPoint): JSX.Element {\n const { useSingleColor = false } = props;\n let selectedPointIndex = 0;\n props.data!.forEach((yDataPoint: HorizontalBarChartWithAxisDataPoint, index: number) => {\n if (yDataPoint.y === point.y) {\n selectedPointIndex = index;\n }\n });\n // eslint-disable-next-line @typescript-eslint/no-shadow\n let color: string;\n if (useSingleColor) {\n //if useSingle color , then check if user has given a palette or not\n // and pick the first color from that or else from our paltette.\n color = props.colors ? _createColors()(1) : getNextColor(1, 0);\n } else {\n color = point.color ? point.color : props.colors ? _createColors()(point.x) : getNextColor(selectedPointIndex, 0);\n }\n return (\n <>\n <ChartPopover\n XValue={point.xAxisCalloutData || point.x.toString()}\n legend={point.legend}\n YValue={point.yAxisCalloutData || point.y}\n color={color}\n culture={props.culture ?? 'en-us'}\n clickPosition={clickPosition}\n isPopoverOpen={isPopoverOpen}\n />\n </>\n );\n }\n\n // eslint-disable-next-line @typescript-eslint/no-shadow\n function _renderCallout(props?: HorizontalBarChartWithAxisDataPoint): JSX.Element | null {\n return props ? _renderContentForOnlyBars(props) : null;\n }\n\n function _getCustomizedCallout() {\n return props.onRenderCalloutPerDataPoint\n ? props.onRenderCalloutPerDataPoint(dataPointCalloutProps, _renderCallout)\n : null;\n }\n\n function _getGraphData(\n xScale: NumericAxis,\n yScale: NumericAxis | StringAxis,\n containerHeight: number,\n containerWidth: number,\n xElement?: SVGElement | null,\n yElement?: SVGElement | null,\n ) {\n return (_bars =\n _yAxisType === YAxisType.NumericAxis\n ? _createNumericBars(containerHeight, containerWidth, xElement!, yElement!)\n : _createStringBars(containerHeight, containerWidth, xElement!, yElement!));\n }\n\n function _createColors(): D3ScaleLinear<string, string> | ColorScale {\n const increment = _colors.length <= 1 ? 1 : 1 / (_colors.length - 1);\n const { useSingleColor = false } = props;\n if (useSingleColor) {\n return (_p?: number) => {\n const { colors } = props;\n return colors && colors.length > 0 ? colors[0] : getColorFromToken(DataVizPalette.color16);\n };\n }\n const domainValues = [];\n for (let i = 0; i < _colors.length; i++) {\n domainValues.push(increment * i * _xMax);\n }\n const colorScale = d3ScaleLinear<string>().domain(domainValues).range(_colors);\n return colorScale;\n }\n\n function _refCallback(element: SVGRectElement, legendTitle: string): void {\n _refArray.push({ index: legendTitle, refElement: element });\n }\n\n function _onBarHover(\n point: HorizontalBarChartWithAxisDataPoint,\n // eslint-disable-next-line @typescript-eslint/no-shadow\n color: string,\n mouseEvent: React.MouseEvent<SVGElement, MouseEvent>,\n ): void {\n mouseEvent.persist();\n // eslint-disable-next-line @typescript-eslint/no-shadow\n if ((isLegendSelected === false || _isLegendHighlighted(point.legend)) && _calloutAnchorPoint !== point) {\n _calloutAnchorPoint = point;\n setPopoverOpen(true);\n _updatePosition(mouseEvent.clientX, mouseEvent.clientY);\n setDataForHoverCard(point.x);\n setSelectedLegendTitle(point.legend!);\n setColor(props.useSingleColor || props.enableGradient ? color : point.color!);\n // To display callout value, if no callout value given, taking given point.x value as a string.\n setXCalloutValue(point.yAxisCalloutData! || point.y.toString());\n setYCalloutValue(point.xAxisCalloutData || point.x.toString());\n setDataPointCalloutProps(point);\n setCallOutAccessibilityData(point.callOutAccessibilityData);\n }\n }\n\n function _onBarLeave(): void {\n setPopoverOpen(false);\n }\n\n function _handleChartMouseLeave(): void {\n _calloutAnchorPoint = null;\n setPopoverOpen(false);\n }\n\n // eslint-disable-next-line @typescript-eslint/no-shadow\n function _onBarFocus(point: HorizontalBarChartWithAxisDataPoint, refArrayIndexNumber: number, color: string): void {\n if ((isLegendSelected === false || _isLegendHighlighted(point.legend)) && _calloutAnchorPoint !== point) {\n // eslint-disable-next-line @typescript-eslint/no-shadow\n _refArray.forEach((obj: RefArrayData, index: number) => {\n if (refArrayIndexNumber === index) {\n setPopoverOpen(true);\n setSelectedLegendTitle(point.legend!);\n setDataForHoverCard(point.x);\n setColor(props.useSingleColor ? color : point.color!);\n setXCalloutValue(point.yAxisCalloutData || point.y.toString());\n setYCalloutValue(point.xAxisCalloutData! || point.x.toString());\n setDataPointCalloutProps(point);\n setCallOutAccessibilityData(point.callOutAccessibilityData);\n }\n });\n }\n }\n\n function _getScales(\n containerHeight: number,\n containerWidth: number,\n isNumericScale: boolean,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n ): { xBarScale: any; yBarScale: any } {\n if (isNumericScale) {\n const xMax = d3Max(_points, (point: HorizontalBarChartWithAxisDataPoint) => point.x as number)!;\n const yMax = d3Max(_points, (point: HorizontalBarChartWithAxisDataPoint) => point.y as number)!;\n const xBarScale = d3ScaleLinear()\n .domain(_isRtl ? [xMax, 0] : [0, xMax])\n .nice()\n .range([_margins.left!, containerWidth - _margins.right!]);\n const yBarScale = d3ScaleLinear()\n .domain([0, yMax])\n .range([containerHeight - _margins.bottom!, _margins.top!]);\n return { xBarScale, yBarScale };\n } else {\n const xMax = d3Max(_points, (point: HorizontalBarChartWithAxisDataPoint) => point.x as number)!;\n // please note these padding default values must be consistent in here\n // and CatrtesianChartBase w for more details refer example\n // http://using-d3js.com/04_07_ordinal_scales.html\n const yBarScale = d3ScaleBand()\n .domain(_yAxisLabels)\n .range([containerHeight - _margins.bottom! - _barHeight / 2, _margins.top! + _barHeight / 2])\n .padding(props.yAxisPadding || 0);\n\n const xBarScale = d3ScaleLinear()\n .domain(_isRtl ? [xMax, 0] : [0, xMax])\n .nice()\n .range([_margins.left!, containerWidth - _margins.right!]);\n return { xBarScale, yBarScale };\n }\n }\n\n function _createNumericBars(\n containerHeight: number,\n containerWidth: number,\n xElement: SVGElement,\n yElement: SVGElement,\n ): JSX.Element[] {\n const { useSingleColor = false } = props;\n const { xBarScale, yBarScale } = _getScales(containerHeight, containerWidth, true);\n const sortedBars: HorizontalBarChartWithAxisDataPoint[] = [..._points];\n sortedBars.sort((a, b) => {\n const aValue = typeof a.y === 'number' ? a.y : parseFloat(a.y);\n const bValue = typeof b.y === 'number' ? b.y : parseFloat(b.y);\n return bValue - aValue;\n });\n\n const bars = sortedBars.map((point: HorizontalBarChartWithAxisDataPoint, index: number) => {\n let shouldHighlight = true;\n if (isLegendHovered || isLegendSelected) {\n shouldHighlight = _isLegendHighlighted(point.legend);\n }\n const barHeight: number = Math.max(yBarScale(point.y), 0);\n if (barHeight < 1) {\n return <React.Fragment key={point.x}> </React.Fragment>;\n }\n let startColor: string;\n if (useSingleColor) {\n //if useSingle color , then check if user has given a palette or not\n // and pick the first color from that or else from our paltette.\n startColor = props.colors ? _createColors()(1) : getNextColor(1, 0);\n } else {\n startColor = props.colors ? _createColors()(point.x) : getNextColor(index, 0);\n }\n\n startColor = point.color && !useSingleColor ? point.color : startColor;\n\n return (\n <React.Fragment key={`${index}_${point.x}`}>\n <rect\n key={point.y}\n x={_isRtl ? xBarScale(point.x) : _margins.left!}\n y={yBarScale(point.y) - _barHeight / 2}\n data-is-focusable={shouldHighlight}\n width={\n _isRtl\n ? containerWidth - _margins.right! - Math.max(xBarScale(point.x), 0)\n : Math.max(xBarScale(point.x), 0) - _margins.left!\n }\n height={_barHeight}\n ref={(e: SVGRectElement) => {\n _refCallback(e, point.legend!);\n }}\n rx={props.roundCorners ? 3 : 0}\n onClick={point.onClick}\n onMouseOver={(event: React.MouseEvent<SVGElement, MouseEvent>) => _onBarHover(point, startColor, event)}\n aria-label={_getAriaLabel(point)}\n role=\"img\"\n aria-labelledby={`toolTip${_calloutId}`}\n onMouseLeave={_onBarLeave}\n onFocus={() => _onBarFocus(point, index, startColor)}\n onBlur={_onBarLeave}\n fill={startColor}\n opacity={shouldHighlight ? 1 : 0.1}\n tabIndex={point.legend !== '' ? 0 : undefined}\n />\n </React.Fragment>\n );\n });\n return bars;\n }\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n function _tooltipOfYAxislabels(ytooltipProps: any) {\n const { tooltipCls, yAxis, id } = ytooltipProps;\n if (yAxis === null) {\n return null;\n }\n const div = d3Select('body').append('div').attr('id', id).attr('class', tooltipCls).style('opacity', 0);\n const aa = yAxis!.selectAll('#BaseSpan')._groups[0];\n const baseSpanLength = aa && Object.keys(aa)!.length;\n const originalDataArray: string[] = [];\n for (let i = 0; i < baseSpanLength; i++) {\n const originalData = aa[i].dataset && (Object.values(aa[i].dataset)[0] as string);\n originalDataArray.push(originalData);\n }\n const tickObject = yAxis!.selectAll('.tick')._groups[0];\n const tickObjectLength = tickObject && Object.keys(tickObject)!.length;\n for (let i = 0; i < tickObjectLength; i++) {\n const d1 = tickObject[i];\n d3Select(d1)\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n .on('mouseover', (event: any, d) => {\n if (!tooltipElement) {\n div.style('opacity', 0.9);\n div\n .text(originalDataArray[i])\n .style('left', event.pageX + 'px')\n .style('top', event.pageY - 28 + 'px');\n }\n })\n .on('mouseout', d => {\n div.style('opacity', 0);\n });\n }\n }\n\n function _createStringBars(\n containerHeight: number,\n containerWidth: number,\n xElement: SVGElement,\n yElement: SVGElement,\n ): JSX.Element[] {\n const { xBarScale, yBarScale } = _getScales(containerHeight, containerWidth, false);\n const { useSingleColor = false } = props;\n const bars = _points.map((point: HorizontalBarChartWithAxisDataPoint, index: number) => {\n let shouldHighlight = true;\n if (isLegendHovered || isLegendSelected) {\n shouldHighlight = _isLegendHighlighted(point.legend);\n }\n const barHeight: number = Math.max(yBarScale(point.y), 0);\n if (barHeight < 1) {\n return <React.Fragment key={point.x}> </React.Fragment>;\n }\n let startColor: string;\n if (useSingleColor) {\n //if useSingle color , then check if user has given a palette or not\n // and pick the first color from that or else from our paltette.\n startColor = props.colors ? _createColors()(1) : getNextColor(1, 0);\n } else {\n startColor = props.colors ? _createColors()(point.x) : getNextColor(index, 0);\n }\n\n startColor = point.color && !useSingleColor ? point.color : startColor;\n\n return (\n <React.Fragment key={`${index}_${point.x}`}>\n <rect\n transform={`translate(0,${0.5 * (yBarScale.bandwidth() - _barHeight)})`}\n key={point.x}\n x={_isRtl ? xBarScale(point.x) : _margins.left!}\n y={yBarScale(point.y)}\n rx={props.roundCorners ? 3 : 0}\n width={\n _isRtl\n ? containerWidth - _margins.right! - Math.max(xBarScale(point.x), 0)\n : Math.max(xBarScale(point.x), 0) - _margins.left!\n }\n height={_barHeight}\n aria-labelledby={`toolTip${_calloutId}`}\n aria-label={_getAriaLabel(point)}\n role=\"img\"\n ref={(e: SVGRectElement) => {\n _refCallback(e, point.legend!);\n }}\n onClick={point.onClick}\n onMouseOver={(event: React.MouseEvent<SVGElement, MouseEvent>) => _onBarHover(point, startColor, event)}\n onMouseLeave={_onBarLeave}\n onBlur={_onBarLeave}\n data-is-focusable={shouldHighlight}\n opacity={shouldHighlight ? 1 : 0.1}\n onFocus={() => _onBarFocus(point, index, startColor)}\n fill={startColor}\n tabIndex={point.legend !== '' ? 0 : undefined}\n />\n </React.Fragment>\n );\n });\n\n // Removing un wanted tooltip div from DOM, when prop not provided, for proper cleanup\n // of unwanted DOM elements, to prevent flacky behaviour in tooltips , that might occur\n // in creating tooltips when tooltips are enabled( as we try to recreate a tspan with _tooltipId)\n if (!props.showYAxisLablesTooltip) {\n try {\n // eslint-disable-next-line @nx/workspace-no-restricted-globals\n document.getElementById(_tooltipId) && document.getElementById(_tooltipId)!.remove();\n //eslint-disable-next-line no-empty\n } catch (e) {}\n }\n // Used to display tooltip at y axis labels.\n if (props.showYAxisLablesTooltip) {\n const yAxisElement = d3Select(yElement).call(yBarScale);\n if (!tooltipElement) {\n try {\n // eslint-disable-next-line @nx/workspace-no-restricted-globals\n document.getElementById(_tooltipId) && document.getElementById(_tooltipId)!.remove();\n //eslint-disable-next-line no-empty\n } catch (e) {}\n }\n const ytooltipProps = {\n tooltipCls: classes.tooltip!,\n id: _tooltipId,\n yAxis: yAxisElement,\n };\n yAxisElement && _tooltipOfYAxislabels(ytooltipProps);\n }\n return bars;\n }\n\n function _onLegendHover(customMessage: string): void {\n if (!_isLegendSelected()) {\n setIsLegendHovered(true);\n setSelectedLegendTitle(customMessage);\n }\n }\n\n function _onLegendLeave(isLegendFocused?: boolean): void {\n if (!!isLegendFocused || !_isLegendSelected()) {\n setIsLegendHovered(false);\n setSelectedLegendTitle('');\n setIsLegendSelected(isLegendFocused ? false : _isLegendSelected());\n }\n }\n\n function _getLegendData(data: HorizontalBarChartWithAxisDataPoint[]): JSX.Element {\n const { useSingleColor } = props;\n const actions: Legend[] = [];\n\n data.forEach((point: HorizontalBarChartWithAxisDataPoint, _index: number) => {\n // eslint-disable-next-line @typescript-eslint/no-shadow\n const color: string = useSingleColor ? (props.colors ? _createColors()(1) : getNextColor(1, 0)) : point.color!;\n\n // mapping data to the format Legends component needs\n const legend: Legend = {\n title: point.legend!,\n color,\n hoverAction: () => {\n _handleChartMouseLeave();\n _onLegendHover(point.legend!);\n },\n // eslint-disable-next-line @typescript-eslint/no-shadow\n onMouseOutAction: (isLegendSelected?: boolean) => {\n _onLegendLeave(isLegendSelected);\n },\n };\n actions.push(legend);\n });\n const legends = (\n <Legends\n legends={actions}\n enabledWrapLines={props.enabledLegendsWrapLines}\n overflowText={props.legendsOverflowText}\n {...props.legendProps}\n onChange={_onLegendSelectionChange}\n />\n );\n return legends;\n }\n\n function _isLegendSelected(): boolean {\n return isLegendSelected!;\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(legend?: string) {\n return _getHighlightedLegend().includes(legend!);\n }\n\n function _getHighlightedLegend() {\n return selectedLegends.length > 0 ? selectedLegends : selectedLegendTitle ? [selectedLegendTitle] : [];\n }\n\n function _onLegendSelectionChange(\n // eslint-disable-next-line @typescript-eslint/no-shadow\n selectedLegends: string[],\n event: React.MouseEvent<HTMLButtonElement>,\n currentLegend?: Legend,\n ): void {\n if (props.legendProps?.canSelectMultipleLegends) {\n setSelectedLegends(selectedLegends);\n setSelectedLegendTitle(currentLegend?.title!);\n } else {\n setSelectedLegends(selectedLegends.slice(-1));\n setSelectedLegendTitle(currentLegend?.title!);\n }\n setIsLegendSelected(selectedLegends.length > 0);\n if (props.legendProps?.onChange) {\n props.legendProps.onChange(selectedLegends, event, currentLegend);\n }\n }\n\n function _getAxisData(yAxisData: IAxisData) {\n if (yAxisData && yAxisData.yAxisDomainValues.length) {\n // For HBCWA x and y Values are swapped\n const { yAxisDomainValues: domainValue } = yAxisData;\n _xMax = Math.max(domainValue[domainValue.length - 1], props.xMaxValue || 0);\n }\n }\n function _getAriaLabel(point: HorizontalBarChartWithAxisDataPoint): string {\n const xValue = point.xAxisCalloutData || point.x;\n const yValue = point.yAxisCalloutData || point.y;\n return point.callOutAccessibilityData?.ariaLabel || `${xValue}. ` + `${yValue}.`;\n }\n\n function _getChartTitle(): string {\n const { chartTitle, data } = props;\n return (chartTitle ? `${chartTitle}. ` : '') + `Horizontal bar chart with ${data?.length || 0} bars. `;\n }\n\n function _isChartEmpty(): boolean {\n return !(props.data && props.data.length > 0);\n }\n\n function _updatePosition(newX: number, newY: number): void {\n const threshold = 1; // Set a threshold for movement\n const { x, y } = clickPosition;\n\n // Calculate the distance moved\n const distance = Math.sqrt(Math.pow(newX - x, 2) + Math.pow(newY - y, 2));\n // Update the position only if the distance moved is greater than the threshold\n if (distance > threshold) {\n setClickPosition({ x: newX, y: newY });\n setPopoverOpen(true);\n }\n }\n\n if (!_isChartEmpty()) {\n _adjustProps();\n const calloutProps: ChartPopoverProps = {\n color: color,\n legend: selectedLegendTitle,\n XValue: xCalloutValue,\n YValue: yCalloutValue ? yCalloutValue : dataForHoverCard,\n ...props.calloutProps,\n ...getAccessibleDataObject(callOutAccessibilityData),\n customCallout: {\n customizedCallout: _getCustomizedCallout() !== null ? _getCustomizedCallout()! : undefined,\n customCalloutProps: props.calloutPropsPerDataPoint\n ? props.calloutPropsPerDataPoint(dataPointCalloutProps!)\n : undefined,\n },\n isCartesian: true,\n isPopoverOpen,\n clickPosition,\n };\n const tickParams = {\n tickValues: props.tickValues,\n tickFormat: props.tickFormat,\n };\n\n const reversedBars = [..._points].reverse();\n _yAxisLabels = reversedBars.map((point: HorizontalBarChartWithAxisDataPoint) => point.y as string);\n _xMax = Math.max(d3Max(_points, (point: HorizontalBarChartWithAxisDataPoint) => point.x)!, props.xMaxValue || 0);\n const legendBars: JSX.Element = _getLegendData(_points);\n return (\n <CartesianChart\n {...props}\n chartTitle={_getChartTitle()}\n points={_points}\n chartType={ChartTypes.HorizontalBarChartWithAxis}\n xAxisType={_xAxisType}\n yAxisType={_yAxisType}\n stringDatasetForYAxisDomain={_yAxisLabels}\n calloutProps={calloutProps}\n tickParams={tickParams}\n legendBars={legendBars}\n barwidth={_barHeight}\n getmargins={_getMargins}\n getGraphData={_getGraphData}\n getAxisData={_getAxisData}\n onChartMouseLeave={_handleChartMouseLeave}\n componentRef={cartesianChartRef}\n /* eslint-disable react/jsx-no-bind */\n // eslint-disable-next-line @typescript-eslint/no-shadow\n children={(props: ChildProps) => {\n return (\n <>\n <g>{_bars}</g>\n </>\n );\n }}\n />\n );\n } else {\n return (\n <div id={_emptyChartId} role={'alert'} style={{ opacity: '0' }} aria-label={'Graph has no data to display'} />\n );\n }\n});\nHorizontalBarChartWithAxis.displayName = 'HorizontalBarChartWithAxis';\n"],"names":["React","max","d3Max","select","d3Select","scaleLinear","d3ScaleLinear","scaleBand","d3ScaleBand","Legends","useId","useHorizontalBarChartWithAxisStyles","CartesianChart","ChartPopover","ChartTypes","getAccessibleDataObject","YAxisType","XAxisTypes","getTypeOfAxis","getNextColor","areArraysEqual","useRtl","DataVizPalette","getColorFromToken","HorizontalBarChartWithAxis","forwardRef","props","forwardedRef","_refArray","_calloutId","_isRtl","_tooltipId","_xAxisType","data","length","x","NumericAxis","_yAxisType","y","StringAxis","_emptyChartId","_points","_barHeight","_colors","_margins","_bars","_yAxisLabels","_xMax","_calloutAnchorPoint","tooltipElement","cartesianChartRef","useRef","color","setColor","useState","dataForHoverCard","setDataForHoverCard","isLegendSelected","setIsLegendSelected","legendProps","selectedLegends","selectedLegend","undefined","isLegendHovered","setIsLegendHovered","selectedLegendTitle","setSelectedLegendTitle","xCalloutValue","setXCalloutValue","yCalloutValue","setYCalloutValue","setSelectedLegends","dataPointCalloutProps","setDataPointCalloutProps","callOutAccessibilityData","setCallOutAccessibilityData","isPopoverOpen","setPopoverOpen","clickPosition","setClickPosition","prevPropsRef","useEffect","current","prevProps","useImperativeHandle","componentRef","chartContainer","classes","_adjustProps","barHeight","defaultPalette","color6","color1","color5","color7","colors","_getMargins","margins","_renderContentForOnlyBars","point","useSingleColor","selectedPointIndex","forEach","yDataPoint","index","_createColors","XValue","xAxisCalloutData","toString","legend","YValue","yAxisCalloutData","culture","_renderCallout","_getCustomizedCallout","onRenderCalloutPerDataPoint","_getGraphData","xScale","yScale","containerHeight","containerWidth","xElement","yElement","_createNumericBars","_createStringBars","increment","_p","color16","domainValues","i","push","colorScale","domain","range","_refCallback","element","legendTitle","refElement","_onBarHover","mouseEvent","persist","_isLegendHighlighted","_updatePosition","clientX","clientY","enableGradient","_onBarLeave","_handleChartMouseLeave","_onBarFocus","refArrayIndexNumber","obj","_getScales","isNumericScale","xMax","yMax","xBarScale","nice","left","right","yBarScale","bottom","top","padding","yAxisPadding","sortedBars","sort","a","b","aValue","parseFloat","bValue","bars","map","shouldHighlight","Math","Fragment","key","startColor","rect","data-is-focusable","width","height","ref","e","rx","roundCorners","onClick","onMouseOver","event","aria-label","_getAriaLabel","role","aria-labelledby","onMouseLeave","onFocus","onBlur","fill","opacity","tabIndex","_tooltipOfYAxislabels","ytooltipProps","tooltipCls","yAxis","id","div","append","attr","style","aa","selectAll","_groups","baseSpanLength","Object","keys","originalDataArray","originalData","dataset","values","tickObject","tickObjectLength","d1","on","d","text","pageX","pageY","transform","bandwidth","showYAxisLablesTooltip","document","getElementById","remove","yAxisElement","call","tooltip","_onLegendHover","customMessage","_isLegendSelected","_onLegendLeave","isLegendFocused","_getLegendData","actions","_index","title","hoverAction","onMouseOutAction","legends","enabledWrapLines","enabledLegendsWrapLines","overflowText","legendsOverflowText","onChange","_onLegendSelectionChange","_getHighlightedLegend","includes","currentLegend","canSelectMultipleLegends","slice","_getAxisData","yAxisData","yAxisDomainValues","domainValue","xMaxValue","xValue","yValue","ariaLabel","_getChartTitle","chartTitle","_isChartEmpty","newX","newY","threshold","distance","sqrt","pow","calloutProps","customCallout","customizedCallout","customCalloutProps","calloutPropsPerDataPoint","isCartesian","tickParams","tickValues","tickFormat","reversedBars","reverse","legendBars","points","chartType","xAxisType","yAxisType","stringDatasetForYAxisDomain","barwidth","getmargins","getGraphData","getAxisData","onChartMouseLeave","children","g","displayName"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":"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"}
1
+ {"version":3,"sources":["HorizontalBarChartWithAxis.tsx"],"sourcesContent":["import * as React from 'react';\nimport { max as d3Max, min as d3Min } from 'd3-array';\nimport { select as d3Select } from 'd3-selection';\nimport { scaleLinear as d3ScaleLinear, ScaleLinear as D3ScaleLinear, scaleBand as d3ScaleBand } from 'd3-scale';\nimport { Legend } from '../../components/Legends/Legends.types';\nimport { Legends } from '../../components/Legends/Legends';\nimport { useId } from '@fluentui/react-utilities';\nimport { useHorizontalBarChartWithAxisStyles } from './useHorizontalBarChartWithAxisStyles.styles';\nimport {\n AccessibilityProps,\n HorizontalBarChartWithAxisDataPoint,\n RefArrayData,\n Margins,\n ChartPopoverProps,\n Chart,\n} from '../../index';\nimport { ChildProps } from '../CommonComponents/CartesianChart.types';\nimport { CartesianChart } from '../CommonComponents/CartesianChart';\nimport { HorizontalBarChartWithAxisProps } from './HorizontalBarChartWithAxis.types';\nimport { ChartPopover } from '../CommonComponents/ChartPopover';\nimport {\n ChartTypes,\n IAxisData,\n getAccessibleDataObject,\n YAxisType,\n XAxisTypes,\n NumericAxis,\n StringAxis,\n getTypeOfAxis,\n getNextColor,\n areArraysEqual,\n useRtl,\n DataVizPalette,\n getColorFromToken,\n computeLongestBars,\n IDomainNRange,\n domainRangeOfNumericForHorizontalBarChartWithAxis,\n groupChartDataByYValue,\n MIN_DOMAIN_MARGIN,\n} from '../../utilities/index';\nimport { getClosestPairDiffAndRange } from '../../utilities/vbc-utils';\ntype ColorScale = (_p?: number) => string;\n\nexport const HorizontalBarChartWithAxis: React.FunctionComponent<HorizontalBarChartWithAxisProps> = React.forwardRef<\n HTMLDivElement,\n HorizontalBarChartWithAxisProps\n>((props, forwardedRef) => {\n const _refArray: RefArrayData[] = [];\n const _calloutId: string = useId('callout');\n const _isRtl: boolean = useRtl();\n const _tooltipId: string = useId('HBCWATooltipID_');\n const _xAxisType: XAxisTypes =\n props.data! && props.data!.length > 0\n ? (getTypeOfAxis(props.data![0].x, true) as XAxisTypes)\n : XAxisTypes.NumericAxis;\n const _yAxisType: YAxisType =\n props.data! && props.data!.length > 0\n ? (getTypeOfAxis(props.data![0].y, false) as YAxisType)\n : YAxisType.StringAxis;\n const _emptyChartId: string = useId('_HBCWithAxis_empty');\n let _points: HorizontalBarChartWithAxisDataPoint[] = [];\n let _barHeight: number = 0;\n let _colors: string[] = [];\n let _margins: Margins;\n let _bars: JSX.Element[];\n let _yAxisLabels: string[];\n let _xMax: number;\n let _calloutAnchorPoint: HorizontalBarChartWithAxisDataPoint | null;\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n let tooltipElement: any;\n let _longestBarPositiveTotalValue: number;\n let _longestBarNegativeTotalValue: number;\n let _domainMargin: number = MIN_DOMAIN_MARGIN;\n let _yAxisPadding: number = props.yAxisPadding ?? 0.5;\n const cartesianChartRef = React.useRef<Chart>(null);\n const X_ORIGIN: number = 0;\n\n const [color, setColor] = React.useState<string>('');\n const [dataForHoverCard, setDataForHoverCard] = React.useState<number>(0);\n const [isLegendSelected, setIsLegendSelected] = React.useState<boolean>(\n (props.legendProps?.selectedLegends && props.legendProps.selectedLegends.length > 0) ||\n props.legendProps?.selectedLegend !== undefined,\n );\n const [isLegendHovered, setIsLegendHovered] = React.useState<boolean>(false);\n const [selectedLegendTitle, setSelectedLegendTitle] = React.useState<string>(props.legendProps?.selectedLegend ?? '');\n const [xCalloutValue, setXCalloutValue] = React.useState<string>('');\n const [yCalloutValue, setYCalloutValue] = React.useState<string>('');\n const [selectedLegends, setSelectedLegends] = React.useState<string[]>(props.legendProps?.selectedLegends || []);\n const [dataPointCalloutProps, setDataPointCalloutProps] = React.useState<HorizontalBarChartWithAxisDataPoint>();\n const [callOutAccessibilityData, setCallOutAccessibilityData] = React.useState<AccessibilityProps>();\n const [isPopoverOpen, setPopoverOpen] = React.useState<boolean>(false);\n const [clickPosition, setClickPosition] = React.useState({ x: 0, y: 0 });\n const prevPropsRef = React.useRef<HorizontalBarChartWithAxisProps | null>(null);\n\n React.useEffect(() => {\n if (prevPropsRef.current) {\n const prevProps = prevPropsRef.current;\n if (!areArraysEqual(prevProps.legendProps?.selectedLegends, props.legendProps?.selectedLegends)) {\n setSelectedLegends(props.legendProps?.selectedLegends || []);\n }\n }\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 const classes = useHorizontalBarChartWithAxisStyles(props);\n function _adjustProps(): void {\n _points = props.data || [];\n _barHeight = props.barHeight || 32;\n const defaultPalette: string[] = [\n getColorFromToken(DataVizPalette.color6),\n getColorFromToken(DataVizPalette.color1),\n getColorFromToken(DataVizPalette.color5),\n getColorFromToken(DataVizPalette.color7),\n ];\n _colors = props.colors! || defaultPalette;\n }\n\n function _getMargins(margins: Margins) {\n _margins = margins;\n }\n\n function _renderContentForOnlyBars(point: HorizontalBarChartWithAxisDataPoint): JSX.Element {\n const { useSingleColor = false } = props;\n let selectedPointIndex = 0;\n props.data!.forEach((yDataPoint: HorizontalBarChartWithAxisDataPoint, index: number) => {\n if (yDataPoint.y === point.y) {\n selectedPointIndex = index;\n }\n });\n // eslint-disable-next-line @typescript-eslint/no-shadow\n let color: string;\n if (useSingleColor) {\n //if useSingle color , then check if user has given a palette or not\n // and pick the first color from that or else from our paltette.\n color = props.colors ? _createColors()(1) : getNextColor(1, 0);\n } else {\n color = point.color ? point.color : props.colors ? _createColors()(point.x) : getNextColor(selectedPointIndex, 0);\n }\n return (\n <>\n <ChartPopover\n XValue={point.xAxisCalloutData || point.x.toString()}\n legend={point.legend}\n YValue={point.yAxisCalloutData || point.y}\n color={color}\n culture={props.culture ?? 'en-us'}\n clickPosition={clickPosition}\n isPopoverOpen={isPopoverOpen}\n />\n </>\n );\n }\n\n // eslint-disable-next-line @typescript-eslint/no-shadow\n function _renderCallout(props?: HorizontalBarChartWithAxisDataPoint): JSX.Element | null {\n return props ? _renderContentForOnlyBars(props) : null;\n }\n\n function _getCustomizedCallout() {\n return props.onRenderCalloutPerDataPoint\n ? props.onRenderCalloutPerDataPoint(dataPointCalloutProps, _renderCallout)\n : null;\n }\n\n function _getGraphData(\n xScale: NumericAxis,\n yScale: NumericAxis | StringAxis,\n containerHeight: number,\n containerWidth: number,\n xElement?: SVGElement | null,\n yElement?: SVGElement | null,\n ) {\n const stackedChartData = groupChartDataByYValue(_points);\n const longestBars = computeLongestBars(stackedChartData, X_ORIGIN);\n _longestBarPositiveTotalValue = longestBars.longestPositiveBar;\n _longestBarNegativeTotalValue = longestBars.longestNegativeBar;\n\n const { xBarScale, yBarScale } =\n _yAxisType === YAxisType.NumericAxis\n ? _getScales(containerHeight, containerWidth, true)\n : _getScales(containerHeight, containerWidth, false);\n const xRange = xBarScale.range();\n let allBars: JSX.Element[] = [];\n // when the chart mounts, the xRange[1] is sometimes seen to be < 0 (like -40) while xRange[0] > 0.\n if (xRange[0] < xRange[1]) {\n allBars = stackedChartData\n .map(singleBarData =>\n _yAxisType === YAxisType.NumericAxis\n ? _createNumericBars(\n containerHeight,\n containerWidth,\n xElement!,\n yElement!,\n singleBarData,\n xBarScale,\n yBarScale,\n )\n : _createStringBars(\n containerHeight,\n containerWidth,\n xElement!,\n yElement!,\n singleBarData,\n xBarScale,\n yBarScale,\n ),\n )\n .flat();\n }\n\n return (_bars = allBars);\n }\n\n function _createColors(): D3ScaleLinear<string, string> | ColorScale {\n const increment = _colors.length <= 1 ? 1 : 1 / (_colors.length - 1);\n const { useSingleColor = false } = props;\n if (useSingleColor) {\n return (_p?: number) => {\n const { colors } = props;\n return colors && colors.length > 0 ? colors[0] : getColorFromToken(DataVizPalette.color16);\n };\n }\n const domainValues = [];\n for (let i = 0; i < _colors.length; i++) {\n domainValues.push(increment * i * _xMax);\n }\n const colorScale = d3ScaleLinear<string>().domain(domainValues).range(_colors);\n return colorScale;\n }\n\n function _refCallback(element: SVGRectElement, legendTitle: string): void {\n _refArray.push({ index: legendTitle, refElement: element });\n }\n\n function _onBarHover(\n point: HorizontalBarChartWithAxisDataPoint,\n // eslint-disable-next-line @typescript-eslint/no-shadow\n color: string,\n mouseEvent: React.MouseEvent<SVGElement, MouseEvent>,\n ): void {\n mouseEvent.persist();\n // eslint-disable-next-line @typescript-eslint/no-shadow\n if ((isLegendSelected === false || _isLegendHighlighted(point.legend)) && _calloutAnchorPoint !== point) {\n _calloutAnchorPoint = point;\n setPopoverOpen(true);\n _updatePosition(mouseEvent.clientX, mouseEvent.clientY);\n setDataForHoverCard(point.x);\n setSelectedLegendTitle(point.legend!);\n setColor(props.useSingleColor || props.enableGradient ? color : point.color!);\n // To display callout value, if no callout value given, taking given point.x value as a string.\n setXCalloutValue(point.yAxisCalloutData! || point.y.toString());\n setYCalloutValue(point.xAxisCalloutData || point.x.toString());\n setDataPointCalloutProps(point);\n setCallOutAccessibilityData(point.callOutAccessibilityData);\n }\n }\n\n function _onBarLeave(): void {\n setPopoverOpen(false);\n }\n\n function _handleChartMouseLeave(): void {\n _calloutAnchorPoint = null;\n setPopoverOpen(false);\n }\n\n // eslint-disable-next-line @typescript-eslint/no-shadow\n function _onBarFocus(point: HorizontalBarChartWithAxisDataPoint, refArrayIndexNumber: number, color: string): void {\n if ((isLegendSelected === false || _isLegendHighlighted(point.legend)) && _calloutAnchorPoint !== point) {\n // eslint-disable-next-line @typescript-eslint/no-shadow\n _refArray.forEach((obj: RefArrayData, index: number) => {\n if (refArrayIndexNumber === index) {\n setPopoverOpen(true);\n setSelectedLegendTitle(point.legend!);\n setDataForHoverCard(point.x);\n setColor(props.useSingleColor ? color : point.color!);\n setXCalloutValue(point.yAxisCalloutData || point.y.toString());\n setYCalloutValue(point.xAxisCalloutData! || point.x.toString());\n setDataPointCalloutProps(point);\n setCallOutAccessibilityData(point.callOutAccessibilityData);\n }\n });\n }\n }\n\n function _getScales(\n containerHeight: number,\n containerWidth: number,\n isNumericScale: boolean,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n ): { xBarScale: any; yBarScale: any } {\n const xMax = _longestBarPositiveTotalValue;\n const xMin = _longestBarNegativeTotalValue;\n const xDomain = [Math.min(X_ORIGIN, xMin), Math.max(X_ORIGIN, xMax)];\n if (isNumericScale) {\n const yMax = d3Max(_points, (point: HorizontalBarChartWithAxisDataPoint) => point.y as number)!;\n const yMin = d3Min(_points, (point: HorizontalBarChartWithAxisDataPoint) => point.y as number)!;\n const yDomainMax = Math.max(yMax, props.yMaxValue || 0);\n // Default to 0 if yMinValue is not provided.\n const yMinProp = props.yMinValue || 0;\n const yDomainMin = Math.min(yMin, yMinProp);\n const xBarScale = d3ScaleLinear()\n .domain(xDomain)\n .nice()\n .range([_margins.left!, containerWidth - _margins.right!]);\n const yBarScale = d3ScaleLinear()\n .domain([yDomainMin, yDomainMax])\n .range([containerHeight - (_margins.bottom! + _domainMargin), _margins.top! + _domainMargin]);\n return { xBarScale, yBarScale };\n } else {\n // please note these padding default values must be consistent in here\n // and CatrtesianChartBase w for more details refer example\n // http://using-d3js.com/04_07_ordinal_scales.html\n const yBarScale = d3ScaleBand()\n .domain(_yAxisLabels)\n .range([containerHeight - (_margins.bottom! + _domainMargin), _margins.top! + _domainMargin])\n .padding(_yAxisPadding);\n\n const xBarScale = d3ScaleLinear()\n .domain(xDomain)\n .nice()\n .range([_margins.left!, containerWidth - _margins.right!]);\n return { xBarScale, yBarScale };\n }\n }\n\n function _createNumericBars(\n containerHeight: number,\n containerWidth: number,\n xElement: SVGElement,\n yElement: SVGElement,\n singleBarData: HorizontalBarChartWithAxisDataPoint[],\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n xBarScale: any,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n yBarScale: any,\n ): JSX.Element[] {\n const { useSingleColor = false } = props;\n const sortedBars: HorizontalBarChartWithAxisDataPoint[] = [...singleBarData];\n sortedBars.sort((a, b) => {\n const aValue = typeof a.y === 'number' ? a.y : parseFloat(a.y);\n const bValue = typeof b.y === 'number' ? b.y : parseFloat(b.y);\n return bValue - aValue;\n });\n\n let prevWidthPositive = 0;\n let prevWidthNegative = 0;\n let prevPoint = 0;\n\n const totalPositiveBars = singleBarData.filter(\n (point: HorizontalBarChartWithAxisDataPoint) => point.x >= X_ORIGIN,\n ).length;\n const totalNegativeBars = singleBarData.length - totalPositiveBars;\n let currPositiveCounter = 0;\n let currNegativeCounter = 0;\n\n const bars = sortedBars.map((point: HorizontalBarChartWithAxisDataPoint, index: number) => {\n let shouldHighlight = true;\n if (isLegendHovered || isLegendSelected) {\n shouldHighlight = _isLegendHighlighted(point.legend);\n }\n if (point.x >= X_ORIGIN) {\n ++currPositiveCounter;\n }\n if (point.x < X_ORIGIN) {\n ++currNegativeCounter;\n }\n const barStartX = _isRtl\n ? containerWidth -\n (_margins.right! + Math.max(xBarScale(point.x + X_ORIGIN), xBarScale(X_ORIGIN)) - _margins.left!)\n : Math.min(xBarScale(point.x + X_ORIGIN), xBarScale(X_ORIGIN));\n const barHeight: number = Math.max(yBarScale(point.y), 0);\n if (barHeight < 1) {\n return <React.Fragment key={point.x}> </React.Fragment>;\n }\n let startColor: string;\n if (useSingleColor) {\n //if useSingle color , then check if user has given a palette or not\n // and pick the first color from that or else from our paltette.\n startColor = props.colors ? _createColors()(1) : getNextColor(1, 0);\n } else {\n startColor = props.colors ? _createColors()(point.x) : getNextColor(index, 0);\n }\n\n startColor = point.color && !useSingleColor ? point.color : startColor;\n\n const prevBarWidth = Math.abs(xBarScale(prevPoint + X_ORIGIN) - xBarScale(X_ORIGIN));\n prevPoint > X_ORIGIN ? (prevWidthPositive += prevBarWidth) : (prevWidthNegative += prevBarWidth);\n const currentWidth = Math.abs(xBarScale(point.x + X_ORIGIN) - xBarScale(X_ORIGIN));\n const gapWidthLTR =\n currentWidth > 2 &&\n ((point.x > X_ORIGIN && currPositiveCounter !== totalPositiveBars) ||\n (point.x < X_ORIGIN && (totalPositiveBars !== 0 || currNegativeCounter > 1)))\n ? 2\n : 0;\n const gapWidthRTL =\n currentWidth > 2 &&\n ((point.x > X_ORIGIN && (totalNegativeBars !== 0 || currPositiveCounter > 1)) ||\n (point.x < X_ORIGIN && currNegativeCounter !== totalNegativeBars))\n ? 2\n : 0;\n let xStart = X_ORIGIN;\n if (_isRtl) {\n xStart = point.x > X_ORIGIN ? barStartX - prevWidthPositive : barStartX + prevWidthNegative;\n } else {\n xStart = point.x > X_ORIGIN ? barStartX + prevWidthPositive : barStartX - prevWidthNegative;\n }\n prevPoint = point.x;\n\n return (\n <React.Fragment key={`${index}_${point.x}`}>\n <rect\n key={point.y}\n x={xStart}\n y={yBarScale(point.y) - _barHeight / 2}\n data-is-focusable={shouldHighlight}\n width={currentWidth - (_isRtl ? gapWidthRTL : gapWidthLTR)}\n height={_barHeight}\n ref={(e: SVGRectElement) => {\n _refCallback(e, point.legend!);\n }}\n rx={props.roundCorners ? 3 : 0}\n onClick={point.onClick}\n onMouseOver={(event: React.MouseEvent<SVGElement, MouseEvent>) => _onBarHover(point, startColor, event)}\n aria-label={_getAriaLabel(point)}\n role=\"img\"\n aria-labelledby={`toolTip${_calloutId}`}\n onMouseLeave={_onBarLeave}\n onFocus={() => _onBarFocus(point, index, startColor)}\n onBlur={_onBarLeave}\n fill={startColor}\n opacity={shouldHighlight ? 1 : 0.1}\n tabIndex={point.legend !== '' ? 0 : undefined}\n />\n </React.Fragment>\n );\n });\n return bars;\n }\n\n function _getUniqueYValues() {\n const mapY: Record<string, number | string> = {};\n props.data?.forEach((point: HorizontalBarChartWithAxisDataPoint) => {\n mapY[point.y] = point.y;\n });\n const uniqueY = Object.values(mapY);\n return uniqueY;\n }\n\n function _calculateAppropriateBarHeight(data: number[] | Date[], totalWidth: number, innerPadding: number) {\n const result = getClosestPairDiffAndRange(data);\n if (!result || result[1] === 0) {\n return 16;\n }\n const closestPairDiff = result[0];\n let range = result[1];\n const yMax = d3Max(_points, (point: HorizontalBarChartWithAxisDataPoint) => point.y as number)!;\n // Since we are always rendering from 0 to yMax, we need to ensure that the range is at least yMax\n // to calculate the bar height correctly.\n range = Math.max(range, yMax);\n // Refer to https://microsoft.github.io/fluentui-charting-contrib/docs/rfcs/fix-overlapping-bars-on-continuous-axes\n // for the derivation of the following formula.\n const barWidth = Math.floor(\n (totalWidth * closestPairDiff * (1 - innerPadding)) / (range + closestPairDiff * (1 - innerPadding)),\n );\n return barWidth;\n }\n\n function _getDomainMarginsForHorizontalBarChart(containerHeight: number): Margins {\n _domainMargin = MIN_DOMAIN_MARGIN;\n const uniqueY = _getUniqueYValues();\n /** Rate at which the space between the bars changes wrt the bar height */\n _yAxisPadding = _yAxisPadding === 1 ? 0.99 : _yAxisPadding;\n const barGapRate = _yAxisPadding / (1 - _yAxisPadding);\n const numBars = uniqueY.length + (uniqueY.length - 1) * barGapRate;\n // Total height available to render the bars\n const totalHeight = containerHeight - (_margins.top! + MIN_DOMAIN_MARGIN) - (_margins.bottom! + MIN_DOMAIN_MARGIN);\n if (_yAxisType !== YAxisType.StringAxis) {\n // Calculate bar height dynamically\n _barHeight =\n props.barHeight || _calculateAppropriateBarHeight(uniqueY as number[] | Date[], totalHeight, _yAxisPadding);\n _barHeight = Math.max(_barHeight, 1);\n _domainMargin += _barHeight / 2;\n } else {\n // Calculate the appropriate bar height\n _barHeight = props.barHeight || totalHeight / numBars;\n /** Total height required to render the bars. Directly proportional to bar height */\n const reqHeight = numBars * _barHeight;\n if (totalHeight >= reqHeight) {\n // Center align the chart by setting equal left and right margins for domain\n _domainMargin = MIN_DOMAIN_MARGIN + (totalHeight - reqHeight) / 2;\n }\n }\n\n return {\n ..._margins,\n top: _margins.top! + _domainMargin,\n bottom: _margins.bottom! + _domainMargin,\n };\n }\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n function _tooltipOfYAxislabels(ytooltipProps: any) {\n const { tooltipCls, yAxis, id } = ytooltipProps;\n if (yAxis === null) {\n return null;\n }\n const div = d3Select('body').append('div').attr('id', id).attr('class', tooltipCls).style('opacity', 0);\n const aa = yAxis!.selectAll('#BaseSpan')._groups[0];\n const baseSpanLength = aa && Object.keys(aa)!.length;\n const originalDataArray: string[] = [];\n for (let i = 0; i < baseSpanLength; i++) {\n const originalData = aa[i].dataset && (Object.values(aa[i].dataset)[0] as string);\n originalDataArray.push(originalData);\n }\n const tickObject = yAxis!.selectAll('.tick')._groups[0];\n const tickObjectLength = tickObject && Object.keys(tickObject)!.length;\n for (let i = 0; i < tickObjectLength; i++) {\n const d1 = tickObject[i];\n d3Select(d1)\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n .on('mouseover', (event: any, d) => {\n if (!tooltipElement) {\n div.style('opacity', 0.9);\n div\n .text(originalDataArray[i])\n .style('left', event.pageX + 'px')\n .style('top', event.pageY - 28 + 'px');\n }\n })\n .on('mouseout', d => {\n div.style('opacity', 0);\n });\n }\n }\n\n function _createStringBars(\n containerHeight: number,\n containerWidth: number,\n xElement: SVGElement,\n yElement: SVGElement,\n singleBarData: HorizontalBarChartWithAxisDataPoint[],\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n xBarScale: any,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n yBarScale: any,\n ): JSX.Element[] {\n const { useSingleColor = false } = props;\n let prevWidthPositive = 0;\n let prevWidthNegative = 0;\n let prevPoint = 0;\n const totalPositiveBars = singleBarData.filter(\n (point: HorizontalBarChartWithAxisDataPoint) => point.x >= X_ORIGIN,\n ).length;\n const totalNegativeBars = singleBarData.length - totalPositiveBars;\n let currPositiveCounter = 0;\n let currNegativeCounter = 0;\n const bars = singleBarData.map((point: HorizontalBarChartWithAxisDataPoint, index: number) => {\n let shouldHighlight = true;\n if (isLegendHovered || isLegendSelected) {\n shouldHighlight = _isLegendHighlighted(point.legend);\n }\n if (point.x >= X_ORIGIN) {\n ++currPositiveCounter;\n }\n if (point.x < X_ORIGIN) {\n ++currNegativeCounter;\n }\n const barStartX = _isRtl\n ? containerWidth -\n (_margins.right! + Math.max(xBarScale(point.x + X_ORIGIN), xBarScale(X_ORIGIN)) - _margins.left!)\n : Math.min(xBarScale(point.x + X_ORIGIN), xBarScale(X_ORIGIN));\n const barHeight: number = Math.max(yBarScale(point.y), 0);\n if (barHeight < 1) {\n return <React.Fragment key={point.x}> </React.Fragment>;\n }\n let startColor: string;\n if (useSingleColor) {\n //if useSingle color , then check if user has given a palette or not\n // and pick the first color from that or else from our paltette.\n startColor = props.colors ? _createColors()(1) : getNextColor(1, 0);\n } else {\n startColor = props.colors ? _createColors()(point.x) : getNextColor(index, 0);\n }\n\n startColor = point.color && !useSingleColor ? point.color : startColor;\n const prevBarWidth = Math.abs(xBarScale(prevPoint + X_ORIGIN) - xBarScale(X_ORIGIN));\n prevPoint > 0 ? (prevWidthPositive += prevBarWidth) : (prevWidthNegative += prevBarWidth);\n const currentWidth = Math.abs(xBarScale(point.x + X_ORIGIN) - xBarScale(X_ORIGIN));\n const gapWidthLTR =\n currentWidth > 2 &&\n ((point.x > X_ORIGIN && currPositiveCounter !== totalPositiveBars) ||\n (point.x < X_ORIGIN && (totalPositiveBars !== 0 || currNegativeCounter > 1)))\n ? 2\n : 0;\n const gapWidthRTL =\n currentWidth > 2 &&\n ((point.x > X_ORIGIN && (totalNegativeBars !== 0 || currPositiveCounter > 1)) ||\n (point.x < X_ORIGIN && currNegativeCounter !== totalNegativeBars))\n ? 2\n : 0;\n prevPoint = point.x;\n let xStart = X_ORIGIN;\n if (_isRtl) {\n xStart = point.x > X_ORIGIN ? barStartX - prevWidthPositive : barStartX + prevWidthNegative;\n } else {\n xStart = point.x > X_ORIGIN ? barStartX + prevWidthPositive : barStartX - prevWidthNegative;\n }\n return (\n <React.Fragment key={`${index}_${point.x}`}>\n <rect\n transform={`translate(0,${0.5 * (yBarScale.bandwidth() - _barHeight)})`}\n key={point.x}\n x={xStart}\n y={yBarScale(point.y)}\n rx={props.roundCorners ? 3 : 0}\n width={currentWidth - (_isRtl ? gapWidthRTL : gapWidthLTR)}\n height={_barHeight}\n aria-labelledby={`toolTip${_calloutId}`}\n aria-label={_getAriaLabel(point)}\n role=\"img\"\n ref={(e: SVGRectElement) => {\n _refCallback(e, point.legend!);\n }}\n onClick={point.onClick}\n onMouseOver={(event: React.MouseEvent<SVGElement, MouseEvent>) => _onBarHover(point, startColor, event)}\n onMouseLeave={_onBarLeave}\n onBlur={_onBarLeave}\n data-is-focusable={shouldHighlight}\n opacity={shouldHighlight ? 1 : 0.1}\n onFocus={() => _onBarFocus(point, index, startColor)}\n fill={startColor}\n tabIndex={point.legend !== '' ? 0 : undefined}\n />\n </React.Fragment>\n );\n });\n\n // Removing un wanted tooltip div from DOM, when prop not provided, for proper cleanup\n // of unwanted DOM elements, to prevent flacky behaviour in tooltips , that might occur\n // in creating tooltips when tooltips are enabled( as we try to recreate a tspan with _tooltipId)\n if (!props.showYAxisLablesTooltip) {\n try {\n // eslint-disable-next-line @nx/workspace-no-restricted-globals\n document.getElementById(_tooltipId) && document.getElementById(_tooltipId)!.remove();\n //eslint-disable-next-line no-empty\n } catch (e) {}\n }\n // Used to display tooltip at y axis labels.\n if (props.showYAxisLablesTooltip) {\n const yAxisElement = d3Select(yElement).call(yBarScale);\n if (!tooltipElement) {\n try {\n // eslint-disable-next-line @nx/workspace-no-restricted-globals\n document.getElementById(_tooltipId) && document.getElementById(_tooltipId)!.remove();\n //eslint-disable-next-line no-empty\n } catch (e) {}\n }\n const ytooltipProps = {\n tooltipCls: classes.tooltip!,\n id: _tooltipId,\n yAxis: yAxisElement,\n };\n yAxisElement && _tooltipOfYAxislabels(ytooltipProps);\n }\n return bars;\n }\n\n function _onLegendHover(customMessage: string): void {\n if (!_isLegendSelected()) {\n setIsLegendHovered(true);\n setSelectedLegendTitle(customMessage);\n }\n }\n\n function _onLegendLeave(isLegendFocused?: boolean): void {\n if (!!isLegendFocused || !_isLegendSelected()) {\n setIsLegendHovered(false);\n setSelectedLegendTitle('');\n setIsLegendSelected(isLegendFocused ? false : _isLegendSelected());\n }\n }\n\n function _getLegendData(data: HorizontalBarChartWithAxisDataPoint[]): JSX.Element {\n const { useSingleColor } = props;\n const actions: Legend[] = [];\n const mapLegendToColor: Record<string, string> = {};\n\n data.forEach((point: HorizontalBarChartWithAxisDataPoint, _index: number) => {\n // eslint-disable-next-line @typescript-eslint/no-shadow\n const color: string = useSingleColor ? (props.colors ? _createColors()(1) : getNextColor(1, 0)) : point.color!;\n\n mapLegendToColor[point.legend!] = color;\n });\n Object.entries(mapLegendToColor).forEach(([legendTitle, color]) => {\n // mapping data to the format Legends component needs\n const legend: Legend = {\n title: legendTitle,\n color,\n hoverAction: () => {\n _handleChartMouseLeave();\n _onLegendHover(legendTitle);\n },\n // eslint-disable-next-line @typescript-eslint/no-shadow\n onMouseOutAction: (isLegendSelected?: boolean) => {\n _onLegendLeave(isLegendSelected);\n },\n };\n actions.push(legend);\n });\n const legends = (\n <Legends\n legends={actions}\n enabledWrapLines={props.enabledLegendsWrapLines}\n overflowText={props.legendsOverflowText}\n {...props.legendProps}\n onChange={_onLegendSelectionChange}\n />\n );\n return legends;\n }\n\n function _isLegendSelected(): boolean {\n return isLegendSelected!;\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(legend?: string) {\n return _getHighlightedLegend().includes(legend!);\n }\n\n function _getHighlightedLegend() {\n return selectedLegends.length > 0 ? selectedLegends : selectedLegendTitle ? [selectedLegendTitle] : [];\n }\n\n function _onLegendSelectionChange(\n // eslint-disable-next-line @typescript-eslint/no-shadow\n selectedLegends: string[],\n event: React.MouseEvent<HTMLButtonElement>,\n currentLegend?: Legend,\n ): void {\n if (props.legendProps?.canSelectMultipleLegends) {\n setSelectedLegends(selectedLegends);\n setSelectedLegendTitle(currentLegend?.title!);\n } else {\n setSelectedLegends(selectedLegends.slice(-1));\n setSelectedLegendTitle(currentLegend?.title!);\n }\n setIsLegendSelected(selectedLegends.length > 0);\n if (props.legendProps?.onChange) {\n props.legendProps.onChange(selectedLegends, event, currentLegend);\n }\n }\n\n function _getAxisData(yAxisData: IAxisData) {\n if (yAxisData && yAxisData.yAxisDomainValues.length) {\n // For HBCWA x and y Values are swapped\n const { yAxisDomainValues: domainValue } = yAxisData;\n _xMax = Math.max(domainValue[domainValue.length - 1], props.xMaxValue || 0);\n }\n }\n function _getAriaLabel(point: HorizontalBarChartWithAxisDataPoint): string {\n const xValue = point.xAxisCalloutData || point.x;\n const yValue = point.yAxisCalloutData || point.y;\n return point.callOutAccessibilityData?.ariaLabel || `${xValue}. ` + `${yValue}.`;\n }\n\n function _getChartTitle(): string {\n const { chartTitle, data } = props;\n return (chartTitle ? `${chartTitle}. ` : '') + `Horizontal bar chart with ${data?.length || 0} bars. `;\n }\n\n function _isChartEmpty(): boolean {\n return !(props.data && props.data.length > 0);\n }\n\n function _updatePosition(newX: number, newY: number): void {\n const threshold = 1; // Set a threshold for movement\n const { x, y } = clickPosition;\n\n // Calculate the distance moved\n const distance = Math.sqrt(Math.pow(newX - x, 2) + Math.pow(newY - y, 2));\n // Update the position only if the distance moved is greater than the threshold\n if (distance > threshold) {\n setClickPosition({ x: newX, y: newY });\n setPopoverOpen(true);\n }\n }\n\n function _getDomainNRangeValues(\n points: HorizontalBarChartWithAxisDataPoint[],\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 = domainRangeOfNumericForHorizontalBarChartWithAxis(\n points,\n margins,\n width,\n isRTL,\n shiftX,\n X_ORIGIN,\n );\n } else {\n domainNRangeValue = { dStartValue: 0, dEndValue: 0, rStartValue: 0, rEndValue: 0 };\n }\n return domainNRangeValue;\n }\n\n if (!_isChartEmpty()) {\n _adjustProps();\n const calloutProps: ChartPopoverProps = {\n color: color,\n legend: selectedLegendTitle,\n XValue: xCalloutValue,\n YValue: yCalloutValue ? yCalloutValue : dataForHoverCard,\n ...props.calloutProps,\n ...getAccessibleDataObject(callOutAccessibilityData),\n customCallout: {\n customizedCallout: _getCustomizedCallout() !== null ? _getCustomizedCallout()! : undefined,\n customCalloutProps: props.calloutPropsPerDataPoint\n ? props.calloutPropsPerDataPoint(dataPointCalloutProps!)\n : undefined,\n },\n isCartesian: true,\n isPopoverOpen,\n clickPosition,\n };\n const tickParams = {\n tickValues: props.tickValues,\n tickFormat: props.tickFormat,\n };\n\n const reversedBars = [..._points].reverse();\n _yAxisLabels = reversedBars.map((point: HorizontalBarChartWithAxisDataPoint) => point.y as string);\n _xMax = Math.max(d3Max(_points, (point: HorizontalBarChartWithAxisDataPoint) => point.x)!, props.xMaxValue || 0);\n const legendBars: JSX.Element = _getLegendData(_points);\n return (\n <CartesianChart\n yAxisPadding={_yAxisPadding}\n {...props}\n chartTitle={_getChartTitle()}\n points={_points}\n chartType={ChartTypes.HorizontalBarChartWithAxis}\n xAxisType={_xAxisType}\n yAxisType={_yAxisType}\n getDomainNRangeValues={_getDomainNRangeValues}\n stringDatasetForYAxisDomain={_yAxisLabels}\n calloutProps={calloutProps}\n tickParams={tickParams}\n legendBars={legendBars}\n barwidth={_barHeight}\n getmargins={_getMargins}\n getYDomainMargins={_getDomainMarginsForHorizontalBarChart}\n getGraphData={_getGraphData}\n getAxisData={_getAxisData}\n onChartMouseLeave={_handleChartMouseLeave}\n componentRef={cartesianChartRef}\n /* eslint-disable react/jsx-no-bind */\n // eslint-disable-next-line @typescript-eslint/no-shadow\n children={(props: ChildProps) => {\n return (\n <>\n <g>{_bars}</g>\n </>\n );\n }}\n />\n );\n } else {\n return (\n <div id={_emptyChartId} role={'alert'} style={{ opacity: '0' }} aria-label={'Graph has no data to display'} />\n );\n }\n});\nHorizontalBarChartWithAxis.displayName = 'HorizontalBarChartWithAxis';\n"],"names":["React","max","d3Max","min","d3Min","select","d3Select","scaleLinear","d3ScaleLinear","scaleBand","d3ScaleBand","Legends","useId","useHorizontalBarChartWithAxisStyles","CartesianChart","ChartPopover","ChartTypes","getAccessibleDataObject","YAxisType","XAxisTypes","getTypeOfAxis","getNextColor","areArraysEqual","useRtl","DataVizPalette","getColorFromToken","computeLongestBars","domainRangeOfNumericForHorizontalBarChartWithAxis","groupChartDataByYValue","MIN_DOMAIN_MARGIN","getClosestPairDiffAndRange","HorizontalBarChartWithAxis","forwardRef","props","forwardedRef","_refArray","_calloutId","_isRtl","_tooltipId","_xAxisType","data","length","x","NumericAxis","_yAxisType","y","StringAxis","_emptyChartId","_points","_barHeight","_colors","_margins","_bars","_yAxisLabels","_xMax","_calloutAnchorPoint","tooltipElement","_longestBarPositiveTotalValue","_longestBarNegativeTotalValue","_domainMargin","_yAxisPadding","yAxisPadding","cartesianChartRef","useRef","X_ORIGIN","color","setColor","useState","dataForHoverCard","setDataForHoverCard","isLegendSelected","setIsLegendSelected","legendProps","selectedLegends","selectedLegend","undefined","isLegendHovered","setIsLegendHovered","selectedLegendTitle","setSelectedLegendTitle","xCalloutValue","setXCalloutValue","yCalloutValue","setYCalloutValue","setSelectedLegends","dataPointCalloutProps","setDataPointCalloutProps","callOutAccessibilityData","setCallOutAccessibilityData","isPopoverOpen","setPopoverOpen","clickPosition","setClickPosition","prevPropsRef","useEffect","current","prevProps","useImperativeHandle","componentRef","chartContainer","classes","_adjustProps","barHeight","defaultPalette","color6","color1","color5","color7","colors","_getMargins","margins","_renderContentForOnlyBars","point","useSingleColor","selectedPointIndex","forEach","yDataPoint","index","_createColors","XValue","xAxisCalloutData","toString","legend","YValue","yAxisCalloutData","culture","_renderCallout","_getCustomizedCallout","onRenderCalloutPerDataPoint","_getGraphData","xScale","yScale","containerHeight","containerWidth","xElement","yElement","stackedChartData","longestBars","longestPositiveBar","longestNegativeBar","xBarScale","yBarScale","_getScales","xRange","range","allBars","map","singleBarData","_createNumericBars","_createStringBars","flat","increment","_p","color16","domainValues","i","push","colorScale","domain","_refCallback","element","legendTitle","refElement","_onBarHover","mouseEvent","persist","_isLegendHighlighted","_updatePosition","clientX","clientY","enableGradient","_onBarLeave","_handleChartMouseLeave","_onBarFocus","refArrayIndexNumber","obj","isNumericScale","xMax","xMin","xDomain","Math","yMax","yMin","yDomainMax","yMaxValue","yMinProp","yMinValue","yDomainMin","nice","left","right","bottom","top","padding","sortedBars","sort","a","b","aValue","parseFloat","bValue","prevWidthPositive","prevWidthNegative","prevPoint","totalPositiveBars","filter","totalNegativeBars","currPositiveCounter","currNegativeCounter","bars","shouldHighlight","barStartX","Fragment","key","startColor","prevBarWidth","abs","currentWidth","gapWidthLTR","gapWidthRTL","xStart","rect","data-is-focusable","width","height","ref","e","rx","roundCorners","onClick","onMouseOver","event","aria-label","_getAriaLabel","role","aria-labelledby","onMouseLeave","onFocus","onBlur","fill","opacity","tabIndex","_getUniqueYValues","mapY","uniqueY","Object","values","_calculateAppropriateBarHeight","totalWidth","innerPadding","result","closestPairDiff","barWidth","floor","_getDomainMarginsForHorizontalBarChart","barGapRate","numBars","totalHeight","reqHeight","_tooltipOfYAxislabels","ytooltipProps","tooltipCls","yAxis","id","div","append","attr","style","aa","selectAll","_groups","baseSpanLength","keys","originalDataArray","originalData","dataset","tickObject","tickObjectLength","d1","on","d","text","pageX","pageY","transform","bandwidth","showYAxisLablesTooltip","document","getElementById","remove","yAxisElement","call","tooltip","_onLegendHover","customMessage","_isLegendSelected","_onLegendLeave","isLegendFocused","_getLegendData","actions","mapLegendToColor","_index","entries","title","hoverAction","onMouseOutAction","legends","enabledWrapLines","enabledLegendsWrapLines","overflowText","legendsOverflowText","onChange","_onLegendSelectionChange","_getHighlightedLegend","includes","currentLegend","canSelectMultipleLegends","slice","_getAxisData","yAxisData","yAxisDomainValues","domainValue","xMaxValue","xValue","yValue","ariaLabel","_getChartTitle","chartTitle","_isChartEmpty","newX","newY","threshold","distance","sqrt","pow","_getDomainNRangeValues","points","chartType","isRTL","xAxisType","tickValues","shiftX","domainNRangeValue","dStartValue","dEndValue","rStartValue","rEndValue","calloutProps","customCallout","customizedCallout","customCalloutProps","calloutPropsPerDataPoint","isCartesian","tickParams","tickFormat","reversedBars","reverse","legendBars","yAxisType","getDomainNRangeValues","stringDatasetForYAxisDomain","barwidth","getmargins","getYDomainMargins","getGraphData","getAxisData","onChartMouseLeave","children","g","displayName"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":"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"}
@@ -9,6 +9,7 @@ import { curveLinear as d3CurveLinear, curveNatural as d3CurveNatural, curveStep
9
9
  import { formatPrefix as d3FormatPrefix } from 'd3-format';
10
10
  import { useFluent_unstable as useFluent } from '@fluentui/react-shared-contexts';
11
11
  import { formatDateToLocaleString, formatToLocaleString, getMultiLevelDateTimeFormatOptions } from '@fluentui/chart-utilities';
12
+ export const MIN_DOMAIN_MARGIN = 8;
12
13
  export var ChartTypes;
13
14
  (function(ChartTypes) {
14
15
  ChartTypes[ChartTypes["AreaChart"] = 0] = "AreaChart";
@@ -487,10 +488,10 @@ export function createYAxisForHorizontalBarChartWithAxis(yAxisParams, isRtl, axi
487
488
  startValue: 0,
488
489
  endValue: 0
489
490
  }, yAxisElement = null, yMaxValue = 0, yMinValue = 0, containerHeight, margins, tickPadding = 12, maxOfYVal = 0, yAxisTickFormat, yAxisTickCount = 4 } = yAxisParams;
490
- // maxOfYVal coming from only area chart and Grouped vertical bar chart(Calculation done at base file)
491
+ // maxOfYVal coming from horizontal bar chart with axis (Calculation done at base file)
491
492
  const tempVal = maxOfYVal || yMinMaxValues.endValue;
492
493
  const finalYmax = tempVal > yMaxValue ? tempVal : yMaxValue;
493
- const finalYmin = yMinMaxValues.startValue < yMinValue ? 0 : yMinValue;
494
+ const finalYmin = yMinMaxValues.startValue < yMinValue ? Math.min(0, yMinMaxValues.startValue) : yMinValue;
494
495
  const yAxisScale = d3ScaleLinear().domain([
495
496
  finalYmin,
496
497
  finalYmax
@@ -549,11 +550,13 @@ export const createStringYAxis = (yAxisParams, dataPoints, isRtl, chartType, bar
549
550
  * @param dataPoints
550
551
  * @param isRtl
551
552
  */ export const createStringYAxisForHorizontalBarChartWithAxis = (yAxisParams, dataPoints, isRtl, barWidth, culture)=>{
552
- const { containerHeight, tickPadding = 12, margins, yAxisTickFormat, yAxisElement } = yAxisParams;
553
+ const { containerHeight, tickPadding = 12, margins, yAxisTickFormat, yAxisElement, yAxisPadding } = yAxisParams;
554
+ let yAxisPaddingValue = yAxisPadding !== null && yAxisPadding !== void 0 ? yAxisPadding : 0.5;
555
+ yAxisPaddingValue = yAxisPaddingValue === 1 ? 0.99 : yAxisPaddingValue;
553
556
  const yAxisScale = d3ScaleBand().domain(dataPoints).range([
554
- containerHeight - margins.bottom - barWidth / 2,
555
- margins.top + barWidth / 2
556
- ]);
557
+ containerHeight - margins.bottom,
558
+ margins.top
559
+ ]).padding(yAxisPaddingValue);
557
560
  const axis = isRtl ? d3AxisRight(yAxisScale) : d3AxisLeft(yAxisScale);
558
561
  const yAxis = axis.tickPadding(tickPadding).ticks(dataPoints);
559
562
  if (yAxisTickFormat) {
@@ -917,6 +920,41 @@ export function tooltipOfXAxislabels(xAxistooltipProps) {
917
920
  rEndValue
918
921
  };
919
922
  }
923
+ /**
924
+ * Groups HorizontalBarChart With Axis data based on YValue
925
+ * Used for stacked case
926
+ * @param {IHorizontalBarChartWithAxisDataPoint[]} chartData
927
+ * @returns {IHorizontalBarChartWithAxisDataPoint[][]}
928
+ */ export function groupChartDataByYValue(chartData) {
929
+ const map = {};
930
+ chartData.forEach((dataPoint)=>{
931
+ const key = dataPoint.y;
932
+ if (!map[key]) {
933
+ map[key] = [];
934
+ }
935
+ map[key].push(dataPoint);
936
+ });
937
+ return Object.values(map);
938
+ }
939
+ /**
940
+ * Calculates maximum domain values for Numeric x axis for both positive and negative values
941
+ * works for Horizontal Bar Chart With axis
942
+ * @param {HorizontalBarChartWithAxisDataPoint[][]} stackedChartData
943
+ * @returns {number}
944
+ */ export function computeLongestBars(stackedChartData, X_ORIGIN) {
945
+ let longestPositiveBar = 0;
946
+ let longestNegativeBar = 0;
947
+ stackedChartData.forEach((group)=>{
948
+ const positiveBarTotal = group.reduce((acc, point)=>acc + (point.x > 0 ? point.x : 0), X_ORIGIN);
949
+ const negativeBarTotal = group.reduce((acc, point)=>acc + (point.x < 0 ? point.x : 0), X_ORIGIN);
950
+ longestPositiveBar = Math.max(longestPositiveBar, positiveBarTotal);
951
+ longestNegativeBar = Math.min(longestNegativeBar, negativeBarTotal);
952
+ });
953
+ return {
954
+ longestPositiveBar,
955
+ longestNegativeBar
956
+ };
957
+ }
920
958
  /**
921
959
  * Calculates Domain and range values for Numeric X axis.
922
960
  * This method calculates Horizontal Chart with Axis
@@ -926,17 +964,19 @@ export function tooltipOfXAxislabels(xAxistooltipProps) {
926
964
  * @param {number} width
927
965
  * @param {boolean} isRTL
928
966
  * @returns {IDomainNRange}
929
- */ export function domainRangeOfNumericForHorizontalBarChartWithAxis(points, margins, containerWidth, isRTL, shiftX) {
930
- const xMax = d3Max(points, (point)=>point.x);
967
+ */ export function domainRangeOfNumericForHorizontalBarChartWithAxis(points, margins, containerWidth, isRTL, shiftX, X_ORIGIN) {
968
+ const longestBars = computeLongestBars(groupChartDataByYValue(points), X_ORIGIN);
969
+ const xMax = longestBars.longestPositiveBar;
970
+ const xMin = longestBars.longestNegativeBar;
931
971
  const rMin = isRTL ? margins.left : margins.left + shiftX;
932
972
  const rMax = isRTL ? containerWidth - margins.right - shiftX : containerWidth - margins.right;
933
973
  return isRTL ? {
934
974
  dStartValue: xMax,
935
- dEndValue: 0,
975
+ dEndValue: Math.min(xMin, X_ORIGIN),
936
976
  rStartValue: rMin,
937
977
  rEndValue: rMax
938
978
  } : {
939
- dStartValue: 0,
979
+ dStartValue: Math.min(xMin, X_ORIGIN),
940
980
  dEndValue: xMax,
941
981
  rStartValue: rMin,
942
982
  rEndValue: rMax
@@ -1144,7 +1184,7 @@ export function tooltipOfXAxislabels(xAxistooltipProps) {
1144
1184
  * @param {number} [barWidth]
1145
1185
  * @returns {IDomainNRange}
1146
1186
  */ export function getDomainNRangeValues(// eslint-disable-next-line @typescript-eslint/no-explicit-any
1147
- points, margins, width, chartType, isRTL, xAxisType, barWidth, tickValues, shiftX) {
1187
+ points, margins, width, chartType, isRTL, xAxisType, barWidth, tickValues, shiftX, X_ORIGIN) {
1148
1188
  let domainNRangeValue;
1149
1189
  if (xAxisType === 0) {
1150
1190
  switch(chartType){
@@ -1159,7 +1199,7 @@ points, margins, width, chartType, isRTL, xAxisType, barWidth, tickValues, shift
1159
1199
  domainNRangeValue = domainRageOfVerticalNumeric(points, margins, width, isRTL, barWidth);
1160
1200
  break;
1161
1201
  case 6:
1162
- domainNRangeValue = domainRangeOfNumericForHorizontalBarChartWithAxis(points, margins, width, isRTL, shiftX);
1202
+ domainNRangeValue = domainRangeOfNumericForHorizontalBarChartWithAxis(points, margins, width, isRTL, shiftX, X_ORIGIN);
1163
1203
  break;
1164
1204
  case 7:
1165
1205
  domainNRangeValue = domainRangeOfNumericForScatterChart(points, margins, width, isRTL);