@undp/data-viz 1.5.2 → 1.5.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/AreaChart.cjs +1 -1
- package/dist/AreaChart.cjs.map +1 -1
- package/dist/AreaChart.js +3 -2
- package/dist/AreaChart.js.map +1 -1
- package/dist/BarGraph.cjs +1 -1
- package/dist/BarGraph.cjs.map +1 -1
- package/dist/BarGraph.js +1196 -1224
- package/dist/BarGraph.js.map +1 -1
- package/dist/BeeSwarmChart.cjs +1 -1
- package/dist/BeeSwarmChart.cjs.map +1 -1
- package/dist/BeeSwarmChart.js +130 -142
- package/dist/BeeSwarmChart.js.map +1 -1
- package/dist/BiVariateChoroplethMap.cjs +1 -1
- package/dist/BiVariateChoroplethMap.cjs.map +1 -1
- package/dist/BiVariateChoroplethMap.js +41 -41
- package/dist/BiVariateChoroplethMap.js.map +1 -1
- package/dist/BulletChart.cjs +1 -1
- package/dist/BulletChart.cjs.map +1 -1
- package/dist/BulletChart.js +483 -487
- package/dist/BulletChart.js.map +1 -1
- package/dist/ButterflyChart.cjs +1 -1
- package/dist/ButterflyChart.cjs.map +1 -1
- package/dist/ButterflyChart.js +99 -99
- package/dist/ButterflyChart.js.map +1 -1
- package/dist/ChoroplethMap.cjs +1 -1
- package/dist/ChoroplethMap.cjs.map +1 -1
- package/dist/ChoroplethMap.js +125 -125
- package/dist/ChoroplethMap.js.map +1 -1
- package/dist/CirclePackingGraph.cjs +1 -1
- package/dist/CirclePackingGraph.js +2 -2
- package/dist/DataCards.cjs +2 -2
- package/dist/DataCards.cjs.map +1 -1
- package/dist/DataCards.js +6 -6
- package/dist/DataCards.js.map +1 -1
- package/dist/DataTable.cjs +1 -1
- package/dist/DataTable.cjs.map +1 -1
- package/dist/DataTable.js +66 -68
- package/dist/DataTable.js.map +1 -1
- package/dist/DifferenceLineChart.cjs +1 -1
- package/dist/DifferenceLineChart.cjs.map +1 -1
- package/dist/DifferenceLineChart.js +3 -2
- package/dist/DifferenceLineChart.js.map +1 -1
- package/dist/DonutChart.cjs +1 -1
- package/dist/DonutChart.cjs.map +1 -1
- package/dist/DonutChart.js +205 -205
- package/dist/DonutChart.js.map +1 -1
- package/dist/DotDensityMap.cjs +1 -1
- package/dist/DotDensityMap.cjs.map +1 -1
- package/dist/DotDensityMap.js +78 -81
- package/dist/DotDensityMap.js.map +1 -1
- package/dist/DualAxisLineChart.cjs +1 -1
- package/dist/DualAxisLineChart.cjs.map +1 -1
- package/dist/DualAxisLineChart.js +3 -2
- package/dist/DualAxisLineChart.js.map +1 -1
- package/dist/DumbbellChart.cjs +1 -1
- package/dist/DumbbellChart.cjs.map +1 -1
- package/dist/DumbbellChart.js +64 -65
- package/dist/DumbbellChart.js.map +1 -1
- package/dist/GeoHubMap.cjs +1 -1
- package/dist/GeoHubMap.js +1 -1
- package/dist/GeoHubMapWithLayerSelection.cjs +1 -1
- package/dist/GeoHubMapWithLayerSelection.js +1 -1
- package/dist/{GraphEl-4RUlclvW.cjs → GraphEl-BcYgMnN2.cjs} +2 -2
- package/dist/{GraphEl-4RUlclvW.cjs.map → GraphEl-BcYgMnN2.cjs.map} +1 -1
- package/dist/{GraphEl-ClIxlWa3.js → GraphEl-CMWeARJ3.js} +2 -2
- package/dist/{GraphEl-ClIxlWa3.js.map → GraphEl-CMWeARJ3.js.map} +1 -1
- package/dist/GriddedGraphs.cjs +1 -1
- package/dist/GriddedGraphs.js +4 -4
- package/dist/GriddedGraphsFromConfig.cjs +1 -1
- package/dist/GriddedGraphsFromConfig.js +1 -1
- package/dist/HeatMap.cjs +1 -1
- package/dist/HeatMap.cjs.map +1 -1
- package/dist/HeatMap.js +83 -83
- package/dist/HeatMap.js.map +1 -1
- package/dist/Histogram.cjs +1 -1
- package/dist/Histogram.js +1 -1
- package/dist/LineChartWithConfidenceInterval.cjs +1 -1
- package/dist/LineChartWithConfidenceInterval.cjs.map +1 -1
- package/dist/LineChartWithConfidenceInterval.js +7 -6
- package/dist/LineChartWithConfidenceInterval.js.map +1 -1
- package/dist/MultiGraphDashboard.cjs +1 -1
- package/dist/MultiGraphDashboard.js +2 -2
- package/dist/MultiGraphDashboardFromConfig.cjs +1 -1
- package/dist/MultiGraphDashboardFromConfig.js +1 -1
- package/dist/MultiGraphDashboardWideToLongFormat.cjs +1 -1
- package/dist/MultiGraphDashboardWideToLongFormat.js +1 -1
- package/dist/MultiGraphDashboardWideToLongFormatFromConfig.cjs +1 -1
- package/dist/MultiGraphDashboardWideToLongFormatFromConfig.js +1 -1
- package/dist/MultiLineAltChart.cjs +1 -1
- package/dist/MultiLineAltChart.cjs.map +1 -1
- package/dist/MultiLineAltChart.js +82 -91
- package/dist/MultiLineAltChart.js.map +1 -1
- package/dist/MultiLineChart.cjs +1 -1
- package/dist/MultiLineChart.cjs.map +1 -1
- package/dist/MultiLineChart.js +3 -2
- package/dist/MultiLineChart.js.map +1 -1
- package/dist/PerformanceIntensiveMultiGraphDashboard.cjs +1 -1
- package/dist/PerformanceIntensiveMultiGraphDashboard.js +2 -2
- package/dist/PerformanceIntensiveMultiGraphDashboardFromConfig.cjs +1 -1
- package/dist/PerformanceIntensiveMultiGraphDashboardFromConfig.js +1 -1
- package/dist/RadarChart.cjs +1 -1
- package/dist/RadarChart.cjs.map +1 -1
- package/dist/RadarChart.js +124 -130
- package/dist/RadarChart.js.map +1 -1
- package/dist/SankeyChart.cjs +1 -1
- package/dist/SankeyChart.cjs.map +1 -1
- package/dist/SankeyChart.js +200 -200
- package/dist/SankeyChart.js.map +1 -1
- package/dist/ScatterPlot.cjs +1 -1
- package/dist/ScatterPlot.cjs.map +1 -1
- package/dist/ScatterPlot.js +149 -155
- package/dist/ScatterPlot.js.map +1 -1
- package/dist/SimpleLineChart.cjs +1 -1
- package/dist/SimpleLineChart.cjs.map +1 -1
- package/dist/SimpleLineChart.js +44 -43
- package/dist/SimpleLineChart.js.map +1 -1
- package/dist/SingleGraphDashboard.cjs +1 -1
- package/dist/SingleGraphDashboard.js +4 -4
- package/dist/SingleGraphDashboardFromConfig.cjs +1 -1
- package/dist/SingleGraphDashboardFromConfig.js +1 -1
- package/dist/SingleGraphDashboardGeoHubMapsFromConfig.cjs +1 -1
- package/dist/SingleGraphDashboardGeoHubMapsFromConfig.js +1 -1
- package/dist/SingleGraphDashboardThreeDGraphs.cjs +1 -1
- package/dist/SingleGraphDashboardThreeDGraphs.js +3 -3
- package/dist/SingleGraphDashboardThreeDGraphsFromConfig.cjs +1 -1
- package/dist/SingleGraphDashboardThreeDGraphsFromConfig.js +1 -1
- package/dist/SlopeChart.cjs +1 -1
- package/dist/SlopeChart.cjs.map +1 -1
- package/dist/SlopeChart.js +107 -113
- package/dist/SlopeChart.js.map +1 -1
- package/dist/SparkLine.cjs +1 -1
- package/dist/SparkLine.cjs.map +1 -1
- package/dist/SparkLine.js +3 -2
- package/dist/SparkLine.js.map +1 -1
- package/dist/StripChart.cjs +1 -1
- package/dist/StripChart.cjs.map +1 -1
- package/dist/StripChart.js +159 -159
- package/dist/StripChart.js.map +1 -1
- package/dist/ThreeDGlobe.cjs +1 -1
- package/dist/ThreeDGlobe.cjs.map +1 -1
- package/dist/ThreeDGlobe.js +3 -3
- package/dist/ThreeDGlobe.js.map +1 -1
- package/dist/TreeMapGraph.cjs +1 -1
- package/dist/TreeMapGraph.cjs.map +1 -1
- package/dist/TreeMapGraph.js +194 -200
- package/dist/TreeMapGraph.js.map +1 -1
- package/dist/ensureCompleteData-DkQYPeDa.cjs +2 -0
- package/dist/ensureCompleteData-DkQYPeDa.cjs.map +1 -0
- package/dist/{ensureCompleteData-BALdOrsS.js → ensureCompleteData-DlmibgaI.js} +28 -8
- package/dist/ensureCompleteData-DlmibgaI.js.map +1 -0
- package/dist/fetchAndParseData-Ba-_CgxS.cjs +16 -0
- package/dist/fetchAndParseData-Ba-_CgxS.cjs.map +1 -0
- package/dist/fetchAndParseData-sapWbnYk.js +583 -0
- package/dist/fetchAndParseData-sapWbnYk.js.map +1 -0
- package/dist/fetchAndParseData.cjs +1 -1
- package/dist/fetchAndParseData.js +1 -1
- package/dist/getJenks-BbngDoBQ.js +19 -0
- package/dist/getJenks-BbngDoBQ.js.map +1 -0
- package/dist/getJenks-GYmdwBqm.cjs +2 -0
- package/dist/getJenks-GYmdwBqm.cjs.map +1 -0
- package/dist/getSliderMarks-9cNoRkDx.js +1023 -0
- package/dist/getSliderMarks-9cNoRkDx.js.map +1 -0
- package/dist/getSliderMarks-CRIbTGYV.cjs +6 -0
- package/dist/getSliderMarks-CRIbTGYV.cjs.map +1 -0
- package/dist/getUniqValue-DiCh_MOD.js +13 -0
- package/dist/getUniqValue-DiCh_MOD.js.map +1 -0
- package/dist/getUniqValue-RViz8tTw.cjs +2 -0
- package/dist/getUniqValue-RViz8tTw.cjs.map +1 -0
- package/dist/{index-BMgDMxKJ.js → index-37q0ULNQ.js} +44 -50
- package/dist/index-37q0ULNQ.js.map +1 -0
- package/dist/index-CVlCtJbC.cjs +2 -0
- package/dist/index-CVlCtJbC.cjs.map +1 -0
- package/dist/index.cjs +1 -1
- package/dist/index.d.ts +1 -1
- package/dist/index.js +6 -6
- package/dist/sort-DfK1b0F5.js +34 -0
- package/dist/sort-DfK1b0F5.js.map +1 -0
- package/dist/sort-O96oMZLb.cjs +2 -0
- package/dist/sort-O96oMZLb.cjs.map +1 -0
- package/dist/transformData.cjs +1 -1
- package/dist/transformData.js +3 -3
- package/dist/transformDataForAggregation-KXGm6flX.cjs +2 -0
- package/dist/{transformDataForAggregation-BVxVu4yY.cjs.map → transformDataForAggregation-KXGm6flX.cjs.map} +1 -1
- package/dist/{transformDataForAggregation-1BYVFqvF.js → transformDataForAggregation-sBpdlX8n.js} +40 -44
- package/dist/{transformDataForAggregation-1BYVFqvF.js.map → transformDataForAggregation-sBpdlX8n.js.map} +1 -1
- package/dist/{transformDataForGraphFromFile-BC9Ha8hF.js → transformDataForGraphFromFile-ComYvzuz.js} +3 -3
- package/dist/{transformDataForGraphFromFile-BC9Ha8hF.js.map → transformDataForGraphFromFile-ComYvzuz.js.map} +1 -1
- package/dist/{transformDataForGraphFromFile-b41aNQYY.cjs → transformDataForGraphFromFile-DVZodTHd.cjs} +2 -2
- package/dist/{transformDataForGraphFromFile-b41aNQYY.cjs.map → transformDataForGraphFromFile-DVZodTHd.cjs.map} +1 -1
- package/dist/uniqBy-BHy4I8PK.js +8 -0
- package/dist/uniqBy-BHy4I8PK.js.map +1 -0
- package/dist/uniqBy-O05lp2S5.cjs +2 -0
- package/dist/uniqBy-O05lp2S5.cjs.map +1 -0
- package/dist/utils.cjs +1 -1
- package/dist/utils.d.ts +1 -1
- package/dist/utils.js +2 -2
- package/package.json +1 -7
- package/dist/ensureCompleteData-BALdOrsS.js.map +0 -1
- package/dist/ensureCompleteData-BU5Zlccy.cjs +0 -2
- package/dist/ensureCompleteData-BU5Zlccy.cjs.map +0 -1
- package/dist/fetchAndParseData-DBOl1Icl.js +0 -1196
- package/dist/fetchAndParseData-DBOl1Icl.js.map +0 -1
- package/dist/fetchAndParseData-Dcy7AS_0.cjs +0 -16
- package/dist/fetchAndParseData-Dcy7AS_0.cjs.map +0 -1
- package/dist/getJenks-DW96UYNE.js +0 -23
- package/dist/getJenks-DW96UYNE.js.map +0 -1
- package/dist/getJenks-vofIZmeb.cjs +0 -2
- package/dist/getJenks-vofIZmeb.cjs.map +0 -1
- package/dist/getSliderMarks-C0jptXeP.js +0 -1054
- package/dist/getSliderMarks-C0jptXeP.js.map +0 -1
- package/dist/getSliderMarks-CtsEXiLV.cjs +0 -6
- package/dist/getSliderMarks-CtsEXiLV.cjs.map +0 -1
- package/dist/getUniqValue-CfuE_l9c.cjs +0 -2
- package/dist/getUniqValue-CfuE_l9c.cjs.map +0 -1
- package/dist/getUniqValue-CttuU_wn.js +0 -20
- package/dist/getUniqValue-CttuU_wn.js.map +0 -1
- package/dist/index-AqnpA7_O.js +0 -631
- package/dist/index-AqnpA7_O.js.map +0 -1
- package/dist/index-BJOeaYTk.cjs +0 -2
- package/dist/index-BJOeaYTk.cjs.map +0 -1
- package/dist/index-BMgDMxKJ.js.map +0 -1
- package/dist/index-DYH8g9WA.cjs +0 -2
- package/dist/index-DYH8g9WA.cjs.map +0 -1
- package/dist/index-Da2GUKrr.cjs +0 -2
- package/dist/index-Da2GUKrr.cjs.map +0 -1
- package/dist/index-fwdktvAS.js +0 -707
- package/dist/index-fwdktvAS.js.map +0 -1
- package/dist/transformDataForAggregation-BVxVu4yY.cjs +0 -2
package/dist/BarGraph.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"BarGraph.js","sources":["../src/Components/Graphs/BarGraph/Horizontal/BarGraph/Graph.tsx","../src/Components/Graphs/BarGraph/Horizontal/BarGraph/index.tsx","../src/Components/Graphs/BarGraph/Horizontal/GroupedBarGraph/Graph.tsx","../src/Components/Graphs/BarGraph/Horizontal/GroupedBarGraph/index.tsx","../src/Components/Graphs/BarGraph/Horizontal/StackedBarGraph/Graph.tsx","../src/Components/Graphs/BarGraph/Horizontal/StackedBarGraph/index.tsx","../src/Components/Graphs/BarGraph/Vertical/BarGraph/Graph.tsx","../src/Components/Graphs/BarGraph/Vertical/BarGraph/index.tsx","../src/Components/Graphs/BarGraph/Vertical/GroupedBarGraph/Graph.tsx","../src/Components/Graphs/BarGraph/Vertical/GroupedBarGraph/index.tsx","../src/Components/Graphs/BarGraph/Vertical/StackedBarGraph/Graph.tsx","../src/Components/Graphs/BarGraph/Vertical/StackedBarGraph/index.tsx","../src/Components/Graphs/BarGraph/index.tsx"],"sourcesContent":["import isEqual from 'fast-deep-equal';\r\nimport { scaleLinear, scaleBand } from 'd3-scale';\r\nimport { useRef, useState } from 'react';\r\nimport { cn } from '@undp/design-system-react/cn';\r\nimport { Modal } from '@undp/design-system-react/Modal';\r\nimport { AnimatePresence, motion, useInView } from 'motion/react';\r\n\r\nimport {\r\n AnimateDataType,\r\n BarGraphDataType,\r\n ClassNameObject,\r\n CustomLayerDataType,\r\n ReferenceDataType,\r\n StyleObject,\r\n} from '@/Types';\r\nimport { numberFormattingFunction } from '@/Utils/numberFormattingFunction';\r\nimport { Tooltip } from '@/Components/Elements/Tooltip';\r\nimport { checkIfNullOrUndefined } from '@/Utils/checkIfNullOrUndefined';\r\nimport { Colors } from '@/Components/ColorPalette';\r\nimport { string2HTML } from '@/Utils/string2HTML';\r\nimport { XTicksAndGridLines } from '@/Components/Elements/Axes/XTicksAndGridLines';\r\nimport { YAxesLabels } from '@/Components/Elements/Axes/YAxesLabels';\r\nimport { AxisTitle } from '@/Components/Elements/Axes/AxisTitle';\r\nimport { Axis } from '@/Components/Elements/Axes/Axis';\r\nimport { RefLineX } from '@/Components/Elements/ReferenceLine';\r\n\r\ninterface Props {\r\n data: BarGraphDataType[];\r\n barColor: string[];\r\n colorDomain: string[];\r\n suffix: string;\r\n prefix: string;\r\n barPadding: number;\r\n showValues: boolean;\r\n showTicks: boolean;\r\n leftMargin: number;\r\n rightMargin: number;\r\n topMargin: number;\r\n bottomMargin: number;\r\n showLabels: boolean;\r\n truncateBy: number;\r\n width: number;\r\n height: number;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n tooltip?: string | ((_d: any) => React.ReactNode);\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseOver?: (_d: any) => void;\r\n refValues?: ReferenceDataType[];\r\n selectedColor?: string;\r\n maxValue: number;\r\n minValue: number;\r\n highlightedDataPoints: (string | number)[];\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseClick?: (_d: any) => void;\r\n labelOrder?: string[];\r\n rtl: boolean;\r\n maxBarThickness?: number;\r\n minBarThickness?: number;\r\n resetSelectionOnDoubleClick: boolean;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n detailsOnClick?: string | ((_d: any) => React.ReactNode);\r\n barAxisTitle?: string;\r\n noOfTicks: number;\r\n valueColor?: string;\r\n styles?: StyleObject;\r\n classNames?: ClassNameObject;\r\n animate: AnimateDataType;\r\n dimmedOpacity: number;\r\n precision: number;\r\n customLayers: CustomLayerDataType[];\r\n naLabel: string;\r\n}\r\n\r\nexport function Graph(props: Props) {\r\n const {\r\n data,\r\n barColor,\r\n suffix,\r\n prefix,\r\n barPadding,\r\n showValues,\r\n showTicks,\r\n leftMargin,\r\n truncateBy,\r\n width,\r\n height,\r\n colorDomain,\r\n rightMargin,\r\n topMargin,\r\n bottomMargin,\r\n showLabels,\r\n tooltip,\r\n onSeriesMouseOver,\r\n refValues,\r\n selectedColor,\r\n highlightedDataPoints,\r\n maxValue,\r\n minValue,\r\n onSeriesMouseClick,\r\n labelOrder,\r\n rtl,\r\n maxBarThickness,\r\n minBarThickness,\r\n resetSelectionOnDoubleClick,\r\n detailsOnClick,\r\n barAxisTitle,\r\n valueColor,\r\n noOfTicks,\r\n styles,\r\n classNames,\r\n animate,\r\n dimmedOpacity,\r\n precision,\r\n customLayers,\r\n naLabel,\r\n } = props;\r\n const svgRef = useRef(null);\r\n const isInView = useInView(svgRef, {\r\n once: animate.once,\r\n amount: animate.amount,\r\n });\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const [mouseOverData, setMouseOverData] = useState<any>(undefined);\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const [mouseClickData, setMouseClickData] = useState<any>(undefined);\r\n const [eventX, setEventX] = useState<number | undefined>(undefined);\r\n const [eventY, setEventY] = useState<number | undefined>(undefined);\r\n const margin = {\r\n top: barAxisTitle ? topMargin + 25 : topMargin,\r\n bottom: bottomMargin,\r\n left: leftMargin,\r\n right: rightMargin,\r\n };\r\n const graphWidth = width - margin.left - margin.right;\r\n const graphHeight = height - margin.top - margin.bottom;\r\n\r\n const dataWithId = data.map((d, i) => ({\r\n ...d,\r\n id: labelOrder ? `${d.label}` : `${i}`,\r\n }));\r\n const x = scaleLinear().domain([minValue, maxValue]).range([0, graphWidth]).nice();\r\n const barOrder = labelOrder || dataWithId.map(d => `${d.id}`);\r\n const y = scaleBand()\r\n .domain(barOrder)\r\n .range([\r\n 0,\r\n minBarThickness\r\n ? Math.max(graphHeight, minBarThickness * barOrder.length)\r\n : maxBarThickness\r\n ? Math.min(graphHeight, maxBarThickness * barOrder.length)\r\n : graphHeight,\r\n ])\r\n .paddingInner(barPadding);\r\n const xTicks = x.ticks(noOfTicks);\r\n\r\n return (\r\n <>\r\n <motion.svg\r\n ref={svgRef}\r\n width={`${width}px`}\r\n height={`${height}px`}\r\n viewBox={`0 0 ${width} ${height}`}\r\n direction='ltr'\r\n >\r\n <g transform={`translate(${margin.left},${margin.top})`}>\r\n {showTicks ? (\r\n <XTicksAndGridLines\r\n values={xTicks.filter(d => d !== 0)}\r\n x={xTicks.filter(d => d !== 0).map(d => x(d))}\r\n y1={0 - topMargin}\r\n y2={graphHeight + margin.bottom}\r\n styles={{\r\n gridLines: styles?.xAxis?.gridLines,\r\n labels: styles?.xAxis?.labels,\r\n }}\r\n classNames={{\r\n gridLines: classNames?.xAxis?.gridLines,\r\n labels: classNames?.xAxis?.labels,\r\n }}\r\n suffix={suffix}\r\n prefix={prefix}\r\n labelType='secondary'\r\n showGridLines\r\n precision={precision}\r\n />\r\n ) : null}\r\n <AxisTitle\r\n x={graphWidth / 2}\r\n y={0 - margin.top + 15}\r\n style={styles?.xAxis?.title}\r\n className={classNames?.xAxis?.title}\r\n text={barAxisTitle}\r\n />\r\n {customLayers.filter(d => d.position === 'before').map(d => d.layer)}\r\n <AnimatePresence>\r\n {dataWithId.map(d =>\r\n !checkIfNullOrUndefined(y(d.id)) ? (\r\n <motion.g\r\n className='undp-viz-g-with-hover'\r\n key={d.label}\r\n variants={{\r\n initial: {\r\n opacity: selectedColor\r\n ? d.color\r\n ? barColor[colorDomain.indexOf(d.color)] === selectedColor\r\n ? 1\r\n : dimmedOpacity\r\n : dimmedOpacity\r\n : highlightedDataPoints.length !== 0\r\n ? highlightedDataPoints.indexOf(d.label) !== -1\r\n ? 0.85\r\n : dimmedOpacity\r\n : 0.85,\r\n },\r\n whileInView: {\r\n opacity: selectedColor\r\n ? d.color\r\n ? barColor[colorDomain.indexOf(d.color)] === selectedColor\r\n ? 1\r\n : dimmedOpacity\r\n : dimmedOpacity\r\n : highlightedDataPoints.length !== 0\r\n ? highlightedDataPoints.indexOf(d.label) !== -1\r\n ? 0.85\r\n : dimmedOpacity\r\n : 0.85,\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n onMouseEnter={event => {\r\n setMouseOverData(d);\r\n setEventY(event.clientY);\r\n setEventX(event.clientX);\r\n onSeriesMouseOver?.(d);\r\n }}\r\n onClick={() => {\r\n if (onSeriesMouseClick || detailsOnClick) {\r\n if (isEqual(mouseClickData, d) && resetSelectionOnDoubleClick) {\r\n setMouseClickData(undefined);\r\n onSeriesMouseClick?.(undefined);\r\n } else {\r\n setMouseClickData(d);\r\n onSeriesMouseClick?.(d);\r\n }\r\n }\r\n }}\r\n onMouseMove={event => {\r\n setMouseOverData(d);\r\n setEventY(event.clientY);\r\n setEventX(event.clientX);\r\n }}\r\n onMouseLeave={() => {\r\n setMouseOverData(undefined);\r\n setEventX(undefined);\r\n setEventY(undefined);\r\n onSeriesMouseOver?.(undefined);\r\n }}\r\n >\r\n {d.size ? (\r\n <motion.rect\r\n variants={{\r\n initial: {\r\n width: 0,\r\n x: x(0),\r\n y: y(`${d.id}`),\r\n fill:\r\n data.filter(el => el.color).length === 0\r\n ? barColor[0]\r\n : !d.color\r\n ? Colors.gray\r\n : barColor[colorDomain.indexOf(d.color)],\r\n },\r\n whileInView: {\r\n width: d.size >= 0 ? x(d.size) - x(0) : x(0) - x(d.size),\r\n x: d.size >= 0 ? x(0) : x(d.size),\r\n y: y(`${d.id}`),\r\n fill:\r\n data.filter(el => el.color).length === 0\r\n ? barColor[0]\r\n : !d.color\r\n ? Colors.gray\r\n : barColor[colorDomain.indexOf(d.color)],\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n exit={{\r\n width: 0,\r\n x: x(0),\r\n transition: { duration: animate.duration },\r\n }}\r\n height={y.bandwidth()}\r\n />\r\n ) : null}\r\n {showLabels ? (\r\n <YAxesLabels\r\n value={\r\n `${d.label}`.length < truncateBy\r\n ? `${d.label}`\r\n : `${`${d.label}`.substring(0, truncateBy)}...`\r\n }\r\n y={y(d.id) || 0}\r\n x={(d.size || 0) < 0 ? x(0) : 0 - margin.left}\r\n width={(d.size || 0) < 0 ? width - x(0) : x(0) + margin.left}\r\n height={y.bandwidth()}\r\n alignment={d.size ? (d.size < 0 ? 'left' : 'right') : 'right'}\r\n style={styles?.yAxis?.labels}\r\n className={classNames?.yAxis?.labels}\r\n animate={animate}\r\n isInView={isInView}\r\n />\r\n ) : null}\r\n {showValues ? (\r\n <motion.text\r\n style={{\r\n textAnchor: d.size ? (d.size < 0 ? 'end' : 'start') : 'start',\r\n ...(styles?.graphObjectValues || {}),\r\n }}\r\n className={cn(\r\n 'graph-value text-sm',\r\n !valueColor && barColor.length > 1\r\n ? ' fill-primary-gray-600 dark:fill-primary-gray-300'\r\n : '',\r\n classNames?.graphObjectValues,\r\n )}\r\n dx={d.size ? (d.size < 0 ? -5 : 5) : 5}\r\n dy='0.33em'\r\n variants={{\r\n initial: {\r\n x: x(0),\r\n y: (y(`${d.id}`) as number) + y.bandwidth() / 2,\r\n opacity: 0,\r\n fill: valueColor\r\n ? valueColor\r\n : data.filter(el => el.color).length === 0\r\n ? barColor[0]\r\n : !d.color\r\n ? Colors.gray\r\n : barColor[colorDomain.indexOf(d.color)],\r\n },\r\n whileInView: {\r\n x: d.size ? x(d.size) : x(0),\r\n opacity: 1,\r\n y: (y(`${d.id}`) as number) + y.bandwidth() / 2,\r\n fill: valueColor\r\n ? valueColor\r\n : data.filter(el => el.color).length === 0\r\n ? barColor[0]\r\n : !d.color\r\n ? Colors.gray\r\n : barColor[colorDomain.indexOf(d.color)],\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n exit={{\r\n opacity: 0,\r\n transition: { duration: animate.duration },\r\n }}\r\n >\r\n {numberFormattingFunction(d.size, naLabel, precision, prefix, suffix)}\r\n </motion.text>\r\n ) : null}\r\n </motion.g>\r\n ) : null,\r\n )}\r\n <Axis\r\n x1={x(minValue < 0 ? 0 : minValue)}\r\n x2={x(minValue < 0 ? 0 : minValue)}\r\n y1={-2.5}\r\n y2={graphHeight + margin.bottom}\r\n classNames={{ axis: classNames?.yAxis?.axis }}\r\n styles={{ axis: styles?.yAxis?.axis }}\r\n />\r\n {refValues ? (\r\n <>\r\n {refValues.map((el, i) => (\r\n <RefLineX\r\n key={i}\r\n text={el.text}\r\n color={el.color}\r\n x={x(el.value as number)}\r\n y1={0 - margin.top}\r\n y2={graphHeight + margin.bottom}\r\n textSide={x(el.value as number) > graphWidth * 0.75 || rtl ? 'left' : 'right'}\r\n classNames={el.classNames}\r\n styles={el.styles}\r\n animate={animate}\r\n isInView={isInView}\r\n />\r\n ))}\r\n </>\r\n ) : null}\r\n </AnimatePresence>\r\n {customLayers.filter(d => d.position === 'after').map(d => d.layer)}\r\n </g>\r\n </motion.svg>\r\n {mouseOverData && tooltip && eventX && eventY ? (\r\n <Tooltip\r\n data={mouseOverData}\r\n body={tooltip}\r\n xPos={eventX}\r\n yPos={eventY}\r\n backgroundStyle={styles?.tooltip}\r\n className={classNames?.tooltip}\r\n />\r\n ) : null}\r\n {detailsOnClick && mouseClickData !== undefined ? (\r\n <Modal\r\n open={mouseClickData !== undefined}\r\n onClose={() => {\r\n setMouseClickData(undefined);\r\n }}\r\n >\r\n <div\r\n className='graph-modal-content m-0'\r\n dangerouslySetInnerHTML={\r\n typeof detailsOnClick === 'string'\r\n ? { __html: string2HTML(detailsOnClick, mouseClickData) }\r\n : undefined\r\n }\r\n >\r\n {typeof detailsOnClick === 'function' ? detailsOnClick(mouseClickData) : null}\r\n </div>\r\n </Modal>\r\n ) : null}\r\n </>\r\n );\r\n}\r\n","import uniqBy from 'lodash.uniqby';\r\nimport { useState, useRef, useEffect } from 'react';\r\nimport sortBy from 'lodash.sortby';\r\nimport { format } from 'date-fns/format';\r\nimport { parse } from 'date-fns/parse';\r\nimport { cn } from '@undp/design-system-react/cn';\r\nimport { SliderUI } from '@undp/design-system-react/SliderUI';\r\nimport { ascending, sort } from 'd3-array';\r\n\r\nimport { Graph } from './Graph';\r\n\r\nimport {\r\n BarGraphDataType,\r\n Languages,\r\n ReferenceDataType,\r\n SourcesDataType,\r\n StyleObject,\r\n ClassNameObject,\r\n CustomLayerDataType,\r\n AnimateDataType,\r\n TimelineDataType,\r\n} from '@/Types';\r\nimport { GraphFooter } from '@/Components/Elements/GraphFooter';\r\nimport { GraphHeader } from '@/Components/Elements/GraphHeader';\r\nimport { ColorLegendWithMouseOver } from '@/Components/Elements/ColorLegendWithMouseOver';\r\nimport { Colors } from '@/Components/ColorPalette';\r\nimport { EmptyState } from '@/Components/Elements/EmptyState';\r\nimport { checkIfNullOrUndefined } from '@/Utils/checkIfNullOrUndefined';\r\nimport { Pause, Play } from '@/Components/Icons';\r\nimport { getSliderMarks } from '@/Utils/getSliderMarks';\r\nimport { ensureCompleteDataForBarChart } from '@/Utils/ensureCompleteData';\r\n\r\ninterface Props {\r\n data: BarGraphDataType[];\r\n colors?: string | string[];\r\n labelOrder?: string[];\r\n graphTitle?: string | React.ReactNode;\r\n graphDescription?: string | React.ReactNode;\r\n footNote?: string | React.ReactNode;\r\n width?: number;\r\n height?: number;\r\n minHeight?: number;\r\n suffix?: string;\r\n prefix?: string;\r\n sources?: SourcesDataType[];\r\n barPadding?: number;\r\n showValues?: boolean;\r\n showTicks?: boolean;\r\n leftMargin?: number;\r\n rightMargin?: number;\r\n truncateBy?: number;\r\n colorDomain?: string[];\r\n colorLegendTitle?: string;\r\n backgroundColor?: string | boolean;\r\n padding?: string;\r\n topMargin?: number;\r\n bottomMargin?: number;\r\n relativeHeight?: number;\r\n showLabels?: boolean;\r\n showColorScale?: boolean;\r\n maxValue?: number;\r\n minValue?: number;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n tooltip?: string | ((_d: any) => React.ReactNode);\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseOver?: (_d: any) => void;\r\n refValues?: ReferenceDataType[];\r\n graphID?: string;\r\n highlightedDataPoints?: (string | number)[];\r\n dimmedOpacity?: number;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseClick?: (_d: any) => void;\r\n graphDownload?: boolean;\r\n dataDownload?: boolean;\r\n sortData?: 'asc' | 'desc';\r\n language?: Languages;\r\n showNAColor?: boolean;\r\n theme?: 'light' | 'dark';\r\n maxBarThickness?: number;\r\n maxNumberOfBars?: number;\r\n minBarThickness?: number;\r\n ariaLabel?: string;\r\n resetSelectionOnDoubleClick?: boolean;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n detailsOnClick?: string | ((_d: any) => React.ReactNode);\r\n barAxisTitle?: string;\r\n noOfTicks?: number;\r\n valueColor?: string;\r\n styles?: StyleObject;\r\n classNames?: ClassNameObject;\r\n filterNA?: boolean;\r\n animate?: boolean | AnimateDataType;\r\n precision?: number;\r\n customLayers?: CustomLayerDataType[];\r\n timeline?: TimelineDataType;\r\n naLabel?: string;\r\n}\r\n\r\nexport function HorizontalBarGraph(props: Props) {\r\n const {\r\n data,\r\n graphTitle,\r\n colors,\r\n suffix = '',\r\n sources,\r\n prefix = '',\r\n graphDescription,\r\n barPadding = 0.25,\r\n showValues = true,\r\n showTicks = true,\r\n leftMargin = 100,\r\n rightMargin = 40,\r\n truncateBy = 999,\r\n height,\r\n width,\r\n footNote,\r\n colorDomain,\r\n colorLegendTitle,\r\n highlightedDataPoints = [],\r\n padding,\r\n backgroundColor = false,\r\n topMargin = 25,\r\n bottomMargin = 10,\r\n showLabels = true,\r\n relativeHeight,\r\n tooltip,\r\n onSeriesMouseOver,\r\n refValues,\r\n showColorScale = true,\r\n graphID,\r\n maxValue,\r\n minValue,\r\n onSeriesMouseClick,\r\n graphDownload = false,\r\n dataDownload = false,\r\n sortData,\r\n labelOrder,\r\n language = 'en',\r\n showNAColor = true,\r\n minHeight = 0,\r\n theme = 'light',\r\n maxBarThickness,\r\n maxNumberOfBars,\r\n minBarThickness,\r\n ariaLabel,\r\n resetSelectionOnDoubleClick = true,\r\n detailsOnClick,\r\n barAxisTitle,\r\n noOfTicks = 5,\r\n valueColor,\r\n styles,\r\n classNames,\r\n filterNA = true,\r\n animate = false,\r\n dimmedOpacity = 0.3,\r\n precision = 2,\r\n customLayers = [],\r\n timeline = { enabled: false, autoplay: false, showOnlyActiveDate: true },\r\n naLabel = 'NA',\r\n } = props;\r\n const [svgWidth, setSvgWidth] = useState(0);\r\n const [svgHeight, setSvgHeight] = useState(0);\r\n const [play, setPlay] = useState(timeline.autoplay);\r\n const uniqDatesSorted = sort(\r\n uniqBy(\r\n data.filter(d => d.date !== undefined && d.date !== null),\r\n d => d.date,\r\n ).map(d => parse(`${d.date}`, timeline.dateFormat || 'yyyy', new Date()).getTime()),\r\n (a, b) => ascending(a, b),\r\n );\r\n const [index, setIndex] = useState(timeline.autoplay ? 0 : uniqDatesSorted.length - 1);\r\n const [selectedColor, setSelectedColor] = useState<string | undefined>(undefined);\r\n\r\n const graphDiv = useRef<HTMLDivElement>(null);\r\n const graphParentDiv = useRef<HTMLDivElement>(null);\r\n useEffect(() => {\r\n const resizeObserver = new ResizeObserver(entries => {\r\n setSvgWidth(width || entries[0].target.clientWidth || 620);\r\n setSvgHeight(height || entries[0].target.clientHeight || 480);\r\n });\r\n if (graphDiv.current) {\r\n setSvgHeight(graphDiv.current.clientHeight || 480);\r\n setSvgWidth(graphDiv.current.clientWidth || 620);\r\n if (!width) resizeObserver.observe(graphDiv.current);\r\n }\r\n return () => resizeObserver.disconnect();\r\n }, [width, height]);\r\n\r\n useEffect(() => {\r\n const interval = setInterval(\r\n () => {\r\n setIndex(i => (i < uniqDatesSorted.length - 1 ? i + 1 : 0));\r\n },\r\n (timeline.speed || 2) * 1000,\r\n );\r\n if (!play) clearInterval(interval);\r\n return () => clearInterval(interval);\r\n }, [uniqDatesSorted, play, timeline.speed]);\r\n\r\n const markObj = getSliderMarks(\r\n uniqDatesSorted,\r\n index,\r\n timeline.showOnlyActiveDate,\r\n timeline.dateFormat || 'yyyy',\r\n );\r\n\r\n return (\r\n <div\r\n className={`${theme || 'light'} flex ${width ? 'w-fit grow-0' : 'w-full grow'}`}\r\n dir={language === 'he' || language === 'ar' ? 'rtl' : undefined}\r\n >\r\n <div\r\n className={cn(\r\n `${\r\n !backgroundColor\r\n ? 'bg-transparent '\r\n : backgroundColor === true\r\n ? 'bg-primary-gray-200 dark:bg-primary-gray-650 '\r\n : ''\r\n }ml-auto mr-auto flex flex-col grow h-inherit ${language || 'en'}`,\r\n width ? 'w-fit' : 'w-full',\r\n classNames?.graphContainer,\r\n )}\r\n style={{\r\n ...(styles?.graphContainer || {}),\r\n ...(backgroundColor && backgroundColor !== true ? { backgroundColor } : {}),\r\n }}\r\n id={graphID}\r\n ref={graphParentDiv}\r\n aria-label={\r\n ariaLabel ||\r\n `${graphTitle ? `The graph shows ${graphTitle}. ` : ''}This is a bar chart. ${\r\n graphDescription ? ` ${graphDescription}` : ''\r\n }`\r\n }\r\n >\r\n <div\r\n className='flex grow'\r\n style={{ padding: backgroundColor ? padding || '1rem' : padding || 0 }}\r\n >\r\n <div className='flex flex-col w-full gap-4 grow justify-between'>\r\n {graphTitle || graphDescription || graphDownload || dataDownload ? (\r\n <GraphHeader\r\n styles={{\r\n title: styles?.title,\r\n description: styles?.description,\r\n }}\r\n classNames={{\r\n title: classNames?.title,\r\n description: classNames?.description,\r\n }}\r\n graphTitle={graphTitle}\r\n graphDescription={graphDescription}\r\n width={width}\r\n graphDownload={graphDownload ? graphParentDiv.current : undefined}\r\n dataDownload={\r\n dataDownload\r\n ? data.map(d => d.data).filter(d => d !== undefined).length > 0\r\n ? data.map(d => d.data).filter(d => d !== undefined)\r\n : data.filter(d => d !== undefined)\r\n : null\r\n }\r\n />\r\n ) : null}\r\n {timeline.enabled && uniqDatesSorted.length > 0 && markObj ? (\r\n <div className='flex gap-6 items-center' dir='ltr'>\r\n <button\r\n type='button'\r\n onClick={() => {\r\n setPlay(!play);\r\n }}\r\n className='p-0 border-0 cursor-pointer bg-transparent'\r\n aria-label={play ? 'Click to pause animation' : 'Click to play animation'}\r\n >\r\n {play ? <Pause /> : <Play />}\r\n </button>\r\n <SliderUI\r\n min={uniqDatesSorted[0]}\r\n max={uniqDatesSorted[uniqDatesSorted.length - 1]}\r\n marks={markObj}\r\n step={null}\r\n defaultValue={uniqDatesSorted[uniqDatesSorted.length - 1]}\r\n value={uniqDatesSorted[index]}\r\n onChangeComplete={nextValue => {\r\n setIndex(uniqDatesSorted.indexOf(nextValue as number));\r\n }}\r\n onChange={nextValue => {\r\n setIndex(uniqDatesSorted.indexOf(nextValue as number));\r\n }}\r\n aria-label='Time slider. Use arrow keys to adjust selected time period.'\r\n />\r\n </div>\r\n ) : null}\r\n <div className='grow flex flex-col justify-center gap-3 w-full'>\r\n {data.length === 0 ? (\r\n <EmptyState />\r\n ) : (\r\n <>\r\n {showColorScale && data.filter(el => el.color).length !== 0 ? (\r\n <ColorLegendWithMouseOver\r\n width={width}\r\n colorLegendTitle={colorLegendTitle}\r\n colors={\r\n (colors as string[] | undefined) || Colors[theme].categoricalColors.colors\r\n }\r\n colorDomain={\r\n colorDomain ||\r\n (uniqBy(\r\n data.filter(el => el.color),\r\n 'color',\r\n ).map(d => d.color) as string[])\r\n }\r\n setSelectedColor={setSelectedColor}\r\n showNAColor={showNAColor}\r\n />\r\n ) : null}\r\n <div\r\n className='flex grow flex-col justify-center w-full leading-0'\r\n ref={graphDiv}\r\n aria-label='Graph area'\r\n >\r\n {(width || svgWidth) && (height || svgHeight) ? (\r\n <Graph\r\n data={\r\n sortData === 'asc'\r\n ? sortBy(\r\n ensureCompleteDataForBarChart(data, timeline.dateFormat || 'yyyy')\r\n .filter(d =>\r\n timeline.enabled\r\n ? d.date ===\r\n format(\r\n new Date(uniqDatesSorted[index]),\r\n timeline.dateFormat || 'yyyy',\r\n )\r\n : d,\r\n )\r\n .filter(d => (filterNA ? !checkIfNullOrUndefined(d.size) : d)),\r\n d => d.size,\r\n ).filter((_d, i) => (maxNumberOfBars ? i < maxNumberOfBars : true))\r\n : sortData === 'desc'\r\n ? sortBy(\r\n ensureCompleteDataForBarChart(data, timeline.dateFormat || 'yyyy')\r\n .filter(d =>\r\n timeline.enabled\r\n ? d.date ===\r\n format(\r\n new Date(uniqDatesSorted[index]),\r\n timeline.dateFormat || 'yyyy',\r\n )\r\n : d,\r\n )\r\n .filter(d => (filterNA ? !checkIfNullOrUndefined(d.size) : d)),\r\n d => d.size,\r\n )\r\n .reverse()\r\n .filter((_d, i) => (maxNumberOfBars ? i < maxNumberOfBars : true))\r\n : ensureCompleteDataForBarChart(data, timeline.dateFormat || 'yyyy')\r\n .filter(d =>\r\n timeline.enabled\r\n ? d.date ===\r\n format(\r\n new Date(uniqDatesSorted[index]),\r\n timeline.dateFormat || 'yyyy',\r\n )\r\n : d,\r\n )\r\n .filter(d => (filterNA ? !checkIfNullOrUndefined(d.size) : d))\r\n .filter((_d, i) => (maxNumberOfBars ? i < maxNumberOfBars : true))\r\n }\r\n barColor={\r\n data.filter(el => el.color).length === 0\r\n ? colors\r\n ? [colors as string]\r\n : [Colors.primaryColors['blue-600']]\r\n : (colors as string[] | undefined) ||\r\n Colors[theme].categoricalColors.colors\r\n }\r\n colorDomain={\r\n data.filter(el => el.color).length === 0\r\n ? []\r\n : colorDomain ||\r\n (uniqBy(\r\n data.filter(el => el.color),\r\n 'color',\r\n ).map(d => d.color) as string[])\r\n }\r\n width={width || svgWidth}\r\n selectedColor={selectedColor}\r\n height={Math.max(\r\n minHeight,\r\n height ||\r\n (relativeHeight\r\n ? minHeight\r\n ? (width || svgWidth) * relativeHeight > minHeight\r\n ? (width || svgWidth) * relativeHeight\r\n : minHeight\r\n : (width || svgWidth) * relativeHeight\r\n : svgHeight),\r\n )}\r\n suffix={suffix}\r\n prefix={prefix}\r\n barPadding={barPadding}\r\n showValues={showValues}\r\n showTicks={showTicks}\r\n leftMargin={leftMargin}\r\n rightMargin={rightMargin}\r\n topMargin={topMargin}\r\n bottomMargin={bottomMargin}\r\n truncateBy={truncateBy}\r\n showLabels={showLabels}\r\n tooltip={tooltip}\r\n onSeriesMouseOver={onSeriesMouseOver}\r\n refValues={refValues}\r\n maxValue={\r\n !checkIfNullOrUndefined(maxValue)\r\n ? (maxValue as number)\r\n : Math.max(\r\n ...data\r\n .filter(d => !checkIfNullOrUndefined(d.size))\r\n .map(d => d.size as number),\r\n ) < 0\r\n ? 0\r\n : Math.max(\r\n ...data\r\n .filter(d => !checkIfNullOrUndefined(d.size))\r\n .map(d => d.size as number),\r\n )\r\n }\r\n minValue={\r\n !checkIfNullOrUndefined(minValue)\r\n ? (minValue as number)\r\n : Math.min(\r\n ...data\r\n .filter(d => !checkIfNullOrUndefined(d.size))\r\n .map(d => d.size as number),\r\n ) >= 0\r\n ? 0\r\n : Math.min(\r\n ...data\r\n .filter(d => !checkIfNullOrUndefined(d.size))\r\n .map(d => d.size as number),\r\n )\r\n }\r\n highlightedDataPoints={highlightedDataPoints}\r\n onSeriesMouseClick={onSeriesMouseClick}\r\n labelOrder={labelOrder}\r\n rtl={language === 'he' || language === 'ar'}\r\n maxBarThickness={maxBarThickness}\r\n minBarThickness={minBarThickness}\r\n resetSelectionOnDoubleClick={resetSelectionOnDoubleClick}\r\n detailsOnClick={detailsOnClick}\r\n barAxisTitle={barAxisTitle}\r\n noOfTicks={noOfTicks}\r\n valueColor={valueColor}\r\n classNames={classNames}\r\n styles={styles}\r\n animate={\r\n animate === true\r\n ? { duration: 0.5, once: true, amount: 0.5 }\r\n : animate || { duration: 0, once: true, amount: 0 }\r\n }\r\n dimmedOpacity={dimmedOpacity}\r\n precision={precision}\r\n customLayers={customLayers}\r\n naLabel={naLabel}\r\n />\r\n ) : null}\r\n </div>\r\n </>\r\n )}\r\n </div>\r\n {sources || footNote ? (\r\n <GraphFooter\r\n sources={sources}\r\n footNote={footNote}\r\n width={width}\r\n styles={{ footnote: styles?.footnote, source: styles?.source }}\r\n classNames={{\r\n footnote: classNames?.footnote,\r\n source: classNames?.source,\r\n }}\r\n />\r\n ) : null}\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n );\r\n}\r\n","import isEqual from 'fast-deep-equal';\r\nimport { scaleLinear, scaleBand } from 'd3-scale';\r\nimport { useRef, useState } from 'react';\r\nimport { cn } from '@undp/design-system-react/cn';\r\nimport { Modal } from '@undp/design-system-react/Modal';\r\nimport { AnimatePresence, motion, useInView } from 'motion/react';\r\n\r\nimport {\r\n AnimateDataType,\r\n ClassNameObject,\r\n CustomLayerDataType,\r\n GroupedBarGraphDataType,\r\n ReferenceDataType,\r\n StyleObject,\r\n} from '@/Types';\r\nimport { numberFormattingFunction } from '@/Utils/numberFormattingFunction';\r\nimport { Tooltip } from '@/Components/Elements/Tooltip';\r\nimport { checkIfNullOrUndefined } from '@/Utils/checkIfNullOrUndefined';\r\nimport { string2HTML } from '@/Utils/string2HTML';\r\nimport { YAxesLabels } from '@/Components/Elements/Axes/YAxesLabels';\r\nimport { Axis } from '@/Components/Elements/Axes/Axis';\r\nimport { AxisTitle } from '@/Components/Elements/Axes/AxisTitle';\r\nimport { XTicksAndGridLines } from '@/Components/Elements/Axes/XTicksAndGridLines';\r\nimport { RefLineX } from '@/Components/Elements/ReferenceLine';\r\n\r\ninterface Props {\r\n data: GroupedBarGraphDataType[];\r\n barColors: string[];\r\n barPadding: number;\r\n showTicks: boolean;\r\n leftMargin: number;\r\n rightMargin: number;\r\n topMargin: number;\r\n bottomMargin: number;\r\n truncateBy: number;\r\n showLabels: boolean;\r\n width: number;\r\n suffix: string;\r\n prefix: string;\r\n showValues: boolean;\r\n height: number;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n tooltip?: string | ((_d: any) => React.ReactNode);\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseOver?: (_d: any) => void;\r\n refValues?: ReferenceDataType[];\r\n maxValue: number;\r\n minValue: number;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseClick?: (_d: any) => void;\r\n selectedColor?: string;\r\n rtl: boolean;\r\n labelOrder?: string[];\r\n maxBarThickness?: number;\r\n resetSelectionOnDoubleClick: boolean;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n detailsOnClick?: string | ((_d: any) => React.ReactNode);\r\n barAxisTitle?: string;\r\n noOfTicks: number;\r\n valueColor?: string;\r\n styles?: StyleObject;\r\n classNames?: ClassNameObject;\r\n animate: AnimateDataType;\r\n colorDomain: string[];\r\n precision: number;\r\n customLayers: CustomLayerDataType[];\r\n naLabel: string;\r\n}\r\n\r\nexport function Graph(props: Props) {\r\n const {\r\n data,\r\n barColors,\r\n barPadding,\r\n showTicks,\r\n leftMargin,\r\n truncateBy,\r\n width,\r\n height,\r\n suffix,\r\n prefix,\r\n showValues,\r\n rightMargin,\r\n topMargin,\r\n bottomMargin,\r\n showLabels,\r\n tooltip,\r\n onSeriesMouseOver,\r\n refValues,\r\n maxValue,\r\n minValue,\r\n onSeriesMouseClick,\r\n selectedColor,\r\n rtl,\r\n labelOrder,\r\n maxBarThickness,\r\n resetSelectionOnDoubleClick,\r\n detailsOnClick,\r\n barAxisTitle,\r\n valueColor,\r\n noOfTicks,\r\n styles,\r\n classNames,\r\n animate,\r\n colorDomain,\r\n precision,\r\n customLayers,\r\n naLabel,\r\n } = props;\r\n const svgRef = useRef(null);\r\n const isInView = useInView(svgRef, {\r\n once: animate.once,\r\n amount: animate.amount,\r\n });\r\n const margin = {\r\n top: barAxisTitle ? topMargin + 25 : topMargin,\r\n bottom: bottomMargin,\r\n left: leftMargin,\r\n right: rightMargin,\r\n };\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const [mouseOverData, setMouseOverData] = useState<any>(undefined);\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const [mouseClickData, setMouseClickData] = useState<any>(undefined);\r\n const [eventX, setEventX] = useState<number | undefined>(undefined);\r\n const [eventY, setEventY] = useState<number | undefined>(undefined);\r\n const graphWidth = width - margin.left - margin.right;\r\n const graphHeight = height - margin.top - margin.bottom;\r\n\r\n const dataWithId = data.map((d, i) => ({\r\n ...d,\r\n id: labelOrder ? `${d.label}` : `${i}`,\r\n }));\r\n const barOrder = labelOrder || dataWithId.map(d => `${d.id}`);\r\n\r\n const x = scaleLinear().domain([minValue, maxValue]).range([0, graphWidth]).nice();\r\n const y = scaleBand()\r\n .domain(barOrder)\r\n .range([\r\n 0,\r\n maxBarThickness ? Math.min(graphHeight, maxBarThickness * barOrder.length) : graphHeight,\r\n ])\r\n .paddingInner(barPadding);\r\n const subBarScale = scaleBand()\r\n .domain(data[0].size.map((_d, i) => `${i}`))\r\n .range([0, y.bandwidth()])\r\n .paddingInner(0.1);\r\n const xTicks = x.ticks(noOfTicks);\r\n return (\r\n <>\r\n <motion.svg\r\n ref={svgRef}\r\n width={`${width}px`}\r\n height={`${height}px`}\r\n viewBox={`0 0 ${width} ${height}`}\r\n direction='ltr'\r\n >\r\n <g transform={`translate(${margin.left},${margin.top})`}>\r\n {showTicks ? (\r\n <XTicksAndGridLines\r\n values={xTicks.filter(d => d !== 0)}\r\n x={xTicks.filter(d => d !== 0).map(d => x(d))}\r\n y1={0 - topMargin}\r\n y2={graphHeight + margin.bottom}\r\n styles={{\r\n gridLines: styles?.xAxis?.gridLines,\r\n labels: styles?.xAxis?.labels,\r\n }}\r\n classNames={{\r\n gridLines: classNames?.xAxis?.gridLines,\r\n labels: classNames?.xAxis?.labels,\r\n }}\r\n suffix={suffix}\r\n prefix={prefix}\r\n labelType='secondary'\r\n showGridLines\r\n precision={precision}\r\n />\r\n ) : null}\r\n <AxisTitle\r\n x={graphWidth / 2}\r\n y={0 - margin.top + 15}\r\n style={styles?.xAxis?.title}\r\n className={classNames?.xAxis?.title}\r\n text={barAxisTitle}\r\n />\r\n {customLayers.filter(d => d.position === 'before').map(d => d.layer)}\r\n <AnimatePresence>\r\n {dataWithId.map(d =>\r\n !checkIfNullOrUndefined(y(d.id)) ? (\r\n <motion.g\r\n key={d.label}\r\n variants={{\r\n initial: {\r\n x: 0,\r\n y: y(`${d.id}`),\r\n },\r\n whileInView: {\r\n x: 0,\r\n y: y(`${d.id}`),\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n >\r\n {d.size.map((el, j) => (\r\n <motion.g\r\n className='undp-viz-g-with-hover'\r\n key={`${d.label}-${colorDomain[j] || j}`}\r\n opacity={selectedColor ? (barColors[j] === selectedColor ? 1 : 0.3) : 0.85}\r\n onMouseEnter={event => {\r\n setMouseOverData({ ...d, sizeIndex: j });\r\n setEventY(event.clientY);\r\n setEventX(event.clientX);\r\n onSeriesMouseOver?.({ ...d, sizeIndex: j });\r\n }}\r\n onMouseMove={event => {\r\n setMouseOverData({ ...d, sizeIndex: j });\r\n setEventY(event.clientY);\r\n setEventX(event.clientX);\r\n }}\r\n onMouseLeave={() => {\r\n setMouseOverData(undefined);\r\n setEventX(undefined);\r\n setEventY(undefined);\r\n onSeriesMouseOver?.(undefined);\r\n }}\r\n onClick={() => {\r\n if (onSeriesMouseClick || detailsOnClick) {\r\n if (\r\n isEqual(mouseClickData, { ...d, sizeIndex: j }) &&\r\n resetSelectionOnDoubleClick\r\n ) {\r\n setMouseClickData(undefined);\r\n onSeriesMouseClick?.(undefined);\r\n } else {\r\n setMouseClickData({ ...d, sizeIndex: j });\r\n if (onSeriesMouseClick) onSeriesMouseClick({ ...d, sizeIndex: j });\r\n }\r\n }\r\n }}\r\n >\r\n {!checkIfNullOrUndefined(el) ? (\r\n <motion.rect\r\n y={subBarScale(`${j}`)}\r\n variants={{\r\n initial: {\r\n width: 0,\r\n x: x(0),\r\n fill: barColors[j],\r\n },\r\n whileInView: {\r\n width: !checkIfNullOrUndefined(el)\r\n ? (el as number) >= 0\r\n ? x(el as number) - x(0)\r\n : x(0) - x(el as number)\r\n : 0,\r\n x: (el as number) >= 0 ? x(0) : x(el as number),\r\n fill: barColors[j],\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n exit={{\r\n width: 0,\r\n x: x(0),\r\n transition: { duration: animate.duration },\r\n }}\r\n height={subBarScale.bandwidth()}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n />\r\n ) : null}\r\n {showValues ? (\r\n <motion.text\r\n y={(subBarScale(`${j}`) as number) + subBarScale.bandwidth() / 2}\r\n style={{\r\n fill: valueColor || barColors[j],\r\n textAnchor: el ? (el < 0 ? 'end' : 'start') : 'start',\r\n ...(styles?.graphObjectValues || {}),\r\n }}\r\n className={cn('graph-value text-sm', classNames?.graphObjectValues)}\r\n dx={el ? (el < 0 ? -5 : 5) : 5}\r\n dy='0.33em'\r\n variants={{\r\n initial: { x: x(0), opacity: 0 },\r\n whileInView: {\r\n x: x(el || 0),\r\n opacity: 1,\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n exit={{\r\n opacity: 0,\r\n transition: { duration: animate.duration },\r\n }}\r\n >\r\n {numberFormattingFunction(el, naLabel, precision, prefix, suffix)}\r\n </motion.text>\r\n ) : null}\r\n </motion.g>\r\n ))}\r\n {showLabels ? (\r\n <YAxesLabels\r\n value={\r\n `${d.label}`.length < truncateBy\r\n ? `${d.label}`\r\n : `${`${d.label}`.substring(0, truncateBy)}...`\r\n }\r\n y={0}\r\n x={0 - margin.left}\r\n width={x(minValue < 0 ? 0 : minValue) + margin.left}\r\n height={y.bandwidth()}\r\n style={styles?.yAxis?.labels}\r\n className={classNames?.yAxis?.labels}\r\n animate={animate}\r\n isInView={isInView}\r\n />\r\n ) : null}\r\n </motion.g>\r\n ) : null,\r\n )}\r\n <Axis\r\n x1={x(minValue < 0 ? 0 : minValue)}\r\n x2={x(minValue < 0 ? 0 : minValue)}\r\n y1={-2.5}\r\n y2={graphHeight + margin.bottom}\r\n classNames={{ axis: classNames?.yAxis?.axis }}\r\n styles={{ axis: styles?.yAxis?.axis }}\r\n />\r\n {refValues ? (\r\n <>\r\n {refValues.map((el, i) => (\r\n <RefLineX\r\n key={i}\r\n text={el.text}\r\n color={el.color}\r\n x={x(el.value as number)}\r\n y1={0 - margin.top}\r\n y2={graphHeight + margin.bottom}\r\n textSide={x(el.value as number) > graphWidth * 0.75 || rtl ? 'left' : 'right'}\r\n classNames={el.classNames}\r\n styles={el.styles}\r\n animate={animate}\r\n isInView={isInView}\r\n />\r\n ))}\r\n </>\r\n ) : null}\r\n </AnimatePresence>\r\n {customLayers.filter(d => d.position === 'after').map(d => d.layer)}\r\n </g>\r\n </motion.svg>\r\n {mouseOverData && tooltip && eventX && eventY ? (\r\n <Tooltip\r\n data={mouseOverData}\r\n body={tooltip}\r\n xPos={eventX}\r\n yPos={eventY}\r\n backgroundStyle={styles?.tooltip}\r\n className={classNames?.tooltip}\r\n />\r\n ) : null}\r\n {detailsOnClick && mouseClickData !== undefined ? (\r\n <Modal\r\n open={mouseClickData !== undefined}\r\n onClose={() => {\r\n setMouseClickData(undefined);\r\n }}\r\n >\r\n <div\r\n className='graph-modal-content m-0'\r\n dangerouslySetInnerHTML={\r\n typeof detailsOnClick === 'string'\r\n ? { __html: string2HTML(detailsOnClick, mouseClickData) }\r\n : undefined\r\n }\r\n >\r\n {typeof detailsOnClick === 'function' ? detailsOnClick(mouseClickData) : null}\r\n </div>\r\n </Modal>\r\n ) : null}\r\n </>\r\n );\r\n}\r\n","import { useState, useRef, useEffect } from 'react';\r\nimport { cn } from '@undp/design-system-react/cn';\r\nimport { SliderUI } from '@undp/design-system-react/SliderUI';\r\nimport { format } from 'date-fns/format';\r\nimport { parse } from 'date-fns/parse';\r\nimport uniqBy from 'lodash.uniqby';\r\nimport { ascending, sort } from 'd3-array';\r\nimport orderBy from 'lodash.orderby';\r\nimport sum from 'lodash.sum';\r\n\r\nimport { Graph } from './Graph';\r\n\r\nimport {\r\n GroupedBarGraphDataType,\r\n Languages,\r\n ReferenceDataType,\r\n SourcesDataType,\r\n StyleObject,\r\n ClassNameObject,\r\n CustomLayerDataType,\r\n AnimateDataType,\r\n TimelineDataType,\r\n} from '@/Types';\r\nimport { GraphHeader } from '@/Components/Elements/GraphHeader';\r\nimport { GraphFooter } from '@/Components/Elements/GraphFooter';\r\nimport { ColorLegendWithMouseOver } from '@/Components/Elements/ColorLegendWithMouseOver';\r\nimport { Colors } from '@/Components/ColorPalette';\r\nimport { EmptyState } from '@/Components/Elements/EmptyState';\r\nimport { checkIfNullOrUndefined } from '@/Utils/checkIfNullOrUndefined';\r\nimport { Pause, Play } from '@/Components/Icons';\r\nimport { getSliderMarks } from '@/Utils/getSliderMarks';\r\nimport { ensureCompleteDataForStackedBarChart } from '@/Utils/ensureCompleteData';\r\n\r\ninterface Props {\r\n data: GroupedBarGraphDataType[];\r\n colors?: string[];\r\n graphTitle?: string | React.ReactNode;\r\n graphDescription?: string | React.ReactNode;\r\n footNote?: string | React.ReactNode;\r\n width?: number;\r\n height?: number;\r\n sources?: SourcesDataType[];\r\n barPadding?: number;\r\n showTicks?: boolean;\r\n truncateBy?: number;\r\n colorDomain: string[];\r\n colorLegendTitle?: string;\r\n suffix?: string;\r\n prefix?: string;\r\n showValues?: boolean;\r\n backgroundColor?: string | boolean;\r\n padding?: string;\r\n leftMargin?: number;\r\n rightMargin?: number;\r\n topMargin?: number;\r\n showLabels?: boolean;\r\n bottomMargin?: number;\r\n relativeHeight?: number;\r\n sortParameter?: number | 'total';\r\n sortData?: 'asc' | 'desc';\r\n showColorScale?: boolean;\r\n minHeight?: number;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n tooltip?: string | ((_d: any) => React.ReactNode);\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseOver?: (_d: any) => void;\r\n refValues?: ReferenceDataType[];\r\n graphID?: string;\r\n maxValue?: number;\r\n minValue?: number;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseClick?: (_d: any) => void;\r\n graphDownload?: boolean;\r\n dataDownload?: boolean;\r\n labelOrder?: string[];\r\n language?: Languages;\r\n theme?: 'light' | 'dark';\r\n maxBarThickness?: number;\r\n ariaLabel?: string;\r\n resetSelectionOnDoubleClick?: boolean;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n detailsOnClick?: string | ((_d: any) => React.ReactNode);\r\n barAxisTitle?: string;\r\n noOfTicks?: number;\r\n valueColor?: string;\r\n styles?: StyleObject;\r\n classNames?: ClassNameObject;\r\n filterNA?: boolean;\r\n animate?: boolean | AnimateDataType;\r\n precision?: number;\r\n customLayers?: CustomLayerDataType[];\r\n timeline?: TimelineDataType;\r\n naLabel?: string;\r\n}\r\n\r\nexport function HorizontalGroupedBarGraph(props: Props) {\r\n const {\r\n data,\r\n graphTitle,\r\n colors = Colors.light.categoricalColors.colors,\r\n sources,\r\n graphDescription,\r\n barPadding = 0.25,\r\n showTicks = true,\r\n truncateBy = 999,\r\n height,\r\n width,\r\n footNote,\r\n colorDomain,\r\n colorLegendTitle,\r\n suffix = '',\r\n prefix = '',\r\n showValues = true,\r\n showColorScale = true,\r\n padding,\r\n backgroundColor = false,\r\n leftMargin = 100,\r\n rightMargin = 40,\r\n topMargin = 25,\r\n bottomMargin = 10,\r\n showLabels = true,\r\n relativeHeight,\r\n tooltip,\r\n onSeriesMouseOver,\r\n refValues,\r\n graphID,\r\n maxValue,\r\n minValue,\r\n onSeriesMouseClick,\r\n graphDownload = false,\r\n dataDownload = false,\r\n language = 'en',\r\n labelOrder,\r\n minHeight = 0,\r\n theme = 'light',\r\n maxBarThickness,\r\n ariaLabel,\r\n resetSelectionOnDoubleClick = true,\r\n detailsOnClick,\r\n barAxisTitle,\r\n noOfTicks = 5,\r\n valueColor,\r\n styles,\r\n classNames,\r\n filterNA = true,\r\n animate = false,\r\n precision = 2,\r\n customLayers = [],\r\n timeline = { enabled: false, autoplay: false, showOnlyActiveDate: true },\r\n naLabel = 'NA',\r\n sortParameter,\r\n sortData,\r\n } = props;\r\n\r\n const [svgWidth, setSvgWidth] = useState(0);\r\n const [svgHeight, setSvgHeight] = useState(0);\r\n const [play, setPlay] = useState(timeline.autoplay);\r\n const uniqDatesSorted = sort(\r\n uniqBy(\r\n data.filter(d => d.date !== undefined && d.date !== null),\r\n d => d.date,\r\n ).map(d => parse(`${d.date}`, timeline.dateFormat || 'yyyy', new Date()).getTime()),\r\n (a, b) => ascending(a, b),\r\n );\r\n const [index, setIndex] = useState(timeline.autoplay ? 0 : uniqDatesSorted.length - 1);\r\n const [selectedColor, setSelectedColor] = useState<string | undefined>(undefined);\r\n\r\n const graphDiv = useRef<HTMLDivElement>(null);\r\n const graphParentDiv = useRef<HTMLDivElement>(null);\r\n useEffect(() => {\r\n const resizeObserver = new ResizeObserver(entries => {\r\n setSvgWidth(width || entries[0].target.clientWidth || 620);\r\n setSvgHeight(height || entries[0].target.clientHeight || 480);\r\n });\r\n if (graphDiv.current) {\r\n setSvgHeight(graphDiv.current.clientHeight || 480);\r\n setSvgWidth(graphDiv.current.clientWidth || 620);\r\n if (!width) resizeObserver.observe(graphDiv.current);\r\n }\r\n return () => resizeObserver.disconnect();\r\n }, [width, height]);\r\n\r\n useEffect(() => {\r\n const interval = setInterval(\r\n () => {\r\n setIndex(i => (i < uniqDatesSorted.length - 1 ? i + 1 : 0));\r\n },\r\n (timeline.speed || 2) * 1000,\r\n );\r\n if (!play) clearInterval(interval);\r\n return () => clearInterval(interval);\r\n }, [uniqDatesSorted, play, timeline.speed]);\r\n\r\n const markObj = getSliderMarks(\r\n uniqDatesSorted,\r\n index,\r\n timeline.showOnlyActiveDate,\r\n timeline.dateFormat || 'yyyy',\r\n );\r\n\r\n return (\r\n <div\r\n className={`${theme || 'light'} flex ${width ? 'w-fit grow-0' : 'w-full grow'}`}\r\n dir={language === 'he' || language === 'ar' ? 'rtl' : undefined}\r\n >\r\n <div\r\n className={cn(\r\n `${\r\n !backgroundColor\r\n ? 'bg-transparent '\r\n : backgroundColor === true\r\n ? 'bg-primary-gray-200 dark:bg-primary-gray-650 '\r\n : ''\r\n }ml-auto mr-auto flex flex-col grow h-inherit ${language || 'en'}`,\r\n width ? 'w-fit' : 'w-full',\r\n classNames?.graphContainer,\r\n )}\r\n style={{\r\n ...(styles?.graphContainer || {}),\r\n ...(backgroundColor && backgroundColor !== true ? { backgroundColor } : {}),\r\n }}\r\n id={graphID}\r\n ref={graphParentDiv}\r\n aria-label={\r\n ariaLabel ||\r\n `${graphTitle ? `The graph shows ${graphTitle}. ` : ''}This is a grouped bar chart. ${\r\n graphDescription ? ` ${graphDescription}` : ''\r\n }`\r\n }\r\n >\r\n <div\r\n className='flex grow'\r\n style={{ padding: backgroundColor ? padding || '1rem' : padding || 0 }}\r\n >\r\n <div className='flex flex-col gap-4 w-full grow justify-between'>\r\n {graphTitle || graphDescription || graphDownload || dataDownload ? (\r\n <GraphHeader\r\n styles={{\r\n title: styles?.title,\r\n description: styles?.description,\r\n }}\r\n classNames={{\r\n title: classNames?.title,\r\n description: classNames?.description,\r\n }}\r\n graphTitle={graphTitle}\r\n graphDescription={graphDescription}\r\n width={width}\r\n graphDownload={graphDownload ? graphParentDiv.current : undefined}\r\n dataDownload={\r\n dataDownload\r\n ? data.map(d => d.data).filter(d => d !== undefined).length > 0\r\n ? data.map(d => d.data).filter(d => d !== undefined)\r\n : data.filter(d => d !== undefined)\r\n : null\r\n }\r\n />\r\n ) : null}\r\n {timeline.enabled && uniqDatesSorted.length > 0 && markObj ? (\r\n <div className='flex gap-6 items-center' dir='ltr'>\r\n <button\r\n type='button'\r\n onClick={() => {\r\n setPlay(!play);\r\n }}\r\n className='p-0 border-0 cursor-pointer bg-transparent'\r\n aria-label={play ? 'Click to pause animation' : 'Click to play animation'}\r\n >\r\n {play ? <Pause /> : <Play />}\r\n </button>\r\n <SliderUI\r\n min={uniqDatesSorted[0]}\r\n max={uniqDatesSorted[uniqDatesSorted.length - 1]}\r\n marks={markObj}\r\n step={null}\r\n defaultValue={uniqDatesSorted[uniqDatesSorted.length - 1]}\r\n value={uniqDatesSorted[index]}\r\n onChangeComplete={nextValue => {\r\n setIndex(uniqDatesSorted.indexOf(nextValue as number));\r\n }}\r\n onChange={nextValue => {\r\n setIndex(uniqDatesSorted.indexOf(nextValue as number));\r\n }}\r\n aria-label='Time slider. Use arrow keys to adjust selected time period.'\r\n />\r\n </div>\r\n ) : null}\r\n <div className='grow flex flex-col justify-center gap-3 w-full'>\r\n {data.length === 0 ? (\r\n <EmptyState />\r\n ) : (\r\n <>\r\n {showColorScale ? (\r\n <ColorLegendWithMouseOver\r\n width={width}\r\n colorDomain={colorDomain}\r\n colors={colors}\r\n colorLegendTitle={colorLegendTitle}\r\n setSelectedColor={setSelectedColor}\r\n showNAColor={false}\r\n />\r\n ) : null}\r\n <div className='w-full grow leading-0' ref={graphDiv} aria-label='Graph area'>\r\n {(width || svgWidth) && (height || svgHeight) ? (\r\n <Graph\r\n data={\r\n sortParameter !== undefined\r\n ? sortParameter === 'total'\r\n ? orderBy(\r\n ensureCompleteDataForStackedBarChart(\r\n data,\r\n timeline.dateFormat || 'yyyy',\r\n )\r\n .filter(d =>\r\n timeline.enabled\r\n ? d.date ===\r\n format(\r\n new Date(uniqDatesSorted[index]),\r\n timeline.dateFormat || 'yyyy',\r\n )\r\n : d,\r\n )\r\n .filter(d =>\r\n filterNA ? !d.size.every(item => item == null) : d,\r\n ),\r\n d => sum(d.size.filter(el => !checkIfNullOrUndefined(el))),\r\n [sortData || 'asc'],\r\n )\r\n : orderBy(\r\n ensureCompleteDataForStackedBarChart(\r\n data,\r\n timeline.dateFormat || 'yyyy',\r\n )\r\n .filter(d =>\r\n timeline.enabled\r\n ? d.date ===\r\n format(\r\n new Date(uniqDatesSorted[index]),\r\n timeline.dateFormat || 'yyyy',\r\n )\r\n : d,\r\n )\r\n .filter(d =>\r\n filterNA ? !d.size.every(item => item == null) : d,\r\n ),\r\n d =>\r\n checkIfNullOrUndefined(d.size[sortParameter])\r\n ? -Infinity\r\n : d.size[sortParameter],\r\n [sortData || 'asc'],\r\n )\r\n : ensureCompleteDataForStackedBarChart(\r\n data,\r\n timeline.dateFormat || 'yyyy',\r\n ).filter(d => (filterNA ? !d.size.every(item => item == null) : d))\r\n }\r\n barColors={colors}\r\n width={width || svgWidth}\r\n height={Math.max(\r\n minHeight,\r\n height ||\r\n (relativeHeight\r\n ? minHeight\r\n ? (width || svgWidth) * relativeHeight > minHeight\r\n ? (width || svgWidth) * relativeHeight\r\n : minHeight\r\n : (width || svgWidth) * relativeHeight\r\n : svgHeight),\r\n )}\r\n suffix={suffix}\r\n prefix={prefix}\r\n showValues={showValues}\r\n barPadding={barPadding}\r\n showTicks={showTicks}\r\n leftMargin={leftMargin}\r\n rightMargin={rightMargin}\r\n topMargin={topMargin}\r\n bottomMargin={bottomMargin}\r\n truncateBy={truncateBy}\r\n showLabels={showLabels}\r\n tooltip={tooltip}\r\n onSeriesMouseOver={onSeriesMouseOver}\r\n refValues={refValues}\r\n maxValue={\r\n !checkIfNullOrUndefined(maxValue)\r\n ? (maxValue as number)\r\n : Math.max(\r\n ...data.map(d =>\r\n Math.max(\r\n ...(d.size.filter(\r\n l => !checkIfNullOrUndefined(l),\r\n ) as number[]),\r\n ),\r\n ),\r\n ) < 0\r\n ? 0\r\n : Math.max(\r\n ...data.map(d =>\r\n Math.max(\r\n ...(d.size.filter(\r\n l => !checkIfNullOrUndefined(l),\r\n ) as number[]),\r\n ),\r\n ),\r\n )\r\n }\r\n minValue={\r\n !checkIfNullOrUndefined(minValue)\r\n ? (minValue as number)\r\n : Math.min(\r\n ...data.map(d =>\r\n Math.min(\r\n ...(d.size.filter(\r\n l => !checkIfNullOrUndefined(l),\r\n ) as number[]),\r\n ),\r\n ),\r\n ) >= 0\r\n ? 0\r\n : Math.min(\r\n ...data.map(d =>\r\n Math.min(\r\n ...(d.size.filter(\r\n l => !checkIfNullOrUndefined(l),\r\n ) as number[]),\r\n ),\r\n ),\r\n )\r\n }\r\n onSeriesMouseClick={onSeriesMouseClick}\r\n selectedColor={selectedColor}\r\n labelOrder={labelOrder}\r\n rtl={language === 'he' || language === 'ar'}\r\n maxBarThickness={maxBarThickness}\r\n resetSelectionOnDoubleClick={resetSelectionOnDoubleClick}\r\n detailsOnClick={detailsOnClick}\r\n barAxisTitle={barAxisTitle}\r\n noOfTicks={noOfTicks}\r\n valueColor={valueColor}\r\n styles={styles}\r\n classNames={classNames}\r\n colorDomain={colorDomain}\r\n animate={\r\n animate === true\r\n ? { duration: 0.5, once: true, amount: 0.5 }\r\n : animate || { duration: 0, once: true, amount: 0 }\r\n }\r\n precision={precision}\r\n customLayers={customLayers}\r\n naLabel={naLabel}\r\n />\r\n ) : null}\r\n </div>\r\n </>\r\n )}\r\n </div>\r\n {sources || footNote ? (\r\n <GraphFooter\r\n styles={{ footnote: styles?.footnote, source: styles?.source }}\r\n classNames={{\r\n footnote: classNames?.footnote,\r\n source: classNames?.source,\r\n }}\r\n sources={sources}\r\n footNote={footNote}\r\n width={width}\r\n />\r\n ) : null}\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n );\r\n}\r\n","import isEqual from 'fast-deep-equal';\r\nimport { scaleLinear, scaleBand } from 'd3-scale';\r\nimport sum from 'lodash.sum';\r\nimport { useRef, useState } from 'react';\r\nimport { cn } from '@undp/design-system-react/cn';\r\nimport { Modal } from '@undp/design-system-react/Modal';\r\nimport { AnimatePresence, motion, useInView } from 'motion/react';\r\n\r\nimport {\r\n AnimateDataType,\r\n ClassNameObject,\r\n CustomLayerDataType,\r\n GroupedBarGraphDataType,\r\n ReferenceDataType,\r\n StyleObject,\r\n} from '@/Types';\r\nimport { numberFormattingFunction } from '@/Utils/numberFormattingFunction';\r\nimport { Tooltip } from '@/Components/Elements/Tooltip';\r\nimport { checkIfNullOrUndefined } from '@/Utils/checkIfNullOrUndefined';\r\nimport { getTextColorBasedOnBgColor } from '@/Utils/getTextColorBasedOnBgColor';\r\nimport { string2HTML } from '@/Utils/string2HTML';\r\nimport { YAxesLabels } from '@/Components/Elements/Axes/YAxesLabels';\r\nimport { XTicksAndGridLines } from '@/Components/Elements/Axes/XTicksAndGridLines';\r\nimport { AxisTitle } from '@/Components/Elements/Axes/AxisTitle';\r\nimport { Axis } from '@/Components/Elements/Axes/Axis';\r\nimport { RefLineX } from '@/Components/Elements/ReferenceLine';\r\n\r\ninterface Props {\r\n data: GroupedBarGraphDataType[];\r\n barColors: string[];\r\n barPadding: number;\r\n showTicks: boolean;\r\n leftMargin: number;\r\n truncateBy: number;\r\n width: number;\r\n height: number;\r\n rightMargin: number;\r\n topMargin: number;\r\n showLabels: boolean;\r\n bottomMargin: number;\r\n suffix: string;\r\n prefix: string;\r\n showValues: boolean;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n tooltip?: string | ((_d: any) => React.ReactNode);\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseOver?: (_d: any) => void;\r\n refValues?: ReferenceDataType[];\r\n maxValue: number;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseClick?: (_d: any) => void;\r\n selectedColor?: string;\r\n rtl: boolean;\r\n labelOrder?: string[];\r\n maxBarThickness?: number;\r\n minBarThickness?: number;\r\n resetSelectionOnDoubleClick: boolean;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n detailsOnClick?: string | ((_d: any) => React.ReactNode);\r\n barAxisTitle?: string;\r\n noOfTicks: number;\r\n valueColor?: string;\r\n styles?: StyleObject;\r\n classNames?: ClassNameObject;\r\n animate: AnimateDataType;\r\n colorDomain: string[];\r\n precision: number;\r\n customLayers: CustomLayerDataType[];\r\n naLabel: string;\r\n}\r\n\r\nexport function Graph(props: Props) {\r\n const {\r\n data,\r\n barColors,\r\n barPadding,\r\n showTicks,\r\n leftMargin,\r\n rightMargin,\r\n truncateBy,\r\n width,\r\n height,\r\n topMargin,\r\n bottomMargin,\r\n tooltip,\r\n onSeriesMouseOver,\r\n showLabels,\r\n suffix,\r\n prefix,\r\n showValues,\r\n refValues,\r\n maxValue,\r\n onSeriesMouseClick,\r\n selectedColor,\r\n rtl,\r\n labelOrder,\r\n maxBarThickness,\r\n minBarThickness,\r\n resetSelectionOnDoubleClick,\r\n detailsOnClick,\r\n barAxisTitle,\r\n valueColor,\r\n noOfTicks,\r\n styles,\r\n classNames,\r\n animate,\r\n colorDomain,\r\n precision,\r\n customLayers,\r\n naLabel,\r\n } = props;\r\n const svgRef = useRef(null);\r\n const isInView = useInView(svgRef, {\r\n once: animate.once,\r\n amount: animate.amount,\r\n });\r\n const margin = {\r\n top: barAxisTitle ? topMargin + 25 : topMargin,\r\n bottom: bottomMargin,\r\n left: leftMargin,\r\n right: rightMargin,\r\n };\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const [mouseOverData, setMouseOverData] = useState<any>(undefined);\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const [mouseClickData, setMouseClickData] = useState<any>(undefined);\r\n const [eventX, setEventX] = useState<number | undefined>(undefined);\r\n const [eventY, setEventY] = useState<number | undefined>(undefined);\r\n const graphWidth = width - margin.left - margin.right;\r\n const graphHeight = height - margin.top - margin.bottom;\r\n\r\n const dataWithId = data.map((d, i) => ({\r\n ...d,\r\n id: labelOrder ? `${d.label}` : `${i}`,\r\n }));\r\n const barOrder = labelOrder || dataWithId.map(d => `${d.id}`);\r\n\r\n const x = scaleLinear().domain([0, maxValue]).range([0, graphWidth]).nice();\r\n const y = scaleBand()\r\n .domain(barOrder)\r\n .range([\r\n 0,\r\n minBarThickness\r\n ? Math.max(graphHeight, minBarThickness * barOrder.length)\r\n : maxBarThickness\r\n ? Math.min(graphHeight, maxBarThickness * barOrder.length)\r\n : graphHeight,\r\n ])\r\n .paddingInner(barPadding);\r\n const xTicks = x.ticks(noOfTicks);\r\n\r\n return (\r\n <>\r\n <motion.svg\r\n ref={svgRef}\r\n width={`${width}px`}\r\n height={`${height}px`}\r\n viewBox={`0 0 ${width} ${height}`}\r\n direction='ltr'\r\n >\r\n <g transform={`translate(${margin.left},${margin.top})`}>\r\n {showTicks ? (\r\n <XTicksAndGridLines\r\n values={xTicks.filter(d => d !== 0)}\r\n x={xTicks.filter(d => d !== 0).map(d => x(d))}\r\n y1={0 - topMargin}\r\n y2={graphHeight + margin.bottom}\r\n styles={{\r\n gridLines: styles?.xAxis?.gridLines,\r\n labels: styles?.xAxis?.labels,\r\n }}\r\n classNames={{\r\n gridLines: classNames?.xAxis?.gridLines,\r\n labels: classNames?.xAxis?.labels,\r\n }}\r\n suffix={suffix}\r\n prefix={prefix}\r\n labelType='secondary'\r\n showGridLines\r\n precision={precision}\r\n />\r\n ) : null}\r\n <AxisTitle\r\n x={graphWidth / 2}\r\n y={0 - margin.top + 15}\r\n style={styles?.xAxis?.title}\r\n className={classNames?.xAxis?.title}\r\n text={barAxisTitle}\r\n />\r\n {customLayers.filter(d => d.position === 'before').map(d => d.layer)}\r\n <AnimatePresence>\r\n {dataWithId.map(d =>\r\n !checkIfNullOrUndefined(y(d.id)) ? (\r\n <motion.g\r\n className='undp-viz-low-opacity undp-viz-g-with-hover'\r\n key={d.label}\r\n variants={{\r\n initial: { x: 0, y: y(`${d.id}`) },\r\n whileInView: {\r\n x: 0,\r\n y: y(`${d.id}`),\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n >\r\n {d.size.map((el, j) => (\r\n <motion.g\r\n key={`${d.label}-${colorDomain[j] || j}`}\r\n opacity={selectedColor ? (barColors[j] === selectedColor ? 1 : 0.3) : 1}\r\n onMouseEnter={event => {\r\n setMouseOverData({ ...d, sizeIndex: j });\r\n setEventY(event.clientY);\r\n setEventX(event.clientX);\r\n onSeriesMouseOver?.({ ...d, sizeIndex: j });\r\n }}\r\n onMouseMove={event => {\r\n setMouseOverData({ ...d, sizeIndex: j });\r\n setEventY(event.clientY);\r\n setEventX(event.clientX);\r\n }}\r\n onMouseLeave={() => {\r\n setMouseOverData(undefined);\r\n setEventX(undefined);\r\n setEventY(undefined);\r\n onSeriesMouseOver?.(undefined);\r\n }}\r\n onClick={() => {\r\n if (onSeriesMouseClick || detailsOnClick) {\r\n if (\r\n isEqual(mouseClickData, { ...d, sizeIndex: j }) &&\r\n resetSelectionOnDoubleClick\r\n ) {\r\n setMouseClickData(undefined);\r\n onSeriesMouseClick?.(undefined);\r\n } else {\r\n setMouseClickData({ ...d, sizeIndex: j });\r\n if (onSeriesMouseClick) onSeriesMouseClick({ ...d, sizeIndex: j });\r\n }\r\n }\r\n }}\r\n >\r\n {el ? (\r\n <motion.rect\r\n key={j}\r\n y={0}\r\n style={{ fill: barColors[j] }}\r\n height={y.bandwidth()}\r\n exit={{\r\n width: 0,\r\n x: x(0),\r\n transition: { duration: animate.duration },\r\n }}\r\n variants={{\r\n initial: {\r\n width: 0,\r\n x: x(0),\r\n fill: barColors[j],\r\n },\r\n whileInView: {\r\n width: x(el || 0),\r\n x: x(\r\n j === 0 ? 0 : sum(d.size.filter((element, k) => k < j && element)),\r\n ),\r\n fill: barColors[j],\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n />\r\n ) : null}\r\n {showValues ? (\r\n <motion.text\r\n y={y.bandwidth() / 2}\r\n style={{\r\n textAnchor: 'middle',\r\n ...(styles?.graphObjectValues || {}),\r\n }}\r\n dy='0.33em'\r\n className={cn('graph-value text-sm', classNames?.graphObjectValues)}\r\n exit={{\r\n opacity: 0,\r\n transition: { duration: animate.duration },\r\n }}\r\n variants={{\r\n initial: {\r\n x: x(0),\r\n opacity: 0,\r\n fill: getTextColorBasedOnBgColor(barColors[j]),\r\n },\r\n whileInView: {\r\n x:\r\n x(\r\n j === 0\r\n ? 0\r\n : sum(d.size.filter((element, k) => k < j && element)),\r\n ) +\r\n x(el || 0) / 2,\r\n opacity:\r\n el &&\r\n x(el) /\r\n numberFormattingFunction(el, naLabel, precision, prefix, suffix)\r\n .length >\r\n 12\r\n ? 1\r\n : 0,\r\n fill: getTextColorBasedOnBgColor(barColors[j]),\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n >\r\n {numberFormattingFunction(el, naLabel, precision, prefix, suffix)}\r\n </motion.text>\r\n ) : null}\r\n </motion.g>\r\n ))}\r\n {showLabels ? (\r\n <YAxesLabels\r\n value={\r\n `${d.label}`.length < truncateBy\r\n ? `${d.label}`\r\n : `${`${d.label}`.substring(0, truncateBy)}...`\r\n }\r\n y={0}\r\n x={0 - margin.left}\r\n width={0 + margin.left}\r\n height={y.bandwidth()}\r\n style={styles?.yAxis?.labels}\r\n className={classNames?.yAxis?.labels}\r\n animate={animate}\r\n isInView={isInView}\r\n />\r\n ) : null}\r\n {showValues ? (\r\n <motion.text\r\n className={cn(\r\n 'graph-value graph-value-total text-sm',\r\n !valueColor ? ' fill-primary-gray-700 dark:fill-primary-gray-300' : '',\r\n classNames?.graphObjectValues,\r\n )}\r\n style={{\r\n ...(valueColor ? { fill: valueColor } : {}),\r\n textAnchor: 'start',\r\n ...(styles?.graphObjectValues || {}),\r\n }}\r\n y={y.bandwidth() / 2}\r\n dx={5}\r\n dy='0.33em'\r\n variants={{\r\n initial: {\r\n x: x(0),\r\n opacity: 0,\r\n },\r\n whileInView: {\r\n x: x(sum(d.size.map(el => el || 0))),\r\n opacity: 1,\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n exit={{\r\n opacity: 0,\r\n transition: { duration: animate.duration },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n >\r\n {numberFormattingFunction(\r\n sum(d.size.filter(element => element)),\r\n naLabel,\r\n precision,\r\n prefix,\r\n suffix,\r\n )}\r\n </motion.text>\r\n ) : null}\r\n </motion.g>\r\n ) : null,\r\n )}\r\n <Axis\r\n x1={x(0)}\r\n x2={x(0)}\r\n y1={-2.5}\r\n y2={graphHeight + margin.bottom}\r\n classNames={{ axis: classNames?.yAxis?.axis }}\r\n styles={{ axis: styles?.yAxis?.axis }}\r\n />\r\n {refValues ? (\r\n <>\r\n {refValues.map((el, i) => (\r\n <RefLineX\r\n key={i}\r\n text={el.text}\r\n color={el.color}\r\n x={x(el.value as number)}\r\n y1={0 - margin.top}\r\n y2={graphHeight + margin.bottom}\r\n textSide={x(el.value as number) > graphWidth * 0.75 || rtl ? 'left' : 'right'}\r\n classNames={el.classNames}\r\n styles={el.styles}\r\n animate={animate}\r\n isInView={isInView}\r\n />\r\n ))}\r\n </>\r\n ) : null}\r\n </AnimatePresence>\r\n {customLayers.filter(d => d.position === 'after').map(d => d.layer)}\r\n </g>\r\n </motion.svg>\r\n {mouseOverData && tooltip && eventX && eventY ? (\r\n <Tooltip\r\n data={mouseOverData}\r\n body={tooltip}\r\n xPos={eventX}\r\n yPos={eventY}\r\n backgroundStyle={styles?.tooltip}\r\n className={classNames?.tooltip}\r\n />\r\n ) : null}\r\n {detailsOnClick && mouseClickData !== undefined ? (\r\n <Modal\r\n open={mouseClickData !== undefined}\r\n onClose={() => {\r\n setMouseClickData(undefined);\r\n }}\r\n >\r\n <div\r\n className='graph-modal-content m-0'\r\n dangerouslySetInnerHTML={\r\n typeof detailsOnClick === 'string'\r\n ? { __html: string2HTML(detailsOnClick, mouseClickData) }\r\n : undefined\r\n }\r\n >\r\n {typeof detailsOnClick === 'function' ? detailsOnClick(mouseClickData) : null}\r\n </div>\r\n </Modal>\r\n ) : null}\r\n </>\r\n );\r\n}\r\n","import { useState, useRef, useEffect } from 'react';\r\nimport sum from 'lodash.sum';\r\nimport { format } from 'date-fns/format';\r\nimport { parse } from 'date-fns/parse';\r\nimport { cn } from '@undp/design-system-react/cn';\r\nimport { SliderUI } from '@undp/design-system-react/SliderUI';\r\nimport { ascending, sort } from 'd3-array';\r\nimport uniqBy from 'lodash.uniqby';\r\nimport orderBy from 'lodash.orderby';\r\n\r\nimport { Graph } from './Graph';\r\n\r\nimport { checkIfNullOrUndefined } from '@/Utils/checkIfNullOrUndefined';\r\nimport {\r\n GroupedBarGraphDataType,\r\n Languages,\r\n ReferenceDataType,\r\n SourcesDataType,\r\n StyleObject,\r\n ClassNameObject,\r\n CustomLayerDataType,\r\n AnimateDataType,\r\n TimelineDataType,\r\n} from '@/Types';\r\nimport { GraphFooter } from '@/Components/Elements/GraphFooter';\r\nimport { GraphHeader } from '@/Components/Elements/GraphHeader';\r\nimport { ColorLegendWithMouseOver } from '@/Components/Elements/ColorLegendWithMouseOver';\r\nimport { Colors } from '@/Components/ColorPalette';\r\nimport { EmptyState } from '@/Components/Elements/EmptyState';\r\nimport { Pause, Play } from '@/Components/Icons';\r\nimport { getSliderMarks } from '@/Utils/getSliderMarks';\r\nimport { ensureCompleteDataForStackedBarChart } from '@/Utils/ensureCompleteData';\r\n\r\ninterface Props {\r\n data: GroupedBarGraphDataType[];\r\n colors?: string[];\r\n labelOrder?: string[];\r\n graphTitle?: string | React.ReactNode;\r\n graphDescription?: string | React.ReactNode;\r\n footNote?: string | React.ReactNode;\r\n width?: number;\r\n height?: number;\r\n sources?: SourcesDataType[];\r\n barPadding?: number;\r\n showTicks?: boolean;\r\n leftMargin?: number;\r\n rightMargin?: number;\r\n truncateBy?: number;\r\n colorDomain: string[];\r\n colorLegendTitle?: string;\r\n backgroundColor?: string | boolean;\r\n padding?: string;\r\n topMargin?: number;\r\n bottomMargin?: number;\r\n suffix?: string;\r\n prefix?: string;\r\n showValues?: boolean;\r\n showLabels?: boolean;\r\n relativeHeight?: number;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n tooltip?: string | ((_d: any) => React.ReactNode);\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseOver?: (_d: any) => void;\r\n refValues?: ReferenceDataType[];\r\n graphID?: string;\r\n maxValue?: number;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseClick?: (_d: any) => void;\r\n graphDownload?: boolean;\r\n dataDownload?: boolean;\r\n language?: Languages;\r\n minHeight?: number;\r\n theme?: 'light' | 'dark';\r\n maxBarThickness?: number;\r\n sortParameter?: number | 'total';\r\n sortData?: 'asc' | 'desc';\r\n maxNumberOfBars?: number;\r\n minBarThickness?: number;\r\n ariaLabel?: string;\r\n resetSelectionOnDoubleClick?: boolean;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n detailsOnClick?: string | ((_d: any) => React.ReactNode);\r\n barAxisTitle?: string;\r\n noOfTicks?: number;\r\n valueColor?: string;\r\n styles?: StyleObject;\r\n classNames?: ClassNameObject;\r\n filterNA?: boolean;\r\n animate?: boolean | AnimateDataType;\r\n precision?: number;\r\n showColorScale?: boolean;\r\n customLayers?: CustomLayerDataType[];\r\n timeline?: TimelineDataType;\r\n naLabel?: string;\r\n}\r\n\r\nexport function HorizontalStackedBarGraph(props: Props) {\r\n const {\r\n data,\r\n graphTitle,\r\n colors = Colors.light.categoricalColors.colors,\r\n sources,\r\n graphDescription,\r\n barPadding = 0.25,\r\n showTicks = true,\r\n leftMargin = 100,\r\n rightMargin = 40,\r\n truncateBy = 999,\r\n height,\r\n width,\r\n footNote,\r\n colorDomain,\r\n colorLegendTitle,\r\n padding,\r\n backgroundColor = false,\r\n topMargin = 25,\r\n bottomMargin = 10,\r\n tooltip,\r\n onSeriesMouseOver,\r\n suffix = '',\r\n prefix = '',\r\n showLabels = true,\r\n relativeHeight,\r\n showValues = true,\r\n refValues,\r\n graphID,\r\n maxValue,\r\n onSeriesMouseClick,\r\n graphDownload = false,\r\n dataDownload = false,\r\n language = 'en',\r\n labelOrder,\r\n minHeight = 0,\r\n theme = 'light',\r\n maxBarThickness,\r\n sortParameter,\r\n maxNumberOfBars,\r\n minBarThickness,\r\n showColorScale = true,\r\n ariaLabel,\r\n resetSelectionOnDoubleClick = true,\r\n detailsOnClick,\r\n barAxisTitle,\r\n noOfTicks = 5,\r\n valueColor,\r\n styles,\r\n classNames,\r\n filterNA = true,\r\n animate = false,\r\n precision = 2,\r\n customLayers = [],\r\n timeline = { enabled: false, autoplay: false, showOnlyActiveDate: true },\r\n naLabel = 'NA',\r\n sortData,\r\n } = props;\r\n\r\n const [svgWidth, setSvgWidth] = useState(0);\r\n const [svgHeight, setSvgHeight] = useState(0);\r\n const [play, setPlay] = useState(timeline.autoplay);\r\n const uniqDatesSorted = sort(\r\n uniqBy(\r\n data.filter(d => d.date !== undefined && d.date !== null),\r\n d => d.date,\r\n ).map(d => parse(`${d.date}`, timeline.dateFormat || 'yyyy', new Date()).getTime()),\r\n (a, b) => ascending(a, b),\r\n );\r\n const [index, setIndex] = useState(timeline.autoplay ? 0 : uniqDatesSorted.length - 1);\r\n const [selectedColor, setSelectedColor] = useState<string | undefined>(undefined);\r\n\r\n const graphDiv = useRef<HTMLDivElement>(null);\r\n const graphParentDiv = useRef<HTMLDivElement>(null);\r\n useEffect(() => {\r\n const resizeObserver = new ResizeObserver(entries => {\r\n setSvgWidth(width || entries[0].target.clientWidth || 620);\r\n setSvgHeight(height || entries[0].target.clientHeight || 480);\r\n });\r\n if (graphDiv.current) {\r\n setSvgHeight(graphDiv.current.clientHeight || 480);\r\n setSvgWidth(graphDiv.current.clientWidth || 620);\r\n if (!width) resizeObserver.observe(graphDiv.current);\r\n }\r\n return () => resizeObserver.disconnect();\r\n }, [width, height]);\r\n\r\n useEffect(() => {\r\n const interval = setInterval(\r\n () => {\r\n setIndex(i => (i < uniqDatesSorted.length - 1 ? i + 1 : 0));\r\n },\r\n (timeline.speed || 2) * 1000,\r\n );\r\n if (!play) clearInterval(interval);\r\n return () => clearInterval(interval);\r\n }, [uniqDatesSorted, play, timeline.speed]);\r\n\r\n const markObj = getSliderMarks(\r\n uniqDatesSorted,\r\n index,\r\n timeline.showOnlyActiveDate,\r\n timeline.dateFormat || 'yyyy',\r\n );\r\n\r\n return (\r\n <div\r\n className={`${theme || 'light'} flex ${width ? 'w-fit grow-0' : 'w-full grow'}`}\r\n dir={language === 'he' || language === 'ar' ? 'rtl' : undefined}\r\n >\r\n <div\r\n className={cn(\r\n `${\r\n !backgroundColor\r\n ? 'bg-transparent '\r\n : backgroundColor === true\r\n ? 'bg-primary-gray-200 dark:bg-primary-gray-650 '\r\n : ''\r\n }ml-auto mr-auto flex flex-col grow h-inherit ${language || 'en'}`,\r\n width ? 'w-fit' : 'w-full',\r\n classNames?.graphContainer,\r\n )}\r\n style={{\r\n ...(styles?.graphContainer || {}),\r\n ...(backgroundColor && backgroundColor !== true ? { backgroundColor } : {}),\r\n }}\r\n id={graphID}\r\n ref={graphParentDiv}\r\n aria-label={\r\n ariaLabel ||\r\n `${graphTitle ? `The graph shows ${graphTitle}. ` : ''}This is a stacked bar chart. ${\r\n graphDescription ? ` ${graphDescription}` : ''\r\n }`\r\n }\r\n >\r\n <div\r\n className='flex grow'\r\n style={{ padding: backgroundColor ? padding || '1rem' : padding || 0 }}\r\n >\r\n <div className='flex flex-col gap-4 w-full grow justify-between'>\r\n {graphTitle || graphDescription || graphDownload || dataDownload ? (\r\n <GraphHeader\r\n styles={{\r\n title: styles?.title,\r\n description: styles?.description,\r\n }}\r\n classNames={{\r\n title: classNames?.title,\r\n description: classNames?.description,\r\n }}\r\n graphTitle={graphTitle}\r\n graphDescription={graphDescription}\r\n width={width}\r\n graphDownload={graphDownload ? graphParentDiv.current : undefined}\r\n dataDownload={\r\n dataDownload\r\n ? data.map(d => d.data).filter(d => d !== undefined).length > 0\r\n ? data.map(d => d.data).filter(d => d !== undefined)\r\n : data.filter(d => d !== undefined)\r\n : null\r\n }\r\n />\r\n ) : null}\r\n {timeline.enabled && uniqDatesSorted.length > 0 && markObj ? (\r\n <div className='flex gap-6 items-center' dir='ltr'>\r\n <button\r\n type='button'\r\n onClick={() => {\r\n setPlay(!play);\r\n }}\r\n className='p-0 border-0 cursor-pointer bg-transparent'\r\n aria-label={play ? 'Click to pause animation' : 'Click to play animation'}\r\n >\r\n {play ? <Pause /> : <Play />}\r\n </button>\r\n <SliderUI\r\n min={uniqDatesSorted[0]}\r\n max={uniqDatesSorted[uniqDatesSorted.length - 1]}\r\n marks={markObj}\r\n step={null}\r\n defaultValue={uniqDatesSorted[uniqDatesSorted.length - 1]}\r\n value={uniqDatesSorted[index]}\r\n onChangeComplete={nextValue => {\r\n setIndex(uniqDatesSorted.indexOf(nextValue as number));\r\n }}\r\n onChange={nextValue => {\r\n setIndex(uniqDatesSorted.indexOf(nextValue as number));\r\n }}\r\n aria-label='Time slider. Use arrow keys to adjust selected time period.'\r\n />\r\n </div>\r\n ) : null}\r\n <div className='grow flex flex-col justify-center gap-3 w-full'>\r\n {data.length === 0 ? (\r\n <EmptyState />\r\n ) : (\r\n <>\r\n {showColorScale ? (\r\n <ColorLegendWithMouseOver\r\n width={width}\r\n colorDomain={colorDomain}\r\n colors={colors}\r\n colorLegendTitle={colorLegendTitle}\r\n setSelectedColor={setSelectedColor}\r\n showNAColor={false}\r\n />\r\n ) : null}\r\n <div className='w-full grow leading-0' ref={graphDiv} aria-label='Graph area'>\r\n {(width || svgWidth) && (height || svgHeight) ? (\r\n <Graph\r\n data={\r\n sortParameter !== undefined\r\n ? sortParameter === 'total'\r\n ? orderBy(\r\n ensureCompleteDataForStackedBarChart(\r\n data,\r\n timeline.dateFormat || 'yyyy',\r\n )\r\n .filter(d =>\r\n timeline.enabled\r\n ? d.date ===\r\n format(\r\n new Date(uniqDatesSorted[index]),\r\n timeline.dateFormat || 'yyyy',\r\n )\r\n : d,\r\n )\r\n .filter(d =>\r\n filterNA ? !d.size.every(item => item == null) : d,\r\n ),\r\n d => sum(d.size.filter(el => !checkIfNullOrUndefined(el))),\r\n [sortData || 'asc'],\r\n ).filter((_d, i) => (maxNumberOfBars ? i < maxNumberOfBars : true))\r\n : orderBy(\r\n ensureCompleteDataForStackedBarChart(\r\n data,\r\n timeline.dateFormat || 'yyyy',\r\n )\r\n .filter(d =>\r\n timeline.enabled\r\n ? d.date ===\r\n format(\r\n new Date(uniqDatesSorted[index]),\r\n timeline.dateFormat || 'yyyy',\r\n )\r\n : d,\r\n )\r\n .filter(d =>\r\n filterNA ? !d.size.every(item => item == null) : d,\r\n ),\r\n d =>\r\n checkIfNullOrUndefined(d.size[sortParameter])\r\n ? -Infinity\r\n : d.size[sortParameter],\r\n [sortData || 'asc'],\r\n ).filter((_d, i) => (maxNumberOfBars ? i < maxNumberOfBars : true))\r\n : ensureCompleteDataForStackedBarChart(\r\n data,\r\n timeline.dateFormat || 'yyyy',\r\n )\r\n .filter(d =>\r\n timeline.enabled\r\n ? d.date ===\r\n format(\r\n new Date(uniqDatesSorted[index]),\r\n timeline.dateFormat || 'yyyy',\r\n )\r\n : d,\r\n )\r\n .filter(d => (filterNA ? !d.size.every(item => item == null) : d))\r\n .filter((_d, i) => (maxNumberOfBars ? i < maxNumberOfBars : true))\r\n }\r\n barColors={colors}\r\n width={width || svgWidth}\r\n height={Math.max(\r\n minHeight,\r\n height ||\r\n (relativeHeight\r\n ? minHeight\r\n ? (width || svgWidth) * relativeHeight > minHeight\r\n ? (width || svgWidth) * relativeHeight\r\n : minHeight\r\n : (width || svgWidth) * relativeHeight\r\n : svgHeight),\r\n )}\r\n barPadding={barPadding}\r\n showTicks={showTicks}\r\n leftMargin={leftMargin}\r\n rightMargin={rightMargin}\r\n topMargin={topMargin}\r\n bottomMargin={bottomMargin}\r\n truncateBy={truncateBy}\r\n showLabels={showLabels}\r\n tooltip={tooltip}\r\n onSeriesMouseOver={onSeriesMouseOver}\r\n showValues={showValues}\r\n suffix={suffix}\r\n prefix={prefix}\r\n refValues={refValues}\r\n maxValue={\r\n !checkIfNullOrUndefined(maxValue)\r\n ? (maxValue as number)\r\n : Math.max(\r\n ...data.map(\r\n d => sum(d.size.filter(l => !checkIfNullOrUndefined(l))) || 0,\r\n ),\r\n )\r\n }\r\n onSeriesMouseClick={onSeriesMouseClick}\r\n selectedColor={selectedColor}\r\n rtl={language === 'he' || language === 'ar'}\r\n labelOrder={labelOrder}\r\n maxBarThickness={maxBarThickness}\r\n minBarThickness={minBarThickness}\r\n resetSelectionOnDoubleClick={resetSelectionOnDoubleClick}\r\n detailsOnClick={detailsOnClick}\r\n barAxisTitle={barAxisTitle}\r\n noOfTicks={noOfTicks}\r\n valueColor={valueColor}\r\n classNames={classNames}\r\n styles={styles}\r\n animate={\r\n animate === true\r\n ? { duration: 0.5, once: true, amount: 0.5 }\r\n : animate || { duration: 0, once: true, amount: 0 }\r\n }\r\n colorDomain={colorDomain}\r\n precision={precision}\r\n customLayers={customLayers}\r\n naLabel={naLabel}\r\n />\r\n ) : null}\r\n </div>\r\n </>\r\n )}\r\n </div>\r\n {sources || footNote ? (\r\n <GraphFooter\r\n styles={{ footnote: styles?.footnote, source: styles?.source }}\r\n classNames={{\r\n footnote: classNames?.footnote,\r\n source: classNames?.source,\r\n }}\r\n sources={sources}\r\n footNote={footNote}\r\n width={width}\r\n />\r\n ) : null}\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n );\r\n}\r\n","import isEqual from 'fast-deep-equal';\r\nimport { scaleLinear, scaleBand } from 'd3-scale';\r\nimport { useRef, useState } from 'react';\r\nimport { cn } from '@undp/design-system-react/cn';\r\nimport { Modal } from '@undp/design-system-react/Modal';\r\nimport { AnimatePresence, motion, useInView } from 'motion/react';\r\n\r\nimport { numberFormattingFunction } from '@/Utils/numberFormattingFunction';\r\nimport {\r\n AnimateDataType,\r\n BarGraphDataType,\r\n ClassNameObject,\r\n CustomLayerDataType,\r\n ReferenceDataType,\r\n StyleObject,\r\n} from '@/Types';\r\nimport { Tooltip } from '@/Components/Elements/Tooltip';\r\nimport { checkIfNullOrUndefined } from '@/Utils/checkIfNullOrUndefined';\r\nimport { Colors } from '@/Components/ColorPalette';\r\nimport { string2HTML } from '@/Utils/string2HTML';\r\nimport { Axis } from '@/Components/Elements/Axes/Axis';\r\nimport { AxisTitle } from '@/Components/Elements/Axes/AxisTitle';\r\nimport { XAxesLabels } from '@/Components/Elements/Axes/XAxesLabels';\r\nimport { RefLineY } from '@/Components/Elements/ReferenceLine';\r\nimport { YTicksAndGridLines } from '@/Components/Elements/Axes/YTicksAndGridLines';\r\n\r\ninterface Props {\r\n data: BarGraphDataType[];\r\n width: number;\r\n height: number;\r\n barColor: string[];\r\n suffix: string;\r\n prefix: string;\r\n barPadding: number;\r\n showLabels: boolean;\r\n showValues: boolean;\r\n showTicks: boolean;\r\n colorDomain: string[];\r\n truncateBy: number;\r\n leftMargin: number;\r\n rightMargin: number;\r\n topMargin: number;\r\n bottomMargin: number;\r\n refValues?: ReferenceDataType[];\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n tooltip?: string | ((_d: any) => React.ReactNode);\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseOver?: (_d: any) => void;\r\n selectedColor?: string;\r\n maxValue: number;\r\n minValue: number;\r\n highlightedDataPoints: (string | number)[];\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseClick?: (_d: any) => void;\r\n labelOrder?: string[];\r\n maxBarThickness?: number;\r\n minBarThickness?: number;\r\n resetSelectionOnDoubleClick: boolean;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n detailsOnClick?: string | ((_d: any) => React.ReactNode);\r\n barAxisTitle?: string;\r\n noOfTicks: number;\r\n valueColor?: string;\r\n styles?: StyleObject;\r\n classNames?: ClassNameObject;\r\n animate: AnimateDataType;\r\n dimmedOpacity: number;\r\n precision: number;\r\n customLayers: CustomLayerDataType[];\r\n naLabel: string;\r\n}\r\n\r\nexport function Graph(props: Props) {\r\n const {\r\n data,\r\n width,\r\n height,\r\n barColor,\r\n suffix,\r\n prefix,\r\n barPadding,\r\n showLabels,\r\n showValues,\r\n showTicks,\r\n colorDomain,\r\n truncateBy,\r\n rightMargin,\r\n topMargin,\r\n bottomMargin,\r\n leftMargin,\r\n tooltip,\r\n onSeriesMouseOver,\r\n refValues,\r\n selectedColor,\r\n maxValue,\r\n minValue,\r\n highlightedDataPoints,\r\n onSeriesMouseClick,\r\n labelOrder,\r\n maxBarThickness,\r\n minBarThickness,\r\n resetSelectionOnDoubleClick,\r\n detailsOnClick,\r\n barAxisTitle,\r\n valueColor,\r\n noOfTicks,\r\n styles,\r\n classNames,\r\n dimmedOpacity,\r\n animate,\r\n precision,\r\n customLayers,\r\n naLabel,\r\n } = props;\r\n const svgRef = useRef(null);\r\n const isInView = useInView(svgRef, {\r\n once: animate.once,\r\n amount: animate.amount,\r\n });\r\n const margin = {\r\n top: topMargin,\r\n bottom: bottomMargin,\r\n left: barAxisTitle ? leftMargin + 30 : leftMargin,\r\n right: rightMargin,\r\n };\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const [mouseOverData, setMouseOverData] = useState<any>(undefined);\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const [mouseClickData, setMouseClickData] = useState<any>(undefined);\r\n const [eventX, setEventX] = useState<number | undefined>(undefined);\r\n const [eventY, setEventY] = useState<number | undefined>(undefined);\r\n const graphWidth = width - margin.left - margin.right;\r\n const graphHeight = height - margin.top - margin.bottom;\r\n\r\n const y = scaleLinear().domain([minValue, maxValue]).range([graphHeight, 0]).nice();\r\n\r\n const dataWithId = data.map((d, i) => ({\r\n ...d,\r\n id: labelOrder ? `${d.label}` : `${i}`,\r\n }));\r\n const barOrder = labelOrder || dataWithId.map(d => `${d.id}`);\r\n const x = scaleBand()\r\n .domain(barOrder)\r\n .range([\r\n 0,\r\n minBarThickness\r\n ? Math.max(graphWidth, minBarThickness * barOrder.length)\r\n : maxBarThickness\r\n ? Math.min(graphWidth, maxBarThickness * barOrder.length)\r\n : graphWidth,\r\n ])\r\n .paddingInner(barPadding);\r\n const yTicks = y.ticks(noOfTicks);\r\n return (\r\n <>\r\n <motion.svg\r\n ref={svgRef}\r\n width={`${width}px`}\r\n height={`${height}px`}\r\n viewBox={`0 0 ${width} ${height}`}\r\n direction='ltr'\r\n >\r\n <g transform={`translate(${margin.left},${margin.top})`}>\r\n <Axis\r\n y1={y(minValue < 0 ? 0 : minValue)}\r\n y2={y(minValue < 0 ? 0 : minValue)}\r\n x1={0 - leftMargin}\r\n x2={graphWidth + margin.right}\r\n label={numberFormattingFunction(\r\n minValue < 0 ? 0 : minValue,\r\n naLabel,\r\n precision,\r\n prefix,\r\n suffix,\r\n )}\r\n labelPos={{\r\n x: 0 - leftMargin,\r\n dx: 0,\r\n dy: maxValue < 0 ? '1em' : -5,\r\n y: y(minValue < 0 ? 0 : minValue),\r\n }}\r\n classNames={{\r\n axis: classNames?.xAxis?.axis,\r\n label: classNames?.yAxis?.labels,\r\n }}\r\n styles={{ axis: styles?.xAxis?.axis, label: styles?.yAxis?.labels }}\r\n />\r\n {showTicks ? (\r\n <YTicksAndGridLines\r\n values={yTicks.filter(d => d !== 0)}\r\n y={yTicks.filter(d => d !== 0).map(d => y(d))}\r\n x1={0 - leftMargin}\r\n x2={graphWidth + margin.right}\r\n styles={{\r\n gridLines: styles?.yAxis?.gridLines,\r\n labels: styles?.yAxis?.labels,\r\n }}\r\n classNames={{\r\n gridLines: classNames?.yAxis?.gridLines,\r\n labels: classNames?.yAxis?.labels,\r\n }}\r\n suffix={suffix}\r\n prefix={prefix}\r\n labelType='secondary'\r\n showGridLines\r\n labelPos='vertical'\r\n precision={precision}\r\n />\r\n ) : null}\r\n <AxisTitle\r\n x={0 - leftMargin - 15}\r\n y={graphHeight / 2}\r\n style={styles?.yAxis?.title}\r\n className={classNames?.yAxis?.title}\r\n text={barAxisTitle}\r\n rotate90\r\n />\r\n {customLayers.filter(d => d.position === 'before').map(d => d.layer)}\r\n <AnimatePresence>\r\n {dataWithId.map((d, _i) =>\r\n !checkIfNullOrUndefined(x(d.id)) ? (\r\n <motion.g\r\n className='undp-viz-g-with-hover'\r\n key={d.label}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n variants={{\r\n initial: {\r\n opacity: selectedColor\r\n ? d.color\r\n ? barColor[colorDomain.indexOf(d.color)] === selectedColor\r\n ? 1\r\n : dimmedOpacity\r\n : dimmedOpacity\r\n : highlightedDataPoints.length !== 0\r\n ? highlightedDataPoints.indexOf(d.label) !== -1\r\n ? 0.85\r\n : dimmedOpacity\r\n : 0.85,\r\n },\r\n whileInView: {\r\n opacity: selectedColor\r\n ? d.color\r\n ? barColor[colorDomain.indexOf(d.color)] === selectedColor\r\n ? 1\r\n : dimmedOpacity\r\n : dimmedOpacity\r\n : highlightedDataPoints.length !== 0\r\n ? highlightedDataPoints.indexOf(d.label) !== -1\r\n ? 0.85\r\n : dimmedOpacity\r\n : 0.85,\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n onMouseEnter={event => {\r\n setMouseOverData(d);\r\n setEventY(event.clientY);\r\n setEventX(event.clientX);\r\n onSeriesMouseOver?.(d);\r\n }}\r\n onClick={() => {\r\n if (onSeriesMouseClick || detailsOnClick) {\r\n if (isEqual(mouseClickData, d) && resetSelectionOnDoubleClick) {\r\n setMouseClickData(undefined);\r\n onSeriesMouseClick?.(undefined);\r\n } else {\r\n setMouseClickData(d);\r\n onSeriesMouseClick?.(d);\r\n }\r\n }\r\n }}\r\n onMouseMove={event => {\r\n setMouseOverData(d);\r\n setEventY(event.clientY);\r\n setEventX(event.clientX);\r\n }}\r\n onMouseLeave={() => {\r\n setMouseOverData(undefined);\r\n setEventX(undefined);\r\n setEventY(undefined);\r\n onSeriesMouseOver?.(undefined);\r\n }}\r\n >\r\n {d.size ? (\r\n <motion.rect\r\n width={x.bandwidth()}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n variants={{\r\n initial: {\r\n height: 0,\r\n x: x(`${d.id}`),\r\n y: y(0),\r\n fill:\r\n data.filter(el => el.color).length === 0\r\n ? barColor[0]\r\n : !d.color\r\n ? Colors.gray\r\n : barColor[colorDomain.indexOf(d.color)],\r\n },\r\n whileInView: {\r\n height: d.size ? Math.abs(y(d.size) - y(0)) : 0,\r\n y: d.size ? (d.size > 0 ? y(d.size) : y(0)) : y(0),\r\n x: x(`${d.id}`),\r\n fill:\r\n data.filter(el => el.color).length === 0\r\n ? barColor[0]\r\n : !d.color\r\n ? Colors.gray\r\n : barColor[colorDomain.indexOf(d.color)],\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n exit={{\r\n height: 0,\r\n y: y(0),\r\n transition: { duration: animate.duration },\r\n }}\r\n />\r\n ) : null}\r\n {showLabels ? (\r\n <XAxesLabels\r\n value={\r\n `${d.label}`.length < truncateBy\r\n ? `${d.label}`\r\n : `${`${d.label}`.substring(0, truncateBy)}...`\r\n }\r\n y={(d.size || 0) < 0 ? 0 : y(0) + 5}\r\n x={x(`${d.id}`) as number}\r\n width={x.bandwidth()}\r\n height={(d.size || 0) < 0 ? y(0) - 5 : margin.bottom}\r\n style={styles?.xAxis?.labels}\r\n className={classNames?.xAxis?.labels}\r\n alignment={(d.size || 0) < 0 ? 'bottom' : 'top'}\r\n animate={animate}\r\n isInView={isInView}\r\n />\r\n ) : null}\r\n {showValues ? (\r\n <motion.text\r\n style={{\r\n textAnchor: 'middle',\r\n ...(styles?.graphObjectValues || {}),\r\n }}\r\n className={cn(\r\n 'graph-value text-sm',\r\n !valueColor && barColor.length > 1\r\n ? ' fill-primary-gray-600 dark:fill-primary-gray-300'\r\n : '',\r\n classNames?.graphObjectValues,\r\n )}\r\n dy={d.size ? (d.size >= 0 ? '-5px' : '1em') : '-5px'}\r\n variants={{\r\n initial: {\r\n x: (x(`${d.id}`) as number) + x.bandwidth() / 2,\r\n y: y(0),\r\n opacity: 0,\r\n fill: valueColor\r\n ? valueColor\r\n : data.filter(el => el.color).length === 0\r\n ? barColor[0]\r\n : !d.color\r\n ? Colors.gray\r\n : barColor[colorDomain.indexOf(d.color)],\r\n },\r\n whileInView: {\r\n x: (x(`${d.id}`) as number) + x.bandwidth() / 2,\r\n y: y(d.size || 0),\r\n fill: valueColor\r\n ? valueColor\r\n : data.filter(el => el.color).length === 0\r\n ? barColor[0]\r\n : !d.color\r\n ? Colors.gray\r\n : barColor[colorDomain.indexOf(d.color)],\r\n opacity: 1,\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n exit={{\r\n opacity: 0,\r\n transition: { duration: animate.duration },\r\n }}\r\n >\r\n {numberFormattingFunction(d.size, naLabel, precision, prefix, suffix)}\r\n </motion.text>\r\n ) : null}\r\n </motion.g>\r\n ) : null,\r\n )}\r\n {refValues ? (\r\n <>\r\n {refValues.map((el, i) => (\r\n <RefLineY\r\n key={i}\r\n text={el.text}\r\n color={el.color}\r\n y={y(el.value as number)}\r\n x1={0 - leftMargin}\r\n x2={graphWidth + margin.right}\r\n classNames={el.classNames}\r\n styles={el.styles}\r\n animate={animate}\r\n isInView={isInView}\r\n />\r\n ))}\r\n </>\r\n ) : null}\r\n </AnimatePresence>\r\n {customLayers.filter(d => d.position === 'after').map(d => d.layer)}\r\n </g>\r\n </motion.svg>\r\n {mouseOverData && tooltip && eventX && eventY ? (\r\n <Tooltip\r\n data={mouseOverData}\r\n body={tooltip}\r\n xPos={eventX}\r\n yPos={eventY}\r\n backgroundStyle={styles?.tooltip}\r\n className={classNames?.tooltip}\r\n />\r\n ) : null}\r\n {detailsOnClick && mouseClickData !== undefined ? (\r\n <Modal\r\n open={mouseClickData !== undefined}\r\n onClose={() => {\r\n setMouseClickData(undefined);\r\n }}\r\n >\r\n <div\r\n className='graph-modal-content m-0'\r\n dangerouslySetInnerHTML={\r\n typeof detailsOnClick === 'string'\r\n ? { __html: string2HTML(detailsOnClick, mouseClickData) }\r\n : undefined\r\n }\r\n >\r\n {typeof detailsOnClick === 'function' ? detailsOnClick(mouseClickData) : null}\r\n </div>\r\n </Modal>\r\n ) : null}\r\n </>\r\n );\r\n}\r\n","import uniqBy from 'lodash.uniqby';\r\nimport { useEffect, useRef, useState } from 'react';\r\nimport sortBy from 'lodash.sortby';\r\nimport { format } from 'date-fns/format';\r\nimport { parse } from 'date-fns/parse';\r\nimport { cn } from '@undp/design-system-react/cn';\r\nimport { SliderUI } from '@undp/design-system-react/SliderUI';\r\nimport { ascending, sort } from 'd3-array';\r\n\r\nimport { Graph } from './Graph';\r\n\r\nimport {\r\n ReferenceDataType,\r\n BarGraphDataType,\r\n SourcesDataType,\r\n Languages,\r\n StyleObject,\r\n ClassNameObject,\r\n CustomLayerDataType,\r\n AnimateDataType,\r\n TimelineDataType,\r\n} from '@/Types';\r\nimport { GraphHeader } from '@/Components/Elements/GraphHeader';\r\nimport { GraphFooter } from '@/Components/Elements/GraphFooter';\r\nimport { ColorLegendWithMouseOver } from '@/Components/Elements/ColorLegendWithMouseOver';\r\nimport { Colors } from '@/Components/ColorPalette';\r\nimport { EmptyState } from '@/Components/Elements/EmptyState';\r\nimport { checkIfNullOrUndefined } from '@/Utils/checkIfNullOrUndefined';\r\nimport { Pause, Play } from '@/Components/Icons';\r\nimport { getSliderMarks } from '@/Utils/getSliderMarks';\r\nimport { ensureCompleteDataForBarChart } from '@/Utils/ensureCompleteData';\r\n\r\ninterface Props {\r\n data: BarGraphDataType[];\r\n colors?: string | string[];\r\n graphTitle?: string | React.ReactNode;\r\n labelOrder?: string[];\r\n width?: number;\r\n height?: number;\r\n suffix?: string;\r\n prefix?: string;\r\n sources?: SourcesDataType[];\r\n graphDescription?: string | React.ReactNode;\r\n footNote?: string | React.ReactNode;\r\n barPadding?: number;\r\n showLabels?: boolean;\r\n showValues?: boolean;\r\n showTicks?: boolean;\r\n colorDomain?: string[];\r\n colorLegendTitle?: string;\r\n truncateBy?: number;\r\n backgroundColor?: string | boolean;\r\n padding?: string;\r\n leftMargin?: number;\r\n rightMargin?: number;\r\n topMargin?: number;\r\n relativeHeight?: number;\r\n bottomMargin?: number;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n tooltip?: string | ((_d: any) => React.ReactNode);\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseOver?: (_d: any) => void;\r\n refValues?: ReferenceDataType[];\r\n showColorScale?: boolean;\r\n graphID?: string;\r\n maxValue?: number;\r\n minValue?: number;\r\n highlightedDataPoints?: (string | number)[];\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseClick?: (_d: any) => void;\r\n graphDownload?: boolean;\r\n dataDownload?: boolean;\r\n sortData?: 'asc' | 'desc';\r\n language?: Languages;\r\n showNAColor?: boolean;\r\n minHeight?: number;\r\n theme?: 'light' | 'dark';\r\n maxBarThickness?: number;\r\n maxNumberOfBars?: number;\r\n minBarThickness?: number;\r\n ariaLabel?: string;\r\n resetSelectionOnDoubleClick?: boolean;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n detailsOnClick?: string | ((_d: any) => React.ReactNode);\r\n barAxisTitle?: string;\r\n noOfTicks?: number;\r\n valueColor?: string;\r\n styles?: StyleObject;\r\n classNames?: ClassNameObject;\r\n filterNA?: boolean;\r\n animate?: boolean | AnimateDataType;\r\n dimmedOpacity?: number;\r\n precision?: number;\r\n customLayers?: CustomLayerDataType[];\r\n timeline?: TimelineDataType;\r\n naLabel?: string;\r\n}\r\n\r\nexport function VerticalBarGraph(props: Props) {\r\n const {\r\n data,\r\n graphTitle,\r\n colors,\r\n barPadding = 0.25,\r\n showTicks = true,\r\n leftMargin = 20,\r\n rightMargin = 20,\r\n topMargin = 20,\r\n bottomMargin = 25,\r\n truncateBy = 999,\r\n showLabels = true,\r\n showValues = true,\r\n backgroundColor = false,\r\n suffix = '',\r\n prefix = '',\r\n sources,\r\n graphDescription,\r\n height,\r\n width,\r\n footNote,\r\n colorDomain,\r\n colorLegendTitle,\r\n padding,\r\n relativeHeight,\r\n tooltip,\r\n onSeriesMouseOver,\r\n refValues,\r\n showColorScale = true,\r\n graphID,\r\n maxValue,\r\n minValue,\r\n highlightedDataPoints = [],\r\n onSeriesMouseClick,\r\n graphDownload = false,\r\n dataDownload = false,\r\n language = 'en',\r\n theme = 'light',\r\n sortData,\r\n labelOrder,\r\n showNAColor = true,\r\n minHeight = 0,\r\n maxBarThickness,\r\n maxNumberOfBars,\r\n minBarThickness,\r\n ariaLabel,\r\n resetSelectionOnDoubleClick = true,\r\n detailsOnClick,\r\n barAxisTitle,\r\n noOfTicks = 5,\r\n valueColor,\r\n styles,\r\n classNames,\r\n filterNA = true,\r\n animate = false,\r\n dimmedOpacity = 0.3,\r\n precision = 2,\r\n customLayers = [],\r\n timeline = { enabled: false, autoplay: false, showOnlyActiveDate: true },\r\n naLabel = 'NA',\r\n } = props;\r\n\r\n const [svgWidth, setSvgWidth] = useState(0);\r\n const [svgHeight, setSvgHeight] = useState(0);\r\n const [play, setPlay] = useState(timeline.autoplay);\r\n const uniqDatesSorted = sort(\r\n uniqBy(\r\n data.filter(d => d.date !== undefined && d.date !== null),\r\n d => d.date,\r\n ).map(d => parse(`${d.date}`, timeline.dateFormat || 'yyyy', new Date()).getTime()),\r\n (a, b) => ascending(a, b),\r\n );\r\n const [index, setIndex] = useState(timeline.autoplay ? 0 : uniqDatesSorted.length - 1);\r\n const [selectedColor, setSelectedColor] = useState<string | undefined>(undefined);\r\n const graphDiv = useRef<HTMLDivElement>(null);\r\n const graphParentDiv = useRef<HTMLDivElement>(null);\r\n\r\n useEffect(() => {\r\n const resizeObserver = new ResizeObserver(entries => {\r\n setSvgWidth(width || entries[0].target.clientWidth || 620);\r\n setSvgHeight(height || entries[0].target.clientHeight || 480);\r\n });\r\n if (graphDiv.current) {\r\n setSvgHeight(graphDiv.current.clientHeight || 480);\r\n setSvgWidth(graphDiv.current.clientWidth || 620);\r\n if (!width) resizeObserver.observe(graphDiv.current);\r\n }\r\n return () => resizeObserver.disconnect();\r\n }, [width, height]);\r\n\r\n useEffect(() => {\r\n const interval = setInterval(\r\n () => {\r\n setIndex(i => (i < uniqDatesSorted.length - 1 ? i + 1 : 0));\r\n },\r\n (timeline.speed || 2) * 1000,\r\n );\r\n if (!play) clearInterval(interval);\r\n return () => clearInterval(interval);\r\n }, [uniqDatesSorted, play, timeline.speed]);\r\n\r\n const markObj = getSliderMarks(\r\n uniqDatesSorted,\r\n index,\r\n timeline.showOnlyActiveDate,\r\n timeline.dateFormat || 'yyyy',\r\n );\r\n\r\n return (\r\n <div\r\n className={`${theme || 'light'} flex ${width ? 'w-fit grow-0' : 'w-full grow'}`}\r\n dir={language === 'he' || language === 'ar' ? 'rtl' : undefined}\r\n >\r\n <div\r\n className={cn(\r\n `${\r\n !backgroundColor\r\n ? 'bg-transparent '\r\n : backgroundColor === true\r\n ? 'bg-primary-gray-200 dark:bg-primary-gray-650 '\r\n : ''\r\n }ml-auto mr-auto flex flex-col grow h-inherit ${language || 'en'}`,\r\n width ? 'w-fit' : 'w-full',\r\n classNames?.graphContainer,\r\n )}\r\n style={{\r\n ...(styles?.graphContainer || {}),\r\n ...(backgroundColor && backgroundColor !== true ? { backgroundColor } : {}),\r\n }}\r\n id={graphID}\r\n ref={graphParentDiv}\r\n aria-label={\r\n ariaLabel ||\r\n `${graphTitle ? `The graph shows ${graphTitle}. ` : ''}This is a grouped bar chart. ${\r\n graphDescription ? ` ${graphDescription}` : ''\r\n }`\r\n }\r\n >\r\n <div\r\n className='flex grow'\r\n style={{ padding: backgroundColor ? padding || '1rem' : padding || 0 }}\r\n >\r\n <div className='flex flex-col w-full gap-4 grow justify-between'>\r\n {graphTitle || graphDescription || graphDownload || dataDownload ? (\r\n <GraphHeader\r\n styles={{\r\n title: styles?.title,\r\n description: styles?.description,\r\n }}\r\n classNames={{\r\n title: classNames?.title,\r\n description: classNames?.description,\r\n }}\r\n graphTitle={graphTitle}\r\n graphDescription={graphDescription}\r\n width={width}\r\n graphDownload={graphDownload ? graphParentDiv.current : undefined}\r\n dataDownload={\r\n dataDownload\r\n ? data.map(d => d.data).filter(d => d !== undefined).length > 0\r\n ? data.map(d => d.data).filter(d => d !== undefined)\r\n : data.filter(d => d !== undefined)\r\n : null\r\n }\r\n />\r\n ) : null}\r\n {timeline.enabled && uniqDatesSorted.length > 0 && markObj ? (\r\n <div className='flex gap-6 items-center' dir='ltr'>\r\n <button\r\n type='button'\r\n onClick={() => {\r\n setPlay(!play);\r\n }}\r\n className='p-0 border-0 cursor-pointer bg-transparent'\r\n aria-label={play ? 'Click to pause animation' : 'Click to play animation'}\r\n >\r\n {play ? <Pause /> : <Play />}\r\n </button>\r\n <SliderUI\r\n min={uniqDatesSorted[0]}\r\n max={uniqDatesSorted[uniqDatesSorted.length - 1]}\r\n marks={markObj}\r\n step={null}\r\n defaultValue={uniqDatesSorted[uniqDatesSorted.length - 1]}\r\n value={uniqDatesSorted[index]}\r\n onChangeComplete={nextValue => {\r\n setIndex(uniqDatesSorted.indexOf(nextValue as number));\r\n }}\r\n onChange={nextValue => {\r\n setIndex(uniqDatesSorted.indexOf(nextValue as number));\r\n }}\r\n aria-label='Time slider. Use arrow keys to adjust selected time period.'\r\n />\r\n </div>\r\n ) : null}\r\n <div className='grow flex flex-col justify-center gap-3 w-full'>\r\n {data.length === 0 ? (\r\n <EmptyState />\r\n ) : (\r\n <>\r\n {showColorScale && data.filter(el => el.color).length !== 0 ? (\r\n <ColorLegendWithMouseOver\r\n width={width}\r\n colorLegendTitle={colorLegendTitle}\r\n colors={\r\n (colors as string[] | undefined) || Colors[theme].categoricalColors.colors\r\n }\r\n colorDomain={\r\n colorDomain ||\r\n (uniqBy(\r\n data.filter(el => el.color),\r\n 'color',\r\n ).map(d => d.color) as string[])\r\n }\r\n setSelectedColor={setSelectedColor}\r\n showNAColor={showNAColor}\r\n />\r\n ) : null}\r\n <div\r\n className='flex grow flex-col justify-center w-full leading-0'\r\n ref={graphDiv}\r\n aria-label='Graph area'\r\n >\r\n {(width || svgWidth) && (height || svgHeight) ? (\r\n <Graph\r\n data={\r\n sortData === 'asc'\r\n ? sortBy(\r\n ensureCompleteDataForBarChart(data, timeline.dateFormat || 'yyyy')\r\n .filter(d =>\r\n timeline.enabled\r\n ? d.date ===\r\n format(\r\n new Date(uniqDatesSorted[index]),\r\n timeline.dateFormat || 'yyyy',\r\n )\r\n : d,\r\n )\r\n .filter(d => (filterNA ? !checkIfNullOrUndefined(d.size) : d)),\r\n d => d.size,\r\n ).filter((_d, i) => (maxNumberOfBars ? i < maxNumberOfBars : true))\r\n : sortData === 'desc'\r\n ? sortBy(\r\n ensureCompleteDataForBarChart(data, timeline.dateFormat || 'yyyy')\r\n .filter(d =>\r\n timeline.enabled\r\n ? d.date ===\r\n format(\r\n new Date(uniqDatesSorted[index]),\r\n timeline.dateFormat || 'yyyy',\r\n )\r\n : d,\r\n )\r\n .filter(d => (filterNA ? !checkIfNullOrUndefined(d.size) : d)),\r\n d => d.size,\r\n )\r\n .reverse()\r\n .filter((_d, i) => (maxNumberOfBars ? i < maxNumberOfBars : true))\r\n : ensureCompleteDataForBarChart(data, timeline.dateFormat || 'yyyy')\r\n .filter(d =>\r\n timeline.enabled\r\n ? d.date ===\r\n format(\r\n new Date(uniqDatesSorted[index]),\r\n timeline.dateFormat || 'yyyy',\r\n )\r\n : d,\r\n )\r\n .filter(d => (filterNA ? !checkIfNullOrUndefined(d.size) : d))\r\n .filter((_d, i) => (maxNumberOfBars ? i < maxNumberOfBars : true))\r\n }\r\n barColor={\r\n data.filter(el => el.color).length === 0\r\n ? colors\r\n ? [colors as string]\r\n : [Colors.primaryColors['blue-600']]\r\n : (colors as string[] | undefined) ||\r\n Colors[theme].categoricalColors.colors\r\n }\r\n colorDomain={\r\n data.filter(el => el.color).length === 0\r\n ? []\r\n : colorDomain ||\r\n (uniqBy(\r\n data.filter(el => el.color),\r\n 'color',\r\n ).map(d => d.color) as string[])\r\n }\r\n width={width || svgWidth}\r\n refValues={refValues}\r\n height={Math.max(\r\n minHeight,\r\n height ||\r\n (relativeHeight\r\n ? minHeight\r\n ? (width || svgWidth) * relativeHeight > minHeight\r\n ? (width || svgWidth) * relativeHeight\r\n : minHeight\r\n : (width || svgWidth) * relativeHeight\r\n : svgHeight),\r\n )}\r\n suffix={suffix}\r\n prefix={prefix}\r\n barPadding={barPadding}\r\n showLabels={showLabels}\r\n showValues={showValues}\r\n showTicks={showTicks}\r\n truncateBy={truncateBy}\r\n leftMargin={leftMargin}\r\n rightMargin={rightMargin}\r\n selectedColor={selectedColor}\r\n topMargin={topMargin}\r\n bottomMargin={bottomMargin}\r\n tooltip={tooltip}\r\n onSeriesMouseOver={onSeriesMouseOver}\r\n maxValue={\r\n !checkIfNullOrUndefined(maxValue)\r\n ? (maxValue as number)\r\n : Math.max(\r\n ...data\r\n .filter(d => !checkIfNullOrUndefined(d.size))\r\n .map(d => d.size as number),\r\n ) < 0\r\n ? 0\r\n : Math.max(\r\n ...data\r\n .filter(d => !checkIfNullOrUndefined(d.size))\r\n .map(d => d.size as number),\r\n )\r\n }\r\n minValue={\r\n !checkIfNullOrUndefined(minValue)\r\n ? (minValue as number)\r\n : Math.min(\r\n ...data\r\n .filter(d => !checkIfNullOrUndefined(d.size))\r\n .map(d => d.size as number),\r\n ) >= 0\r\n ? 0\r\n : Math.min(\r\n ...data\r\n .filter(d => !checkIfNullOrUndefined(d.size))\r\n .map(d => d.size as number),\r\n )\r\n }\r\n highlightedDataPoints={highlightedDataPoints}\r\n onSeriesMouseClick={onSeriesMouseClick}\r\n labelOrder={labelOrder}\r\n maxBarThickness={maxBarThickness}\r\n minBarThickness={minBarThickness}\r\n resetSelectionOnDoubleClick={resetSelectionOnDoubleClick}\r\n detailsOnClick={detailsOnClick}\r\n barAxisTitle={barAxisTitle}\r\n noOfTicks={noOfTicks}\r\n valueColor={valueColor}\r\n styles={styles}\r\n classNames={classNames}\r\n animate={\r\n animate === true\r\n ? { duration: 0.5, once: true, amount: 0.5 }\r\n : animate || { duration: 0, once: true, amount: 0 }\r\n }\r\n dimmedOpacity={dimmedOpacity}\r\n precision={precision}\r\n customLayers={customLayers}\r\n naLabel={naLabel}\r\n />\r\n ) : null}\r\n </div>\r\n </>\r\n )}\r\n </div>\r\n {sources || footNote ? (\r\n <GraphFooter\r\n styles={{ footnote: styles?.footnote, source: styles?.source }}\r\n classNames={{\r\n footnote: classNames?.footnote,\r\n source: classNames?.source,\r\n }}\r\n sources={sources}\r\n footNote={footNote}\r\n width={width}\r\n />\r\n ) : null}\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n );\r\n}\r\n","import isEqual from 'fast-deep-equal';\r\nimport { scaleLinear, scaleBand } from 'd3-scale';\r\nimport { useRef, useState } from 'react';\r\nimport { cn } from '@undp/design-system-react/cn';\r\nimport { Modal } from '@undp/design-system-react/Modal';\r\nimport { AnimatePresence, motion, useInView } from 'motion/react';\r\n\r\nimport { numberFormattingFunction } from '@/Utils/numberFormattingFunction';\r\nimport {\r\n ReferenceDataType,\r\n GroupedBarGraphDataType,\r\n StyleObject,\r\n ClassNameObject,\r\n CustomLayerDataType,\r\n AnimateDataType,\r\n} from '@/Types';\r\nimport { Tooltip } from '@/Components/Elements/Tooltip';\r\nimport { checkIfNullOrUndefined } from '@/Utils/checkIfNullOrUndefined';\r\nimport { string2HTML } from '@/Utils/string2HTML';\r\nimport { AxisTitle } from '@/Components/Elements/Axes/AxisTitle';\r\nimport { Axis } from '@/Components/Elements/Axes/Axis';\r\nimport { XAxesLabels } from '@/Components/Elements/Axes/XAxesLabels';\r\nimport { RefLineY } from '@/Components/Elements/ReferenceLine';\r\nimport { YTicksAndGridLines } from '@/Components/Elements/Axes/YTicksAndGridLines';\r\n\r\ninterface Props {\r\n data: GroupedBarGraphDataType[];\r\n width: number;\r\n height: number;\r\n barColors: string[];\r\n suffix: string;\r\n prefix: string;\r\n barPadding: number;\r\n showLabels: boolean;\r\n showValues: boolean;\r\n showTicks: boolean;\r\n truncateBy: number;\r\n leftMargin: number;\r\n rightMargin: number;\r\n topMargin: number;\r\n bottomMargin: number;\r\n refValues?: ReferenceDataType[];\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n tooltip?: string | ((_d: any) => React.ReactNode);\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseOver?: (_d: any) => void;\r\n maxValue: number;\r\n minValue: number;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseClick?: (_d: any) => void;\r\n selectedColor?: string;\r\n labelOrder?: string[];\r\n maxBarThickness?: number;\r\n resetSelectionOnDoubleClick: boolean;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n detailsOnClick?: string | ((_d: any) => React.ReactNode);\r\n barAxisTitle?: string;\r\n noOfTicks: number;\r\n valueColor?: string;\r\n styles?: StyleObject;\r\n classNames?: ClassNameObject;\r\n animate: AnimateDataType;\r\n colorDomain: string[];\r\n precision: number;\r\n customLayers: CustomLayerDataType[];\r\n naLabel: string;\r\n}\r\n\r\nexport function Graph(props: Props) {\r\n const {\r\n data,\r\n width,\r\n height,\r\n barColors,\r\n suffix,\r\n prefix,\r\n barPadding,\r\n showLabels,\r\n showValues,\r\n showTicks,\r\n truncateBy,\r\n leftMargin,\r\n rightMargin,\r\n topMargin,\r\n bottomMargin,\r\n tooltip,\r\n onSeriesMouseOver,\r\n refValues,\r\n maxValue,\r\n minValue,\r\n onSeriesMouseClick,\r\n selectedColor,\r\n labelOrder,\r\n maxBarThickness,\r\n resetSelectionOnDoubleClick,\r\n detailsOnClick,\r\n barAxisTitle,\r\n valueColor,\r\n noOfTicks,\r\n styles,\r\n classNames,\r\n animate,\r\n colorDomain,\r\n precision,\r\n customLayers,\r\n naLabel,\r\n } = props;\r\n const svgRef = useRef(null);\r\n const isInView = useInView(svgRef, {\r\n once: animate.once,\r\n amount: animate.amount,\r\n });\r\n const margin = {\r\n top: topMargin,\r\n bottom: bottomMargin,\r\n left: barAxisTitle ? leftMargin + 30 : leftMargin,\r\n right: rightMargin,\r\n };\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const [mouseOverData, setMouseOverData] = useState<any>(undefined);\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const [mouseClickData, setMouseClickData] = useState<any>(undefined);\r\n const [eventX, setEventX] = useState<number | undefined>(undefined);\r\n const [eventY, setEventY] = useState<number | undefined>(undefined);\r\n const graphWidth = width - margin.left - margin.right;\r\n const graphHeight = height - margin.top - margin.bottom;\r\n\r\n const y = scaleLinear().domain([minValue, maxValue]).range([graphHeight, 0]).nice();\r\n\r\n const dataWithId = data.map((d, i) => ({\r\n ...d,\r\n id: labelOrder ? `${d.label}` : `${i}`,\r\n }));\r\n const barOrder = labelOrder || dataWithId.map(d => `${d.id}`);\r\n const x = scaleBand()\r\n .domain(barOrder)\r\n .range([\r\n 0,\r\n maxBarThickness ? Math.min(graphWidth, maxBarThickness * barOrder.length) : graphWidth,\r\n ])\r\n .paddingInner(barPadding);\r\n const subBarScale = scaleBand()\r\n .domain(data[0].size.map((_d, i) => `${i}`))\r\n .range([0, x.bandwidth()])\r\n .paddingInner(0.1);\r\n const yTicks = y.ticks(noOfTicks);\r\n return (\r\n <>\r\n <motion.svg\r\n width={`${width}px`}\r\n height={`${height}px`}\r\n viewBox={`0 0 ${width} ${height}`}\r\n direction='ltr'\r\n ref={svgRef}\r\n >\r\n <g transform={`translate(${margin.left},${margin.top})`}>\r\n <Axis\r\n y1={y(minValue < 0 ? 0 : minValue)}\r\n y2={y(minValue < 0 ? 0 : minValue)}\r\n x1={0 - leftMargin}\r\n x2={graphWidth + margin.right}\r\n label={numberFormattingFunction(\r\n minValue < 0 ? 0 : minValue,\r\n naLabel,\r\n precision,\r\n prefix,\r\n suffix,\r\n )}\r\n labelPos={{\r\n x: 0 - leftMargin,\r\n dx: 0,\r\n dy: maxValue < 0 ? '1em' : -5,\r\n y: y(minValue < 0 ? 0 : minValue),\r\n }}\r\n classNames={{\r\n axis: classNames?.xAxis?.axis,\r\n label: classNames?.yAxis?.labels,\r\n }}\r\n styles={{ axis: styles?.xAxis?.axis, label: styles?.yAxis?.labels }}\r\n />\r\n {showTicks ? (\r\n <YTicksAndGridLines\r\n values={yTicks.filter(d => d !== 0)}\r\n y={yTicks.filter(d => d !== 0).map(d => y(d))}\r\n x1={0 - leftMargin}\r\n x2={graphWidth + margin.right}\r\n styles={{\r\n gridLines: styles?.yAxis?.gridLines,\r\n labels: styles?.yAxis?.labels,\r\n }}\r\n classNames={{\r\n gridLines: classNames?.yAxis?.gridLines,\r\n labels: classNames?.yAxis?.labels,\r\n }}\r\n suffix={suffix}\r\n prefix={prefix}\r\n labelType='secondary'\r\n showGridLines\r\n labelPos='vertical'\r\n precision={precision}\r\n />\r\n ) : null}\r\n <AxisTitle\r\n x={0 - leftMargin - 15}\r\n y={graphHeight / 2}\r\n style={styles?.yAxis?.title}\r\n className={classNames?.yAxis?.title}\r\n text={barAxisTitle}\r\n rotate90\r\n />\r\n {customLayers.filter(d => d.position === 'before').map(d => d.layer)}\r\n <AnimatePresence>\r\n {dataWithId.map(d =>\r\n !checkIfNullOrUndefined(x(d.id)) ? (\r\n <motion.g\r\n key={d.label}\r\n variants={{\r\n initial: {\r\n x: x(`${d.id}`),\r\n y: 0,\r\n },\r\n whileInView: {\r\n x: x(`${d.id}`),\r\n y: 0,\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n >\r\n {d.size.map((el, j) => (\r\n <motion.g\r\n className='undp-viz-g-with-hover'\r\n key={`${d.label}-${colorDomain[j] || j}`}\r\n opacity={selectedColor ? (barColors[j] === selectedColor ? 1 : 0.3) : 0.85}\r\n onMouseEnter={event => {\r\n setMouseOverData({ ...d, sizeIndex: j });\r\n setEventY(event.clientY);\r\n setEventX(event.clientX);\r\n onSeriesMouseOver?.({ ...d, sizeIndex: j });\r\n }}\r\n onMouseMove={event => {\r\n setMouseOverData({ ...d, sizeIndex: j });\r\n setEventY(event.clientY);\r\n setEventX(event.clientX);\r\n }}\r\n onMouseLeave={() => {\r\n setMouseOverData(undefined);\r\n setEventX(undefined);\r\n setEventY(undefined);\r\n onSeriesMouseOver?.(undefined);\r\n }}\r\n onClick={() => {\r\n if (onSeriesMouseClick || detailsOnClick) {\r\n if (\r\n isEqual(mouseClickData, { ...d, sizeIndex: j }) &&\r\n resetSelectionOnDoubleClick\r\n ) {\r\n setMouseClickData(undefined);\r\n onSeriesMouseClick?.(undefined);\r\n } else {\r\n setMouseClickData({ ...d, sizeIndex: j });\r\n if (onSeriesMouseClick) onSeriesMouseClick({ ...d, sizeIndex: j });\r\n }\r\n }\r\n }}\r\n >\r\n <motion.rect\r\n x={subBarScale(`${j}`)}\r\n width={subBarScale.bandwidth()}\r\n variants={{\r\n initial: {\r\n height: 0,\r\n y: y(0),\r\n fill: barColors[j],\r\n },\r\n whileInView: {\r\n height: !checkIfNullOrUndefined(el)\r\n ? Math.abs(y(el as number) - y(0))\r\n : 0,\r\n y: !checkIfNullOrUndefined(el)\r\n ? (el as number) > 0\r\n ? y(el as number)\r\n : y(0)\r\n : y(0),\r\n fill: barColors[j],\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n exit={{\r\n height: 0,\r\n y: y(0),\r\n transition: { duration: animate.duration },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n />\r\n {showValues ? (\r\n <motion.text\r\n x={(subBarScale(`${j}`) as number) + subBarScale.bandwidth() / 2}\r\n style={{\r\n fill: valueColor || barColors[j],\r\n textAnchor: 'middle',\r\n ...(styles?.graphObjectValues || {}),\r\n }}\r\n className={cn('graph-value text-sm', classNames?.graphObjectValues)}\r\n dy={el ? (el >= 0 ? '-5px' : '1em') : '-5px'}\r\n variants={{\r\n initial: { y: y(0), opacity: 0 },\r\n whileInView: {\r\n y: y(el || 0),\r\n opacity: 1,\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n exit={{\r\n opacity: 0,\r\n transition: { duration: animate.duration },\r\n }}\r\n >\r\n {numberFormattingFunction(el, naLabel, precision, prefix, suffix)}\r\n </motion.text>\r\n ) : null}\r\n </motion.g>\r\n ))}\r\n {showLabels ? (\r\n <XAxesLabels\r\n value={\r\n `${d.label}`.length < truncateBy\r\n ? `${d.label}`\r\n : `${`${d.label}`.substring(0, truncateBy)}...`\r\n }\r\n y={y(0) + 5}\r\n x={0}\r\n width={x.bandwidth()}\r\n height={margin.bottom}\r\n style={styles?.xAxis?.labels}\r\n className={classNames?.xAxis?.labels}\r\n alignment='top'\r\n animate={animate}\r\n isInView={isInView}\r\n />\r\n ) : null}\r\n </motion.g>\r\n ) : null,\r\n )}\r\n {refValues ? (\r\n <>\r\n {refValues.map((el, i) => (\r\n <RefLineY\r\n key={i}\r\n text={el.text}\r\n color={el.color}\r\n y={y(el.value as number)}\r\n x1={0 - leftMargin}\r\n x2={graphWidth + margin.right}\r\n classNames={el.classNames}\r\n styles={el.styles}\r\n animate={animate}\r\n isInView={isInView}\r\n />\r\n ))}\r\n </>\r\n ) : null}\r\n </AnimatePresence>\r\n {customLayers.filter(d => d.position === 'after').map(d => d.layer)}\r\n </g>\r\n </motion.svg>\r\n {mouseOverData && tooltip && eventX && eventY ? (\r\n <Tooltip\r\n data={mouseOverData}\r\n body={tooltip}\r\n xPos={eventX}\r\n yPos={eventY}\r\n backgroundStyle={styles?.tooltip}\r\n className={classNames?.tooltip}\r\n />\r\n ) : null}\r\n {detailsOnClick && mouseClickData !== undefined ? (\r\n <Modal\r\n open={mouseClickData !== undefined}\r\n onClose={() => {\r\n setMouseClickData(undefined);\r\n }}\r\n >\r\n <div\r\n className='graph-modal-content m-0'\r\n dangerouslySetInnerHTML={\r\n typeof detailsOnClick === 'string'\r\n ? { __html: string2HTML(detailsOnClick, mouseClickData) }\r\n : undefined\r\n }\r\n >\r\n {typeof detailsOnClick === 'function' ? detailsOnClick(mouseClickData) : null}\r\n </div>\r\n </Modal>\r\n ) : null}\r\n </>\r\n );\r\n}\r\n","import { useState, useRef, useEffect } from 'react';\r\nimport { cn } from '@undp/design-system-react/cn';\r\nimport { SliderUI } from '@undp/design-system-react/SliderUI';\r\nimport { format } from 'date-fns/format';\r\nimport { parse } from 'date-fns/parse';\r\nimport { ascending, sort } from 'd3-array';\r\nimport uniqBy from 'lodash.uniqby';\r\nimport orderBy from 'lodash.orderby';\r\nimport sum from 'lodash.sum';\r\n\r\nimport { Graph } from './Graph';\r\n\r\nimport {\r\n ReferenceDataType,\r\n GroupedBarGraphDataType,\r\n SourcesDataType,\r\n Languages,\r\n StyleObject,\r\n ClassNameObject,\r\n CustomLayerDataType,\r\n AnimateDataType,\r\n TimelineDataType,\r\n} from '@/Types';\r\nimport { GraphHeader } from '@/Components/Elements/GraphHeader';\r\nimport { GraphFooter } from '@/Components/Elements/GraphFooter';\r\nimport { ColorLegendWithMouseOver } from '@/Components/Elements/ColorLegendWithMouseOver';\r\nimport { Colors } from '@/Components/ColorPalette';\r\nimport { EmptyState } from '@/Components/Elements/EmptyState';\r\nimport { checkIfNullOrUndefined } from '@/Utils/checkIfNullOrUndefined';\r\nimport { Pause, Play } from '@/Components/Icons';\r\nimport { getSliderMarks } from '@/Utils/getSliderMarks';\r\nimport { ensureCompleteDataForStackedBarChart } from '@/Utils/ensureCompleteData';\r\n\r\ninterface Props {\r\n data: GroupedBarGraphDataType[];\r\n colors?: string[];\r\n graphTitle?: string | React.ReactNode;\r\n width?: number;\r\n height?: number;\r\n suffix?: string;\r\n prefix?: string;\r\n sources?: SourcesDataType[];\r\n graphDescription?: string | React.ReactNode;\r\n footNote?: string | React.ReactNode;\r\n barPadding?: number;\r\n showLabels?: boolean;\r\n showValues?: boolean;\r\n showTicks?: boolean;\r\n colorDomain: string[];\r\n colorLegendTitle?: string;\r\n showColorScale?: boolean;\r\n labelOrder?: string[];\r\n truncateBy?: number;\r\n sortParameter?: number | 'total';\r\n sortData?: 'asc' | 'desc';\r\n backgroundColor?: string | boolean;\r\n padding?: string;\r\n leftMargin?: number;\r\n rightMargin?: number;\r\n topMargin?: number;\r\n bottomMargin?: number;\r\n relativeHeight?: number;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n tooltip?: string | ((_d: any) => React.ReactNode);\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseOver?: (_d: any) => void;\r\n refValues?: ReferenceDataType[];\r\n graphID?: string;\r\n maxValue?: number;\r\n minValue?: number;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseClick?: (_d: any) => void;\r\n graphDownload?: boolean;\r\n dataDownload?: boolean;\r\n language?: Languages;\r\n minHeight?: number;\r\n theme?: 'light' | 'dark';\r\n maxBarThickness?: number;\r\n ariaLabel?: string;\r\n resetSelectionOnDoubleClick?: boolean;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n detailsOnClick?: string | ((_d: any) => React.ReactNode);\r\n barAxisTitle?: string;\r\n noOfTicks?: number;\r\n valueColor?: string;\r\n styles?: StyleObject;\r\n classNames?: ClassNameObject;\r\n filterNA?: boolean;\r\n animate?: boolean | AnimateDataType;\r\n precision?: number;\r\n customLayers?: CustomLayerDataType[];\r\n timeline?: TimelineDataType;\r\n naLabel?: string;\r\n}\r\n\r\nexport function VerticalGroupedBarGraph(props: Props) {\r\n const {\r\n data,\r\n graphTitle,\r\n colors = Colors.light.categoricalColors.colors,\r\n sources,\r\n graphDescription,\r\n barPadding = 0.25,\r\n showTicks = true,\r\n leftMargin = 20,\r\n rightMargin = 20,\r\n topMargin = 20,\r\n bottomMargin = 25,\r\n truncateBy = 999,\r\n showLabels = true,\r\n showValues = true,\r\n backgroundColor = false,\r\n suffix = '',\r\n prefix = '',\r\n height,\r\n width,\r\n footNote,\r\n colorDomain,\r\n colorLegendTitle,\r\n padding,\r\n relativeHeight,\r\n tooltip,\r\n onSeriesMouseOver,\r\n refValues,\r\n graphID,\r\n maxValue,\r\n minValue,\r\n onSeriesMouseClick,\r\n graphDownload = false,\r\n dataDownload = false,\r\n language = 'en',\r\n theme = 'light',\r\n labelOrder,\r\n minHeight = 0,\r\n maxBarThickness,\r\n ariaLabel,\r\n resetSelectionOnDoubleClick = true,\r\n detailsOnClick,\r\n barAxisTitle,\r\n noOfTicks = 5,\r\n valueColor,\r\n styles,\r\n classNames,\r\n filterNA = true,\r\n showColorScale = true,\r\n animate = false,\r\n precision = 2,\r\n customLayers = [],\r\n timeline = { enabled: false, autoplay: false, showOnlyActiveDate: true },\r\n naLabel = 'NA',\r\n sortParameter,\r\n sortData,\r\n } = props;\r\n\r\n const [svgWidth, setSvgWidth] = useState(0);\r\n const [svgHeight, setSvgHeight] = useState(0);\r\n const [play, setPlay] = useState(timeline.autoplay);\r\n const uniqDatesSorted = sort(\r\n uniqBy(\r\n data.filter(d => d.date !== undefined && d.date !== null),\r\n d => d.date,\r\n ).map(d => parse(`${d.date}`, timeline.dateFormat || 'yyyy', new Date()).getTime()),\r\n (a, b) => ascending(a, b),\r\n );\r\n const [index, setIndex] = useState(timeline.autoplay ? 0 : uniqDatesSorted.length - 1);\r\n const [selectedColor, setSelectedColor] = useState<string | undefined>(undefined);\r\n\r\n const graphDiv = useRef<HTMLDivElement>(null);\r\n const graphParentDiv = useRef<HTMLDivElement>(null);\r\n useEffect(() => {\r\n const resizeObserver = new ResizeObserver(entries => {\r\n setSvgWidth(width || entries[0].target.clientWidth || 620);\r\n setSvgHeight(height || entries[0].target.clientHeight || 480);\r\n });\r\n if (graphDiv.current) {\r\n setSvgHeight(graphDiv.current.clientHeight || 480);\r\n setSvgWidth(graphDiv.current.clientWidth || 620);\r\n if (!width) resizeObserver.observe(graphDiv.current);\r\n }\r\n return () => resizeObserver.disconnect();\r\n }, [width, height]);\r\n\r\n useEffect(() => {\r\n const interval = setInterval(\r\n () => {\r\n setIndex(i => (i < uniqDatesSorted.length - 1 ? i + 1 : 0));\r\n },\r\n (timeline.speed || 2) * 1000,\r\n );\r\n if (!play) clearInterval(interval);\r\n return () => clearInterval(interval);\r\n }, [uniqDatesSorted, play, timeline.speed]);\r\n\r\n const markObj = getSliderMarks(\r\n uniqDatesSorted,\r\n index,\r\n timeline.showOnlyActiveDate,\r\n timeline.dateFormat || 'yyyy',\r\n );\r\n\r\n return (\r\n <div\r\n className={`${theme || 'light'} flex ${width ? 'w-fit grow-0' : 'w-full grow'}`}\r\n dir={language === 'he' || language === 'ar' ? 'rtl' : undefined}\r\n >\r\n <div\r\n className={cn(\r\n `${\r\n !backgroundColor\r\n ? 'bg-transparent '\r\n : backgroundColor === true\r\n ? 'bg-primary-gray-200 dark:bg-primary-gray-650 '\r\n : ''\r\n }ml-auto mr-auto flex flex-col grow h-inherit ${language || 'en'}`,\r\n width ? 'w-fit' : 'w-full',\r\n classNames?.graphContainer,\r\n )}\r\n style={{\r\n ...(styles?.graphContainer || {}),\r\n ...(backgroundColor && backgroundColor !== true ? { backgroundColor } : {}),\r\n }}\r\n id={graphID}\r\n ref={graphParentDiv}\r\n aria-label={\r\n ariaLabel ||\r\n `${graphTitle ? `The graph shows ${graphTitle}. ` : ''}This is a grouped bar chart. ${\r\n graphDescription ? ` ${graphDescription}` : ''\r\n }`\r\n }\r\n >\r\n <div\r\n className='flex grow'\r\n style={{ padding: backgroundColor ? padding || '1rem' : padding || 0 }}\r\n >\r\n <div className='flex flex-col w-full gap-4 grow justify-between'>\r\n {graphTitle || graphDescription || graphDownload || dataDownload ? (\r\n <GraphHeader\r\n styles={{\r\n title: styles?.title,\r\n description: styles?.description,\r\n }}\r\n classNames={{\r\n title: classNames?.title,\r\n description: classNames?.description,\r\n }}\r\n graphTitle={graphTitle}\r\n graphDescription={graphDescription}\r\n width={width}\r\n graphDownload={graphDownload ? graphParentDiv.current : undefined}\r\n dataDownload={\r\n dataDownload\r\n ? data.map(d => d.data).filter(d => d !== undefined).length > 0\r\n ? data.map(d => d.data).filter(d => d !== undefined)\r\n : data.filter(d => d !== undefined)\r\n : null\r\n }\r\n />\r\n ) : null}\r\n {timeline.enabled && uniqDatesSorted.length > 0 && markObj ? (\r\n <div className='flex gap-6 items-center' dir='ltr'>\r\n <button\r\n type='button'\r\n onClick={() => {\r\n setPlay(!play);\r\n }}\r\n className='p-0 border-0 cursor-pointer bg-transparent'\r\n aria-label={play ? 'Click to pause animation' : 'Click to play animation'}\r\n >\r\n {play ? <Pause /> : <Play />}\r\n </button>\r\n <SliderUI\r\n min={uniqDatesSorted[0]}\r\n max={uniqDatesSorted[uniqDatesSorted.length - 1]}\r\n marks={markObj}\r\n step={null}\r\n defaultValue={uniqDatesSorted[uniqDatesSorted.length - 1]}\r\n value={uniqDatesSorted[index]}\r\n onChangeComplete={nextValue => {\r\n setIndex(uniqDatesSorted.indexOf(nextValue as number));\r\n }}\r\n onChange={nextValue => {\r\n setIndex(uniqDatesSorted.indexOf(nextValue as number));\r\n }}\r\n aria-label='Time slider. Use arrow keys to adjust selected time period.'\r\n />\r\n </div>\r\n ) : null}\r\n <div className='grow flex flex-col justify-center gap-3 w-full'>\r\n {data.length === 0 ? (\r\n <EmptyState />\r\n ) : (\r\n <>\r\n {showColorScale ? (\r\n <ColorLegendWithMouseOver\r\n width={width}\r\n colorDomain={colorDomain}\r\n colors={colors}\r\n colorLegendTitle={colorLegendTitle}\r\n setSelectedColor={setSelectedColor}\r\n showNAColor={false}\r\n />\r\n ) : null}\r\n <div className='w-full grow leading-0' ref={graphDiv} aria-label='Graph area'>\r\n {(width || svgWidth) && (height || svgHeight) ? (\r\n <Graph\r\n data={\r\n sortParameter !== undefined\r\n ? sortParameter === 'total'\r\n ? orderBy(\r\n ensureCompleteDataForStackedBarChart(\r\n data,\r\n timeline.dateFormat || 'yyyy',\r\n )\r\n .filter(d =>\r\n timeline.enabled\r\n ? d.date ===\r\n format(\r\n new Date(uniqDatesSorted[index]),\r\n timeline.dateFormat || 'yyyy',\r\n )\r\n : d,\r\n )\r\n .filter(d =>\r\n filterNA ? !d.size.every(item => item == null) : d,\r\n ),\r\n d => sum(d.size.filter(el => !checkIfNullOrUndefined(el))),\r\n [sortData || 'asc'],\r\n )\r\n : orderBy(\r\n ensureCompleteDataForStackedBarChart(\r\n data,\r\n timeline.dateFormat || 'yyyy',\r\n )\r\n .filter(d =>\r\n timeline.enabled\r\n ? d.date ===\r\n format(\r\n new Date(uniqDatesSorted[index]),\r\n timeline.dateFormat || 'yyyy',\r\n )\r\n : d,\r\n )\r\n .filter(d =>\r\n filterNA ? !d.size.every(item => item == null) : d,\r\n ),\r\n d =>\r\n checkIfNullOrUndefined(d.size[sortParameter])\r\n ? -Infinity\r\n : d.size[sortParameter],\r\n [sortData || 'asc'],\r\n )\r\n : ensureCompleteDataForStackedBarChart(\r\n data,\r\n timeline.dateFormat || 'yyyy',\r\n ).filter(d => (filterNA ? !d.size.every(item => item == null) : d))\r\n }\r\n barColors={colors}\r\n width={width || svgWidth}\r\n height={Math.max(\r\n minHeight,\r\n height ||\r\n (relativeHeight\r\n ? minHeight\r\n ? (width || svgWidth) * relativeHeight > minHeight\r\n ? (width || svgWidth) * relativeHeight\r\n : minHeight\r\n : (width || svgWidth) * relativeHeight\r\n : svgHeight),\r\n )}\r\n suffix={suffix}\r\n prefix={prefix}\r\n barPadding={barPadding}\r\n showLabels={showLabels}\r\n showValues={showValues}\r\n showTicks={showTicks}\r\n truncateBy={truncateBy}\r\n leftMargin={leftMargin}\r\n rightMargin={rightMargin}\r\n topMargin={topMargin}\r\n bottomMargin={bottomMargin}\r\n tooltip={tooltip}\r\n onSeriesMouseOver={onSeriesMouseOver}\r\n refValues={refValues}\r\n maxValue={\r\n !checkIfNullOrUndefined(maxValue)\r\n ? (maxValue as number)\r\n : Math.max(\r\n ...data.map(d =>\r\n Math.max(\r\n ...(d.size.filter(\r\n l => !checkIfNullOrUndefined(l),\r\n ) as number[]),\r\n ),\r\n ),\r\n ) < 0\r\n ? 0\r\n : Math.max(\r\n ...data.map(d =>\r\n Math.max(\r\n ...(d.size.filter(\r\n l => !checkIfNullOrUndefined(l),\r\n ) as number[]),\r\n ),\r\n ),\r\n )\r\n }\r\n minValue={\r\n !checkIfNullOrUndefined(minValue)\r\n ? (minValue as number)\r\n : Math.min(\r\n ...data.map(d =>\r\n Math.min(\r\n ...(d.size.filter(\r\n l => !checkIfNullOrUndefined(l),\r\n ) as number[]),\r\n ),\r\n ),\r\n ) >= 0\r\n ? 0\r\n : Math.min(\r\n ...data.map(d =>\r\n Math.min(\r\n ...(d.size.filter(\r\n l => !checkIfNullOrUndefined(l),\r\n ) as number[]),\r\n ),\r\n ),\r\n )\r\n }\r\n onSeriesMouseClick={onSeriesMouseClick}\r\n selectedColor={selectedColor}\r\n labelOrder={labelOrder}\r\n maxBarThickness={maxBarThickness}\r\n resetSelectionOnDoubleClick={resetSelectionOnDoubleClick}\r\n detailsOnClick={detailsOnClick}\r\n barAxisTitle={barAxisTitle}\r\n noOfTicks={noOfTicks}\r\n valueColor={valueColor}\r\n styles={styles}\r\n classNames={classNames}\r\n animate={\r\n animate === true\r\n ? { duration: 0.5, once: true, amount: 0.5 }\r\n : animate || { duration: 0, once: true, amount: 0 }\r\n }\r\n colorDomain={colorDomain}\r\n precision={precision}\r\n customLayers={customLayers}\r\n naLabel={naLabel}\r\n />\r\n ) : null}\r\n </div>\r\n </>\r\n )}\r\n </div>\r\n {sources || footNote ? (\r\n <GraphFooter\r\n styles={{ footnote: styles?.footnote, source: styles?.source }}\r\n classNames={{\r\n footnote: classNames?.footnote,\r\n source: classNames?.source,\r\n }}\r\n sources={sources}\r\n footNote={footNote}\r\n width={width}\r\n />\r\n ) : null}\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n );\r\n}\r\n","import isEqual from 'fast-deep-equal';\r\nimport { scaleLinear, scaleBand } from 'd3-scale';\r\nimport sum from 'lodash.sum';\r\nimport { useRef, useState } from 'react';\r\nimport { cn } from '@undp/design-system-react/cn';\r\nimport { Modal } from '@undp/design-system-react/Modal';\r\nimport { AnimatePresence, motion, useInView } from 'motion/react';\r\n\r\nimport { numberFormattingFunction } from '@/Utils/numberFormattingFunction';\r\nimport {\r\n AnimateDataType,\r\n ClassNameObject,\r\n CustomLayerDataType,\r\n GroupedBarGraphDataType,\r\n ReferenceDataType,\r\n StyleObject,\r\n} from '@/Types';\r\nimport { Tooltip } from '@/Components/Elements/Tooltip';\r\nimport { checkIfNullOrUndefined } from '@/Utils/checkIfNullOrUndefined';\r\nimport { getTextColorBasedOnBgColor } from '@/Utils/getTextColorBasedOnBgColor';\r\nimport { string2HTML } from '@/Utils/string2HTML';\r\nimport { AxisTitle } from '@/Components/Elements/Axes/AxisTitle';\r\nimport { Axis } from '@/Components/Elements/Axes/Axis';\r\nimport { XAxesLabels } from '@/Components/Elements/Axes/XAxesLabels';\r\nimport { RefLineY } from '@/Components/Elements/ReferenceLine';\r\nimport { YTicksAndGridLines } from '@/Components/Elements/Axes/YTicksAndGridLines';\r\n\r\ninterface Props {\r\n data: GroupedBarGraphDataType[];\r\n width: number;\r\n height: number;\r\n barColors: string[];\r\n barPadding: number;\r\n showLabels: boolean;\r\n showTicks: boolean;\r\n truncateBy: number;\r\n leftMargin: number;\r\n rightMargin: number;\r\n topMargin: number;\r\n bottomMargin: number;\r\n suffix: string;\r\n prefix: string;\r\n showValues: boolean;\r\n refValues?: ReferenceDataType[];\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n tooltip?: string | ((_d: any) => React.ReactNode);\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseOver?: (_d: any) => void;\r\n maxValue: number;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseClick?: (_d: any) => void;\r\n selectedColor?: string;\r\n labelOrder?: string[];\r\n maxBarThickness?: number;\r\n minBarThickness?: number;\r\n resetSelectionOnDoubleClick: boolean;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n detailsOnClick?: string | ((_d: any) => React.ReactNode);\r\n barAxisTitle?: string;\r\n noOfTicks: number;\r\n valueColor?: string;\r\n styles?: StyleObject;\r\n classNames?: ClassNameObject;\r\n animate: AnimateDataType;\r\n colorDomain: string[];\r\n precision: number;\r\n customLayers: CustomLayerDataType[];\r\n naLabel: string;\r\n}\r\n\r\nexport function Graph(props: Props) {\r\n const {\r\n data,\r\n width,\r\n height,\r\n barColors,\r\n barPadding,\r\n showLabels,\r\n showTicks,\r\n truncateBy,\r\n leftMargin,\r\n topMargin,\r\n bottomMargin,\r\n rightMargin,\r\n tooltip,\r\n onSeriesMouseOver,\r\n suffix,\r\n prefix,\r\n showValues,\r\n refValues,\r\n maxValue,\r\n onSeriesMouseClick,\r\n selectedColor,\r\n labelOrder,\r\n maxBarThickness,\r\n minBarThickness,\r\n resetSelectionOnDoubleClick,\r\n detailsOnClick,\r\n barAxisTitle,\r\n valueColor,\r\n noOfTicks,\r\n styles,\r\n classNames,\r\n animate,\r\n colorDomain,\r\n precision,\r\n customLayers,\r\n naLabel,\r\n } = props;\r\n const svgRef = useRef(null);\r\n const isInView = useInView(svgRef, {\r\n once: animate.once,\r\n amount: animate.amount,\r\n });\r\n const margin = {\r\n top: topMargin,\r\n bottom: bottomMargin,\r\n left: barAxisTitle ? leftMargin + 30 : leftMargin,\r\n right: rightMargin,\r\n };\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const [mouseOverData, setMouseOverData] = useState<any>(undefined);\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const [mouseClickData, setMouseClickData] = useState<any>(undefined);\r\n const [eventX, setEventX] = useState<number | undefined>(undefined);\r\n const [eventY, setEventY] = useState<number | undefined>(undefined);\r\n const graphWidth = width - margin.left - margin.right;\r\n const graphHeight = height - margin.top - margin.bottom;\r\n\r\n const y = scaleLinear().domain([0, maxValue]).range([graphHeight, 0]).nice();\r\n const dataWithId = data.map((d, i) => ({\r\n ...d,\r\n id: labelOrder ? `${d.label}` : `${i}`,\r\n }));\r\n const barOrder = labelOrder || dataWithId.map(d => `${d.id}`);\r\n const x = scaleBand()\r\n .domain(barOrder)\r\n .range([\r\n 0,\r\n minBarThickness\r\n ? Math.max(graphWidth, minBarThickness * barOrder.length)\r\n : maxBarThickness\r\n ? Math.min(graphWidth, maxBarThickness * barOrder.length)\r\n : graphWidth,\r\n ])\r\n .paddingInner(barPadding);\r\n const yTicks = y.ticks(noOfTicks);\r\n return (\r\n <>\r\n <motion.svg\r\n width={`${width}px`}\r\n height={`${height}px`}\r\n viewBox={`0 0 ${width} ${height}`}\r\n direction='ltr'\r\n ref={svgRef}\r\n >\r\n <g transform={`translate(${margin.left},${margin.top})`}>\r\n <Axis\r\n y1={y(0)}\r\n y2={y(0)}\r\n x1={0 - leftMargin}\r\n x2={graphWidth + margin.right}\r\n label={numberFormattingFunction(0, naLabel, precision, prefix, suffix)}\r\n labelPos={{\r\n x: 0 - leftMargin,\r\n y: y(0),\r\n dx: 0,\r\n dy: -5,\r\n }}\r\n classNames={{\r\n axis: classNames?.xAxis?.axis,\r\n label: classNames?.yAxis?.labels,\r\n }}\r\n styles={{ axis: styles?.xAxis?.axis, label: styles?.yAxis?.labels }}\r\n />\r\n {showTicks ? (\r\n <YTicksAndGridLines\r\n values={yTicks.filter(d => d !== 0)}\r\n y={yTicks.filter(d => d !== 0).map(d => y(d))}\r\n x1={0 - leftMargin}\r\n x2={graphWidth + margin.right}\r\n styles={{\r\n gridLines: styles?.yAxis?.gridLines,\r\n labels: styles?.yAxis?.labels,\r\n }}\r\n classNames={{\r\n gridLines: classNames?.yAxis?.gridLines,\r\n labels: classNames?.yAxis?.labels,\r\n }}\r\n suffix={suffix}\r\n prefix={prefix}\r\n labelType='secondary'\r\n showGridLines\r\n labelPos='vertical'\r\n precision={precision}\r\n />\r\n ) : null}\r\n <AxisTitle\r\n x={0 - leftMargin - 15}\r\n y={graphHeight / 2}\r\n style={styles?.yAxis?.title}\r\n className={classNames?.yAxis?.title}\r\n text={barAxisTitle}\r\n rotate90\r\n />\r\n {customLayers.filter(d => d.position === 'before').map(d => d.layer)}\r\n <AnimatePresence>\r\n {dataWithId.map(d =>\r\n !checkIfNullOrUndefined(x(d.id)) ? (\r\n <motion.g\r\n className='undp-viz-low-opacity undp-viz-g-with-hover'\r\n key={d.label}\r\n variants={{\r\n initial: { x: x(`${d.id}`), y: 0 },\r\n whileInView: {\r\n x: x(`${d.id}`),\r\n y: 0,\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n transition={{ duration: animate.duration }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n >\r\n {d.size.map((el, j) => (\r\n <motion.g\r\n key={`${d.label}-${colorDomain[j] || j}`}\r\n opacity={selectedColor ? (barColors[j] === selectedColor ? 1 : 0.3) : 1}\r\n onMouseEnter={event => {\r\n setMouseOverData({ ...d, sizeIndex: j });\r\n setEventY(event.clientY);\r\n setEventX(event.clientX);\r\n onSeriesMouseOver?.({ ...d, sizeIndex: j });\r\n }}\r\n onMouseMove={event => {\r\n setMouseOverData({ ...d, sizeIndex: j });\r\n setEventY(event.clientY);\r\n setEventX(event.clientX);\r\n }}\r\n onMouseLeave={() => {\r\n setMouseOverData(undefined);\r\n setEventX(undefined);\r\n setEventY(undefined);\r\n onSeriesMouseOver?.(undefined);\r\n }}\r\n onClick={() => {\r\n if (onSeriesMouseClick || detailsOnClick) {\r\n if (\r\n isEqual(mouseClickData, { ...d, sizeIndex: j }) &&\r\n resetSelectionOnDoubleClick\r\n ) {\r\n setMouseClickData(undefined);\r\n onSeriesMouseClick?.(undefined);\r\n } else {\r\n setMouseClickData({ ...d, sizeIndex: j });\r\n if (onSeriesMouseClick) onSeriesMouseClick({ ...d, sizeIndex: j });\r\n }\r\n }\r\n }}\r\n >\r\n <motion.rect\r\n x={0}\r\n width={x.bandwidth()}\r\n variants={{\r\n initial: {\r\n height: 0,\r\n fill: barColors[j],\r\n y: y(0),\r\n },\r\n whileInView: {\r\n height: Math.abs(\r\n y(sum(d.size.filter((element, k) => k <= j && element))) -\r\n y(sum(d.size.filter((element, k) => k < j && element))),\r\n ),\r\n y: y(sum(d.size.filter((element, k) => k <= j && element))),\r\n fill: barColors[j],\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n exit={{\r\n height: 0,\r\n y: y(0),\r\n transition: { duration: animate.duration },\r\n }}\r\n />\r\n {showValues ? (\r\n <motion.text\r\n x={x.bandwidth() / 2}\r\n style={{\r\n fill: getTextColorBasedOnBgColor(barColors[j]),\r\n textAnchor: 'middle',\r\n ...(styles?.graphObjectValues || {}),\r\n }}\r\n className={cn('graph-value text-sm', classNames?.graphObjectValues)}\r\n dy='0.33em'\r\n variants={{\r\n initial: {\r\n y: y(0),\r\n opacity: 0,\r\n fill: getTextColorBasedOnBgColor(barColors[j]),\r\n },\r\n whileInView: {\r\n y:\r\n y(sum(d.size.filter((element, k) => k <= j && element))) +\r\n Math.abs(\r\n y(sum(d.size.filter((element, k) => k <= j && element))) -\r\n y(sum(d.size.filter((element, k) => k < j && element))),\r\n ) /\r\n 2,\r\n opacity:\r\n el &&\r\n Math.abs(\r\n y(sum(d.size.filter((element, k) => k <= j && element))) -\r\n y(sum(d.size.filter((element, k) => k < j && element))),\r\n ) > 20\r\n ? 1\r\n : 0,\r\n fill: getTextColorBasedOnBgColor(barColors[j]),\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n >\r\n {numberFormattingFunction(el, naLabel, precision, prefix, suffix)}\r\n </motion.text>\r\n ) : null}\r\n </motion.g>\r\n ))}\r\n {showLabels ? (\r\n <XAxesLabels\r\n value={\r\n `${d.label}`.length < truncateBy\r\n ? `${d.label}`\r\n : `${`${d.label}`.substring(0, truncateBy)}...`\r\n }\r\n y={y(0) + 5}\r\n x={0}\r\n width={x.bandwidth()}\r\n height={margin.bottom}\r\n style={styles?.xAxis?.labels}\r\n className={classNames?.xAxis?.labels}\r\n alignment='top'\r\n animate={animate}\r\n isInView={isInView}\r\n />\r\n ) : null}\r\n {showValues ? (\r\n <motion.text\r\n style={{\r\n ...(valueColor && { fill: valueColor }),\r\n textAnchor: 'middle',\r\n ...(styles?.graphObjectValues || {}),\r\n }}\r\n x={x.bandwidth() / 2}\r\n dy={-10}\r\n className={cn(\r\n 'graph-value graph-value-total',\r\n !valueColor\r\n ? 'fill-primary-gray-700 dark:fill-primary-gray-300 text-sm'\r\n : 'text-sm',\r\n classNames?.graphObjectValues,\r\n )}\r\n variants={{\r\n initial: {\r\n y: y(0),\r\n opacity: 0,\r\n },\r\n whileInView: {\r\n y: y(sum(d.size.map(el => el || 0))),\r\n opacity: 1,\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n exit={{\r\n opacity: 0,\r\n transition: { duration: animate.duration },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n >\r\n {numberFormattingFunction(\r\n sum(d.size.filter(element => element)),\r\n naLabel,\r\n precision,\r\n prefix,\r\n suffix,\r\n )}\r\n </motion.text>\r\n ) : null}\r\n </motion.g>\r\n ) : null,\r\n )}\r\n {refValues ? (\r\n <>\r\n {refValues.map((el, i) => (\r\n <RefLineY\r\n key={i}\r\n text={el.text}\r\n color={el.color}\r\n y={y(el.value as number)}\r\n x1={0 - leftMargin}\r\n x2={graphWidth + margin.right}\r\n classNames={el.classNames}\r\n styles={el.styles}\r\n animate={animate}\r\n isInView={isInView}\r\n />\r\n ))}\r\n </>\r\n ) : null}\r\n </AnimatePresence>\r\n {customLayers.filter(d => d.position === 'after').map(d => d.layer)}\r\n </g>\r\n </motion.svg>\r\n {mouseOverData && tooltip && eventX && eventY ? (\r\n <Tooltip\r\n data={mouseOverData}\r\n body={tooltip}\r\n xPos={eventX}\r\n yPos={eventY}\r\n backgroundStyle={styles?.tooltip}\r\n className={classNames?.tooltip}\r\n />\r\n ) : null}\r\n {detailsOnClick && mouseClickData !== undefined ? (\r\n <Modal\r\n open={mouseClickData !== undefined}\r\n onClose={() => {\r\n setMouseClickData(undefined);\r\n }}\r\n >\r\n <div\r\n className='graph-modal-content m-0'\r\n dangerouslySetInnerHTML={\r\n typeof detailsOnClick === 'string'\r\n ? { __html: string2HTML(detailsOnClick, mouseClickData) }\r\n : undefined\r\n }\r\n >\r\n {typeof detailsOnClick === 'function' ? detailsOnClick(mouseClickData) : null}\r\n </div>\r\n </Modal>\r\n ) : null}\r\n </>\r\n );\r\n}\r\n","import { useEffect, useRef, useState } from 'react';\r\nimport sum from 'lodash.sum';\r\nimport { format } from 'date-fns/format';\r\nimport { parse } from 'date-fns/parse';\r\nimport { cn } from '@undp/design-system-react/cn';\r\nimport { SliderUI } from '@undp/design-system-react/SliderUI';\r\nimport { ascending, sort } from 'd3-array';\r\nimport uniqBy from 'lodash.uniqby';\r\nimport orderBy from 'lodash.orderby';\r\n\r\nimport { Graph } from './Graph';\r\n\r\nimport {\r\n ReferenceDataType,\r\n GroupedBarGraphDataType,\r\n SourcesDataType,\r\n Languages,\r\n StyleObject,\r\n ClassNameObject,\r\n CustomLayerDataType,\r\n AnimateDataType,\r\n TimelineDataType,\r\n} from '@/Types';\r\nimport { checkIfNullOrUndefined } from '@/Utils/checkIfNullOrUndefined';\r\nimport { GraphFooter } from '@/Components/Elements/GraphFooter';\r\nimport { GraphHeader } from '@/Components/Elements/GraphHeader';\r\nimport { ColorLegendWithMouseOver } from '@/Components/Elements/ColorLegendWithMouseOver';\r\nimport { Colors } from '@/Components/ColorPalette';\r\nimport { EmptyState } from '@/Components/Elements/EmptyState';\r\nimport { Pause, Play } from '@/Components/Icons';\r\nimport { getSliderMarks } from '@/Utils/getSliderMarks';\r\nimport { ensureCompleteDataForStackedBarChart } from '@/Utils/ensureCompleteData';\r\n\r\ninterface Props {\r\n data: GroupedBarGraphDataType[];\r\n colors?: string[];\r\n graphTitle?: string | React.ReactNode;\r\n width?: number;\r\n labelOrder?: string[];\r\n height?: number;\r\n sources?: SourcesDataType[];\r\n graphDescription?: string | React.ReactNode;\r\n footNote?: string | React.ReactNode;\r\n barPadding?: number;\r\n showLabels?: boolean;\r\n showTicks?: boolean;\r\n colorDomain: string[];\r\n colorLegendTitle?: string;\r\n showColorScale?: boolean;\r\n truncateBy?: number;\r\n backgroundColor?: string | boolean;\r\n padding?: string;\r\n leftMargin?: number;\r\n rightMargin?: number;\r\n topMargin?: number;\r\n bottomMargin?: number;\r\n showValues?: boolean;\r\n suffix?: string;\r\n prefix?: string;\r\n relativeHeight?: number;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n tooltip?: string | ((_d: any) => React.ReactNode);\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseOver?: (_d: any) => void;\r\n refValues?: ReferenceDataType[];\r\n graphID?: string;\r\n maxValue?: number;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseClick?: (_d: any) => void;\r\n graphDownload?: boolean;\r\n dataDownload?: boolean;\r\n language?: Languages;\r\n minHeight?: number;\r\n theme?: 'light' | 'dark';\r\n maxBarThickness?: number;\r\n sortParameter?: number | 'total';\r\n sortData?: 'asc' | 'desc';\r\n maxNumberOfBars?: number;\r\n minBarThickness?: number;\r\n ariaLabel?: string;\r\n resetSelectionOnDoubleClick?: boolean;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n detailsOnClick?: string | ((_d: any) => React.ReactNode);\r\n barAxisTitle?: string;\r\n noOfTicks?: number;\r\n valueColor?: string;\r\n styles?: StyleObject;\r\n classNames?: ClassNameObject;\r\n filterNA?: boolean;\r\n animate?: boolean | AnimateDataType;\r\n precision?: number;\r\n customLayers?: CustomLayerDataType[];\r\n timeline?: TimelineDataType;\r\n naLabel?: string;\r\n}\r\n\r\nexport function VerticalStackedBarGraph(props: Props) {\r\n const {\r\n data,\r\n graphTitle,\r\n colors = Colors.light.categoricalColors.colors,\r\n sources,\r\n graphDescription,\r\n barPadding = 0.25,\r\n showTicks = true,\r\n leftMargin = 20,\r\n rightMargin = 20,\r\n topMargin = 20,\r\n bottomMargin = 25,\r\n truncateBy = 999,\r\n showLabels = true,\r\n showValues = true,\r\n backgroundColor = false,\r\n showColorScale = true,\r\n suffix = '',\r\n prefix = '',\r\n height,\r\n width,\r\n footNote,\r\n colorDomain,\r\n colorLegendTitle,\r\n padding,\r\n tooltip,\r\n onSeriesMouseOver,\r\n relativeHeight,\r\n refValues,\r\n graphID,\r\n maxValue,\r\n onSeriesMouseClick,\r\n graphDownload = false,\r\n dataDownload = false,\r\n language = 'en',\r\n theme = 'light',\r\n labelOrder,\r\n minHeight = 0,\r\n maxBarThickness,\r\n sortParameter,\r\n maxNumberOfBars,\r\n minBarThickness,\r\n ariaLabel,\r\n resetSelectionOnDoubleClick = true,\r\n detailsOnClick,\r\n barAxisTitle,\r\n noOfTicks = 5,\r\n valueColor,\r\n styles,\r\n classNames,\r\n filterNA = true,\r\n animate = false,\r\n precision = 2,\r\n customLayers = [],\r\n timeline = { enabled: false, autoplay: false, showOnlyActiveDate: true },\r\n naLabel = 'NA',\r\n sortData,\r\n } = props;\r\n\r\n const [svgWidth, setSvgWidth] = useState(0);\r\n const [svgHeight, setSvgHeight] = useState(0);\r\n const [play, setPlay] = useState(timeline.autoplay);\r\n const uniqDatesSorted = sort(\r\n uniqBy(\r\n data.filter(d => d.date !== undefined && d.date !== null),\r\n d => d.date,\r\n ).map(d => parse(`${d.date}`, timeline.dateFormat || 'yyyy', new Date()).getTime()),\r\n (a, b) => ascending(a, b),\r\n );\r\n const [index, setIndex] = useState(timeline.autoplay ? 0 : uniqDatesSorted.length - 1);\r\n const [selectedColor, setSelectedColor] = useState<string | undefined>(undefined);\r\n\r\n const graphDiv = useRef<HTMLDivElement>(null);\r\n const graphParentDiv = useRef<HTMLDivElement>(null);\r\n useEffect(() => {\r\n const resizeObserver = new ResizeObserver(entries => {\r\n setSvgWidth(width || entries[0].target.clientWidth || 620);\r\n setSvgHeight(height || entries[0].target.clientHeight || 480);\r\n });\r\n if (graphDiv.current) {\r\n setSvgHeight(graphDiv.current.clientHeight || 480);\r\n setSvgWidth(graphDiv.current.clientWidth || 620);\r\n if (!width) resizeObserver.observe(graphDiv.current);\r\n }\r\n return () => resizeObserver.disconnect();\r\n }, [width, height]);\r\n\r\n useEffect(() => {\r\n const interval = setInterval(\r\n () => {\r\n setIndex(i => (i < uniqDatesSorted.length - 1 ? i + 1 : 0));\r\n },\r\n (timeline.speed || 2) * 1000,\r\n );\r\n if (!play) clearInterval(interval);\r\n return () => clearInterval(interval);\r\n }, [uniqDatesSorted, play, timeline.speed]);\r\n\r\n const markObj = getSliderMarks(\r\n uniqDatesSorted,\r\n index,\r\n timeline.showOnlyActiveDate,\r\n timeline.dateFormat || 'yyyy',\r\n );\r\n\r\n return (\r\n <div\r\n className={`${theme || 'light'} flex ${width ? 'w-fit grow-0' : 'w-full grow'}`}\r\n dir={language === 'he' || language === 'ar' ? 'rtl' : undefined}\r\n >\r\n <div\r\n className={cn(\r\n `${\r\n !backgroundColor\r\n ? 'bg-transparent '\r\n : backgroundColor === true\r\n ? 'bg-primary-gray-200 dark:bg-primary-gray-650 '\r\n : ''\r\n }ml-auto mr-auto flex flex-col grow h-inherit ${language || 'en'}`,\r\n width ? 'w-fit' : 'w-full',\r\n classNames?.graphContainer,\r\n )}\r\n style={{\r\n ...(styles?.graphContainer || {}),\r\n ...(backgroundColor && backgroundColor !== true ? { backgroundColor } : {}),\r\n }}\r\n id={graphID}\r\n ref={graphParentDiv}\r\n aria-label={\r\n ariaLabel ||\r\n `${graphTitle ? `The graph shows ${graphTitle}. ` : ''}This is a stacked bar chart. ${\r\n graphDescription ? ` ${graphDescription}` : ''\r\n }`\r\n }\r\n >\r\n <div style={{ padding: backgroundColor ? padding || '1rem' : padding || 0 }}>\r\n <div className='flex flex-col w-full gap-4 grow justify-between'>\r\n {graphTitle || graphDescription || graphDownload || dataDownload ? (\r\n <GraphHeader\r\n styles={{\r\n title: styles?.title,\r\n description: styles?.description,\r\n }}\r\n classNames={{\r\n title: classNames?.title,\r\n description: classNames?.description,\r\n }}\r\n graphTitle={graphTitle}\r\n graphDescription={graphDescription}\r\n width={width}\r\n graphDownload={graphDownload ? graphParentDiv.current : undefined}\r\n dataDownload={\r\n dataDownload\r\n ? data.map(d => d.data).filter(d => d !== undefined).length > 0\r\n ? data.map(d => d.data).filter(d => d !== undefined)\r\n : data.filter(d => d !== undefined)\r\n : null\r\n }\r\n />\r\n ) : null}\r\n {timeline.enabled && uniqDatesSorted.length > 0 && markObj ? (\r\n <div className='flex gap-6 items-center' dir='ltr'>\r\n <button\r\n type='button'\r\n onClick={() => {\r\n setPlay(!play);\r\n }}\r\n className='p-0 border-0 cursor-pointer bg-transparent'\r\n aria-label={play ? 'Click to pause animation' : 'Click to play animation'}\r\n >\r\n {play ? <Pause /> : <Play />}\r\n </button>\r\n <SliderUI\r\n min={uniqDatesSorted[0]}\r\n max={uniqDatesSorted[uniqDatesSorted.length - 1]}\r\n marks={markObj}\r\n step={null}\r\n defaultValue={uniqDatesSorted[uniqDatesSorted.length - 1]}\r\n value={uniqDatesSorted[index]}\r\n onChangeComplete={nextValue => {\r\n setIndex(uniqDatesSorted.indexOf(nextValue as number));\r\n }}\r\n onChange={nextValue => {\r\n setIndex(uniqDatesSorted.indexOf(nextValue as number));\r\n }}\r\n aria-label='Time slider. Use arrow keys to adjust selected time period.'\r\n />\r\n </div>\r\n ) : null}\r\n <div className='grow flex flex-col justify-center gap-3 w-full'>\r\n {data.length === 0 ? (\r\n <EmptyState />\r\n ) : (\r\n <>\r\n {showColorScale ? (\r\n <ColorLegendWithMouseOver\r\n width={width}\r\n colorDomain={colorDomain}\r\n colors={colors}\r\n colorLegendTitle={colorLegendTitle}\r\n setSelectedColor={setSelectedColor}\r\n showNAColor={false}\r\n />\r\n ) : null}\r\n <div className='w-full grow leading-0' ref={graphDiv} aria-label='Graph area'>\r\n {(width || svgWidth) && (height || svgHeight) ? (\r\n <Graph\r\n data={\r\n sortParameter !== undefined\r\n ? sortParameter === 'total'\r\n ? orderBy(\r\n ensureCompleteDataForStackedBarChart(\r\n data,\r\n timeline.dateFormat || 'yyyy',\r\n )\r\n .filter(d =>\r\n timeline.enabled\r\n ? d.date ===\r\n format(\r\n new Date(uniqDatesSorted[index]),\r\n timeline.dateFormat || 'yyyy',\r\n )\r\n : d,\r\n )\r\n .filter(d =>\r\n filterNA ? !d.size.every(item => item == null) : d,\r\n ),\r\n d => sum(d.size.filter(el => !checkIfNullOrUndefined(el))),\r\n [sortData || 'asc'],\r\n ).filter((_d, i) => (maxNumberOfBars ? i < maxNumberOfBars : true))\r\n : orderBy(\r\n ensureCompleteDataForStackedBarChart(\r\n data,\r\n timeline.dateFormat || 'yyyy',\r\n )\r\n .filter(d =>\r\n timeline.enabled\r\n ? d.date ===\r\n format(\r\n new Date(uniqDatesSorted[index]),\r\n timeline.dateFormat || 'yyyy',\r\n )\r\n : d,\r\n )\r\n .filter(d =>\r\n filterNA ? !d.size.every(item => item == null) : d,\r\n ),\r\n d =>\r\n checkIfNullOrUndefined(d.size[sortParameter])\r\n ? -Infinity\r\n : d.size[sortParameter],\r\n [sortData || 'asc'],\r\n ).filter((_d, i) => (maxNumberOfBars ? i < maxNumberOfBars : true))\r\n : ensureCompleteDataForStackedBarChart(\r\n data,\r\n timeline.dateFormat || 'yyyy',\r\n )\r\n .filter(d => (filterNA ? !d.size.every(item => item == null) : d))\r\n .filter((_d, i) => (maxNumberOfBars ? i < maxNumberOfBars : true))\r\n }\r\n barColors={colors}\r\n width={width || svgWidth}\r\n height={Math.max(\r\n minHeight,\r\n height ||\r\n (relativeHeight\r\n ? minHeight\r\n ? (width || svgWidth) * relativeHeight > minHeight\r\n ? (width || svgWidth) * relativeHeight\r\n : minHeight\r\n : (width || svgWidth) * relativeHeight\r\n : svgHeight),\r\n )}\r\n barPadding={barPadding}\r\n showLabels={showLabels}\r\n showTicks={showTicks}\r\n truncateBy={truncateBy}\r\n leftMargin={leftMargin}\r\n rightMargin={rightMargin}\r\n topMargin={topMargin}\r\n bottomMargin={bottomMargin}\r\n tooltip={tooltip}\r\n onSeriesMouseOver={onSeriesMouseOver}\r\n showValues={showValues}\r\n suffix={suffix}\r\n prefix={prefix}\r\n refValues={refValues}\r\n maxValue={\r\n !checkIfNullOrUndefined(maxValue)\r\n ? (maxValue as number)\r\n : Math.max(\r\n ...data.map(\r\n d => sum(d.size.filter(l => !checkIfNullOrUndefined(l))) || 0,\r\n ),\r\n )\r\n }\r\n onSeriesMouseClick={onSeriesMouseClick}\r\n selectedColor={selectedColor}\r\n labelOrder={labelOrder}\r\n maxBarThickness={maxBarThickness}\r\n minBarThickness={minBarThickness}\r\n resetSelectionOnDoubleClick={resetSelectionOnDoubleClick}\r\n detailsOnClick={detailsOnClick}\r\n barAxisTitle={barAxisTitle}\r\n noOfTicks={noOfTicks}\r\n valueColor={valueColor}\r\n styles={styles}\r\n classNames={classNames}\r\n animate={\r\n animate === true\r\n ? { duration: 0.5, once: true, amount: 0.5 }\r\n : animate || { duration: 0, once: true, amount: 0 }\r\n }\r\n colorDomain={colorDomain}\r\n precision={precision}\r\n customLayers={customLayers}\r\n naLabel={naLabel}\r\n />\r\n ) : null}\r\n </div>\r\n </>\r\n )}\r\n </div>\r\n {sources || footNote ? (\r\n <GraphFooter\r\n styles={{ footnote: styles?.footnote, source: styles?.source }}\r\n classNames={{\r\n footnote: classNames?.footnote,\r\n source: classNames?.source,\r\n }}\r\n sources={sources}\r\n footNote={footNote}\r\n width={width}\r\n />\r\n ) : null}\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n );\r\n}\r\n","import { HorizontalBarGraph } from './Horizontal/BarGraph';\r\nimport { HorizontalGroupedBarGraph } from './Horizontal/GroupedBarGraph';\r\nimport { HorizontalStackedBarGraph } from './Horizontal/StackedBarGraph';\r\nimport { VerticalBarGraph } from './Vertical/BarGraph';\r\nimport { VerticalGroupedBarGraph } from './Vertical/GroupedBarGraph';\r\nimport { VerticalStackedBarGraph } from './Vertical/StackedBarGraph';\r\n\r\nimport {\r\n ReferenceDataType,\r\n BarGraphDataType,\r\n SourcesDataType,\r\n Languages,\r\n StyleObject,\r\n ClassNameObject,\r\n GroupedBarGraphDataType,\r\n CustomLayerDataType,\r\n AnimateDataType,\r\n TimelineDataType,\r\n} from '@/Types';\r\n\r\ninterface Props {\r\n // Data\r\n /** Array of data objects */\r\n data: BarGraphDataType[];\r\n\r\n /** Orientation of the graph */\r\n orientation?: 'vertical' | 'horizontal';\r\n\r\n // Titles, Labels, and Sources\r\n /** Title of the graph */\r\n graphTitle?: string | React.ReactNode;\r\n /** Description of the graph */\r\n graphDescription?: string | React.ReactNode;\r\n /** Footnote for the graph */\r\n footNote?: string | React.ReactNode;\r\n /** Source data for the graph */\r\n sources?: SourcesDataType[];\r\n /** Accessibility label */\r\n ariaLabel?: string;\r\n\r\n // Colors and Styling\r\n /** Color or array of colors for bars */\r\n colors?: string | string[];\r\n /** Domain of colors for the graph */\r\n colorDomain?: string[];\r\n /** Title for the color legend */\r\n colorLegendTitle?: string;\r\n /** Color of value labels */\r\n valueColor?: string;\r\n /** Background color of the graph */\r\n backgroundColor?: string | boolean;\r\n /** Custom styles for the graph. Each object should be a valid React CSS style object. */\r\n styles?: StyleObject;\r\n /** Custom class names */\r\n classNames?: ClassNameObject;\r\n\r\n // Size and Spacing\r\n /** Width of the graph */\r\n width?: number;\r\n /** Height of the graph */\r\n height?: number;\r\n /** Minimum height of the graph */\r\n minHeight?: number;\r\n /** Relative height scaling factor. This overwrites the height props */\r\n relativeHeight?: number;\r\n /** Padding around the graph. Defaults to 0 if no backgroundColor is mentioned else defaults to 1rem */\r\n padding?: string;\r\n /** Left margin of the graph */\r\n leftMargin?: number;\r\n /** Right margin of the graph */\r\n rightMargin?: number;\r\n /** Top margin of the graph */\r\n topMargin?: number;\r\n /** Bottom margin of the graph */\r\n bottomMargin?: number;\r\n /** Padding between bars */\r\n barPadding?: number;\r\n /** Maximum thickness of bars */\r\n maxBarThickness?: number;\r\n /** Minimum thickness of bars */\r\n minBarThickness?: number;\r\n /** Maximum number of bars shown in the graph */\r\n maxNumberOfBars?: number;\r\n\r\n // Values and Ticks\r\n /** Prefix for values */\r\n prefix?: string;\r\n /** Suffix for values */\r\n suffix?: string;\r\n /** Maximum value for the chart */\r\n maxValue?: number;\r\n /** Minimum value for the chart */\r\n minValue?: number;\r\n /** Truncate labels by specified length */\r\n truncateBy?: number;\r\n /** Reference values for comparison */\r\n refValues?: ReferenceDataType[];\r\n /** Number of ticks on the axis */\r\n noOfTicks?: number;\r\n\r\n // Graph Parameters\r\n /** Toggle visibility of labels */\r\n showLabels?: boolean;\r\n /** Toggle visibility of values */\r\n showValues?: boolean;\r\n /** Custom order for labels */\r\n labelOrder?: string[];\r\n /** Defines how “NA” values should be displayed/labelled in the graph */\r\n naLabel?: string;\r\n /** Toggle visibility of axis ticks */\r\n showTicks?: boolean;\r\n /** Toggle visibility of color scale. This is only applicable if the data props hae color parameter */\r\n showColorScale?: boolean;\r\n /** Toggle visibility of NA color in the color scale. This is only applicable if the data props hae color parameter and showColorScale prop is true */\r\n showNAColor?: boolean;\r\n /** Data points to highlight. Use the label value from data to highlight the data point */\r\n highlightedDataPoints?: (string | number)[];\r\n /** Defines the opacity of the non-highlighted data */\r\n dimmedOpacity?: number;\r\n /** Title for the bar axis */\r\n barAxisTitle?: string;\r\n /** Sorting order for data. This is overwritten by labelOrder prop. */\r\n sortData?: 'asc' | 'desc';\r\n /** Toggles if data point which are undefined or has value null are filtered out. */\r\n filterNA?: boolean;\r\n /** Toggles if the graph animates in when loaded. */\r\n animate?: boolean | AnimateDataType;\r\n /** Specifies the number of decimal places to display in the value. */\r\n precision?: number;\r\n /** Optional SVG <g> element or function that renders custom content behind or in front of the graph. */\r\n customLayers?: CustomLayerDataType[];\r\n /** Configures playback and slider controls for animating the chart over time. The data must have a key date for it to work properly. */\r\n timeline?: TimelineDataType;\r\n /** Enable graph download option as png */\r\n graphDownload?: boolean;\r\n /** Enable data download option as a csv */\r\n dataDownload?: boolean;\r\n /** Reset selection on double-click. Only applicable when used in a dashboard context with filters. */\r\n resetSelectionOnDoubleClick?: boolean;\r\n\r\n // Interactions and Callbacks\r\n /** Tooltip content. If the type is string then this uses the [handlebar](../?path=/docs/misc-handlebars-templates-and-custom-helpers--docs) template to display the data */\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n tooltip?: string | ((_d: any) => React.ReactNode);\r\n /** Details displayed on the modal when user clicks of a data point. If the type is string then this uses the [handlebar](../?path=/docs/misc-handlebars-templates-and-custom-helpers--docs) template to display the data */\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n detailsOnClick?: string | ((_d: any) => React.ReactNode);\r\n /** Callback for mouse over event */\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseOver?: (_d: any) => void;\r\n /** Callback for mouse click event */\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseClick?: (_d: any) => void;\r\n\r\n // Configuration and Options\r\n /** Language setting */\r\n language?: Languages;\r\n /** Color theme */\r\n theme?: 'light' | 'dark';\r\n /** Unique ID for the graph */\r\n graphID?: string;\r\n}\r\n\r\nexport function SimpleBarGraph(props: Props) {\r\n const {\r\n data,\r\n graphTitle,\r\n colors,\r\n barPadding,\r\n showTicks,\r\n leftMargin,\r\n rightMargin,\r\n topMargin,\r\n bottomMargin,\r\n truncateBy,\r\n showLabels,\r\n showValues,\r\n backgroundColor,\r\n suffix,\r\n prefix,\r\n sources,\r\n graphDescription,\r\n height,\r\n width,\r\n footNote,\r\n colorDomain,\r\n colorLegendTitle,\r\n padding,\r\n relativeHeight,\r\n tooltip,\r\n onSeriesMouseOver,\r\n refValues,\r\n showColorScale,\r\n graphID,\r\n maxValue,\r\n minValue,\r\n highlightedDataPoints,\r\n onSeriesMouseClick,\r\n graphDownload,\r\n dataDownload,\r\n language,\r\n theme,\r\n sortData,\r\n labelOrder,\r\n showNAColor,\r\n minHeight,\r\n maxBarThickness,\r\n maxNumberOfBars,\r\n minBarThickness,\r\n ariaLabel,\r\n resetSelectionOnDoubleClick,\r\n detailsOnClick,\r\n barAxisTitle,\r\n noOfTicks,\r\n valueColor,\r\n orientation = 'vertical',\r\n styles,\r\n classNames,\r\n filterNA,\r\n animate,\r\n dimmedOpacity,\r\n precision,\r\n customLayers,\r\n timeline,\r\n naLabel,\r\n } = props;\r\n\r\n if (orientation === 'vertical')\r\n return (\r\n <VerticalBarGraph\r\n data={data}\r\n graphTitle={graphTitle}\r\n colors={colors}\r\n barPadding={barPadding}\r\n showTicks={showTicks}\r\n leftMargin={leftMargin}\r\n rightMargin={rightMargin}\r\n topMargin={topMargin}\r\n bottomMargin={bottomMargin}\r\n truncateBy={truncateBy}\r\n showLabels={showLabels}\r\n showValues={showValues}\r\n backgroundColor={backgroundColor}\r\n suffix={suffix}\r\n prefix={prefix}\r\n sources={sources}\r\n graphDescription={graphDescription}\r\n height={height}\r\n width={width}\r\n footNote={footNote}\r\n colorDomain={colorDomain}\r\n colorLegendTitle={colorLegendTitle}\r\n padding={padding}\r\n relativeHeight={relativeHeight}\r\n tooltip={tooltip}\r\n onSeriesMouseOver={onSeriesMouseOver}\r\n refValues={refValues}\r\n showColorScale={showColorScale}\r\n graphID={graphID}\r\n maxValue={maxValue}\r\n minValue={minValue}\r\n highlightedDataPoints={highlightedDataPoints}\r\n onSeriesMouseClick={onSeriesMouseClick}\r\n graphDownload={graphDownload}\r\n dataDownload={dataDownload}\r\n language={language}\r\n theme={theme}\r\n sortData={sortData}\r\n labelOrder={labelOrder}\r\n showNAColor={showNAColor}\r\n minHeight={minHeight}\r\n maxBarThickness={maxBarThickness}\r\n maxNumberOfBars={maxNumberOfBars}\r\n minBarThickness={minBarThickness}\r\n ariaLabel={ariaLabel}\r\n resetSelectionOnDoubleClick={resetSelectionOnDoubleClick}\r\n styles={styles}\r\n detailsOnClick={detailsOnClick}\r\n barAxisTitle={barAxisTitle}\r\n noOfTicks={noOfTicks}\r\n valueColor={valueColor}\r\n classNames={classNames}\r\n filterNA={filterNA}\r\n animate={animate}\r\n dimmedOpacity={dimmedOpacity}\r\n precision={precision}\r\n customLayers={customLayers}\r\n timeline={timeline}\r\n naLabel={naLabel}\r\n />\r\n );\r\n return (\r\n <HorizontalBarGraph\r\n data={data}\r\n graphTitle={graphTitle}\r\n colors={colors}\r\n barPadding={barPadding}\r\n showTicks={showTicks}\r\n leftMargin={leftMargin}\r\n rightMargin={rightMargin}\r\n topMargin={topMargin}\r\n bottomMargin={bottomMargin}\r\n truncateBy={truncateBy}\r\n showLabels={showLabels}\r\n showValues={showValues}\r\n backgroundColor={backgroundColor}\r\n suffix={suffix}\r\n prefix={prefix}\r\n sources={sources}\r\n graphDescription={graphDescription}\r\n height={height}\r\n width={width}\r\n footNote={footNote}\r\n colorDomain={colorDomain}\r\n colorLegendTitle={colorLegendTitle}\r\n padding={padding}\r\n relativeHeight={relativeHeight}\r\n tooltip={tooltip}\r\n onSeriesMouseOver={onSeriesMouseOver}\r\n refValues={refValues}\r\n showColorScale={showColorScale}\r\n graphID={graphID}\r\n maxValue={maxValue}\r\n minValue={minValue}\r\n highlightedDataPoints={highlightedDataPoints}\r\n onSeriesMouseClick={onSeriesMouseClick}\r\n graphDownload={graphDownload}\r\n dataDownload={dataDownload}\r\n language={language}\r\n theme={theme}\r\n sortData={sortData}\r\n labelOrder={labelOrder}\r\n showNAColor={showNAColor}\r\n minHeight={minHeight}\r\n maxBarThickness={maxBarThickness}\r\n maxNumberOfBars={maxNumberOfBars}\r\n minBarThickness={minBarThickness}\r\n ariaLabel={ariaLabel}\r\n resetSelectionOnDoubleClick={resetSelectionOnDoubleClick}\r\n styles={styles}\r\n detailsOnClick={detailsOnClick}\r\n barAxisTitle={barAxisTitle}\r\n noOfTicks={noOfTicks}\r\n valueColor={valueColor}\r\n classNames={classNames}\r\n filterNA={filterNA}\r\n animate={animate}\r\n dimmedOpacity={dimmedOpacity}\r\n precision={precision}\r\n customLayers={customLayers}\r\n timeline={timeline}\r\n naLabel={naLabel}\r\n />\r\n );\r\n}\r\n\r\ninterface GroupedBarChartProps {\r\n // Data\r\n /** Array of data objects */\r\n data: GroupedBarGraphDataType[];\r\n\r\n /** Orientation of the graph */\r\n orientation?: 'vertical' | 'horizontal';\r\n\r\n // Titles, Labels, and Sources\r\n /** Title of the graph */\r\n graphTitle?: string | React.ReactNode;\r\n /** Description of the graph */\r\n graphDescription?: string | React.ReactNode;\r\n /** Footnote for the graph */\r\n footNote?: string | React.ReactNode;\r\n /** Source data for the graph */\r\n sources?: SourcesDataType[];\r\n /** Accessibility label */\r\n ariaLabel?: string;\r\n\r\n // Colors and Styling\r\n /** Array of colors for different bars in the group */\r\n colors?: string[];\r\n /** Domain of colors for the graph */\r\n colorDomain: string[];\r\n /** Title for the color legend */\r\n colorLegendTitle?: string;\r\n /** Color of value labels */\r\n valueColor?: string;\r\n /** Background color of the graph */\r\n backgroundColor?: string | boolean;\r\n /** Custom styles for the graph. Each object should be a valid React CSS style object. */\r\n styles?: StyleObject;\r\n /** Custom class names */\r\n classNames?: ClassNameObject;\r\n\r\n // Size and Spacing\r\n /** Width of the graph */\r\n width?: number;\r\n /** Height of the graph */\r\n height?: number;\r\n /** Minimum height of the graph */\r\n minHeight?: number;\r\n /** Relative height scaling factor. This overwrites the height props */\r\n relativeHeight?: number;\r\n /** Padding around the graph. Defaults to 0 if no backgroundColor is mentioned else defaults to 1rem */\r\n padding?: string;\r\n /** Left margin of the graph */\r\n leftMargin?: number;\r\n /** Right margin of the graph */\r\n rightMargin?: number;\r\n /** Top margin of the graph */\r\n topMargin?: number;\r\n /** Bottom margin of the graph */\r\n bottomMargin?: number;\r\n /** Padding between bars */\r\n barPadding?: number;\r\n /** Maximum thickness of bars */\r\n maxBarThickness?: number;\r\n\r\n // Values and Ticks\r\n /** Prefix for values */\r\n prefix?: string;\r\n /** Suffix for values */\r\n suffix?: string;\r\n /** Maximum value for the chart */\r\n maxValue?: number;\r\n /** Minimum value for the chart */\r\n minValue?: number;\r\n /** Truncate labels by specified length */\r\n truncateBy?: number;\r\n /** Toggles if data points which have all the values as undefined or null are filtered out. */\r\n filterNA?: boolean;\r\n /** Parameter to sort the data. If a number is provided, it refers to the index of the size array to determine which value to sort by. If set to total, it sorts by the sum of all the values. */\r\n sortParameter?: number | 'total';\r\n /** Sorting order for data. This is overwritten by labelOrder prop. */\r\n sortData?: 'asc' | 'desc';\r\n /** Toggles if the graph animates in when loaded. */\r\n animate?: boolean | AnimateDataType;\r\n /** Reference values for comparison */\r\n refValues?: ReferenceDataType[];\r\n /** Number of ticks on the axis */\r\n noOfTicks?: number;\r\n\r\n // Graph Parameters\r\n /** Toggle visibility of labels */\r\n showLabels?: boolean;\r\n /** Toggle visibility of values */\r\n showValues?: boolean;\r\n /** Custom order for labels */\r\n labelOrder?: string[];\r\n /** Toggle visibility of axis ticks */\r\n showTicks?: boolean;\r\n /** Toggle visibility of color scale. This is only applicable if the data props hae color parameter */\r\n showColorScale?: boolean;\r\n /** Title for the bar axis */\r\n barAxisTitle?: string;\r\n /** Defines how “NA” values should be displayed/labelled in the graph */\r\n naLabel?: string;\r\n /** Specifies the number of decimal places to display in the value. */\r\n precision?: number;\r\n /** Optional SVG <g> element or function that renders custom content behind or in front of the graph. */\r\n customLayers?: CustomLayerDataType[];\r\n /** Configures playback and slider controls for animating the chart over time. The data must have a key date for it to work properly. */\r\n timeline?: TimelineDataType;\r\n /** Enable graph download option as png */\r\n graphDownload?: boolean;\r\n /** Enable data download option as a csv */\r\n dataDownload?: boolean;\r\n /** Reset selection on double-click. Only applicable when used in a dashboard context with filters. */\r\n resetSelectionOnDoubleClick?: boolean;\r\n\r\n // Interactions and Callbacks\r\n /** Tooltip content. If the type is string then this uses the [handlebar](../?path=/docs/misc-handlebars-templates-and-custom-helpers--docs) template to display the data */\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n tooltip?: string | ((_d: any) => React.ReactNode);\r\n /** Details displayed on the modal when user clicks of a data point. If the type is string then this uses the [handlebar](../?path=/docs/misc-handlebars-templates-and-custom-helpers--docs) template to display the data */\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n detailsOnClick?: string | ((_d: any) => React.ReactNode);\r\n /** Callback for mouse over event */\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseOver?: (_d: any) => void;\r\n /** Callback for mouse click event */\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseClick?: (_d: any) => void;\r\n\r\n // Configuration and Options\r\n /** Language setting */\r\n language?: Languages;\r\n /** Color theme */\r\n theme?: 'light' | 'dark';\r\n /** Unique ID for the graph */\r\n graphID?: string;\r\n}\r\n\r\nexport function GroupedBarGraph(props: GroupedBarChartProps) {\r\n const {\r\n data,\r\n graphTitle,\r\n colors,\r\n sources,\r\n graphDescription,\r\n barPadding,\r\n showTicks,\r\n truncateBy,\r\n height,\r\n width,\r\n footNote,\r\n colorDomain,\r\n colorLegendTitle,\r\n suffix,\r\n prefix,\r\n showValues,\r\n padding,\r\n backgroundColor,\r\n leftMargin,\r\n rightMargin,\r\n topMargin,\r\n bottomMargin,\r\n showLabels,\r\n relativeHeight,\r\n tooltip,\r\n onSeriesMouseOver,\r\n refValues,\r\n graphID,\r\n maxValue,\r\n minValue,\r\n onSeriesMouseClick,\r\n graphDownload,\r\n dataDownload,\r\n language,\r\n labelOrder,\r\n minHeight,\r\n theme,\r\n sortParameter,\r\n sortData,\r\n maxBarThickness,\r\n ariaLabel,\r\n resetSelectionOnDoubleClick,\r\n detailsOnClick,\r\n barAxisTitle,\r\n noOfTicks,\r\n valueColor,\r\n orientation = 'vertical',\r\n styles,\r\n classNames,\r\n filterNA,\r\n animate,\r\n precision,\r\n customLayers,\r\n showColorScale,\r\n timeline,\r\n naLabel,\r\n } = props;\r\n\r\n if (orientation === 'vertical')\r\n return (\r\n <VerticalGroupedBarGraph\r\n data={data}\r\n graphTitle={graphTitle}\r\n colors={colors}\r\n sources={sources}\r\n graphDescription={graphDescription}\r\n barPadding={barPadding}\r\n showTicks={showTicks}\r\n truncateBy={truncateBy}\r\n height={height}\r\n width={width}\r\n footNote={footNote}\r\n colorDomain={colorDomain}\r\n colorLegendTitle={colorLegendTitle}\r\n suffix={suffix}\r\n prefix={prefix}\r\n showValues={showValues}\r\n padding={padding}\r\n backgroundColor={backgroundColor}\r\n leftMargin={leftMargin}\r\n rightMargin={rightMargin}\r\n sortParameter={sortParameter}\r\n sortData={sortData}\r\n topMargin={topMargin}\r\n bottomMargin={bottomMargin}\r\n showLabels={showLabels}\r\n relativeHeight={relativeHeight}\r\n tooltip={tooltip}\r\n onSeriesMouseOver={onSeriesMouseOver}\r\n refValues={refValues}\r\n graphID={graphID}\r\n maxValue={maxValue}\r\n minValue={minValue}\r\n onSeriesMouseClick={onSeriesMouseClick}\r\n graphDownload={graphDownload}\r\n dataDownload={dataDownload}\r\n language={language}\r\n labelOrder={labelOrder}\r\n minHeight={minHeight}\r\n theme={theme}\r\n maxBarThickness={maxBarThickness}\r\n ariaLabel={ariaLabel}\r\n resetSelectionOnDoubleClick={resetSelectionOnDoubleClick}\r\n styles={styles}\r\n detailsOnClick={detailsOnClick}\r\n barAxisTitle={barAxisTitle}\r\n noOfTicks={noOfTicks}\r\n valueColor={valueColor}\r\n classNames={classNames}\r\n filterNA={filterNA}\r\n animate={animate}\r\n precision={precision}\r\n customLayers={customLayers}\r\n showColorScale={showColorScale}\r\n timeline={timeline}\r\n naLabel={naLabel}\r\n />\r\n );\r\n return (\r\n <HorizontalGroupedBarGraph\r\n data={data}\r\n graphTitle={graphTitle}\r\n colors={colors}\r\n sortParameter={sortParameter}\r\n sortData={sortData}\r\n sources={sources}\r\n graphDescription={graphDescription}\r\n barPadding={barPadding}\r\n showTicks={showTicks}\r\n truncateBy={truncateBy}\r\n height={height}\r\n width={width}\r\n footNote={footNote}\r\n colorDomain={colorDomain}\r\n colorLegendTitle={colorLegendTitle}\r\n suffix={suffix}\r\n prefix={prefix}\r\n showValues={showValues}\r\n padding={padding}\r\n backgroundColor={backgroundColor}\r\n leftMargin={leftMargin}\r\n rightMargin={rightMargin}\r\n topMargin={topMargin}\r\n bottomMargin={bottomMargin}\r\n showLabels={showLabels}\r\n relativeHeight={relativeHeight}\r\n tooltip={tooltip}\r\n onSeriesMouseOver={onSeriesMouseOver}\r\n refValues={refValues}\r\n graphID={graphID}\r\n maxValue={maxValue}\r\n minValue={minValue}\r\n onSeriesMouseClick={onSeriesMouseClick}\r\n graphDownload={graphDownload}\r\n dataDownload={dataDownload}\r\n language={language}\r\n labelOrder={labelOrder}\r\n minHeight={minHeight}\r\n theme={theme}\r\n maxBarThickness={maxBarThickness}\r\n ariaLabel={ariaLabel}\r\n resetSelectionOnDoubleClick={resetSelectionOnDoubleClick}\r\n styles={styles}\r\n detailsOnClick={detailsOnClick}\r\n barAxisTitle={barAxisTitle}\r\n noOfTicks={noOfTicks}\r\n valueColor={valueColor}\r\n classNames={classNames}\r\n filterNA={filterNA}\r\n animate={animate}\r\n precision={precision}\r\n customLayers={customLayers}\r\n showColorScale={showColorScale}\r\n timeline={timeline}\r\n naLabel={naLabel}\r\n />\r\n );\r\n}\r\n\r\ninterface StackedBarChartProps {\r\n // Data\r\n /** Array of data objects */\r\n data: GroupedBarGraphDataType[];\r\n\r\n /** Orientation of the graph */\r\n orientation?: 'vertical' | 'horizontal';\r\n\r\n // Titles, Labels, and Sources\r\n /** Title of the graph */\r\n graphTitle?: string | React.ReactNode;\r\n /** Description of the graph */\r\n graphDescription?: string | React.ReactNode;\r\n /** Footnote for the graph */\r\n footNote?: string | React.ReactNode;\r\n /** Source data for the graph */\r\n sources?: SourcesDataType[];\r\n /** Accessibility label */\r\n ariaLabel?: string;\r\n\r\n // Colors and Styling\r\n /** Array of colors for different bars in the group */\r\n colors?: string[];\r\n /** Domain of colors for the graph */\r\n colorDomain: string[];\r\n /** Title for the color legend */\r\n colorLegendTitle?: string;\r\n /** Color of value labels */\r\n valueColor?: string;\r\n /** Background color of the graph */\r\n backgroundColor?: string | boolean;\r\n /** Custom styles for the graph. Each object should be a valid React CSS style object. */\r\n styles?: StyleObject;\r\n /** Custom class names */\r\n classNames?: ClassNameObject;\r\n\r\n // Size and Spacing\r\n /** Width of the graph */\r\n width?: number;\r\n /** Height of the graph */\r\n height?: number;\r\n /** Minimum height of the graph */\r\n minHeight?: number;\r\n /** Relative height scaling factor. This overwrites the height props */\r\n relativeHeight?: number;\r\n /** Padding around the graph. Defaults to 0 if no backgroundColor is mentioned else defaults to 1rem */\r\n padding?: string;\r\n /** Left margin of the graph */\r\n leftMargin?: number;\r\n /** Right margin of the graph */\r\n rightMargin?: number;\r\n /** Top margin of the graph */\r\n topMargin?: number;\r\n /** Bottom margin of the graph */\r\n bottomMargin?: number;\r\n /** Padding between bars */\r\n barPadding?: number;\r\n /** Maximum thickness of bars */\r\n maxBarThickness?: number;\r\n /** Minimum thickness of bars */\r\n minBarThickness?: number;\r\n /** Maximum number of bars shown in the graph */\r\n maxNumberOfBars?: number;\r\n\r\n // Values and Ticks\r\n /** Prefix for values */\r\n prefix?: string;\r\n /** Suffix for values */\r\n suffix?: string;\r\n /** Maximum value for the chart */\r\n maxValue?: number;\r\n /** Minimum value for the chart */\r\n truncateBy?: number;\r\n /** Reference values for comparison */\r\n refValues?: ReferenceDataType[];\r\n /** Number of ticks on the axis */\r\n noOfTicks?: number;\r\n\r\n // Graph Parameters\r\n /** Toggle visibility of labels */\r\n showLabels?: boolean;\r\n /** Toggle visibility of values */\r\n showValues?: boolean;\r\n /** Custom order for labels */\r\n labelOrder?: string[];\r\n /** Toggle visibility of axis ticks */\r\n showTicks?: boolean;\r\n /** Toggle visibility of color scale. This is only applicable if the data props hae color parameter */\r\n showColorScale?: boolean;\r\n /** Title for the bar axis */\r\n barAxisTitle?: string;\r\n /** Defines how “NA” values should be displayed/labelled in the graph */\r\n naLabel?: string;\r\n /** Parameter to sort the data. If a number is provided, it refers to the index of the size array to determine which value to sort by. If set to total, it sorts by the sum of all the values. */\r\n sortParameter?: number | 'total';\r\n /** Sorting order for data. This is overwritten by labelOrder prop. */\r\n sortData?: 'asc' | 'desc';\r\n /** Toggles if data points which have all the values as undefined or null are filtered out. */\r\n filterNA?: boolean;\r\n /** Toggles if the graph animates in when loaded. */\r\n animate?: boolean | AnimateDataType;\r\n /** Specifies the number of decimal places to display in the value. */\r\n precision?: number;\r\n /** Optional SVG <g> element or function that renders custom content behind or in front of the graph. */\r\n customLayers?: CustomLayerDataType[];\r\n /** Configures playback and slider controls for animating the chart over time. The data must have a key date for it to work properly. */\r\n timeline?: TimelineDataType;\r\n /** Enable graph download option as png */\r\n graphDownload?: boolean;\r\n /** Enable data download option as a csv */\r\n dataDownload?: boolean;\r\n /** Reset selection on double-click. Only applicable when used in a dashboard context with filters. */\r\n resetSelectionOnDoubleClick?: boolean;\r\n\r\n // Interactions and Callbacks\r\n /** Tooltip content. If the type is string then this uses the [handlebar](../?path=/docs/misc-handlebars-templates-and-custom-helpers--docs) template to display the data */\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n tooltip?: string | ((_d: any) => React.ReactNode);\r\n /** Details displayed on the modal when user clicks of a data point. If the type is string then this uses the [handlebar](../?path=/docs/misc-handlebars-templates-and-custom-helpers--docs) template to display the data */\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n detailsOnClick?: string | ((_d: any) => React.ReactNode);\r\n /** Callback for mouse over event */\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseOver?: (_d: any) => void;\r\n /** Callback for mouse click event */\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseClick?: (_d: any) => void;\r\n\r\n // Configuration and Options\r\n /** Language setting */\r\n language?: Languages;\r\n /** Color theme */\r\n theme?: 'light' | 'dark';\r\n /** Unique ID for the graph */\r\n graphID?: string;\r\n}\r\n\r\nexport function StackedBarGraph(props: StackedBarChartProps) {\r\n const {\r\n data,\r\n graphTitle,\r\n colors,\r\n sources,\r\n graphDescription,\r\n barPadding,\r\n showTicks,\r\n leftMargin,\r\n rightMargin,\r\n topMargin,\r\n bottomMargin,\r\n truncateBy,\r\n showLabels,\r\n showValues,\r\n backgroundColor,\r\n suffix,\r\n prefix,\r\n height,\r\n width,\r\n footNote,\r\n colorDomain,\r\n colorLegendTitle,\r\n padding,\r\n tooltip,\r\n onSeriesMouseOver,\r\n relativeHeight,\r\n refValues,\r\n graphID,\r\n maxValue,\r\n onSeriesMouseClick,\r\n graphDownload,\r\n dataDownload,\r\n language,\r\n theme,\r\n labelOrder,\r\n minHeight,\r\n maxBarThickness,\r\n sortParameter,\r\n sortData,\r\n maxNumberOfBars,\r\n minBarThickness,\r\n ariaLabel,\r\n resetSelectionOnDoubleClick,\r\n detailsOnClick,\r\n barAxisTitle,\r\n noOfTicks,\r\n valueColor,\r\n orientation = 'vertical',\r\n styles,\r\n classNames,\r\n filterNA,\r\n animate,\r\n precision,\r\n customLayers,\r\n showColorScale,\r\n timeline,\r\n naLabel,\r\n } = props;\r\n\r\n if (orientation === 'vertical')\r\n return (\r\n <VerticalStackedBarGraph\r\n data={data}\r\n graphTitle={graphTitle}\r\n colors={colors}\r\n sources={sources}\r\n graphDescription={graphDescription}\r\n barPadding={barPadding}\r\n showTicks={showTicks}\r\n leftMargin={leftMargin}\r\n rightMargin={rightMargin}\r\n topMargin={topMargin}\r\n bottomMargin={bottomMargin}\r\n truncateBy={truncateBy}\r\n showLabels={showLabels}\r\n showValues={showValues}\r\n backgroundColor={backgroundColor}\r\n suffix={suffix}\r\n prefix={prefix}\r\n height={height}\r\n width={width}\r\n footNote={footNote}\r\n colorDomain={colorDomain}\r\n colorLegendTitle={colorLegendTitle}\r\n padding={padding}\r\n tooltip={tooltip}\r\n onSeriesMouseOver={onSeriesMouseOver}\r\n relativeHeight={relativeHeight}\r\n refValues={refValues}\r\n graphID={graphID}\r\n maxValue={maxValue}\r\n onSeriesMouseClick={onSeriesMouseClick}\r\n graphDownload={graphDownload}\r\n dataDownload={dataDownload}\r\n language={language}\r\n theme={theme}\r\n labelOrder={labelOrder}\r\n minHeight={minHeight}\r\n maxBarThickness={maxBarThickness}\r\n sortParameter={sortParameter}\r\n sortData={sortData}\r\n maxNumberOfBars={maxNumberOfBars}\r\n minBarThickness={minBarThickness}\r\n ariaLabel={ariaLabel}\r\n resetSelectionOnDoubleClick={resetSelectionOnDoubleClick}\r\n styles={styles}\r\n detailsOnClick={detailsOnClick}\r\n barAxisTitle={barAxisTitle}\r\n noOfTicks={noOfTicks}\r\n valueColor={valueColor}\r\n classNames={classNames}\r\n filterNA={filterNA}\r\n animate={animate}\r\n precision={precision}\r\n customLayers={customLayers}\r\n showColorScale={showColorScale}\r\n timeline={timeline}\r\n naLabel={naLabel}\r\n />\r\n );\r\n return (\r\n <HorizontalStackedBarGraph\r\n data={data}\r\n graphTitle={graphTitle}\r\n colors={colors}\r\n sources={sources}\r\n graphDescription={graphDescription}\r\n barPadding={barPadding}\r\n showTicks={showTicks}\r\n leftMargin={leftMargin}\r\n rightMargin={rightMargin}\r\n topMargin={topMargin}\r\n bottomMargin={bottomMargin}\r\n truncateBy={truncateBy}\r\n showLabels={showLabels}\r\n showValues={showValues}\r\n backgroundColor={backgroundColor}\r\n suffix={suffix}\r\n prefix={prefix}\r\n height={height}\r\n width={width}\r\n footNote={footNote}\r\n colorDomain={colorDomain}\r\n colorLegendTitle={colorLegendTitle}\r\n padding={padding}\r\n tooltip={tooltip}\r\n onSeriesMouseOver={onSeriesMouseOver}\r\n relativeHeight={relativeHeight}\r\n refValues={refValues}\r\n graphID={graphID}\r\n maxValue={maxValue}\r\n onSeriesMouseClick={onSeriesMouseClick}\r\n graphDownload={graphDownload}\r\n dataDownload={dataDownload}\r\n language={language}\r\n theme={theme}\r\n labelOrder={labelOrder}\r\n minHeight={minHeight}\r\n maxBarThickness={maxBarThickness}\r\n sortParameter={sortParameter}\r\n sortData={sortData}\r\n maxNumberOfBars={maxNumberOfBars}\r\n minBarThickness={minBarThickness}\r\n ariaLabel={ariaLabel}\r\n resetSelectionOnDoubleClick={resetSelectionOnDoubleClick}\r\n styles={styles}\r\n detailsOnClick={detailsOnClick}\r\n barAxisTitle={barAxisTitle}\r\n noOfTicks={noOfTicks}\r\n valueColor={valueColor}\r\n classNames={classNames}\r\n filterNA={filterNA}\r\n animate={animate}\r\n precision={precision}\r\n customLayers={customLayers}\r\n showColorScale={showColorScale}\r\n timeline={timeline}\r\n naLabel={naLabel}\r\n />\r\n );\r\n}\r\n"],"names":["Graph","props","data","barColor","suffix","prefix","barPadding","showValues","showTicks","leftMargin","truncateBy","width","height","colorDomain","rightMargin","topMargin","bottomMargin","showLabels","tooltip","onSeriesMouseOver","refValues","selectedColor","highlightedDataPoints","maxValue","minValue","onSeriesMouseClick","labelOrder","rtl","maxBarThickness","minBarThickness","resetSelectionOnDoubleClick","detailsOnClick","barAxisTitle","valueColor","noOfTicks","styles","classNames","animate","dimmedOpacity","precision","customLayers","naLabel","svgRef","useRef","isInView","useInView","mouseOverData","setMouseOverData","useState","mouseClickData","setMouseClickData","eventX","setEventX","eventY","setEventY","margin","graphWidth","graphHeight","dataWithId","d","i","x","scaleLinear","barOrder","y","scaleBand","xTicks","jsxs","Fragment","jsx","motion","XTicksAndGridLines","AxisTitle","AnimatePresence","checkIfNullOrUndefined","event","isEqual","el","Colors","YAxesLabels","cn","Axis","RefLineX","Tooltip","Modal","string2HTML","HorizontalBarGraph","graphTitle","colors","sources","graphDescription","footNote","colorLegendTitle","padding","backgroundColor","relativeHeight","showColorScale","graphID","graphDownload","dataDownload","sortData","language","showNAColor","minHeight","theme","maxNumberOfBars","ariaLabel","filterNA","timeline","svgWidth","setSvgWidth","svgHeight","setSvgHeight","play","setPlay","uniqDatesSorted","sort","uniqBy","parse","b","ascending","index","setIndex","setSelectedColor","graphDiv","graphParentDiv","useEffect","resizeObserver","entries","interval","markObj","getSliderMarks","GraphHeader","Pause","Play","SliderUI","nextValue","EmptyState","ColorLegendWithMouseOver","sortBy","ensureCompleteDataForBarChart","format","_d","GraphFooter","barColors","subBarScale","j","numberFormattingFunction","HorizontalGroupedBarGraph","sortParameter","a","orderBy","ensureCompleteDataForStackedBarChart","item","sum","l","element","k","getTextColorBasedOnBgColor","HorizontalStackedBarGraph","yTicks","YTicksAndGridLines","_i","XAxesLabels","RefLineY","VerticalBarGraph","VerticalGroupedBarGraph","VerticalStackedBarGraph","SimpleBarGraph","orientation","GroupedBarGraph","StackedBarGraph"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"BarGraph.js","sources":["../src/Components/Graphs/BarGraph/Horizontal/BarGraph/Graph.tsx","../src/Components/Graphs/BarGraph/Horizontal/BarGraph/index.tsx","../src/Components/Graphs/BarGraph/Horizontal/GroupedBarGraph/Graph.tsx","../src/Components/Graphs/BarGraph/Horizontal/GroupedBarGraph/index.tsx","../src/Components/Graphs/BarGraph/Horizontal/StackedBarGraph/Graph.tsx","../src/Components/Graphs/BarGraph/Horizontal/StackedBarGraph/index.tsx","../src/Components/Graphs/BarGraph/Vertical/BarGraph/Graph.tsx","../src/Components/Graphs/BarGraph/Vertical/BarGraph/index.tsx","../src/Components/Graphs/BarGraph/Vertical/GroupedBarGraph/Graph.tsx","../src/Components/Graphs/BarGraph/Vertical/GroupedBarGraph/index.tsx","../src/Components/Graphs/BarGraph/Vertical/StackedBarGraph/Graph.tsx","../src/Components/Graphs/BarGraph/Vertical/StackedBarGraph/index.tsx","../src/Components/Graphs/BarGraph/index.tsx"],"sourcesContent":["import isEqual from 'fast-deep-equal';\r\nimport { scaleLinear, scaleBand } from 'd3-scale';\r\nimport { useRef, useState } from 'react';\r\nimport { cn } from '@undp/design-system-react/cn';\r\nimport { Modal } from '@undp/design-system-react/Modal';\r\nimport { AnimatePresence, motion, useInView } from 'motion/react';\r\n\r\nimport {\r\n AnimateDataType,\r\n BarGraphDataType,\r\n ClassNameObject,\r\n CustomLayerDataType,\r\n ReferenceDataType,\r\n StyleObject,\r\n} from '@/Types';\r\nimport { numberFormattingFunction } from '@/Utils/numberFormattingFunction';\r\nimport { Tooltip } from '@/Components/Elements/Tooltip';\r\nimport { checkIfNullOrUndefined } from '@/Utils/checkIfNullOrUndefined';\r\nimport { Colors } from '@/Components/ColorPalette';\r\nimport { string2HTML } from '@/Utils/string2HTML';\r\nimport { XTicksAndGridLines } from '@/Components/Elements/Axes/XTicksAndGridLines';\r\nimport { YAxesLabels } from '@/Components/Elements/Axes/YAxesLabels';\r\nimport { AxisTitle } from '@/Components/Elements/Axes/AxisTitle';\r\nimport { Axis } from '@/Components/Elements/Axes/Axis';\r\nimport { RefLineX } from '@/Components/Elements/ReferenceLine';\r\n\r\ninterface Props {\r\n data: BarGraphDataType[];\r\n barColor: string[];\r\n colorDomain: string[];\r\n suffix: string;\r\n prefix: string;\r\n barPadding: number;\r\n showValues: boolean;\r\n showTicks: boolean;\r\n leftMargin: number;\r\n rightMargin: number;\r\n topMargin: number;\r\n bottomMargin: number;\r\n showLabels: boolean;\r\n truncateBy: number;\r\n width: number;\r\n height: number;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n tooltip?: string | ((_d: any) => React.ReactNode);\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseOver?: (_d: any) => void;\r\n refValues?: ReferenceDataType[];\r\n selectedColor?: string;\r\n maxValue: number;\r\n minValue: number;\r\n highlightedDataPoints: (string | number)[];\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseClick?: (_d: any) => void;\r\n labelOrder?: string[];\r\n rtl: boolean;\r\n maxBarThickness?: number;\r\n minBarThickness?: number;\r\n resetSelectionOnDoubleClick: boolean;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n detailsOnClick?: string | ((_d: any) => React.ReactNode);\r\n barAxisTitle?: string;\r\n noOfTicks: number;\r\n valueColor?: string;\r\n styles?: StyleObject;\r\n classNames?: ClassNameObject;\r\n animate: AnimateDataType;\r\n dimmedOpacity: number;\r\n precision: number;\r\n customLayers: CustomLayerDataType[];\r\n naLabel: string;\r\n}\r\n\r\nexport function Graph(props: Props) {\r\n const {\r\n data,\r\n barColor,\r\n suffix,\r\n prefix,\r\n barPadding,\r\n showValues,\r\n showTicks,\r\n leftMargin,\r\n truncateBy,\r\n width,\r\n height,\r\n colorDomain,\r\n rightMargin,\r\n topMargin,\r\n bottomMargin,\r\n showLabels,\r\n tooltip,\r\n onSeriesMouseOver,\r\n refValues,\r\n selectedColor,\r\n highlightedDataPoints,\r\n maxValue,\r\n minValue,\r\n onSeriesMouseClick,\r\n labelOrder,\r\n rtl,\r\n maxBarThickness,\r\n minBarThickness,\r\n resetSelectionOnDoubleClick,\r\n detailsOnClick,\r\n barAxisTitle,\r\n valueColor,\r\n noOfTicks,\r\n styles,\r\n classNames,\r\n animate,\r\n dimmedOpacity,\r\n precision,\r\n customLayers,\r\n naLabel,\r\n } = props;\r\n const svgRef = useRef(null);\r\n const isInView = useInView(svgRef, {\r\n once: animate.once,\r\n amount: animate.amount,\r\n });\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const [mouseOverData, setMouseOverData] = useState<any>(undefined);\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const [mouseClickData, setMouseClickData] = useState<any>(undefined);\r\n const [eventX, setEventX] = useState<number | undefined>(undefined);\r\n const [eventY, setEventY] = useState<number | undefined>(undefined);\r\n const margin = {\r\n top: barAxisTitle ? topMargin + 25 : topMargin,\r\n bottom: bottomMargin,\r\n left: leftMargin,\r\n right: rightMargin,\r\n };\r\n const graphWidth = width - margin.left - margin.right;\r\n const graphHeight = height - margin.top - margin.bottom;\r\n\r\n const dataWithId = data.map((d, i) => ({\r\n ...d,\r\n id: labelOrder ? `${d.label}` : `${i}`,\r\n }));\r\n const x = scaleLinear().domain([minValue, maxValue]).range([0, graphWidth]).nice();\r\n const barOrder = labelOrder || dataWithId.map(d => `${d.id}`);\r\n const y = scaleBand()\r\n .domain(barOrder)\r\n .range([\r\n 0,\r\n minBarThickness\r\n ? Math.max(graphHeight, minBarThickness * barOrder.length)\r\n : maxBarThickness\r\n ? Math.min(graphHeight, maxBarThickness * barOrder.length)\r\n : graphHeight,\r\n ])\r\n .paddingInner(barPadding);\r\n const xTicks = x.ticks(noOfTicks);\r\n\r\n return (\r\n <>\r\n <motion.svg\r\n ref={svgRef}\r\n width={`${width}px`}\r\n height={`${height}px`}\r\n viewBox={`0 0 ${width} ${height}`}\r\n direction='ltr'\r\n >\r\n <g transform={`translate(${margin.left},${margin.top})`}>\r\n {showTicks ? (\r\n <XTicksAndGridLines\r\n values={xTicks.filter(d => d !== 0)}\r\n x={xTicks.filter(d => d !== 0).map(d => x(d))}\r\n y1={0 - topMargin}\r\n y2={graphHeight + margin.bottom}\r\n styles={{\r\n gridLines: styles?.xAxis?.gridLines,\r\n labels: styles?.xAxis?.labels,\r\n }}\r\n classNames={{\r\n gridLines: classNames?.xAxis?.gridLines,\r\n labels: classNames?.xAxis?.labels,\r\n }}\r\n suffix={suffix}\r\n prefix={prefix}\r\n labelType='secondary'\r\n showGridLines\r\n precision={precision}\r\n />\r\n ) : null}\r\n <AxisTitle\r\n x={graphWidth / 2}\r\n y={0 - margin.top + 15}\r\n style={styles?.xAxis?.title}\r\n className={classNames?.xAxis?.title}\r\n text={barAxisTitle}\r\n />\r\n {customLayers.filter(d => d.position === 'before').map(d => d.layer)}\r\n <AnimatePresence>\r\n {dataWithId.map(d =>\r\n !checkIfNullOrUndefined(y(d.id)) ? (\r\n <motion.g\r\n className='undp-viz-g-with-hover'\r\n key={d.label}\r\n variants={{\r\n initial: {\r\n opacity: selectedColor\r\n ? d.color\r\n ? barColor[colorDomain.indexOf(d.color)] === selectedColor\r\n ? 1\r\n : dimmedOpacity\r\n : dimmedOpacity\r\n : highlightedDataPoints.length !== 0\r\n ? highlightedDataPoints.indexOf(d.label) !== -1\r\n ? 0.85\r\n : dimmedOpacity\r\n : 0.85,\r\n },\r\n whileInView: {\r\n opacity: selectedColor\r\n ? d.color\r\n ? barColor[colorDomain.indexOf(d.color)] === selectedColor\r\n ? 1\r\n : dimmedOpacity\r\n : dimmedOpacity\r\n : highlightedDataPoints.length !== 0\r\n ? highlightedDataPoints.indexOf(d.label) !== -1\r\n ? 0.85\r\n : dimmedOpacity\r\n : 0.85,\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n onMouseEnter={event => {\r\n setMouseOverData(d);\r\n setEventY(event.clientY);\r\n setEventX(event.clientX);\r\n onSeriesMouseOver?.(d);\r\n }}\r\n onClick={() => {\r\n if (onSeriesMouseClick || detailsOnClick) {\r\n if (isEqual(mouseClickData, d) && resetSelectionOnDoubleClick) {\r\n setMouseClickData(undefined);\r\n onSeriesMouseClick?.(undefined);\r\n } else {\r\n setMouseClickData(d);\r\n onSeriesMouseClick?.(d);\r\n }\r\n }\r\n }}\r\n onMouseMove={event => {\r\n setMouseOverData(d);\r\n setEventY(event.clientY);\r\n setEventX(event.clientX);\r\n }}\r\n onMouseLeave={() => {\r\n setMouseOverData(undefined);\r\n setEventX(undefined);\r\n setEventY(undefined);\r\n onSeriesMouseOver?.(undefined);\r\n }}\r\n >\r\n {d.size ? (\r\n <motion.rect\r\n variants={{\r\n initial: {\r\n width: 0,\r\n x: x(0),\r\n y: y(`${d.id}`),\r\n fill:\r\n data.filter(el => el.color).length === 0\r\n ? barColor[0]\r\n : !d.color\r\n ? Colors.gray\r\n : barColor[colorDomain.indexOf(d.color)],\r\n },\r\n whileInView: {\r\n width: d.size >= 0 ? x(d.size) - x(0) : x(0) - x(d.size),\r\n x: d.size >= 0 ? x(0) : x(d.size),\r\n y: y(`${d.id}`),\r\n fill:\r\n data.filter(el => el.color).length === 0\r\n ? barColor[0]\r\n : !d.color\r\n ? Colors.gray\r\n : barColor[colorDomain.indexOf(d.color)],\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n exit={{\r\n width: 0,\r\n x: x(0),\r\n transition: { duration: animate.duration },\r\n }}\r\n height={y.bandwidth()}\r\n />\r\n ) : null}\r\n {showLabels ? (\r\n <YAxesLabels\r\n value={\r\n `${d.label}`.length < truncateBy\r\n ? `${d.label}`\r\n : `${`${d.label}`.substring(0, truncateBy)}...`\r\n }\r\n y={y(d.id) || 0}\r\n x={(d.size || 0) < 0 ? x(0) : 0 - margin.left}\r\n width={(d.size || 0) < 0 ? width - x(0) : x(0) + margin.left}\r\n height={y.bandwidth()}\r\n alignment={d.size ? (d.size < 0 ? 'left' : 'right') : 'right'}\r\n style={styles?.yAxis?.labels}\r\n className={classNames?.yAxis?.labels}\r\n animate={animate}\r\n isInView={isInView}\r\n />\r\n ) : null}\r\n {showValues ? (\r\n <motion.text\r\n style={{\r\n textAnchor: d.size ? (d.size < 0 ? 'end' : 'start') : 'start',\r\n ...(styles?.graphObjectValues || {}),\r\n }}\r\n className={cn(\r\n 'graph-value text-sm',\r\n !valueColor && barColor.length > 1\r\n ? ' fill-primary-gray-600 dark:fill-primary-gray-300'\r\n : '',\r\n classNames?.graphObjectValues,\r\n )}\r\n dx={d.size ? (d.size < 0 ? -5 : 5) : 5}\r\n dy='0.33em'\r\n variants={{\r\n initial: {\r\n x: x(0),\r\n y: (y(`${d.id}`) as number) + y.bandwidth() / 2,\r\n opacity: 0,\r\n fill: valueColor\r\n ? valueColor\r\n : data.filter(el => el.color).length === 0\r\n ? barColor[0]\r\n : !d.color\r\n ? Colors.gray\r\n : barColor[colorDomain.indexOf(d.color)],\r\n },\r\n whileInView: {\r\n x: d.size ? x(d.size) : x(0),\r\n opacity: 1,\r\n y: (y(`${d.id}`) as number) + y.bandwidth() / 2,\r\n fill: valueColor\r\n ? valueColor\r\n : data.filter(el => el.color).length === 0\r\n ? barColor[0]\r\n : !d.color\r\n ? Colors.gray\r\n : barColor[colorDomain.indexOf(d.color)],\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n exit={{\r\n opacity: 0,\r\n transition: { duration: animate.duration },\r\n }}\r\n >\r\n {numberFormattingFunction(d.size, naLabel, precision, prefix, suffix)}\r\n </motion.text>\r\n ) : null}\r\n </motion.g>\r\n ) : null,\r\n )}\r\n <Axis\r\n x1={x(minValue < 0 ? 0 : minValue)}\r\n x2={x(minValue < 0 ? 0 : minValue)}\r\n y1={-2.5}\r\n y2={graphHeight + margin.bottom}\r\n classNames={{ axis: classNames?.yAxis?.axis }}\r\n styles={{ axis: styles?.yAxis?.axis }}\r\n />\r\n {refValues ? (\r\n <>\r\n {refValues.map((el, i) => (\r\n <RefLineX\r\n key={i}\r\n text={el.text}\r\n color={el.color}\r\n x={x(el.value as number)}\r\n y1={0 - margin.top}\r\n y2={graphHeight + margin.bottom}\r\n textSide={x(el.value as number) > graphWidth * 0.75 || rtl ? 'left' : 'right'}\r\n classNames={el.classNames}\r\n styles={el.styles}\r\n animate={animate}\r\n isInView={isInView}\r\n />\r\n ))}\r\n </>\r\n ) : null}\r\n </AnimatePresence>\r\n {customLayers.filter(d => d.position === 'after').map(d => d.layer)}\r\n </g>\r\n </motion.svg>\r\n {mouseOverData && tooltip && eventX && eventY ? (\r\n <Tooltip\r\n data={mouseOverData}\r\n body={tooltip}\r\n xPos={eventX}\r\n yPos={eventY}\r\n backgroundStyle={styles?.tooltip}\r\n className={classNames?.tooltip}\r\n />\r\n ) : null}\r\n {detailsOnClick && mouseClickData !== undefined ? (\r\n <Modal\r\n open={mouseClickData !== undefined}\r\n onClose={() => {\r\n setMouseClickData(undefined);\r\n }}\r\n >\r\n <div\r\n className='graph-modal-content m-0'\r\n dangerouslySetInnerHTML={\r\n typeof detailsOnClick === 'string'\r\n ? { __html: string2HTML(detailsOnClick, mouseClickData) }\r\n : undefined\r\n }\r\n >\r\n {typeof detailsOnClick === 'function' ? detailsOnClick(mouseClickData) : null}\r\n </div>\r\n </Modal>\r\n ) : null}\r\n </>\r\n );\r\n}\r\n","import { useState, useRef, useEffect } from 'react';\r\nimport { format } from 'date-fns/format';\r\nimport { parse } from 'date-fns/parse';\r\nimport { cn } from '@undp/design-system-react/cn';\r\nimport { SliderUI } from '@undp/design-system-react/SliderUI';\r\nimport { ascending, sort } from 'd3-array';\r\nimport orderBy from 'lodash.orderby';\r\n\r\nimport { Graph } from './Graph';\r\n\r\nimport {\r\n BarGraphDataType,\r\n Languages,\r\n ReferenceDataType,\r\n SourcesDataType,\r\n StyleObject,\r\n ClassNameObject,\r\n CustomLayerDataType,\r\n AnimateDataType,\r\n TimelineDataType,\r\n} from '@/Types';\r\nimport { GraphFooter } from '@/Components/Elements/GraphFooter';\r\nimport { GraphHeader } from '@/Components/Elements/GraphHeader';\r\nimport { ColorLegendWithMouseOver } from '@/Components/Elements/ColorLegendWithMouseOver';\r\nimport { Colors } from '@/Components/ColorPalette';\r\nimport { EmptyState } from '@/Components/Elements/EmptyState';\r\nimport { checkIfNullOrUndefined } from '@/Utils/checkIfNullOrUndefined';\r\nimport { Pause, Play } from '@/Components/Icons';\r\nimport { getSliderMarks } from '@/Utils/getSliderMarks';\r\nimport { ensureCompleteDataForBarChart } from '@/Utils/ensureCompleteData';\r\nimport { uniqBy } from '@/Utils/uniqBy';\r\n\r\ninterface Props {\r\n data: BarGraphDataType[];\r\n colors?: string | string[];\r\n labelOrder?: string[];\r\n graphTitle?: string | React.ReactNode;\r\n graphDescription?: string | React.ReactNode;\r\n footNote?: string | React.ReactNode;\r\n width?: number;\r\n height?: number;\r\n minHeight?: number;\r\n suffix?: string;\r\n prefix?: string;\r\n sources?: SourcesDataType[];\r\n barPadding?: number;\r\n showValues?: boolean;\r\n showTicks?: boolean;\r\n leftMargin?: number;\r\n rightMargin?: number;\r\n truncateBy?: number;\r\n colorDomain?: string[];\r\n colorLegendTitle?: string;\r\n backgroundColor?: string | boolean;\r\n padding?: string;\r\n topMargin?: number;\r\n bottomMargin?: number;\r\n relativeHeight?: number;\r\n showLabels?: boolean;\r\n showColorScale?: boolean;\r\n maxValue?: number;\r\n minValue?: number;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n tooltip?: string | ((_d: any) => React.ReactNode);\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseOver?: (_d: any) => void;\r\n refValues?: ReferenceDataType[];\r\n graphID?: string;\r\n highlightedDataPoints?: (string | number)[];\r\n dimmedOpacity?: number;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseClick?: (_d: any) => void;\r\n graphDownload?: boolean;\r\n dataDownload?: boolean;\r\n sortData?: 'asc' | 'desc';\r\n language?: Languages;\r\n showNAColor?: boolean;\r\n theme?: 'light' | 'dark';\r\n maxBarThickness?: number;\r\n maxNumberOfBars?: number;\r\n minBarThickness?: number;\r\n ariaLabel?: string;\r\n resetSelectionOnDoubleClick?: boolean;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n detailsOnClick?: string | ((_d: any) => React.ReactNode);\r\n barAxisTitle?: string;\r\n noOfTicks?: number;\r\n valueColor?: string;\r\n styles?: StyleObject;\r\n classNames?: ClassNameObject;\r\n filterNA?: boolean;\r\n animate?: boolean | AnimateDataType;\r\n precision?: number;\r\n customLayers?: CustomLayerDataType[];\r\n timeline?: TimelineDataType;\r\n naLabel?: string;\r\n}\r\n\r\nexport function HorizontalBarGraph(props: Props) {\r\n const {\r\n data,\r\n graphTitle,\r\n colors,\r\n suffix = '',\r\n sources,\r\n prefix = '',\r\n graphDescription,\r\n barPadding = 0.25,\r\n showValues = true,\r\n showTicks = true,\r\n leftMargin = 100,\r\n rightMargin = 40,\r\n truncateBy = 999,\r\n height,\r\n width,\r\n footNote,\r\n colorDomain,\r\n colorLegendTitle,\r\n highlightedDataPoints = [],\r\n padding,\r\n backgroundColor = false,\r\n topMargin = 25,\r\n bottomMargin = 10,\r\n showLabels = true,\r\n relativeHeight,\r\n tooltip,\r\n onSeriesMouseOver,\r\n refValues,\r\n showColorScale = true,\r\n graphID,\r\n maxValue,\r\n minValue,\r\n onSeriesMouseClick,\r\n graphDownload = false,\r\n dataDownload = false,\r\n sortData,\r\n labelOrder,\r\n language = 'en',\r\n showNAColor = true,\r\n minHeight = 0,\r\n theme = 'light',\r\n maxBarThickness,\r\n maxNumberOfBars,\r\n minBarThickness,\r\n ariaLabel,\r\n resetSelectionOnDoubleClick = true,\r\n detailsOnClick,\r\n barAxisTitle,\r\n noOfTicks = 5,\r\n valueColor,\r\n styles,\r\n classNames,\r\n filterNA = true,\r\n animate = false,\r\n dimmedOpacity = 0.3,\r\n precision = 2,\r\n customLayers = [],\r\n timeline = { enabled: false, autoplay: false, showOnlyActiveDate: true },\r\n naLabel = 'NA',\r\n } = props;\r\n const [svgWidth, setSvgWidth] = useState(0);\r\n const [svgHeight, setSvgHeight] = useState(0);\r\n const [play, setPlay] = useState(timeline.autoplay);\r\n const uniqDatesSorted = sort(\r\n uniqBy(data, 'date', true).map(d =>\r\n parse(`${d}`, timeline.dateFormat || 'yyyy', new Date()).getTime(),\r\n ),\r\n (a, b) => ascending(a, b),\r\n );\r\n const [index, setIndex] = useState(timeline.autoplay ? 0 : uniqDatesSorted.length - 1);\r\n const [selectedColor, setSelectedColor] = useState<string | undefined>(undefined);\r\n\r\n const graphDiv = useRef<HTMLDivElement>(null);\r\n const graphParentDiv = useRef<HTMLDivElement>(null);\r\n useEffect(() => {\r\n const resizeObserver = new ResizeObserver(entries => {\r\n setSvgWidth(width || entries[0].target.clientWidth || 620);\r\n setSvgHeight(height || entries[0].target.clientHeight || 480);\r\n });\r\n if (graphDiv.current) {\r\n setSvgHeight(graphDiv.current.clientHeight || 480);\r\n setSvgWidth(graphDiv.current.clientWidth || 620);\r\n if (!width) resizeObserver.observe(graphDiv.current);\r\n }\r\n return () => resizeObserver.disconnect();\r\n }, [width, height]);\r\n\r\n useEffect(() => {\r\n const interval = setInterval(\r\n () => {\r\n setIndex(i => (i < uniqDatesSorted.length - 1 ? i + 1 : 0));\r\n },\r\n (timeline.speed || 2) * 1000,\r\n );\r\n if (!play) clearInterval(interval);\r\n return () => clearInterval(interval);\r\n }, [uniqDatesSorted, play, timeline.speed]);\r\n\r\n const markObj = getSliderMarks(\r\n uniqDatesSorted,\r\n index,\r\n timeline.showOnlyActiveDate,\r\n timeline.dateFormat || 'yyyy',\r\n );\r\n\r\n return (\r\n <div\r\n className={`${theme || 'light'} flex ${width ? 'w-fit grow-0' : 'w-full grow'}`}\r\n dir={language === 'he' || language === 'ar' ? 'rtl' : undefined}\r\n >\r\n <div\r\n className={cn(\r\n `${\r\n !backgroundColor\r\n ? 'bg-transparent '\r\n : backgroundColor === true\r\n ? 'bg-primary-gray-200 dark:bg-primary-gray-650 '\r\n : ''\r\n }ml-auto mr-auto flex flex-col grow h-inherit ${language || 'en'}`,\r\n width ? 'w-fit' : 'w-full',\r\n classNames?.graphContainer,\r\n )}\r\n style={{\r\n ...(styles?.graphContainer || {}),\r\n ...(backgroundColor && backgroundColor !== true ? { backgroundColor } : {}),\r\n }}\r\n id={graphID}\r\n ref={graphParentDiv}\r\n aria-label={\r\n ariaLabel ||\r\n `${graphTitle ? `The graph shows ${graphTitle}. ` : ''}This is a bar chart. ${\r\n graphDescription ? ` ${graphDescription}` : ''\r\n }`\r\n }\r\n >\r\n <div\r\n className='flex grow'\r\n style={{ padding: backgroundColor ? padding || '1rem' : padding || 0 }}\r\n >\r\n <div className='flex flex-col w-full gap-4 grow justify-between'>\r\n {graphTitle || graphDescription || graphDownload || dataDownload ? (\r\n <GraphHeader\r\n styles={{\r\n title: styles?.title,\r\n description: styles?.description,\r\n }}\r\n classNames={{\r\n title: classNames?.title,\r\n description: classNames?.description,\r\n }}\r\n graphTitle={graphTitle}\r\n graphDescription={graphDescription}\r\n width={width}\r\n graphDownload={graphDownload ? graphParentDiv.current : undefined}\r\n dataDownload={\r\n dataDownload\r\n ? data.map(d => d.data).filter(d => d !== undefined).length > 0\r\n ? data.map(d => d.data).filter(d => d !== undefined)\r\n : data.filter(d => d !== undefined)\r\n : null\r\n }\r\n />\r\n ) : null}\r\n {timeline.enabled && uniqDatesSorted.length > 0 && markObj ? (\r\n <div className='flex gap-6 items-center' dir='ltr'>\r\n <button\r\n type='button'\r\n onClick={() => {\r\n setPlay(!play);\r\n }}\r\n className='p-0 border-0 cursor-pointer bg-transparent'\r\n aria-label={play ? 'Click to pause animation' : 'Click to play animation'}\r\n >\r\n {play ? <Pause /> : <Play />}\r\n </button>\r\n <SliderUI\r\n min={uniqDatesSorted[0]}\r\n max={uniqDatesSorted[uniqDatesSorted.length - 1]}\r\n marks={markObj}\r\n step={null}\r\n defaultValue={uniqDatesSorted[uniqDatesSorted.length - 1]}\r\n value={uniqDatesSorted[index]}\r\n onChangeComplete={nextValue => {\r\n setIndex(uniqDatesSorted.indexOf(nextValue as number));\r\n }}\r\n onChange={nextValue => {\r\n setIndex(uniqDatesSorted.indexOf(nextValue as number));\r\n }}\r\n aria-label='Time slider. Use arrow keys to adjust selected time period.'\r\n />\r\n </div>\r\n ) : null}\r\n <div className='grow flex flex-col justify-center gap-3 w-full'>\r\n {data.length === 0 ? (\r\n <EmptyState />\r\n ) : (\r\n <>\r\n {showColorScale && data.filter(el => el.color).length !== 0 ? (\r\n <ColorLegendWithMouseOver\r\n width={width}\r\n colorLegendTitle={colorLegendTitle}\r\n colors={\r\n (colors as string[] | undefined) || Colors[theme].categoricalColors.colors\r\n }\r\n colorDomain={\r\n colorDomain || (uniqBy(data, 'color', true) as (string | number)[])\r\n }\r\n setSelectedColor={setSelectedColor}\r\n showNAColor={showNAColor}\r\n />\r\n ) : null}\r\n <div\r\n className='flex grow flex-col justify-center w-full leading-0'\r\n ref={graphDiv}\r\n aria-label='Graph area'\r\n >\r\n {(width || svgWidth) && (height || svgHeight) ? (\r\n <Graph\r\n data={\r\n sortData\r\n ? orderBy(\r\n ensureCompleteDataForBarChart(data, timeline.dateFormat || 'yyyy')\r\n .filter(d =>\r\n timeline.enabled\r\n ? d.date ===\r\n format(\r\n new Date(uniqDatesSorted[index]),\r\n timeline.dateFormat || 'yyyy',\r\n )\r\n : d,\r\n )\r\n .filter(d => (filterNA ? !checkIfNullOrUndefined(d.size) : d)),\r\n [\r\n d =>\r\n d.size === undefined\r\n ? sortData === 'asc'\r\n ? Infinity\r\n : -Infinity\r\n : d.size,\r\n ],\r\n [sortData],\r\n ).filter((_d, i) => (maxNumberOfBars ? i < maxNumberOfBars : true))\r\n : ensureCompleteDataForBarChart(data, timeline.dateFormat || 'yyyy')\r\n .filter(d =>\r\n timeline.enabled\r\n ? d.date ===\r\n format(\r\n new Date(uniqDatesSorted[index]),\r\n timeline.dateFormat || 'yyyy',\r\n )\r\n : d,\r\n )\r\n .filter(d => (filterNA ? !checkIfNullOrUndefined(d.size) : d))\r\n .filter((_d, i) => (maxNumberOfBars ? i < maxNumberOfBars : true))\r\n }\r\n barColor={\r\n data.filter(el => el.color).length === 0\r\n ? colors\r\n ? [colors as string]\r\n : [Colors.primaryColors['blue-600']]\r\n : (colors as string[] | undefined) ||\r\n Colors[theme].categoricalColors.colors\r\n }\r\n colorDomain={\r\n data.filter(el => el.color).length === 0\r\n ? []\r\n : colorDomain || (uniqBy(data, 'color', true) as string[])\r\n }\r\n width={width || svgWidth}\r\n selectedColor={selectedColor}\r\n height={Math.max(\r\n minHeight,\r\n height ||\r\n (relativeHeight\r\n ? minHeight\r\n ? (width || svgWidth) * relativeHeight > minHeight\r\n ? (width || svgWidth) * relativeHeight\r\n : minHeight\r\n : (width || svgWidth) * relativeHeight\r\n : svgHeight),\r\n )}\r\n suffix={suffix}\r\n prefix={prefix}\r\n barPadding={barPadding}\r\n showValues={showValues}\r\n showTicks={showTicks}\r\n leftMargin={leftMargin}\r\n rightMargin={rightMargin}\r\n topMargin={topMargin}\r\n bottomMargin={bottomMargin}\r\n truncateBy={truncateBy}\r\n showLabels={showLabels}\r\n tooltip={tooltip}\r\n onSeriesMouseOver={onSeriesMouseOver}\r\n refValues={refValues}\r\n maxValue={\r\n !checkIfNullOrUndefined(maxValue)\r\n ? (maxValue as number)\r\n : Math.max(\r\n ...data\r\n .filter(d => !checkIfNullOrUndefined(d.size))\r\n .map(d => d.size as number),\r\n ) < 0\r\n ? 0\r\n : Math.max(\r\n ...data\r\n .filter(d => !checkIfNullOrUndefined(d.size))\r\n .map(d => d.size as number),\r\n )\r\n }\r\n minValue={\r\n !checkIfNullOrUndefined(minValue)\r\n ? (minValue as number)\r\n : Math.min(\r\n ...data\r\n .filter(d => !checkIfNullOrUndefined(d.size))\r\n .map(d => d.size as number),\r\n ) >= 0\r\n ? 0\r\n : Math.min(\r\n ...data\r\n .filter(d => !checkIfNullOrUndefined(d.size))\r\n .map(d => d.size as number),\r\n )\r\n }\r\n highlightedDataPoints={highlightedDataPoints}\r\n onSeriesMouseClick={onSeriesMouseClick}\r\n labelOrder={labelOrder}\r\n rtl={language === 'he' || language === 'ar'}\r\n maxBarThickness={maxBarThickness}\r\n minBarThickness={minBarThickness}\r\n resetSelectionOnDoubleClick={resetSelectionOnDoubleClick}\r\n detailsOnClick={detailsOnClick}\r\n barAxisTitle={barAxisTitle}\r\n noOfTicks={noOfTicks}\r\n valueColor={valueColor}\r\n classNames={classNames}\r\n styles={styles}\r\n animate={\r\n animate === true\r\n ? { duration: 0.5, once: true, amount: 0.5 }\r\n : animate || { duration: 0, once: true, amount: 0 }\r\n }\r\n dimmedOpacity={dimmedOpacity}\r\n precision={precision}\r\n customLayers={customLayers}\r\n naLabel={naLabel}\r\n />\r\n ) : null}\r\n </div>\r\n </>\r\n )}\r\n </div>\r\n {sources || footNote ? (\r\n <GraphFooter\r\n sources={sources}\r\n footNote={footNote}\r\n width={width}\r\n styles={{ footnote: styles?.footnote, source: styles?.source }}\r\n classNames={{\r\n footnote: classNames?.footnote,\r\n source: classNames?.source,\r\n }}\r\n />\r\n ) : null}\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n );\r\n}\r\n","import isEqual from 'fast-deep-equal';\r\nimport { scaleLinear, scaleBand } from 'd3-scale';\r\nimport { useRef, useState } from 'react';\r\nimport { cn } from '@undp/design-system-react/cn';\r\nimport { Modal } from '@undp/design-system-react/Modal';\r\nimport { AnimatePresence, motion, useInView } from 'motion/react';\r\n\r\nimport {\r\n AnimateDataType,\r\n ClassNameObject,\r\n CustomLayerDataType,\r\n GroupedBarGraphDataType,\r\n ReferenceDataType,\r\n StyleObject,\r\n} from '@/Types';\r\nimport { numberFormattingFunction } from '@/Utils/numberFormattingFunction';\r\nimport { Tooltip } from '@/Components/Elements/Tooltip';\r\nimport { checkIfNullOrUndefined } from '@/Utils/checkIfNullOrUndefined';\r\nimport { string2HTML } from '@/Utils/string2HTML';\r\nimport { YAxesLabels } from '@/Components/Elements/Axes/YAxesLabels';\r\nimport { Axis } from '@/Components/Elements/Axes/Axis';\r\nimport { AxisTitle } from '@/Components/Elements/Axes/AxisTitle';\r\nimport { XTicksAndGridLines } from '@/Components/Elements/Axes/XTicksAndGridLines';\r\nimport { RefLineX } from '@/Components/Elements/ReferenceLine';\r\n\r\ninterface Props {\r\n data: GroupedBarGraphDataType[];\r\n barColors: string[];\r\n barPadding: number;\r\n showTicks: boolean;\r\n leftMargin: number;\r\n rightMargin: number;\r\n topMargin: number;\r\n bottomMargin: number;\r\n truncateBy: number;\r\n showLabels: boolean;\r\n width: number;\r\n suffix: string;\r\n prefix: string;\r\n showValues: boolean;\r\n height: number;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n tooltip?: string | ((_d: any) => React.ReactNode);\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseOver?: (_d: any) => void;\r\n refValues?: ReferenceDataType[];\r\n maxValue: number;\r\n minValue: number;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseClick?: (_d: any) => void;\r\n selectedColor?: string;\r\n rtl: boolean;\r\n labelOrder?: string[];\r\n maxBarThickness?: number;\r\n resetSelectionOnDoubleClick: boolean;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n detailsOnClick?: string | ((_d: any) => React.ReactNode);\r\n barAxisTitle?: string;\r\n noOfTicks: number;\r\n valueColor?: string;\r\n styles?: StyleObject;\r\n classNames?: ClassNameObject;\r\n animate: AnimateDataType;\r\n colorDomain: string[];\r\n precision: number;\r\n customLayers: CustomLayerDataType[];\r\n naLabel: string;\r\n}\r\n\r\nexport function Graph(props: Props) {\r\n const {\r\n data,\r\n barColors,\r\n barPadding,\r\n showTicks,\r\n leftMargin,\r\n truncateBy,\r\n width,\r\n height,\r\n suffix,\r\n prefix,\r\n showValues,\r\n rightMargin,\r\n topMargin,\r\n bottomMargin,\r\n showLabels,\r\n tooltip,\r\n onSeriesMouseOver,\r\n refValues,\r\n maxValue,\r\n minValue,\r\n onSeriesMouseClick,\r\n selectedColor,\r\n rtl,\r\n labelOrder,\r\n maxBarThickness,\r\n resetSelectionOnDoubleClick,\r\n detailsOnClick,\r\n barAxisTitle,\r\n valueColor,\r\n noOfTicks,\r\n styles,\r\n classNames,\r\n animate,\r\n colorDomain,\r\n precision,\r\n customLayers,\r\n naLabel,\r\n } = props;\r\n const svgRef = useRef(null);\r\n const isInView = useInView(svgRef, {\r\n once: animate.once,\r\n amount: animate.amount,\r\n });\r\n const margin = {\r\n top: barAxisTitle ? topMargin + 25 : topMargin,\r\n bottom: bottomMargin,\r\n left: leftMargin,\r\n right: rightMargin,\r\n };\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const [mouseOverData, setMouseOverData] = useState<any>(undefined);\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const [mouseClickData, setMouseClickData] = useState<any>(undefined);\r\n const [eventX, setEventX] = useState<number | undefined>(undefined);\r\n const [eventY, setEventY] = useState<number | undefined>(undefined);\r\n const graphWidth = width - margin.left - margin.right;\r\n const graphHeight = height - margin.top - margin.bottom;\r\n\r\n const dataWithId = data.map((d, i) => ({\r\n ...d,\r\n id: labelOrder ? `${d.label}` : `${i}`,\r\n }));\r\n const barOrder = labelOrder || dataWithId.map(d => `${d.id}`);\r\n\r\n const x = scaleLinear().domain([minValue, maxValue]).range([0, graphWidth]).nice();\r\n const y = scaleBand()\r\n .domain(barOrder)\r\n .range([\r\n 0,\r\n maxBarThickness ? Math.min(graphHeight, maxBarThickness * barOrder.length) : graphHeight,\r\n ])\r\n .paddingInner(barPadding);\r\n const subBarScale = scaleBand()\r\n .domain(data[0].size.map((_d, i) => `${i}`))\r\n .range([0, y.bandwidth()])\r\n .paddingInner(0.1);\r\n const xTicks = x.ticks(noOfTicks);\r\n return (\r\n <>\r\n <motion.svg\r\n ref={svgRef}\r\n width={`${width}px`}\r\n height={`${height}px`}\r\n viewBox={`0 0 ${width} ${height}`}\r\n direction='ltr'\r\n >\r\n <g transform={`translate(${margin.left},${margin.top})`}>\r\n {showTicks ? (\r\n <XTicksAndGridLines\r\n values={xTicks.filter(d => d !== 0)}\r\n x={xTicks.filter(d => d !== 0).map(d => x(d))}\r\n y1={0 - topMargin}\r\n y2={graphHeight + margin.bottom}\r\n styles={{\r\n gridLines: styles?.xAxis?.gridLines,\r\n labels: styles?.xAxis?.labels,\r\n }}\r\n classNames={{\r\n gridLines: classNames?.xAxis?.gridLines,\r\n labels: classNames?.xAxis?.labels,\r\n }}\r\n suffix={suffix}\r\n prefix={prefix}\r\n labelType='secondary'\r\n showGridLines\r\n precision={precision}\r\n />\r\n ) : null}\r\n <AxisTitle\r\n x={graphWidth / 2}\r\n y={0 - margin.top + 15}\r\n style={styles?.xAxis?.title}\r\n className={classNames?.xAxis?.title}\r\n text={barAxisTitle}\r\n />\r\n {customLayers.filter(d => d.position === 'before').map(d => d.layer)}\r\n <AnimatePresence>\r\n {dataWithId.map(d =>\r\n !checkIfNullOrUndefined(y(d.id)) ? (\r\n <motion.g\r\n key={d.label}\r\n variants={{\r\n initial: {\r\n x: 0,\r\n y: y(`${d.id}`),\r\n },\r\n whileInView: {\r\n x: 0,\r\n y: y(`${d.id}`),\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n >\r\n {d.size.map((el, j) => (\r\n <motion.g\r\n className='undp-viz-g-with-hover'\r\n key={`${d.label}-${colorDomain[j] || j}`}\r\n opacity={selectedColor ? (barColors[j] === selectedColor ? 1 : 0.3) : 0.85}\r\n onMouseEnter={event => {\r\n setMouseOverData({ ...d, sizeIndex: j });\r\n setEventY(event.clientY);\r\n setEventX(event.clientX);\r\n onSeriesMouseOver?.({ ...d, sizeIndex: j });\r\n }}\r\n onMouseMove={event => {\r\n setMouseOverData({ ...d, sizeIndex: j });\r\n setEventY(event.clientY);\r\n setEventX(event.clientX);\r\n }}\r\n onMouseLeave={() => {\r\n setMouseOverData(undefined);\r\n setEventX(undefined);\r\n setEventY(undefined);\r\n onSeriesMouseOver?.(undefined);\r\n }}\r\n onClick={() => {\r\n if (onSeriesMouseClick || detailsOnClick) {\r\n if (\r\n isEqual(mouseClickData, { ...d, sizeIndex: j }) &&\r\n resetSelectionOnDoubleClick\r\n ) {\r\n setMouseClickData(undefined);\r\n onSeriesMouseClick?.(undefined);\r\n } else {\r\n setMouseClickData({ ...d, sizeIndex: j });\r\n if (onSeriesMouseClick) onSeriesMouseClick({ ...d, sizeIndex: j });\r\n }\r\n }\r\n }}\r\n >\r\n {!checkIfNullOrUndefined(el) ? (\r\n <motion.rect\r\n y={subBarScale(`${j}`)}\r\n variants={{\r\n initial: {\r\n width: 0,\r\n x: x(0),\r\n fill: barColors[j],\r\n },\r\n whileInView: {\r\n width: !checkIfNullOrUndefined(el)\r\n ? (el as number) >= 0\r\n ? x(el as number) - x(0)\r\n : x(0) - x(el as number)\r\n : 0,\r\n x: (el as number) >= 0 ? x(0) : x(el as number),\r\n fill: barColors[j],\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n exit={{\r\n width: 0,\r\n x: x(0),\r\n transition: { duration: animate.duration },\r\n }}\r\n height={subBarScale.bandwidth()}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n />\r\n ) : null}\r\n {showValues ? (\r\n <motion.text\r\n y={(subBarScale(`${j}`) as number) + subBarScale.bandwidth() / 2}\r\n style={{\r\n fill: valueColor || barColors[j],\r\n textAnchor: el ? (el < 0 ? 'end' : 'start') : 'start',\r\n ...(styles?.graphObjectValues || {}),\r\n }}\r\n className={cn('graph-value text-sm', classNames?.graphObjectValues)}\r\n dx={el ? (el < 0 ? -5 : 5) : 5}\r\n dy='0.33em'\r\n variants={{\r\n initial: { x: x(0), opacity: 0 },\r\n whileInView: {\r\n x: x(el || 0),\r\n opacity: 1,\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n exit={{\r\n opacity: 0,\r\n transition: { duration: animate.duration },\r\n }}\r\n >\r\n {numberFormattingFunction(el, naLabel, precision, prefix, suffix)}\r\n </motion.text>\r\n ) : null}\r\n </motion.g>\r\n ))}\r\n {showLabels ? (\r\n <YAxesLabels\r\n value={\r\n `${d.label}`.length < truncateBy\r\n ? `${d.label}`\r\n : `${`${d.label}`.substring(0, truncateBy)}...`\r\n }\r\n y={0}\r\n x={0 - margin.left}\r\n width={x(minValue < 0 ? 0 : minValue) + margin.left}\r\n height={y.bandwidth()}\r\n style={styles?.yAxis?.labels}\r\n className={classNames?.yAxis?.labels}\r\n animate={animate}\r\n isInView={isInView}\r\n />\r\n ) : null}\r\n </motion.g>\r\n ) : null,\r\n )}\r\n <Axis\r\n x1={x(minValue < 0 ? 0 : minValue)}\r\n x2={x(minValue < 0 ? 0 : minValue)}\r\n y1={-2.5}\r\n y2={graphHeight + margin.bottom}\r\n classNames={{ axis: classNames?.yAxis?.axis }}\r\n styles={{ axis: styles?.yAxis?.axis }}\r\n />\r\n {refValues ? (\r\n <>\r\n {refValues.map((el, i) => (\r\n <RefLineX\r\n key={i}\r\n text={el.text}\r\n color={el.color}\r\n x={x(el.value as number)}\r\n y1={0 - margin.top}\r\n y2={graphHeight + margin.bottom}\r\n textSide={x(el.value as number) > graphWidth * 0.75 || rtl ? 'left' : 'right'}\r\n classNames={el.classNames}\r\n styles={el.styles}\r\n animate={animate}\r\n isInView={isInView}\r\n />\r\n ))}\r\n </>\r\n ) : null}\r\n </AnimatePresence>\r\n {customLayers.filter(d => d.position === 'after').map(d => d.layer)}\r\n </g>\r\n </motion.svg>\r\n {mouseOverData && tooltip && eventX && eventY ? (\r\n <Tooltip\r\n data={mouseOverData}\r\n body={tooltip}\r\n xPos={eventX}\r\n yPos={eventY}\r\n backgroundStyle={styles?.tooltip}\r\n className={classNames?.tooltip}\r\n />\r\n ) : null}\r\n {detailsOnClick && mouseClickData !== undefined ? (\r\n <Modal\r\n open={mouseClickData !== undefined}\r\n onClose={() => {\r\n setMouseClickData(undefined);\r\n }}\r\n >\r\n <div\r\n className='graph-modal-content m-0'\r\n dangerouslySetInnerHTML={\r\n typeof detailsOnClick === 'string'\r\n ? { __html: string2HTML(detailsOnClick, mouseClickData) }\r\n : undefined\r\n }\r\n >\r\n {typeof detailsOnClick === 'function' ? detailsOnClick(mouseClickData) : null}\r\n </div>\r\n </Modal>\r\n ) : null}\r\n </>\r\n );\r\n}\r\n","import { useState, useRef, useEffect } from 'react';\r\nimport { cn } from '@undp/design-system-react/cn';\r\nimport { SliderUI } from '@undp/design-system-react/SliderUI';\r\nimport { format } from 'date-fns/format';\r\nimport { parse } from 'date-fns/parse';\r\nimport { ascending, sort } from 'd3-array';\r\nimport orderBy from 'lodash.orderby';\r\nimport sum from 'lodash.sum';\r\n\r\nimport { Graph } from './Graph';\r\n\r\nimport {\r\n GroupedBarGraphDataType,\r\n Languages,\r\n ReferenceDataType,\r\n SourcesDataType,\r\n StyleObject,\r\n ClassNameObject,\r\n CustomLayerDataType,\r\n AnimateDataType,\r\n TimelineDataType,\r\n} from '@/Types';\r\nimport { GraphHeader } from '@/Components/Elements/GraphHeader';\r\nimport { GraphFooter } from '@/Components/Elements/GraphFooter';\r\nimport { ColorLegendWithMouseOver } from '@/Components/Elements/ColorLegendWithMouseOver';\r\nimport { Colors } from '@/Components/ColorPalette';\r\nimport { EmptyState } from '@/Components/Elements/EmptyState';\r\nimport { checkIfNullOrUndefined } from '@/Utils/checkIfNullOrUndefined';\r\nimport { Pause, Play } from '@/Components/Icons';\r\nimport { getSliderMarks } from '@/Utils/getSliderMarks';\r\nimport { ensureCompleteDataForStackedBarChart } from '@/Utils/ensureCompleteData';\r\nimport { uniqBy } from '@/Utils/uniqBy';\r\n\r\ninterface Props {\r\n data: GroupedBarGraphDataType[];\r\n colors?: string[];\r\n graphTitle?: string | React.ReactNode;\r\n graphDescription?: string | React.ReactNode;\r\n footNote?: string | React.ReactNode;\r\n width?: number;\r\n height?: number;\r\n sources?: SourcesDataType[];\r\n barPadding?: number;\r\n showTicks?: boolean;\r\n truncateBy?: number;\r\n colorDomain: string[];\r\n colorLegendTitle?: string;\r\n suffix?: string;\r\n prefix?: string;\r\n showValues?: boolean;\r\n backgroundColor?: string | boolean;\r\n padding?: string;\r\n leftMargin?: number;\r\n rightMargin?: number;\r\n topMargin?: number;\r\n showLabels?: boolean;\r\n bottomMargin?: number;\r\n relativeHeight?: number;\r\n sortParameter?: number | 'total';\r\n sortData?: 'asc' | 'desc';\r\n showColorScale?: boolean;\r\n minHeight?: number;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n tooltip?: string | ((_d: any) => React.ReactNode);\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseOver?: (_d: any) => void;\r\n refValues?: ReferenceDataType[];\r\n graphID?: string;\r\n maxValue?: number;\r\n minValue?: number;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseClick?: (_d: any) => void;\r\n graphDownload?: boolean;\r\n dataDownload?: boolean;\r\n labelOrder?: string[];\r\n language?: Languages;\r\n theme?: 'light' | 'dark';\r\n maxBarThickness?: number;\r\n ariaLabel?: string;\r\n resetSelectionOnDoubleClick?: boolean;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n detailsOnClick?: string | ((_d: any) => React.ReactNode);\r\n barAxisTitle?: string;\r\n noOfTicks?: number;\r\n valueColor?: string;\r\n styles?: StyleObject;\r\n classNames?: ClassNameObject;\r\n filterNA?: boolean;\r\n animate?: boolean | AnimateDataType;\r\n precision?: number;\r\n customLayers?: CustomLayerDataType[];\r\n timeline?: TimelineDataType;\r\n naLabel?: string;\r\n}\r\n\r\nexport function HorizontalGroupedBarGraph(props: Props) {\r\n const {\r\n data,\r\n graphTitle,\r\n colors = Colors.light.categoricalColors.colors,\r\n sources,\r\n graphDescription,\r\n barPadding = 0.25,\r\n showTicks = true,\r\n truncateBy = 999,\r\n height,\r\n width,\r\n footNote,\r\n colorDomain,\r\n colorLegendTitle,\r\n suffix = '',\r\n prefix = '',\r\n showValues = true,\r\n showColorScale = true,\r\n padding,\r\n backgroundColor = false,\r\n leftMargin = 100,\r\n rightMargin = 40,\r\n topMargin = 25,\r\n bottomMargin = 10,\r\n showLabels = true,\r\n relativeHeight,\r\n tooltip,\r\n onSeriesMouseOver,\r\n refValues,\r\n graphID,\r\n maxValue,\r\n minValue,\r\n onSeriesMouseClick,\r\n graphDownload = false,\r\n dataDownload = false,\r\n language = 'en',\r\n labelOrder,\r\n minHeight = 0,\r\n theme = 'light',\r\n maxBarThickness,\r\n ariaLabel,\r\n resetSelectionOnDoubleClick = true,\r\n detailsOnClick,\r\n barAxisTitle,\r\n noOfTicks = 5,\r\n valueColor,\r\n styles,\r\n classNames,\r\n filterNA = true,\r\n animate = false,\r\n precision = 2,\r\n customLayers = [],\r\n timeline = { enabled: false, autoplay: false, showOnlyActiveDate: true },\r\n naLabel = 'NA',\r\n sortParameter,\r\n sortData,\r\n } = props;\r\n\r\n const [svgWidth, setSvgWidth] = useState(0);\r\n const [svgHeight, setSvgHeight] = useState(0);\r\n const [play, setPlay] = useState(timeline.autoplay);\r\n const uniqDatesSorted = sort(\r\n uniqBy(data, 'date', true).map(d =>\r\n parse(`${d}`, timeline.dateFormat || 'yyyy', new Date()).getTime(),\r\n ),\r\n (a, b) => ascending(a, b),\r\n );\r\n const [index, setIndex] = useState(timeline.autoplay ? 0 : uniqDatesSorted.length - 1);\r\n const [selectedColor, setSelectedColor] = useState<string | undefined>(undefined);\r\n\r\n const graphDiv = useRef<HTMLDivElement>(null);\r\n const graphParentDiv = useRef<HTMLDivElement>(null);\r\n useEffect(() => {\r\n const resizeObserver = new ResizeObserver(entries => {\r\n setSvgWidth(width || entries[0].target.clientWidth || 620);\r\n setSvgHeight(height || entries[0].target.clientHeight || 480);\r\n });\r\n if (graphDiv.current) {\r\n setSvgHeight(graphDiv.current.clientHeight || 480);\r\n setSvgWidth(graphDiv.current.clientWidth || 620);\r\n if (!width) resizeObserver.observe(graphDiv.current);\r\n }\r\n return () => resizeObserver.disconnect();\r\n }, [width, height]);\r\n\r\n useEffect(() => {\r\n const interval = setInterval(\r\n () => {\r\n setIndex(i => (i < uniqDatesSorted.length - 1 ? i + 1 : 0));\r\n },\r\n (timeline.speed || 2) * 1000,\r\n );\r\n if (!play) clearInterval(interval);\r\n return () => clearInterval(interval);\r\n }, [uniqDatesSorted, play, timeline.speed]);\r\n\r\n const markObj = getSliderMarks(\r\n uniqDatesSorted,\r\n index,\r\n timeline.showOnlyActiveDate,\r\n timeline.dateFormat || 'yyyy',\r\n );\r\n\r\n return (\r\n <div\r\n className={`${theme || 'light'} flex ${width ? 'w-fit grow-0' : 'w-full grow'}`}\r\n dir={language === 'he' || language === 'ar' ? 'rtl' : undefined}\r\n >\r\n <div\r\n className={cn(\r\n `${\r\n !backgroundColor\r\n ? 'bg-transparent '\r\n : backgroundColor === true\r\n ? 'bg-primary-gray-200 dark:bg-primary-gray-650 '\r\n : ''\r\n }ml-auto mr-auto flex flex-col grow h-inherit ${language || 'en'}`,\r\n width ? 'w-fit' : 'w-full',\r\n classNames?.graphContainer,\r\n )}\r\n style={{\r\n ...(styles?.graphContainer || {}),\r\n ...(backgroundColor && backgroundColor !== true ? { backgroundColor } : {}),\r\n }}\r\n id={graphID}\r\n ref={graphParentDiv}\r\n aria-label={\r\n ariaLabel ||\r\n `${graphTitle ? `The graph shows ${graphTitle}. ` : ''}This is a grouped bar chart. ${\r\n graphDescription ? ` ${graphDescription}` : ''\r\n }`\r\n }\r\n >\r\n <div\r\n className='flex grow'\r\n style={{ padding: backgroundColor ? padding || '1rem' : padding || 0 }}\r\n >\r\n <div className='flex flex-col gap-4 w-full grow justify-between'>\r\n {graphTitle || graphDescription || graphDownload || dataDownload ? (\r\n <GraphHeader\r\n styles={{\r\n title: styles?.title,\r\n description: styles?.description,\r\n }}\r\n classNames={{\r\n title: classNames?.title,\r\n description: classNames?.description,\r\n }}\r\n graphTitle={graphTitle}\r\n graphDescription={graphDescription}\r\n width={width}\r\n graphDownload={graphDownload ? graphParentDiv.current : undefined}\r\n dataDownload={\r\n dataDownload\r\n ? data.map(d => d.data).filter(d => d !== undefined).length > 0\r\n ? data.map(d => d.data).filter(d => d !== undefined)\r\n : data.filter(d => d !== undefined)\r\n : null\r\n }\r\n />\r\n ) : null}\r\n {timeline.enabled && uniqDatesSorted.length > 0 && markObj ? (\r\n <div className='flex gap-6 items-center' dir='ltr'>\r\n <button\r\n type='button'\r\n onClick={() => {\r\n setPlay(!play);\r\n }}\r\n className='p-0 border-0 cursor-pointer bg-transparent'\r\n aria-label={play ? 'Click to pause animation' : 'Click to play animation'}\r\n >\r\n {play ? <Pause /> : <Play />}\r\n </button>\r\n <SliderUI\r\n min={uniqDatesSorted[0]}\r\n max={uniqDatesSorted[uniqDatesSorted.length - 1]}\r\n marks={markObj}\r\n step={null}\r\n defaultValue={uniqDatesSorted[uniqDatesSorted.length - 1]}\r\n value={uniqDatesSorted[index]}\r\n onChangeComplete={nextValue => {\r\n setIndex(uniqDatesSorted.indexOf(nextValue as number));\r\n }}\r\n onChange={nextValue => {\r\n setIndex(uniqDatesSorted.indexOf(nextValue as number));\r\n }}\r\n aria-label='Time slider. Use arrow keys to adjust selected time period.'\r\n />\r\n </div>\r\n ) : null}\r\n <div className='grow flex flex-col justify-center gap-3 w-full'>\r\n {data.length === 0 ? (\r\n <EmptyState />\r\n ) : (\r\n <>\r\n {showColorScale ? (\r\n <ColorLegendWithMouseOver\r\n width={width}\r\n colorDomain={colorDomain}\r\n colors={colors}\r\n colorLegendTitle={colorLegendTitle}\r\n setSelectedColor={setSelectedColor}\r\n showNAColor={false}\r\n />\r\n ) : null}\r\n <div className='w-full grow leading-0' ref={graphDiv} aria-label='Graph area'>\r\n {(width || svgWidth) && (height || svgHeight) ? (\r\n <Graph\r\n data={\r\n sortParameter !== undefined\r\n ? sortParameter === 'total'\r\n ? orderBy(\r\n ensureCompleteDataForStackedBarChart(\r\n data,\r\n timeline.dateFormat || 'yyyy',\r\n )\r\n .filter(d =>\r\n timeline.enabled\r\n ? d.date ===\r\n format(\r\n new Date(uniqDatesSorted[index]),\r\n timeline.dateFormat || 'yyyy',\r\n )\r\n : d,\r\n )\r\n .filter(d =>\r\n filterNA ? !d.size.every(item => item == null) : d,\r\n ),\r\n d => sum(d.size.filter(el => !checkIfNullOrUndefined(el))),\r\n [sortData || 'asc'],\r\n )\r\n : orderBy(\r\n ensureCompleteDataForStackedBarChart(\r\n data,\r\n timeline.dateFormat || 'yyyy',\r\n )\r\n .filter(d =>\r\n timeline.enabled\r\n ? d.date ===\r\n format(\r\n new Date(uniqDatesSorted[index]),\r\n timeline.dateFormat || 'yyyy',\r\n )\r\n : d,\r\n )\r\n .filter(d =>\r\n filterNA ? !d.size.every(item => item == null) : d,\r\n ),\r\n d =>\r\n checkIfNullOrUndefined(d.size[sortParameter])\r\n ? -Infinity\r\n : d.size[sortParameter],\r\n [sortData || 'asc'],\r\n )\r\n : ensureCompleteDataForStackedBarChart(\r\n data,\r\n timeline.dateFormat || 'yyyy',\r\n ).filter(d => (filterNA ? !d.size.every(item => item == null) : d))\r\n }\r\n barColors={colors}\r\n width={width || svgWidth}\r\n height={Math.max(\r\n minHeight,\r\n height ||\r\n (relativeHeight\r\n ? minHeight\r\n ? (width || svgWidth) * relativeHeight > minHeight\r\n ? (width || svgWidth) * relativeHeight\r\n : minHeight\r\n : (width || svgWidth) * relativeHeight\r\n : svgHeight),\r\n )}\r\n suffix={suffix}\r\n prefix={prefix}\r\n showValues={showValues}\r\n barPadding={barPadding}\r\n showTicks={showTicks}\r\n leftMargin={leftMargin}\r\n rightMargin={rightMargin}\r\n topMargin={topMargin}\r\n bottomMargin={bottomMargin}\r\n truncateBy={truncateBy}\r\n showLabels={showLabels}\r\n tooltip={tooltip}\r\n onSeriesMouseOver={onSeriesMouseOver}\r\n refValues={refValues}\r\n maxValue={\r\n !checkIfNullOrUndefined(maxValue)\r\n ? (maxValue as number)\r\n : Math.max(\r\n ...data.map(d =>\r\n Math.max(\r\n ...(d.size.filter(\r\n l => !checkIfNullOrUndefined(l),\r\n ) as number[]),\r\n ),\r\n ),\r\n ) < 0\r\n ? 0\r\n : Math.max(\r\n ...data.map(d =>\r\n Math.max(\r\n ...(d.size.filter(\r\n l => !checkIfNullOrUndefined(l),\r\n ) as number[]),\r\n ),\r\n ),\r\n )\r\n }\r\n minValue={\r\n !checkIfNullOrUndefined(minValue)\r\n ? (minValue as number)\r\n : Math.min(\r\n ...data.map(d =>\r\n Math.min(\r\n ...(d.size.filter(\r\n l => !checkIfNullOrUndefined(l),\r\n ) as number[]),\r\n ),\r\n ),\r\n ) >= 0\r\n ? 0\r\n : Math.min(\r\n ...data.map(d =>\r\n Math.min(\r\n ...(d.size.filter(\r\n l => !checkIfNullOrUndefined(l),\r\n ) as number[]),\r\n ),\r\n ),\r\n )\r\n }\r\n onSeriesMouseClick={onSeriesMouseClick}\r\n selectedColor={selectedColor}\r\n labelOrder={labelOrder}\r\n rtl={language === 'he' || language === 'ar'}\r\n maxBarThickness={maxBarThickness}\r\n resetSelectionOnDoubleClick={resetSelectionOnDoubleClick}\r\n detailsOnClick={detailsOnClick}\r\n barAxisTitle={barAxisTitle}\r\n noOfTicks={noOfTicks}\r\n valueColor={valueColor}\r\n styles={styles}\r\n classNames={classNames}\r\n colorDomain={colorDomain}\r\n animate={\r\n animate === true\r\n ? { duration: 0.5, once: true, amount: 0.5 }\r\n : animate || { duration: 0, once: true, amount: 0 }\r\n }\r\n precision={precision}\r\n customLayers={customLayers}\r\n naLabel={naLabel}\r\n />\r\n ) : null}\r\n </div>\r\n </>\r\n )}\r\n </div>\r\n {sources || footNote ? (\r\n <GraphFooter\r\n styles={{ footnote: styles?.footnote, source: styles?.source }}\r\n classNames={{\r\n footnote: classNames?.footnote,\r\n source: classNames?.source,\r\n }}\r\n sources={sources}\r\n footNote={footNote}\r\n width={width}\r\n />\r\n ) : null}\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n );\r\n}\r\n","import isEqual from 'fast-deep-equal';\r\nimport { scaleLinear, scaleBand } from 'd3-scale';\r\nimport sum from 'lodash.sum';\r\nimport { useRef, useState } from 'react';\r\nimport { cn } from '@undp/design-system-react/cn';\r\nimport { Modal } from '@undp/design-system-react/Modal';\r\nimport { AnimatePresence, motion, useInView } from 'motion/react';\r\n\r\nimport {\r\n AnimateDataType,\r\n ClassNameObject,\r\n CustomLayerDataType,\r\n GroupedBarGraphDataType,\r\n ReferenceDataType,\r\n StyleObject,\r\n} from '@/Types';\r\nimport { numberFormattingFunction } from '@/Utils/numberFormattingFunction';\r\nimport { Tooltip } from '@/Components/Elements/Tooltip';\r\nimport { checkIfNullOrUndefined } from '@/Utils/checkIfNullOrUndefined';\r\nimport { getTextColorBasedOnBgColor } from '@/Utils/getTextColorBasedOnBgColor';\r\nimport { string2HTML } from '@/Utils/string2HTML';\r\nimport { YAxesLabels } from '@/Components/Elements/Axes/YAxesLabels';\r\nimport { XTicksAndGridLines } from '@/Components/Elements/Axes/XTicksAndGridLines';\r\nimport { AxisTitle } from '@/Components/Elements/Axes/AxisTitle';\r\nimport { Axis } from '@/Components/Elements/Axes/Axis';\r\nimport { RefLineX } from '@/Components/Elements/ReferenceLine';\r\n\r\ninterface Props {\r\n data: GroupedBarGraphDataType[];\r\n barColors: string[];\r\n barPadding: number;\r\n showTicks: boolean;\r\n leftMargin: number;\r\n truncateBy: number;\r\n width: number;\r\n height: number;\r\n rightMargin: number;\r\n topMargin: number;\r\n showLabels: boolean;\r\n bottomMargin: number;\r\n suffix: string;\r\n prefix: string;\r\n showValues: boolean;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n tooltip?: string | ((_d: any) => React.ReactNode);\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseOver?: (_d: any) => void;\r\n refValues?: ReferenceDataType[];\r\n maxValue: number;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseClick?: (_d: any) => void;\r\n selectedColor?: string;\r\n rtl: boolean;\r\n labelOrder?: string[];\r\n maxBarThickness?: number;\r\n minBarThickness?: number;\r\n resetSelectionOnDoubleClick: boolean;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n detailsOnClick?: string | ((_d: any) => React.ReactNode);\r\n barAxisTitle?: string;\r\n noOfTicks: number;\r\n valueColor?: string;\r\n styles?: StyleObject;\r\n classNames?: ClassNameObject;\r\n animate: AnimateDataType;\r\n colorDomain: string[];\r\n precision: number;\r\n customLayers: CustomLayerDataType[];\r\n naLabel: string;\r\n}\r\n\r\nexport function Graph(props: Props) {\r\n const {\r\n data,\r\n barColors,\r\n barPadding,\r\n showTicks,\r\n leftMargin,\r\n rightMargin,\r\n truncateBy,\r\n width,\r\n height,\r\n topMargin,\r\n bottomMargin,\r\n tooltip,\r\n onSeriesMouseOver,\r\n showLabels,\r\n suffix,\r\n prefix,\r\n showValues,\r\n refValues,\r\n maxValue,\r\n onSeriesMouseClick,\r\n selectedColor,\r\n rtl,\r\n labelOrder,\r\n maxBarThickness,\r\n minBarThickness,\r\n resetSelectionOnDoubleClick,\r\n detailsOnClick,\r\n barAxisTitle,\r\n valueColor,\r\n noOfTicks,\r\n styles,\r\n classNames,\r\n animate,\r\n colorDomain,\r\n precision,\r\n customLayers,\r\n naLabel,\r\n } = props;\r\n const svgRef = useRef(null);\r\n const isInView = useInView(svgRef, {\r\n once: animate.once,\r\n amount: animate.amount,\r\n });\r\n const margin = {\r\n top: barAxisTitle ? topMargin + 25 : topMargin,\r\n bottom: bottomMargin,\r\n left: leftMargin,\r\n right: rightMargin,\r\n };\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const [mouseOverData, setMouseOverData] = useState<any>(undefined);\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const [mouseClickData, setMouseClickData] = useState<any>(undefined);\r\n const [eventX, setEventX] = useState<number | undefined>(undefined);\r\n const [eventY, setEventY] = useState<number | undefined>(undefined);\r\n const graphWidth = width - margin.left - margin.right;\r\n const graphHeight = height - margin.top - margin.bottom;\r\n\r\n const dataWithId = data.map((d, i) => ({\r\n ...d,\r\n id: labelOrder ? `${d.label}` : `${i}`,\r\n }));\r\n const barOrder = labelOrder || dataWithId.map(d => `${d.id}`);\r\n\r\n const x = scaleLinear().domain([0, maxValue]).range([0, graphWidth]).nice();\r\n const y = scaleBand()\r\n .domain(barOrder)\r\n .range([\r\n 0,\r\n minBarThickness\r\n ? Math.max(graphHeight, minBarThickness * barOrder.length)\r\n : maxBarThickness\r\n ? Math.min(graphHeight, maxBarThickness * barOrder.length)\r\n : graphHeight,\r\n ])\r\n .paddingInner(barPadding);\r\n const xTicks = x.ticks(noOfTicks);\r\n\r\n return (\r\n <>\r\n <motion.svg\r\n ref={svgRef}\r\n width={`${width}px`}\r\n height={`${height}px`}\r\n viewBox={`0 0 ${width} ${height}`}\r\n direction='ltr'\r\n >\r\n <g transform={`translate(${margin.left},${margin.top})`}>\r\n {showTicks ? (\r\n <XTicksAndGridLines\r\n values={xTicks.filter(d => d !== 0)}\r\n x={xTicks.filter(d => d !== 0).map(d => x(d))}\r\n y1={0 - topMargin}\r\n y2={graphHeight + margin.bottom}\r\n styles={{\r\n gridLines: styles?.xAxis?.gridLines,\r\n labels: styles?.xAxis?.labels,\r\n }}\r\n classNames={{\r\n gridLines: classNames?.xAxis?.gridLines,\r\n labels: classNames?.xAxis?.labels,\r\n }}\r\n suffix={suffix}\r\n prefix={prefix}\r\n labelType='secondary'\r\n showGridLines\r\n precision={precision}\r\n />\r\n ) : null}\r\n <AxisTitle\r\n x={graphWidth / 2}\r\n y={0 - margin.top + 15}\r\n style={styles?.xAxis?.title}\r\n className={classNames?.xAxis?.title}\r\n text={barAxisTitle}\r\n />\r\n {customLayers.filter(d => d.position === 'before').map(d => d.layer)}\r\n <AnimatePresence>\r\n {dataWithId.map(d =>\r\n !checkIfNullOrUndefined(y(d.id)) ? (\r\n <motion.g\r\n className='undp-viz-low-opacity undp-viz-g-with-hover'\r\n key={d.label}\r\n variants={{\r\n initial: { x: 0, y: y(`${d.id}`) },\r\n whileInView: {\r\n x: 0,\r\n y: y(`${d.id}`),\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n >\r\n {d.size.map((el, j) => (\r\n <motion.g\r\n key={`${d.label}-${colorDomain[j] || j}`}\r\n opacity={selectedColor ? (barColors[j] === selectedColor ? 1 : 0.3) : 1}\r\n onMouseEnter={event => {\r\n setMouseOverData({ ...d, sizeIndex: j });\r\n setEventY(event.clientY);\r\n setEventX(event.clientX);\r\n onSeriesMouseOver?.({ ...d, sizeIndex: j });\r\n }}\r\n onMouseMove={event => {\r\n setMouseOverData({ ...d, sizeIndex: j });\r\n setEventY(event.clientY);\r\n setEventX(event.clientX);\r\n }}\r\n onMouseLeave={() => {\r\n setMouseOverData(undefined);\r\n setEventX(undefined);\r\n setEventY(undefined);\r\n onSeriesMouseOver?.(undefined);\r\n }}\r\n onClick={() => {\r\n if (onSeriesMouseClick || detailsOnClick) {\r\n if (\r\n isEqual(mouseClickData, { ...d, sizeIndex: j }) &&\r\n resetSelectionOnDoubleClick\r\n ) {\r\n setMouseClickData(undefined);\r\n onSeriesMouseClick?.(undefined);\r\n } else {\r\n setMouseClickData({ ...d, sizeIndex: j });\r\n if (onSeriesMouseClick) onSeriesMouseClick({ ...d, sizeIndex: j });\r\n }\r\n }\r\n }}\r\n >\r\n {el ? (\r\n <motion.rect\r\n key={j}\r\n y={0}\r\n style={{ fill: barColors[j] }}\r\n height={y.bandwidth()}\r\n exit={{\r\n width: 0,\r\n x: x(0),\r\n transition: { duration: animate.duration },\r\n }}\r\n variants={{\r\n initial: {\r\n width: 0,\r\n x: x(0),\r\n fill: barColors[j],\r\n },\r\n whileInView: {\r\n width: x(el || 0),\r\n x: x(\r\n j === 0 ? 0 : sum(d.size.filter((element, k) => k < j && element)),\r\n ),\r\n fill: barColors[j],\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n />\r\n ) : null}\r\n {showValues ? (\r\n <motion.text\r\n y={y.bandwidth() / 2}\r\n style={{\r\n textAnchor: 'middle',\r\n ...(styles?.graphObjectValues || {}),\r\n }}\r\n dy='0.33em'\r\n className={cn('graph-value text-sm', classNames?.graphObjectValues)}\r\n exit={{\r\n opacity: 0,\r\n transition: { duration: animate.duration },\r\n }}\r\n variants={{\r\n initial: {\r\n x: x(0),\r\n opacity: 0,\r\n fill: getTextColorBasedOnBgColor(barColors[j]),\r\n },\r\n whileInView: {\r\n x:\r\n x(\r\n j === 0\r\n ? 0\r\n : sum(d.size.filter((element, k) => k < j && element)),\r\n ) +\r\n x(el || 0) / 2,\r\n opacity:\r\n el &&\r\n x(el) /\r\n numberFormattingFunction(el, naLabel, precision, prefix, suffix)\r\n .length >\r\n 12\r\n ? 1\r\n : 0,\r\n fill: getTextColorBasedOnBgColor(barColors[j]),\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n >\r\n {numberFormattingFunction(el, naLabel, precision, prefix, suffix)}\r\n </motion.text>\r\n ) : null}\r\n </motion.g>\r\n ))}\r\n {showLabels ? (\r\n <YAxesLabels\r\n value={\r\n `${d.label}`.length < truncateBy\r\n ? `${d.label}`\r\n : `${`${d.label}`.substring(0, truncateBy)}...`\r\n }\r\n y={0}\r\n x={0 - margin.left}\r\n width={0 + margin.left}\r\n height={y.bandwidth()}\r\n style={styles?.yAxis?.labels}\r\n className={classNames?.yAxis?.labels}\r\n animate={animate}\r\n isInView={isInView}\r\n />\r\n ) : null}\r\n {showValues ? (\r\n <motion.text\r\n className={cn(\r\n 'graph-value graph-value-total text-sm',\r\n !valueColor ? ' fill-primary-gray-700 dark:fill-primary-gray-300' : '',\r\n classNames?.graphObjectValues,\r\n )}\r\n style={{\r\n ...(valueColor ? { fill: valueColor } : {}),\r\n textAnchor: 'start',\r\n ...(styles?.graphObjectValues || {}),\r\n }}\r\n y={y.bandwidth() / 2}\r\n dx={5}\r\n dy='0.33em'\r\n variants={{\r\n initial: {\r\n x: x(0),\r\n opacity: 0,\r\n },\r\n whileInView: {\r\n x: x(sum(d.size.map(el => el || 0))),\r\n opacity: 1,\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n exit={{\r\n opacity: 0,\r\n transition: { duration: animate.duration },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n >\r\n {numberFormattingFunction(\r\n sum(d.size.filter(element => element)),\r\n naLabel,\r\n precision,\r\n prefix,\r\n suffix,\r\n )}\r\n </motion.text>\r\n ) : null}\r\n </motion.g>\r\n ) : null,\r\n )}\r\n <Axis\r\n x1={x(0)}\r\n x2={x(0)}\r\n y1={-2.5}\r\n y2={graphHeight + margin.bottom}\r\n classNames={{ axis: classNames?.yAxis?.axis }}\r\n styles={{ axis: styles?.yAxis?.axis }}\r\n />\r\n {refValues ? (\r\n <>\r\n {refValues.map((el, i) => (\r\n <RefLineX\r\n key={i}\r\n text={el.text}\r\n color={el.color}\r\n x={x(el.value as number)}\r\n y1={0 - margin.top}\r\n y2={graphHeight + margin.bottom}\r\n textSide={x(el.value as number) > graphWidth * 0.75 || rtl ? 'left' : 'right'}\r\n classNames={el.classNames}\r\n styles={el.styles}\r\n animate={animate}\r\n isInView={isInView}\r\n />\r\n ))}\r\n </>\r\n ) : null}\r\n </AnimatePresence>\r\n {customLayers.filter(d => d.position === 'after').map(d => d.layer)}\r\n </g>\r\n </motion.svg>\r\n {mouseOverData && tooltip && eventX && eventY ? (\r\n <Tooltip\r\n data={mouseOverData}\r\n body={tooltip}\r\n xPos={eventX}\r\n yPos={eventY}\r\n backgroundStyle={styles?.tooltip}\r\n className={classNames?.tooltip}\r\n />\r\n ) : null}\r\n {detailsOnClick && mouseClickData !== undefined ? (\r\n <Modal\r\n open={mouseClickData !== undefined}\r\n onClose={() => {\r\n setMouseClickData(undefined);\r\n }}\r\n >\r\n <div\r\n className='graph-modal-content m-0'\r\n dangerouslySetInnerHTML={\r\n typeof detailsOnClick === 'string'\r\n ? { __html: string2HTML(detailsOnClick, mouseClickData) }\r\n : undefined\r\n }\r\n >\r\n {typeof detailsOnClick === 'function' ? detailsOnClick(mouseClickData) : null}\r\n </div>\r\n </Modal>\r\n ) : null}\r\n </>\r\n );\r\n}\r\n","import { useState, useRef, useEffect } from 'react';\r\nimport sum from 'lodash.sum';\r\nimport { format } from 'date-fns/format';\r\nimport { parse } from 'date-fns/parse';\r\nimport { cn } from '@undp/design-system-react/cn';\r\nimport { SliderUI } from '@undp/design-system-react/SliderUI';\r\nimport { ascending, sort } from 'd3-array';\r\nimport orderBy from 'lodash.orderby';\r\n\r\nimport { Graph } from './Graph';\r\n\r\nimport { checkIfNullOrUndefined } from '@/Utils/checkIfNullOrUndefined';\r\nimport {\r\n GroupedBarGraphDataType,\r\n Languages,\r\n ReferenceDataType,\r\n SourcesDataType,\r\n StyleObject,\r\n ClassNameObject,\r\n CustomLayerDataType,\r\n AnimateDataType,\r\n TimelineDataType,\r\n} from '@/Types';\r\nimport { GraphFooter } from '@/Components/Elements/GraphFooter';\r\nimport { GraphHeader } from '@/Components/Elements/GraphHeader';\r\nimport { ColorLegendWithMouseOver } from '@/Components/Elements/ColorLegendWithMouseOver';\r\nimport { Colors } from '@/Components/ColorPalette';\r\nimport { EmptyState } from '@/Components/Elements/EmptyState';\r\nimport { Pause, Play } from '@/Components/Icons';\r\nimport { getSliderMarks } from '@/Utils/getSliderMarks';\r\nimport { ensureCompleteDataForStackedBarChart } from '@/Utils/ensureCompleteData';\r\nimport { uniqBy } from '@/Utils/uniqBy';\r\n\r\ninterface Props {\r\n data: GroupedBarGraphDataType[];\r\n colors?: string[];\r\n labelOrder?: string[];\r\n graphTitle?: string | React.ReactNode;\r\n graphDescription?: string | React.ReactNode;\r\n footNote?: string | React.ReactNode;\r\n width?: number;\r\n height?: number;\r\n sources?: SourcesDataType[];\r\n barPadding?: number;\r\n showTicks?: boolean;\r\n leftMargin?: number;\r\n rightMargin?: number;\r\n truncateBy?: number;\r\n colorDomain: string[];\r\n colorLegendTitle?: string;\r\n backgroundColor?: string | boolean;\r\n padding?: string;\r\n topMargin?: number;\r\n bottomMargin?: number;\r\n suffix?: string;\r\n prefix?: string;\r\n showValues?: boolean;\r\n showLabels?: boolean;\r\n relativeHeight?: number;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n tooltip?: string | ((_d: any) => React.ReactNode);\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseOver?: (_d: any) => void;\r\n refValues?: ReferenceDataType[];\r\n graphID?: string;\r\n maxValue?: number;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseClick?: (_d: any) => void;\r\n graphDownload?: boolean;\r\n dataDownload?: boolean;\r\n language?: Languages;\r\n minHeight?: number;\r\n theme?: 'light' | 'dark';\r\n maxBarThickness?: number;\r\n sortParameter?: number | 'total';\r\n sortData?: 'asc' | 'desc';\r\n maxNumberOfBars?: number;\r\n minBarThickness?: number;\r\n ariaLabel?: string;\r\n resetSelectionOnDoubleClick?: boolean;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n detailsOnClick?: string | ((_d: any) => React.ReactNode);\r\n barAxisTitle?: string;\r\n noOfTicks?: number;\r\n valueColor?: string;\r\n styles?: StyleObject;\r\n classNames?: ClassNameObject;\r\n filterNA?: boolean;\r\n animate?: boolean | AnimateDataType;\r\n precision?: number;\r\n showColorScale?: boolean;\r\n customLayers?: CustomLayerDataType[];\r\n timeline?: TimelineDataType;\r\n naLabel?: string;\r\n}\r\n\r\nexport function HorizontalStackedBarGraph(props: Props) {\r\n const {\r\n data,\r\n graphTitle,\r\n colors = Colors.light.categoricalColors.colors,\r\n sources,\r\n graphDescription,\r\n barPadding = 0.25,\r\n showTicks = true,\r\n leftMargin = 100,\r\n rightMargin = 40,\r\n truncateBy = 999,\r\n height,\r\n width,\r\n footNote,\r\n colorDomain,\r\n colorLegendTitle,\r\n padding,\r\n backgroundColor = false,\r\n topMargin = 25,\r\n bottomMargin = 10,\r\n tooltip,\r\n onSeriesMouseOver,\r\n suffix = '',\r\n prefix = '',\r\n showLabels = true,\r\n relativeHeight,\r\n showValues = true,\r\n refValues,\r\n graphID,\r\n maxValue,\r\n onSeriesMouseClick,\r\n graphDownload = false,\r\n dataDownload = false,\r\n language = 'en',\r\n labelOrder,\r\n minHeight = 0,\r\n theme = 'light',\r\n maxBarThickness,\r\n sortParameter,\r\n maxNumberOfBars,\r\n minBarThickness,\r\n showColorScale = true,\r\n ariaLabel,\r\n resetSelectionOnDoubleClick = true,\r\n detailsOnClick,\r\n barAxisTitle,\r\n noOfTicks = 5,\r\n valueColor,\r\n styles,\r\n classNames,\r\n filterNA = true,\r\n animate = false,\r\n precision = 2,\r\n customLayers = [],\r\n timeline = { enabled: false, autoplay: false, showOnlyActiveDate: true },\r\n naLabel = 'NA',\r\n sortData,\r\n } = props;\r\n\r\n const [svgWidth, setSvgWidth] = useState(0);\r\n const [svgHeight, setSvgHeight] = useState(0);\r\n const [play, setPlay] = useState(timeline.autoplay);\r\n const uniqDatesSorted = sort(\r\n uniqBy(data, 'date', true).map(d =>\r\n parse(`${d}`, timeline.dateFormat || 'yyyy', new Date()).getTime(),\r\n ),\r\n (a, b) => ascending(a, b),\r\n );\r\n const [index, setIndex] = useState(timeline.autoplay ? 0 : uniqDatesSorted.length - 1);\r\n const [selectedColor, setSelectedColor] = useState<string | undefined>(undefined);\r\n\r\n const graphDiv = useRef<HTMLDivElement>(null);\r\n const graphParentDiv = useRef<HTMLDivElement>(null);\r\n useEffect(() => {\r\n const resizeObserver = new ResizeObserver(entries => {\r\n setSvgWidth(width || entries[0].target.clientWidth || 620);\r\n setSvgHeight(height || entries[0].target.clientHeight || 480);\r\n });\r\n if (graphDiv.current) {\r\n setSvgHeight(graphDiv.current.clientHeight || 480);\r\n setSvgWidth(graphDiv.current.clientWidth || 620);\r\n if (!width) resizeObserver.observe(graphDiv.current);\r\n }\r\n return () => resizeObserver.disconnect();\r\n }, [width, height]);\r\n\r\n useEffect(() => {\r\n const interval = setInterval(\r\n () => {\r\n setIndex(i => (i < uniqDatesSorted.length - 1 ? i + 1 : 0));\r\n },\r\n (timeline.speed || 2) * 1000,\r\n );\r\n if (!play) clearInterval(interval);\r\n return () => clearInterval(interval);\r\n }, [uniqDatesSorted, play, timeline.speed]);\r\n\r\n const markObj = getSliderMarks(\r\n uniqDatesSorted,\r\n index,\r\n timeline.showOnlyActiveDate,\r\n timeline.dateFormat || 'yyyy',\r\n );\r\n\r\n return (\r\n <div\r\n className={`${theme || 'light'} flex ${width ? 'w-fit grow-0' : 'w-full grow'}`}\r\n dir={language === 'he' || language === 'ar' ? 'rtl' : undefined}\r\n >\r\n <div\r\n className={cn(\r\n `${\r\n !backgroundColor\r\n ? 'bg-transparent '\r\n : backgroundColor === true\r\n ? 'bg-primary-gray-200 dark:bg-primary-gray-650 '\r\n : ''\r\n }ml-auto mr-auto flex flex-col grow h-inherit ${language || 'en'}`,\r\n width ? 'w-fit' : 'w-full',\r\n classNames?.graphContainer,\r\n )}\r\n style={{\r\n ...(styles?.graphContainer || {}),\r\n ...(backgroundColor && backgroundColor !== true ? { backgroundColor } : {}),\r\n }}\r\n id={graphID}\r\n ref={graphParentDiv}\r\n aria-label={\r\n ariaLabel ||\r\n `${graphTitle ? `The graph shows ${graphTitle}. ` : ''}This is a stacked bar chart. ${\r\n graphDescription ? ` ${graphDescription}` : ''\r\n }`\r\n }\r\n >\r\n <div\r\n className='flex grow'\r\n style={{ padding: backgroundColor ? padding || '1rem' : padding || 0 }}\r\n >\r\n <div className='flex flex-col gap-4 w-full grow justify-between'>\r\n {graphTitle || graphDescription || graphDownload || dataDownload ? (\r\n <GraphHeader\r\n styles={{\r\n title: styles?.title,\r\n description: styles?.description,\r\n }}\r\n classNames={{\r\n title: classNames?.title,\r\n description: classNames?.description,\r\n }}\r\n graphTitle={graphTitle}\r\n graphDescription={graphDescription}\r\n width={width}\r\n graphDownload={graphDownload ? graphParentDiv.current : undefined}\r\n dataDownload={\r\n dataDownload\r\n ? data.map(d => d.data).filter(d => d !== undefined).length > 0\r\n ? data.map(d => d.data).filter(d => d !== undefined)\r\n : data.filter(d => d !== undefined)\r\n : null\r\n }\r\n />\r\n ) : null}\r\n {timeline.enabled && uniqDatesSorted.length > 0 && markObj ? (\r\n <div className='flex gap-6 items-center' dir='ltr'>\r\n <button\r\n type='button'\r\n onClick={() => {\r\n setPlay(!play);\r\n }}\r\n className='p-0 border-0 cursor-pointer bg-transparent'\r\n aria-label={play ? 'Click to pause animation' : 'Click to play animation'}\r\n >\r\n {play ? <Pause /> : <Play />}\r\n </button>\r\n <SliderUI\r\n min={uniqDatesSorted[0]}\r\n max={uniqDatesSorted[uniqDatesSorted.length - 1]}\r\n marks={markObj}\r\n step={null}\r\n defaultValue={uniqDatesSorted[uniqDatesSorted.length - 1]}\r\n value={uniqDatesSorted[index]}\r\n onChangeComplete={nextValue => {\r\n setIndex(uniqDatesSorted.indexOf(nextValue as number));\r\n }}\r\n onChange={nextValue => {\r\n setIndex(uniqDatesSorted.indexOf(nextValue as number));\r\n }}\r\n aria-label='Time slider. Use arrow keys to adjust selected time period.'\r\n />\r\n </div>\r\n ) : null}\r\n <div className='grow flex flex-col justify-center gap-3 w-full'>\r\n {data.length === 0 ? (\r\n <EmptyState />\r\n ) : (\r\n <>\r\n {showColorScale ? (\r\n <ColorLegendWithMouseOver\r\n width={width}\r\n colorDomain={colorDomain}\r\n colors={colors}\r\n colorLegendTitle={colorLegendTitle}\r\n setSelectedColor={setSelectedColor}\r\n showNAColor={false}\r\n />\r\n ) : null}\r\n <div className='w-full grow leading-0' ref={graphDiv} aria-label='Graph area'>\r\n {(width || svgWidth) && (height || svgHeight) ? (\r\n <Graph\r\n data={\r\n sortParameter !== undefined\r\n ? sortParameter === 'total'\r\n ? orderBy(\r\n ensureCompleteDataForStackedBarChart(\r\n data,\r\n timeline.dateFormat || 'yyyy',\r\n )\r\n .filter(d =>\r\n timeline.enabled\r\n ? d.date ===\r\n format(\r\n new Date(uniqDatesSorted[index]),\r\n timeline.dateFormat || 'yyyy',\r\n )\r\n : d,\r\n )\r\n .filter(d =>\r\n filterNA ? !d.size.every(item => item == null) : d,\r\n ),\r\n d => sum(d.size.filter(el => !checkIfNullOrUndefined(el))),\r\n [sortData || 'asc'],\r\n ).filter((_d, i) => (maxNumberOfBars ? i < maxNumberOfBars : true))\r\n : orderBy(\r\n ensureCompleteDataForStackedBarChart(\r\n data,\r\n timeline.dateFormat || 'yyyy',\r\n )\r\n .filter(d =>\r\n timeline.enabled\r\n ? d.date ===\r\n format(\r\n new Date(uniqDatesSorted[index]),\r\n timeline.dateFormat || 'yyyy',\r\n )\r\n : d,\r\n )\r\n .filter(d =>\r\n filterNA ? !d.size.every(item => item == null) : d,\r\n ),\r\n d =>\r\n checkIfNullOrUndefined(d.size[sortParameter])\r\n ? -Infinity\r\n : d.size[sortParameter],\r\n [sortData || 'asc'],\r\n ).filter((_d, i) => (maxNumberOfBars ? i < maxNumberOfBars : true))\r\n : ensureCompleteDataForStackedBarChart(\r\n data,\r\n timeline.dateFormat || 'yyyy',\r\n )\r\n .filter(d =>\r\n timeline.enabled\r\n ? d.date ===\r\n format(\r\n new Date(uniqDatesSorted[index]),\r\n timeline.dateFormat || 'yyyy',\r\n )\r\n : d,\r\n )\r\n .filter(d => (filterNA ? !d.size.every(item => item == null) : d))\r\n .filter((_d, i) => (maxNumberOfBars ? i < maxNumberOfBars : true))\r\n }\r\n barColors={colors}\r\n width={width || svgWidth}\r\n height={Math.max(\r\n minHeight,\r\n height ||\r\n (relativeHeight\r\n ? minHeight\r\n ? (width || svgWidth) * relativeHeight > minHeight\r\n ? (width || svgWidth) * relativeHeight\r\n : minHeight\r\n : (width || svgWidth) * relativeHeight\r\n : svgHeight),\r\n )}\r\n barPadding={barPadding}\r\n showTicks={showTicks}\r\n leftMargin={leftMargin}\r\n rightMargin={rightMargin}\r\n topMargin={topMargin}\r\n bottomMargin={bottomMargin}\r\n truncateBy={truncateBy}\r\n showLabels={showLabels}\r\n tooltip={tooltip}\r\n onSeriesMouseOver={onSeriesMouseOver}\r\n showValues={showValues}\r\n suffix={suffix}\r\n prefix={prefix}\r\n refValues={refValues}\r\n maxValue={\r\n !checkIfNullOrUndefined(maxValue)\r\n ? (maxValue as number)\r\n : Math.max(\r\n ...data.map(\r\n d => sum(d.size.filter(l => !checkIfNullOrUndefined(l))) || 0,\r\n ),\r\n )\r\n }\r\n onSeriesMouseClick={onSeriesMouseClick}\r\n selectedColor={selectedColor}\r\n rtl={language === 'he' || language === 'ar'}\r\n labelOrder={labelOrder}\r\n maxBarThickness={maxBarThickness}\r\n minBarThickness={minBarThickness}\r\n resetSelectionOnDoubleClick={resetSelectionOnDoubleClick}\r\n detailsOnClick={detailsOnClick}\r\n barAxisTitle={barAxisTitle}\r\n noOfTicks={noOfTicks}\r\n valueColor={valueColor}\r\n classNames={classNames}\r\n styles={styles}\r\n animate={\r\n animate === true\r\n ? { duration: 0.5, once: true, amount: 0.5 }\r\n : animate || { duration: 0, once: true, amount: 0 }\r\n }\r\n colorDomain={colorDomain}\r\n precision={precision}\r\n customLayers={customLayers}\r\n naLabel={naLabel}\r\n />\r\n ) : null}\r\n </div>\r\n </>\r\n )}\r\n </div>\r\n {sources || footNote ? (\r\n <GraphFooter\r\n styles={{ footnote: styles?.footnote, source: styles?.source }}\r\n classNames={{\r\n footnote: classNames?.footnote,\r\n source: classNames?.source,\r\n }}\r\n sources={sources}\r\n footNote={footNote}\r\n width={width}\r\n />\r\n ) : null}\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n );\r\n}\r\n","import isEqual from 'fast-deep-equal';\r\nimport { scaleLinear, scaleBand } from 'd3-scale';\r\nimport { useRef, useState } from 'react';\r\nimport { cn } from '@undp/design-system-react/cn';\r\nimport { Modal } from '@undp/design-system-react/Modal';\r\nimport { AnimatePresence, motion, useInView } from 'motion/react';\r\n\r\nimport { numberFormattingFunction } from '@/Utils/numberFormattingFunction';\r\nimport {\r\n AnimateDataType,\r\n BarGraphDataType,\r\n ClassNameObject,\r\n CustomLayerDataType,\r\n ReferenceDataType,\r\n StyleObject,\r\n} from '@/Types';\r\nimport { Tooltip } from '@/Components/Elements/Tooltip';\r\nimport { checkIfNullOrUndefined } from '@/Utils/checkIfNullOrUndefined';\r\nimport { Colors } from '@/Components/ColorPalette';\r\nimport { string2HTML } from '@/Utils/string2HTML';\r\nimport { Axis } from '@/Components/Elements/Axes/Axis';\r\nimport { AxisTitle } from '@/Components/Elements/Axes/AxisTitle';\r\nimport { XAxesLabels } from '@/Components/Elements/Axes/XAxesLabels';\r\nimport { RefLineY } from '@/Components/Elements/ReferenceLine';\r\nimport { YTicksAndGridLines } from '@/Components/Elements/Axes/YTicksAndGridLines';\r\n\r\ninterface Props {\r\n data: BarGraphDataType[];\r\n width: number;\r\n height: number;\r\n barColor: string[];\r\n suffix: string;\r\n prefix: string;\r\n barPadding: number;\r\n showLabels: boolean;\r\n showValues: boolean;\r\n showTicks: boolean;\r\n colorDomain: string[];\r\n truncateBy: number;\r\n leftMargin: number;\r\n rightMargin: number;\r\n topMargin: number;\r\n bottomMargin: number;\r\n refValues?: ReferenceDataType[];\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n tooltip?: string | ((_d: any) => React.ReactNode);\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseOver?: (_d: any) => void;\r\n selectedColor?: string;\r\n maxValue: number;\r\n minValue: number;\r\n highlightedDataPoints: (string | number)[];\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseClick?: (_d: any) => void;\r\n labelOrder?: string[];\r\n maxBarThickness?: number;\r\n minBarThickness?: number;\r\n resetSelectionOnDoubleClick: boolean;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n detailsOnClick?: string | ((_d: any) => React.ReactNode);\r\n barAxisTitle?: string;\r\n noOfTicks: number;\r\n valueColor?: string;\r\n styles?: StyleObject;\r\n classNames?: ClassNameObject;\r\n animate: AnimateDataType;\r\n dimmedOpacity: number;\r\n precision: number;\r\n customLayers: CustomLayerDataType[];\r\n naLabel: string;\r\n}\r\n\r\nexport function Graph(props: Props) {\r\n const {\r\n data,\r\n width,\r\n height,\r\n barColor,\r\n suffix,\r\n prefix,\r\n barPadding,\r\n showLabels,\r\n showValues,\r\n showTicks,\r\n colorDomain,\r\n truncateBy,\r\n rightMargin,\r\n topMargin,\r\n bottomMargin,\r\n leftMargin,\r\n tooltip,\r\n onSeriesMouseOver,\r\n refValues,\r\n selectedColor,\r\n maxValue,\r\n minValue,\r\n highlightedDataPoints,\r\n onSeriesMouseClick,\r\n labelOrder,\r\n maxBarThickness,\r\n minBarThickness,\r\n resetSelectionOnDoubleClick,\r\n detailsOnClick,\r\n barAxisTitle,\r\n valueColor,\r\n noOfTicks,\r\n styles,\r\n classNames,\r\n dimmedOpacity,\r\n animate,\r\n precision,\r\n customLayers,\r\n naLabel,\r\n } = props;\r\n const svgRef = useRef(null);\r\n const isInView = useInView(svgRef, {\r\n once: animate.once,\r\n amount: animate.amount,\r\n });\r\n const margin = {\r\n top: topMargin,\r\n bottom: bottomMargin,\r\n left: barAxisTitle ? leftMargin + 30 : leftMargin,\r\n right: rightMargin,\r\n };\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const [mouseOverData, setMouseOverData] = useState<any>(undefined);\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const [mouseClickData, setMouseClickData] = useState<any>(undefined);\r\n const [eventX, setEventX] = useState<number | undefined>(undefined);\r\n const [eventY, setEventY] = useState<number | undefined>(undefined);\r\n const graphWidth = width - margin.left - margin.right;\r\n const graphHeight = height - margin.top - margin.bottom;\r\n\r\n const y = scaleLinear().domain([minValue, maxValue]).range([graphHeight, 0]).nice();\r\n\r\n const dataWithId = data.map((d, i) => ({\r\n ...d,\r\n id: labelOrder ? `${d.label}` : `${i}`,\r\n }));\r\n const barOrder = labelOrder || dataWithId.map(d => `${d.id}`);\r\n const x = scaleBand()\r\n .domain(barOrder)\r\n .range([\r\n 0,\r\n minBarThickness\r\n ? Math.max(graphWidth, minBarThickness * barOrder.length)\r\n : maxBarThickness\r\n ? Math.min(graphWidth, maxBarThickness * barOrder.length)\r\n : graphWidth,\r\n ])\r\n .paddingInner(barPadding);\r\n const yTicks = y.ticks(noOfTicks);\r\n return (\r\n <>\r\n <motion.svg\r\n ref={svgRef}\r\n width={`${width}px`}\r\n height={`${height}px`}\r\n viewBox={`0 0 ${width} ${height}`}\r\n direction='ltr'\r\n >\r\n <g transform={`translate(${margin.left},${margin.top})`}>\r\n <Axis\r\n y1={y(minValue < 0 ? 0 : minValue)}\r\n y2={y(minValue < 0 ? 0 : minValue)}\r\n x1={0 - leftMargin}\r\n x2={graphWidth + margin.right}\r\n label={numberFormattingFunction(\r\n minValue < 0 ? 0 : minValue,\r\n naLabel,\r\n precision,\r\n prefix,\r\n suffix,\r\n )}\r\n labelPos={{\r\n x: 0 - leftMargin,\r\n dx: 0,\r\n dy: maxValue < 0 ? '1em' : -5,\r\n y: y(minValue < 0 ? 0 : minValue),\r\n }}\r\n classNames={{\r\n axis: classNames?.xAxis?.axis,\r\n label: classNames?.yAxis?.labels,\r\n }}\r\n styles={{ axis: styles?.xAxis?.axis, label: styles?.yAxis?.labels }}\r\n />\r\n {showTicks ? (\r\n <YTicksAndGridLines\r\n values={yTicks.filter(d => d !== 0)}\r\n y={yTicks.filter(d => d !== 0).map(d => y(d))}\r\n x1={0 - leftMargin}\r\n x2={graphWidth + margin.right}\r\n styles={{\r\n gridLines: styles?.yAxis?.gridLines,\r\n labels: styles?.yAxis?.labels,\r\n }}\r\n classNames={{\r\n gridLines: classNames?.yAxis?.gridLines,\r\n labels: classNames?.yAxis?.labels,\r\n }}\r\n suffix={suffix}\r\n prefix={prefix}\r\n labelType='secondary'\r\n showGridLines\r\n labelPos='vertical'\r\n precision={precision}\r\n />\r\n ) : null}\r\n <AxisTitle\r\n x={0 - leftMargin - 15}\r\n y={graphHeight / 2}\r\n style={styles?.yAxis?.title}\r\n className={classNames?.yAxis?.title}\r\n text={barAxisTitle}\r\n rotate90\r\n />\r\n {customLayers.filter(d => d.position === 'before').map(d => d.layer)}\r\n <AnimatePresence>\r\n {dataWithId.map((d, _i) =>\r\n !checkIfNullOrUndefined(x(d.id)) ? (\r\n <motion.g\r\n className='undp-viz-g-with-hover'\r\n key={d.label}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n variants={{\r\n initial: {\r\n opacity: selectedColor\r\n ? d.color\r\n ? barColor[colorDomain.indexOf(d.color)] === selectedColor\r\n ? 1\r\n : dimmedOpacity\r\n : dimmedOpacity\r\n : highlightedDataPoints.length !== 0\r\n ? highlightedDataPoints.indexOf(d.label) !== -1\r\n ? 0.85\r\n : dimmedOpacity\r\n : 0.85,\r\n },\r\n whileInView: {\r\n opacity: selectedColor\r\n ? d.color\r\n ? barColor[colorDomain.indexOf(d.color)] === selectedColor\r\n ? 1\r\n : dimmedOpacity\r\n : dimmedOpacity\r\n : highlightedDataPoints.length !== 0\r\n ? highlightedDataPoints.indexOf(d.label) !== -1\r\n ? 0.85\r\n : dimmedOpacity\r\n : 0.85,\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n onMouseEnter={event => {\r\n setMouseOverData(d);\r\n setEventY(event.clientY);\r\n setEventX(event.clientX);\r\n onSeriesMouseOver?.(d);\r\n }}\r\n onClick={() => {\r\n if (onSeriesMouseClick || detailsOnClick) {\r\n if (isEqual(mouseClickData, d) && resetSelectionOnDoubleClick) {\r\n setMouseClickData(undefined);\r\n onSeriesMouseClick?.(undefined);\r\n } else {\r\n setMouseClickData(d);\r\n onSeriesMouseClick?.(d);\r\n }\r\n }\r\n }}\r\n onMouseMove={event => {\r\n setMouseOverData(d);\r\n setEventY(event.clientY);\r\n setEventX(event.clientX);\r\n }}\r\n onMouseLeave={() => {\r\n setMouseOverData(undefined);\r\n setEventX(undefined);\r\n setEventY(undefined);\r\n onSeriesMouseOver?.(undefined);\r\n }}\r\n >\r\n {d.size ? (\r\n <motion.rect\r\n width={x.bandwidth()}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n variants={{\r\n initial: {\r\n height: 0,\r\n x: x(`${d.id}`),\r\n y: y(0),\r\n fill:\r\n data.filter(el => el.color).length === 0\r\n ? barColor[0]\r\n : !d.color\r\n ? Colors.gray\r\n : barColor[colorDomain.indexOf(d.color)],\r\n },\r\n whileInView: {\r\n height: d.size ? Math.abs(y(d.size) - y(0)) : 0,\r\n y: d.size ? (d.size > 0 ? y(d.size) : y(0)) : y(0),\r\n x: x(`${d.id}`),\r\n fill:\r\n data.filter(el => el.color).length === 0\r\n ? barColor[0]\r\n : !d.color\r\n ? Colors.gray\r\n : barColor[colorDomain.indexOf(d.color)],\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n exit={{\r\n height: 0,\r\n y: y(0),\r\n transition: { duration: animate.duration },\r\n }}\r\n />\r\n ) : null}\r\n {showLabels ? (\r\n <XAxesLabels\r\n value={\r\n `${d.label}`.length < truncateBy\r\n ? `${d.label}`\r\n : `${`${d.label}`.substring(0, truncateBy)}...`\r\n }\r\n y={(d.size || 0) < 0 ? 0 : y(0) + 5}\r\n x={x(`${d.id}`) as number}\r\n width={x.bandwidth()}\r\n height={(d.size || 0) < 0 ? y(0) - 5 : margin.bottom}\r\n style={styles?.xAxis?.labels}\r\n className={classNames?.xAxis?.labels}\r\n alignment={(d.size || 0) < 0 ? 'bottom' : 'top'}\r\n animate={animate}\r\n isInView={isInView}\r\n />\r\n ) : null}\r\n {showValues ? (\r\n <motion.text\r\n style={{\r\n textAnchor: 'middle',\r\n ...(styles?.graphObjectValues || {}),\r\n }}\r\n className={cn(\r\n 'graph-value text-sm',\r\n !valueColor && barColor.length > 1\r\n ? ' fill-primary-gray-600 dark:fill-primary-gray-300'\r\n : '',\r\n classNames?.graphObjectValues,\r\n )}\r\n dy={d.size ? (d.size >= 0 ? '-5px' : '1em') : '-5px'}\r\n variants={{\r\n initial: {\r\n x: (x(`${d.id}`) as number) + x.bandwidth() / 2,\r\n y: y(0),\r\n opacity: 0,\r\n fill: valueColor\r\n ? valueColor\r\n : data.filter(el => el.color).length === 0\r\n ? barColor[0]\r\n : !d.color\r\n ? Colors.gray\r\n : barColor[colorDomain.indexOf(d.color)],\r\n },\r\n whileInView: {\r\n x: (x(`${d.id}`) as number) + x.bandwidth() / 2,\r\n y: y(d.size || 0),\r\n fill: valueColor\r\n ? valueColor\r\n : data.filter(el => el.color).length === 0\r\n ? barColor[0]\r\n : !d.color\r\n ? Colors.gray\r\n : barColor[colorDomain.indexOf(d.color)],\r\n opacity: 1,\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n exit={{\r\n opacity: 0,\r\n transition: { duration: animate.duration },\r\n }}\r\n >\r\n {numberFormattingFunction(d.size, naLabel, precision, prefix, suffix)}\r\n </motion.text>\r\n ) : null}\r\n </motion.g>\r\n ) : null,\r\n )}\r\n {refValues ? (\r\n <>\r\n {refValues.map((el, i) => (\r\n <RefLineY\r\n key={i}\r\n text={el.text}\r\n color={el.color}\r\n y={y(el.value as number)}\r\n x1={0 - leftMargin}\r\n x2={graphWidth + margin.right}\r\n classNames={el.classNames}\r\n styles={el.styles}\r\n animate={animate}\r\n isInView={isInView}\r\n />\r\n ))}\r\n </>\r\n ) : null}\r\n </AnimatePresence>\r\n {customLayers.filter(d => d.position === 'after').map(d => d.layer)}\r\n </g>\r\n </motion.svg>\r\n {mouseOverData && tooltip && eventX && eventY ? (\r\n <Tooltip\r\n data={mouseOverData}\r\n body={tooltip}\r\n xPos={eventX}\r\n yPos={eventY}\r\n backgroundStyle={styles?.tooltip}\r\n className={classNames?.tooltip}\r\n />\r\n ) : null}\r\n {detailsOnClick && mouseClickData !== undefined ? (\r\n <Modal\r\n open={mouseClickData !== undefined}\r\n onClose={() => {\r\n setMouseClickData(undefined);\r\n }}\r\n >\r\n <div\r\n className='graph-modal-content m-0'\r\n dangerouslySetInnerHTML={\r\n typeof detailsOnClick === 'string'\r\n ? { __html: string2HTML(detailsOnClick, mouseClickData) }\r\n : undefined\r\n }\r\n >\r\n {typeof detailsOnClick === 'function' ? detailsOnClick(mouseClickData) : null}\r\n </div>\r\n </Modal>\r\n ) : null}\r\n </>\r\n );\r\n}\r\n","import { useEffect, useRef, useState } from 'react';\r\nimport { format } from 'date-fns/format';\r\nimport { parse } from 'date-fns/parse';\r\nimport { cn } from '@undp/design-system-react/cn';\r\nimport { SliderUI } from '@undp/design-system-react/SliderUI';\r\nimport { ascending, sort } from 'd3-array';\r\nimport orderBy from 'lodash.orderby';\r\n\r\nimport { Graph } from './Graph';\r\n\r\nimport {\r\n ReferenceDataType,\r\n BarGraphDataType,\r\n SourcesDataType,\r\n Languages,\r\n StyleObject,\r\n ClassNameObject,\r\n CustomLayerDataType,\r\n AnimateDataType,\r\n TimelineDataType,\r\n} from '@/Types';\r\nimport { GraphHeader } from '@/Components/Elements/GraphHeader';\r\nimport { GraphFooter } from '@/Components/Elements/GraphFooter';\r\nimport { ColorLegendWithMouseOver } from '@/Components/Elements/ColorLegendWithMouseOver';\r\nimport { Colors } from '@/Components/ColorPalette';\r\nimport { EmptyState } from '@/Components/Elements/EmptyState';\r\nimport { checkIfNullOrUndefined } from '@/Utils/checkIfNullOrUndefined';\r\nimport { Pause, Play } from '@/Components/Icons';\r\nimport { getSliderMarks } from '@/Utils/getSliderMarks';\r\nimport { ensureCompleteDataForBarChart } from '@/Utils/ensureCompleteData';\r\nimport { uniqBy } from '@/Utils/uniqBy';\r\n\r\ninterface Props {\r\n data: BarGraphDataType[];\r\n colors?: string | string[];\r\n graphTitle?: string | React.ReactNode;\r\n labelOrder?: string[];\r\n width?: number;\r\n height?: number;\r\n suffix?: string;\r\n prefix?: string;\r\n sources?: SourcesDataType[];\r\n graphDescription?: string | React.ReactNode;\r\n footNote?: string | React.ReactNode;\r\n barPadding?: number;\r\n showLabels?: boolean;\r\n showValues?: boolean;\r\n showTicks?: boolean;\r\n colorDomain?: string[];\r\n colorLegendTitle?: string;\r\n truncateBy?: number;\r\n backgroundColor?: string | boolean;\r\n padding?: string;\r\n leftMargin?: number;\r\n rightMargin?: number;\r\n topMargin?: number;\r\n relativeHeight?: number;\r\n bottomMargin?: number;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n tooltip?: string | ((_d: any) => React.ReactNode);\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseOver?: (_d: any) => void;\r\n refValues?: ReferenceDataType[];\r\n showColorScale?: boolean;\r\n graphID?: string;\r\n maxValue?: number;\r\n minValue?: number;\r\n highlightedDataPoints?: (string | number)[];\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseClick?: (_d: any) => void;\r\n graphDownload?: boolean;\r\n dataDownload?: boolean;\r\n sortData?: 'asc' | 'desc';\r\n language?: Languages;\r\n showNAColor?: boolean;\r\n minHeight?: number;\r\n theme?: 'light' | 'dark';\r\n maxBarThickness?: number;\r\n maxNumberOfBars?: number;\r\n minBarThickness?: number;\r\n ariaLabel?: string;\r\n resetSelectionOnDoubleClick?: boolean;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n detailsOnClick?: string | ((_d: any) => React.ReactNode);\r\n barAxisTitle?: string;\r\n noOfTicks?: number;\r\n valueColor?: string;\r\n styles?: StyleObject;\r\n classNames?: ClassNameObject;\r\n filterNA?: boolean;\r\n animate?: boolean | AnimateDataType;\r\n dimmedOpacity?: number;\r\n precision?: number;\r\n customLayers?: CustomLayerDataType[];\r\n timeline?: TimelineDataType;\r\n naLabel?: string;\r\n}\r\n\r\nexport function VerticalBarGraph(props: Props) {\r\n const {\r\n data,\r\n graphTitle,\r\n colors,\r\n barPadding = 0.25,\r\n showTicks = true,\r\n leftMargin = 20,\r\n rightMargin = 20,\r\n topMargin = 20,\r\n bottomMargin = 25,\r\n truncateBy = 999,\r\n showLabels = true,\r\n showValues = true,\r\n backgroundColor = false,\r\n suffix = '',\r\n prefix = '',\r\n sources,\r\n graphDescription,\r\n height,\r\n width,\r\n footNote,\r\n colorDomain,\r\n colorLegendTitle,\r\n padding,\r\n relativeHeight,\r\n tooltip,\r\n onSeriesMouseOver,\r\n refValues,\r\n showColorScale = true,\r\n graphID,\r\n maxValue,\r\n minValue,\r\n highlightedDataPoints = [],\r\n onSeriesMouseClick,\r\n graphDownload = false,\r\n dataDownload = false,\r\n language = 'en',\r\n theme = 'light',\r\n sortData,\r\n labelOrder,\r\n showNAColor = true,\r\n minHeight = 0,\r\n maxBarThickness,\r\n maxNumberOfBars,\r\n minBarThickness,\r\n ariaLabel,\r\n resetSelectionOnDoubleClick = true,\r\n detailsOnClick,\r\n barAxisTitle,\r\n noOfTicks = 5,\r\n valueColor,\r\n styles,\r\n classNames,\r\n filterNA = true,\r\n animate = false,\r\n dimmedOpacity = 0.3,\r\n precision = 2,\r\n customLayers = [],\r\n timeline = { enabled: false, autoplay: false, showOnlyActiveDate: true },\r\n naLabel = 'NA',\r\n } = props;\r\n\r\n const [svgWidth, setSvgWidth] = useState(0);\r\n const [svgHeight, setSvgHeight] = useState(0);\r\n const [play, setPlay] = useState(timeline.autoplay);\r\n const uniqDatesSorted = sort(\r\n uniqBy(data, 'date', true).map(d =>\r\n parse(`${d}`, timeline.dateFormat || 'yyyy', new Date()).getTime(),\r\n ),\r\n (a, b) => ascending(a, b),\r\n );\r\n const [index, setIndex] = useState(timeline.autoplay ? 0 : uniqDatesSorted.length - 1);\r\n const [selectedColor, setSelectedColor] = useState<string | undefined>(undefined);\r\n const graphDiv = useRef<HTMLDivElement>(null);\r\n const graphParentDiv = useRef<HTMLDivElement>(null);\r\n\r\n useEffect(() => {\r\n const resizeObserver = new ResizeObserver(entries => {\r\n setSvgWidth(width || entries[0].target.clientWidth || 620);\r\n setSvgHeight(height || entries[0].target.clientHeight || 480);\r\n });\r\n if (graphDiv.current) {\r\n setSvgHeight(graphDiv.current.clientHeight || 480);\r\n setSvgWidth(graphDiv.current.clientWidth || 620);\r\n if (!width) resizeObserver.observe(graphDiv.current);\r\n }\r\n return () => resizeObserver.disconnect();\r\n }, [width, height]);\r\n\r\n useEffect(() => {\r\n const interval = setInterval(\r\n () => {\r\n setIndex(i => (i < uniqDatesSorted.length - 1 ? i + 1 : 0));\r\n },\r\n (timeline.speed || 2) * 1000,\r\n );\r\n if (!play) clearInterval(interval);\r\n return () => clearInterval(interval);\r\n }, [uniqDatesSorted, play, timeline.speed]);\r\n\r\n const markObj = getSliderMarks(\r\n uniqDatesSorted,\r\n index,\r\n timeline.showOnlyActiveDate,\r\n timeline.dateFormat || 'yyyy',\r\n );\r\n\r\n return (\r\n <div\r\n className={`${theme || 'light'} flex ${width ? 'w-fit grow-0' : 'w-full grow'}`}\r\n dir={language === 'he' || language === 'ar' ? 'rtl' : undefined}\r\n >\r\n <div\r\n className={cn(\r\n `${\r\n !backgroundColor\r\n ? 'bg-transparent '\r\n : backgroundColor === true\r\n ? 'bg-primary-gray-200 dark:bg-primary-gray-650 '\r\n : ''\r\n }ml-auto mr-auto flex flex-col grow h-inherit ${language || 'en'}`,\r\n width ? 'w-fit' : 'w-full',\r\n classNames?.graphContainer,\r\n )}\r\n style={{\r\n ...(styles?.graphContainer || {}),\r\n ...(backgroundColor && backgroundColor !== true ? { backgroundColor } : {}),\r\n }}\r\n id={graphID}\r\n ref={graphParentDiv}\r\n aria-label={\r\n ariaLabel ||\r\n `${graphTitle ? `The graph shows ${graphTitle}. ` : ''}This is a grouped bar chart. ${\r\n graphDescription ? ` ${graphDescription}` : ''\r\n }`\r\n }\r\n >\r\n <div\r\n className='flex grow'\r\n style={{ padding: backgroundColor ? padding || '1rem' : padding || 0 }}\r\n >\r\n <div className='flex flex-col w-full gap-4 grow justify-between'>\r\n {graphTitle || graphDescription || graphDownload || dataDownload ? (\r\n <GraphHeader\r\n styles={{\r\n title: styles?.title,\r\n description: styles?.description,\r\n }}\r\n classNames={{\r\n title: classNames?.title,\r\n description: classNames?.description,\r\n }}\r\n graphTitle={graphTitle}\r\n graphDescription={graphDescription}\r\n width={width}\r\n graphDownload={graphDownload ? graphParentDiv.current : undefined}\r\n dataDownload={\r\n dataDownload\r\n ? data.map(d => d.data).filter(d => d !== undefined).length > 0\r\n ? data.map(d => d.data).filter(d => d !== undefined)\r\n : data.filter(d => d !== undefined)\r\n : null\r\n }\r\n />\r\n ) : null}\r\n {timeline.enabled && uniqDatesSorted.length > 0 && markObj ? (\r\n <div className='flex gap-6 items-center' dir='ltr'>\r\n <button\r\n type='button'\r\n onClick={() => {\r\n setPlay(!play);\r\n }}\r\n className='p-0 border-0 cursor-pointer bg-transparent'\r\n aria-label={play ? 'Click to pause animation' : 'Click to play animation'}\r\n >\r\n {play ? <Pause /> : <Play />}\r\n </button>\r\n <SliderUI\r\n min={uniqDatesSorted[0]}\r\n max={uniqDatesSorted[uniqDatesSorted.length - 1]}\r\n marks={markObj}\r\n step={null}\r\n defaultValue={uniqDatesSorted[uniqDatesSorted.length - 1]}\r\n value={uniqDatesSorted[index]}\r\n onChangeComplete={nextValue => {\r\n setIndex(uniqDatesSorted.indexOf(nextValue as number));\r\n }}\r\n onChange={nextValue => {\r\n setIndex(uniqDatesSorted.indexOf(nextValue as number));\r\n }}\r\n aria-label='Time slider. Use arrow keys to adjust selected time period.'\r\n />\r\n </div>\r\n ) : null}\r\n <div className='grow flex flex-col justify-center gap-3 w-full'>\r\n {data.length === 0 ? (\r\n <EmptyState />\r\n ) : (\r\n <>\r\n {showColorScale && data.filter(el => el.color).length !== 0 ? (\r\n <ColorLegendWithMouseOver\r\n width={width}\r\n colorLegendTitle={colorLegendTitle}\r\n colors={\r\n (colors as string[] | undefined) || Colors[theme].categoricalColors.colors\r\n }\r\n colorDomain={colorDomain || (uniqBy(data, 'color', true) as string[])}\r\n setSelectedColor={setSelectedColor}\r\n showNAColor={showNAColor}\r\n />\r\n ) : null}\r\n <div\r\n className='flex grow flex-col justify-center w-full leading-0'\r\n ref={graphDiv}\r\n aria-label='Graph area'\r\n >\r\n {(width || svgWidth) && (height || svgHeight) ? (\r\n <Graph\r\n data={\r\n sortData\r\n ? orderBy(\r\n ensureCompleteDataForBarChart(data, timeline.dateFormat || 'yyyy')\r\n .filter(d =>\r\n timeline.enabled\r\n ? d.date ===\r\n format(\r\n new Date(uniqDatesSorted[index]),\r\n timeline.dateFormat || 'yyyy',\r\n )\r\n : d,\r\n )\r\n .filter(d => (filterNA ? !checkIfNullOrUndefined(d.size) : d)),\r\n [\r\n d =>\r\n d.size === undefined\r\n ? sortData === 'asc'\r\n ? -Infinity\r\n : Infinity\r\n : d.size,\r\n ],\r\n [sortData],\r\n ).filter((_d, i) => (maxNumberOfBars ? i < maxNumberOfBars : true))\r\n : ensureCompleteDataForBarChart(data, timeline.dateFormat || 'yyyy')\r\n .filter(d =>\r\n timeline.enabled\r\n ? d.date ===\r\n format(\r\n new Date(uniqDatesSorted[index]),\r\n timeline.dateFormat || 'yyyy',\r\n )\r\n : d,\r\n )\r\n .filter(d => (filterNA ? !checkIfNullOrUndefined(d.size) : d))\r\n .filter((_d, i) => (maxNumberOfBars ? i < maxNumberOfBars : true))\r\n }\r\n barColor={\r\n data.filter(el => el.color).length === 0\r\n ? colors\r\n ? [colors as string]\r\n : [Colors.primaryColors['blue-600']]\r\n : (colors as string[] | undefined) ||\r\n Colors[theme].categoricalColors.colors\r\n }\r\n colorDomain={\r\n data.filter(el => el.color).length === 0\r\n ? []\r\n : colorDomain || (uniqBy(data, 'color', true) as string[])\r\n }\r\n width={width || svgWidth}\r\n refValues={refValues}\r\n height={Math.max(\r\n minHeight,\r\n height ||\r\n (relativeHeight\r\n ? minHeight\r\n ? (width || svgWidth) * relativeHeight > minHeight\r\n ? (width || svgWidth) * relativeHeight\r\n : minHeight\r\n : (width || svgWidth) * relativeHeight\r\n : svgHeight),\r\n )}\r\n suffix={suffix}\r\n prefix={prefix}\r\n barPadding={barPadding}\r\n showLabels={showLabels}\r\n showValues={showValues}\r\n showTicks={showTicks}\r\n truncateBy={truncateBy}\r\n leftMargin={leftMargin}\r\n rightMargin={rightMargin}\r\n selectedColor={selectedColor}\r\n topMargin={topMargin}\r\n bottomMargin={bottomMargin}\r\n tooltip={tooltip}\r\n onSeriesMouseOver={onSeriesMouseOver}\r\n maxValue={\r\n !checkIfNullOrUndefined(maxValue)\r\n ? (maxValue as number)\r\n : Math.max(\r\n ...data\r\n .filter(d => !checkIfNullOrUndefined(d.size))\r\n .map(d => d.size as number),\r\n ) < 0\r\n ? 0\r\n : Math.max(\r\n ...data\r\n .filter(d => !checkIfNullOrUndefined(d.size))\r\n .map(d => d.size as number),\r\n )\r\n }\r\n minValue={\r\n !checkIfNullOrUndefined(minValue)\r\n ? (minValue as number)\r\n : Math.min(\r\n ...data\r\n .filter(d => !checkIfNullOrUndefined(d.size))\r\n .map(d => d.size as number),\r\n ) >= 0\r\n ? 0\r\n : Math.min(\r\n ...data\r\n .filter(d => !checkIfNullOrUndefined(d.size))\r\n .map(d => d.size as number),\r\n )\r\n }\r\n highlightedDataPoints={highlightedDataPoints}\r\n onSeriesMouseClick={onSeriesMouseClick}\r\n labelOrder={labelOrder}\r\n maxBarThickness={maxBarThickness}\r\n minBarThickness={minBarThickness}\r\n resetSelectionOnDoubleClick={resetSelectionOnDoubleClick}\r\n detailsOnClick={detailsOnClick}\r\n barAxisTitle={barAxisTitle}\r\n noOfTicks={noOfTicks}\r\n valueColor={valueColor}\r\n styles={styles}\r\n classNames={classNames}\r\n animate={\r\n animate === true\r\n ? { duration: 0.5, once: true, amount: 0.5 }\r\n : animate || { duration: 0, once: true, amount: 0 }\r\n }\r\n dimmedOpacity={dimmedOpacity}\r\n precision={precision}\r\n customLayers={customLayers}\r\n naLabel={naLabel}\r\n />\r\n ) : null}\r\n </div>\r\n </>\r\n )}\r\n </div>\r\n {sources || footNote ? (\r\n <GraphFooter\r\n styles={{ footnote: styles?.footnote, source: styles?.source }}\r\n classNames={{\r\n footnote: classNames?.footnote,\r\n source: classNames?.source,\r\n }}\r\n sources={sources}\r\n footNote={footNote}\r\n width={width}\r\n />\r\n ) : null}\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n );\r\n}\r\n","import isEqual from 'fast-deep-equal';\r\nimport { scaleLinear, scaleBand } from 'd3-scale';\r\nimport { useRef, useState } from 'react';\r\nimport { cn } from '@undp/design-system-react/cn';\r\nimport { Modal } from '@undp/design-system-react/Modal';\r\nimport { AnimatePresence, motion, useInView } from 'motion/react';\r\n\r\nimport { numberFormattingFunction } from '@/Utils/numberFormattingFunction';\r\nimport {\r\n ReferenceDataType,\r\n GroupedBarGraphDataType,\r\n StyleObject,\r\n ClassNameObject,\r\n CustomLayerDataType,\r\n AnimateDataType,\r\n} from '@/Types';\r\nimport { Tooltip } from '@/Components/Elements/Tooltip';\r\nimport { checkIfNullOrUndefined } from '@/Utils/checkIfNullOrUndefined';\r\nimport { string2HTML } from '@/Utils/string2HTML';\r\nimport { AxisTitle } from '@/Components/Elements/Axes/AxisTitle';\r\nimport { Axis } from '@/Components/Elements/Axes/Axis';\r\nimport { XAxesLabels } from '@/Components/Elements/Axes/XAxesLabels';\r\nimport { RefLineY } from '@/Components/Elements/ReferenceLine';\r\nimport { YTicksAndGridLines } from '@/Components/Elements/Axes/YTicksAndGridLines';\r\n\r\ninterface Props {\r\n data: GroupedBarGraphDataType[];\r\n width: number;\r\n height: number;\r\n barColors: string[];\r\n suffix: string;\r\n prefix: string;\r\n barPadding: number;\r\n showLabels: boolean;\r\n showValues: boolean;\r\n showTicks: boolean;\r\n truncateBy: number;\r\n leftMargin: number;\r\n rightMargin: number;\r\n topMargin: number;\r\n bottomMargin: number;\r\n refValues?: ReferenceDataType[];\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n tooltip?: string | ((_d: any) => React.ReactNode);\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseOver?: (_d: any) => void;\r\n maxValue: number;\r\n minValue: number;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseClick?: (_d: any) => void;\r\n selectedColor?: string;\r\n labelOrder?: string[];\r\n maxBarThickness?: number;\r\n resetSelectionOnDoubleClick: boolean;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n detailsOnClick?: string | ((_d: any) => React.ReactNode);\r\n barAxisTitle?: string;\r\n noOfTicks: number;\r\n valueColor?: string;\r\n styles?: StyleObject;\r\n classNames?: ClassNameObject;\r\n animate: AnimateDataType;\r\n colorDomain: string[];\r\n precision: number;\r\n customLayers: CustomLayerDataType[];\r\n naLabel: string;\r\n}\r\n\r\nexport function Graph(props: Props) {\r\n const {\r\n data,\r\n width,\r\n height,\r\n barColors,\r\n suffix,\r\n prefix,\r\n barPadding,\r\n showLabels,\r\n showValues,\r\n showTicks,\r\n truncateBy,\r\n leftMargin,\r\n rightMargin,\r\n topMargin,\r\n bottomMargin,\r\n tooltip,\r\n onSeriesMouseOver,\r\n refValues,\r\n maxValue,\r\n minValue,\r\n onSeriesMouseClick,\r\n selectedColor,\r\n labelOrder,\r\n maxBarThickness,\r\n resetSelectionOnDoubleClick,\r\n detailsOnClick,\r\n barAxisTitle,\r\n valueColor,\r\n noOfTicks,\r\n styles,\r\n classNames,\r\n animate,\r\n colorDomain,\r\n precision,\r\n customLayers,\r\n naLabel,\r\n } = props;\r\n const svgRef = useRef(null);\r\n const isInView = useInView(svgRef, {\r\n once: animate.once,\r\n amount: animate.amount,\r\n });\r\n const margin = {\r\n top: topMargin,\r\n bottom: bottomMargin,\r\n left: barAxisTitle ? leftMargin + 30 : leftMargin,\r\n right: rightMargin,\r\n };\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const [mouseOverData, setMouseOverData] = useState<any>(undefined);\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const [mouseClickData, setMouseClickData] = useState<any>(undefined);\r\n const [eventX, setEventX] = useState<number | undefined>(undefined);\r\n const [eventY, setEventY] = useState<number | undefined>(undefined);\r\n const graphWidth = width - margin.left - margin.right;\r\n const graphHeight = height - margin.top - margin.bottom;\r\n\r\n const y = scaleLinear().domain([minValue, maxValue]).range([graphHeight, 0]).nice();\r\n\r\n const dataWithId = data.map((d, i) => ({\r\n ...d,\r\n id: labelOrder ? `${d.label}` : `${i}`,\r\n }));\r\n const barOrder = labelOrder || dataWithId.map(d => `${d.id}`);\r\n const x = scaleBand()\r\n .domain(barOrder)\r\n .range([\r\n 0,\r\n maxBarThickness ? Math.min(graphWidth, maxBarThickness * barOrder.length) : graphWidth,\r\n ])\r\n .paddingInner(barPadding);\r\n const subBarScale = scaleBand()\r\n .domain(data[0].size.map((_d, i) => `${i}`))\r\n .range([0, x.bandwidth()])\r\n .paddingInner(0.1);\r\n const yTicks = y.ticks(noOfTicks);\r\n return (\r\n <>\r\n <motion.svg\r\n width={`${width}px`}\r\n height={`${height}px`}\r\n viewBox={`0 0 ${width} ${height}`}\r\n direction='ltr'\r\n ref={svgRef}\r\n >\r\n <g transform={`translate(${margin.left},${margin.top})`}>\r\n <Axis\r\n y1={y(minValue < 0 ? 0 : minValue)}\r\n y2={y(minValue < 0 ? 0 : minValue)}\r\n x1={0 - leftMargin}\r\n x2={graphWidth + margin.right}\r\n label={numberFormattingFunction(\r\n minValue < 0 ? 0 : minValue,\r\n naLabel,\r\n precision,\r\n prefix,\r\n suffix,\r\n )}\r\n labelPos={{\r\n x: 0 - leftMargin,\r\n dx: 0,\r\n dy: maxValue < 0 ? '1em' : -5,\r\n y: y(minValue < 0 ? 0 : minValue),\r\n }}\r\n classNames={{\r\n axis: classNames?.xAxis?.axis,\r\n label: classNames?.yAxis?.labels,\r\n }}\r\n styles={{ axis: styles?.xAxis?.axis, label: styles?.yAxis?.labels }}\r\n />\r\n {showTicks ? (\r\n <YTicksAndGridLines\r\n values={yTicks.filter(d => d !== 0)}\r\n y={yTicks.filter(d => d !== 0).map(d => y(d))}\r\n x1={0 - leftMargin}\r\n x2={graphWidth + margin.right}\r\n styles={{\r\n gridLines: styles?.yAxis?.gridLines,\r\n labels: styles?.yAxis?.labels,\r\n }}\r\n classNames={{\r\n gridLines: classNames?.yAxis?.gridLines,\r\n labels: classNames?.yAxis?.labels,\r\n }}\r\n suffix={suffix}\r\n prefix={prefix}\r\n labelType='secondary'\r\n showGridLines\r\n labelPos='vertical'\r\n precision={precision}\r\n />\r\n ) : null}\r\n <AxisTitle\r\n x={0 - leftMargin - 15}\r\n y={graphHeight / 2}\r\n style={styles?.yAxis?.title}\r\n className={classNames?.yAxis?.title}\r\n text={barAxisTitle}\r\n rotate90\r\n />\r\n {customLayers.filter(d => d.position === 'before').map(d => d.layer)}\r\n <AnimatePresence>\r\n {dataWithId.map(d =>\r\n !checkIfNullOrUndefined(x(d.id)) ? (\r\n <motion.g\r\n key={d.label}\r\n variants={{\r\n initial: {\r\n x: x(`${d.id}`),\r\n y: 0,\r\n },\r\n whileInView: {\r\n x: x(`${d.id}`),\r\n y: 0,\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n >\r\n {d.size.map((el, j) => (\r\n <motion.g\r\n className='undp-viz-g-with-hover'\r\n key={`${d.label}-${colorDomain[j] || j}`}\r\n opacity={selectedColor ? (barColors[j] === selectedColor ? 1 : 0.3) : 0.85}\r\n onMouseEnter={event => {\r\n setMouseOverData({ ...d, sizeIndex: j });\r\n setEventY(event.clientY);\r\n setEventX(event.clientX);\r\n onSeriesMouseOver?.({ ...d, sizeIndex: j });\r\n }}\r\n onMouseMove={event => {\r\n setMouseOverData({ ...d, sizeIndex: j });\r\n setEventY(event.clientY);\r\n setEventX(event.clientX);\r\n }}\r\n onMouseLeave={() => {\r\n setMouseOverData(undefined);\r\n setEventX(undefined);\r\n setEventY(undefined);\r\n onSeriesMouseOver?.(undefined);\r\n }}\r\n onClick={() => {\r\n if (onSeriesMouseClick || detailsOnClick) {\r\n if (\r\n isEqual(mouseClickData, { ...d, sizeIndex: j }) &&\r\n resetSelectionOnDoubleClick\r\n ) {\r\n setMouseClickData(undefined);\r\n onSeriesMouseClick?.(undefined);\r\n } else {\r\n setMouseClickData({ ...d, sizeIndex: j });\r\n if (onSeriesMouseClick) onSeriesMouseClick({ ...d, sizeIndex: j });\r\n }\r\n }\r\n }}\r\n >\r\n <motion.rect\r\n x={subBarScale(`${j}`)}\r\n width={subBarScale.bandwidth()}\r\n variants={{\r\n initial: {\r\n height: 0,\r\n y: y(0),\r\n fill: barColors[j],\r\n },\r\n whileInView: {\r\n height: !checkIfNullOrUndefined(el)\r\n ? Math.abs(y(el as number) - y(0))\r\n : 0,\r\n y: !checkIfNullOrUndefined(el)\r\n ? (el as number) > 0\r\n ? y(el as number)\r\n : y(0)\r\n : y(0),\r\n fill: barColors[j],\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n exit={{\r\n height: 0,\r\n y: y(0),\r\n transition: { duration: animate.duration },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n />\r\n {showValues ? (\r\n <motion.text\r\n x={(subBarScale(`${j}`) as number) + subBarScale.bandwidth() / 2}\r\n style={{\r\n fill: valueColor || barColors[j],\r\n textAnchor: 'middle',\r\n ...(styles?.graphObjectValues || {}),\r\n }}\r\n className={cn('graph-value text-sm', classNames?.graphObjectValues)}\r\n dy={el ? (el >= 0 ? '-5px' : '1em') : '-5px'}\r\n variants={{\r\n initial: { y: y(0), opacity: 0 },\r\n whileInView: {\r\n y: y(el || 0),\r\n opacity: 1,\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n exit={{\r\n opacity: 0,\r\n transition: { duration: animate.duration },\r\n }}\r\n >\r\n {numberFormattingFunction(el, naLabel, precision, prefix, suffix)}\r\n </motion.text>\r\n ) : null}\r\n </motion.g>\r\n ))}\r\n {showLabels ? (\r\n <XAxesLabels\r\n value={\r\n `${d.label}`.length < truncateBy\r\n ? `${d.label}`\r\n : `${`${d.label}`.substring(0, truncateBy)}...`\r\n }\r\n y={y(0) + 5}\r\n x={0}\r\n width={x.bandwidth()}\r\n height={margin.bottom}\r\n style={styles?.xAxis?.labels}\r\n className={classNames?.xAxis?.labels}\r\n alignment='top'\r\n animate={animate}\r\n isInView={isInView}\r\n />\r\n ) : null}\r\n </motion.g>\r\n ) : null,\r\n )}\r\n {refValues ? (\r\n <>\r\n {refValues.map((el, i) => (\r\n <RefLineY\r\n key={i}\r\n text={el.text}\r\n color={el.color}\r\n y={y(el.value as number)}\r\n x1={0 - leftMargin}\r\n x2={graphWidth + margin.right}\r\n classNames={el.classNames}\r\n styles={el.styles}\r\n animate={animate}\r\n isInView={isInView}\r\n />\r\n ))}\r\n </>\r\n ) : null}\r\n </AnimatePresence>\r\n {customLayers.filter(d => d.position === 'after').map(d => d.layer)}\r\n </g>\r\n </motion.svg>\r\n {mouseOverData && tooltip && eventX && eventY ? (\r\n <Tooltip\r\n data={mouseOverData}\r\n body={tooltip}\r\n xPos={eventX}\r\n yPos={eventY}\r\n backgroundStyle={styles?.tooltip}\r\n className={classNames?.tooltip}\r\n />\r\n ) : null}\r\n {detailsOnClick && mouseClickData !== undefined ? (\r\n <Modal\r\n open={mouseClickData !== undefined}\r\n onClose={() => {\r\n setMouseClickData(undefined);\r\n }}\r\n >\r\n <div\r\n className='graph-modal-content m-0'\r\n dangerouslySetInnerHTML={\r\n typeof detailsOnClick === 'string'\r\n ? { __html: string2HTML(detailsOnClick, mouseClickData) }\r\n : undefined\r\n }\r\n >\r\n {typeof detailsOnClick === 'function' ? detailsOnClick(mouseClickData) : null}\r\n </div>\r\n </Modal>\r\n ) : null}\r\n </>\r\n );\r\n}\r\n","import { useState, useRef, useEffect } from 'react';\r\nimport { cn } from '@undp/design-system-react/cn';\r\nimport { SliderUI } from '@undp/design-system-react/SliderUI';\r\nimport { format } from 'date-fns/format';\r\nimport { parse } from 'date-fns/parse';\r\nimport { ascending, sort } from 'd3-array';\r\nimport orderBy from 'lodash.orderby';\r\nimport sum from 'lodash.sum';\r\n\r\nimport { Graph } from './Graph';\r\n\r\nimport {\r\n ReferenceDataType,\r\n GroupedBarGraphDataType,\r\n SourcesDataType,\r\n Languages,\r\n StyleObject,\r\n ClassNameObject,\r\n CustomLayerDataType,\r\n AnimateDataType,\r\n TimelineDataType,\r\n} from '@/Types';\r\nimport { GraphHeader } from '@/Components/Elements/GraphHeader';\r\nimport { GraphFooter } from '@/Components/Elements/GraphFooter';\r\nimport { ColorLegendWithMouseOver } from '@/Components/Elements/ColorLegendWithMouseOver';\r\nimport { Colors } from '@/Components/ColorPalette';\r\nimport { EmptyState } from '@/Components/Elements/EmptyState';\r\nimport { checkIfNullOrUndefined } from '@/Utils/checkIfNullOrUndefined';\r\nimport { Pause, Play } from '@/Components/Icons';\r\nimport { getSliderMarks } from '@/Utils/getSliderMarks';\r\nimport { ensureCompleteDataForStackedBarChart } from '@/Utils/ensureCompleteData';\r\nimport { uniqBy } from '@/Utils/uniqBy';\r\n\r\ninterface Props {\r\n data: GroupedBarGraphDataType[];\r\n colors?: string[];\r\n graphTitle?: string | React.ReactNode;\r\n width?: number;\r\n height?: number;\r\n suffix?: string;\r\n prefix?: string;\r\n sources?: SourcesDataType[];\r\n graphDescription?: string | React.ReactNode;\r\n footNote?: string | React.ReactNode;\r\n barPadding?: number;\r\n showLabels?: boolean;\r\n showValues?: boolean;\r\n showTicks?: boolean;\r\n colorDomain: string[];\r\n colorLegendTitle?: string;\r\n showColorScale?: boolean;\r\n labelOrder?: string[];\r\n truncateBy?: number;\r\n sortParameter?: number | 'total';\r\n sortData?: 'asc' | 'desc';\r\n backgroundColor?: string | boolean;\r\n padding?: string;\r\n leftMargin?: number;\r\n rightMargin?: number;\r\n topMargin?: number;\r\n bottomMargin?: number;\r\n relativeHeight?: number;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n tooltip?: string | ((_d: any) => React.ReactNode);\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseOver?: (_d: any) => void;\r\n refValues?: ReferenceDataType[];\r\n graphID?: string;\r\n maxValue?: number;\r\n minValue?: number;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseClick?: (_d: any) => void;\r\n graphDownload?: boolean;\r\n dataDownload?: boolean;\r\n language?: Languages;\r\n minHeight?: number;\r\n theme?: 'light' | 'dark';\r\n maxBarThickness?: number;\r\n ariaLabel?: string;\r\n resetSelectionOnDoubleClick?: boolean;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n detailsOnClick?: string | ((_d: any) => React.ReactNode);\r\n barAxisTitle?: string;\r\n noOfTicks?: number;\r\n valueColor?: string;\r\n styles?: StyleObject;\r\n classNames?: ClassNameObject;\r\n filterNA?: boolean;\r\n animate?: boolean | AnimateDataType;\r\n precision?: number;\r\n customLayers?: CustomLayerDataType[];\r\n timeline?: TimelineDataType;\r\n naLabel?: string;\r\n}\r\n\r\nexport function VerticalGroupedBarGraph(props: Props) {\r\n const {\r\n data,\r\n graphTitle,\r\n colors = Colors.light.categoricalColors.colors,\r\n sources,\r\n graphDescription,\r\n barPadding = 0.25,\r\n showTicks = true,\r\n leftMargin = 20,\r\n rightMargin = 20,\r\n topMargin = 20,\r\n bottomMargin = 25,\r\n truncateBy = 999,\r\n showLabels = true,\r\n showValues = true,\r\n backgroundColor = false,\r\n suffix = '',\r\n prefix = '',\r\n height,\r\n width,\r\n footNote,\r\n colorDomain,\r\n colorLegendTitle,\r\n padding,\r\n relativeHeight,\r\n tooltip,\r\n onSeriesMouseOver,\r\n refValues,\r\n graphID,\r\n maxValue,\r\n minValue,\r\n onSeriesMouseClick,\r\n graphDownload = false,\r\n dataDownload = false,\r\n language = 'en',\r\n theme = 'light',\r\n labelOrder,\r\n minHeight = 0,\r\n maxBarThickness,\r\n ariaLabel,\r\n resetSelectionOnDoubleClick = true,\r\n detailsOnClick,\r\n barAxisTitle,\r\n noOfTicks = 5,\r\n valueColor,\r\n styles,\r\n classNames,\r\n filterNA = true,\r\n showColorScale = true,\r\n animate = false,\r\n precision = 2,\r\n customLayers = [],\r\n timeline = { enabled: false, autoplay: false, showOnlyActiveDate: true },\r\n naLabel = 'NA',\r\n sortParameter,\r\n sortData,\r\n } = props;\r\n\r\n const [svgWidth, setSvgWidth] = useState(0);\r\n const [svgHeight, setSvgHeight] = useState(0);\r\n const [play, setPlay] = useState(timeline.autoplay);\r\n const uniqDatesSorted = sort(\r\n uniqBy(data, 'date', true).map(d =>\r\n parse(`${d}`, timeline.dateFormat || 'yyyy', new Date()).getTime(),\r\n ),\r\n (a, b) => ascending(a, b),\r\n );\r\n const [index, setIndex] = useState(timeline.autoplay ? 0 : uniqDatesSorted.length - 1);\r\n const [selectedColor, setSelectedColor] = useState<string | undefined>(undefined);\r\n\r\n const graphDiv = useRef<HTMLDivElement>(null);\r\n const graphParentDiv = useRef<HTMLDivElement>(null);\r\n useEffect(() => {\r\n const resizeObserver = new ResizeObserver(entries => {\r\n setSvgWidth(width || entries[0].target.clientWidth || 620);\r\n setSvgHeight(height || entries[0].target.clientHeight || 480);\r\n });\r\n if (graphDiv.current) {\r\n setSvgHeight(graphDiv.current.clientHeight || 480);\r\n setSvgWidth(graphDiv.current.clientWidth || 620);\r\n if (!width) resizeObserver.observe(graphDiv.current);\r\n }\r\n return () => resizeObserver.disconnect();\r\n }, [width, height]);\r\n\r\n useEffect(() => {\r\n const interval = setInterval(\r\n () => {\r\n setIndex(i => (i < uniqDatesSorted.length - 1 ? i + 1 : 0));\r\n },\r\n (timeline.speed || 2) * 1000,\r\n );\r\n if (!play) clearInterval(interval);\r\n return () => clearInterval(interval);\r\n }, [uniqDatesSorted, play, timeline.speed]);\r\n\r\n const markObj = getSliderMarks(\r\n uniqDatesSorted,\r\n index,\r\n timeline.showOnlyActiveDate,\r\n timeline.dateFormat || 'yyyy',\r\n );\r\n\r\n return (\r\n <div\r\n className={`${theme || 'light'} flex ${width ? 'w-fit grow-0' : 'w-full grow'}`}\r\n dir={language === 'he' || language === 'ar' ? 'rtl' : undefined}\r\n >\r\n <div\r\n className={cn(\r\n `${\r\n !backgroundColor\r\n ? 'bg-transparent '\r\n : backgroundColor === true\r\n ? 'bg-primary-gray-200 dark:bg-primary-gray-650 '\r\n : ''\r\n }ml-auto mr-auto flex flex-col grow h-inherit ${language || 'en'}`,\r\n width ? 'w-fit' : 'w-full',\r\n classNames?.graphContainer,\r\n )}\r\n style={{\r\n ...(styles?.graphContainer || {}),\r\n ...(backgroundColor && backgroundColor !== true ? { backgroundColor } : {}),\r\n }}\r\n id={graphID}\r\n ref={graphParentDiv}\r\n aria-label={\r\n ariaLabel ||\r\n `${graphTitle ? `The graph shows ${graphTitle}. ` : ''}This is a grouped bar chart. ${\r\n graphDescription ? ` ${graphDescription}` : ''\r\n }`\r\n }\r\n >\r\n <div\r\n className='flex grow'\r\n style={{ padding: backgroundColor ? padding || '1rem' : padding || 0 }}\r\n >\r\n <div className='flex flex-col w-full gap-4 grow justify-between'>\r\n {graphTitle || graphDescription || graphDownload || dataDownload ? (\r\n <GraphHeader\r\n styles={{\r\n title: styles?.title,\r\n description: styles?.description,\r\n }}\r\n classNames={{\r\n title: classNames?.title,\r\n description: classNames?.description,\r\n }}\r\n graphTitle={graphTitle}\r\n graphDescription={graphDescription}\r\n width={width}\r\n graphDownload={graphDownload ? graphParentDiv.current : undefined}\r\n dataDownload={\r\n dataDownload\r\n ? data.map(d => d.data).filter(d => d !== undefined).length > 0\r\n ? data.map(d => d.data).filter(d => d !== undefined)\r\n : data.filter(d => d !== undefined)\r\n : null\r\n }\r\n />\r\n ) : null}\r\n {timeline.enabled && uniqDatesSorted.length > 0 && markObj ? (\r\n <div className='flex gap-6 items-center' dir='ltr'>\r\n <button\r\n type='button'\r\n onClick={() => {\r\n setPlay(!play);\r\n }}\r\n className='p-0 border-0 cursor-pointer bg-transparent'\r\n aria-label={play ? 'Click to pause animation' : 'Click to play animation'}\r\n >\r\n {play ? <Pause /> : <Play />}\r\n </button>\r\n <SliderUI\r\n min={uniqDatesSorted[0]}\r\n max={uniqDatesSorted[uniqDatesSorted.length - 1]}\r\n marks={markObj}\r\n step={null}\r\n defaultValue={uniqDatesSorted[uniqDatesSorted.length - 1]}\r\n value={uniqDatesSorted[index]}\r\n onChangeComplete={nextValue => {\r\n setIndex(uniqDatesSorted.indexOf(nextValue as number));\r\n }}\r\n onChange={nextValue => {\r\n setIndex(uniqDatesSorted.indexOf(nextValue as number));\r\n }}\r\n aria-label='Time slider. Use arrow keys to adjust selected time period.'\r\n />\r\n </div>\r\n ) : null}\r\n <div className='grow flex flex-col justify-center gap-3 w-full'>\r\n {data.length === 0 ? (\r\n <EmptyState />\r\n ) : (\r\n <>\r\n {showColorScale ? (\r\n <ColorLegendWithMouseOver\r\n width={width}\r\n colorDomain={colorDomain}\r\n colors={colors}\r\n colorLegendTitle={colorLegendTitle}\r\n setSelectedColor={setSelectedColor}\r\n showNAColor={false}\r\n />\r\n ) : null}\r\n <div className='w-full grow leading-0' ref={graphDiv} aria-label='Graph area'>\r\n {(width || svgWidth) && (height || svgHeight) ? (\r\n <Graph\r\n data={\r\n sortParameter !== undefined\r\n ? sortParameter === 'total'\r\n ? orderBy(\r\n ensureCompleteDataForStackedBarChart(\r\n data,\r\n timeline.dateFormat || 'yyyy',\r\n )\r\n .filter(d =>\r\n timeline.enabled\r\n ? d.date ===\r\n format(\r\n new Date(uniqDatesSorted[index]),\r\n timeline.dateFormat || 'yyyy',\r\n )\r\n : d,\r\n )\r\n .filter(d =>\r\n filterNA ? !d.size.every(item => item == null) : d,\r\n ),\r\n d => sum(d.size.filter(el => !checkIfNullOrUndefined(el))),\r\n [sortData || 'asc'],\r\n )\r\n : orderBy(\r\n ensureCompleteDataForStackedBarChart(\r\n data,\r\n timeline.dateFormat || 'yyyy',\r\n )\r\n .filter(d =>\r\n timeline.enabled\r\n ? d.date ===\r\n format(\r\n new Date(uniqDatesSorted[index]),\r\n timeline.dateFormat || 'yyyy',\r\n )\r\n : d,\r\n )\r\n .filter(d =>\r\n filterNA ? !d.size.every(item => item == null) : d,\r\n ),\r\n d =>\r\n checkIfNullOrUndefined(d.size[sortParameter])\r\n ? -Infinity\r\n : d.size[sortParameter],\r\n [sortData || 'asc'],\r\n )\r\n : ensureCompleteDataForStackedBarChart(\r\n data,\r\n timeline.dateFormat || 'yyyy',\r\n ).filter(d => (filterNA ? !d.size.every(item => item == null) : d))\r\n }\r\n barColors={colors}\r\n width={width || svgWidth}\r\n height={Math.max(\r\n minHeight,\r\n height ||\r\n (relativeHeight\r\n ? minHeight\r\n ? (width || svgWidth) * relativeHeight > minHeight\r\n ? (width || svgWidth) * relativeHeight\r\n : minHeight\r\n : (width || svgWidth) * relativeHeight\r\n : svgHeight),\r\n )}\r\n suffix={suffix}\r\n prefix={prefix}\r\n barPadding={barPadding}\r\n showLabels={showLabels}\r\n showValues={showValues}\r\n showTicks={showTicks}\r\n truncateBy={truncateBy}\r\n leftMargin={leftMargin}\r\n rightMargin={rightMargin}\r\n topMargin={topMargin}\r\n bottomMargin={bottomMargin}\r\n tooltip={tooltip}\r\n onSeriesMouseOver={onSeriesMouseOver}\r\n refValues={refValues}\r\n maxValue={\r\n !checkIfNullOrUndefined(maxValue)\r\n ? (maxValue as number)\r\n : Math.max(\r\n ...data.map(d =>\r\n Math.max(\r\n ...(d.size.filter(\r\n l => !checkIfNullOrUndefined(l),\r\n ) as number[]),\r\n ),\r\n ),\r\n ) < 0\r\n ? 0\r\n : Math.max(\r\n ...data.map(d =>\r\n Math.max(\r\n ...(d.size.filter(\r\n l => !checkIfNullOrUndefined(l),\r\n ) as number[]),\r\n ),\r\n ),\r\n )\r\n }\r\n minValue={\r\n !checkIfNullOrUndefined(minValue)\r\n ? (minValue as number)\r\n : Math.min(\r\n ...data.map(d =>\r\n Math.min(\r\n ...(d.size.filter(\r\n l => !checkIfNullOrUndefined(l),\r\n ) as number[]),\r\n ),\r\n ),\r\n ) >= 0\r\n ? 0\r\n : Math.min(\r\n ...data.map(d =>\r\n Math.min(\r\n ...(d.size.filter(\r\n l => !checkIfNullOrUndefined(l),\r\n ) as number[]),\r\n ),\r\n ),\r\n )\r\n }\r\n onSeriesMouseClick={onSeriesMouseClick}\r\n selectedColor={selectedColor}\r\n labelOrder={labelOrder}\r\n maxBarThickness={maxBarThickness}\r\n resetSelectionOnDoubleClick={resetSelectionOnDoubleClick}\r\n detailsOnClick={detailsOnClick}\r\n barAxisTitle={barAxisTitle}\r\n noOfTicks={noOfTicks}\r\n valueColor={valueColor}\r\n styles={styles}\r\n classNames={classNames}\r\n animate={\r\n animate === true\r\n ? { duration: 0.5, once: true, amount: 0.5 }\r\n : animate || { duration: 0, once: true, amount: 0 }\r\n }\r\n colorDomain={colorDomain}\r\n precision={precision}\r\n customLayers={customLayers}\r\n naLabel={naLabel}\r\n />\r\n ) : null}\r\n </div>\r\n </>\r\n )}\r\n </div>\r\n {sources || footNote ? (\r\n <GraphFooter\r\n styles={{ footnote: styles?.footnote, source: styles?.source }}\r\n classNames={{\r\n footnote: classNames?.footnote,\r\n source: classNames?.source,\r\n }}\r\n sources={sources}\r\n footNote={footNote}\r\n width={width}\r\n />\r\n ) : null}\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n );\r\n}\r\n","import isEqual from 'fast-deep-equal';\r\nimport { scaleLinear, scaleBand } from 'd3-scale';\r\nimport sum from 'lodash.sum';\r\nimport { useRef, useState } from 'react';\r\nimport { cn } from '@undp/design-system-react/cn';\r\nimport { Modal } from '@undp/design-system-react/Modal';\r\nimport { AnimatePresence, motion, useInView } from 'motion/react';\r\n\r\nimport { numberFormattingFunction } from '@/Utils/numberFormattingFunction';\r\nimport {\r\n AnimateDataType,\r\n ClassNameObject,\r\n CustomLayerDataType,\r\n GroupedBarGraphDataType,\r\n ReferenceDataType,\r\n StyleObject,\r\n} from '@/Types';\r\nimport { Tooltip } from '@/Components/Elements/Tooltip';\r\nimport { checkIfNullOrUndefined } from '@/Utils/checkIfNullOrUndefined';\r\nimport { getTextColorBasedOnBgColor } from '@/Utils/getTextColorBasedOnBgColor';\r\nimport { string2HTML } from '@/Utils/string2HTML';\r\nimport { AxisTitle } from '@/Components/Elements/Axes/AxisTitle';\r\nimport { Axis } from '@/Components/Elements/Axes/Axis';\r\nimport { XAxesLabels } from '@/Components/Elements/Axes/XAxesLabels';\r\nimport { RefLineY } from '@/Components/Elements/ReferenceLine';\r\nimport { YTicksAndGridLines } from '@/Components/Elements/Axes/YTicksAndGridLines';\r\n\r\ninterface Props {\r\n data: GroupedBarGraphDataType[];\r\n width: number;\r\n height: number;\r\n barColors: string[];\r\n barPadding: number;\r\n showLabels: boolean;\r\n showTicks: boolean;\r\n truncateBy: number;\r\n leftMargin: number;\r\n rightMargin: number;\r\n topMargin: number;\r\n bottomMargin: number;\r\n suffix: string;\r\n prefix: string;\r\n showValues: boolean;\r\n refValues?: ReferenceDataType[];\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n tooltip?: string | ((_d: any) => React.ReactNode);\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseOver?: (_d: any) => void;\r\n maxValue: number;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseClick?: (_d: any) => void;\r\n selectedColor?: string;\r\n labelOrder?: string[];\r\n maxBarThickness?: number;\r\n minBarThickness?: number;\r\n resetSelectionOnDoubleClick: boolean;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n detailsOnClick?: string | ((_d: any) => React.ReactNode);\r\n barAxisTitle?: string;\r\n noOfTicks: number;\r\n valueColor?: string;\r\n styles?: StyleObject;\r\n classNames?: ClassNameObject;\r\n animate: AnimateDataType;\r\n colorDomain: string[];\r\n precision: number;\r\n customLayers: CustomLayerDataType[];\r\n naLabel: string;\r\n}\r\n\r\nexport function Graph(props: Props) {\r\n const {\r\n data,\r\n width,\r\n height,\r\n barColors,\r\n barPadding,\r\n showLabels,\r\n showTicks,\r\n truncateBy,\r\n leftMargin,\r\n topMargin,\r\n bottomMargin,\r\n rightMargin,\r\n tooltip,\r\n onSeriesMouseOver,\r\n suffix,\r\n prefix,\r\n showValues,\r\n refValues,\r\n maxValue,\r\n onSeriesMouseClick,\r\n selectedColor,\r\n labelOrder,\r\n maxBarThickness,\r\n minBarThickness,\r\n resetSelectionOnDoubleClick,\r\n detailsOnClick,\r\n barAxisTitle,\r\n valueColor,\r\n noOfTicks,\r\n styles,\r\n classNames,\r\n animate,\r\n colorDomain,\r\n precision,\r\n customLayers,\r\n naLabel,\r\n } = props;\r\n const svgRef = useRef(null);\r\n const isInView = useInView(svgRef, {\r\n once: animate.once,\r\n amount: animate.amount,\r\n });\r\n const margin = {\r\n top: topMargin,\r\n bottom: bottomMargin,\r\n left: barAxisTitle ? leftMargin + 30 : leftMargin,\r\n right: rightMargin,\r\n };\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const [mouseOverData, setMouseOverData] = useState<any>(undefined);\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const [mouseClickData, setMouseClickData] = useState<any>(undefined);\r\n const [eventX, setEventX] = useState<number | undefined>(undefined);\r\n const [eventY, setEventY] = useState<number | undefined>(undefined);\r\n const graphWidth = width - margin.left - margin.right;\r\n const graphHeight = height - margin.top - margin.bottom;\r\n\r\n const y = scaleLinear().domain([0, maxValue]).range([graphHeight, 0]).nice();\r\n const dataWithId = data.map((d, i) => ({\r\n ...d,\r\n id: labelOrder ? `${d.label}` : `${i}`,\r\n }));\r\n const barOrder = labelOrder || dataWithId.map(d => `${d.id}`);\r\n const x = scaleBand()\r\n .domain(barOrder)\r\n .range([\r\n 0,\r\n minBarThickness\r\n ? Math.max(graphWidth, minBarThickness * barOrder.length)\r\n : maxBarThickness\r\n ? Math.min(graphWidth, maxBarThickness * barOrder.length)\r\n : graphWidth,\r\n ])\r\n .paddingInner(barPadding);\r\n const yTicks = y.ticks(noOfTicks);\r\n return (\r\n <>\r\n <motion.svg\r\n width={`${width}px`}\r\n height={`${height}px`}\r\n viewBox={`0 0 ${width} ${height}`}\r\n direction='ltr'\r\n ref={svgRef}\r\n >\r\n <g transform={`translate(${margin.left},${margin.top})`}>\r\n <Axis\r\n y1={y(0)}\r\n y2={y(0)}\r\n x1={0 - leftMargin}\r\n x2={graphWidth + margin.right}\r\n label={numberFormattingFunction(0, naLabel, precision, prefix, suffix)}\r\n labelPos={{\r\n x: 0 - leftMargin,\r\n y: y(0),\r\n dx: 0,\r\n dy: -5,\r\n }}\r\n classNames={{\r\n axis: classNames?.xAxis?.axis,\r\n label: classNames?.yAxis?.labels,\r\n }}\r\n styles={{ axis: styles?.xAxis?.axis, label: styles?.yAxis?.labels }}\r\n />\r\n {showTicks ? (\r\n <YTicksAndGridLines\r\n values={yTicks.filter(d => d !== 0)}\r\n y={yTicks.filter(d => d !== 0).map(d => y(d))}\r\n x1={0 - leftMargin}\r\n x2={graphWidth + margin.right}\r\n styles={{\r\n gridLines: styles?.yAxis?.gridLines,\r\n labels: styles?.yAxis?.labels,\r\n }}\r\n classNames={{\r\n gridLines: classNames?.yAxis?.gridLines,\r\n labels: classNames?.yAxis?.labels,\r\n }}\r\n suffix={suffix}\r\n prefix={prefix}\r\n labelType='secondary'\r\n showGridLines\r\n labelPos='vertical'\r\n precision={precision}\r\n />\r\n ) : null}\r\n <AxisTitle\r\n x={0 - leftMargin - 15}\r\n y={graphHeight / 2}\r\n style={styles?.yAxis?.title}\r\n className={classNames?.yAxis?.title}\r\n text={barAxisTitle}\r\n rotate90\r\n />\r\n {customLayers.filter(d => d.position === 'before').map(d => d.layer)}\r\n <AnimatePresence>\r\n {dataWithId.map(d =>\r\n !checkIfNullOrUndefined(x(d.id)) ? (\r\n <motion.g\r\n className='undp-viz-low-opacity undp-viz-g-with-hover'\r\n key={d.label}\r\n variants={{\r\n initial: { x: x(`${d.id}`), y: 0 },\r\n whileInView: {\r\n x: x(`${d.id}`),\r\n y: 0,\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n transition={{ duration: animate.duration }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n >\r\n {d.size.map((el, j) => (\r\n <motion.g\r\n key={`${d.label}-${colorDomain[j] || j}`}\r\n opacity={selectedColor ? (barColors[j] === selectedColor ? 1 : 0.3) : 1}\r\n onMouseEnter={event => {\r\n setMouseOverData({ ...d, sizeIndex: j });\r\n setEventY(event.clientY);\r\n setEventX(event.clientX);\r\n onSeriesMouseOver?.({ ...d, sizeIndex: j });\r\n }}\r\n onMouseMove={event => {\r\n setMouseOverData({ ...d, sizeIndex: j });\r\n setEventY(event.clientY);\r\n setEventX(event.clientX);\r\n }}\r\n onMouseLeave={() => {\r\n setMouseOverData(undefined);\r\n setEventX(undefined);\r\n setEventY(undefined);\r\n onSeriesMouseOver?.(undefined);\r\n }}\r\n onClick={() => {\r\n if (onSeriesMouseClick || detailsOnClick) {\r\n if (\r\n isEqual(mouseClickData, { ...d, sizeIndex: j }) &&\r\n resetSelectionOnDoubleClick\r\n ) {\r\n setMouseClickData(undefined);\r\n onSeriesMouseClick?.(undefined);\r\n } else {\r\n setMouseClickData({ ...d, sizeIndex: j });\r\n if (onSeriesMouseClick) onSeriesMouseClick({ ...d, sizeIndex: j });\r\n }\r\n }\r\n }}\r\n >\r\n <motion.rect\r\n x={0}\r\n width={x.bandwidth()}\r\n variants={{\r\n initial: {\r\n height: 0,\r\n fill: barColors[j],\r\n y: y(0),\r\n },\r\n whileInView: {\r\n height: Math.abs(\r\n y(sum(d.size.filter((element, k) => k <= j && element))) -\r\n y(sum(d.size.filter((element, k) => k < j && element))),\r\n ),\r\n y: y(sum(d.size.filter((element, k) => k <= j && element))),\r\n fill: barColors[j],\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n exit={{\r\n height: 0,\r\n y: y(0),\r\n transition: { duration: animate.duration },\r\n }}\r\n />\r\n {showValues ? (\r\n <motion.text\r\n x={x.bandwidth() / 2}\r\n style={{\r\n fill: getTextColorBasedOnBgColor(barColors[j]),\r\n textAnchor: 'middle',\r\n ...(styles?.graphObjectValues || {}),\r\n }}\r\n className={cn('graph-value text-sm', classNames?.graphObjectValues)}\r\n dy='0.33em'\r\n variants={{\r\n initial: {\r\n y: y(0),\r\n opacity: 0,\r\n fill: getTextColorBasedOnBgColor(barColors[j]),\r\n },\r\n whileInView: {\r\n y:\r\n y(sum(d.size.filter((element, k) => k <= j && element))) +\r\n Math.abs(\r\n y(sum(d.size.filter((element, k) => k <= j && element))) -\r\n y(sum(d.size.filter((element, k) => k < j && element))),\r\n ) /\r\n 2,\r\n opacity:\r\n el &&\r\n Math.abs(\r\n y(sum(d.size.filter((element, k) => k <= j && element))) -\r\n y(sum(d.size.filter((element, k) => k < j && element))),\r\n ) > 20\r\n ? 1\r\n : 0,\r\n fill: getTextColorBasedOnBgColor(barColors[j]),\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n >\r\n {numberFormattingFunction(el, naLabel, precision, prefix, suffix)}\r\n </motion.text>\r\n ) : null}\r\n </motion.g>\r\n ))}\r\n {showLabels ? (\r\n <XAxesLabels\r\n value={\r\n `${d.label}`.length < truncateBy\r\n ? `${d.label}`\r\n : `${`${d.label}`.substring(0, truncateBy)}...`\r\n }\r\n y={y(0) + 5}\r\n x={0}\r\n width={x.bandwidth()}\r\n height={margin.bottom}\r\n style={styles?.xAxis?.labels}\r\n className={classNames?.xAxis?.labels}\r\n alignment='top'\r\n animate={animate}\r\n isInView={isInView}\r\n />\r\n ) : null}\r\n {showValues ? (\r\n <motion.text\r\n style={{\r\n ...(valueColor && { fill: valueColor }),\r\n textAnchor: 'middle',\r\n ...(styles?.graphObjectValues || {}),\r\n }}\r\n x={x.bandwidth() / 2}\r\n dy={-10}\r\n className={cn(\r\n 'graph-value graph-value-total',\r\n !valueColor\r\n ? 'fill-primary-gray-700 dark:fill-primary-gray-300 text-sm'\r\n : 'text-sm',\r\n classNames?.graphObjectValues,\r\n )}\r\n variants={{\r\n initial: {\r\n y: y(0),\r\n opacity: 0,\r\n },\r\n whileInView: {\r\n y: y(sum(d.size.map(el => el || 0))),\r\n opacity: 1,\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n exit={{\r\n opacity: 0,\r\n transition: { duration: animate.duration },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n >\r\n {numberFormattingFunction(\r\n sum(d.size.filter(element => element)),\r\n naLabel,\r\n precision,\r\n prefix,\r\n suffix,\r\n )}\r\n </motion.text>\r\n ) : null}\r\n </motion.g>\r\n ) : null,\r\n )}\r\n {refValues ? (\r\n <>\r\n {refValues.map((el, i) => (\r\n <RefLineY\r\n key={i}\r\n text={el.text}\r\n color={el.color}\r\n y={y(el.value as number)}\r\n x1={0 - leftMargin}\r\n x2={graphWidth + margin.right}\r\n classNames={el.classNames}\r\n styles={el.styles}\r\n animate={animate}\r\n isInView={isInView}\r\n />\r\n ))}\r\n </>\r\n ) : null}\r\n </AnimatePresence>\r\n {customLayers.filter(d => d.position === 'after').map(d => d.layer)}\r\n </g>\r\n </motion.svg>\r\n {mouseOverData && tooltip && eventX && eventY ? (\r\n <Tooltip\r\n data={mouseOverData}\r\n body={tooltip}\r\n xPos={eventX}\r\n yPos={eventY}\r\n backgroundStyle={styles?.tooltip}\r\n className={classNames?.tooltip}\r\n />\r\n ) : null}\r\n {detailsOnClick && mouseClickData !== undefined ? (\r\n <Modal\r\n open={mouseClickData !== undefined}\r\n onClose={() => {\r\n setMouseClickData(undefined);\r\n }}\r\n >\r\n <div\r\n className='graph-modal-content m-0'\r\n dangerouslySetInnerHTML={\r\n typeof detailsOnClick === 'string'\r\n ? { __html: string2HTML(detailsOnClick, mouseClickData) }\r\n : undefined\r\n }\r\n >\r\n {typeof detailsOnClick === 'function' ? detailsOnClick(mouseClickData) : null}\r\n </div>\r\n </Modal>\r\n ) : null}\r\n </>\r\n );\r\n}\r\n","import { useEffect, useRef, useState } from 'react';\r\nimport sum from 'lodash.sum';\r\nimport { format } from 'date-fns/format';\r\nimport { parse } from 'date-fns/parse';\r\nimport { cn } from '@undp/design-system-react/cn';\r\nimport { SliderUI } from '@undp/design-system-react/SliderUI';\r\nimport { ascending, sort } from 'd3-array';\r\nimport orderBy from 'lodash.orderby';\r\n\r\nimport { Graph } from './Graph';\r\n\r\nimport {\r\n ReferenceDataType,\r\n GroupedBarGraphDataType,\r\n SourcesDataType,\r\n Languages,\r\n StyleObject,\r\n ClassNameObject,\r\n CustomLayerDataType,\r\n AnimateDataType,\r\n TimelineDataType,\r\n} from '@/Types';\r\nimport { checkIfNullOrUndefined } from '@/Utils/checkIfNullOrUndefined';\r\nimport { GraphFooter } from '@/Components/Elements/GraphFooter';\r\nimport { GraphHeader } from '@/Components/Elements/GraphHeader';\r\nimport { ColorLegendWithMouseOver } from '@/Components/Elements/ColorLegendWithMouseOver';\r\nimport { Colors } from '@/Components/ColorPalette';\r\nimport { EmptyState } from '@/Components/Elements/EmptyState';\r\nimport { Pause, Play } from '@/Components/Icons';\r\nimport { getSliderMarks } from '@/Utils/getSliderMarks';\r\nimport { ensureCompleteDataForStackedBarChart } from '@/Utils/ensureCompleteData';\r\nimport { uniqBy } from '@/Utils/uniqBy';\r\n\r\ninterface Props {\r\n data: GroupedBarGraphDataType[];\r\n colors?: string[];\r\n graphTitle?: string | React.ReactNode;\r\n width?: number;\r\n labelOrder?: string[];\r\n height?: number;\r\n sources?: SourcesDataType[];\r\n graphDescription?: string | React.ReactNode;\r\n footNote?: string | React.ReactNode;\r\n barPadding?: number;\r\n showLabels?: boolean;\r\n showTicks?: boolean;\r\n colorDomain: string[];\r\n colorLegendTitle?: string;\r\n showColorScale?: boolean;\r\n truncateBy?: number;\r\n backgroundColor?: string | boolean;\r\n padding?: string;\r\n leftMargin?: number;\r\n rightMargin?: number;\r\n topMargin?: number;\r\n bottomMargin?: number;\r\n showValues?: boolean;\r\n suffix?: string;\r\n prefix?: string;\r\n relativeHeight?: number;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n tooltip?: string | ((_d: any) => React.ReactNode);\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseOver?: (_d: any) => void;\r\n refValues?: ReferenceDataType[];\r\n graphID?: string;\r\n maxValue?: number;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseClick?: (_d: any) => void;\r\n graphDownload?: boolean;\r\n dataDownload?: boolean;\r\n language?: Languages;\r\n minHeight?: number;\r\n theme?: 'light' | 'dark';\r\n maxBarThickness?: number;\r\n sortParameter?: number | 'total';\r\n sortData?: 'asc' | 'desc';\r\n maxNumberOfBars?: number;\r\n minBarThickness?: number;\r\n ariaLabel?: string;\r\n resetSelectionOnDoubleClick?: boolean;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n detailsOnClick?: string | ((_d: any) => React.ReactNode);\r\n barAxisTitle?: string;\r\n noOfTicks?: number;\r\n valueColor?: string;\r\n styles?: StyleObject;\r\n classNames?: ClassNameObject;\r\n filterNA?: boolean;\r\n animate?: boolean | AnimateDataType;\r\n precision?: number;\r\n customLayers?: CustomLayerDataType[];\r\n timeline?: TimelineDataType;\r\n naLabel?: string;\r\n}\r\n\r\nexport function VerticalStackedBarGraph(props: Props) {\r\n const {\r\n data,\r\n graphTitle,\r\n colors = Colors.light.categoricalColors.colors,\r\n sources,\r\n graphDescription,\r\n barPadding = 0.25,\r\n showTicks = true,\r\n leftMargin = 20,\r\n rightMargin = 20,\r\n topMargin = 20,\r\n bottomMargin = 25,\r\n truncateBy = 999,\r\n showLabels = true,\r\n showValues = true,\r\n backgroundColor = false,\r\n showColorScale = true,\r\n suffix = '',\r\n prefix = '',\r\n height,\r\n width,\r\n footNote,\r\n colorDomain,\r\n colorLegendTitle,\r\n padding,\r\n tooltip,\r\n onSeriesMouseOver,\r\n relativeHeight,\r\n refValues,\r\n graphID,\r\n maxValue,\r\n onSeriesMouseClick,\r\n graphDownload = false,\r\n dataDownload = false,\r\n language = 'en',\r\n theme = 'light',\r\n labelOrder,\r\n minHeight = 0,\r\n maxBarThickness,\r\n sortParameter,\r\n maxNumberOfBars,\r\n minBarThickness,\r\n ariaLabel,\r\n resetSelectionOnDoubleClick = true,\r\n detailsOnClick,\r\n barAxisTitle,\r\n noOfTicks = 5,\r\n valueColor,\r\n styles,\r\n classNames,\r\n filterNA = true,\r\n animate = false,\r\n precision = 2,\r\n customLayers = [],\r\n timeline = { enabled: false, autoplay: false, showOnlyActiveDate: true },\r\n naLabel = 'NA',\r\n sortData,\r\n } = props;\r\n\r\n const [svgWidth, setSvgWidth] = useState(0);\r\n const [svgHeight, setSvgHeight] = useState(0);\r\n const [play, setPlay] = useState(timeline.autoplay);\r\n const uniqDatesSorted = sort(\r\n uniqBy(data, 'date', true).map(d =>\r\n parse(`${d}`, timeline.dateFormat || 'yyyy', new Date()).getTime(),\r\n ),\r\n (a, b) => ascending(a, b),\r\n );\r\n const [index, setIndex] = useState(timeline.autoplay ? 0 : uniqDatesSorted.length - 1);\r\n const [selectedColor, setSelectedColor] = useState<string | undefined>(undefined);\r\n\r\n const graphDiv = useRef<HTMLDivElement>(null);\r\n const graphParentDiv = useRef<HTMLDivElement>(null);\r\n useEffect(() => {\r\n const resizeObserver = new ResizeObserver(entries => {\r\n setSvgWidth(width || entries[0].target.clientWidth || 620);\r\n setSvgHeight(height || entries[0].target.clientHeight || 480);\r\n });\r\n if (graphDiv.current) {\r\n setSvgHeight(graphDiv.current.clientHeight || 480);\r\n setSvgWidth(graphDiv.current.clientWidth || 620);\r\n if (!width) resizeObserver.observe(graphDiv.current);\r\n }\r\n return () => resizeObserver.disconnect();\r\n }, [width, height]);\r\n\r\n useEffect(() => {\r\n const interval = setInterval(\r\n () => {\r\n setIndex(i => (i < uniqDatesSorted.length - 1 ? i + 1 : 0));\r\n },\r\n (timeline.speed || 2) * 1000,\r\n );\r\n if (!play) clearInterval(interval);\r\n return () => clearInterval(interval);\r\n }, [uniqDatesSorted, play, timeline.speed]);\r\n\r\n const markObj = getSliderMarks(\r\n uniqDatesSorted,\r\n index,\r\n timeline.showOnlyActiveDate,\r\n timeline.dateFormat || 'yyyy',\r\n );\r\n\r\n return (\r\n <div\r\n className={`${theme || 'light'} flex ${width ? 'w-fit grow-0' : 'w-full grow'}`}\r\n dir={language === 'he' || language === 'ar' ? 'rtl' : undefined}\r\n >\r\n <div\r\n className={cn(\r\n `${\r\n !backgroundColor\r\n ? 'bg-transparent '\r\n : backgroundColor === true\r\n ? 'bg-primary-gray-200 dark:bg-primary-gray-650 '\r\n : ''\r\n }ml-auto mr-auto flex flex-col grow h-inherit ${language || 'en'}`,\r\n width ? 'w-fit' : 'w-full',\r\n classNames?.graphContainer,\r\n )}\r\n style={{\r\n ...(styles?.graphContainer || {}),\r\n ...(backgroundColor && backgroundColor !== true ? { backgroundColor } : {}),\r\n }}\r\n id={graphID}\r\n ref={graphParentDiv}\r\n aria-label={\r\n ariaLabel ||\r\n `${graphTitle ? `The graph shows ${graphTitle}. ` : ''}This is a stacked bar chart. ${\r\n graphDescription ? ` ${graphDescription}` : ''\r\n }`\r\n }\r\n >\r\n <div style={{ padding: backgroundColor ? padding || '1rem' : padding || 0 }}>\r\n <div className='flex flex-col w-full gap-4 grow justify-between'>\r\n {graphTitle || graphDescription || graphDownload || dataDownload ? (\r\n <GraphHeader\r\n styles={{\r\n title: styles?.title,\r\n description: styles?.description,\r\n }}\r\n classNames={{\r\n title: classNames?.title,\r\n description: classNames?.description,\r\n }}\r\n graphTitle={graphTitle}\r\n graphDescription={graphDescription}\r\n width={width}\r\n graphDownload={graphDownload ? graphParentDiv.current : undefined}\r\n dataDownload={\r\n dataDownload\r\n ? data.map(d => d.data).filter(d => d !== undefined).length > 0\r\n ? data.map(d => d.data).filter(d => d !== undefined)\r\n : data.filter(d => d !== undefined)\r\n : null\r\n }\r\n />\r\n ) : null}\r\n {timeline.enabled && uniqDatesSorted.length > 0 && markObj ? (\r\n <div className='flex gap-6 items-center' dir='ltr'>\r\n <button\r\n type='button'\r\n onClick={() => {\r\n setPlay(!play);\r\n }}\r\n className='p-0 border-0 cursor-pointer bg-transparent'\r\n aria-label={play ? 'Click to pause animation' : 'Click to play animation'}\r\n >\r\n {play ? <Pause /> : <Play />}\r\n </button>\r\n <SliderUI\r\n min={uniqDatesSorted[0]}\r\n max={uniqDatesSorted[uniqDatesSorted.length - 1]}\r\n marks={markObj}\r\n step={null}\r\n defaultValue={uniqDatesSorted[uniqDatesSorted.length - 1]}\r\n value={uniqDatesSorted[index]}\r\n onChangeComplete={nextValue => {\r\n setIndex(uniqDatesSorted.indexOf(nextValue as number));\r\n }}\r\n onChange={nextValue => {\r\n setIndex(uniqDatesSorted.indexOf(nextValue as number));\r\n }}\r\n aria-label='Time slider. Use arrow keys to adjust selected time period.'\r\n />\r\n </div>\r\n ) : null}\r\n <div className='grow flex flex-col justify-center gap-3 w-full'>\r\n {data.length === 0 ? (\r\n <EmptyState />\r\n ) : (\r\n <>\r\n {showColorScale ? (\r\n <ColorLegendWithMouseOver\r\n width={width}\r\n colorDomain={colorDomain}\r\n colors={colors}\r\n colorLegendTitle={colorLegendTitle}\r\n setSelectedColor={setSelectedColor}\r\n showNAColor={false}\r\n />\r\n ) : null}\r\n <div className='w-full grow leading-0' ref={graphDiv} aria-label='Graph area'>\r\n {(width || svgWidth) && (height || svgHeight) ? (\r\n <Graph\r\n data={\r\n sortParameter !== undefined\r\n ? sortParameter === 'total'\r\n ? orderBy(\r\n ensureCompleteDataForStackedBarChart(\r\n data,\r\n timeline.dateFormat || 'yyyy',\r\n )\r\n .filter(d =>\r\n timeline.enabled\r\n ? d.date ===\r\n format(\r\n new Date(uniqDatesSorted[index]),\r\n timeline.dateFormat || 'yyyy',\r\n )\r\n : d,\r\n )\r\n .filter(d =>\r\n filterNA ? !d.size.every(item => item == null) : d,\r\n ),\r\n d => sum(d.size.filter(el => !checkIfNullOrUndefined(el))),\r\n [sortData || 'asc'],\r\n ).filter((_d, i) => (maxNumberOfBars ? i < maxNumberOfBars : true))\r\n : orderBy(\r\n ensureCompleteDataForStackedBarChart(\r\n data,\r\n timeline.dateFormat || 'yyyy',\r\n )\r\n .filter(d =>\r\n timeline.enabled\r\n ? d.date ===\r\n format(\r\n new Date(uniqDatesSorted[index]),\r\n timeline.dateFormat || 'yyyy',\r\n )\r\n : d,\r\n )\r\n .filter(d =>\r\n filterNA ? !d.size.every(item => item == null) : d,\r\n ),\r\n d =>\r\n checkIfNullOrUndefined(d.size[sortParameter])\r\n ? -Infinity\r\n : d.size[sortParameter],\r\n [sortData || 'asc'],\r\n ).filter((_d, i) => (maxNumberOfBars ? i < maxNumberOfBars : true))\r\n : ensureCompleteDataForStackedBarChart(\r\n data,\r\n timeline.dateFormat || 'yyyy',\r\n )\r\n .filter(d => (filterNA ? !d.size.every(item => item == null) : d))\r\n .filter((_d, i) => (maxNumberOfBars ? i < maxNumberOfBars : true))\r\n }\r\n barColors={colors}\r\n width={width || svgWidth}\r\n height={Math.max(\r\n minHeight,\r\n height ||\r\n (relativeHeight\r\n ? minHeight\r\n ? (width || svgWidth) * relativeHeight > minHeight\r\n ? (width || svgWidth) * relativeHeight\r\n : minHeight\r\n : (width || svgWidth) * relativeHeight\r\n : svgHeight),\r\n )}\r\n barPadding={barPadding}\r\n showLabels={showLabels}\r\n showTicks={showTicks}\r\n truncateBy={truncateBy}\r\n leftMargin={leftMargin}\r\n rightMargin={rightMargin}\r\n topMargin={topMargin}\r\n bottomMargin={bottomMargin}\r\n tooltip={tooltip}\r\n onSeriesMouseOver={onSeriesMouseOver}\r\n showValues={showValues}\r\n suffix={suffix}\r\n prefix={prefix}\r\n refValues={refValues}\r\n maxValue={\r\n !checkIfNullOrUndefined(maxValue)\r\n ? (maxValue as number)\r\n : Math.max(\r\n ...data.map(\r\n d => sum(d.size.filter(l => !checkIfNullOrUndefined(l))) || 0,\r\n ),\r\n )\r\n }\r\n onSeriesMouseClick={onSeriesMouseClick}\r\n selectedColor={selectedColor}\r\n labelOrder={labelOrder}\r\n maxBarThickness={maxBarThickness}\r\n minBarThickness={minBarThickness}\r\n resetSelectionOnDoubleClick={resetSelectionOnDoubleClick}\r\n detailsOnClick={detailsOnClick}\r\n barAxisTitle={barAxisTitle}\r\n noOfTicks={noOfTicks}\r\n valueColor={valueColor}\r\n styles={styles}\r\n classNames={classNames}\r\n animate={\r\n animate === true\r\n ? { duration: 0.5, once: true, amount: 0.5 }\r\n : animate || { duration: 0, once: true, amount: 0 }\r\n }\r\n colorDomain={colorDomain}\r\n precision={precision}\r\n customLayers={customLayers}\r\n naLabel={naLabel}\r\n />\r\n ) : null}\r\n </div>\r\n </>\r\n )}\r\n </div>\r\n {sources || footNote ? (\r\n <GraphFooter\r\n styles={{ footnote: styles?.footnote, source: styles?.source }}\r\n classNames={{\r\n footnote: classNames?.footnote,\r\n source: classNames?.source,\r\n }}\r\n sources={sources}\r\n footNote={footNote}\r\n width={width}\r\n />\r\n ) : null}\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n );\r\n}\r\n","import { HorizontalBarGraph } from './Horizontal/BarGraph';\r\nimport { HorizontalGroupedBarGraph } from './Horizontal/GroupedBarGraph';\r\nimport { HorizontalStackedBarGraph } from './Horizontal/StackedBarGraph';\r\nimport { VerticalBarGraph } from './Vertical/BarGraph';\r\nimport { VerticalGroupedBarGraph } from './Vertical/GroupedBarGraph';\r\nimport { VerticalStackedBarGraph } from './Vertical/StackedBarGraph';\r\n\r\nimport {\r\n ReferenceDataType,\r\n BarGraphDataType,\r\n SourcesDataType,\r\n Languages,\r\n StyleObject,\r\n ClassNameObject,\r\n GroupedBarGraphDataType,\r\n CustomLayerDataType,\r\n AnimateDataType,\r\n TimelineDataType,\r\n} from '@/Types';\r\n\r\ninterface Props {\r\n // Data\r\n /** Array of data objects */\r\n data: BarGraphDataType[];\r\n\r\n /** Orientation of the graph */\r\n orientation?: 'vertical' | 'horizontal';\r\n\r\n // Titles, Labels, and Sources\r\n /** Title of the graph */\r\n graphTitle?: string | React.ReactNode;\r\n /** Description of the graph */\r\n graphDescription?: string | React.ReactNode;\r\n /** Footnote for the graph */\r\n footNote?: string | React.ReactNode;\r\n /** Source data for the graph */\r\n sources?: SourcesDataType[];\r\n /** Accessibility label */\r\n ariaLabel?: string;\r\n\r\n // Colors and Styling\r\n /** Color or array of colors for bars */\r\n colors?: string | string[];\r\n /** Domain of colors for the graph */\r\n colorDomain?: string[];\r\n /** Title for the color legend */\r\n colorLegendTitle?: string;\r\n /** Color of value labels */\r\n valueColor?: string;\r\n /** Background color of the graph */\r\n backgroundColor?: string | boolean;\r\n /** Custom styles for the graph. Each object should be a valid React CSS style object. */\r\n styles?: StyleObject;\r\n /** Custom class names */\r\n classNames?: ClassNameObject;\r\n\r\n // Size and Spacing\r\n /** Width of the graph */\r\n width?: number;\r\n /** Height of the graph */\r\n height?: number;\r\n /** Minimum height of the graph */\r\n minHeight?: number;\r\n /** Relative height scaling factor. This overwrites the height props */\r\n relativeHeight?: number;\r\n /** Padding around the graph. Defaults to 0 if no backgroundColor is mentioned else defaults to 1rem */\r\n padding?: string;\r\n /** Left margin of the graph */\r\n leftMargin?: number;\r\n /** Right margin of the graph */\r\n rightMargin?: number;\r\n /** Top margin of the graph */\r\n topMargin?: number;\r\n /** Bottom margin of the graph */\r\n bottomMargin?: number;\r\n /** Padding between bars */\r\n barPadding?: number;\r\n /** Maximum thickness of bars */\r\n maxBarThickness?: number;\r\n /** Minimum thickness of bars */\r\n minBarThickness?: number;\r\n /** Maximum number of bars shown in the graph */\r\n maxNumberOfBars?: number;\r\n\r\n // Values and Ticks\r\n /** Prefix for values */\r\n prefix?: string;\r\n /** Suffix for values */\r\n suffix?: string;\r\n /** Maximum value for the chart */\r\n maxValue?: number;\r\n /** Minimum value for the chart */\r\n minValue?: number;\r\n /** Truncate labels by specified length */\r\n truncateBy?: number;\r\n /** Reference values for comparison */\r\n refValues?: ReferenceDataType[];\r\n /** Number of ticks on the axis */\r\n noOfTicks?: number;\r\n\r\n // Graph Parameters\r\n /** Toggle visibility of labels */\r\n showLabels?: boolean;\r\n /** Toggle visibility of values */\r\n showValues?: boolean;\r\n /** Custom order for labels */\r\n labelOrder?: string[];\r\n /** Defines how “NA” values should be displayed/labelled in the graph */\r\n naLabel?: string;\r\n /** Toggle visibility of axis ticks */\r\n showTicks?: boolean;\r\n /** Toggle visibility of color scale. This is only applicable if the data props hae color parameter */\r\n showColorScale?: boolean;\r\n /** Toggle visibility of NA color in the color scale. This is only applicable if the data props hae color parameter and showColorScale prop is true */\r\n showNAColor?: boolean;\r\n /** Data points to highlight. Use the label value from data to highlight the data point */\r\n highlightedDataPoints?: (string | number)[];\r\n /** Defines the opacity of the non-highlighted data */\r\n dimmedOpacity?: number;\r\n /** Title for the bar axis */\r\n barAxisTitle?: string;\r\n /** Sorting order for data. This is overwritten by labelOrder prop. */\r\n sortData?: 'asc' | 'desc';\r\n /** Toggles if data point which are undefined or has value null are filtered out. */\r\n filterNA?: boolean;\r\n /** Toggles if the graph animates in when loaded. */\r\n animate?: boolean | AnimateDataType;\r\n /** Specifies the number of decimal places to display in the value. */\r\n precision?: number;\r\n /** Optional SVG <g> element or function that renders custom content behind or in front of the graph. */\r\n customLayers?: CustomLayerDataType[];\r\n /** Configures playback and slider controls for animating the chart over time. The data must have a key date for it to work properly. */\r\n timeline?: TimelineDataType;\r\n /** Enable graph download option as png */\r\n graphDownload?: boolean;\r\n /** Enable data download option as a csv */\r\n dataDownload?: boolean;\r\n /** Reset selection on double-click. Only applicable when used in a dashboard context with filters. */\r\n resetSelectionOnDoubleClick?: boolean;\r\n\r\n // Interactions and Callbacks\r\n /** Tooltip content. If the type is string then this uses the [handlebar](../?path=/docs/misc-handlebars-templates-and-custom-helpers--docs) template to display the data */\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n tooltip?: string | ((_d: any) => React.ReactNode);\r\n /** Details displayed on the modal when user clicks of a data point. If the type is string then this uses the [handlebar](../?path=/docs/misc-handlebars-templates-and-custom-helpers--docs) template to display the data */\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n detailsOnClick?: string | ((_d: any) => React.ReactNode);\r\n /** Callback for mouse over event */\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseOver?: (_d: any) => void;\r\n /** Callback for mouse click event */\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseClick?: (_d: any) => void;\r\n\r\n // Configuration and Options\r\n /** Language setting */\r\n language?: Languages;\r\n /** Color theme */\r\n theme?: 'light' | 'dark';\r\n /** Unique ID for the graph */\r\n graphID?: string;\r\n}\r\n\r\nexport function SimpleBarGraph(props: Props) {\r\n const {\r\n data,\r\n graphTitle,\r\n colors,\r\n barPadding,\r\n showTicks,\r\n leftMargin,\r\n rightMargin,\r\n topMargin,\r\n bottomMargin,\r\n truncateBy,\r\n showLabels,\r\n showValues,\r\n backgroundColor,\r\n suffix,\r\n prefix,\r\n sources,\r\n graphDescription,\r\n height,\r\n width,\r\n footNote,\r\n colorDomain,\r\n colorLegendTitle,\r\n padding,\r\n relativeHeight,\r\n tooltip,\r\n onSeriesMouseOver,\r\n refValues,\r\n showColorScale,\r\n graphID,\r\n maxValue,\r\n minValue,\r\n highlightedDataPoints,\r\n onSeriesMouseClick,\r\n graphDownload,\r\n dataDownload,\r\n language,\r\n theme,\r\n sortData,\r\n labelOrder,\r\n showNAColor,\r\n minHeight,\r\n maxBarThickness,\r\n maxNumberOfBars,\r\n minBarThickness,\r\n ariaLabel,\r\n resetSelectionOnDoubleClick,\r\n detailsOnClick,\r\n barAxisTitle,\r\n noOfTicks,\r\n valueColor,\r\n orientation = 'vertical',\r\n styles,\r\n classNames,\r\n filterNA,\r\n animate,\r\n dimmedOpacity,\r\n precision,\r\n customLayers,\r\n timeline,\r\n naLabel,\r\n } = props;\r\n\r\n if (orientation === 'vertical')\r\n return (\r\n <VerticalBarGraph\r\n data={data}\r\n graphTitle={graphTitle}\r\n colors={colors}\r\n barPadding={barPadding}\r\n showTicks={showTicks}\r\n leftMargin={leftMargin}\r\n rightMargin={rightMargin}\r\n topMargin={topMargin}\r\n bottomMargin={bottomMargin}\r\n truncateBy={truncateBy}\r\n showLabels={showLabels}\r\n showValues={showValues}\r\n backgroundColor={backgroundColor}\r\n suffix={suffix}\r\n prefix={prefix}\r\n sources={sources}\r\n graphDescription={graphDescription}\r\n height={height}\r\n width={width}\r\n footNote={footNote}\r\n colorDomain={colorDomain}\r\n colorLegendTitle={colorLegendTitle}\r\n padding={padding}\r\n relativeHeight={relativeHeight}\r\n tooltip={tooltip}\r\n onSeriesMouseOver={onSeriesMouseOver}\r\n refValues={refValues}\r\n showColorScale={showColorScale}\r\n graphID={graphID}\r\n maxValue={maxValue}\r\n minValue={minValue}\r\n highlightedDataPoints={highlightedDataPoints}\r\n onSeriesMouseClick={onSeriesMouseClick}\r\n graphDownload={graphDownload}\r\n dataDownload={dataDownload}\r\n language={language}\r\n theme={theme}\r\n sortData={sortData}\r\n labelOrder={labelOrder}\r\n showNAColor={showNAColor}\r\n minHeight={minHeight}\r\n maxBarThickness={maxBarThickness}\r\n maxNumberOfBars={maxNumberOfBars}\r\n minBarThickness={minBarThickness}\r\n ariaLabel={ariaLabel}\r\n resetSelectionOnDoubleClick={resetSelectionOnDoubleClick}\r\n styles={styles}\r\n detailsOnClick={detailsOnClick}\r\n barAxisTitle={barAxisTitle}\r\n noOfTicks={noOfTicks}\r\n valueColor={valueColor}\r\n classNames={classNames}\r\n filterNA={filterNA}\r\n animate={animate}\r\n dimmedOpacity={dimmedOpacity}\r\n precision={precision}\r\n customLayers={customLayers}\r\n timeline={timeline}\r\n naLabel={naLabel}\r\n />\r\n );\r\n return (\r\n <HorizontalBarGraph\r\n data={data}\r\n graphTitle={graphTitle}\r\n colors={colors}\r\n barPadding={barPadding}\r\n showTicks={showTicks}\r\n leftMargin={leftMargin}\r\n rightMargin={rightMargin}\r\n topMargin={topMargin}\r\n bottomMargin={bottomMargin}\r\n truncateBy={truncateBy}\r\n showLabels={showLabels}\r\n showValues={showValues}\r\n backgroundColor={backgroundColor}\r\n suffix={suffix}\r\n prefix={prefix}\r\n sources={sources}\r\n graphDescription={graphDescription}\r\n height={height}\r\n width={width}\r\n footNote={footNote}\r\n colorDomain={colorDomain}\r\n colorLegendTitle={colorLegendTitle}\r\n padding={padding}\r\n relativeHeight={relativeHeight}\r\n tooltip={tooltip}\r\n onSeriesMouseOver={onSeriesMouseOver}\r\n refValues={refValues}\r\n showColorScale={showColorScale}\r\n graphID={graphID}\r\n maxValue={maxValue}\r\n minValue={minValue}\r\n highlightedDataPoints={highlightedDataPoints}\r\n onSeriesMouseClick={onSeriesMouseClick}\r\n graphDownload={graphDownload}\r\n dataDownload={dataDownload}\r\n language={language}\r\n theme={theme}\r\n sortData={sortData}\r\n labelOrder={labelOrder}\r\n showNAColor={showNAColor}\r\n minHeight={minHeight}\r\n maxBarThickness={maxBarThickness}\r\n maxNumberOfBars={maxNumberOfBars}\r\n minBarThickness={minBarThickness}\r\n ariaLabel={ariaLabel}\r\n resetSelectionOnDoubleClick={resetSelectionOnDoubleClick}\r\n styles={styles}\r\n detailsOnClick={detailsOnClick}\r\n barAxisTitle={barAxisTitle}\r\n noOfTicks={noOfTicks}\r\n valueColor={valueColor}\r\n classNames={classNames}\r\n filterNA={filterNA}\r\n animate={animate}\r\n dimmedOpacity={dimmedOpacity}\r\n precision={precision}\r\n customLayers={customLayers}\r\n timeline={timeline}\r\n naLabel={naLabel}\r\n />\r\n );\r\n}\r\n\r\ninterface GroupedBarChartProps {\r\n // Data\r\n /** Array of data objects */\r\n data: GroupedBarGraphDataType[];\r\n\r\n /** Orientation of the graph */\r\n orientation?: 'vertical' | 'horizontal';\r\n\r\n // Titles, Labels, and Sources\r\n /** Title of the graph */\r\n graphTitle?: string | React.ReactNode;\r\n /** Description of the graph */\r\n graphDescription?: string | React.ReactNode;\r\n /** Footnote for the graph */\r\n footNote?: string | React.ReactNode;\r\n /** Source data for the graph */\r\n sources?: SourcesDataType[];\r\n /** Accessibility label */\r\n ariaLabel?: string;\r\n\r\n // Colors and Styling\r\n /** Array of colors for different bars in the group */\r\n colors?: string[];\r\n /** Domain of colors for the graph */\r\n colorDomain: string[];\r\n /** Title for the color legend */\r\n colorLegendTitle?: string;\r\n /** Color of value labels */\r\n valueColor?: string;\r\n /** Background color of the graph */\r\n backgroundColor?: string | boolean;\r\n /** Custom styles for the graph. Each object should be a valid React CSS style object. */\r\n styles?: StyleObject;\r\n /** Custom class names */\r\n classNames?: ClassNameObject;\r\n\r\n // Size and Spacing\r\n /** Width of the graph */\r\n width?: number;\r\n /** Height of the graph */\r\n height?: number;\r\n /** Minimum height of the graph */\r\n minHeight?: number;\r\n /** Relative height scaling factor. This overwrites the height props */\r\n relativeHeight?: number;\r\n /** Padding around the graph. Defaults to 0 if no backgroundColor is mentioned else defaults to 1rem */\r\n padding?: string;\r\n /** Left margin of the graph */\r\n leftMargin?: number;\r\n /** Right margin of the graph */\r\n rightMargin?: number;\r\n /** Top margin of the graph */\r\n topMargin?: number;\r\n /** Bottom margin of the graph */\r\n bottomMargin?: number;\r\n /** Padding between bars */\r\n barPadding?: number;\r\n /** Maximum thickness of bars */\r\n maxBarThickness?: number;\r\n\r\n // Values and Ticks\r\n /** Prefix for values */\r\n prefix?: string;\r\n /** Suffix for values */\r\n suffix?: string;\r\n /** Maximum value for the chart */\r\n maxValue?: number;\r\n /** Minimum value for the chart */\r\n minValue?: number;\r\n /** Truncate labels by specified length */\r\n truncateBy?: number;\r\n /** Toggles if data points which have all the values as undefined or null are filtered out. */\r\n filterNA?: boolean;\r\n /** Parameter to sort the data. If a number is provided, it refers to the index of the size array to determine which value to sort by. If set to total, it sorts by the sum of all the values. */\r\n sortParameter?: number | 'total';\r\n /** Sorting order for data. This is overwritten by labelOrder prop. */\r\n sortData?: 'asc' | 'desc';\r\n /** Toggles if the graph animates in when loaded. */\r\n animate?: boolean | AnimateDataType;\r\n /** Reference values for comparison */\r\n refValues?: ReferenceDataType[];\r\n /** Number of ticks on the axis */\r\n noOfTicks?: number;\r\n\r\n // Graph Parameters\r\n /** Toggle visibility of labels */\r\n showLabels?: boolean;\r\n /** Toggle visibility of values */\r\n showValues?: boolean;\r\n /** Custom order for labels */\r\n labelOrder?: string[];\r\n /** Toggle visibility of axis ticks */\r\n showTicks?: boolean;\r\n /** Toggle visibility of color scale. This is only applicable if the data props hae color parameter */\r\n showColorScale?: boolean;\r\n /** Title for the bar axis */\r\n barAxisTitle?: string;\r\n /** Defines how “NA” values should be displayed/labelled in the graph */\r\n naLabel?: string;\r\n /** Specifies the number of decimal places to display in the value. */\r\n precision?: number;\r\n /** Optional SVG <g> element or function that renders custom content behind or in front of the graph. */\r\n customLayers?: CustomLayerDataType[];\r\n /** Configures playback and slider controls for animating the chart over time. The data must have a key date for it to work properly. */\r\n timeline?: TimelineDataType;\r\n /** Enable graph download option as png */\r\n graphDownload?: boolean;\r\n /** Enable data download option as a csv */\r\n dataDownload?: boolean;\r\n /** Reset selection on double-click. Only applicable when used in a dashboard context with filters. */\r\n resetSelectionOnDoubleClick?: boolean;\r\n\r\n // Interactions and Callbacks\r\n /** Tooltip content. If the type is string then this uses the [handlebar](../?path=/docs/misc-handlebars-templates-and-custom-helpers--docs) template to display the data */\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n tooltip?: string | ((_d: any) => React.ReactNode);\r\n /** Details displayed on the modal when user clicks of a data point. If the type is string then this uses the [handlebar](../?path=/docs/misc-handlebars-templates-and-custom-helpers--docs) template to display the data */\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n detailsOnClick?: string | ((_d: any) => React.ReactNode);\r\n /** Callback for mouse over event */\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseOver?: (_d: any) => void;\r\n /** Callback for mouse click event */\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseClick?: (_d: any) => void;\r\n\r\n // Configuration and Options\r\n /** Language setting */\r\n language?: Languages;\r\n /** Color theme */\r\n theme?: 'light' | 'dark';\r\n /** Unique ID for the graph */\r\n graphID?: string;\r\n}\r\n\r\nexport function GroupedBarGraph(props: GroupedBarChartProps) {\r\n const {\r\n data,\r\n graphTitle,\r\n colors,\r\n sources,\r\n graphDescription,\r\n barPadding,\r\n showTicks,\r\n truncateBy,\r\n height,\r\n width,\r\n footNote,\r\n colorDomain,\r\n colorLegendTitle,\r\n suffix,\r\n prefix,\r\n showValues,\r\n padding,\r\n backgroundColor,\r\n leftMargin,\r\n rightMargin,\r\n topMargin,\r\n bottomMargin,\r\n showLabels,\r\n relativeHeight,\r\n tooltip,\r\n onSeriesMouseOver,\r\n refValues,\r\n graphID,\r\n maxValue,\r\n minValue,\r\n onSeriesMouseClick,\r\n graphDownload,\r\n dataDownload,\r\n language,\r\n labelOrder,\r\n minHeight,\r\n theme,\r\n sortParameter,\r\n sortData,\r\n maxBarThickness,\r\n ariaLabel,\r\n resetSelectionOnDoubleClick,\r\n detailsOnClick,\r\n barAxisTitle,\r\n noOfTicks,\r\n valueColor,\r\n orientation = 'vertical',\r\n styles,\r\n classNames,\r\n filterNA,\r\n animate,\r\n precision,\r\n customLayers,\r\n showColorScale,\r\n timeline,\r\n naLabel,\r\n } = props;\r\n\r\n if (orientation === 'vertical')\r\n return (\r\n <VerticalGroupedBarGraph\r\n data={data}\r\n graphTitle={graphTitle}\r\n colors={colors}\r\n sources={sources}\r\n graphDescription={graphDescription}\r\n barPadding={barPadding}\r\n showTicks={showTicks}\r\n truncateBy={truncateBy}\r\n height={height}\r\n width={width}\r\n footNote={footNote}\r\n colorDomain={colorDomain}\r\n colorLegendTitle={colorLegendTitle}\r\n suffix={suffix}\r\n prefix={prefix}\r\n showValues={showValues}\r\n padding={padding}\r\n backgroundColor={backgroundColor}\r\n leftMargin={leftMargin}\r\n rightMargin={rightMargin}\r\n sortParameter={sortParameter}\r\n sortData={sortData}\r\n topMargin={topMargin}\r\n bottomMargin={bottomMargin}\r\n showLabels={showLabels}\r\n relativeHeight={relativeHeight}\r\n tooltip={tooltip}\r\n onSeriesMouseOver={onSeriesMouseOver}\r\n refValues={refValues}\r\n graphID={graphID}\r\n maxValue={maxValue}\r\n minValue={minValue}\r\n onSeriesMouseClick={onSeriesMouseClick}\r\n graphDownload={graphDownload}\r\n dataDownload={dataDownload}\r\n language={language}\r\n labelOrder={labelOrder}\r\n minHeight={minHeight}\r\n theme={theme}\r\n maxBarThickness={maxBarThickness}\r\n ariaLabel={ariaLabel}\r\n resetSelectionOnDoubleClick={resetSelectionOnDoubleClick}\r\n styles={styles}\r\n detailsOnClick={detailsOnClick}\r\n barAxisTitle={barAxisTitle}\r\n noOfTicks={noOfTicks}\r\n valueColor={valueColor}\r\n classNames={classNames}\r\n filterNA={filterNA}\r\n animate={animate}\r\n precision={precision}\r\n customLayers={customLayers}\r\n showColorScale={showColorScale}\r\n timeline={timeline}\r\n naLabel={naLabel}\r\n />\r\n );\r\n return (\r\n <HorizontalGroupedBarGraph\r\n data={data}\r\n graphTitle={graphTitle}\r\n colors={colors}\r\n sortParameter={sortParameter}\r\n sortData={sortData}\r\n sources={sources}\r\n graphDescription={graphDescription}\r\n barPadding={barPadding}\r\n showTicks={showTicks}\r\n truncateBy={truncateBy}\r\n height={height}\r\n width={width}\r\n footNote={footNote}\r\n colorDomain={colorDomain}\r\n colorLegendTitle={colorLegendTitle}\r\n suffix={suffix}\r\n prefix={prefix}\r\n showValues={showValues}\r\n padding={padding}\r\n backgroundColor={backgroundColor}\r\n leftMargin={leftMargin}\r\n rightMargin={rightMargin}\r\n topMargin={topMargin}\r\n bottomMargin={bottomMargin}\r\n showLabels={showLabels}\r\n relativeHeight={relativeHeight}\r\n tooltip={tooltip}\r\n onSeriesMouseOver={onSeriesMouseOver}\r\n refValues={refValues}\r\n graphID={graphID}\r\n maxValue={maxValue}\r\n minValue={minValue}\r\n onSeriesMouseClick={onSeriesMouseClick}\r\n graphDownload={graphDownload}\r\n dataDownload={dataDownload}\r\n language={language}\r\n labelOrder={labelOrder}\r\n minHeight={minHeight}\r\n theme={theme}\r\n maxBarThickness={maxBarThickness}\r\n ariaLabel={ariaLabel}\r\n resetSelectionOnDoubleClick={resetSelectionOnDoubleClick}\r\n styles={styles}\r\n detailsOnClick={detailsOnClick}\r\n barAxisTitle={barAxisTitle}\r\n noOfTicks={noOfTicks}\r\n valueColor={valueColor}\r\n classNames={classNames}\r\n filterNA={filterNA}\r\n animate={animate}\r\n precision={precision}\r\n customLayers={customLayers}\r\n showColorScale={showColorScale}\r\n timeline={timeline}\r\n naLabel={naLabel}\r\n />\r\n );\r\n}\r\n\r\ninterface StackedBarChartProps {\r\n // Data\r\n /** Array of data objects */\r\n data: GroupedBarGraphDataType[];\r\n\r\n /** Orientation of the graph */\r\n orientation?: 'vertical' | 'horizontal';\r\n\r\n // Titles, Labels, and Sources\r\n /** Title of the graph */\r\n graphTitle?: string | React.ReactNode;\r\n /** Description of the graph */\r\n graphDescription?: string | React.ReactNode;\r\n /** Footnote for the graph */\r\n footNote?: string | React.ReactNode;\r\n /** Source data for the graph */\r\n sources?: SourcesDataType[];\r\n /** Accessibility label */\r\n ariaLabel?: string;\r\n\r\n // Colors and Styling\r\n /** Array of colors for different bars in the group */\r\n colors?: string[];\r\n /** Domain of colors for the graph */\r\n colorDomain: string[];\r\n /** Title for the color legend */\r\n colorLegendTitle?: string;\r\n /** Color of value labels */\r\n valueColor?: string;\r\n /** Background color of the graph */\r\n backgroundColor?: string | boolean;\r\n /** Custom styles for the graph. Each object should be a valid React CSS style object. */\r\n styles?: StyleObject;\r\n /** Custom class names */\r\n classNames?: ClassNameObject;\r\n\r\n // Size and Spacing\r\n /** Width of the graph */\r\n width?: number;\r\n /** Height of the graph */\r\n height?: number;\r\n /** Minimum height of the graph */\r\n minHeight?: number;\r\n /** Relative height scaling factor. This overwrites the height props */\r\n relativeHeight?: number;\r\n /** Padding around the graph. Defaults to 0 if no backgroundColor is mentioned else defaults to 1rem */\r\n padding?: string;\r\n /** Left margin of the graph */\r\n leftMargin?: number;\r\n /** Right margin of the graph */\r\n rightMargin?: number;\r\n /** Top margin of the graph */\r\n topMargin?: number;\r\n /** Bottom margin of the graph */\r\n bottomMargin?: number;\r\n /** Padding between bars */\r\n barPadding?: number;\r\n /** Maximum thickness of bars */\r\n maxBarThickness?: number;\r\n /** Minimum thickness of bars */\r\n minBarThickness?: number;\r\n /** Maximum number of bars shown in the graph */\r\n maxNumberOfBars?: number;\r\n\r\n // Values and Ticks\r\n /** Prefix for values */\r\n prefix?: string;\r\n /** Suffix for values */\r\n suffix?: string;\r\n /** Maximum value for the chart */\r\n maxValue?: number;\r\n /** Minimum value for the chart */\r\n truncateBy?: number;\r\n /** Reference values for comparison */\r\n refValues?: ReferenceDataType[];\r\n /** Number of ticks on the axis */\r\n noOfTicks?: number;\r\n\r\n // Graph Parameters\r\n /** Toggle visibility of labels */\r\n showLabels?: boolean;\r\n /** Toggle visibility of values */\r\n showValues?: boolean;\r\n /** Custom order for labels */\r\n labelOrder?: string[];\r\n /** Toggle visibility of axis ticks */\r\n showTicks?: boolean;\r\n /** Toggle visibility of color scale. This is only applicable if the data props hae color parameter */\r\n showColorScale?: boolean;\r\n /** Title for the bar axis */\r\n barAxisTitle?: string;\r\n /** Defines how “NA” values should be displayed/labelled in the graph */\r\n naLabel?: string;\r\n /** Parameter to sort the data. If a number is provided, it refers to the index of the size array to determine which value to sort by. If set to total, it sorts by the sum of all the values. */\r\n sortParameter?: number | 'total';\r\n /** Sorting order for data. This is overwritten by labelOrder prop. */\r\n sortData?: 'asc' | 'desc';\r\n /** Toggles if data points which have all the values as undefined or null are filtered out. */\r\n filterNA?: boolean;\r\n /** Toggles if the graph animates in when loaded. */\r\n animate?: boolean | AnimateDataType;\r\n /** Specifies the number of decimal places to display in the value. */\r\n precision?: number;\r\n /** Optional SVG <g> element or function that renders custom content behind or in front of the graph. */\r\n customLayers?: CustomLayerDataType[];\r\n /** Configures playback and slider controls for animating the chart over time. The data must have a key date for it to work properly. */\r\n timeline?: TimelineDataType;\r\n /** Enable graph download option as png */\r\n graphDownload?: boolean;\r\n /** Enable data download option as a csv */\r\n dataDownload?: boolean;\r\n /** Reset selection on double-click. Only applicable when used in a dashboard context with filters. */\r\n resetSelectionOnDoubleClick?: boolean;\r\n\r\n // Interactions and Callbacks\r\n /** Tooltip content. If the type is string then this uses the [handlebar](../?path=/docs/misc-handlebars-templates-and-custom-helpers--docs) template to display the data */\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n tooltip?: string | ((_d: any) => React.ReactNode);\r\n /** Details displayed on the modal when user clicks of a data point. If the type is string then this uses the [handlebar](../?path=/docs/misc-handlebars-templates-and-custom-helpers--docs) template to display the data */\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n detailsOnClick?: string | ((_d: any) => React.ReactNode);\r\n /** Callback for mouse over event */\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseOver?: (_d: any) => void;\r\n /** Callback for mouse click event */\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseClick?: (_d: any) => void;\r\n\r\n // Configuration and Options\r\n /** Language setting */\r\n language?: Languages;\r\n /** Color theme */\r\n theme?: 'light' | 'dark';\r\n /** Unique ID for the graph */\r\n graphID?: string;\r\n}\r\n\r\nexport function StackedBarGraph(props: StackedBarChartProps) {\r\n const {\r\n data,\r\n graphTitle,\r\n colors,\r\n sources,\r\n graphDescription,\r\n barPadding,\r\n showTicks,\r\n leftMargin,\r\n rightMargin,\r\n topMargin,\r\n bottomMargin,\r\n truncateBy,\r\n showLabels,\r\n showValues,\r\n backgroundColor,\r\n suffix,\r\n prefix,\r\n height,\r\n width,\r\n footNote,\r\n colorDomain,\r\n colorLegendTitle,\r\n padding,\r\n tooltip,\r\n onSeriesMouseOver,\r\n relativeHeight,\r\n refValues,\r\n graphID,\r\n maxValue,\r\n onSeriesMouseClick,\r\n graphDownload,\r\n dataDownload,\r\n language,\r\n theme,\r\n labelOrder,\r\n minHeight,\r\n maxBarThickness,\r\n sortParameter,\r\n sortData,\r\n maxNumberOfBars,\r\n minBarThickness,\r\n ariaLabel,\r\n resetSelectionOnDoubleClick,\r\n detailsOnClick,\r\n barAxisTitle,\r\n noOfTicks,\r\n valueColor,\r\n orientation = 'vertical',\r\n styles,\r\n classNames,\r\n filterNA,\r\n animate,\r\n precision,\r\n customLayers,\r\n showColorScale,\r\n timeline,\r\n naLabel,\r\n } = props;\r\n\r\n if (orientation === 'vertical')\r\n return (\r\n <VerticalStackedBarGraph\r\n data={data}\r\n graphTitle={graphTitle}\r\n colors={colors}\r\n sources={sources}\r\n graphDescription={graphDescription}\r\n barPadding={barPadding}\r\n showTicks={showTicks}\r\n leftMargin={leftMargin}\r\n rightMargin={rightMargin}\r\n topMargin={topMargin}\r\n bottomMargin={bottomMargin}\r\n truncateBy={truncateBy}\r\n showLabels={showLabels}\r\n showValues={showValues}\r\n backgroundColor={backgroundColor}\r\n suffix={suffix}\r\n prefix={prefix}\r\n height={height}\r\n width={width}\r\n footNote={footNote}\r\n colorDomain={colorDomain}\r\n colorLegendTitle={colorLegendTitle}\r\n padding={padding}\r\n tooltip={tooltip}\r\n onSeriesMouseOver={onSeriesMouseOver}\r\n relativeHeight={relativeHeight}\r\n refValues={refValues}\r\n graphID={graphID}\r\n maxValue={maxValue}\r\n onSeriesMouseClick={onSeriesMouseClick}\r\n graphDownload={graphDownload}\r\n dataDownload={dataDownload}\r\n language={language}\r\n theme={theme}\r\n labelOrder={labelOrder}\r\n minHeight={minHeight}\r\n maxBarThickness={maxBarThickness}\r\n sortParameter={sortParameter}\r\n sortData={sortData}\r\n maxNumberOfBars={maxNumberOfBars}\r\n minBarThickness={minBarThickness}\r\n ariaLabel={ariaLabel}\r\n resetSelectionOnDoubleClick={resetSelectionOnDoubleClick}\r\n styles={styles}\r\n detailsOnClick={detailsOnClick}\r\n barAxisTitle={barAxisTitle}\r\n noOfTicks={noOfTicks}\r\n valueColor={valueColor}\r\n classNames={classNames}\r\n filterNA={filterNA}\r\n animate={animate}\r\n precision={precision}\r\n customLayers={customLayers}\r\n showColorScale={showColorScale}\r\n timeline={timeline}\r\n naLabel={naLabel}\r\n />\r\n );\r\n return (\r\n <HorizontalStackedBarGraph\r\n data={data}\r\n graphTitle={graphTitle}\r\n colors={colors}\r\n sources={sources}\r\n graphDescription={graphDescription}\r\n barPadding={barPadding}\r\n showTicks={showTicks}\r\n leftMargin={leftMargin}\r\n rightMargin={rightMargin}\r\n topMargin={topMargin}\r\n bottomMargin={bottomMargin}\r\n truncateBy={truncateBy}\r\n showLabels={showLabels}\r\n showValues={showValues}\r\n backgroundColor={backgroundColor}\r\n suffix={suffix}\r\n prefix={prefix}\r\n height={height}\r\n width={width}\r\n footNote={footNote}\r\n colorDomain={colorDomain}\r\n colorLegendTitle={colorLegendTitle}\r\n padding={padding}\r\n tooltip={tooltip}\r\n onSeriesMouseOver={onSeriesMouseOver}\r\n relativeHeight={relativeHeight}\r\n refValues={refValues}\r\n graphID={graphID}\r\n maxValue={maxValue}\r\n onSeriesMouseClick={onSeriesMouseClick}\r\n graphDownload={graphDownload}\r\n dataDownload={dataDownload}\r\n language={language}\r\n theme={theme}\r\n labelOrder={labelOrder}\r\n minHeight={minHeight}\r\n maxBarThickness={maxBarThickness}\r\n sortParameter={sortParameter}\r\n sortData={sortData}\r\n maxNumberOfBars={maxNumberOfBars}\r\n minBarThickness={minBarThickness}\r\n ariaLabel={ariaLabel}\r\n resetSelectionOnDoubleClick={resetSelectionOnDoubleClick}\r\n styles={styles}\r\n detailsOnClick={detailsOnClick}\r\n barAxisTitle={barAxisTitle}\r\n noOfTicks={noOfTicks}\r\n valueColor={valueColor}\r\n classNames={classNames}\r\n filterNA={filterNA}\r\n animate={animate}\r\n precision={precision}\r\n customLayers={customLayers}\r\n showColorScale={showColorScale}\r\n timeline={timeline}\r\n naLabel={naLabel}\r\n />\r\n );\r\n}\r\n"],"names":["Graph","props","data","barColor","suffix","prefix","barPadding","showValues","showTicks","leftMargin","truncateBy","width","height","colorDomain","rightMargin","topMargin","bottomMargin","showLabels","tooltip","onSeriesMouseOver","refValues","selectedColor","highlightedDataPoints","maxValue","minValue","onSeriesMouseClick","labelOrder","rtl","maxBarThickness","minBarThickness","resetSelectionOnDoubleClick","detailsOnClick","barAxisTitle","valueColor","noOfTicks","styles","classNames","animate","dimmedOpacity","precision","customLayers","naLabel","svgRef","useRef","isInView","useInView","mouseOverData","setMouseOverData","useState","mouseClickData","setMouseClickData","eventX","setEventX","eventY","setEventY","margin","graphWidth","graphHeight","dataWithId","d","i","x","scaleLinear","barOrder","y","scaleBand","xTicks","jsxs","Fragment","jsx","motion","XTicksAndGridLines","AxisTitle","AnimatePresence","checkIfNullOrUndefined","event","isEqual","el","Colors","YAxesLabels","cn","Axis","RefLineX","Tooltip","Modal","string2HTML","HorizontalBarGraph","graphTitle","colors","sources","graphDescription","footNote","colorLegendTitle","padding","backgroundColor","relativeHeight","showColorScale","graphID","graphDownload","dataDownload","sortData","language","showNAColor","minHeight","theme","maxNumberOfBars","ariaLabel","filterNA","timeline","svgWidth","setSvgWidth","svgHeight","setSvgHeight","play","setPlay","uniqDatesSorted","sort","uniqBy","parse","a","b","ascending","index","setIndex","setSelectedColor","graphDiv","graphParentDiv","useEffect","resizeObserver","entries","interval","markObj","getSliderMarks","GraphHeader","Pause","Play","SliderUI","nextValue","EmptyState","ColorLegendWithMouseOver","orderBy","ensureCompleteDataForBarChart","format","_d","GraphFooter","barColors","subBarScale","j","numberFormattingFunction","HorizontalGroupedBarGraph","sortParameter","ensureCompleteDataForStackedBarChart","item","sum","l","element","k","getTextColorBasedOnBgColor","HorizontalStackedBarGraph","yTicks","YTicksAndGridLines","_i","XAxesLabels","RefLineY","VerticalBarGraph","VerticalGroupedBarGraph","VerticalStackedBarGraph","SimpleBarGraph","orientation","GroupedBarGraph","StackedBarGraph"],"mappings":"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"}
|