@undp/data-viz 1.5.7 → 1.5.9
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.js +13 -13
- package/dist/{Axis-Ddg-seDi.js → Axis-4gUOL8B7.js} +2 -2
- package/dist/{Axis-Ddg-seDi.js.map → Axis-4gUOL8B7.js.map} +1 -1
- package/dist/{Axis-DE7dSn1_.cjs → Axis-CkNn1wit.cjs} +2 -2
- package/dist/{Axis-DE7dSn1_.cjs.map → Axis-CkNn1wit.cjs.map} +1 -1
- package/dist/{AxisTitle-CK9YeovX.cjs → AxisTitle-Wkz-xeQL.cjs} +2 -2
- package/dist/{AxisTitle-CK9YeovX.cjs.map → AxisTitle-Wkz-xeQL.cjs.map} +1 -1
- package/dist/{AxisTitle-BmHLMRJZ.js → AxisTitle-v6_xcXZ-.js} +2 -2
- package/dist/{AxisTitle-BmHLMRJZ.js.map → AxisTitle-v6_xcXZ-.js.map} +1 -1
- package/dist/BarGraph.cjs +1 -1
- package/dist/BarGraph.cjs.map +1 -1
- package/dist/BarGraph.js +666 -664
- package/dist/BarGraph.js.map +1 -1
- package/dist/BasicStatCard.cjs +1 -1
- package/dist/BasicStatCard.js +2 -2
- package/dist/BeeSwarmChart.cjs +1 -1
- package/dist/BeeSwarmChart.js +42 -42
- package/dist/BiVariateChoroplethMap.cjs +1 -1
- package/dist/BiVariateChoroplethMap.cjs.map +1 -1
- package/dist/BiVariateChoroplethMap.d.ts +2 -0
- package/dist/BiVariateChoroplethMap.js +257 -264
- package/dist/BiVariateChoroplethMap.js.map +1 -1
- package/dist/BulletChart.cjs +1 -1
- package/dist/BulletChart.cjs.map +1 -1
- package/dist/BulletChart.js +223 -221
- package/dist/BulletChart.js.map +1 -1
- package/dist/ButterflyChart.cjs +1 -1
- package/dist/ButterflyChart.cjs.map +1 -1
- package/dist/ButterflyChart.js +84 -82
- package/dist/ButterflyChart.js.map +1 -1
- package/dist/ChoroplethMap.cjs +1 -1
- package/dist/ChoroplethMap.cjs.map +1 -1
- package/dist/ChoroplethMap.d.ts +2 -0
- package/dist/ChoroplethMap.js +296 -304
- package/dist/ChoroplethMap.js.map +1 -1
- package/dist/CirclePackingGraph.cjs +1 -1
- package/dist/CirclePackingGraph.js +3 -3
- package/dist/ColorLegend.cjs +1 -1
- package/dist/ColorLegend.js +2 -2
- package/dist/ColorLegendWithMouseOver.cjs +1 -1
- package/dist/ColorLegendWithMouseOver.js +2 -2
- package/dist/CopyTextButton.cjs +4 -4
- package/dist/CopyTextButton.cjs.map +1 -1
- package/dist/CopyTextButton.js +27 -27
- package/dist/CopyTextButton.js.map +1 -1
- package/dist/CsvDownloadButton.cjs +1 -1
- package/dist/CsvDownloadButton.js +2 -2
- package/dist/DataCards.cjs +3 -3
- package/dist/DataCards.cjs.map +1 -1
- package/dist/DataCards.js +16 -16
- package/dist/DataCards.js.map +1 -1
- package/dist/DataTable.cjs +1 -1
- package/dist/DataTable.js +3 -3
- package/dist/DifferenceLineChart.cjs +1 -1
- package/dist/DifferenceLineChart.cjs.map +1 -1
- package/dist/DifferenceLineChart.js +133 -131
- package/dist/DifferenceLineChart.js.map +1 -1
- package/dist/DonutChart.cjs +1 -1
- package/dist/DonutChart.js +20 -20
- package/dist/DotDensityMap.cjs +1 -1
- package/dist/DotDensityMap.cjs.map +1 -1
- package/dist/DotDensityMap.d.ts +2 -0
- package/dist/DotDensityMap.js +282 -289
- package/dist/DotDensityMap.js.map +1 -1
- package/dist/{DropdownSelect-CtOKZHD0.js → DropdownSelect-6kjXM6oW.js} +2 -2
- package/dist/DropdownSelect-6kjXM6oW.js.map +1 -0
- package/dist/{DropdownSelect-DBDM64B5.cjs → DropdownSelect-vt8yiB-g.cjs} +5 -5
- package/dist/DropdownSelect-vt8yiB-g.cjs.map +1 -0
- package/dist/DualAxisLineChart.cjs +1 -1
- package/dist/DualAxisLineChart.cjs.map +1 -1
- package/dist/DualAxisLineChart.js +141 -121
- package/dist/DualAxisLineChart.js.map +1 -1
- package/dist/DumbbellChart.cjs +1 -1
- package/dist/DumbbellChart.cjs.map +1 -1
- package/dist/DumbbellChart.js +307 -307
- package/dist/DumbbellChart.js.map +1 -1
- package/dist/{EmptyState-DdTp-Mdn.js → EmptyState-36lXXyui.js} +4 -4
- package/dist/{EmptyState-DdTp-Mdn.js.map → EmptyState-36lXXyui.js.map} +1 -1
- package/dist/{EmptyState-d8_8SxeW.cjs → EmptyState-B8IpKGcL.cjs} +2 -2
- package/dist/{EmptyState-d8_8SxeW.cjs.map → EmptyState-B8IpKGcL.cjs.map} +1 -1
- package/dist/ExcelDownloadButton.cjs +1 -1
- package/dist/ExcelDownloadButton.js +2 -2
- package/dist/FootNote.cjs +1 -1
- package/dist/FootNote.js +2 -2
- package/dist/GeoHubCompareMaps.cjs +1 -1
- package/dist/GeoHubCompareMaps.cjs.map +1 -1
- package/dist/GeoHubCompareMaps.js +65 -80
- package/dist/GeoHubCompareMaps.js.map +1 -1
- package/dist/GeoHubMap.cjs +1 -1
- package/dist/GeoHubMap.cjs.map +1 -1
- package/dist/GeoHubMap.js +95 -125
- package/dist/GeoHubMap.js.map +1 -1
- package/dist/GeoHubMapWithLayerSelection.cjs +1 -1
- package/dist/GeoHubMapWithLayerSelection.cjs.map +1 -1
- package/dist/GeoHubMapWithLayerSelection.js +73 -88
- package/dist/GeoHubMapWithLayerSelection.js.map +1 -1
- package/dist/GraphDescription.cjs +1 -1
- package/dist/GraphDescription.js +2 -2
- package/dist/{GraphEl-CqWzvOyr.js → GraphEl-2IiUDxjR.js} +15 -12
- package/dist/GraphEl-2IiUDxjR.js.map +1 -0
- package/dist/GraphEl-qrlfGPe3.cjs +2 -0
- package/dist/GraphEl-qrlfGPe3.cjs.map +1 -0
- package/dist/GraphFooter.cjs +1 -1
- package/dist/GraphFooter.js +1 -1
- package/dist/GraphHeader.cjs +1 -1
- package/dist/GraphHeader.js +1 -1
- package/dist/GraphTitle.cjs +1 -1
- package/dist/GraphTitle.js +2 -2
- package/dist/GriddedGraphs.cjs +1 -1
- package/dist/GriddedGraphs.d.ts +1 -0
- package/dist/GriddedGraphs.js +5 -5
- package/dist/GriddedGraphsFromConfig.cjs +1 -1
- package/dist/GriddedGraphsFromConfig.d.ts +1 -0
- package/dist/GriddedGraphsFromConfig.js +2 -2
- package/dist/HeatMap.cjs +1 -1
- package/dist/HeatMap.js +19 -19
- package/dist/Histogram.cjs +1 -1
- package/dist/Histogram.js +3 -3
- package/dist/ImageDownloadButton.cjs +1 -1
- package/dist/ImageDownloadButton.js +2 -2
- package/dist/LineChartWithConfidenceInterval.cjs +1 -1
- package/dist/LineChartWithConfidenceInterval.cjs.map +1 -1
- package/dist/LineChartWithConfidenceInterval.js +204 -184
- package/dist/LineChartWithConfidenceInterval.js.map +1 -1
- package/dist/LinearColorLegend.cjs +1 -1
- package/dist/LinearColorLegend.js +2 -2
- package/dist/{Modal-DVVwpKhP.js → Modal-Cg8daIlV.js} +198 -187
- package/dist/Modal-Cg8daIlV.js.map +1 -0
- package/dist/Modal-CuuJdWkD.cjs +46 -0
- package/dist/Modal-CuuJdWkD.cjs.map +1 -0
- package/dist/MultiGraphDashboard.cjs +1 -1
- package/dist/MultiGraphDashboard.d.ts +1 -0
- package/dist/MultiGraphDashboard.js +3 -3
- package/dist/MultiGraphDashboardFromConfig.cjs +1 -1
- package/dist/MultiGraphDashboardFromConfig.d.ts +1 -0
- package/dist/MultiGraphDashboardFromConfig.js +2 -2
- package/dist/MultiGraphDashboardWideToLongFormat.cjs +1 -1
- package/dist/MultiGraphDashboardWideToLongFormat.js +4 -4
- package/dist/MultiGraphDashboardWideToLongFormatFromConfig.cjs +1 -1
- package/dist/MultiGraphDashboardWideToLongFormatFromConfig.js +2 -2
- package/dist/MultiLineAltChart.cjs +1 -1
- package/dist/MultiLineAltChart.cjs.map +1 -1
- package/dist/MultiLineAltChart.js +172 -173
- package/dist/MultiLineAltChart.js.map +1 -1
- package/dist/MultiLineChart.cjs +1 -1
- package/dist/MultiLineChart.cjs.map +1 -1
- package/dist/MultiLineChart.js +89 -78
- package/dist/MultiLineChart.js.map +1 -1
- package/dist/ParetoChart.cjs +1 -1
- package/dist/ParetoChart.cjs.map +1 -1
- package/dist/ParetoChart.js +186 -181
- package/dist/ParetoChart.js.map +1 -1
- package/dist/PerformanceIntensiveMultiGraphDashboard.cjs +1 -1
- package/dist/PerformanceIntensiveMultiGraphDashboard.d.ts +1 -0
- package/dist/PerformanceIntensiveMultiGraphDashboard.js +3 -3
- package/dist/PerformanceIntensiveMultiGraphDashboardFromConfig.cjs +1 -1
- package/dist/PerformanceIntensiveMultiGraphDashboardFromConfig.d.ts +1 -0
- package/dist/PerformanceIntensiveMultiGraphDashboardFromConfig.js +2 -2
- package/dist/PerformanceIntensiveScrollStory.cjs +1 -1
- package/dist/PerformanceIntensiveScrollStory.d.ts +1 -0
- package/dist/PerformanceIntensiveScrollStory.js +3 -3
- package/dist/RadarChart.cjs +1 -1
- package/dist/RadarChart.cjs.map +1 -1
- package/dist/RadarChart.js +256 -244
- package/dist/RadarChart.js.map +1 -1
- package/dist/{ReferenceLine-CfAW3vKJ.js → ReferenceLine-CPMaAX0r.js} +3 -3
- package/dist/{ReferenceLine-CfAW3vKJ.js.map → ReferenceLine-CPMaAX0r.js.map} +1 -1
- package/dist/{ReferenceLine-CFVBBN__.cjs → ReferenceLine-D04j-zeV.cjs} +2 -2
- package/dist/{ReferenceLine-CFVBBN__.cjs.map → ReferenceLine-D04j-zeV.cjs.map} +1 -1
- package/dist/{RegressionLine-mH7UKOPi.js → RegressionLine-CW7iViH2.js} +13 -12
- package/dist/RegressionLine-CW7iViH2.js.map +1 -0
- package/dist/RegressionLine-D-49RaHa.cjs +2 -0
- package/dist/RegressionLine-D-49RaHa.cjs.map +1 -0
- package/dist/SVGDownloadButton.cjs +1 -1
- package/dist/SVGDownloadButton.js +2 -2
- package/dist/SankeyChart.cjs +1 -1
- package/dist/SankeyChart.js +27 -27
- package/dist/ScatterPlot.cjs +1 -1
- package/dist/ScatterPlot.cjs.map +1 -1
- package/dist/ScatterPlot.js +145 -144
- package/dist/ScatterPlot.js.map +1 -1
- package/dist/ScrollStory.cjs +1 -1
- package/dist/ScrollStory.d.ts +1 -0
- package/dist/ScrollStory.js +3 -3
- package/dist/SimpleLineChart.cjs +1 -1
- package/dist/SimpleLineChart.cjs.map +1 -1
- package/dist/SimpleLineChart.js +53 -48
- package/dist/SimpleLineChart.js.map +1 -1
- package/dist/SingleGraphDashboard.cjs +1 -1
- package/dist/SingleGraphDashboard.d.ts +1 -0
- package/dist/SingleGraphDashboard.js +6 -6
- package/dist/SingleGraphDashboardFromConfig.cjs +1 -1
- package/dist/SingleGraphDashboardFromConfig.d.ts +1 -0
- package/dist/SingleGraphDashboardFromConfig.js +2 -2
- package/dist/SingleGraphDashboardGeoHubMaps.cjs +1 -1
- package/dist/SingleGraphDashboardGeoHubMaps.d.ts +1 -0
- package/dist/SingleGraphDashboardGeoHubMaps.js +2 -2
- package/dist/SingleGraphDashboardGeoHubMapsFromConfig.cjs +1 -1
- package/dist/SingleGraphDashboardGeoHubMapsFromConfig.d.ts +1 -0
- package/dist/SingleGraphDashboardGeoHubMapsFromConfig.js +2 -2
- package/dist/SingleGraphDashboardThreeDGraphs.cjs +1 -1
- package/dist/SingleGraphDashboardThreeDGraphs.cjs.map +1 -1
- package/dist/SingleGraphDashboardThreeDGraphs.d.ts +1 -0
- package/dist/SingleGraphDashboardThreeDGraphs.js +14 -13
- package/dist/SingleGraphDashboardThreeDGraphs.js.map +1 -1
- package/dist/SingleGraphDashboardThreeDGraphsFromConfig.cjs +1 -1
- package/dist/SingleGraphDashboardThreeDGraphsFromConfig.d.ts +1 -0
- package/dist/SingleGraphDashboardThreeDGraphsFromConfig.js +2 -2
- package/dist/SlopeChart.cjs +1 -1
- package/dist/SlopeChart.cjs.map +1 -1
- package/dist/SlopeChart.js +137 -133
- package/dist/SlopeChart.js.map +1 -1
- package/dist/Source.cjs +1 -1
- package/dist/Source.js +2 -2
- package/dist/SparkLine.cjs +1 -1
- package/dist/SparkLine.js +2 -2
- package/dist/{Spinner-C85UF28E.js → Spinner-Bpz70q_g.js} +2 -2
- package/dist/{Spinner-C85UF28E.js.map → Spinner-Bpz70q_g.js.map} +1 -1
- package/dist/{Spinner-DA6Z5E4n.cjs → Spinner-C6wLp85s.cjs} +2 -2
- package/dist/{Spinner-DA6Z5E4n.cjs.map → Spinner-C6wLp85s.cjs.map} +1 -1
- package/dist/StatCardFromData.cjs +1 -1
- package/dist/StatCardFromData.js +2 -2
- package/dist/StripChart.cjs +1 -1
- package/dist/StripChart.cjs.map +1 -1
- package/dist/StripChart.js +307 -295
- package/dist/StripChart.js.map +1 -1
- package/dist/ThreeDGlobe.cjs +1 -1
- package/dist/ThreeDGlobe.cjs.map +1 -1
- package/dist/ThreeDGlobe.d.ts +2 -0
- package/dist/ThreeDGlobe.js +220 -228
- package/dist/ThreeDGlobe.js.map +1 -1
- package/dist/ThresholdColorLegendWithMouseOver.cjs +1 -1
- package/dist/ThresholdColorLegendWithMouseOver.js +2 -2
- package/dist/{Tooltip-CVCGWyzw.js → Tooltip-6LIdPQGC.js} +2 -2
- package/dist/{Tooltip-CVCGWyzw.js.map → Tooltip-6LIdPQGC.js.map} +1 -1
- package/dist/{Tooltip-De16GWhY.cjs → Tooltip-Cpv0QohJ.cjs} +2 -2
- package/dist/{Tooltip-De16GWhY.cjs.map → Tooltip-Cpv0QohJ.cjs.map} +1 -1
- package/dist/TreeMapGraph.cjs +1 -1
- package/dist/TreeMapGraph.js +24 -24
- package/dist/Types.d.ts +1 -0
- package/dist/{Typography-k-kOjICQ.cjs → Typography-BDULiwlF.cjs} +2 -2
- package/dist/{Typography-k-kOjICQ.cjs.map → Typography-BDULiwlF.cjs.map} +1 -1
- package/dist/{Typography-Ctgfl1J5.js → Typography-LmZ9LEpe.js} +2 -2
- package/dist/{Typography-Ctgfl1J5.js.map → Typography-LmZ9LEpe.js.map} +1 -1
- package/dist/UnitChart.cjs +1 -1
- package/dist/UnitChart.cjs.map +1 -1
- package/dist/UnitChart.js +25 -26
- package/dist/UnitChart.js.map +1 -1
- package/dist/{XAxesLabels-Drf7M3YK.cjs → XAxesLabels-CLZnBgSr.cjs} +2 -2
- package/dist/{XAxesLabels-Drf7M3YK.cjs.map → XAxesLabels-CLZnBgSr.cjs.map} +1 -1
- package/dist/{XAxesLabels-loO78vUO.js → XAxesLabels-SOSmso5J.js} +3 -3
- package/dist/{XAxesLabels-loO78vUO.js.map → XAxesLabels-SOSmso5J.js.map} +1 -1
- package/dist/{XTicksAndGridLines-Bn9u5gOM.js → XTicksAndGridLines-DuydSnZ_.js} +2 -2
- package/dist/{XTicksAndGridLines-Bn9u5gOM.js.map → XTicksAndGridLines-DuydSnZ_.js.map} +1 -1
- package/dist/{XTicksAndGridLines-CCzXIV8d.cjs → XTicksAndGridLines-RKy7BVCO.cjs} +2 -2
- package/dist/{XTicksAndGridLines-CCzXIV8d.cjs.map → XTicksAndGridLines-RKy7BVCO.cjs.map} +1 -1
- package/dist/{YAxesLabels-DECkMgq8.js → YAxesLabels-DlDyLvhi.js} +3 -3
- package/dist/{YAxesLabels-DECkMgq8.js.map → YAxesLabels-DlDyLvhi.js.map} +1 -1
- package/dist/{YAxesLabels-yRFFdx1s.cjs → YAxesLabels-Dqd259-t.cjs} +2 -2
- package/dist/{YAxesLabels-yRFFdx1s.cjs.map → YAxesLabels-Dqd259-t.cjs.map} +1 -1
- package/dist/{YTicksAndGridLines-B6ah7CRf.js → YTicksAndGridLines-7t4MKtGw.js} +2 -2
- package/dist/{YTicksAndGridLines-B6ah7CRf.js.map → YTicksAndGridLines-7t4MKtGw.js.map} +1 -1
- package/dist/{YTicksAndGridLines-DBDuz6vb.cjs → YTicksAndGridLines-qGpRo_t1.cjs} +2 -2
- package/dist/{YTicksAndGridLines-DBDuz6vb.cjs.map → YTicksAndGridLines-qGpRo_t1.cjs.map} +1 -1
- package/dist/checkIfMultiple-Dko_cBvE.cjs +12 -0
- package/dist/checkIfMultiple-Dko_cBvE.cjs.map +1 -0
- package/dist/{checkIfMultiple-ChTJk2Tk.js → checkIfMultiple-u2SmbiCf.js} +11 -11
- package/dist/checkIfMultiple-u2SmbiCf.js.map +1 -0
- package/dist/{customArea-CK768gCn.cjs → customArea-1G1S78s_.cjs} +2 -2
- package/dist/{customArea-CK768gCn.cjs.map → customArea-1G1S78s_.cjs.map} +1 -1
- package/dist/{customArea-B-dWU0zZ.js → customArea-x4L4xwLl.js} +3 -3
- package/dist/{customArea-B-dWU0zZ.js.map → customArea-x4L4xwLl.js.map} +1 -1
- package/dist/getCentroidCoordinates-Dfk6IqEG.js.map +1 -1
- package/dist/getCentroidCoordinates-DxTBqzp2.cjs.map +1 -1
- package/dist/getSliderMarks-CUxPy36E.cjs +6 -0
- package/dist/getSliderMarks-CUxPy36E.cjs.map +1 -0
- package/dist/{getSliderMarks-9cNoRkDx.js → getSliderMarks-_pYOWEtO.js} +3 -3
- package/dist/getSliderMarks-_pYOWEtO.js.map +1 -0
- package/dist/{index-BYzIB5V6.cjs → index-BHe3wsWF.cjs} +2 -2
- package/dist/{index-BYzIB5V6.cjs.map → index-BHe3wsWF.cjs.map} +1 -1
- package/dist/{index-DKCxu1Gh.js → index-Bw_eHBVN.js} +3 -3
- package/dist/{index-DKCxu1Gh.js.map → index-Bw_eHBVN.js.map} +1 -1
- package/dist/{index-BW_-wD2k.cjs → index-C0bpbS4F.cjs} +2 -2
- package/dist/{index-BW_-wD2k.cjs.map → index-C0bpbS4F.cjs.map} +1 -1
- package/dist/{index-37q0ULNQ.js → index-CE9pmfxt.js} +17 -17
- package/dist/{index-37q0ULNQ.js.map → index-CE9pmfxt.js.map} +1 -1
- package/dist/{index-CVlCtJbC.cjs → index-CEJwW3lL.cjs} +2 -2
- package/dist/{index-CVlCtJbC.cjs.map → index-CEJwW3lL.cjs.map} +1 -1
- package/dist/{index-CHPV5EwG-BPSP-7Jg.js → index-CHPV5EwG-DBWUSD9b.js} +539 -543
- package/dist/index-CHPV5EwG-DBWUSD9b.js.map +1 -0
- package/dist/index-CHPV5EwG-DjM48pIC.cjs +44 -0
- package/dist/index-CHPV5EwG-DjM48pIC.cjs.map +1 -0
- package/dist/{index-BW8iNx7E.cjs → index-Cm8NIdOO.cjs} +2 -2
- package/dist/{index-BW8iNx7E.cjs.map → index-Cm8NIdOO.cjs.map} +1 -1
- package/dist/{index-tvAyXPPW-DBlMKnNB.js → index-Cw8sCyo_-BuI_jX5Z.js} +3 -3
- package/dist/{index-tvAyXPPW-DBlMKnNB.js.map → index-Cw8sCyo_-BuI_jX5Z.js.map} +1 -1
- package/dist/index-Cw8sCyo_-gxT8ADyn.cjs +2 -0
- package/dist/index-Cw8sCyo_-gxT8ADyn.cjs.map +1 -0
- package/dist/{index-CNvov0eg.js → index-Cwgh7i7X.js} +3 -3
- package/dist/{index-CNvov0eg.js.map → index-Cwgh7i7X.js.map} +1 -1
- package/dist/{index-DG3YrCr5-D3FrrXj8.js → index-Dzc_aaI9-BKklH89r.js} +2 -2
- package/dist/{index-DG3YrCr5-D3FrrXj8.js.map → index-Dzc_aaI9-BKklH89r.js.map} +1 -1
- package/dist/{index-DG3YrCr5-v7rayV3N.cjs → index-Dzc_aaI9-RIk2GRHD.cjs} +2 -2
- package/dist/{index-DG3YrCr5-v7rayV3N.cjs.map → index-Dzc_aaI9-RIk2GRHD.cjs.map} +1 -1
- package/dist/{index-BmCqpO1B.js → index-zZjQEHlm.js} +2 -2
- package/dist/{index-BmCqpO1B.js.map → index-zZjQEHlm.js.map} +1 -1
- package/dist/index.cjs +1 -1
- package/dist/index.d.ts +9 -0
- package/dist/index.js +1 -1
- package/dist/{proxy-CkpFesk1.js → proxy-BYIC9BuT.js} +2 -2
- package/dist/{proxy-CkpFesk1.js.map → proxy-BYIC9BuT.js.map} +1 -1
- package/dist/{proxy-BHRoeZgd.cjs → proxy-CKadx4lC.cjs} +2 -2
- package/dist/{proxy-BHRoeZgd.cjs.map → proxy-CKadx4lC.cjs.map} +1 -1
- package/dist/style.css +1 -1
- package/dist/{use-in-view-sQJZ_xDO.cjs → use-in-view-CEwlc_dd.cjs} +2 -2
- package/dist/{use-in-view-sQJZ_xDO.cjs.map → use-in-view-CEwlc_dd.cjs.map} +1 -1
- package/dist/{use-in-view-yS6jzJAp.js → use-in-view-DR-UTB96.js} +2 -2
- package/dist/{use-in-view-yS6jzJAp.js.map → use-in-view-DR-UTB96.js.map} +1 -1
- package/package.json +4 -4
- package/dist/DropdownSelect-CtOKZHD0.js.map +0 -1
- package/dist/DropdownSelect-DBDM64B5.cjs.map +0 -1
- package/dist/GraphEl-C6yjl1VM.cjs +0 -2
- package/dist/GraphEl-C6yjl1VM.cjs.map +0 -1
- package/dist/GraphEl-CqWzvOyr.js.map +0 -1
- package/dist/Modal-DVVwpKhP.js.map +0 -1
- package/dist/Modal-tXZlLE5s.cjs +0 -46
- package/dist/Modal-tXZlLE5s.cjs.map +0 -1
- package/dist/RegressionLine-mH7UKOPi.js.map +0 -1
- package/dist/RegressionLine-xKdiJ8sw.cjs +0 -2
- package/dist/RegressionLine-xKdiJ8sw.cjs.map +0 -1
- package/dist/checkIfMultiple-BXbHUCWM.cjs +0 -12
- package/dist/checkIfMultiple-BXbHUCWM.cjs.map +0 -1
- package/dist/checkIfMultiple-ChTJk2Tk.js.map +0 -1
- package/dist/getSliderMarks-9cNoRkDx.js.map +0 -1
- package/dist/getSliderMarks-CRIbTGYV.cjs +0 -6
- package/dist/getSliderMarks-CRIbTGYV.cjs.map +0 -1
- package/dist/index-CHPV5EwG-BPSP-7Jg.js.map +0 -1
- package/dist/index-CHPV5EwG-DDoeWRVt.cjs +0 -44
- package/dist/index-CHPV5EwG-DDoeWRVt.cjs.map +0 -1
- package/dist/index-tvAyXPPW-DPOG-C2i.cjs +0 -2
- package/dist/index-tvAyXPPW-DPOG-C2i.cjs.map +0 -1
package/dist/StripChart.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"StripChart.js","sources":["../src/Utils/getTickPosition.ts","../src/Components/Graphs/StripChart/Horizontal/Graph.tsx","../src/Components/Graphs/StripChart/Horizontal/index.tsx","../src/Components/Graphs/StripChart/Vertical/Graph.tsx","../src/Components/Graphs/StripChart/Vertical/index.tsx","../src/Components/Graphs/StripChart/index.tsx"],"sourcesContent":["export function getTickPositions(count: number, width: number) {\r\n if (count < 2) return [];\r\n const step = width / (count - 1);\r\n return Array.from({ length: count }, (_, i) => i * step);\r\n}\r\n","import isEqual from 'fast-deep-equal';\r\nimport { useRef, useState } from 'react';\r\nimport { scaleLinear } from 'd3-scale';\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\nimport orderBy from 'lodash.orderby';\r\n\r\nimport {\r\n AnimateDataType,\r\n ClassNameObject,\r\n CustomLayerDataType,\r\n StripChartDataType,\r\n StyleObject,\r\n} from '@/Types';\r\nimport { Tooltip } from '@/Components/Elements/Tooltip';\r\nimport { checkIfNullOrUndefined } from '@/Utils/checkIfNullOrUndefined';\r\nimport { numberFormattingFunction } from '@/Utils/numberFormattingFunction';\r\nimport { Colors } from '@/Components/ColorPalette';\r\nimport { string2HTML } from '@/Utils/string2HTML';\r\nimport { getTickPositions } from '@/Utils/getTickPosition';\r\n\r\ninterface Props {\r\n data: StripChartDataType[];\r\n width: number;\r\n height: number;\r\n selectedColor?: string;\r\n colors: string[];\r\n colorDomain: string[];\r\n radius: number;\r\n leftMargin: number;\r\n rightMargin: number;\r\n topMargin: 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 highlightedDataPoints: (string | number)[];\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 prefix: string;\r\n suffix: string;\r\n stripType: 'strip' | 'dot';\r\n highlightColor?: string;\r\n dotOpacity: 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 styles?: StyleObject;\r\n classNames?: ClassNameObject;\r\n valueColor?: string;\r\n animate: AnimateDataType;\r\n noOfTicks: number;\r\n dimmedOpacity: number;\r\n precision: number;\r\n customLayers: CustomLayerDataType[];\r\n}\r\n\r\nexport function Graph(props: Props) {\r\n const {\r\n data,\r\n width,\r\n height,\r\n colors,\r\n colorDomain,\r\n radius,\r\n leftMargin,\r\n rightMargin,\r\n topMargin,\r\n bottomMargin,\r\n tooltip,\r\n onSeriesMouseOver,\r\n highlightedDataPoints,\r\n selectedColor,\r\n minValue,\r\n maxValue,\r\n onSeriesMouseClick,\r\n prefix,\r\n suffix,\r\n stripType,\r\n highlightColor,\r\n dotOpacity,\r\n resetSelectionOnDoubleClick,\r\n detailsOnClick,\r\n styles,\r\n classNames,\r\n valueColor,\r\n animate,\r\n noOfTicks,\r\n dimmedOpacity,\r\n precision,\r\n customLayers,\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: 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) => ({ ...d, id: `${i}` }));\r\n\r\n const sortedData = orderBy(\r\n dataWithId,\r\n [\r\n item => {\r\n const index = (highlightedDataPoints || []).indexOf(item.label);\r\n return index === -1 ? Infinity : index;\r\n },\r\n ],\r\n ['desc'],\r\n );\r\n const xMaxValue = !checkIfNullOrUndefined(maxValue)\r\n ? (maxValue as number)\r\n : Math.max(...data.filter(d => !checkIfNullOrUndefined(d.position)).map(d => d.position)) < 0\r\n ? 0\r\n : Math.max(...data.filter(d => !checkIfNullOrUndefined(d.position)).map(d => d.position));\r\n const xMinValue = !checkIfNullOrUndefined(minValue)\r\n ? (minValue as number)\r\n : Math.min(...data.filter(d => !checkIfNullOrUndefined(d.position)).map(d => d.position)) >= 0\r\n ? 0\r\n : Math.min(...data.filter(d => !checkIfNullOrUndefined(d.position)).map(d => d.position));\r\n const x = scaleLinear().domain([xMinValue, xMaxValue]).range([0, graphWidth]).nice();\r\n const ticks = getTickPositions(noOfTicks, graphWidth);\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 {customLayers.filter(d => d.position === 'before').map(d => d.layer)}\r\n <AnimatePresence>\r\n {sortedData.map(d => {\r\n return (\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: 0,\r\n x: x(0),\r\n y: graphHeight / 2,\r\n },\r\n whileInView: {\r\n x: x(d.position),\r\n y: graphHeight / 2,\r\n opacity: selectedColor\r\n ? d.color\r\n ? colors[colorDomain.indexOf(d.color)] === selectedColor\r\n ? 0.95\r\n : dimmedOpacity\r\n : dimmedOpacity\r\n : highlightedDataPoints.length !== 0\r\n ? highlightedDataPoints.indexOf(d.label) !== -1\r\n ? 0.95\r\n : dimmedOpacity\r\n : dotOpacity,\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 {stripType === 'dot' ? (\r\n <motion.circle\r\n cy={0}\r\n cx={0}\r\n variants={{\r\n initial: {\r\n fill:\r\n highlightColor && highlightedDataPoints\r\n ? highlightedDataPoints.indexOf(d.label) !== -1\r\n ? highlightColor\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)]\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)],\r\n },\r\n whileInView: {\r\n fill:\r\n highlightColor && highlightedDataPoints\r\n ? highlightedDataPoints.indexOf(d.label) !== -1\r\n ? highlightColor\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)]\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[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={{ opacity: 0, transition: { duration: animate.duration } }}\r\n r={radius}\r\n />\r\n ) : (\r\n <motion.rect\r\n y={0 - radius}\r\n x={-1}\r\n height={radius * 2}\r\n width={2}\r\n variants={{\r\n initial: {\r\n fill:\r\n highlightColor && highlightedDataPoints\r\n ? highlightedDataPoints.indexOf(d.label) !== -1\r\n ? highlightColor\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)]\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)],\r\n },\r\n whileInView: {\r\n fill:\r\n highlightColor && highlightedDataPoints\r\n ? highlightedDataPoints.indexOf(d.label) !== -1\r\n ? highlightColor\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)]\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[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={{ opacity: 0, transition: { duration: animate.duration } }}\r\n />\r\n )}\r\n {highlightedDataPoints.length !== 0 ? (\r\n highlightedDataPoints.indexOf(d.label) !== -1 ? (\r\n <motion.text\r\n x={0}\r\n y={0 - radius - 5}\r\n variants={{\r\n initial: { opacity: 0 },\r\n whileInView: {\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={{ opacity: 0, transition: { duration: animate.duration } }}\r\n style={{\r\n fill:\r\n valueColor ||\r\n (highlightColor && highlightedDataPoints\r\n ? highlightedDataPoints.indexOf(d.label) !== -1\r\n ? highlightColor\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)]\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)]),\r\n textAnchor: 'middle',\r\n ...(styles?.graphObjectValues || {}),\r\n }}\r\n className={cn(\r\n 'graph-value text-sm font-bold',\r\n classNames?.graphObjectValues,\r\n )}\r\n >\r\n {numberFormattingFunction(d.position, 'NA', precision, prefix, suffix)}\r\n </motion.text>\r\n ) : null\r\n ) : null}\r\n </motion.g>\r\n );\r\n })}\r\n {ticks.map((tick, i) => (\r\n <text\r\n key={i}\r\n x={tick}\r\n y={graphHeight / 2 + radius}\r\n style={{\r\n textAnchor: i === 0 ? 'start' : i === ticks.length - 1 ? 'end' : 'middle',\r\n ...(styles?.xAxis?.labels || {}),\r\n }}\r\n className={cn(\r\n 'fill-primary-gray-550 dark:fill-primary-gray-500 text-xs',\r\n classNames?.xAxis?.labels,\r\n )}\r\n dy='1em'\r\n >\r\n {numberFormattingFunction(x.invert(tick), 'NA', precision, prefix, suffix)}\r\n </text>\r\n ))}\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\n\r\nimport { Graph } from './Graph';\r\n\r\nimport {\r\n Languages,\r\n SourcesDataType,\r\n StripChartDataType,\r\n StyleObject,\r\n ClassNameObject,\r\n CustomLayerDataType,\r\n AnimateDataType,\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 { uniqBy } from '@/Utils/uniqBy';\r\n\r\ninterface Props {\r\n data: StripChartDataType[];\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 stripType?: 'strip' | 'dot';\r\n colors?: string | string[];\r\n colorDomain?: string[];\r\n colorLegendTitle?: string;\r\n radius?: 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 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 highlightedDataPoints?: (string | number)[];\r\n showColorScale?: boolean;\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 prefix?: string;\r\n suffix?: string;\r\n language?: Languages;\r\n highlightColor?: string;\r\n dotOpacity?: number;\r\n showNAColor?: boolean;\r\n minHeight?: number;\r\n theme?: 'light' | 'dark';\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 styles?: StyleObject;\r\n classNames?: ClassNameObject;\r\n valueColor?: string;\r\n animate?: boolean | AnimateDataType;\r\n noOfTicks?: number;\r\n dimmedOpacity?: number;\r\n precision?: number;\r\n customLayers?: CustomLayerDataType[];\r\n}\r\n\r\nexport function HorizontalStripChart(props: Props) {\r\n const {\r\n data,\r\n graphTitle,\r\n colors,\r\n sources,\r\n graphDescription,\r\n height,\r\n width,\r\n footNote,\r\n colorDomain,\r\n colorLegendTitle,\r\n radius = 5,\r\n padding,\r\n backgroundColor = false,\r\n leftMargin = 5,\r\n rightMargin = 5,\r\n topMargin = 10,\r\n bottomMargin = 10,\r\n tooltip,\r\n relativeHeight,\r\n onSeriesMouseOver,\r\n showColorScale = true,\r\n highlightedDataPoints = [],\r\n graphID,\r\n minValue,\r\n maxValue,\r\n onSeriesMouseClick,\r\n graphDownload = false,\r\n dataDownload = false,\r\n prefix = '',\r\n suffix = '',\r\n stripType = 'dot',\r\n language = 'en',\r\n highlightColor,\r\n dotOpacity = 0.3,\r\n showNAColor = true,\r\n minHeight = 0,\r\n theme = 'light',\r\n ariaLabel,\r\n resetSelectionOnDoubleClick = true,\r\n detailsOnClick,\r\n styles,\r\n classNames,\r\n valueColor,\r\n animate = false,\r\n noOfTicks = 2,\r\n dimmedOpacity = 0.3,\r\n precision = 2,\r\n customLayers = [],\r\n } = props;\r\n\r\n const [svgWidth, setSvgWidth] = useState(0);\r\n const [svgHeight, setSvgHeight] = useState(0);\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 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 `${\r\n graphTitle ? `The graph shows ${graphTitle}. ` : ''\r\n }This is a strip chart showing distribution of data along the horizontal axis. Each dot represents an individual data point, helping to visualize the spread and clustering of values.${\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 <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 !== false && 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={\r\n showNAColor === undefined || showNAColor === null ? true : showNAColor\r\n }\r\n />\r\n ) : null}\r\n <div\r\n className='flex flex-col grow 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={data}\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 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 colors={\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 selectedColor={selectedColor}\r\n radius={radius}\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 highlightedDataPoints={highlightedDataPoints}\r\n minValue={minValue}\r\n maxValue={maxValue}\r\n onSeriesMouseClick={onSeriesMouseClick}\r\n prefix={prefix}\r\n suffix={suffix}\r\n stripType={stripType}\r\n highlightColor={highlightColor}\r\n dotOpacity={dotOpacity}\r\n resetSelectionOnDoubleClick={resetSelectionOnDoubleClick}\r\n detailsOnClick={detailsOnClick}\r\n styles={styles}\r\n classNames={classNames}\r\n valueColor={valueColor}\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 noOfTicks={noOfTicks}\r\n dimmedOpacity={dimmedOpacity}\r\n precision={precision}\r\n customLayers={customLayers}\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 { useRef, useState } from 'react';\r\nimport { scaleLinear } from 'd3-scale';\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\nimport orderBy from 'lodash.orderby';\r\n\r\nimport {\r\n AnimateDataType,\r\n ClassNameObject,\r\n CustomLayerDataType,\r\n StripChartDataType,\r\n StyleObject,\r\n} from '@/Types';\r\nimport { Tooltip } from '@/Components/Elements/Tooltip';\r\nimport { checkIfNullOrUndefined } from '@/Utils/checkIfNullOrUndefined';\r\nimport { numberFormattingFunction } from '@/Utils/numberFormattingFunction';\r\nimport { Colors } from '@/Components/ColorPalette';\r\nimport { string2HTML } from '@/Utils/string2HTML';\r\nimport { getTickPositions } from '@/Utils/getTickPosition';\r\n\r\ninterface Props {\r\n data: StripChartDataType[];\r\n width: number;\r\n height: number;\r\n selectedColor?: string;\r\n colors: string[];\r\n colorDomain: string[];\r\n radius: number;\r\n leftMargin: number;\r\n rightMargin: number;\r\n topMargin: 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 highlightedDataPoints: (string | number)[];\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 prefix: string;\r\n suffix: string;\r\n stripType: 'strip' | 'dot';\r\n highlightColor?: string;\r\n dotOpacity: 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 styles?: StyleObject;\r\n classNames?: ClassNameObject;\r\n valueColor?: string;\r\n animate: AnimateDataType;\r\n noOfTicks: number;\r\n dimmedOpacity: number;\r\n precision: number;\r\n customLayers: CustomLayerDataType[];\r\n}\r\n\r\nexport function Graph(props: Props) {\r\n const {\r\n data,\r\n width,\r\n height,\r\n colors,\r\n colorDomain,\r\n radius,\r\n leftMargin,\r\n rightMargin,\r\n topMargin,\r\n bottomMargin,\r\n tooltip,\r\n onSeriesMouseOver,\r\n highlightedDataPoints,\r\n selectedColor,\r\n minValue,\r\n maxValue,\r\n onSeriesMouseClick,\r\n noOfTicks,\r\n prefix,\r\n suffix,\r\n stripType,\r\n highlightColor,\r\n dotOpacity,\r\n resetSelectionOnDoubleClick,\r\n detailsOnClick,\r\n styles,\r\n classNames,\r\n valueColor,\r\n animate,\r\n dimmedOpacity,\r\n precision,\r\n customLayers,\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: 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) => ({ ...d, id: `${i}` }));\r\n\r\n const sortedData = orderBy(\r\n dataWithId,\r\n [\r\n item => {\r\n const index = (highlightedDataPoints || []).indexOf(item.label);\r\n return index === -1 ? Infinity : index;\r\n },\r\n ],\r\n ['desc'],\r\n );\r\n const yMaxValue = !checkIfNullOrUndefined(maxValue)\r\n ? (maxValue as number)\r\n : Math.max(...data.filter(d => !checkIfNullOrUndefined(d.position)).map(d => d.position)) < 0\r\n ? 0\r\n : Math.max(...data.filter(d => !checkIfNullOrUndefined(d.position)).map(d => d.position));\r\n const yMinValue = !checkIfNullOrUndefined(minValue)\r\n ? (minValue as number)\r\n : Math.min(...data.filter(d => !checkIfNullOrUndefined(d.position)).map(d => d.position)) >= 0\r\n ? 0\r\n : Math.min(...data.filter(d => !checkIfNullOrUndefined(d.position)).map(d => d.position));\r\n const y = scaleLinear().domain([yMinValue, yMaxValue]).range([graphHeight, 0]).nice();\r\n const ticks = getTickPositions(noOfTicks, graphHeight);\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 {customLayers.filter(d => d.position === 'before').map(d => d.layer)}\r\n <AnimatePresence>\r\n {sortedData.map(d => {\r\n return (\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: 0,\r\n x: graphWidth / 2,\r\n y: y(0),\r\n },\r\n whileInView: {\r\n x: graphWidth / 2,\r\n y: y(d.position),\r\n opacity: selectedColor\r\n ? d.color\r\n ? colors[colorDomain.indexOf(d.color)] === selectedColor\r\n ? 0.95\r\n : dimmedOpacity\r\n : dimmedOpacity\r\n : highlightedDataPoints.length !== 0\r\n ? highlightedDataPoints.indexOf(d.label) !== -1\r\n ? 0.95\r\n : dimmedOpacity\r\n : dotOpacity,\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 {stripType === 'dot' ? (\r\n <motion.circle\r\n cy={0}\r\n cx={0}\r\n variants={{\r\n initial: {\r\n fill:\r\n highlightColor && highlightedDataPoints\r\n ? highlightedDataPoints.indexOf(d.label) !== -1\r\n ? highlightColor\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)]\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)],\r\n },\r\n whileInView: {\r\n fill:\r\n highlightColor && highlightedDataPoints\r\n ? highlightedDataPoints.indexOf(d.label) !== -1\r\n ? highlightColor\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)]\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[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={{ opacity: 0, transition: { duration: animate.duration } }}\r\n r={radius}\r\n />\r\n ) : (\r\n <motion.rect\r\n x={0 - radius}\r\n y={-1}\r\n width={radius * 2}\r\n height={2}\r\n variants={{\r\n initial: {\r\n fill:\r\n highlightColor && highlightedDataPoints\r\n ? highlightedDataPoints.indexOf(d.label) !== -1\r\n ? highlightColor\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)]\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)],\r\n },\r\n whileInView: {\r\n fill:\r\n highlightColor && highlightedDataPoints\r\n ? highlightedDataPoints.indexOf(d.label) !== -1\r\n ? highlightColor\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)]\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[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={{ opacity: 0, transition: { duration: animate.duration } }}\r\n />\r\n )}\r\n {highlightedDataPoints.length !== 0 ? (\r\n highlightedDataPoints.indexOf(d.label) !== -1 ? (\r\n <motion.text\r\n y={0}\r\n dy='0.33em'\r\n x={0 + radius + 3}\r\n variants={{\r\n initial: { opacity: 0 },\r\n whileInView: {\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={{ opacity: 0, transition: { duration: animate.duration } }}\r\n style={{\r\n fill:\r\n valueColor ||\r\n (highlightColor && highlightedDataPoints\r\n ? highlightedDataPoints.indexOf(d.label) !== -1\r\n ? highlightColor\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)]\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)]),\r\n textAnchor: 'start',\r\n ...(styles?.graphObjectValues || {}),\r\n }}\r\n className={cn(\r\n 'graph-value text-sm font-bold',\r\n classNames?.graphObjectValues,\r\n )}\r\n >\r\n {numberFormattingFunction(d.position, 'NA', precision, prefix, suffix)}\r\n </motion.text>\r\n ) : null\r\n ) : null}\r\n </motion.g>\r\n );\r\n })}\r\n {ticks.map((tick, i) => (\r\n <text\r\n key={i}\r\n y={tick}\r\n x={graphWidth / 2 + radius + 5}\r\n style={{\r\n textAnchor: 'start',\r\n ...(styles?.yAxis?.labels || {}),\r\n }}\r\n className={cn(\r\n 'fill-primary-gray-550 dark:fill-primary-gray-500 text-xs',\r\n classNames?.yAxis?.labels,\r\n )}\r\n >\r\n {numberFormattingFunction(y.invert(tick), 'NA', precision, prefix, suffix)}\r\n </text>\r\n ))}\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\n\r\nimport { Graph } from './Graph';\r\n\r\nimport {\r\n Languages,\r\n SourcesDataType,\r\n StripChartDataType,\r\n StyleObject,\r\n ClassNameObject,\r\n CustomLayerDataType,\r\n AnimateDataType,\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 { uniqBy } from '@/Utils/uniqBy';\r\n\r\ninterface Props {\r\n data: StripChartDataType[];\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 colors?: string | string[];\r\n colorDomain?: string[];\r\n colorLegendTitle?: string;\r\n radius?: 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 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 highlightedDataPoints?: (string | number)[];\r\n showColorScale?: boolean;\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 prefix?: string;\r\n suffix?: string;\r\n stripType?: 'strip' | 'dot';\r\n language?: Languages;\r\n highlightColor?: string;\r\n dotOpacity?: number;\r\n showNAColor?: boolean;\r\n minHeight?: number;\r\n theme?: 'light' | 'dark';\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 styles?: StyleObject;\r\n classNames?: ClassNameObject;\r\n valueColor?: string;\r\n animate?: boolean | AnimateDataType;\r\n noOfTicks?: number;\r\n dimmedOpacity?: number;\r\n precision?: number;\r\n customLayers?: CustomLayerDataType[];\r\n}\r\n\r\nexport function VerticalStripChart(props: Props) {\r\n const {\r\n data,\r\n graphTitle,\r\n colors,\r\n sources,\r\n graphDescription,\r\n height,\r\n width,\r\n footNote,\r\n colorDomain,\r\n colorLegendTitle,\r\n radius = 5,\r\n padding,\r\n backgroundColor = false,\r\n leftMargin = 20,\r\n rightMargin = 20,\r\n topMargin = 10,\r\n bottomMargin = 10,\r\n tooltip,\r\n relativeHeight,\r\n onSeriesMouseOver,\r\n showColorScale = true,\r\n highlightedDataPoints = [],\r\n graphID,\r\n minValue,\r\n maxValue,\r\n onSeriesMouseClick,\r\n graphDownload = false,\r\n dataDownload = false,\r\n prefix = '',\r\n suffix = '',\r\n stripType = 'dot',\r\n language = 'en',\r\n highlightColor,\r\n dotOpacity = 0.3,\r\n showNAColor = true,\r\n minHeight = 0,\r\n theme = 'light',\r\n ariaLabel,\r\n resetSelectionOnDoubleClick = true,\r\n detailsOnClick,\r\n styles,\r\n classNames,\r\n valueColor,\r\n animate = false,\r\n noOfTicks = 2,\r\n dimmedOpacity = 0.3,\r\n precision = 2,\r\n customLayers = [],\r\n } = props;\r\n\r\n const [svgWidth, setSvgWidth] = useState(0);\r\n const [svgHeight, setSvgHeight] = useState(0);\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 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 `${\r\n graphTitle ? `The graph shows ${graphTitle}. ` : ''\r\n }This is a strip chart showing distribution of data along the vertical axis. Each dot represents an individual data point, helping to visualize the spread and clustering of values.${\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 <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 !== false && 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 flex-col grow justify-center w-full leading-0'\r\n ref={graphDiv}\r\n >\r\n {(width || svgWidth) && (height || svgHeight) ? (\r\n <Graph\r\n data={data}\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 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 colors={\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 selectedColor={selectedColor}\r\n radius={radius}\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 highlightedDataPoints={highlightedDataPoints}\r\n minValue={minValue}\r\n maxValue={maxValue}\r\n onSeriesMouseClick={onSeriesMouseClick}\r\n prefix={prefix}\r\n suffix={suffix}\r\n stripType={stripType}\r\n highlightColor={highlightColor}\r\n dotOpacity={dotOpacity}\r\n resetSelectionOnDoubleClick={resetSelectionOnDoubleClick}\r\n detailsOnClick={detailsOnClick}\r\n styles={styles}\r\n classNames={classNames}\r\n valueColor={valueColor}\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 noOfTicks={noOfTicks}\r\n dimmedOpacity={dimmedOpacity}\r\n precision={precision}\r\n customLayers={customLayers}\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 { HorizontalStripChart } from './Horizontal';\r\nimport { VerticalStripChart } from './Vertical';\r\n\r\nimport {\r\n SourcesDataType,\r\n Languages,\r\n StripChartDataType,\r\n StyleObject,\r\n ClassNameObject,\r\n CustomLayerDataType,\r\n AnimateDataType,\r\n} from '@/Types';\r\n\r\ninterface Props {\r\n // Data\r\n /** Array of data objects */\r\n data: StripChartDataType[];\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 circles */\r\n colors?: string | string[];\r\n /** Color of the highlighted data points */\r\n highlightColor?: 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\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\r\n // Graph Parameters\r\n /** Number of ticks on the axis */\r\n noOfTicks?: number;\r\n /** Radius of the dots or width of the strips */\r\n radius?: number;\r\n /** Opacity of each dot or strip */\r\n dotOpacity?: number;\r\n /** Type of strip */\r\n stripType?: 'strip' | 'dot';\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 /** 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 /** 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 StripChart(props: Props) {\r\n const {\r\n data,\r\n graphTitle,\r\n colors,\r\n sources,\r\n graphDescription,\r\n height,\r\n width,\r\n footNote,\r\n colorDomain,\r\n colorLegendTitle,\r\n radius,\r\n padding,\r\n backgroundColor,\r\n leftMargin,\r\n rightMargin,\r\n topMargin,\r\n bottomMargin,\r\n tooltip,\r\n relativeHeight,\r\n onSeriesMouseOver,\r\n showColorScale,\r\n highlightedDataPoints,\r\n graphID,\r\n minValue,\r\n maxValue,\r\n onSeriesMouseClick,\r\n noOfTicks,\r\n graphDownload,\r\n dataDownload,\r\n prefix,\r\n suffix,\r\n stripType,\r\n language,\r\n highlightColor,\r\n dotOpacity,\r\n showNAColor,\r\n minHeight,\r\n theme,\r\n ariaLabel,\r\n valueColor,\r\n resetSelectionOnDoubleClick,\r\n detailsOnClick,\r\n orientation = 'vertical',\r\n styles,\r\n classNames,\r\n animate,\r\n dimmedOpacity = 0.3,\r\n precision,\r\n customLayers,\r\n } = props;\r\n\r\n if (orientation === 'vertical')\r\n return (\r\n <VerticalStripChart\r\n data={data}\r\n graphTitle={graphTitle}\r\n colors={colors}\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 radius={radius}\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 tooltip={tooltip}\r\n relativeHeight={relativeHeight}\r\n onSeriesMouseOver={onSeriesMouseOver}\r\n showColorScale={showColorScale}\r\n highlightedDataPoints={highlightedDataPoints}\r\n graphID={graphID}\r\n minValue={minValue}\r\n maxValue={maxValue}\r\n onSeriesMouseClick={onSeriesMouseClick}\r\n noOfTicks={noOfTicks}\r\n graphDownload={graphDownload}\r\n dataDownload={dataDownload}\r\n prefix={prefix}\r\n suffix={suffix}\r\n stripType={stripType}\r\n language={language}\r\n highlightColor={highlightColor}\r\n dotOpacity={dotOpacity}\r\n showNAColor={showNAColor}\r\n minHeight={minHeight}\r\n theme={theme}\r\n ariaLabel={ariaLabel}\r\n resetSelectionOnDoubleClick={resetSelectionOnDoubleClick}\r\n styles={styles}\r\n valueColor={valueColor}\r\n detailsOnClick={detailsOnClick}\r\n classNames={classNames}\r\n animate={animate}\r\n dimmedOpacity={dimmedOpacity}\r\n precision={precision}\r\n customLayers={customLayers}\r\n />\r\n );\r\n return (\r\n <HorizontalStripChart\r\n data={data}\r\n graphTitle={graphTitle}\r\n colors={colors}\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 radius={radius}\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 tooltip={tooltip}\r\n relativeHeight={relativeHeight}\r\n onSeriesMouseOver={onSeriesMouseOver}\r\n showColorScale={showColorScale}\r\n highlightedDataPoints={highlightedDataPoints}\r\n graphID={graphID}\r\n minValue={minValue}\r\n maxValue={maxValue}\r\n onSeriesMouseClick={onSeriesMouseClick}\r\n noOfTicks={noOfTicks}\r\n graphDownload={graphDownload}\r\n dataDownload={dataDownload}\r\n prefix={prefix}\r\n suffix={suffix}\r\n stripType={stripType}\r\n language={language}\r\n highlightColor={highlightColor}\r\n dotOpacity={dotOpacity}\r\n showNAColor={showNAColor}\r\n minHeight={minHeight}\r\n theme={theme}\r\n ariaLabel={ariaLabel}\r\n resetSelectionOnDoubleClick={resetSelectionOnDoubleClick}\r\n styles={styles}\r\n valueColor={valueColor}\r\n detailsOnClick={detailsOnClick}\r\n classNames={classNames}\r\n animate={animate}\r\n dimmedOpacity={dimmedOpacity}\r\n precision={precision}\r\n customLayers={customLayers}\r\n />\r\n );\r\n}\r\n"],"names":["getTickPositions","count","width","step","_","i","Graph","props","data","height","colors","colorDomain","radius","leftMargin","rightMargin","topMargin","bottomMargin","tooltip","onSeriesMouseOver","highlightedDataPoints","selectedColor","minValue","maxValue","onSeriesMouseClick","prefix","suffix","stripType","highlightColor","dotOpacity","resetSelectionOnDoubleClick","detailsOnClick","styles","classNames","valueColor","animate","noOfTicks","dimmedOpacity","precision","customLayers","svgRef","useRef","isInView","useInView","mouseOverData","setMouseOverData","useState","mouseClickData","setMouseClickData","eventX","setEventX","eventY","setEventY","margin","graphWidth","graphHeight","dataWithId","d","sortedData","orderBy","item","index","xMaxValue","checkIfNullOrUndefined","xMinValue","x","scaleLinear","ticks","jsxs","Fragment","jsx","motion","AnimatePresence","event","isEqual","el","Colors","cn","tick","numberFormattingFunction","Tooltip","Modal","string2HTML","HorizontalStripChart","graphTitle","sources","graphDescription","footNote","colorLegendTitle","padding","backgroundColor","relativeHeight","showColorScale","graphID","graphDownload","dataDownload","language","showNAColor","minHeight","theme","ariaLabel","svgWidth","setSvgWidth","svgHeight","setSvgHeight","setSelectedColor","graphDiv","graphParentDiv","useEffect","resizeObserver","entries","GraphHeader","EmptyState","ColorLegendWithMouseOver","uniqBy","GraphFooter","yMaxValue","yMinValue","y","VerticalStripChart","StripChart","orientation"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"StripChart.js","sources":["../src/Utils/getTickPosition.ts","../src/Components/Graphs/StripChart/Horizontal/Graph.tsx","../src/Components/Graphs/StripChart/Horizontal/index.tsx","../src/Components/Graphs/StripChart/Vertical/Graph.tsx","../src/Components/Graphs/StripChart/Vertical/index.tsx","../src/Components/Graphs/StripChart/index.tsx"],"sourcesContent":["export function getTickPositions(count: number, width: number) {\r\n if (count < 2) return [];\r\n const step = width / (count - 1);\r\n return Array.from({ length: count }, (_, i) => i * step);\r\n}\r\n","import isEqual from 'fast-deep-equal';\r\nimport { useRef, useState } from 'react';\r\nimport { scaleLinear } from 'd3-scale';\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\nimport orderBy from 'lodash.orderby';\r\n\r\nimport {\r\n AnimateDataType,\r\n ClassNameObject,\r\n CustomLayerDataType,\r\n StripChartDataType,\r\n StyleObject,\r\n} from '@/Types';\r\nimport { Tooltip } from '@/Components/Elements/Tooltip';\r\nimport { checkIfNullOrUndefined } from '@/Utils/checkIfNullOrUndefined';\r\nimport { numberFormattingFunction } from '@/Utils/numberFormattingFunction';\r\nimport { Colors } from '@/Components/ColorPalette';\r\nimport { string2HTML } from '@/Utils/string2HTML';\r\nimport { getTickPositions } from '@/Utils/getTickPosition';\r\n\r\ninterface Props {\r\n data: StripChartDataType[];\r\n width: number;\r\n height: number;\r\n selectedColor?: string;\r\n colors: string[];\r\n colorDomain: string[];\r\n radius: number;\r\n leftMargin: number;\r\n rightMargin: number;\r\n topMargin: 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 highlightedDataPoints: (string | number)[];\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 prefix: string;\r\n suffix: string;\r\n stripType: 'strip' | 'dot';\r\n highlightColor?: string;\r\n dotOpacity: 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 styles?: StyleObject;\r\n classNames?: ClassNameObject;\r\n valueColor?: string;\r\n animate: AnimateDataType;\r\n noOfTicks: number;\r\n dimmedOpacity: number;\r\n precision: number;\r\n customLayers: CustomLayerDataType[];\r\n}\r\n\r\nexport function Graph(props: Props) {\r\n const {\r\n data,\r\n width,\r\n height,\r\n colors,\r\n colorDomain,\r\n radius,\r\n leftMargin,\r\n rightMargin,\r\n topMargin,\r\n bottomMargin,\r\n tooltip,\r\n onSeriesMouseOver,\r\n highlightedDataPoints,\r\n selectedColor,\r\n minValue,\r\n maxValue,\r\n onSeriesMouseClick,\r\n prefix,\r\n suffix,\r\n stripType,\r\n highlightColor,\r\n dotOpacity,\r\n resetSelectionOnDoubleClick,\r\n detailsOnClick,\r\n styles,\r\n classNames,\r\n valueColor,\r\n animate,\r\n noOfTicks,\r\n dimmedOpacity,\r\n precision,\r\n customLayers,\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: 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) => ({ ...d, id: `${i}` }));\r\n\r\n const sortedData = orderBy(\r\n dataWithId,\r\n [\r\n item => {\r\n const index = (highlightedDataPoints || []).indexOf(item.label);\r\n return index === -1 ? Infinity : index;\r\n },\r\n ],\r\n ['desc'],\r\n );\r\n const xMaxValue = !checkIfNullOrUndefined(maxValue)\r\n ? (maxValue as number)\r\n : Math.max(...data.filter(d => !checkIfNullOrUndefined(d.position)).map(d => d.position)) < 0\r\n ? 0\r\n : Math.max(...data.filter(d => !checkIfNullOrUndefined(d.position)).map(d => d.position));\r\n const xMinValue = !checkIfNullOrUndefined(minValue)\r\n ? (minValue as number)\r\n : Math.min(...data.filter(d => !checkIfNullOrUndefined(d.position)).map(d => d.position)) >= 0\r\n ? 0\r\n : Math.min(...data.filter(d => !checkIfNullOrUndefined(d.position)).map(d => d.position));\r\n const x = scaleLinear().domain([xMinValue, xMaxValue]).range([0, graphWidth]).nice();\r\n const ticks = getTickPositions(noOfTicks, graphWidth);\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 {customLayers.filter(d => d.position === 'before').map(d => d.layer)}\r\n <AnimatePresence>\r\n {sortedData.map(d => {\r\n return (\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: 0,\r\n x: x(0),\r\n y: graphHeight / 2,\r\n },\r\n whileInView: {\r\n x: x(d.position),\r\n y: graphHeight / 2,\r\n opacity: selectedColor\r\n ? d.color\r\n ? colors[colorDomain.indexOf(d.color)] === selectedColor\r\n ? 0.95\r\n : dimmedOpacity\r\n : dimmedOpacity\r\n : highlightedDataPoints.length !== 0\r\n ? highlightedDataPoints.indexOf(d.label) !== -1\r\n ? 0.95\r\n : dimmedOpacity\r\n : dotOpacity,\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 {stripType === 'dot' ? (\r\n <motion.circle\r\n cy={0}\r\n cx={0}\r\n variants={{\r\n initial: {\r\n fill:\r\n highlightColor && highlightedDataPoints\r\n ? highlightedDataPoints.indexOf(d.label) !== -1\r\n ? highlightColor\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)]\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)],\r\n },\r\n whileInView: {\r\n fill:\r\n highlightColor && highlightedDataPoints\r\n ? highlightedDataPoints.indexOf(d.label) !== -1\r\n ? highlightColor\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)]\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[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={{ opacity: 0, transition: { duration: animate.duration } }}\r\n r={radius}\r\n />\r\n ) : (\r\n <motion.rect\r\n x={-1}\r\n width={2}\r\n variants={{\r\n initial: {\r\n y: 0 - radius,\r\n height: radius * 2,\r\n fill:\r\n highlightColor && highlightedDataPoints\r\n ? highlightedDataPoints.indexOf(d.label) !== -1\r\n ? highlightColor\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)]\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)],\r\n },\r\n whileInView: {\r\n y: 0 - radius,\r\n height: radius * 2,\r\n fill:\r\n highlightColor && highlightedDataPoints\r\n ? highlightedDataPoints.indexOf(d.label) !== -1\r\n ? highlightColor\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)]\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[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={{ opacity: 0, transition: { duration: animate.duration } }}\r\n />\r\n )}\r\n {highlightedDataPoints.length !== 0 ? (\r\n highlightedDataPoints.indexOf(d.label) !== -1 ? (\r\n <motion.text\r\n x={0}\r\n variants={{\r\n initial: {\r\n opacity: 0,\r\n y: 0 - radius - 5,\r\n fill:\r\n valueColor ||\r\n (highlightColor && highlightedDataPoints\r\n ? highlightedDataPoints.indexOf(d.label) !== -1\r\n ? highlightColor\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)]\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)]),\r\n },\r\n whileInView: {\r\n opacity: 1,\r\n y: 0 - radius - 5,\r\n fill:\r\n valueColor ||\r\n (highlightColor && highlightedDataPoints\r\n ? highlightedDataPoints.indexOf(d.label) !== -1\r\n ? highlightColor\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)]\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[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={{ opacity: 0, transition: { duration: animate.duration } }}\r\n style={{\r\n textAnchor: 'middle',\r\n ...(styles?.graphObjectValues || {}),\r\n }}\r\n className={cn(\r\n 'graph-value text-sm font-bold',\r\n classNames?.graphObjectValues,\r\n )}\r\n >\r\n {numberFormattingFunction(d.position, 'NA', precision, prefix, suffix)}\r\n </motion.text>\r\n ) : null\r\n ) : null}\r\n </motion.g>\r\n );\r\n })}\r\n {ticks.map((tick, i) => (\r\n <text\r\n key={i}\r\n x={tick}\r\n y={graphHeight / 2 + radius}\r\n style={{\r\n textAnchor: i === 0 ? 'start' : i === ticks.length - 1 ? 'end' : 'middle',\r\n ...(styles?.xAxis?.labels || {}),\r\n }}\r\n className={cn(\r\n 'fill-primary-gray-550 dark:fill-primary-gray-500 text-xs',\r\n classNames?.xAxis?.labels,\r\n )}\r\n dy='1em'\r\n >\r\n {numberFormattingFunction(x.invert(tick), 'NA', precision, prefix, suffix)}\r\n </text>\r\n ))}\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\n\r\nimport { Graph } from './Graph';\r\n\r\nimport {\r\n Languages,\r\n SourcesDataType,\r\n StripChartDataType,\r\n StyleObject,\r\n ClassNameObject,\r\n CustomLayerDataType,\r\n AnimateDataType,\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 { uniqBy } from '@/Utils/uniqBy';\r\n\r\ninterface Props {\r\n data: StripChartDataType[];\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 stripType?: 'strip' | 'dot';\r\n colors?: string | string[];\r\n colorDomain?: string[];\r\n colorLegendTitle?: string;\r\n radius?: 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 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 highlightedDataPoints?: (string | number)[];\r\n showColorScale?: boolean;\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 prefix?: string;\r\n suffix?: string;\r\n language?: Languages;\r\n highlightColor?: string;\r\n dotOpacity?: number;\r\n showNAColor?: boolean;\r\n minHeight?: number;\r\n theme?: 'light' | 'dark';\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 styles?: StyleObject;\r\n classNames?: ClassNameObject;\r\n valueColor?: string;\r\n animate?: boolean | AnimateDataType;\r\n noOfTicks?: number;\r\n dimmedOpacity?: number;\r\n precision?: number;\r\n customLayers?: CustomLayerDataType[];\r\n}\r\n\r\nexport function HorizontalStripChart(props: Props) {\r\n const {\r\n data,\r\n graphTitle,\r\n colors,\r\n sources,\r\n graphDescription,\r\n height,\r\n width,\r\n footNote,\r\n colorDomain,\r\n colorLegendTitle,\r\n radius = 5,\r\n padding,\r\n backgroundColor = false,\r\n leftMargin = 5,\r\n rightMargin = 5,\r\n topMargin = 10,\r\n bottomMargin = 10,\r\n tooltip,\r\n relativeHeight,\r\n onSeriesMouseOver,\r\n showColorScale = true,\r\n highlightedDataPoints = [],\r\n graphID,\r\n minValue,\r\n maxValue,\r\n onSeriesMouseClick,\r\n graphDownload = false,\r\n dataDownload = false,\r\n prefix = '',\r\n suffix = '',\r\n stripType = 'dot',\r\n language = 'en',\r\n highlightColor,\r\n dotOpacity = 0.3,\r\n showNAColor = true,\r\n minHeight = 0,\r\n theme = 'light',\r\n ariaLabel,\r\n resetSelectionOnDoubleClick = true,\r\n detailsOnClick,\r\n styles,\r\n classNames,\r\n valueColor,\r\n animate = false,\r\n noOfTicks = 2,\r\n dimmedOpacity = 0.3,\r\n precision = 2,\r\n customLayers = [],\r\n } = props;\r\n\r\n const [svgWidth, setSvgWidth] = useState(0);\r\n const [svgHeight, setSvgHeight] = useState(0);\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 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 `${\r\n graphTitle ? `The graph shows ${graphTitle}. ` : ''\r\n }This is a strip chart showing distribution of data along the horizontal axis. Each dot represents an individual data point, helping to visualize the spread and clustering of values.${\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 <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 !== false && 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={\r\n showNAColor === undefined || showNAColor === null ? true : showNAColor\r\n }\r\n />\r\n ) : null}\r\n <div\r\n className='flex flex-col grow 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={data}\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 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 colors={\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 selectedColor={selectedColor}\r\n radius={radius}\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 highlightedDataPoints={highlightedDataPoints}\r\n minValue={minValue}\r\n maxValue={maxValue}\r\n onSeriesMouseClick={onSeriesMouseClick}\r\n prefix={prefix}\r\n suffix={suffix}\r\n stripType={stripType}\r\n highlightColor={highlightColor}\r\n dotOpacity={dotOpacity}\r\n resetSelectionOnDoubleClick={resetSelectionOnDoubleClick}\r\n detailsOnClick={detailsOnClick}\r\n styles={styles}\r\n classNames={classNames}\r\n valueColor={valueColor}\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 noOfTicks={noOfTicks}\r\n dimmedOpacity={dimmedOpacity}\r\n precision={precision}\r\n customLayers={customLayers}\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 { useRef, useState } from 'react';\r\nimport { scaleLinear } from 'd3-scale';\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\nimport orderBy from 'lodash.orderby';\r\n\r\nimport {\r\n AnimateDataType,\r\n ClassNameObject,\r\n CustomLayerDataType,\r\n StripChartDataType,\r\n StyleObject,\r\n} from '@/Types';\r\nimport { Tooltip } from '@/Components/Elements/Tooltip';\r\nimport { checkIfNullOrUndefined } from '@/Utils/checkIfNullOrUndefined';\r\nimport { numberFormattingFunction } from '@/Utils/numberFormattingFunction';\r\nimport { Colors } from '@/Components/ColorPalette';\r\nimport { string2HTML } from '@/Utils/string2HTML';\r\nimport { getTickPositions } from '@/Utils/getTickPosition';\r\n\r\ninterface Props {\r\n data: StripChartDataType[];\r\n width: number;\r\n height: number;\r\n selectedColor?: string;\r\n colors: string[];\r\n colorDomain: string[];\r\n radius: number;\r\n leftMargin: number;\r\n rightMargin: number;\r\n topMargin: 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 highlightedDataPoints: (string | number)[];\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 prefix: string;\r\n suffix: string;\r\n stripType: 'strip' | 'dot';\r\n highlightColor?: string;\r\n dotOpacity: 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 styles?: StyleObject;\r\n classNames?: ClassNameObject;\r\n valueColor?: string;\r\n animate: AnimateDataType;\r\n noOfTicks: number;\r\n dimmedOpacity: number;\r\n precision: number;\r\n customLayers: CustomLayerDataType[];\r\n}\r\n\r\nexport function Graph(props: Props) {\r\n const {\r\n data,\r\n width,\r\n height,\r\n colors,\r\n colorDomain,\r\n radius,\r\n leftMargin,\r\n rightMargin,\r\n topMargin,\r\n bottomMargin,\r\n tooltip,\r\n onSeriesMouseOver,\r\n highlightedDataPoints,\r\n selectedColor,\r\n minValue,\r\n maxValue,\r\n onSeriesMouseClick,\r\n noOfTicks,\r\n prefix,\r\n suffix,\r\n stripType,\r\n highlightColor,\r\n dotOpacity,\r\n resetSelectionOnDoubleClick,\r\n detailsOnClick,\r\n styles,\r\n classNames,\r\n valueColor,\r\n animate,\r\n dimmedOpacity,\r\n precision,\r\n customLayers,\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: 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) => ({ ...d, id: `${i}` }));\r\n\r\n const sortedData = orderBy(\r\n dataWithId,\r\n [\r\n item => {\r\n const index = (highlightedDataPoints || []).indexOf(item.label);\r\n return index === -1 ? Infinity : index;\r\n },\r\n ],\r\n ['desc'],\r\n );\r\n const yMaxValue = !checkIfNullOrUndefined(maxValue)\r\n ? (maxValue as number)\r\n : Math.max(...data.filter(d => !checkIfNullOrUndefined(d.position)).map(d => d.position)) < 0\r\n ? 0\r\n : Math.max(...data.filter(d => !checkIfNullOrUndefined(d.position)).map(d => d.position));\r\n const yMinValue = !checkIfNullOrUndefined(minValue)\r\n ? (minValue as number)\r\n : Math.min(...data.filter(d => !checkIfNullOrUndefined(d.position)).map(d => d.position)) >= 0\r\n ? 0\r\n : Math.min(...data.filter(d => !checkIfNullOrUndefined(d.position)).map(d => d.position));\r\n const y = scaleLinear().domain([yMinValue, yMaxValue]).range([graphHeight, 0]).nice();\r\n const ticks = getTickPositions(noOfTicks, graphHeight);\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 {customLayers.filter(d => d.position === 'before').map(d => d.layer)}\r\n <AnimatePresence>\r\n {sortedData.map(d => {\r\n return (\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: 0,\r\n x: graphWidth / 2,\r\n y: y(0),\r\n },\r\n whileInView: {\r\n x: graphWidth / 2,\r\n y: y(d.position),\r\n opacity: selectedColor\r\n ? d.color\r\n ? colors[colorDomain.indexOf(d.color)] === selectedColor\r\n ? 0.95\r\n : dimmedOpacity\r\n : dimmedOpacity\r\n : highlightedDataPoints.length !== 0\r\n ? highlightedDataPoints.indexOf(d.label) !== -1\r\n ? 0.95\r\n : dimmedOpacity\r\n : dotOpacity,\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 {stripType === 'dot' ? (\r\n <motion.circle\r\n cy={0}\r\n cx={0}\r\n variants={{\r\n initial: {\r\n fill:\r\n highlightColor && highlightedDataPoints\r\n ? highlightedDataPoints.indexOf(d.label) !== -1\r\n ? highlightColor\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)]\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)],\r\n },\r\n whileInView: {\r\n fill:\r\n highlightColor && highlightedDataPoints\r\n ? highlightedDataPoints.indexOf(d.label) !== -1\r\n ? highlightColor\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)]\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[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={{ opacity: 0, transition: { duration: animate.duration } }}\r\n r={radius}\r\n />\r\n ) : (\r\n <motion.rect\r\n y={-1}\r\n height={2}\r\n variants={{\r\n initial: {\r\n x: 0 - radius,\r\n width: radius * 2,\r\n fill:\r\n highlightColor && highlightedDataPoints\r\n ? highlightedDataPoints.indexOf(d.label) !== -1\r\n ? highlightColor\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)]\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)],\r\n },\r\n whileInView: {\r\n x: 0 - radius,\r\n width: radius * 2,\r\n fill:\r\n highlightColor && highlightedDataPoints\r\n ? highlightedDataPoints.indexOf(d.label) !== -1\r\n ? highlightColor\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)]\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[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={{ opacity: 0, transition: { duration: animate.duration } }}\r\n />\r\n )}\r\n {highlightedDataPoints.length !== 0 ? (\r\n highlightedDataPoints.indexOf(d.label) !== -1 ? (\r\n <motion.text\r\n y={0}\r\n dy='0.33em'\r\n variants={{\r\n initial: {\r\n opacity: 0,\r\n x: 0 + radius + 3,\r\n fill:\r\n valueColor ||\r\n (highlightColor && highlightedDataPoints\r\n ? highlightedDataPoints.indexOf(d.label) !== -1\r\n ? highlightColor\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)]\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)]),\r\n },\r\n whileInView: {\r\n opacity: 1,\r\n x: 0 + radius + 3,\r\n fill:\r\n valueColor ||\r\n (highlightColor && highlightedDataPoints\r\n ? highlightedDataPoints.indexOf(d.label) !== -1\r\n ? highlightColor\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)]\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[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={{ opacity: 0, transition: { duration: animate.duration } }}\r\n style={{\r\n textAnchor: 'start',\r\n ...(styles?.graphObjectValues || {}),\r\n }}\r\n className={cn(\r\n 'graph-value text-sm font-bold',\r\n classNames?.graphObjectValues,\r\n )}\r\n >\r\n {numberFormattingFunction(d.position, 'NA', precision, prefix, suffix)}\r\n </motion.text>\r\n ) : null\r\n ) : null}\r\n </motion.g>\r\n );\r\n })}\r\n {ticks.map((tick, i) => (\r\n <text\r\n key={i}\r\n y={tick}\r\n x={graphWidth / 2 + radius + 5}\r\n style={{\r\n textAnchor: 'start',\r\n ...(styles?.yAxis?.labels || {}),\r\n }}\r\n className={cn(\r\n 'fill-primary-gray-550 dark:fill-primary-gray-500 text-xs',\r\n classNames?.yAxis?.labels,\r\n )}\r\n >\r\n {numberFormattingFunction(y.invert(tick), 'NA', precision, prefix, suffix)}\r\n </text>\r\n ))}\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\n\r\nimport { Graph } from './Graph';\r\n\r\nimport {\r\n Languages,\r\n SourcesDataType,\r\n StripChartDataType,\r\n StyleObject,\r\n ClassNameObject,\r\n CustomLayerDataType,\r\n AnimateDataType,\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 { uniqBy } from '@/Utils/uniqBy';\r\n\r\ninterface Props {\r\n data: StripChartDataType[];\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 colors?: string | string[];\r\n colorDomain?: string[];\r\n colorLegendTitle?: string;\r\n radius?: 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 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 highlightedDataPoints?: (string | number)[];\r\n showColorScale?: boolean;\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 prefix?: string;\r\n suffix?: string;\r\n stripType?: 'strip' | 'dot';\r\n language?: Languages;\r\n highlightColor?: string;\r\n dotOpacity?: number;\r\n showNAColor?: boolean;\r\n minHeight?: number;\r\n theme?: 'light' | 'dark';\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 styles?: StyleObject;\r\n classNames?: ClassNameObject;\r\n valueColor?: string;\r\n animate?: boolean | AnimateDataType;\r\n noOfTicks?: number;\r\n dimmedOpacity?: number;\r\n precision?: number;\r\n customLayers?: CustomLayerDataType[];\r\n}\r\n\r\nexport function VerticalStripChart(props: Props) {\r\n const {\r\n data,\r\n graphTitle,\r\n colors,\r\n sources,\r\n graphDescription,\r\n height,\r\n width,\r\n footNote,\r\n colorDomain,\r\n colorLegendTitle,\r\n radius = 5,\r\n padding,\r\n backgroundColor = false,\r\n leftMargin = 20,\r\n rightMargin = 20,\r\n topMargin = 10,\r\n bottomMargin = 10,\r\n tooltip,\r\n relativeHeight,\r\n onSeriesMouseOver,\r\n showColorScale = true,\r\n highlightedDataPoints = [],\r\n graphID,\r\n minValue,\r\n maxValue,\r\n onSeriesMouseClick,\r\n graphDownload = false,\r\n dataDownload = false,\r\n prefix = '',\r\n suffix = '',\r\n stripType = 'dot',\r\n language = 'en',\r\n highlightColor,\r\n dotOpacity = 0.3,\r\n showNAColor = true,\r\n minHeight = 0,\r\n theme = 'light',\r\n ariaLabel,\r\n resetSelectionOnDoubleClick = true,\r\n detailsOnClick,\r\n styles,\r\n classNames,\r\n valueColor,\r\n animate = false,\r\n noOfTicks = 2,\r\n dimmedOpacity = 0.3,\r\n precision = 2,\r\n customLayers = [],\r\n } = props;\r\n\r\n const [svgWidth, setSvgWidth] = useState(0);\r\n const [svgHeight, setSvgHeight] = useState(0);\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 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 `${\r\n graphTitle ? `The graph shows ${graphTitle}. ` : ''\r\n }This is a strip chart showing distribution of data along the vertical axis. Each dot represents an individual data point, helping to visualize the spread and clustering of values.${\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 <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 !== false && 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 flex-col grow justify-center w-full leading-0'\r\n ref={graphDiv}\r\n >\r\n {(width || svgWidth) && (height || svgHeight) ? (\r\n <Graph\r\n data={data}\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 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 colors={\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 selectedColor={selectedColor}\r\n radius={radius}\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 highlightedDataPoints={highlightedDataPoints}\r\n minValue={minValue}\r\n maxValue={maxValue}\r\n onSeriesMouseClick={onSeriesMouseClick}\r\n prefix={prefix}\r\n suffix={suffix}\r\n stripType={stripType}\r\n highlightColor={highlightColor}\r\n dotOpacity={dotOpacity}\r\n resetSelectionOnDoubleClick={resetSelectionOnDoubleClick}\r\n detailsOnClick={detailsOnClick}\r\n styles={styles}\r\n classNames={classNames}\r\n valueColor={valueColor}\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 noOfTicks={noOfTicks}\r\n dimmedOpacity={dimmedOpacity}\r\n precision={precision}\r\n customLayers={customLayers}\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 { HorizontalStripChart } from './Horizontal';\r\nimport { VerticalStripChart } from './Vertical';\r\n\r\nimport {\r\n SourcesDataType,\r\n Languages,\r\n StripChartDataType,\r\n StyleObject,\r\n ClassNameObject,\r\n CustomLayerDataType,\r\n AnimateDataType,\r\n} from '@/Types';\r\n\r\ninterface Props {\r\n // Data\r\n /** Array of data objects */\r\n data: StripChartDataType[];\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 circles */\r\n colors?: string | string[];\r\n /** Color of the highlighted data points */\r\n highlightColor?: 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\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\r\n // Graph Parameters\r\n /** Number of ticks on the axis */\r\n noOfTicks?: number;\r\n /** Radius of the dots or width of the strips */\r\n radius?: number;\r\n /** Opacity of each dot or strip */\r\n dotOpacity?: number;\r\n /** Type of strip */\r\n stripType?: 'strip' | 'dot';\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 /** 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 /** 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 StripChart(props: Props) {\r\n const {\r\n data,\r\n graphTitle,\r\n colors,\r\n sources,\r\n graphDescription,\r\n height,\r\n width,\r\n footNote,\r\n colorDomain,\r\n colorLegendTitle,\r\n radius,\r\n padding,\r\n backgroundColor,\r\n leftMargin,\r\n rightMargin,\r\n topMargin,\r\n bottomMargin,\r\n tooltip,\r\n relativeHeight,\r\n onSeriesMouseOver,\r\n showColorScale,\r\n highlightedDataPoints,\r\n graphID,\r\n minValue,\r\n maxValue,\r\n onSeriesMouseClick,\r\n noOfTicks,\r\n graphDownload,\r\n dataDownload,\r\n prefix,\r\n suffix,\r\n stripType,\r\n language,\r\n highlightColor,\r\n dotOpacity,\r\n showNAColor,\r\n minHeight,\r\n theme,\r\n ariaLabel,\r\n valueColor,\r\n resetSelectionOnDoubleClick,\r\n detailsOnClick,\r\n orientation = 'vertical',\r\n styles,\r\n classNames,\r\n animate,\r\n dimmedOpacity = 0.3,\r\n precision,\r\n customLayers,\r\n } = props;\r\n\r\n if (orientation === 'vertical')\r\n return (\r\n <VerticalStripChart\r\n data={data}\r\n graphTitle={graphTitle}\r\n colors={colors}\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 radius={radius}\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 tooltip={tooltip}\r\n relativeHeight={relativeHeight}\r\n onSeriesMouseOver={onSeriesMouseOver}\r\n showColorScale={showColorScale}\r\n highlightedDataPoints={highlightedDataPoints}\r\n graphID={graphID}\r\n minValue={minValue}\r\n maxValue={maxValue}\r\n onSeriesMouseClick={onSeriesMouseClick}\r\n noOfTicks={noOfTicks}\r\n graphDownload={graphDownload}\r\n dataDownload={dataDownload}\r\n prefix={prefix}\r\n suffix={suffix}\r\n stripType={stripType}\r\n language={language}\r\n highlightColor={highlightColor}\r\n dotOpacity={dotOpacity}\r\n showNAColor={showNAColor}\r\n minHeight={minHeight}\r\n theme={theme}\r\n ariaLabel={ariaLabel}\r\n resetSelectionOnDoubleClick={resetSelectionOnDoubleClick}\r\n styles={styles}\r\n valueColor={valueColor}\r\n detailsOnClick={detailsOnClick}\r\n classNames={classNames}\r\n animate={animate}\r\n dimmedOpacity={dimmedOpacity}\r\n precision={precision}\r\n customLayers={customLayers}\r\n />\r\n );\r\n return (\r\n <HorizontalStripChart\r\n data={data}\r\n graphTitle={graphTitle}\r\n colors={colors}\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 radius={radius}\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 tooltip={tooltip}\r\n relativeHeight={relativeHeight}\r\n onSeriesMouseOver={onSeriesMouseOver}\r\n showColorScale={showColorScale}\r\n highlightedDataPoints={highlightedDataPoints}\r\n graphID={graphID}\r\n minValue={minValue}\r\n maxValue={maxValue}\r\n onSeriesMouseClick={onSeriesMouseClick}\r\n noOfTicks={noOfTicks}\r\n graphDownload={graphDownload}\r\n dataDownload={dataDownload}\r\n prefix={prefix}\r\n suffix={suffix}\r\n stripType={stripType}\r\n language={language}\r\n highlightColor={highlightColor}\r\n dotOpacity={dotOpacity}\r\n showNAColor={showNAColor}\r\n minHeight={minHeight}\r\n theme={theme}\r\n ariaLabel={ariaLabel}\r\n resetSelectionOnDoubleClick={resetSelectionOnDoubleClick}\r\n styles={styles}\r\n valueColor={valueColor}\r\n detailsOnClick={detailsOnClick}\r\n classNames={classNames}\r\n animate={animate}\r\n dimmedOpacity={dimmedOpacity}\r\n precision={precision}\r\n customLayers={customLayers}\r\n />\r\n );\r\n}\r\n"],"names":["getTickPositions","count","width","step","_","i","Graph","props","data","height","colors","colorDomain","radius","leftMargin","rightMargin","topMargin","bottomMargin","tooltip","onSeriesMouseOver","highlightedDataPoints","selectedColor","minValue","maxValue","onSeriesMouseClick","prefix","suffix","stripType","highlightColor","dotOpacity","resetSelectionOnDoubleClick","detailsOnClick","styles","classNames","valueColor","animate","noOfTicks","dimmedOpacity","precision","customLayers","svgRef","useRef","isInView","useInView","mouseOverData","setMouseOverData","useState","mouseClickData","setMouseClickData","eventX","setEventX","eventY","setEventY","margin","graphWidth","graphHeight","dataWithId","d","sortedData","orderBy","item","index","xMaxValue","checkIfNullOrUndefined","xMinValue","x","scaleLinear","ticks","jsxs","Fragment","jsx","motion","AnimatePresence","event","isEqual","el","Colors","cn","tick","numberFormattingFunction","Tooltip","Modal","string2HTML","HorizontalStripChart","graphTitle","sources","graphDescription","footNote","colorLegendTitle","padding","backgroundColor","relativeHeight","showColorScale","graphID","graphDownload","dataDownload","language","showNAColor","minHeight","theme","ariaLabel","svgWidth","setSvgWidth","svgHeight","setSvgHeight","setSelectedColor","graphDiv","graphParentDiv","useEffect","resizeObserver","entries","GraphHeader","EmptyState","ColorLegendWithMouseOver","uniqBy","GraphFooter","yMaxValue","yMinValue","y","VerticalStripChart","StripChart","orientation"],"mappings":"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"}
|
package/dist/ThreeDGlobe.cjs
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const o=require("./index-CHPV5EwG-DDoeWRVt.cjs"),l=require("react"),ge=require("./Spinner-DA6Z5E4n.cjs"),xe=require("react-globe.gl"),ye=require("./index-DQA8q5sC.cjs"),fe=require("three"),be=require("./Modal-tXZlLE5s.cjs"),pe=require("./Typography-k-kOjICQ.cjs"),ve=require("./Tooltip-De16GWhY.cjs"),je=require("./numberFormattingFunction-02t-wJta.cjs"),we=require("./index-BW_-wD2k.cjs"),Ce=require("./string2HTML-z7CwHXcx.cjs"),Ee=require("./getCentroidCoordinates-DxTBqzp2.cjs"),Re=require("./ordinal-BOeNbyae.cjs"),Se=require("./threshold-DNsSUf8Q.cjs"),ke=require("./GraphHeader.cjs"),De=require("./GraphFooter.cjs"),Ne=require("./fetchAndParseData-Ba-_CgxS.cjs"),T=require("./Colors.cjs"),Me=require("./getUniqValue-RViz8tTw.cjs"),qe=require("./getJenks-GYmdwBqm.cjs");function Oe(e){const r=Object.create(null,{[Symbol.toStringTag]:{value:"Module"}});if(e){for(const p in e)if(p!=="default"){const m=Object.getOwnPropertyDescriptor(e,p);Object.defineProperty(r,p,m.get?m:{enumerable:!0,get:()=>e[p]})}}return r.default=e,Object.freeze(r)}const q=Oe(fe);function Le(e){let r;switch(e.type){case"ambient":r=new q.AmbientLight(e.color,e.intensity);break;case"directional":r=new q.DirectionalLight(e.color,e.intensity),e.position&&(e.position==="camera"?r.position.set(0,0,0):r.position.set(e.position.x,e.position.y,e.position.z)),(e.target||e.position==="camera")&&r.target.position.set(e.target?.x||0,e.target?.y||0,e.target?.z===void 0?-1:e.target.z),e.castShadow&&(r.castShadow=!0,e.shadow&&(r.shadow.mapSize.width=e.shadow.mapSize.width,r.shadow.mapSize.height=e.shadow.mapSize.height,r.shadow.camera.near=e.shadow.camera.near,r.shadow.camera.far=e.shadow.camera.far));break;case"point":r=new q.PointLight(e.color,e.intensity,e.distance||0,e.decay||2),e.position&&(e.position==="camera"?r.position.set(0,0,0):r.position.set(e.position.x,e.position.y,e.position.z));break;case"spot":r=new q.SpotLight(e.color,e.intensity,e.distance||0,e.angle||Math.PI/3,e.penumbra||0,e.decay||2),e.position&&(e.position==="camera"?r.position.set(0,0,0):r.position.set(e.position.x,e.position.y,e.position.z)),(e.target||e.position==="camera")&&r.target.position.set(e.target?.x||0,e.target?.y||0,e.target?.z||0),e.castShadow&&(r.castShadow=!0,e.shadow&&(r.shadow.mapSize.width=e.shadow.mapSize.width,r.shadow.mapSize.height=e.shadow.mapSize.height,r.shadow.camera.near=e.shadow.camera.near,r.shadow.camera.far=e.shadow.camera.far));break;default:throw new Error("Unknown light type")}return r}function Pe(e){const{width:r,autoRotate:p,data:m,enableZoom:z,categorical:O,colorDomain:g,colors:c,globeMaterial:u,height:V,polygonData:H,mapProperty:d,mapBorderColor:A,atmosphereColor:W,tooltip:_,styles:C,classNames:te,mapNoDataColor:y,colorLegendTitle:G,showColorScale:re,hoverStrokeColor:oe,detailsOnClick:j,onSeriesMouseClick:k,onSeriesMouseOver:b,resetSelectionOnDoubleClick:L,highlightedIds:J,scale:f,globeOffset:E,polygonAltitude:F,centerLng:$,centerLat:I,atmosphereAltitude:X,globeCurvatureResolution:se,fogSettings:D,lights:N,highlightedAltitude:Z,selectedId:v}=e,[Y,ae]=l.useState(!1),n=l.useRef(void 0),[R,P]=l.useState(void 0),[ie,K]=l.useState(!(r<680)),[Q,ne]=l.useState({x:0,y:0}),[S,le]=l.useState(void 0),B=O?Re.ordinal().domain(g).range(c):Se.threshold().domain(g).range(c);l.useEffect(()=>{n.current&&(n.current.controls().enableZoom=z)},[z]),l.useEffect(()=>{n.current&&(S||v?n.current.controls().autoRotate=!1:(n.current.controls().autoRotate=p!==0,n.current.controls().autoRotateSpeed=p))},[S,v,p]),l.useEffect(()=>{if(n.current&&v){const t=H.find(x=>x.properties[d]===v),[s,i]=Ee.getCentroidCoordinates(t);n.current.pointOfView({lat:i,lng:s,altitude:f},1e3)}},[v,f,H,d]),l.useEffect(()=>{const t=n.current?.renderer().domElement;if(!t)return;const s=i=>{ne({x:i.clientX,y:i.clientY})};return t.addEventListener("mousemove",s),()=>t.removeEventListener("mousemove",s)},[]),l.useEffect(()=>{n.current&&n.current.pointOfView({lat:I,lng:$,altitude:f},1e3)},[f,$,I]);const U=u||new q.MeshBasicMaterial({color:"#FFF"}),h=l.useCallback(()=>{if(!n.current)return;const t=n.current.scene(),s=n.current.camera();let i=[];t.traverse(a=>{a instanceof q.Light&&i.push(a)}),i=[...i,...s.children],i.forEach(a=>a.parent?.remove(a)),N.map(a=>Le(a)).forEach((a,w)=>{N[w].type!=="ambient"&&N[w].position==="camera"?(s.add(a),N[w].type!=="point"&&s.add(a.target)):t.add(a)}),D&&(t.fog=new q.Fog(D.color,D.near,D.far))},[N,D]),ee=l.useCallback(()=>{ae(!0),h()},[h]);return l.useEffect(()=>{Y&&h()},[Y,h]),o.jsxRuntimeExports.jsxs("div",{className:"relative",children:[o.jsxRuntimeExports.jsx(xe,{ref:n,height:V,width:r,globeOffset:E,lineHoverPrecision:0,polygonsData:H,polygonAltitude:t=>J.includes(t?.properties?.[d])||t?.properties?.[d]===v?Z*(t?.properties?.[d]===v?2:1):t?.properties?.[d]===S?.id||t?.properties?.[d]===R?.id?Z:F,polygonCapColor:t=>{const s=t?.properties?.[d],i=m.find(x=>x.id===s)?.x;return i!=null?B(i):y},polygonSideColor:t=>{const s=t?.properties?.[d],i=m.find(a=>a.id===s)?.x,x=i!=null?B(i):y;return J.includes(t?.properties?.[d])||t?.properties?.[d]===v?x:"rgba(100,100,100,0)"},polygonStrokeColor:t=>t?.properties?.[d]===S?.id?oe:A,onGlobeClick:()=>{P(void 0)},onPolygonClick:t=>{const s=t?.properties?.[d]?m.find(i=>i.id===t?.properties?.[d]):void 0;(k||j)&&(ye.isEqual(R,s)&&L&&s?(P(void 0),k?.(void 0)):(P(s),k?.(s)))},onPolygonHover:t=>{const s=t?.properties?.[d]?m.find(i=>i.id===t?.properties?.[d]):void 0;le(s),b?.(s)},atmosphereColor:W,atmosphereAltitude:X,globeCurvatureResolution:se,globeMaterial:U,backgroundColor:"rgba(0, 0, 0, 0)",polygonsTransitionDuration:100,onGlobeReady:()=>{if(n.current){n.current.pointOfView({lat:I,lng:$});const t=n.current.scene();setTimeout(()=>{(t.children[3]?.children[0]?.children[4]?.children||[]).forEach(x=>{const a=x.children[1];a.renderOrder=2})},300);const s=n.current.camera();t.add(s),ee()}}}),re===!1?null:o.jsxRuntimeExports.jsx("div",{className:"absolute left-4 bottom-4",children:ie?o.jsxRuntimeExports.jsxs(o.jsxRuntimeExports.Fragment,{children:[o.jsxRuntimeExports.jsx("div",{style:{backgroundColor:"rgba(240,240,240, 0.7)",border:"1px solid var(--gray-400)",borderRadius:"999px",width:"24px",height:"24px",padding:"3px",cursor:"pointer",zIndex:10,position:"absolute",right:"-0.75rem",top:"-0.75rem"},onClick:()=>{K(!1)},children:o.jsxRuntimeExports.jsx(we.X,{})}),o.jsxRuntimeExports.jsxs("div",{className:"p-2",style:{backgroundColor:"rgba(240,240,240, 0.7)",width:O?void 0:"340px"},children:[G&&G!==""?o.jsxRuntimeExports.jsx(pe.u,{size:"xs",marginBottom:"xs",className:"p-0 leading-normal overflow-hidden text-primary-gray-700 dark:text-primary-gray-300",style:{display:"-webkit-box",WebkitLineClamp:"1",WebkitBoxOrient:"vertical"},children:G}):null,O?o.jsxRuntimeExports.jsx("div",{className:"flex flex-col gap-3",children:g.map((t,s)=>o.jsxRuntimeExports.jsxs("div",{className:"flex gap-2 items-center",children:[o.jsxRuntimeExports.jsx("div",{className:"w-2 h-2 rounded-full",style:{backgroundColor:c[s%c.length]}}),o.jsxRuntimeExports.jsx(pe.u,{size:"sm",marginBottom:"none",leading:"none",children:t})]},s))}):o.jsxRuntimeExports.jsx("svg",{width:"100%",viewBox:"0 0 320 30",direction:"ltr",children:o.jsxRuntimeExports.jsxs("g",{children:[g.map((t,s)=>o.jsxRuntimeExports.jsxs("g",{className:"cursor-pointer",children:[o.jsxRuntimeExports.jsx("rect",{x:s*320/c.length+1,y:1,width:320/c.length-2,height:8,style:{fill:c[s],stroke:c[s]}}),o.jsxRuntimeExports.jsx("text",{x:(s+1)*320/c.length,y:25,className:"fill-primary-gray-700 dark:fill-primary-gray-300 text-xs",style:{textAnchor:"middle"},children:je.numberFormattingFunction(t,"NA")})]},s)),o.jsxRuntimeExports.jsx("g",{children:o.jsxRuntimeExports.jsx("rect",{x:g.length*320/c.length+1,y:1,width:320/c.length-2,height:8,style:{fill:c[g.length],stroke:c[g.length]}})})]})})]})]}):o.jsxRuntimeExports.jsx("button",{type:"button",className:"mb-0 border-0 bg-transparent p-0 self-start",onClick:()=>{K(!0)},children:o.jsxRuntimeExports.jsx("div",{className:"items-start text-sm font-medium cursor-pointer p-2 mb-0 flex text-primary-black dark:text-primary-gray-300 bg-primary-gray-300 dark:bg-primary-gray-550 border-primary-gray-400 dark:border-primary-gray-500",children:"Show Legend"})})}),S&&_?o.jsxRuntimeExports.jsx(ve.Tooltip,{data:S,body:_,xPos:Q.x,yPos:Q.y,backgroundStyle:C?.tooltip,className:te?.tooltip}):null,j&&R!==void 0?o.jsxRuntimeExports.jsx(be.X,{open:R!==void 0,onClose:()=>{P(void 0)},children:o.jsxRuntimeExports.jsx("div",{className:"graph-modal-content m-0",dangerouslySetInnerHTML:typeof j=="string"?{__html:Ce.string2HTML(j,R)}:void 0,children:typeof j=="function"?j(R):null})}):null]})}function Te(e){const{data:r,mapData:p="https://raw.githubusercontent.com/UNDP-Data/dv-country-geojson/refs/heads/main/worldMap-simplified.json",graphTitle:m,colors:z,sources:O,graphDescription:g,height:c,width:u,footNote:V="The designations employed and the presentation of material on this map do not imply the expression of any opinion whatsoever on the part of the Secretariat of the United Nations or UNDP concerning the legal status of any country, territory, city or area or its authorities, or concerning the delimitation of its frontiers or boundaries.",colorDomain:H,colorLegendTitle:d,scaleType:A="threshold",padding:W,mapNoDataColor:_=T.Colors.light.graphNoData,backgroundColor:C=!1,mapBorderColor:te=T.Colors.light.grays["gray-500"],relativeHeight:y,tooltip:G,graphID:re,mapProperty:oe="ISO3",dataDownload:j=!1,language:k="en",minHeight:b=0,theme:L="light",ariaLabel:J,styles:f,classNames:E,autoRotate:F=!0,enableZoom:$=!0,globeMaterial:I,centerPoint:X=[0,0],atmosphereColor:se="#999",showColorScale:D=!0,resetSelectionOnDoubleClick:N=!0,detailsOnClick:Z,onSeriesMouseOver:v,onSeriesMouseClick:Y,highlightedIds:ae=[],highlightedAltitude:n=.1,scale:R=1,globeOffset:P=[0,0],polygonAltitude:ie=.01,globeCurvatureResolution:K=4,atmosphereAltitude:Q=.15,fogSettings:ne,lights:S=[{type:"ambient",color:4210752,intensity:.4},{type:"directional",color:16777215,intensity:1,position:{x:5,y:10,z:5}}],selectedId:le}=e,[B,U]=l.useState(void 0),[h,ee]=l.useState(0),[t,s]=l.useState(0),i=l.useRef(null);l.useEffect(()=>{const a=new ResizeObserver(w=>{ee(u||w[0].target.clientWidth||760),s(c||w[0].target.clientHeight||480)});return i.current&&(s(i.current.clientHeight||480),ee(i.current.clientWidth||760),u||a.observe(i.current)),()=>a.disconnect()},[u,c]),l.useEffect(()=>{typeof p=="string"?Ne.fetchAndParseJSON(p).then(w=>{if(p==="https://raw.githubusercontent.com/UNDP-Data/dv-country-geojson/refs/heads/main/worldMap-simplified.json"){const he=w.features.map(M=>{if(M.geometry.type==="Polygon"){const ce=[...M.geometry.coordinates[0]].reverse(),de={...M.geometry,coordinates:[ce]};return{...M,geometry:de}}const ue=[];M.geometry.coordinates.forEach(ce=>{const de=[...ce[0]].reverse();ue.push([de])});const me={...M.geometry,coordinates:ue};return{...M,geometry:me}});U(he)}else U(w.features)}):U(p.features)},[p]);const x=H||(A==="categorical"?Me.getUniqValue(r,"x"):qe.getJenks(r.map(a=>a.x),z?.length||4));return o.jsxRuntimeExports.jsx("div",{className:`${L||"light"} flex ${u?"w-fit grow-0":"w-full grow"}`,dir:k==="he"||k==="ar"?"rtl":void 0,children:o.jsxRuntimeExports.jsx("div",{className:o.mo(`${C?C===!0?"bg-primary-gray-200 dark:bg-primary-gray-650 ":"":"bg-transparent "}ml-auto mr-auto flex flex-col grow h-inherit ${k||"en"}`,u?"w-fit":"w-full",E?.graphContainer),style:{...f?.graphContainer||{},...C&&C!==!0?{backgroundColor:C}:{}},id:re,"aria-label":J||`${m?`The graph shows ${m}. `:""}This is a map.${g?` ${g}`:""}`,children:o.jsxRuntimeExports.jsx("div",{className:"flex grow",style:{padding:C?W||"1rem":W||0},children:o.jsxRuntimeExports.jsxs("div",{className:"flex flex-col w-full gap-4 grow justify-between",children:[m||g||j?o.jsxRuntimeExports.jsx(ke.GraphHeader,{styles:{title:f?.title,description:f?.description},classNames:{title:E?.title,description:E?.description},graphTitle:m,graphDescription:g,width:u,graphDownload:void 0,dataDownload:j?r.map(a=>a.data).filter(a=>a!==void 0).length>0?r.map(a=>a.data).filter(a=>a!==void 0):r.filter(a=>a!==void 0):null}):null,o.jsxRuntimeExports.jsx("div",{className:"flex flex-col grow justify-center leading-0",ref:i,"aria-label":"Map area",children:(u||h)&&(c||t)&&B?o.jsxRuntimeExports.jsx(Pe,{data:r,globeOffset:P,polygonData:B,colorDomain:x,width:u||h,height:Math.max(b,c||(y?b?(u||h)*y>b?(u||h)*y:b:(u||h)*y:t)),colors:z||(A==="categorical"?T.Colors[L].sequentialColors[`neutralColorsx0${x.length}`]:T.Colors[L].sequentialColors[`neutralColorsx0${x.length+1}`]),mapNoDataColor:_,categorical:A==="categorical",mapBorderColor:te,tooltip:G,mapProperty:oe,styles:f,classNames:E,autoRotate:F===!0?1.5:F===!1?0:F,enableZoom:$,globeMaterial:I,atmosphereColor:se,colorLegendTitle:d,showColorScale:D,hoverStrokeColor:L==="light"?T.Colors.light.grays["gray-700"]:T.Colors.light.grays["gray-300"],highlightedIds:ae,resetSelectionOnDoubleClick:N,detailsOnClick:Z,onSeriesMouseOver:v,onSeriesMouseClick:Y,scale:R,polygonAltitude:ie,centerLat:X[0],centerLng:X[1],atmosphereAltitude:Q,globeCurvatureResolution:K,fogSettings:ne,lights:S,highlightedAltitude:n,selectedId:le}):o.jsxRuntimeExports.jsx("div",{style:{height:`${Math.max(b,c||(y?b?(u||h)*y>b?(u||h)*y:b:(u||h)*y:t))}px`},className:"flex items-center justify-center",children:o.jsxRuntimeExports.jsx(ge.y,{"aria-label":"Loading graph"})})}),O||V?o.jsxRuntimeExports.jsx(De.GraphFooter,{styles:{footnote:f?.footnote,source:f?.source},classNames:{footnote:E?.footnote,source:E?.source},sources:O,footNote:V,width:u}):null]})})})})}exports.ThreeDGlobe=Te;
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const o=require("./index-CHPV5EwG-DjM48pIC.cjs"),l=require("react"),xe=require("./Spinner-C6wLp85s.cjs"),ye=require("react-globe.gl"),fe=require("./index-DQA8q5sC.cjs"),be=require("three"),ve=require("./Modal-CuuJdWkD.cjs"),he=require("./Typography-BDULiwlF.cjs"),je=require("./Tooltip-Cpv0QohJ.cjs"),we=require("./numberFormattingFunction-02t-wJta.cjs"),Ce=require("./index-C0bpbS4F.cjs"),Ee=require("./string2HTML-z7CwHXcx.cjs"),Se=require("./getCentroidCoordinates-DxTBqzp2.cjs"),Re=require("./ordinal-BOeNbyae.cjs"),ke=require("./threshold-DNsSUf8Q.cjs"),De=require("./GraphHeader.cjs"),Ne=require("./GraphFooter.cjs"),Me=require("./fetchAndParseData-Ba-_CgxS.cjs"),T=require("./Colors.cjs"),qe=require("./getUniqValue-RViz8tTw.cjs"),Oe=require("./getJenks-GYmdwBqm.cjs");function Le(e){const r=Object.create(null,{[Symbol.toStringTag]:{value:"Module"}});if(e){for(const p in e)if(p!=="default"){const m=Object.getOwnPropertyDescriptor(e,p);Object.defineProperty(r,p,m.get?m:{enumerable:!0,get:()=>e[p]})}}return r.default=e,Object.freeze(r)}const q=Le(be);function Pe(e){let r;switch(e.type){case"ambient":r=new q.AmbientLight(e.color,e.intensity);break;case"directional":r=new q.DirectionalLight(e.color,e.intensity),e.position&&(e.position==="camera"?r.position.set(0,0,0):r.position.set(e.position.x,e.position.y,e.position.z)),(e.target||e.position==="camera")&&r.target.position.set(e.target?.x||0,e.target?.y||0,e.target?.z===void 0?-1:e.target.z),e.castShadow&&(r.castShadow=!0,e.shadow&&(r.shadow.mapSize.width=e.shadow.mapSize.width,r.shadow.mapSize.height=e.shadow.mapSize.height,r.shadow.camera.near=e.shadow.camera.near,r.shadow.camera.far=e.shadow.camera.far));break;case"point":r=new q.PointLight(e.color,e.intensity,e.distance||0,e.decay||2),e.position&&(e.position==="camera"?r.position.set(0,0,0):r.position.set(e.position.x,e.position.y,e.position.z));break;case"spot":r=new q.SpotLight(e.color,e.intensity,e.distance||0,e.angle||Math.PI/3,e.penumbra||0,e.decay||2),e.position&&(e.position==="camera"?r.position.set(0,0,0):r.position.set(e.position.x,e.position.y,e.position.z)),(e.target||e.position==="camera")&&r.target.position.set(e.target?.x||0,e.target?.y||0,e.target?.z||0),e.castShadow&&(r.castShadow=!0,e.shadow&&(r.shadow.mapSize.width=e.shadow.mapSize.width,r.shadow.mapSize.height=e.shadow.mapSize.height,r.shadow.camera.near=e.shadow.camera.near,r.shadow.camera.far=e.shadow.camera.far));break;default:throw new Error("Unknown light type")}return r}function Te(e){const{width:r,autoRotate:p,data:m,enableZoom:z,categorical:O,colorDomain:g,colors:c,globeMaterial:u,height:V,polygonData:H,mapProperty:d,mapBorderColor:G,atmosphereColor:W,tooltip:_,styles:C,classNames:re,mapNoDataColor:y,colorLegendTitle:A,showColorScale:oe,hoverStrokeColor:se,detailsOnClick:j,onSeriesMouseClick:k,onSeriesMouseOver:b,resetSelectionOnDoubleClick:L,highlightedIds:J,scale:f,globeOffset:E,polygonAltitude:F,centerLng:$,centerLat:B,atmosphereAltitude:Z,globeCurvatureResolution:ae,fogSettings:D,lights:N,highlightedAltitude:X,selectedId:v,collapseColorScaleByDefault:Y}=e,[K,ie]=l.useState(!1),n=l.useRef(void 0),[S,P]=l.useState(void 0),[ne,Q]=l.useState(Y===void 0?!(r<680):!Y),[ee,le]=l.useState({x:0,y:0}),[R,ce]=l.useState(void 0),I=O?Re.ordinal().domain(g).range(c):ke.threshold().domain(g).range(c);l.useEffect(()=>{n.current&&(n.current.controls().enableZoom=z)},[z]),l.useEffect(()=>{n.current&&(R||v?n.current.controls().autoRotate=!1:(n.current.controls().autoRotate=p!==0,n.current.controls().autoRotateSpeed=p))},[R,v,p]),l.useEffect(()=>{if(n.current&&v){const t=H.find(x=>x.properties[d]===v),[s,i]=Se.getCentroidCoordinates(t);n.current.pointOfView({lat:i,lng:s,altitude:f},1e3)}},[v,f,H,d]),l.useEffect(()=>{const t=n.current?.renderer().domElement;if(!t)return;const s=i=>{le({x:i.clientX,y:i.clientY})};return t.addEventListener("mousemove",s),()=>t.removeEventListener("mousemove",s)},[]),l.useEffect(()=>{n.current&&n.current.pointOfView({lat:B,lng:$,altitude:f},1e3)},[f,$,B]);const U=u||new q.MeshBasicMaterial({color:"#FFF"}),h=l.useCallback(()=>{if(!n.current)return;const t=n.current.scene(),s=n.current.camera();let i=[];t.traverse(a=>{a instanceof q.Light&&i.push(a)}),i=[...i,...s.children],i.forEach(a=>a.parent?.remove(a)),N.map(a=>Pe(a)).forEach((a,w)=>{N[w].type!=="ambient"&&N[w].position==="camera"?(s.add(a),N[w].type!=="point"&&s.add(a.target)):t.add(a)}),D&&(t.fog=new q.Fog(D.color,D.near,D.far))},[N,D]),te=l.useCallback(()=>{ie(!0),h()},[h]);return l.useEffect(()=>{K&&h()},[K,h]),o.jsxRuntimeExports.jsxs("div",{className:"relative",children:[o.jsxRuntimeExports.jsx(ye,{ref:n,height:V,width:r,globeOffset:E,lineHoverPrecision:0,polygonsData:H,polygonAltitude:t=>J.includes(t?.properties?.[d])||t?.properties?.[d]===v?X*(t?.properties?.[d]===v?2:1):t?.properties?.[d]===R?.id||t?.properties?.[d]===S?.id?X:F,polygonCapColor:t=>{const s=t?.properties?.[d],i=m.find(x=>x.id===s)?.x;return i!=null?I(i):y},polygonSideColor:t=>{const s=t?.properties?.[d],i=m.find(a=>a.id===s)?.x,x=i!=null?I(i):y;return J.includes(t?.properties?.[d])||t?.properties?.[d]===v?x:"rgba(100,100,100,0)"},polygonStrokeColor:t=>t?.properties?.[d]===R?.id?se:G,onGlobeClick:()=>{P(void 0)},onPolygonClick:t=>{const s=t?.properties?.[d]?m.find(i=>i.id===t?.properties?.[d]):void 0;(k||j)&&(fe.isEqual(S,s)&&L&&s?(P(void 0),k?.(void 0)):(P(s),k?.(s)))},onPolygonHover:t=>{const s=t?.properties?.[d]?m.find(i=>i.id===t?.properties?.[d]):void 0;ce(s),b?.(s)},atmosphereColor:W,atmosphereAltitude:Z,globeCurvatureResolution:ae,globeMaterial:U,backgroundColor:"rgba(0, 0, 0, 0)",polygonsTransitionDuration:100,onGlobeReady:()=>{if(n.current){n.current.pointOfView({lat:B,lng:$});const t=n.current.scene();setTimeout(()=>{(t.children[3]?.children[0]?.children[4]?.children||[]).forEach(x=>{const a=x.children[1];a.renderOrder=2})},300);const s=n.current.camera();t.add(s),te()}}}),oe===!1?null:o.jsxRuntimeExports.jsx("div",{className:"absolute left-4 bottom-4",children:ne?o.jsxRuntimeExports.jsxs(o.jsxRuntimeExports.Fragment,{children:[o.jsxRuntimeExports.jsx("div",{className:"color-legend-close-button bg-[rgba(240,240,240,0.7)] dark:bg-[rgba(30,30,30,0.7)] border border-[var(--gray-400)] rounded-full w-6 h-6 p-[3px] cursor-pointer z-10 absolute right-[-0.75rem] top-[-0.75rem]",onClick:()=>{Q(!1)},children:o.jsxRuntimeExports.jsx(Ce.X,{})}),o.jsxRuntimeExports.jsxs("div",{className:"color-legend-box p-2 bg-[rgba(240,240,240,0.7)] dark:bg-[rgba(30,30,30,0.7)]",style:{width:O?void 0:"340px"},children:[A&&A!==""?o.jsxRuntimeExports.jsx(he.u,{size:"xs",marginBottom:"xs",className:"p-0 leading-normal overflow-hidden text-primary-gray-700 dark:text-primary-gray-300",style:{display:"-webkit-box",WebkitLineClamp:"1",WebkitBoxOrient:"vertical"},children:A}):null,O?o.jsxRuntimeExports.jsx("div",{className:"flex flex-col gap-3",children:g.map((t,s)=>o.jsxRuntimeExports.jsxs("div",{className:"flex gap-2 items-center",children:[o.jsxRuntimeExports.jsx("div",{className:"w-2 h-2 rounded-full",style:{backgroundColor:c[s%c.length]}}),o.jsxRuntimeExports.jsx(he.u,{size:"sm",marginBottom:"none",leading:"none",children:t})]},s))}):o.jsxRuntimeExports.jsx("svg",{width:"100%",viewBox:"0 0 320 30",direction:"ltr",children:o.jsxRuntimeExports.jsxs("g",{children:[g.map((t,s)=>o.jsxRuntimeExports.jsxs("g",{className:"cursor-pointer",children:[o.jsxRuntimeExports.jsx("rect",{x:s*320/c.length+1,y:1,width:320/c.length-2,height:8,style:{fill:c[s],stroke:c[s]}}),o.jsxRuntimeExports.jsx("text",{x:(s+1)*320/c.length,y:25,className:"fill-primary-gray-700 dark:fill-primary-gray-300 text-xs",style:{textAnchor:"middle"},children:we.numberFormattingFunction(t,"NA")})]},s)),o.jsxRuntimeExports.jsx("g",{children:o.jsxRuntimeExports.jsx("rect",{x:g.length*320/c.length+1,y:1,width:320/c.length-2,height:8,style:{fill:c[g.length],stroke:c[g.length]}})})]})})]})]}):o.jsxRuntimeExports.jsx("button",{type:"button",className:"mb-0 border-0 bg-transparent p-0 self-start",onClick:()=>{Q(!0)},children:o.jsxRuntimeExports.jsx("div",{className:"show-color-legend-button items-start text-sm font-medium cursor-pointer p-2 mb-0 flex text-primary-black dark:text-primary-gray-300 bg-primary-gray-300 dark:bg-primary-gray-600 border-primary-gray-400 dark:border-primary-gray-500",children:"Show Legend"})})}),R&&_?o.jsxRuntimeExports.jsx(je.Tooltip,{data:R,body:_,xPos:ee.x,yPos:ee.y,backgroundStyle:C?.tooltip,className:re?.tooltip}):null,j&&S!==void 0?o.jsxRuntimeExports.jsx(ve.G,{open:S!==void 0,onClose:()=>{P(void 0)},children:o.jsxRuntimeExports.jsx("div",{className:"graph-modal-content m-0",dangerouslySetInnerHTML:typeof j=="string"?{__html:Ee.string2HTML(j,S)}:void 0,children:typeof j=="function"?j(S):null})}):null]})}function ze(e){const{data:r,mapData:p="https://raw.githubusercontent.com/UNDP-Data/dv-country-geojson/refs/heads/main/worldMap-simplified.json",graphTitle:m,colors:z,sources:O,graphDescription:g,height:c,width:u,footNote:V="The designations employed and the presentation of material on this map do not imply the expression of any opinion whatsoever on the part of the Secretariat of the United Nations or UNDP concerning the legal status of any country, territory, city or area or its authorities, or concerning the delimitation of its frontiers or boundaries.",colorDomain:H,colorLegendTitle:d,scaleType:G="threshold",padding:W,mapNoDataColor:_=T.Colors.light.graphNoData,backgroundColor:C=!1,mapBorderColor:re=T.Colors.light.grays["gray-500"],relativeHeight:y,tooltip:A,graphID:oe,mapProperty:se="ISO3",dataDownload:j=!1,language:k="en",minHeight:b=0,theme:L="light",ariaLabel:J,styles:f,classNames:E,autoRotate:F=!0,enableZoom:$=!0,globeMaterial:B,centerPoint:Z=[0,0],atmosphereColor:ae="#999",showColorScale:D=!0,resetSelectionOnDoubleClick:N=!0,detailsOnClick:X,onSeriesMouseOver:v,onSeriesMouseClick:Y,highlightedIds:K=[],highlightedAltitude:ie=.1,scale:n=1,globeOffset:S=[0,0],polygonAltitude:P=.01,globeCurvatureResolution:ne=4,atmosphereAltitude:Q=.15,fogSettings:ee,lights:le=[{type:"ambient",color:4210752,intensity:.4},{type:"directional",color:16777215,intensity:1,position:{x:5,y:10,z:5}}],selectedId:R,collapseColorScaleByDefault:ce}=e,[I,U]=l.useState(void 0),[h,te]=l.useState(0),[t,s]=l.useState(0),i=l.useRef(null);l.useEffect(()=>{const a=new ResizeObserver(w=>{te(u||w[0].target.clientWidth||760),s(c||w[0].target.clientHeight||480)});return i.current&&(s(i.current.clientHeight||480),te(i.current.clientWidth||760),u||a.observe(i.current)),()=>a.disconnect()},[u,c]),l.useEffect(()=>{typeof p=="string"?Me.fetchAndParseJSON(p).then(w=>{if(p==="https://raw.githubusercontent.com/UNDP-Data/dv-country-geojson/refs/heads/main/worldMap-simplified.json"){const me=w.features.map(M=>{if(M.geometry.type==="Polygon"){const de=[...M.geometry.coordinates[0]].reverse(),ue={...M.geometry,coordinates:[de]};return{...M,geometry:ue}}const pe=[];M.geometry.coordinates.forEach(de=>{const ue=[...de[0]].reverse();pe.push([ue])});const ge={...M.geometry,coordinates:pe};return{...M,geometry:ge}});U(me)}else U(w.features)}):U(p.features)},[p]);const x=H||(G==="categorical"?qe.getUniqValue(r,"x"):Oe.getJenks(r.map(a=>a.x),z?.length||4));return o.jsxRuntimeExports.jsx("div",{className:`${L||"light"} flex ${u?"w-fit grow-0":"w-full grow"}`,dir:k==="he"||k==="ar"?"rtl":void 0,children:o.jsxRuntimeExports.jsx("div",{className:o.mo(`${C?C===!0?"bg-primary-gray-200 dark:bg-primary-gray-650 ":"":"bg-transparent "}ml-auto mr-auto flex flex-col grow h-inherit ${k||"en"}`,u?"w-fit":"w-full",E?.graphContainer),style:{...f?.graphContainer||{},...C&&C!==!0?{backgroundColor:C}:{}},id:oe,"aria-label":J||`${m?`The graph shows ${m}. `:""}This is a map.${g?` ${g}`:""}`,children:o.jsxRuntimeExports.jsx("div",{className:"flex grow",style:{padding:C?W||"1rem":W||0},children:o.jsxRuntimeExports.jsxs("div",{className:"flex flex-col w-full gap-4 grow justify-between",children:[m||g||j?o.jsxRuntimeExports.jsx(De.GraphHeader,{styles:{title:f?.title,description:f?.description},classNames:{title:E?.title,description:E?.description},graphTitle:m,graphDescription:g,width:u,graphDownload:void 0,dataDownload:j?r.map(a=>a.data).filter(a=>a!==void 0).length>0?r.map(a=>a.data).filter(a=>a!==void 0):r.filter(a=>a!==void 0):null}):null,o.jsxRuntimeExports.jsx("div",{className:"flex flex-col grow justify-center leading-0",ref:i,"aria-label":"Map area",children:(u||h)&&(c||t)&&I?o.jsxRuntimeExports.jsx(Te,{data:r,globeOffset:S,polygonData:I,colorDomain:x,width:u||h,height:Math.max(b,c||(y?b?(u||h)*y>b?(u||h)*y:b:(u||h)*y:t)),colors:z||(G==="categorical"?T.Colors[L].sequentialColors[`neutralColorsx0${x.length}`]:T.Colors[L].sequentialColors[`neutralColorsx0${x.length+1}`]),mapNoDataColor:_,categorical:G==="categorical",mapBorderColor:re,tooltip:A,mapProperty:se,styles:f,classNames:E,autoRotate:F===!0?1.5:F===!1?0:F,enableZoom:$,globeMaterial:B,atmosphereColor:ae,colorLegendTitle:d,showColorScale:D,hoverStrokeColor:L==="light"?T.Colors.light.grays["gray-700"]:T.Colors.light.grays["gray-300"],highlightedIds:K,resetSelectionOnDoubleClick:N,detailsOnClick:X,onSeriesMouseOver:v,onSeriesMouseClick:Y,scale:n,polygonAltitude:P,centerLat:Z[0],centerLng:Z[1],atmosphereAltitude:Q,globeCurvatureResolution:ne,fogSettings:ee,lights:le,highlightedAltitude:ie,selectedId:R,collapseColorScaleByDefault:ce}):o.jsxRuntimeExports.jsx("div",{style:{height:`${Math.max(b,c||(y?b?(u||h)*y>b?(u||h)*y:b:(u||h)*y:t))}px`},className:"flex items-center justify-center",children:o.jsxRuntimeExports.jsx(xe.y,{"aria-label":"Loading graph"})})}),O||V?o.jsxRuntimeExports.jsx(Ne.GraphFooter,{styles:{footnote:f?.footnote,source:f?.source},classNames:{footnote:E?.footnote,source:E?.source},sources:O,footNote:V,width:u}):null]})})})})}exports.ThreeDGlobe=ze;
|
|
2
2
|
//# sourceMappingURL=ThreeDGlobe.cjs.map
|