@undp/data-viz 2.5.4 → 2.6.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/AreaChart.cjs +1 -1
- package/dist/AreaChart.cjs.map +1 -1
- package/dist/AreaChart.js +17 -16
- package/dist/AreaChart.js.map +1 -1
- package/dist/Axis-DY7jsk1Y.cjs +2 -0
- package/dist/{Axis-BTaS9oPQ.cjs.map → Axis-DY7jsk1Y.cjs.map} +1 -1
- package/dist/{Axis-CNZYWzH0.js → Axis-RRx-0Rlw.js} +9 -8
- package/dist/{Axis-CNZYWzH0.js.map → Axis-RRx-0Rlw.js.map} +1 -1
- package/dist/AxisTitle-B9F80_Z0.js +30 -0
- package/dist/AxisTitle-B9F80_Z0.js.map +1 -0
- package/dist/AxisTitle-CyFFbdNU.cjs +2 -0
- package/dist/{AxisTitle-DP_evhbe.cjs.map → AxisTitle-CyFFbdNU.cjs.map} +1 -1
- package/dist/BarGraph.cjs +1 -1
- package/dist/BarGraph.cjs.map +1 -1
- package/dist/BarGraph.js +203 -201
- package/dist/BarGraph.js.map +1 -1
- package/dist/BasicStatCard.cjs +1 -1
- package/dist/BasicStatCard.cjs.map +1 -1
- package/dist/BasicStatCard.js +15 -14
- package/dist/BasicStatCard.js.map +1 -1
- package/dist/BeeSwarmChart.cjs +1 -1
- package/dist/BeeSwarmChart.cjs.map +1 -1
- package/dist/BeeSwarmChart.js +60 -59
- package/dist/BeeSwarmChart.js.map +1 -1
- package/dist/BiVariateChoroplethMap.cjs +1 -1
- package/dist/BiVariateChoroplethMap.cjs.map +1 -1
- package/dist/BiVariateChoroplethMap.js +88 -86
- package/dist/BiVariateChoroplethMap.js.map +1 -1
- package/dist/BulletChart.cjs +1 -1
- package/dist/BulletChart.cjs.map +1 -1
- package/dist/BulletChart.js +88 -86
- package/dist/BulletChart.js.map +1 -1
- package/dist/ButterflyChart.cjs +1 -1
- package/dist/ButterflyChart.cjs.map +1 -1
- package/dist/ButterflyChart.js +100 -98
- package/dist/ButterflyChart.js.map +1 -1
- package/dist/ChoroplethMap.cjs +1 -1
- package/dist/ChoroplethMap.cjs.map +1 -1
- package/dist/ChoroplethMap.js +83 -81
- package/dist/ChoroplethMap.js.map +1 -1
- package/dist/CirclePackingGraph.cjs +1 -1
- package/dist/CirclePackingGraph.js +4 -4
- package/dist/ColorLegend.cjs +1 -1
- package/dist/ColorLegend.cjs.map +1 -1
- package/dist/ColorLegend.js +17 -16
- package/dist/ColorLegend.js.map +1 -1
- package/dist/ColorLegendWithMouseOver.cjs +1 -1
- package/dist/ColorLegendWithMouseOver.cjs.map +1 -1
- package/dist/ColorLegendWithMouseOver.js +13 -12
- package/dist/ColorLegendWithMouseOver.js.map +1 -1
- package/dist/CopyTextButton.cjs +1 -1
- package/dist/CopyTextButton.cjs.map +1 -1
- package/dist/CopyTextButton.js +37 -754
- package/dist/CopyTextButton.js.map +1 -1
- package/dist/CsvDownloadButton.cjs +4 -4
- package/dist/CsvDownloadButton.cjs.map +1 -1
- package/dist/CsvDownloadButton.js +47 -45
- package/dist/CsvDownloadButton.js.map +1 -1
- package/dist/DataCards.cjs +1 -1
- package/dist/DataCards.cjs.map +1 -1
- package/dist/DataCards.js +213 -467
- package/dist/DataCards.js.map +1 -1
- package/dist/DataTable.cjs +1 -1
- package/dist/DataTable.cjs.map +1 -1
- package/dist/DataTable.js +19 -19
- package/dist/DetailsModal-BmjtLqrZ.cjs +2 -0
- package/dist/{DetailsModal-Du8Fr1QD.cjs.map → DetailsModal-BmjtLqrZ.cjs.map} +1 -1
- package/dist/{DetailsModal-GqEbGHY2.js → DetailsModal-k-Me_U_T.js} +3 -3
- package/dist/{DetailsModal-GqEbGHY2.js.map → DetailsModal-k-Me_U_T.js.map} +1 -1
- package/dist/DifferenceLineChart.cjs +1 -1
- package/dist/DifferenceLineChart.cjs.map +1 -1
- package/dist/DifferenceLineChart.js +61 -60
- package/dist/DifferenceLineChart.js.map +1 -1
- package/dist/DonutChart.cjs +1 -1
- package/dist/DonutChart.cjs.map +1 -1
- package/dist/DonutChart.js +47 -46
- package/dist/DonutChart.js.map +1 -1
- package/dist/DotDensityMap.cjs +1 -1
- package/dist/DotDensityMap.cjs.map +1 -1
- package/dist/DotDensityMap.js +112 -110
- package/dist/DotDensityMap.js.map +1 -1
- package/dist/DualAxisLineChart.cjs +1 -1
- package/dist/DualAxisLineChart.cjs.map +1 -1
- package/dist/DualAxisLineChart.js +13 -12
- package/dist/DualAxisLineChart.js.map +1 -1
- package/dist/DumbbellChart.cjs +1 -1
- package/dist/DumbbellChart.cjs.map +1 -1
- package/dist/DumbbellChart.js +104 -102
- package/dist/DumbbellChart.js.map +1 -1
- package/dist/EmptyState-BoaUUuo6.cjs +2 -0
- package/dist/{EmptyState-CFmiFPHz.cjs.map → EmptyState-BoaUUuo6.cjs.map} +1 -1
- package/dist/{EmptyState-CaxXCkiN.js → EmptyState-prZ8OnEs.js} +4 -4
- package/dist/{EmptyState-CaxXCkiN.js.map → EmptyState-prZ8OnEs.js.map} +1 -1
- package/dist/ExcelDownloadButton.cjs +1 -1
- package/dist/ExcelDownloadButton.cjs.map +1 -1
- package/dist/ExcelDownloadButton.js +15 -13
- package/dist/ExcelDownloadButton.js.map +1 -1
- package/dist/FootNote.cjs +1 -1
- package/dist/FootNote.cjs.map +1 -1
- package/dist/FootNote.js +10 -9
- package/dist/FootNote.js.map +1 -1
- package/dist/GeoHubCompareMaps.cjs +1 -1
- package/dist/GeoHubCompareMaps.cjs.map +1 -1
- package/dist/GeoHubCompareMaps.js +14 -14
- package/dist/GeoHubMap.cjs +1 -1
- package/dist/GeoHubMap.cjs.map +1 -1
- package/dist/GeoHubMap.js +59 -59
- package/dist/GeoHubMapWithLayerSelection.cjs +1 -1
- package/dist/GeoHubMapWithLayerSelection.cjs.map +1 -1
- package/dist/GeoHubMapWithLayerSelection.js +50 -50
- package/dist/{GraphContainer-B8ZqOzKI.js → GraphContainer-DcOM2CI6.js} +28 -27
- package/dist/GraphContainer-DcOM2CI6.js.map +1 -0
- package/dist/GraphContainer-gaG9TSy4.cjs +2 -0
- package/dist/{GraphContainer-Cul9b74X.cjs.map → GraphContainer-gaG9TSy4.cjs.map} +1 -1
- package/dist/GraphDescription.cjs +1 -1
- package/dist/GraphDescription.cjs.map +1 -1
- package/dist/GraphDescription.js +14 -13
- package/dist/GraphDescription.js.map +1 -1
- package/dist/{GraphEl-Ch0uAeZw.js → GraphEl-C7KBBHvB.js} +9 -9
- package/dist/{GraphEl-Ch0uAeZw.js.map → GraphEl-C7KBBHvB.js.map} +1 -1
- package/dist/GraphEl-CGALp07K.cjs +2 -0
- package/dist/{GraphEl-BgkDbq50.cjs.map → GraphEl-CGALp07K.cjs.map} +1 -1
- package/dist/GraphFooter.cjs +1 -1
- package/dist/GraphFooter.cjs.map +1 -1
- package/dist/GraphFooter.js +2 -2
- package/dist/GraphHeader.cjs +1 -1
- package/dist/GraphHeader.cjs.map +1 -1
- package/dist/GraphHeader.js +1 -1
- package/dist/GraphTitle.cjs +1 -1
- package/dist/GraphTitle.cjs.map +1 -1
- package/dist/GraphTitle.js +14 -13
- package/dist/GraphTitle.js.map +1 -1
- package/dist/GriddedGraphs.cjs +1 -1
- package/dist/GriddedGraphs.cjs.map +1 -1
- package/dist/GriddedGraphs.js +58 -55
- package/dist/GriddedGraphs.js.map +1 -1
- package/dist/GriddedGraphsFromConfig.cjs +1 -1
- package/dist/GriddedGraphsFromConfig.cjs.map +1 -1
- package/dist/GriddedGraphsFromConfig.js +15 -15
- package/dist/HeatMap.cjs +1 -1
- package/dist/HeatMap.cjs.map +1 -1
- package/dist/HeatMap.js +17 -16
- package/dist/HeatMap.js.map +1 -1
- package/dist/Histogram.cjs +1 -1
- package/dist/Histogram.cjs.map +1 -1
- package/dist/Histogram.js +3 -3
- package/dist/HybridMap.cjs +1 -1
- package/dist/HybridMap.cjs.map +1 -1
- package/dist/HybridMap.js +392 -424
- package/dist/HybridMap.js.map +1 -1
- package/dist/ImageDownloadButton.cjs +1 -1
- package/dist/ImageDownloadButton.cjs.map +1 -1
- package/dist/ImageDownloadButton.js +16 -14
- package/dist/ImageDownloadButton.js.map +1 -1
- package/dist/LineChartWithConfidenceInterval.cjs +1 -1
- package/dist/LineChartWithConfidenceInterval.cjs.map +1 -1
- package/dist/LineChartWithConfidenceInterval.js +16 -15
- package/dist/LineChartWithConfidenceInterval.js.map +1 -1
- package/dist/LinearColorLegend.cjs +1 -1
- package/dist/LinearColorLegend.cjs.map +1 -1
- package/dist/LinearColorLegend.js +5 -4
- package/dist/LinearColorLegend.js.map +1 -1
- package/dist/MultiGraphDashboard.cjs +1 -1
- package/dist/MultiGraphDashboard.cjs.map +1 -1
- package/dist/MultiGraphDashboard.js +62 -60
- package/dist/MultiGraphDashboard.js.map +1 -1
- package/dist/MultiGraphDashboardFromConfig.cjs +1 -1
- package/dist/MultiGraphDashboardFromConfig.cjs.map +1 -1
- package/dist/MultiGraphDashboardFromConfig.js +7 -7
- package/dist/MultiGraphDashboardWideToLongFormat.cjs +1 -1
- package/dist/MultiGraphDashboardWideToLongFormat.cjs.map +1 -1
- package/dist/MultiGraphDashboardWideToLongFormat.js +21 -21
- package/dist/MultiGraphDashboardWideToLongFormat.js.map +1 -1
- package/dist/MultiGraphDashboardWideToLongFormatFromConfig.cjs +1 -1
- package/dist/MultiGraphDashboardWideToLongFormatFromConfig.cjs.map +1 -1
- package/dist/MultiGraphDashboardWideToLongFormatFromConfig.js +3 -3
- package/dist/MultiLineAltChart.cjs +1 -1
- package/dist/MultiLineAltChart.cjs.map +1 -1
- package/dist/MultiLineAltChart.js +16 -15
- package/dist/MultiLineAltChart.js.map +1 -1
- package/dist/MultiLineChart.cjs +1 -1
- package/dist/MultiLineChart.cjs.map +1 -1
- package/dist/MultiLineChart.js +16 -15
- package/dist/MultiLineChart.js.map +1 -1
- package/dist/ParetoChart.cjs +1 -1
- package/dist/ParetoChart.cjs.map +1 -1
- package/dist/ParetoChart.js +14 -13
- package/dist/ParetoChart.js.map +1 -1
- package/dist/PerformanceIntensiveMultiGraphDashboard.cjs +1 -1
- package/dist/PerformanceIntensiveMultiGraphDashboard.cjs.map +1 -1
- package/dist/PerformanceIntensiveMultiGraphDashboard.js +67 -65
- package/dist/PerformanceIntensiveMultiGraphDashboard.js.map +1 -1
- package/dist/PerformanceIntensiveMultiGraphDashboardFromConfig.cjs +1 -1
- package/dist/PerformanceIntensiveMultiGraphDashboardFromConfig.cjs.map +1 -1
- package/dist/PerformanceIntensiveMultiGraphDashboardFromConfig.js +8 -8
- package/dist/PerformanceIntensiveScrollStory.cjs +1 -1
- package/dist/PerformanceIntensiveScrollStory.cjs.map +1 -1
- package/dist/PerformanceIntensiveScrollStory.js +3 -3
- package/dist/RadarChart.cjs +1 -1
- package/dist/RadarChart.cjs.map +1 -1
- package/dist/RadarChart.js +11 -10
- package/dist/RadarChart.js.map +1 -1
- package/dist/ReferenceLine-CxITVT1K.cjs +2 -0
- package/dist/{ReferenceLine-CpU4G01Y.cjs.map → ReferenceLine-CxITVT1K.cjs.map} +1 -1
- package/dist/{ReferenceLine-D41VuUhE.js → ReferenceLine-NF4g3Reh.js} +26 -25
- package/dist/ReferenceLine-NF4g3Reh.js.map +1 -0
- package/dist/RegressionLine-BQ6h-NZP.js +88 -0
- package/dist/RegressionLine-BQ6h-NZP.js.map +1 -0
- package/dist/RegressionLine-BpcVBjL0.cjs +2 -0
- package/dist/{RegressionLine-BFoBiVJk.cjs.map → RegressionLine-BpcVBjL0.cjs.map} +1 -1
- package/dist/SVGDownloadButton.cjs +1 -1
- package/dist/SVGDownloadButton.cjs.map +1 -1
- package/dist/SVGDownloadButton.js +11 -9
- package/dist/SVGDownloadButton.js.map +1 -1
- package/dist/SankeyChart.cjs +1 -1
- package/dist/SankeyChart.cjs.map +1 -1
- package/dist/SankeyChart.js +63 -62
- package/dist/SankeyChart.js.map +1 -1
- package/dist/ScatterPlot.cjs +1 -1
- package/dist/ScatterPlot.cjs.map +1 -1
- package/dist/ScatterPlot.js +109 -107
- package/dist/ScatterPlot.js.map +1 -1
- package/dist/ScrollStory.cjs +1 -1
- package/dist/ScrollStory.cjs.map +1 -1
- package/dist/ScrollStory.js +3 -3
- package/dist/SimpleLineChart.cjs +1 -1
- package/dist/SimpleLineChart.cjs.map +1 -1
- package/dist/SimpleLineChart.js +17 -16
- package/dist/SimpleLineChart.js.map +1 -1
- package/dist/SingleGraphDashboard.cjs +1 -1
- package/dist/SingleGraphDashboard.cjs.map +1 -1
- package/dist/SingleGraphDashboard.js +59 -56
- package/dist/SingleGraphDashboard.js.map +1 -1
- package/dist/SingleGraphDashboardFromConfig.cjs +1 -1
- package/dist/SingleGraphDashboardFromConfig.cjs.map +1 -1
- package/dist/SingleGraphDashboardFromConfig.js +6 -6
- package/dist/SingleGraphDashboardGeoHubMaps.cjs +1 -1
- package/dist/SingleGraphDashboardGeoHubMaps.cjs.map +1 -1
- package/dist/SingleGraphDashboardGeoHubMaps.js +12 -12
- package/dist/SingleGraphDashboardGeoHubMapsFromConfig.cjs +1 -1
- package/dist/SingleGraphDashboardGeoHubMapsFromConfig.cjs.map +1 -1
- package/dist/SingleGraphDashboardGeoHubMapsFromConfig.js +8 -8
- package/dist/SingleGraphDashboardThreeDGraphs.cjs +1 -1
- package/dist/SingleGraphDashboardThreeDGraphs.cjs.map +1 -1
- package/dist/SingleGraphDashboardThreeDGraphs.js +59 -56
- package/dist/SingleGraphDashboardThreeDGraphs.js.map +1 -1
- package/dist/SingleGraphDashboardThreeDGraphsFromConfig.cjs +1 -1
- package/dist/SingleGraphDashboardThreeDGraphsFromConfig.cjs.map +1 -1
- package/dist/SingleGraphDashboardThreeDGraphsFromConfig.js +7 -7
- package/dist/SlopeChart.cjs +1 -1
- package/dist/SlopeChart.cjs.map +1 -1
- package/dist/SlopeChart.js +60 -59
- package/dist/SlopeChart.js.map +1 -1
- package/dist/Source.cjs +1 -1
- package/dist/Source.cjs.map +1 -1
- package/dist/Source.js +38 -4
- package/dist/Source.js.map +1 -1
- package/dist/SparkLine.cjs +1 -1
- package/dist/SparkLine.cjs.map +1 -1
- package/dist/SparkLine.js +11 -10
- package/dist/SparkLine.js.map +1 -1
- package/dist/StatCardFromData.cjs +1 -1
- package/dist/StatCardFromData.cjs.map +1 -1
- package/dist/StatCardFromData.js +15 -14
- package/dist/StatCardFromData.js.map +1 -1
- package/dist/StripChart.cjs +1 -1
- package/dist/StripChart.cjs.map +1 -1
- package/dist/StripChart.js +11 -10
- package/dist/StripChart.js.map +1 -1
- package/dist/ThreeDGlobe.cjs +1 -1
- package/dist/ThreeDGlobe.cjs.map +1 -1
- package/dist/ThreeDGlobe.js +52 -51
- package/dist/ThreeDGlobe.js.map +1 -1
- package/dist/ThresholdColorLegendWithMouseOver.cjs +1 -1
- package/dist/ThresholdColorLegendWithMouseOver.cjs.map +1 -1
- package/dist/ThresholdColorLegendWithMouseOver.js +17 -16
- package/dist/ThresholdColorLegendWithMouseOver.js.map +1 -1
- package/dist/{Tooltip-3EYDVa3w.js → Tooltip-DO56mY4b.js} +11 -10
- package/dist/{Tooltip-3EYDVa3w.js.map → Tooltip-DO56mY4b.js.map} +1 -1
- package/dist/Tooltip-DwUFLDrj.cjs +2 -0
- package/dist/{Tooltip-C9F3uYG0.cjs.map → Tooltip-DwUFLDrj.cjs.map} +1 -1
- package/dist/TreeMapGraph.cjs +1 -1
- package/dist/TreeMapGraph.cjs.map +1 -1
- package/dist/TreeMapGraph.js +34 -33
- package/dist/TreeMapGraph.js.map +1 -1
- package/dist/UnitChart.cjs +1 -1
- package/dist/UnitChart.cjs.map +1 -1
- package/dist/UnitChart.js +27 -27
- package/dist/WaterfallChart.cjs +1 -1
- package/dist/WaterfallChart.cjs.map +1 -1
- package/dist/WaterfallChart.js +21 -20
- package/dist/WaterfallChart.js.map +1 -1
- package/dist/XAxesLabels-0ROJnigy.cjs +2 -0
- package/dist/{XAxesLabels-C03jHniq.cjs.map → XAxesLabels-0ROJnigy.cjs.map} +1 -1
- package/dist/{XAxesLabels-B9gkjUiC.js → XAxesLabels-CPZX3OJN.js} +12 -11
- package/dist/XAxesLabels-CPZX3OJN.js.map +1 -0
- package/dist/XTicksAndGridLines-BO6KJc8d.cjs +2 -0
- package/dist/{XTicksAndGridLines-B4UhDVyU.cjs.map → XTicksAndGridLines-BO6KJc8d.cjs.map} +1 -1
- package/dist/{XTicksAndGridLines-CkYwVshF.js → XTicksAndGridLines-obTK2e7G.js} +10 -9
- package/dist/{XTicksAndGridLines-CkYwVshF.js.map → XTicksAndGridLines-obTK2e7G.js.map} +1 -1
- package/dist/{YAxesLabels-hWEUCTvs.js → YAxesLabels-CwVnFG2a.js} +13 -12
- package/dist/YAxesLabels-CwVnFG2a.js.map +1 -0
- package/dist/YAxesLabels-DIa2cEXL.cjs +2 -0
- package/dist/{YAxesLabels-DeENFC2M.cjs.map → YAxesLabels-DIa2cEXL.cjs.map} +1 -1
- package/dist/YTicksAndGridLines-C7glLI5b.cjs +2 -0
- package/dist/{YTicksAndGridLines-sT3zdCs6.cjs.map → YTicksAndGridLines-C7glLI5b.cjs.map} +1 -1
- package/dist/{YTicksAndGridLines-BbujwxOB.js → YTicksAndGridLines-wtuAKNeT.js} +10 -9
- package/dist/{YTicksAndGridLines-BbujwxOB.js.map → YTicksAndGridLines-wtuAKNeT.js.map} +1 -1
- package/dist/checkIfMultiple-BIEQDuA3.cjs +2 -0
- package/dist/checkIfMultiple-BIEQDuA3.cjs.map +1 -0
- package/dist/checkIfMultiple-D2tgEnYM.js +11 -0
- package/dist/checkIfMultiple-D2tgEnYM.js.map +1 -0
- package/dist/compiler-runtime-oPPev21o.cjs +11 -0
- package/dist/compiler-runtime-oPPev21o.cjs.map +1 -0
- package/dist/compiler-runtime-qHgugrLy.js +297 -0
- package/dist/compiler-runtime-qHgugrLy.js.map +1 -0
- package/dist/customArea-BCGIYDQa.cjs +2 -0
- package/dist/{customArea-BAcQ3pBM.cjs.map → customArea-BCGIYDQa.cjs.map} +1 -1
- package/dist/{customArea-D89lETG0.js → customArea-Dixg0NtQ.js} +10 -9
- package/dist/{customArea-D89lETG0.js.map → customArea-Dixg0NtQ.js.map} +1 -1
- package/dist/{fetchAndParseData-BAXhgTDM.js → fetchAndParseData-CDjQZ1fL.js} +5 -5
- package/dist/{fetchAndParseData-BAXhgTDM.js.map → fetchAndParseData-CDjQZ1fL.js.map} +1 -1
- package/dist/fetchAndParseData.js +1 -1
- package/dist/getSliderMarks-Bj_JJTtX.cjs +2 -0
- package/dist/getSliderMarks-Bj_JJTtX.cjs.map +1 -0
- package/dist/getSliderMarks-DSxFGb1f.js +21 -0
- package/dist/getSliderMarks-DSxFGb1f.js.map +1 -0
- package/dist/index-5BQWR1Z8.cjs +10 -0
- package/dist/{index-FXfr51ZM.cjs.map → index-5BQWR1Z8.cjs.map} +1 -1
- package/dist/index-BaXzoD4r.cjs +2 -0
- package/dist/{index-BuhBhuCq.cjs.map → index-BaXzoD4r.cjs.map} +1 -1
- package/dist/{index-Cv_5q6Rb.js → index-CNUlPiEL.js} +3 -3
- package/dist/{index-Cv_5q6Rb.js.map → index-CNUlPiEL.js.map} +1 -1
- package/dist/{index-DHVGV8Df.js → index-CmkqqFRG.js} +3 -3
- package/dist/{index-DHVGV8Df.js.map → index-CmkqqFRG.js.map} +1 -1
- package/dist/index-D_ls5oK8.js +142 -0
- package/dist/index-D_ls5oK8.js.map +1 -0
- package/dist/index-DbSnila_.cjs +2 -0
- package/dist/index-DbSnila_.cjs.map +1 -0
- package/dist/{index-BPyj_6hG.js → index-_w-CQAbR.js} +113 -112
- package/dist/{index-BPyj_6hG.js.map → index-_w-CQAbR.js.map} +1 -1
- package/dist/index-dN3wiQgD.cjs +2 -0
- package/dist/{index-DuLvdHo2.cjs.map → index-dN3wiQgD.cjs.map} +1 -1
- package/dist/index.cjs +1 -1
- package/dist/index.js +181 -180
- package/dist/index.js.map +1 -1
- package/dist/{proxy-BsxtcZKa.js → proxy-D31SA_aE.js} +2 -2
- package/dist/{proxy-BsxtcZKa.js.map → proxy-D31SA_aE.js.map} +1 -1
- package/dist/proxy-QMeVVqam.cjs +2 -0
- package/dist/{proxy-CqH8m8IQ.cjs.map → proxy-QMeVVqam.cjs.map} +1 -1
- package/dist/style.css +1 -1
- package/dist/transformData.js +2 -2
- package/dist/{transformDataForGraphFromFile-dt9sHTVy.js → transformDataForGraphFromFile-COZC6A0_.js} +4 -4
- package/dist/{transformDataForGraphFromFile-dt9sHTVy.js.map → transformDataForGraphFromFile-COZC6A0_.js.map} +1 -1
- package/dist/{use-in-view-KOXq5Kmc.js → use-in-view-Co5SmzfT.js} +2 -2
- package/dist/{use-in-view-KOXq5Kmc.js.map → use-in-view-Co5SmzfT.js.map} +1 -1
- package/dist/use-in-view-DjR_gqJP.cjs +2 -0
- package/dist/{use-in-view-dnRv_qqF.cjs.map → use-in-view-DjR_gqJP.cjs.map} +1 -1
- package/package.json +1 -1
- package/dist/Axis-BTaS9oPQ.cjs +0 -2
- package/dist/AxisTitle-CyLCqpW6.js +0 -29
- package/dist/AxisTitle-CyLCqpW6.js.map +0 -1
- package/dist/AxisTitle-DP_evhbe.cjs +0 -2
- package/dist/DetailsModal-Du8Fr1QD.cjs +0 -2
- package/dist/DropdownSelect-CX1yMemd.cjs +0 -5
- package/dist/DropdownSelect-CX1yMemd.cjs.map +0 -1
- package/dist/DropdownSelect-Dz7imdTB.js +0 -4191
- package/dist/DropdownSelect-Dz7imdTB.js.map +0 -1
- package/dist/EmptyState-CFmiFPHz.cjs +0 -2
- package/dist/GraphContainer-B8ZqOzKI.js.map +0 -1
- package/dist/GraphContainer-Cul9b74X.cjs +0 -2
- package/dist/GraphEl-BgkDbq50.cjs +0 -2
- package/dist/Modal-BIErPPKT.cjs +0 -46
- package/dist/Modal-BIErPPKT.cjs.map +0 -1
- package/dist/Modal-CrUYln5V.js +0 -1047
- package/dist/Modal-CrUYln5V.js.map +0 -1
- package/dist/ReferenceLine-CpU4G01Y.cjs +0 -2
- package/dist/ReferenceLine-D41VuUhE.js.map +0 -1
- package/dist/RegressionLine-BFoBiVJk.cjs +0 -2
- package/dist/RegressionLine-CuwB42I6.js +0 -87
- package/dist/RegressionLine-CuwB42I6.js.map +0 -1
- package/dist/Source-PKuwZOn3.cjs +0 -2
- package/dist/Source-PKuwZOn3.cjs.map +0 -1
- package/dist/Source-QGk8vhkS.js +0 -78
- package/dist/Source-QGk8vhkS.js.map +0 -1
- package/dist/Spinner-B2IIKg9r.js +0 -47
- package/dist/Spinner-B2IIKg9r.js.map +0 -1
- package/dist/Spinner-WHzzloYQ.cjs +0 -2
- package/dist/Spinner-WHzzloYQ.cjs.map +0 -1
- package/dist/Tooltip-C9F3uYG0.cjs +0 -2
- package/dist/Typography-BO0gQDIT.js +0 -270
- package/dist/Typography-BO0gQDIT.js.map +0 -1
- package/dist/Typography-BqmyF1gP.cjs +0 -2
- package/dist/Typography-BqmyF1gP.cjs.map +0 -1
- package/dist/XAxesLabels-B9gkjUiC.js.map +0 -1
- package/dist/XAxesLabels-C03jHniq.cjs +0 -2
- package/dist/XTicksAndGridLines-B4UhDVyU.cjs +0 -2
- package/dist/YAxesLabels-DeENFC2M.cjs +0 -2
- package/dist/YAxesLabels-hWEUCTvs.js.map +0 -1
- package/dist/YTicksAndGridLines-sT3zdCs6.cjs +0 -2
- package/dist/checkIfMultiple-CH5tqj4q.cjs +0 -2
- package/dist/checkIfMultiple-CH5tqj4q.cjs.map +0 -1
- package/dist/checkIfMultiple-Dpyy6BUP.js +0 -938
- package/dist/checkIfMultiple-Dpyy6BUP.js.map +0 -1
- package/dist/customArea-BAcQ3pBM.cjs +0 -2
- package/dist/getSliderMarks-BzrpHrHS.cjs +0 -2
- package/dist/getSliderMarks-BzrpHrHS.cjs.map +0 -1
- package/dist/getSliderMarks-X-_goqH9.js +0 -1027
- package/dist/getSliderMarks-X-_goqH9.js.map +0 -1
- package/dist/index-ApTBN0kp.js +0 -196
- package/dist/index-ApTBN0kp.js.map +0 -1
- package/dist/index-BhI7mBJx.cjs +0 -2
- package/dist/index-BhI7mBJx.cjs.map +0 -1
- package/dist/index-BuhBhuCq.cjs +0 -2
- package/dist/index-CHPV5EwG-BzibaIRc.js +0 -3360
- package/dist/index-CHPV5EwG-BzibaIRc.js.map +0 -1
- package/dist/index-CHPV5EwG-D4pAp7u0.cjs +0 -20
- package/dist/index-CHPV5EwG-D4pAp7u0.cjs.map +0 -1
- package/dist/index-DuLvdHo2.cjs +0 -2
- package/dist/index-FXfr51ZM.cjs +0 -10
- package/dist/index-Scxs_wcm-BAjU0Cob.js +0 -49
- package/dist/index-Scxs_wcm-BAjU0Cob.js.map +0 -1
- package/dist/index-Scxs_wcm-DUDU-Gll.cjs +0 -2
- package/dist/index-Scxs_wcm-DUDU-Gll.cjs.map +0 -1
- package/dist/index-w64Zl8io-DrMm5QSb.cjs +0 -2
- package/dist/index-w64Zl8io-DrMm5QSb.cjs.map +0 -1
- package/dist/index-w64Zl8io-ihagHOdP.js +0 -459
- package/dist/index-w64Zl8io-ihagHOdP.js.map +0 -1
- package/dist/proxy-CqH8m8IQ.cjs +0 -2
- package/dist/toConsumableArray-DiWOvh_d-DcLaZvDq.cjs +0 -4
- package/dist/toConsumableArray-DiWOvh_d-DcLaZvDq.cjs.map +0 -1
- package/dist/toConsumableArray-DiWOvh_d-DlpOlgap.js +0 -145
- package/dist/toConsumableArray-DiWOvh_d-DlpOlgap.js.map +0 -1
- package/dist/use-in-view-dnRv_qqF.cjs +0 -2
- package/dist/x-BXShoIAM-BC2sxios.cjs +0 -2
- package/dist/x-BXShoIAM-BC2sxios.cjs.map +0 -1
- package/dist/x-BXShoIAM-D6VWO6z5.js +0 -74
- package/dist/x-BXShoIAM-D6VWO6z5.js.map +0 -1
package/dist/ThreeDGlobe.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ThreeDGlobe.js","sources":["../node_modules/hex-to-rgba/build/index.js","../src/Components/Graphs/Maps/ThreeDGlobe/Graph.tsx","../src/Components/Graphs/Maps/ThreeDGlobe/index.tsx"],"sourcesContent":["\"use strict\";\n\nvar removeHash = function removeHash(hex) {\n return hex.charAt(0) === '#' ? hex.slice(1) : hex;\n};\n\nvar parseHex = function parseHex(nakedHex) {\n var isShort = nakedHex.length === 3 || nakedHex.length === 4;\n var twoDigitHexR = isShort ? \"\".concat(nakedHex.slice(0, 1)).concat(nakedHex.slice(0, 1)) : nakedHex.slice(0, 2);\n var twoDigitHexG = isShort ? \"\".concat(nakedHex.slice(1, 2)).concat(nakedHex.slice(1, 2)) : nakedHex.slice(2, 4);\n var twoDigitHexB = isShort ? \"\".concat(nakedHex.slice(2, 3)).concat(nakedHex.slice(2, 3)) : nakedHex.slice(4, 6);\n var twoDigitHexA = (isShort ? \"\".concat(nakedHex.slice(3, 4)).concat(nakedHex.slice(3, 4)) : nakedHex.slice(6, 8)) || 'ff'; // const numericA = +((parseInt(a, 16) / 255).toFixed(2));\n\n return {\n r: twoDigitHexR,\n g: twoDigitHexG,\n b: twoDigitHexB,\n a: twoDigitHexA\n };\n};\n\nvar hexToDecimal = function hexToDecimal(hex) {\n return parseInt(hex, 16);\n};\n\nvar hexesToDecimals = function hexesToDecimals(_ref) {\n var r = _ref.r,\n g = _ref.g,\n b = _ref.b,\n a = _ref.a;\n return {\n r: hexToDecimal(r),\n g: hexToDecimal(g),\n b: hexToDecimal(b),\n a: +(hexToDecimal(a) / 255).toFixed(2)\n };\n};\n\nvar isNumeric = function isNumeric(n) {\n return !isNaN(parseFloat(n)) && isFinite(n);\n}; // eslint-disable-line no-restricted-globals, max-len\n\n\nvar formatRgb = function formatRgb(decimalObject, parameterA) {\n var r = decimalObject.r,\n g = decimalObject.g,\n b = decimalObject.b,\n parsedA = decimalObject.a;\n var a = isNumeric(parameterA) ? parameterA : parsedA;\n return \"rgba(\".concat(r, \", \").concat(g, \", \").concat(b, \", \").concat(a, \")\");\n};\n/**\n * Turns an old-fashioned css hex color value into a rgb color value.\n *\n * If you specify an alpha value, you'll get a rgba() value instead.\n *\n * @param The hex value to convert. ('123456'. '#123456', ''123', '#123')\n * @param An alpha value to apply. (optional) ('0.5', '0.25')\n * @return An rgb or rgba value. ('rgb(11, 22, 33)'. 'rgba(11, 22, 33, 0.5)')\n */\n\n\nvar hexToRgba = function hexToRgba(hex, a) {\n var hashlessHex = removeHash(hex);\n var hexObject = parseHex(hashlessHex);\n var decimalObject = hexesToDecimals(hexObject);\n return formatRgb(decimalObject, a);\n};\n\nmodule.exports = hexToRgba;","/* eslint-disable @typescript-eslint/no-explicit-any */\r\nimport Globe, { GlobeMethods } from 'react-globe.gl';\r\nimport isEqual from 'fast-deep-equal';\r\nimport { useCallback, useEffect, useRef, useState } from 'react';\r\nimport { scaleOrdinal, scaleThreshold } from 'd3-scale';\r\nimport * as THREE from 'three';\r\nimport { P } from '@undp/design-system-react/Typography';\r\nimport { cn } from '@undp/design-system-react/cn';\r\nimport hexToRgba from 'hex-to-rgba';\r\n\r\nimport {\r\n ChoroplethMapDataType,\r\n ClassNameObject,\r\n FogDataType,\r\n LightConfig,\r\n NumberFormatOptions,\r\n StyleObject,\r\n} from '@/Types';\r\nimport { Tooltip } from '@/Components/Elements/Tooltip';\r\nimport { numberFormattingFunction } from '@/Utils/numberFormattingFunction';\r\nimport { ExpandIcon, X } from '@/Components/Icons';\r\nimport { getCentroidCoordinates } from '@/Utils/getCentroidCoordinates';\r\nimport { DetailsModal } from '@/Components/Elements/DetailsModal';\r\n\r\ninterface Props {\r\n width: number;\r\n data: ChoroplethMapDataType[];\r\n autoRotate: number;\r\n enableZoom: boolean;\r\n categorical: boolean;\r\n colorDomain: (number | string)[];\r\n colors: string[];\r\n height: number;\r\n globeMaterial?: THREE.Material;\r\n lights: LightConfig[];\r\n polygonData: any;\r\n mapProperty: string;\r\n mapBorderColor: string;\r\n atmosphereColor: string;\r\n tooltip?: string | ((_d: any) => React.ReactNode);\r\n styles?: StyleObject;\r\n classNames?: ClassNameObject;\r\n onSeriesMouseOver?: (_d: any) => void;\r\n onSeriesMouseClick?: (_d: any) => void;\r\n mapNoDataColor: string;\r\n colorLegendTitle?: string;\r\n showColorScale: boolean;\r\n hoverStrokeColor: string;\r\n detailsOnClick?: string | ((_d: any) => React.ReactNode);\r\n resetSelectionOnDoubleClick: boolean;\r\n highlightedIds?: string[];\r\n scale: number;\r\n globeOffset: [number, number];\r\n polygonAltitude: number;\r\n centerLng: number;\r\n centerLat: number;\r\n atmosphereAltitude: number;\r\n globeCurvatureResolution: number;\r\n fogSettings?: FogDataType;\r\n highlightedAltitude: number;\r\n selectedId?: string;\r\n collapseColorScaleByDefault?: boolean;\r\n dimmedOpacity: number;\r\n numberDisplayOptions?: Omit<NumberFormatOptions, 'suffix' | 'prefix'>;\r\n}\r\n\r\nfunction createLightFromConfig(config: LightConfig): THREE.Light {\r\n let light: THREE.Light;\r\n\r\n switch (config.type) {\r\n case 'ambient':\r\n light = new THREE.AmbientLight(config.color, config.intensity);\r\n break;\r\n case 'directional':\r\n light = new THREE.DirectionalLight(config.color, config.intensity);\r\n if (config.position) {\r\n if (config.position === 'camera') light.position.set(0, 0, 0);\r\n else light.position.set(config.position.x, config.position.y, config.position.z);\r\n }\r\n if (config.target || config.position === 'camera') {\r\n (light as THREE.SpotLight).target.position.set(\r\n config.target?.x || 0,\r\n config.target?.y || 0,\r\n config.target?.z === undefined ? -1 : config.target.z,\r\n );\r\n }\r\n if (config.castShadow) {\r\n (light as THREE.DirectionalLight).castShadow = true;\r\n if (config.shadow) {\r\n (light as THREE.DirectionalLight).shadow.mapSize.width = config.shadow.mapSize.width;\r\n (light as THREE.DirectionalLight).shadow.mapSize.height = config.shadow.mapSize.height;\r\n (light as THREE.DirectionalLight).shadow.camera.near = config.shadow.camera.near;\r\n (light as THREE.DirectionalLight).shadow.camera.far = config.shadow.camera.far;\r\n }\r\n }\r\n break;\r\n case 'point':\r\n light = new THREE.PointLight(\r\n config.color,\r\n config.intensity,\r\n config.distance || 0,\r\n config.decay || 2,\r\n );\r\n if (config.position) {\r\n if (config.position === 'camera') light.position.set(0, 0, 0);\r\n else light.position.set(config.position.x, config.position.y, config.position.z);\r\n }\r\n break;\r\n case 'spot':\r\n light = new THREE.SpotLight(\r\n config.color,\r\n config.intensity,\r\n config.distance || 0,\r\n config.angle || Math.PI / 3,\r\n config.penumbra || 0,\r\n config.decay || 2,\r\n );\r\n if (config.position) {\r\n if (config.position === 'camera') light.position.set(0, 0, 0);\r\n else light.position.set(config.position.x, config.position.y, config.position.z);\r\n }\r\n if (config.target || config.position === 'camera') {\r\n (light as THREE.SpotLight).target.position.set(\r\n config.target?.x || 0,\r\n config.target?.y || 0,\r\n config.target?.z || 0,\r\n );\r\n }\r\n if (config.castShadow) {\r\n (light as THREE.SpotLight).castShadow = true;\r\n if (config.shadow) {\r\n (light as THREE.SpotLight).shadow.mapSize.width = config.shadow.mapSize.width;\r\n (light as THREE.SpotLight).shadow.mapSize.height = config.shadow.mapSize.height;\r\n (light as THREE.SpotLight).shadow.camera.near = config.shadow.camera.near;\r\n (light as THREE.SpotLight).shadow.camera.far = config.shadow.camera.far;\r\n }\r\n }\r\n break;\r\n default:\r\n throw new Error('Unknown light type');\r\n }\r\n\r\n return light;\r\n}\r\nfunction Graph(props: Props) {\r\n const {\r\n width,\r\n autoRotate,\r\n data,\r\n enableZoom,\r\n categorical,\r\n colorDomain,\r\n colors,\r\n globeMaterial,\r\n height,\r\n polygonData,\r\n mapProperty,\r\n mapBorderColor,\r\n atmosphereColor,\r\n tooltip,\r\n styles,\r\n classNames,\r\n mapNoDataColor,\r\n colorLegendTitle,\r\n showColorScale,\r\n hoverStrokeColor,\r\n detailsOnClick,\r\n onSeriesMouseClick,\r\n onSeriesMouseOver,\r\n resetSelectionOnDoubleClick,\r\n highlightedIds,\r\n scale,\r\n globeOffset,\r\n polygonAltitude,\r\n centerLng,\r\n centerLat,\r\n atmosphereAltitude,\r\n globeCurvatureResolution,\r\n fogSettings,\r\n lights,\r\n highlightedAltitude,\r\n selectedId,\r\n collapseColorScaleByDefault,\r\n dimmedOpacity,\r\n numberDisplayOptions,\r\n } = props;\r\n const [globeReady, setGlobeReady] = useState(false);\r\n const globeEl = useRef<GlobeMethods | undefined>(undefined);\r\n const [mouseClickData, setMouseClickData] = useState<any>(undefined);\r\n\r\n const [showLegend, setShowLegend] = useState(\r\n collapseColorScaleByDefault === undefined ? !(width < 680) : !collapseColorScaleByDefault,\r\n );\r\n const [mousePos, setMousePos] = useState({ x: 0, y: 0 });\r\n const [mouseOverData, setMouseOverData] = useState<ChoroplethMapDataType | undefined>(undefined);\r\n const colorScale = categorical\r\n ? scaleOrdinal<number | string, string>().domain(colorDomain).range(colors)\r\n : scaleThreshold<number, string>()\r\n .domain(colorDomain as number[])\r\n .range(colors);\r\n useEffect(() => {\r\n if (globeEl.current) {\r\n globeEl.current.controls().enableZoom = enableZoom;\r\n }\r\n }, [enableZoom]);\r\n useEffect(() => {\r\n if (globeEl.current) {\r\n if (mouseOverData || selectedId) {\r\n globeEl.current.controls().autoRotate = false;\r\n } else {\r\n globeEl.current.controls().autoRotate = autoRotate === 0 ? false : true;\r\n globeEl.current.controls().autoRotateSpeed = autoRotate;\r\n }\r\n }\r\n }, [mouseOverData, selectedId, autoRotate]);\r\n useEffect(() => {\r\n if (globeEl.current && selectedId) {\r\n const selectedPolygon = polygonData.find(\r\n (d: any) => d.properties[mapProperty] === selectedId,\r\n );\r\n const [lng, lat] = getCentroidCoordinates(selectedPolygon);\r\n globeEl.current.pointOfView({ lat, lng, altitude: scale }, 1000);\r\n }\r\n }, [selectedId, scale, polygonData, mapProperty]);\r\n\r\n useEffect(() => {\r\n const canvas = globeEl.current?.renderer().domElement;\r\n if (!canvas) return;\r\n\r\n const handleMouseMove = (e: MouseEvent) => {\r\n setMousePos({ x: e.clientX, y: e.clientY });\r\n };\r\n\r\n canvas.addEventListener('mousemove', handleMouseMove);\r\n return () => canvas.removeEventListener('mousemove', handleMouseMove);\r\n }, []);\r\n\r\n useEffect(() => {\r\n if (globeEl.current) {\r\n globeEl.current.pointOfView({ lat: centerLat, lng: centerLng, altitude: scale }, 1000);\r\n }\r\n }, [scale, centerLng, centerLat]);\r\n const materials =\r\n globeMaterial ||\r\n new THREE.MeshBasicMaterial({\r\n color: '#FFF',\r\n });\r\n const setupCustomLighting = useCallback(() => {\r\n if (!globeEl.current) return;\r\n\r\n const scene = globeEl.current.scene();\r\n const camera = globeEl.current.camera();\r\n\r\n let lightsAndObjToRemove: THREE.Object3D[] = [];\r\n scene.traverse(obj => {\r\n if (obj instanceof THREE.Light) {\r\n lightsAndObjToRemove.push(obj);\r\n }\r\n });\r\n lightsAndObjToRemove = [...lightsAndObjToRemove, ...camera.children];\r\n lightsAndObjToRemove.forEach(light => light.parent?.remove(light));\r\n\r\n const lightConfig = lights.map(config => createLightFromConfig(config));\r\n lightConfig.forEach((light, i) => {\r\n if (lights[i].type !== 'ambient' && lights[i].position === 'camera') {\r\n camera.add(light);\r\n if (lights[i].type !== 'point') {\r\n camera.add((light as THREE.DirectionalLight | THREE.SpotLight).target);\r\n }\r\n } else {\r\n scene.add(light);\r\n }\r\n });\r\n\r\n if (fogSettings) {\r\n scene.fog = new THREE.Fog(fogSettings.color, fogSettings.near, fogSettings.far);\r\n }\r\n }, [lights, fogSettings]);\r\n\r\n const handleGlobeReady = () => {\r\n setGlobeReady(true);\r\n setupCustomLighting();\r\n };\r\n useEffect(() => {\r\n if (globeReady) {\r\n setupCustomLighting();\r\n }\r\n }, [globeReady, setupCustomLighting]);\r\n return (\r\n <div className='relative'>\r\n <Globe\r\n ref={globeEl}\r\n height={height}\r\n width={width}\r\n globeOffset={globeOffset}\r\n lineHoverPrecision={0}\r\n polygonsData={polygonData}\r\n polygonAltitude={(polygon: any) =>\r\n highlightedIds?.includes(polygon?.properties?.[mapProperty]) ||\r\n polygon?.properties?.[mapProperty] === selectedId\r\n ? highlightedAltitude\r\n : polygon?.properties?.[mapProperty] === mouseOverData?.id ||\r\n polygon?.properties?.[mapProperty] === mouseClickData?.id\r\n ? highlightedAltitude\r\n : polygonAltitude\r\n }\r\n polygonCapColor={(polygon: any) => {\r\n const opacity = selectedId\r\n ? polygon?.properties?.[mapProperty] === selectedId\r\n ? 1\r\n : dimmedOpacity\r\n : highlightedIds\r\n ? highlightedIds.includes(polygon?.properties?.[mapProperty])\r\n ? 1\r\n : dimmedOpacity\r\n : 1;\r\n const id = polygon?.properties?.[mapProperty];\r\n const val = data.find(el => el.id === id)?.x;\r\n const color = val !== undefined && val !== null ? colorScale(val as any) : mapNoDataColor;\r\n return hexToRgba(color, `${opacity}`);\r\n }}\r\n polygonSideColor={(polygon: any) => {\r\n const id = polygon?.properties?.[mapProperty];\r\n const val = data.find(el => el.id === id)?.x;\r\n const opacity = selectedId\r\n ? polygon?.properties?.[mapProperty] === selectedId\r\n ? 1\r\n : dimmedOpacity\r\n : highlightedIds\r\n ? highlightedIds.includes(polygon?.properties?.[mapProperty])\r\n ? 1\r\n : dimmedOpacity\r\n : 1;\r\n const color = val !== undefined && val !== null ? colorScale(val as any) : mapNoDataColor;\r\n return hexToRgba(color, `${opacity}`);\r\n }}\r\n polygonStrokeColor={(polygon: any) =>\r\n polygon?.properties?.[mapProperty] === mouseOverData?.id\r\n ? hoverStrokeColor\r\n : mapBorderColor\r\n }\r\n onGlobeClick={() => {\r\n setMouseClickData(undefined);\r\n }}\r\n onPolygonClick={(polygon: any) => {\r\n const clickedData = polygon?.properties?.[mapProperty]\r\n ? data.find(el => el.id === polygon?.properties?.[mapProperty])\r\n : undefined;\r\n if (onSeriesMouseClick || detailsOnClick) {\r\n if (\r\n isEqual(mouseClickData, clickedData) &&\r\n resetSelectionOnDoubleClick &&\r\n clickedData\r\n ) {\r\n setMouseClickData(undefined);\r\n onSeriesMouseClick?.(undefined);\r\n } else {\r\n setMouseClickData(clickedData);\r\n onSeriesMouseClick?.(clickedData);\r\n }\r\n }\r\n }}\r\n onPolygonHover={(polygon: any) => {\r\n const hoverData = polygon?.properties?.[mapProperty]\r\n ? data.find(el => el.id === polygon?.properties?.[mapProperty])\r\n : undefined;\r\n setMouseOverData(hoverData);\r\n onSeriesMouseOver?.(hoverData);\r\n }}\r\n atmosphereColor={atmosphereColor}\r\n atmosphereAltitude={atmosphereAltitude}\r\n globeCurvatureResolution={globeCurvatureResolution}\r\n globeMaterial={materials}\r\n backgroundColor='rgba(0, 0, 0, 0)'\r\n polygonsTransitionDuration={100}\r\n onGlobeReady={() => {\r\n if (globeEl.current) {\r\n globeEl.current.pointOfView({\r\n lat: centerLat,\r\n lng: centerLng,\r\n });\r\n const scene = globeEl.current.scene();\r\n setTimeout(() => {\r\n const polygons = scene.children[3]?.children[0]?.children[4]?.children || [];\r\n polygons.forEach(d => {\r\n const line = d.children[1];\r\n line.renderOrder = 2;\r\n });\r\n }, 300);\r\n const camera = globeEl.current.camera();\r\n scene.add(camera);\r\n handleGlobeReady();\r\n }\r\n }}\r\n />\r\n {showColorScale === false ? null : (\r\n <div className={cn('absolute left-4 bottom-4 map-color-legend', classNames?.colorLegend)}>\r\n {showLegend ? (\r\n <>\r\n <div\r\n 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]'\r\n onClick={() => {\r\n setShowLegend(false);\r\n }}\r\n >\r\n <X />\r\n </div>\r\n <div\r\n className='color-legend-box p-2 bg-[rgba(240,240,240,0.7)] dark:bg-[rgba(30,30,30,0.7)]'\r\n style={{\r\n width: categorical ? undefined : '340px',\r\n }}\r\n >\r\n {colorLegendTitle && colorLegendTitle !== '' ? (\r\n <P\r\n size='xs'\r\n marginBottom='xs'\r\n className='p-0 leading-normal overflow-hidden text-primary-gray-700 dark:text-primary-gray-300'\r\n style={{\r\n display: '-webkit-box',\r\n WebkitLineClamp: '1',\r\n WebkitBoxOrient: 'vertical',\r\n }}\r\n >\r\n {colorLegendTitle}\r\n </P>\r\n ) : null}\r\n {!categorical ? (\r\n <svg width='100%' viewBox='0 0 320 30' direction='ltr'>\r\n <g>\r\n {colorDomain.map((d, i) => (\r\n <g key={i} className='cursor-pointer'>\r\n <rect\r\n x={(i * 320) / colors.length + 1}\r\n y={1}\r\n width={320 / colors.length - 2}\r\n height={8}\r\n style={{\r\n fill: colors[i],\r\n stroke: colors[i],\r\n }}\r\n />\r\n <text\r\n x={((i + 1) * 320) / colors.length}\r\n y={25}\r\n className='fill-primary-gray-700 dark:fill-primary-gray-300 text-xs'\r\n style={{ textAnchor: 'middle' }}\r\n >\r\n {numberFormattingFunction(\r\n d as number,\r\n undefined,\r\n numberDisplayOptions?.precision ?? 2,\r\n undefined,\r\n undefined,\r\n numberDisplayOptions?.locale || 'en',\r\n numberDisplayOptions?.padZeros || false,\r\n )}\r\n </text>\r\n </g>\r\n ))}\r\n <g>\r\n <rect\r\n x={(colorDomain.length * 320) / colors.length + 1}\r\n y={1}\r\n width={320 / colors.length - 2}\r\n height={8}\r\n style={{\r\n fill: colors[colorDomain.length],\r\n stroke: colors[colorDomain.length],\r\n }}\r\n />\r\n </g>\r\n </g>\r\n </svg>\r\n ) : (\r\n <div className='flex flex-col gap-3'>\r\n {colorDomain.map((d, i) => (\r\n <div key={i} className='flex gap-2 items-center'>\r\n <div\r\n className='w-2 h-2 rounded-full'\r\n style={{ backgroundColor: colors[i % colors.length] }}\r\n />\r\n <P size='sm' marginBottom='none' leading='none'>\r\n {d}\r\n </P>\r\n </div>\r\n ))}\r\n </div>\r\n )}\r\n </div>\r\n </>\r\n ) : (\r\n <button\r\n type='button'\r\n className='p-1 border-0 rounded-[2px] text-primary-gray-700 bg-primary-gray-300 dark:bg-primary-gray-500 map-legend-button'\r\n onClick={() => {\r\n setShowLegend(true);\r\n }}\r\n >\r\n <ExpandIcon />\r\n </button>\r\n )}\r\n </div>\r\n )}\r\n {mouseOverData && tooltip ? (\r\n <Tooltip\r\n data={mouseOverData}\r\n body={tooltip}\r\n xPos={mousePos.x}\r\n yPos={mousePos.y}\r\n backgroundStyle={styles?.tooltip}\r\n className={classNames?.tooltip}\r\n />\r\n ) : null}\r\n {detailsOnClick && mouseClickData !== undefined ? (\r\n <DetailsModal\r\n body={detailsOnClick}\r\n data={mouseClickData}\r\n setData={setMouseClickData}\r\n className={classNames?.modal}\r\n />\r\n ) : null}\r\n </div>\r\n );\r\n}\r\n\r\nexport default Graph;\r\n","import React, { useEffect, useEffectEvent, useRef, useState } from 'react';\r\nimport { Spinner } from '@undp/design-system-react/Spinner';\r\nimport * as THREE from 'three';\r\n\r\nimport Graph from './Graph';\r\n\r\nimport { GraphHeader } from '@/Components/Elements/GraphHeader';\r\nimport { GraphFooter } from '@/Components/Elements/GraphFooter';\r\nimport {\r\n ChoroplethMapDataType,\r\n ClassNameObject,\r\n FogDataType,\r\n Languages,\r\n LightConfig,\r\n NumberFormatOptions,\r\n ScaleDataType,\r\n SourcesDataType,\r\n StyleObject,\r\n} from '@/Types';\r\nimport { fetchAndParseJSON } from '@/Utils/fetchAndParseData';\r\nimport { Colors } from '@/Components/ColorPalette';\r\nimport { getUniqValue } from '@/Utils/getUniqValue';\r\nimport { getJenks } from '@/Utils/getJenks';\r\nimport { GraphArea, GraphContainer } from '@/Components/Elements/GraphContainer';\r\n\r\ninterface Props {\r\n // Data\r\n /** Array of data objects */\r\n data: ChoroplethMapDataType[];\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 /** Colors for the choropleth map. Make sure the the colors are in hex code, any other format can cause issues. */\r\n colors?: string[];\r\n /** Domain of colors for the graph */\r\n colorDomain?: number[] | string[];\r\n /** Title for the color legend */\r\n colorLegendTitle?: string;\r\n /** Color for the areas where data is no available */\r\n mapNoDataColor?: 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\r\n // Graph Parameters\r\n /** Map data as an object in geoJson format or a url for geoJson */\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n mapData?: any;\r\n /** Stroke color of the regions in the map */\r\n mapBorderColor?: string;\r\n /** Center point of the map */\r\n centerPoint?: [number, number];\r\n /** Defines if the globe rotates automatically */\r\n autoRotate?: number | boolean;\r\n /** Defines the material property applied to the sphere of the globe */\r\n globeMaterial?: THREE.Material;\r\n /** Defines the lights for the 3D scene */\r\n lights?: LightConfig[];\r\n /** Defines the colo of the glow around the globe */\r\n atmosphereColor?: string;\r\n /** Defines if the globe can be zoomed when scrolled */\r\n enableZoom?: boolean;\r\n /** Position offset of the globe relative to the canvas center */\r\n globeOffset?: [number, number];\r\n /** Defines the camera distance from Earth. This helps in defining the default size of the globe. Smaller = closer camera therefore the globe is bigger) */\r\n scale?: number;\r\n /** Defines the spacing between the country shape polygon with the sphere */\r\n polygonAltitude?: number;\r\n /** Scale for the colors */\r\n scaleType?: Exclude<ScaleDataType, 'linear'>;\r\n /** Toggle visibility of color scale. */\r\n showColorScale?: boolean;\r\n /** Configuration options for controlling number formatting, localization, precision, and zero padding. */\r\n numberDisplayOptions?: Omit<NumberFormatOptions, 'suffix' | 'prefix'>;\r\n /** Toggle if color scale is collapsed by default. */\r\n collapseColorScaleByDefault?: boolean;\r\n /** The max altitude of the atmosphere, in terms of globe radius units. */\r\n atmosphereAltitude?: number;\r\n /** Resolution in angular degrees of the sphere curvature. The finer the resolution, the more the globe is fragmented into smaller faces to approximate the spheric surface, at the cost of performance. */\r\n globeCurvatureResolution?: number;\r\n /** Defines fog settings for the scene. */\r\n fogSettings?: FogDataType;\r\n /** Property in the property object in mapData geoJson object is used to match to the id in the data object */\r\n mapProperty?: string;\r\n /** Countries or regions to be highlighted */\r\n selectedId?: string;\r\n /** Countries or regions to be highlighted */\r\n highlightedIds?: string[];\r\n /** Defines the altitude of the highlighted countries or the countries on mouseover. */\r\n highlightedAltitude?: number;\r\n /** Defines the opacity of the non-highlighted data */\r\n dimmedOpacity?: number;\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\n/** For using these maps you will have to install [`three`](https://threejs.org/manual/) and [react-globe.gl](https://www.npmjs.com/package/react-globe.gl) package to your project */\r\nexport function ThreeDGlobe(props: Props) {\r\n const {\r\n data,\r\n mapData = 'https://raw.githubusercontent.com/UNDP-Data/dv-country-geojson/refs/heads/main/worldMap-simplified.json',\r\n graphTitle,\r\n colors,\r\n sources,\r\n graphDescription,\r\n height,\r\n width,\r\n footNote = '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.',\r\n colorDomain,\r\n colorLegendTitle,\r\n scaleType = 'threshold',\r\n padding,\r\n mapNoDataColor = Colors.light.graphNoData,\r\n backgroundColor = false,\r\n mapBorderColor = Colors.light.grays['gray-500'],\r\n relativeHeight,\r\n tooltip,\r\n graphID,\r\n mapProperty = 'ISO3',\r\n dataDownload = false,\r\n language = 'en',\r\n minHeight = 0,\r\n theme = 'light',\r\n ariaLabel,\r\n styles,\r\n classNames,\r\n autoRotate = true,\r\n enableZoom = true,\r\n globeMaterial,\r\n centerPoint = [0, 0],\r\n atmosphereColor = '#999',\r\n showColorScale = true,\r\n resetSelectionOnDoubleClick = true,\r\n detailsOnClick,\r\n onSeriesMouseOver,\r\n onSeriesMouseClick,\r\n highlightedIds,\r\n highlightedAltitude = 0.1,\r\n dimmedOpacity = 0.3,\r\n scale = 1,\r\n globeOffset = [0, 0],\r\n polygonAltitude = 0.01,\r\n globeCurvatureResolution = 4,\r\n atmosphereAltitude = 0.15,\r\n fogSettings,\r\n lights = [\r\n {\r\n type: 'ambient',\r\n color: 0x404040,\r\n intensity: 0.4,\r\n },\r\n {\r\n type: 'directional',\r\n color: 0xffffff,\r\n intensity: 1,\r\n position: { x: 5, y: 10, z: 5 },\r\n },\r\n ],\r\n selectedId,\r\n collapseColorScaleByDefault,\r\n numberDisplayOptions,\r\n } = props;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const [mapShape, setMapShape] = useState<any>(undefined);\r\n\r\n const [svgWidth, setSvgWidth] = useState(0);\r\n const [svgHeight, setSvgHeight] = useState(0);\r\n\r\n const graphDiv = useRef<HTMLDivElement>(null);\r\n const graphParentDiv = useRef<HTMLDivElement>(null);\r\n\r\n useEffect(() => {\r\n const resizeObserver = new ResizeObserver(entries => {\r\n setSvgWidth(entries[0].target.clientWidth || 620);\r\n setSvgHeight(entries[0].target.clientHeight || 480);\r\n });\r\n if (graphDiv.current) {\r\n resizeObserver.observe(graphDiv.current);\r\n }\r\n return () => resizeObserver.disconnect();\r\n }, []);\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const onUpdateShape = useEffectEvent((shape: any) => {\r\n setMapShape(shape);\r\n });\r\n useEffect(() => {\r\n if (typeof mapData === 'string') {\r\n const fetchData = fetchAndParseJSON(mapData);\r\n fetchData.then(d => {\r\n if (\r\n mapData ===\r\n 'https://raw.githubusercontent.com/UNDP-Data/dv-country-geojson/refs/heads/main/worldMap-simplified.json'\r\n ) {\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const features = d.features.map((el: any) => {\r\n if (el.geometry.type === 'Polygon') {\r\n const reversed = [...el.geometry.coordinates[0]].reverse();\r\n const geometry = { ...el.geometry, coordinates: [reversed] };\r\n return { ...el, geometry };\r\n }\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const coord: any = [];\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n el.geometry.coordinates.forEach((c: any) => {\r\n const reversed = [...c[0]].reverse();\r\n coord.push([reversed]);\r\n });\r\n const geometry = { ...el.geometry, coordinates: coord };\r\n return { ...el, geometry };\r\n });\r\n onUpdateShape(features);\r\n } else onUpdateShape(d.features);\r\n });\r\n } else {\r\n onUpdateShape(mapData.features);\r\n }\r\n }, [mapData]);\r\n\r\n const domain =\r\n colorDomain ||\r\n (scaleType === 'categorical'\r\n ? getUniqValue(data, 'x')\r\n : getJenks(\r\n data.map(d => d.x as number | null | undefined),\r\n colors?.length || 4,\r\n ));\r\n return (\r\n <GraphContainer\r\n className={classNames?.graphContainer}\r\n style={styles?.graphContainer}\r\n id={graphID}\r\n ref={graphParentDiv}\r\n aria-label={ariaLabel}\r\n backgroundColor={backgroundColor}\r\n theme={theme}\r\n language={language}\r\n minHeight={minHeight}\r\n width={width}\r\n height={height}\r\n relativeHeight={relativeHeight}\r\n padding={padding}\r\n >\r\n {graphTitle || graphDescription || 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={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 <GraphArea ref={graphDiv}>\r\n {svgWidth && svgHeight && mapShape ? (\r\n <Graph\r\n data={data}\r\n globeOffset={globeOffset}\r\n polygonData={mapShape}\r\n colorDomain={domain}\r\n width={svgWidth}\r\n height={svgHeight}\r\n colors={\r\n colors ||\r\n (scaleType === 'categorical'\r\n ? Colors[theme].sequentialColors[\r\n `neutralColorsx0${domain.length as 4 | 5 | 6 | 7 | 8 | 9}`\r\n ]\r\n : Colors[theme].sequentialColors[\r\n `neutralColorsx0${(domain.length + 1) as 4 | 5 | 6 | 7 | 8 | 9}`\r\n ])\r\n }\r\n mapNoDataColor={mapNoDataColor}\r\n categorical={scaleType === 'categorical'}\r\n mapBorderColor={mapBorderColor}\r\n tooltip={tooltip}\r\n mapProperty={mapProperty}\r\n styles={styles}\r\n classNames={classNames}\r\n autoRotate={autoRotate === true ? 1.5 : autoRotate === false ? 0 : autoRotate}\r\n enableZoom={enableZoom}\r\n globeMaterial={globeMaterial}\r\n atmosphereColor={atmosphereColor}\r\n colorLegendTitle={colorLegendTitle}\r\n showColorScale={showColorScale}\r\n hoverStrokeColor={\r\n theme === 'light' ? Colors.light.grays['gray-700'] : Colors.light.grays['gray-300']\r\n }\r\n highlightedIds={highlightedIds}\r\n resetSelectionOnDoubleClick={resetSelectionOnDoubleClick}\r\n detailsOnClick={detailsOnClick}\r\n onSeriesMouseOver={onSeriesMouseOver}\r\n onSeriesMouseClick={onSeriesMouseClick}\r\n scale={scale}\r\n polygonAltitude={polygonAltitude}\r\n centerLat={centerPoint[0]}\r\n centerLng={centerPoint[1]}\r\n atmosphereAltitude={atmosphereAltitude}\r\n globeCurvatureResolution={globeCurvatureResolution}\r\n fogSettings={fogSettings}\r\n lights={lights}\r\n highlightedAltitude={highlightedAltitude}\r\n selectedId={selectedId}\r\n collapseColorScaleByDefault={collapseColorScaleByDefault}\r\n dimmedOpacity={dimmedOpacity}\r\n numberDisplayOptions={numberDisplayOptions}\r\n />\r\n ) : (\r\n <div\r\n style={{\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 )}px`,\r\n }}\r\n className='flex items-center justify-center'\r\n >\r\n <Spinner aria-label='Loading graph' />\r\n </div>\r\n )}\r\n </GraphArea>\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 </GraphContainer>\r\n );\r\n}\r\n"],"names":["removeHash","hex","parseHex","nakedHex","isShort","twoDigitHexR","twoDigitHexG","twoDigitHexB","twoDigitHexA","hexToDecimal","hexesToDecimals","_ref","r","g","b","a","isNumeric","n","formatRgb","decimalObject","parameterA","parsedA","hexToRgba","hashlessHex","hexObject","build","createLightFromConfig","config","light","type","THREE","AmbientLight","color","intensity","DirectionalLight","position","set","x","y","z","target","undefined","castShadow","shadow","mapSize","width","height","camera","near","far","PointLight","distance","decay","SpotLight","angle","Math","PI","penumbra","Error","Graph","props","autoRotate","data","enableZoom","categorical","colorDomain","colors","globeMaterial","polygonData","mapProperty","mapBorderColor","atmosphereColor","tooltip","styles","classNames","mapNoDataColor","colorLegendTitle","showColorScale","hoverStrokeColor","detailsOnClick","onSeriesMouseClick","onSeriesMouseOver","resetSelectionOnDoubleClick","highlightedIds","scale","globeOffset","polygonAltitude","centerLng","centerLat","atmosphereAltitude","globeCurvatureResolution","fogSettings","lights","highlightedAltitude","selectedId","collapseColorScaleByDefault","dimmedOpacity","numberDisplayOptions","globeReady","setGlobeReady","useState","globeEl","useRef","mouseClickData","setMouseClickData","showLegend","setShowLegend","mousePos","setMousePos","mouseOverData","setMouseOverData","colorScale","scaleOrdinal","domain","range","scaleThreshold","useEffect","current","controls","autoRotateSpeed","selectedPolygon","find","d","properties","lng","lat","getCentroidCoordinates","pointOfView","altitude","canvas","renderer","domElement","handleMouseMove","e","clientX","clientY","addEventListener","removeEventListener","materials","MeshBasicMaterial","setupCustomLighting","useCallback","scene","lightsAndObjToRemove","traverse","obj","Light","push","children","forEach","parent","remove","map","i","add","fog","Fog","handleGlobeReady","jsxs","jsx","Globe","polygon","includes","id","opacity","val","el","clickedData","isEqual","hoverData","setTimeout","polygons","line","renderOrder","cn","colorLegend","Fragment","X","P","display","WebkitLineClamp","WebkitBoxOrient","backgroundColor","length","fill","stroke","textAnchor","numberFormattingFunction","precision","locale","padZeros","ExpandIcon","Tooltip","DetailsModal","modal","ThreeDGlobe","$","_c","mapData","t0","graphTitle","sources","graphDescription","footNote","t1","scaleType","t2","padding","t3","t4","t5","relativeHeight","graphID","t6","dataDownload","t7","language","t8","minHeight","t9","theme","t10","ariaLabel","t11","t12","centerPoint","t13","t14","t15","t16","t17","t18","t19","t20","t21","t22","t23","t24","Colors","graphNoData","grays","t25","t26","t27","mapShape","setMapShape","svgWidth","setSvgWidth","svgHeight","setSvgHeight","graphDiv","graphParentDiv","t28","t29","Symbol","for","resizeObserver","ResizeObserver","entries","clientWidth","clientHeight","observe","disconnect","t30","shape","onUpdateShape","useEffectEvent","t31","fetchAndParseJSON","then","features","_temp","t32","t33","getUniqValue","getJenks","_temp2","t34","graphContainer","t35","t36","description","title","GraphHeader","_temp3","filter","_temp4","_temp5","_temp6","_temp7","t37","GraphArea","sequentialColors","max","Spinner","t38","footnote","source","GraphFooter","t39","GraphContainer","d_3","d_2","d_1","d_5","d_4","d_0","geometry","reversed","coordinates","reverse","coord","c","reversed_0","geometry_0"],"mappings":"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","x_google_ignoreList":[0]}
|
|
1
|
+
{"version":3,"file":"ThreeDGlobe.js","sources":["../node_modules/hex-to-rgba/build/index.js","../src/Components/Graphs/Maps/ThreeDGlobe/Graph.tsx","../src/Components/Graphs/Maps/ThreeDGlobe/index.tsx"],"sourcesContent":["\"use strict\";\n\nvar removeHash = function removeHash(hex) {\n return hex.charAt(0) === '#' ? hex.slice(1) : hex;\n};\n\nvar parseHex = function parseHex(nakedHex) {\n var isShort = nakedHex.length === 3 || nakedHex.length === 4;\n var twoDigitHexR = isShort ? \"\".concat(nakedHex.slice(0, 1)).concat(nakedHex.slice(0, 1)) : nakedHex.slice(0, 2);\n var twoDigitHexG = isShort ? \"\".concat(nakedHex.slice(1, 2)).concat(nakedHex.slice(1, 2)) : nakedHex.slice(2, 4);\n var twoDigitHexB = isShort ? \"\".concat(nakedHex.slice(2, 3)).concat(nakedHex.slice(2, 3)) : nakedHex.slice(4, 6);\n var twoDigitHexA = (isShort ? \"\".concat(nakedHex.slice(3, 4)).concat(nakedHex.slice(3, 4)) : nakedHex.slice(6, 8)) || 'ff'; // const numericA = +((parseInt(a, 16) / 255).toFixed(2));\n\n return {\n r: twoDigitHexR,\n g: twoDigitHexG,\n b: twoDigitHexB,\n a: twoDigitHexA\n };\n};\n\nvar hexToDecimal = function hexToDecimal(hex) {\n return parseInt(hex, 16);\n};\n\nvar hexesToDecimals = function hexesToDecimals(_ref) {\n var r = _ref.r,\n g = _ref.g,\n b = _ref.b,\n a = _ref.a;\n return {\n r: hexToDecimal(r),\n g: hexToDecimal(g),\n b: hexToDecimal(b),\n a: +(hexToDecimal(a) / 255).toFixed(2)\n };\n};\n\nvar isNumeric = function isNumeric(n) {\n return !isNaN(parseFloat(n)) && isFinite(n);\n}; // eslint-disable-line no-restricted-globals, max-len\n\n\nvar formatRgb = function formatRgb(decimalObject, parameterA) {\n var r = decimalObject.r,\n g = decimalObject.g,\n b = decimalObject.b,\n parsedA = decimalObject.a;\n var a = isNumeric(parameterA) ? parameterA : parsedA;\n return \"rgba(\".concat(r, \", \").concat(g, \", \").concat(b, \", \").concat(a, \")\");\n};\n/**\n * Turns an old-fashioned css hex color value into a rgb color value.\n *\n * If you specify an alpha value, you'll get a rgba() value instead.\n *\n * @param The hex value to convert. ('123456'. '#123456', ''123', '#123')\n * @param An alpha value to apply. (optional) ('0.5', '0.25')\n * @return An rgb or rgba value. ('rgb(11, 22, 33)'. 'rgba(11, 22, 33, 0.5)')\n */\n\n\nvar hexToRgba = function hexToRgba(hex, a) {\n var hashlessHex = removeHash(hex);\n var hexObject = parseHex(hashlessHex);\n var decimalObject = hexesToDecimals(hexObject);\n return formatRgb(decimalObject, a);\n};\n\nmodule.exports = hexToRgba;","/* eslint-disable @typescript-eslint/no-explicit-any */\r\nimport Globe, { GlobeMethods } from 'react-globe.gl';\r\nimport isEqual from 'fast-deep-equal';\r\nimport { useCallback, useEffect, useRef, useState } from 'react';\r\nimport { scaleOrdinal, scaleThreshold } from 'd3-scale';\r\nimport * as THREE from 'three';\r\nimport { P } from '@undp/design-system-react/Typography';\r\nimport { cn } from '@undp/design-system-react/cn';\r\nimport hexToRgba from 'hex-to-rgba';\r\n\r\nimport {\r\n ChoroplethMapDataType,\r\n ClassNameObject,\r\n FogDataType,\r\n LightConfig,\r\n NumberFormatOptions,\r\n StyleObject,\r\n} from '@/Types';\r\nimport { Tooltip } from '@/Components/Elements/Tooltip';\r\nimport { numberFormattingFunction } from '@/Utils/numberFormattingFunction';\r\nimport { ExpandIcon, X } from '@/Components/Icons';\r\nimport { getCentroidCoordinates } from '@/Utils/getCentroidCoordinates';\r\nimport { DetailsModal } from '@/Components/Elements/DetailsModal';\r\n\r\ninterface Props {\r\n width: number;\r\n data: ChoroplethMapDataType[];\r\n autoRotate: number;\r\n enableZoom: boolean;\r\n categorical: boolean;\r\n colorDomain: (number | string)[];\r\n colors: string[];\r\n height: number;\r\n globeMaterial?: THREE.Material;\r\n lights: LightConfig[];\r\n polygonData: any;\r\n mapProperty: string;\r\n mapBorderColor: string;\r\n atmosphereColor: string;\r\n tooltip?: string | ((_d: any) => React.ReactNode);\r\n styles?: StyleObject;\r\n classNames?: ClassNameObject;\r\n onSeriesMouseOver?: (_d: any) => void;\r\n onSeriesMouseClick?: (_d: any) => void;\r\n mapNoDataColor: string;\r\n colorLegendTitle?: string;\r\n showColorScale: boolean;\r\n hoverStrokeColor: string;\r\n detailsOnClick?: string | ((_d: any) => React.ReactNode);\r\n resetSelectionOnDoubleClick: boolean;\r\n highlightedIds?: string[];\r\n scale: number;\r\n globeOffset: [number, number];\r\n polygonAltitude: number;\r\n centerLng: number;\r\n centerLat: number;\r\n atmosphereAltitude: number;\r\n globeCurvatureResolution: number;\r\n fogSettings?: FogDataType;\r\n highlightedAltitude: number;\r\n selectedId?: string;\r\n collapseColorScaleByDefault?: boolean;\r\n dimmedOpacity: number;\r\n numberDisplayOptions?: Omit<NumberFormatOptions, 'suffix' | 'prefix'>;\r\n}\r\n\r\nfunction createLightFromConfig(config: LightConfig): THREE.Light {\r\n let light: THREE.Light;\r\n\r\n switch (config.type) {\r\n case 'ambient':\r\n light = new THREE.AmbientLight(config.color, config.intensity);\r\n break;\r\n case 'directional':\r\n light = new THREE.DirectionalLight(config.color, config.intensity);\r\n if (config.position) {\r\n if (config.position === 'camera') light.position.set(0, 0, 0);\r\n else light.position.set(config.position.x, config.position.y, config.position.z);\r\n }\r\n if (config.target || config.position === 'camera') {\r\n (light as THREE.SpotLight).target.position.set(\r\n config.target?.x || 0,\r\n config.target?.y || 0,\r\n config.target?.z === undefined ? -1 : config.target.z,\r\n );\r\n }\r\n if (config.castShadow) {\r\n (light as THREE.DirectionalLight).castShadow = true;\r\n if (config.shadow) {\r\n (light as THREE.DirectionalLight).shadow.mapSize.width = config.shadow.mapSize.width;\r\n (light as THREE.DirectionalLight).shadow.mapSize.height = config.shadow.mapSize.height;\r\n (light as THREE.DirectionalLight).shadow.camera.near = config.shadow.camera.near;\r\n (light as THREE.DirectionalLight).shadow.camera.far = config.shadow.camera.far;\r\n }\r\n }\r\n break;\r\n case 'point':\r\n light = new THREE.PointLight(\r\n config.color,\r\n config.intensity,\r\n config.distance || 0,\r\n config.decay || 2,\r\n );\r\n if (config.position) {\r\n if (config.position === 'camera') light.position.set(0, 0, 0);\r\n else light.position.set(config.position.x, config.position.y, config.position.z);\r\n }\r\n break;\r\n case 'spot':\r\n light = new THREE.SpotLight(\r\n config.color,\r\n config.intensity,\r\n config.distance || 0,\r\n config.angle || Math.PI / 3,\r\n config.penumbra || 0,\r\n config.decay || 2,\r\n );\r\n if (config.position) {\r\n if (config.position === 'camera') light.position.set(0, 0, 0);\r\n else light.position.set(config.position.x, config.position.y, config.position.z);\r\n }\r\n if (config.target || config.position === 'camera') {\r\n (light as THREE.SpotLight).target.position.set(\r\n config.target?.x || 0,\r\n config.target?.y || 0,\r\n config.target?.z || 0,\r\n );\r\n }\r\n if (config.castShadow) {\r\n (light as THREE.SpotLight).castShadow = true;\r\n if (config.shadow) {\r\n (light as THREE.SpotLight).shadow.mapSize.width = config.shadow.mapSize.width;\r\n (light as THREE.SpotLight).shadow.mapSize.height = config.shadow.mapSize.height;\r\n (light as THREE.SpotLight).shadow.camera.near = config.shadow.camera.near;\r\n (light as THREE.SpotLight).shadow.camera.far = config.shadow.camera.far;\r\n }\r\n }\r\n break;\r\n default:\r\n throw new Error('Unknown light type');\r\n }\r\n\r\n return light;\r\n}\r\nfunction Graph(props: Props) {\r\n const {\r\n width,\r\n autoRotate,\r\n data,\r\n enableZoom,\r\n categorical,\r\n colorDomain,\r\n colors,\r\n globeMaterial,\r\n height,\r\n polygonData,\r\n mapProperty,\r\n mapBorderColor,\r\n atmosphereColor,\r\n tooltip,\r\n styles,\r\n classNames,\r\n mapNoDataColor,\r\n colorLegendTitle,\r\n showColorScale,\r\n hoverStrokeColor,\r\n detailsOnClick,\r\n onSeriesMouseClick,\r\n onSeriesMouseOver,\r\n resetSelectionOnDoubleClick,\r\n highlightedIds,\r\n scale,\r\n globeOffset,\r\n polygonAltitude,\r\n centerLng,\r\n centerLat,\r\n atmosphereAltitude,\r\n globeCurvatureResolution,\r\n fogSettings,\r\n lights,\r\n highlightedAltitude,\r\n selectedId,\r\n collapseColorScaleByDefault,\r\n dimmedOpacity,\r\n numberDisplayOptions,\r\n } = props;\r\n const [globeReady, setGlobeReady] = useState(false);\r\n const globeEl = useRef<GlobeMethods | undefined>(undefined);\r\n const [mouseClickData, setMouseClickData] = useState<any>(undefined);\r\n\r\n const [showLegend, setShowLegend] = useState(\r\n collapseColorScaleByDefault === undefined ? !(width < 680) : !collapseColorScaleByDefault,\r\n );\r\n const [mousePos, setMousePos] = useState({ x: 0, y: 0 });\r\n const [mouseOverData, setMouseOverData] = useState<ChoroplethMapDataType | undefined>(undefined);\r\n const colorScale = categorical\r\n ? scaleOrdinal<number | string, string>().domain(colorDomain).range(colors)\r\n : scaleThreshold<number, string>()\r\n .domain(colorDomain as number[])\r\n .range(colors);\r\n useEffect(() => {\r\n if (globeEl.current) {\r\n globeEl.current.controls().enableZoom = enableZoom;\r\n }\r\n }, [enableZoom]);\r\n useEffect(() => {\r\n if (globeEl.current) {\r\n if (mouseOverData || selectedId) {\r\n globeEl.current.controls().autoRotate = false;\r\n } else {\r\n globeEl.current.controls().autoRotate = autoRotate === 0 ? false : true;\r\n globeEl.current.controls().autoRotateSpeed = autoRotate;\r\n }\r\n }\r\n }, [mouseOverData, selectedId, autoRotate]);\r\n useEffect(() => {\r\n if (globeEl.current && selectedId) {\r\n const selectedPolygon = polygonData.find(\r\n (d: any) => d.properties[mapProperty] === selectedId,\r\n );\r\n const [lng, lat] = getCentroidCoordinates(selectedPolygon);\r\n globeEl.current.pointOfView({ lat, lng, altitude: scale }, 1000);\r\n }\r\n }, [selectedId, scale, polygonData, mapProperty]);\r\n\r\n useEffect(() => {\r\n const canvas = globeEl.current?.renderer().domElement;\r\n if (!canvas) return;\r\n\r\n const handleMouseMove = (e: MouseEvent) => {\r\n setMousePos({ x: e.clientX, y: e.clientY });\r\n };\r\n\r\n canvas.addEventListener('mousemove', handleMouseMove);\r\n return () => canvas.removeEventListener('mousemove', handleMouseMove);\r\n }, []);\r\n\r\n useEffect(() => {\r\n if (globeEl.current) {\r\n globeEl.current.pointOfView({ lat: centerLat, lng: centerLng, altitude: scale }, 1000);\r\n }\r\n }, [scale, centerLng, centerLat]);\r\n const materials =\r\n globeMaterial ||\r\n new THREE.MeshBasicMaterial({\r\n color: '#FFF',\r\n });\r\n const setupCustomLighting = useCallback(() => {\r\n if (!globeEl.current) return;\r\n\r\n const scene = globeEl.current.scene();\r\n const camera = globeEl.current.camera();\r\n\r\n let lightsAndObjToRemove: THREE.Object3D[] = [];\r\n scene.traverse(obj => {\r\n if (obj instanceof THREE.Light) {\r\n lightsAndObjToRemove.push(obj);\r\n }\r\n });\r\n lightsAndObjToRemove = [...lightsAndObjToRemove, ...camera.children];\r\n lightsAndObjToRemove.forEach(light => light.parent?.remove(light));\r\n\r\n const lightConfig = lights.map(config => createLightFromConfig(config));\r\n lightConfig.forEach((light, i) => {\r\n if (lights[i].type !== 'ambient' && lights[i].position === 'camera') {\r\n camera.add(light);\r\n if (lights[i].type !== 'point') {\r\n camera.add((light as THREE.DirectionalLight | THREE.SpotLight).target);\r\n }\r\n } else {\r\n scene.add(light);\r\n }\r\n });\r\n\r\n if (fogSettings) {\r\n scene.fog = new THREE.Fog(fogSettings.color, fogSettings.near, fogSettings.far);\r\n }\r\n }, [lights, fogSettings]);\r\n\r\n const handleGlobeReady = () => {\r\n setGlobeReady(true);\r\n setupCustomLighting();\r\n };\r\n useEffect(() => {\r\n if (globeReady) {\r\n setupCustomLighting();\r\n }\r\n }, [globeReady, setupCustomLighting]);\r\n return (\r\n <div className='relative'>\r\n <Globe\r\n ref={globeEl}\r\n height={height}\r\n width={width}\r\n globeOffset={globeOffset}\r\n lineHoverPrecision={0}\r\n polygonsData={polygonData}\r\n polygonAltitude={(polygon: any) =>\r\n highlightedIds?.includes(polygon?.properties?.[mapProperty]) ||\r\n polygon?.properties?.[mapProperty] === selectedId\r\n ? highlightedAltitude\r\n : polygon?.properties?.[mapProperty] === mouseOverData?.id ||\r\n polygon?.properties?.[mapProperty] === mouseClickData?.id\r\n ? highlightedAltitude\r\n : polygonAltitude\r\n }\r\n polygonCapColor={(polygon: any) => {\r\n const opacity = selectedId\r\n ? polygon?.properties?.[mapProperty] === selectedId\r\n ? 1\r\n : dimmedOpacity\r\n : highlightedIds\r\n ? highlightedIds.includes(polygon?.properties?.[mapProperty])\r\n ? 1\r\n : dimmedOpacity\r\n : 1;\r\n const id = polygon?.properties?.[mapProperty];\r\n const val = data.find(el => el.id === id)?.x;\r\n const color = val !== undefined && val !== null ? colorScale(val as any) : mapNoDataColor;\r\n return hexToRgba(color, `${opacity}`);\r\n }}\r\n polygonSideColor={(polygon: any) => {\r\n const id = polygon?.properties?.[mapProperty];\r\n const val = data.find(el => el.id === id)?.x;\r\n const opacity = selectedId\r\n ? polygon?.properties?.[mapProperty] === selectedId\r\n ? 1\r\n : dimmedOpacity\r\n : highlightedIds\r\n ? highlightedIds.includes(polygon?.properties?.[mapProperty])\r\n ? 1\r\n : dimmedOpacity\r\n : 1;\r\n const color = val !== undefined && val !== null ? colorScale(val as any) : mapNoDataColor;\r\n return hexToRgba(color, `${opacity}`);\r\n }}\r\n polygonStrokeColor={(polygon: any) =>\r\n polygon?.properties?.[mapProperty] === mouseOverData?.id\r\n ? hoverStrokeColor\r\n : mapBorderColor\r\n }\r\n onGlobeClick={() => {\r\n setMouseClickData(undefined);\r\n }}\r\n onPolygonClick={(polygon: any) => {\r\n const clickedData = polygon?.properties?.[mapProperty]\r\n ? data.find(el => el.id === polygon?.properties?.[mapProperty])\r\n : undefined;\r\n if (onSeriesMouseClick || detailsOnClick) {\r\n if (\r\n isEqual(mouseClickData, clickedData) &&\r\n resetSelectionOnDoubleClick &&\r\n clickedData\r\n ) {\r\n setMouseClickData(undefined);\r\n onSeriesMouseClick?.(undefined);\r\n } else {\r\n setMouseClickData(clickedData);\r\n onSeriesMouseClick?.(clickedData);\r\n }\r\n }\r\n }}\r\n onPolygonHover={(polygon: any) => {\r\n const hoverData = polygon?.properties?.[mapProperty]\r\n ? data.find(el => el.id === polygon?.properties?.[mapProperty])\r\n : undefined;\r\n setMouseOverData(hoverData);\r\n onSeriesMouseOver?.(hoverData);\r\n }}\r\n atmosphereColor={atmosphereColor}\r\n atmosphereAltitude={atmosphereAltitude}\r\n globeCurvatureResolution={globeCurvatureResolution}\r\n globeMaterial={materials}\r\n backgroundColor='rgba(0, 0, 0, 0)'\r\n polygonsTransitionDuration={100}\r\n onGlobeReady={() => {\r\n if (globeEl.current) {\r\n globeEl.current.pointOfView({\r\n lat: centerLat,\r\n lng: centerLng,\r\n });\r\n const scene = globeEl.current.scene();\r\n setTimeout(() => {\r\n const polygons = scene.children[3]?.children[0]?.children[4]?.children || [];\r\n polygons.forEach(d => {\r\n const line = d.children[1];\r\n line.renderOrder = 2;\r\n });\r\n }, 300);\r\n const camera = globeEl.current.camera();\r\n scene.add(camera);\r\n handleGlobeReady();\r\n }\r\n }}\r\n />\r\n {showColorScale === false ? null : (\r\n <div className={cn('absolute left-4 bottom-4 map-color-legend', classNames?.colorLegend)}>\r\n {showLegend ? (\r\n <>\r\n <div\r\n 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]'\r\n onClick={() => {\r\n setShowLegend(false);\r\n }}\r\n >\r\n <X />\r\n </div>\r\n <div\r\n className='color-legend-box p-2 bg-[rgba(240,240,240,0.7)] dark:bg-[rgba(30,30,30,0.7)]'\r\n style={{\r\n width: categorical ? undefined : '340px',\r\n }}\r\n >\r\n {colorLegendTitle && colorLegendTitle !== '' ? (\r\n <P\r\n size='xs'\r\n marginBottom='xs'\r\n className='p-0 leading-normal overflow-hidden text-primary-gray-700 dark:text-primary-gray-300'\r\n style={{\r\n display: '-webkit-box',\r\n WebkitLineClamp: '1',\r\n WebkitBoxOrient: 'vertical',\r\n }}\r\n >\r\n {colorLegendTitle}\r\n </P>\r\n ) : null}\r\n {!categorical ? (\r\n <svg width='100%' viewBox='0 0 320 30' direction='ltr'>\r\n <g>\r\n {colorDomain.map((d, i) => (\r\n <g key={i} className='cursor-pointer'>\r\n <rect\r\n x={(i * 320) / colors.length + 1}\r\n y={1}\r\n width={320 / colors.length - 2}\r\n height={8}\r\n style={{\r\n fill: colors[i],\r\n stroke: colors[i],\r\n }}\r\n />\r\n <text\r\n x={((i + 1) * 320) / colors.length}\r\n y={25}\r\n className='fill-primary-gray-700 dark:fill-primary-gray-300 text-xs'\r\n style={{ textAnchor: 'middle' }}\r\n >\r\n {numberFormattingFunction(\r\n d as number,\r\n undefined,\r\n numberDisplayOptions?.precision ?? 2,\r\n undefined,\r\n undefined,\r\n numberDisplayOptions?.locale || 'en',\r\n numberDisplayOptions?.padZeros || false,\r\n )}\r\n </text>\r\n </g>\r\n ))}\r\n <g>\r\n <rect\r\n x={(colorDomain.length * 320) / colors.length + 1}\r\n y={1}\r\n width={320 / colors.length - 2}\r\n height={8}\r\n style={{\r\n fill: colors[colorDomain.length],\r\n stroke: colors[colorDomain.length],\r\n }}\r\n />\r\n </g>\r\n </g>\r\n </svg>\r\n ) : (\r\n <div className='flex flex-col gap-3'>\r\n {colorDomain.map((d, i) => (\r\n <div key={i} className='flex gap-2 items-center'>\r\n <div\r\n className='w-2 h-2 rounded-full'\r\n style={{ backgroundColor: colors[i % colors.length] }}\r\n />\r\n <P size='sm' marginBottom='none' leading='none'>\r\n {d}\r\n </P>\r\n </div>\r\n ))}\r\n </div>\r\n )}\r\n </div>\r\n </>\r\n ) : (\r\n <button\r\n type='button'\r\n className='p-1 border-0 rounded-[2px] text-primary-gray-700 bg-primary-gray-300 dark:bg-primary-gray-500 map-legend-button'\r\n onClick={() => {\r\n setShowLegend(true);\r\n }}\r\n >\r\n <ExpandIcon />\r\n </button>\r\n )}\r\n </div>\r\n )}\r\n {mouseOverData && tooltip ? (\r\n <Tooltip\r\n data={mouseOverData}\r\n body={tooltip}\r\n xPos={mousePos.x}\r\n yPos={mousePos.y}\r\n backgroundStyle={styles?.tooltip}\r\n className={classNames?.tooltip}\r\n />\r\n ) : null}\r\n {detailsOnClick && mouseClickData !== undefined ? (\r\n <DetailsModal\r\n body={detailsOnClick}\r\n data={mouseClickData}\r\n setData={setMouseClickData}\r\n className={classNames?.modal}\r\n />\r\n ) : null}\r\n </div>\r\n );\r\n}\r\n\r\nexport default Graph;\r\n","import React, { useEffect, useEffectEvent, useRef, useState } from 'react';\r\nimport { Spinner } from '@undp/design-system-react/Spinner';\r\nimport * as THREE from 'three';\r\n\r\nimport Graph from './Graph';\r\n\r\nimport { GraphHeader } from '@/Components/Elements/GraphHeader';\r\nimport { GraphFooter } from '@/Components/Elements/GraphFooter';\r\nimport {\r\n ChoroplethMapDataType,\r\n ClassNameObject,\r\n FogDataType,\r\n Languages,\r\n LightConfig,\r\n NumberFormatOptions,\r\n ScaleDataType,\r\n SourcesDataType,\r\n StyleObject,\r\n} from '@/Types';\r\nimport { fetchAndParseJSON } from '@/Utils/fetchAndParseData';\r\nimport { Colors } from '@/Components/ColorPalette';\r\nimport { getUniqValue } from '@/Utils/getUniqValue';\r\nimport { getJenks } from '@/Utils/getJenks';\r\nimport { GraphArea, GraphContainer } from '@/Components/Elements/GraphContainer';\r\n\r\ninterface Props {\r\n // Data\r\n /** Array of data objects */\r\n data: ChoroplethMapDataType[];\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 /** Colors for the choropleth map. Make sure the the colors are in hex code, any other format can cause issues. */\r\n colors?: string[];\r\n /** Domain of colors for the graph */\r\n colorDomain?: number[] | string[];\r\n /** Title for the color legend */\r\n colorLegendTitle?: string;\r\n /** Color for the areas where data is no available */\r\n mapNoDataColor?: 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\r\n // Graph Parameters\r\n /** Map data as an object in geoJson format or a url for geoJson */\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n mapData?: any;\r\n /** Stroke color of the regions in the map */\r\n mapBorderColor?: string;\r\n /** Center point of the map */\r\n centerPoint?: [number, number];\r\n /** Defines if the globe rotates automatically */\r\n autoRotate?: number | boolean;\r\n /** Defines the material property applied to the sphere of the globe */\r\n globeMaterial?: THREE.Material;\r\n /** Defines the lights for the 3D scene */\r\n lights?: LightConfig[];\r\n /** Defines the colo of the glow around the globe */\r\n atmosphereColor?: string;\r\n /** Defines if the globe can be zoomed when scrolled */\r\n enableZoom?: boolean;\r\n /** Position offset of the globe relative to the canvas center */\r\n globeOffset?: [number, number];\r\n /** Defines the camera distance from Earth. This helps in defining the default size of the globe. Smaller = closer camera therefore the globe is bigger) */\r\n scale?: number;\r\n /** Defines the spacing between the country shape polygon with the sphere */\r\n polygonAltitude?: number;\r\n /** Scale for the colors */\r\n scaleType?: Exclude<ScaleDataType, 'linear'>;\r\n /** Toggle visibility of color scale. */\r\n showColorScale?: boolean;\r\n /** Configuration options for controlling number formatting, localization, precision, and zero padding. */\r\n numberDisplayOptions?: Omit<NumberFormatOptions, 'suffix' | 'prefix'>;\r\n /** Toggle if color scale is collapsed by default. */\r\n collapseColorScaleByDefault?: boolean;\r\n /** The max altitude of the atmosphere, in terms of globe radius units. */\r\n atmosphereAltitude?: number;\r\n /** Resolution in angular degrees of the sphere curvature. The finer the resolution, the more the globe is fragmented into smaller faces to approximate the spheric surface, at the cost of performance. */\r\n globeCurvatureResolution?: number;\r\n /** Defines fog settings for the scene. */\r\n fogSettings?: FogDataType;\r\n /** Property in the property object in mapData geoJson object is used to match to the id in the data object */\r\n mapProperty?: string;\r\n /** Countries or regions to be highlighted */\r\n selectedId?: string;\r\n /** Countries or regions to be highlighted */\r\n highlightedIds?: string[];\r\n /** Defines the altitude of the highlighted countries or the countries on mouseover. */\r\n highlightedAltitude?: number;\r\n /** Defines the opacity of the non-highlighted data */\r\n dimmedOpacity?: number;\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\n/** For using these maps you will have to install [`three`](https://threejs.org/manual/) and [react-globe.gl](https://www.npmjs.com/package/react-globe.gl) package to your project */\r\nexport function ThreeDGlobe(props: Props) {\r\n const {\r\n data,\r\n mapData = 'https://raw.githubusercontent.com/UNDP-Data/dv-country-geojson/refs/heads/main/worldMap-simplified.json',\r\n graphTitle,\r\n colors,\r\n sources,\r\n graphDescription,\r\n height,\r\n width,\r\n footNote = '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.',\r\n colorDomain,\r\n colorLegendTitle,\r\n scaleType = 'threshold',\r\n padding,\r\n mapNoDataColor = Colors.light.graphNoData,\r\n backgroundColor = false,\r\n mapBorderColor = Colors.light.grays['gray-500'],\r\n relativeHeight,\r\n tooltip,\r\n graphID,\r\n mapProperty = 'ISO3',\r\n dataDownload = false,\r\n language = 'en',\r\n minHeight = 0,\r\n theme = 'light',\r\n ariaLabel,\r\n styles,\r\n classNames,\r\n autoRotate = true,\r\n enableZoom = true,\r\n globeMaterial,\r\n centerPoint = [0, 0],\r\n atmosphereColor = '#999',\r\n showColorScale = true,\r\n resetSelectionOnDoubleClick = true,\r\n detailsOnClick,\r\n onSeriesMouseOver,\r\n onSeriesMouseClick,\r\n highlightedIds,\r\n highlightedAltitude = 0.1,\r\n dimmedOpacity = 0.3,\r\n scale = 1,\r\n globeOffset = [0, 0],\r\n polygonAltitude = 0.01,\r\n globeCurvatureResolution = 4,\r\n atmosphereAltitude = 0.15,\r\n fogSettings,\r\n lights = [\r\n {\r\n type: 'ambient',\r\n color: 0x404040,\r\n intensity: 0.4,\r\n },\r\n {\r\n type: 'directional',\r\n color: 0xffffff,\r\n intensity: 1,\r\n position: { x: 5, y: 10, z: 5 },\r\n },\r\n ],\r\n selectedId,\r\n collapseColorScaleByDefault,\r\n numberDisplayOptions,\r\n } = props;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const [mapShape, setMapShape] = useState<any>(undefined);\r\n\r\n const [svgWidth, setSvgWidth] = useState(0);\r\n const [svgHeight, setSvgHeight] = useState(0);\r\n\r\n const graphDiv = useRef<HTMLDivElement>(null);\r\n const graphParentDiv = useRef<HTMLDivElement>(null);\r\n\r\n useEffect(() => {\r\n const resizeObserver = new ResizeObserver(entries => {\r\n setSvgWidth(entries[0].target.clientWidth || 620);\r\n setSvgHeight(entries[0].target.clientHeight || 480);\r\n });\r\n if (graphDiv.current) {\r\n resizeObserver.observe(graphDiv.current);\r\n }\r\n return () => resizeObserver.disconnect();\r\n }, []);\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const onUpdateShape = useEffectEvent((shape: any) => {\r\n setMapShape(shape);\r\n });\r\n useEffect(() => {\r\n if (typeof mapData === 'string') {\r\n const fetchData = fetchAndParseJSON(mapData);\r\n fetchData.then(d => {\r\n if (\r\n mapData ===\r\n 'https://raw.githubusercontent.com/UNDP-Data/dv-country-geojson/refs/heads/main/worldMap-simplified.json'\r\n ) {\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const features = d.features.map((el: any) => {\r\n if (el.geometry.type === 'Polygon') {\r\n const reversed = [...el.geometry.coordinates[0]].reverse();\r\n const geometry = { ...el.geometry, coordinates: [reversed] };\r\n return { ...el, geometry };\r\n }\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const coord: any = [];\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n el.geometry.coordinates.forEach((c: any) => {\r\n const reversed = [...c[0]].reverse();\r\n coord.push([reversed]);\r\n });\r\n const geometry = { ...el.geometry, coordinates: coord };\r\n return { ...el, geometry };\r\n });\r\n onUpdateShape(features);\r\n } else onUpdateShape(d.features);\r\n });\r\n } else {\r\n onUpdateShape(mapData.features);\r\n }\r\n }, [mapData]);\r\n\r\n const domain =\r\n colorDomain ||\r\n (scaleType === 'categorical'\r\n ? getUniqValue(data, 'x')\r\n : getJenks(\r\n data.map(d => d.x as number | null | undefined),\r\n colors?.length || 4,\r\n ));\r\n return (\r\n <GraphContainer\r\n className={classNames?.graphContainer}\r\n style={styles?.graphContainer}\r\n id={graphID}\r\n ref={graphParentDiv}\r\n aria-label={ariaLabel}\r\n backgroundColor={backgroundColor}\r\n theme={theme}\r\n language={language}\r\n minHeight={minHeight}\r\n width={width}\r\n height={height}\r\n relativeHeight={relativeHeight}\r\n padding={padding}\r\n >\r\n {graphTitle || graphDescription || 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={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 <GraphArea ref={graphDiv}>\r\n {svgWidth && svgHeight && mapShape ? (\r\n <Graph\r\n data={data}\r\n globeOffset={globeOffset}\r\n polygonData={mapShape}\r\n colorDomain={domain}\r\n width={svgWidth}\r\n height={svgHeight}\r\n colors={\r\n colors ||\r\n (scaleType === 'categorical'\r\n ? Colors[theme].sequentialColors[\r\n `neutralColorsx0${domain.length as 4 | 5 | 6 | 7 | 8 | 9}`\r\n ]\r\n : Colors[theme].sequentialColors[\r\n `neutralColorsx0${(domain.length + 1) as 4 | 5 | 6 | 7 | 8 | 9}`\r\n ])\r\n }\r\n mapNoDataColor={mapNoDataColor}\r\n categorical={scaleType === 'categorical'}\r\n mapBorderColor={mapBorderColor}\r\n tooltip={tooltip}\r\n mapProperty={mapProperty}\r\n styles={styles}\r\n classNames={classNames}\r\n autoRotate={autoRotate === true ? 1.5 : autoRotate === false ? 0 : autoRotate}\r\n enableZoom={enableZoom}\r\n globeMaterial={globeMaterial}\r\n atmosphereColor={atmosphereColor}\r\n colorLegendTitle={colorLegendTitle}\r\n showColorScale={showColorScale}\r\n hoverStrokeColor={\r\n theme === 'light' ? Colors.light.grays['gray-700'] : Colors.light.grays['gray-300']\r\n }\r\n highlightedIds={highlightedIds}\r\n resetSelectionOnDoubleClick={resetSelectionOnDoubleClick}\r\n detailsOnClick={detailsOnClick}\r\n onSeriesMouseOver={onSeriesMouseOver}\r\n onSeriesMouseClick={onSeriesMouseClick}\r\n scale={scale}\r\n polygonAltitude={polygonAltitude}\r\n centerLat={centerPoint[0]}\r\n centerLng={centerPoint[1]}\r\n atmosphereAltitude={atmosphereAltitude}\r\n globeCurvatureResolution={globeCurvatureResolution}\r\n fogSettings={fogSettings}\r\n lights={lights}\r\n highlightedAltitude={highlightedAltitude}\r\n selectedId={selectedId}\r\n collapseColorScaleByDefault={collapseColorScaleByDefault}\r\n dimmedOpacity={dimmedOpacity}\r\n numberDisplayOptions={numberDisplayOptions}\r\n />\r\n ) : (\r\n <div\r\n style={{\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 )}px`,\r\n }}\r\n className='flex items-center justify-center'\r\n >\r\n <Spinner aria-label='Loading graph' />\r\n </div>\r\n )}\r\n </GraphArea>\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 </GraphContainer>\r\n );\r\n}\r\n"],"names":["removeHash","hex","parseHex","nakedHex","isShort","twoDigitHexR","twoDigitHexG","twoDigitHexB","twoDigitHexA","hexToDecimal","hexesToDecimals","_ref","r","g","b","a","isNumeric","n","formatRgb","decimalObject","parameterA","parsedA","hexToRgba","hashlessHex","hexObject","build","createLightFromConfig","config","light","type","THREE","AmbientLight","color","intensity","DirectionalLight","position","set","x","y","z","target","undefined","castShadow","shadow","mapSize","width","height","camera","near","far","PointLight","distance","decay","SpotLight","angle","Math","PI","penumbra","Error","Graph","props","autoRotate","data","enableZoom","categorical","colorDomain","colors","globeMaterial","polygonData","mapProperty","mapBorderColor","atmosphereColor","tooltip","styles","classNames","mapNoDataColor","colorLegendTitle","showColorScale","hoverStrokeColor","detailsOnClick","onSeriesMouseClick","onSeriesMouseOver","resetSelectionOnDoubleClick","highlightedIds","scale","globeOffset","polygonAltitude","centerLng","centerLat","atmosphereAltitude","globeCurvatureResolution","fogSettings","lights","highlightedAltitude","selectedId","collapseColorScaleByDefault","dimmedOpacity","numberDisplayOptions","globeReady","setGlobeReady","useState","globeEl","useRef","mouseClickData","setMouseClickData","showLegend","setShowLegend","mousePos","setMousePos","mouseOverData","setMouseOverData","colorScale","scaleOrdinal","domain","range","scaleThreshold","useEffect","current","controls","autoRotateSpeed","selectedPolygon","find","d","properties","lng","lat","getCentroidCoordinates","pointOfView","altitude","canvas","renderer","domElement","handleMouseMove","e","clientX","clientY","addEventListener","removeEventListener","materials","MeshBasicMaterial","setupCustomLighting","useCallback","scene","lightsAndObjToRemove","traverse","obj","Light","push","children","forEach","parent","remove","map","i","add","fog","Fog","handleGlobeReady","jsxs","jsx","Globe","polygon","includes","id","opacity","val","el","clickedData","isEqual","hoverData","setTimeout","polygons","line","renderOrder","cn","colorLegend","Fragment","X","P","display","WebkitLineClamp","WebkitBoxOrient","backgroundColor","length","fill","stroke","textAnchor","numberFormattingFunction","precision","locale","padZeros","ExpandIcon","Tooltip","DetailsModal","modal","ThreeDGlobe","$","_c","mapData","t0","graphTitle","sources","graphDescription","footNote","t1","scaleType","t2","padding","t3","t4","t5","relativeHeight","graphID","t6","dataDownload","t7","language","t8","minHeight","t9","theme","t10","ariaLabel","t11","t12","centerPoint","t13","t14","t15","t16","t17","t18","t19","t20","t21","t22","t23","t24","Colors","graphNoData","grays","t25","t26","t27","mapShape","setMapShape","svgWidth","setSvgWidth","svgHeight","setSvgHeight","graphDiv","graphParentDiv","t28","t29","Symbol","for","resizeObserver","ResizeObserver","entries","clientWidth","clientHeight","observe","disconnect","t30","shape","onUpdateShape","useEffectEvent","t31","fetchAndParseJSON","then","features","_temp","t32","t33","getUniqValue","getJenks","_temp2","t34","graphContainer","t35","t36","description","title","GraphHeader","_temp3","filter","_temp4","_temp5","_temp6","_temp7","t37","GraphArea","sequentialColors","max","Spinner","t38","footnote","source","GraphFooter","t39","GraphContainer","d_3","d_2","d_1","d_5","d_4","d_0","geometry","reversed","coordinates","reverse","coord","c","reversed_0","geometry_0"],"mappings":"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","x_google_ignoreList":[0]}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const o=require("./
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const o=require("./compiler-runtime-oPPev21o.cjs"),B=require("react"),P=require("@undp/design-system-react/cn"),_=require("@undp/design-system-react/Typography"),z=require("./numberFormattingFunction-u2iNHL_c.cjs");function H(A){const e=o.compilerRuntimeExports.c(55),{colorLegendTitle:k,colorDomain:r,colors:t,setSelectedColor:s,width:S,naColor:i,className:w,showNAColor:C,locale:T,naLabel:$}=A,R=T===void 0?"en":T,M=$===void 0?"NA":$,[l,c]=B.useState(void 0),n=i?320:360;let x;e[0]!==w?(x=P.cn("flex flex-wrap gap-0 justify-center leading-0",w),e[0]=w,e[1]=x):x=e[1];const b=S?`${S}px`:"none";let m;e[2]!==b?(m={maxWidth:b},e[2]=b,e[3]=m):m=e[3];let h;e[4]!==k?(h=k&&k!==""?o.jsxRuntimeExports.jsx(_.P,{size:"sm",marginBottom:"2xs",className:"w-full text-center",children:k}):null,e[4]=k,e[5]=h):h=e[5];let E;e[6]===Symbol.for("react.memo_cache_sentinel")?(E={maxWidth:"360px"},e[6]=E):E=e[6];let d;if(e[7]!==r||e[8]!==t||e[9]!==l||e[10]!==R||e[11]!==n||e[12]!==s){let D;e[14]!==t||e[15]!==l||e[16]!==R||e[17]!==n||e[18]!==s?(D=(F,a)=>o.jsxRuntimeExports.jsxs("g",{onMouseOver:()=>{c(t[a]),s(t[a])},onMouseLeave:()=>{c(void 0),s(void 0)},className:"cursor-pointer",children:[o.jsxRuntimeExports.jsx("rect",{x:a*n/t.length+1,y:1,width:n/t.length-2,height:8,className:`stroke-1 ${l===t[a]?"stroke-primary-gray-700 dark:stroke-primary-gray-300":""}`,style:{fill:t[a],...l!==t[a]?{stroke:t[a]}:{}}}),o.jsxRuntimeExports.jsx("text",{x:(a+1)*n/t.length,y:25,className:"fill-primary-gray-700 dark:fill-primary-gray-300 text-sm",style:{textAnchor:"middle"},children:z.numberFormattingFunction(F,void 0,2,"","",R)})]},a),e[14]=t,e[15]=l,e[16]=R,e[17]=n,e[18]=s,e[19]=D):D=e[19],d=r.map(D),e[7]=r,e[8]=t,e[9]=l,e[10]=R,e[11]=n,e[12]=s,e[13]=d}else d=e[13];let g;e[20]!==r.length||e[21]!==t||e[22]!==s?(g=()=>{c(t[r.length]),s(t[r.length])},e[20]=r.length,e[21]=t,e[22]=s,e[23]=g):g=e[23];let u;e[24]!==s?(u=()=>{c(void 0),s(void 0)},e[24]=s,e[25]=u):u=e[25];const L=r.length*n/t.length+1,O=n/t.length-2,W=`cursor-pointer stroke-1 ${l===t[r.length]?"stroke-primary-gray-700 dark:stroke-primary-gray-300":""}`,q=t[r.length];let y;e[26]!==r.length||e[27]!==t||e[28]!==l?(y=l!==t[r.length]?{stroke:t[r.length]}:{},e[26]=r.length,e[27]=t,e[28]=l,e[29]=y):y=e[29];let p;e[30]!==q||e[31]!==y?(p={fill:q,...y},e[30]=q,e[31]=y,e[32]=p):p=e[32];let f;e[33]!==L||e[34]!==O||e[35]!==W||e[36]!==p||e[37]!==g||e[38]!==u?(f=o.jsxRuntimeExports.jsx("g",{children:o.jsxRuntimeExports.jsx("rect",{onMouseOver:g,onMouseLeave:u,x:L,y:1,width:O,height:8,className:W,style:p})}),e[33]=L,e[34]=O,e[35]=W,e[36]=p,e[37]=g,e[38]=u,e[39]=f):f=e[39];let j;e[40]!==l||e[41]!==i||e[42]!==M||e[43]!==s||e[44]!==C?(j=C?o.jsxRuntimeExports.jsxs("g",{onMouseOver:()=>{c(i||"#D4D6D8"),s(i||"#D4D6D8")},onMouseLeave:()=>{c(void 0),s(void 0)},className:"cursor-pointer",children:[o.jsxRuntimeExports.jsx("rect",{x:335,y:1,width:24,height:8,className:`stroke-1 ${l===i?"stroke-primary-gray-700 dark:stroke-primary-gray-300":""}`,style:{fill:i||"#D4D6D8",...l!==i?{stroke:i}:{},strokeWidth:1}}),o.jsxRuntimeExports.jsx("text",{x:337.5,y:25,className:"fill-primary-gray-700 dark:fill-primary-gray-300 text-sm",style:{textAnchor:"start"},children:M})]}):null,e[40]=l,e[41]=i,e[42]=M,e[43]=s,e[44]=C,e[45]=j):j=e[45];let v;e[46]!==f||e[47]!==j||e[48]!==d?(v=o.jsxRuntimeExports.jsx("svg",{width:"100%",viewBox:"0 0 360 30",style:E,direction:"ltr",children:o.jsxRuntimeExports.jsxs("g",{children:[d,f,j]})}),e[46]=f,e[47]=j,e[48]=d,e[49]=v):v=e[49];let N;return e[50]!==v||e[51]!==x||e[52]!==m||e[53]!==h?(N=o.jsxRuntimeExports.jsxs("div",{className:x,style:m,"aria-label":"Color legend",children:[h,v]}),e[50]=v,e[51]=x,e[52]=m,e[53]=h,e[54]=N):N=e[54],N}exports.ThresholdColorLegendWithMouseOver=H;
|
|
2
2
|
//# sourceMappingURL=ThresholdColorLegendWithMouseOver.cjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ThresholdColorLegendWithMouseOver.cjs","sources":["../src/Components/Elements/ThresholdColorLegendWithMouseOver.tsx"],"sourcesContent":["import { useState } from 'react';\r\nimport { cn } from '@undp/design-system-react/cn';\r\nimport { P } from '@undp/design-system-react/Typography';\r\n\r\nimport { numberFormattingFunction } from '@/Utils/numberFormattingFunction';\r\n\r\ninterface Props {\r\n colors: string[];\r\n colorDomain: number[];\r\n colorLegendTitle?: string;\r\n setSelectedColor: (_d?: string) => void;\r\n width?: number;\r\n naColor?: string;\r\n className?: string;\r\n showNAColor: boolean;\r\n locale?: string;\r\n naLabel: string;\r\n}\r\n\r\nexport function ThresholdColorLegendWithMouseOver(props: Props) {\r\n const {\r\n colorLegendTitle,\r\n colorDomain,\r\n colors,\r\n setSelectedColor,\r\n width,\r\n naColor,\r\n className,\r\n showNAColor,\r\n locale = 'en',\r\n naLabel = 'NA',\r\n } = props;\r\n\r\n const [hoveredColor, setHoveredColor] = useState<string | undefined>(undefined);\r\n const mainColorWidth = naColor ? 320 : 360;\r\n return (\r\n <div\r\n className={cn('flex flex-wrap gap-0 justify-center leading-0', className)}\r\n style={{ maxWidth: width ? `${width}px` : 'none' }}\r\n aria-label='Color legend'\r\n >\r\n {colorLegendTitle && colorLegendTitle !== '' ? (\r\n <P size='sm' marginBottom='2xs' className='w-full text-center'>\r\n {colorLegendTitle}\r\n </P>\r\n ) : null}\r\n <svg width='100%' viewBox='0 0 360 30' style={{ maxWidth: '360px' }} direction='ltr'>\r\n <g>\r\n {colorDomain.map((d, i) => (\r\n <g\r\n key={i}\r\n onMouseOver={() => {\r\n setHoveredColor(colors[i]);\r\n setSelectedColor(colors[i]);\r\n }}\r\n onMouseLeave={() => {\r\n setHoveredColor(undefined);\r\n setSelectedColor(undefined);\r\n }}\r\n className='cursor-pointer'\r\n >\r\n <rect\r\n x={(i * mainColorWidth) / colors.length + 1}\r\n y={1}\r\n width={mainColorWidth / colors.length - 2}\r\n height={8}\r\n className={`stroke-1 ${\r\n hoveredColor === colors[i]\r\n ? 'stroke-primary-gray-700 dark:stroke-primary-gray-300'\r\n : ''\r\n }`}\r\n style={{\r\n fill: colors[i],\r\n ...(hoveredColor !== colors[i] ? { stroke: colors[i] } : {}),\r\n }}\r\n />\r\n <text\r\n x={((i + 1) * mainColorWidth) / colors.length}\r\n y={25}\r\n className='fill-primary-gray-700 dark:fill-primary-gray-300 text-sm'\r\n style={{ textAnchor: 'middle' }}\r\n >\r\n {numberFormattingFunction(d as number, undefined, 2, '', '', locale)}\r\n </text>\r\n </g>\r\n ))}\r\n <g>\r\n <rect\r\n onMouseOver={() => {\r\n setHoveredColor(colors[colorDomain.length]);\r\n setSelectedColor(colors[colorDomain.length]);\r\n }}\r\n onMouseLeave={() => {\r\n setHoveredColor(undefined);\r\n setSelectedColor(undefined);\r\n }}\r\n x={(colorDomain.length * mainColorWidth) / colors.length + 1}\r\n y={1}\r\n width={mainColorWidth / colors.length - 2}\r\n height={8}\r\n className={`cursor-pointer stroke-1 ${\r\n hoveredColor === colors[colorDomain.length]\r\n ? 'stroke-primary-gray-700 dark:stroke-primary-gray-300'\r\n : ''\r\n }`}\r\n style={{\r\n fill: colors[colorDomain.length],\r\n ...(hoveredColor !== colors[colorDomain.length]\r\n ? { stroke: colors[colorDomain.length] }\r\n : {}),\r\n }}\r\n />\r\n </g>\r\n {showNAColor ? (\r\n <g\r\n onMouseOver={() => {\r\n setHoveredColor(naColor || '#D4D6D8');\r\n setSelectedColor(naColor || '#D4D6D8');\r\n }}\r\n onMouseLeave={() => {\r\n setHoveredColor(undefined);\r\n setSelectedColor(undefined);\r\n }}\r\n className='cursor-pointer'\r\n >\r\n <rect\r\n x={335}\r\n y={1}\r\n width={24}\r\n height={8}\r\n className={`stroke-1 ${\r\n hoveredColor === naColor\r\n ? 'stroke-primary-gray-700 dark:stroke-primary-gray-300'\r\n : ''\r\n }`}\r\n style={{\r\n fill: naColor || '#D4D6D8',\r\n ...(hoveredColor !== naColor ? { stroke: naColor } : {}),\r\n strokeWidth: 1,\r\n }}\r\n />\r\n <text\r\n x={337.5}\r\n y={25}\r\n className='fill-primary-gray-700 dark:fill-primary-gray-300 text-sm'\r\n style={{ textAnchor: 'start' }}\r\n >\r\n {naLabel}\r\n </text>\r\n </g>\r\n ) : null}\r\n </g>\r\n </svg>\r\n </div>\r\n );\r\n}\r\n"],"names":["ThresholdColorLegendWithMouseOver","props","$","_c","colorLegendTitle","colorDomain","colors","setSelectedColor","width","naColor","className","showNAColor","locale","t0","naLabel","t1","undefined","hoveredColor","setHoveredColor","useState","mainColorWidth","t2","cn","t3","t4","maxWidth","t5","jsx","P","t6","Symbol","for","t7","t8","d","i","jsxs","length","fill","stroke","textAnchor","numberFormattingFunction","map","t9","t10","t11","t12","t13","t14","t15","t16","t17","strokeWidth","t18","t19"],"mappings":"gPAmBO,SAAAA,EAAAC,EAAA,CAAA,MAAAC,EAAAC,EAAAA,uBAAAA,EAAA,EAAA,EACL,CAAAC,iBAAAA,EAAAC,YAAAA,EAAAC,OAAAA,EAAAC,iBAAAA,EAAAC,MAAAA,EAAAC,QAAAA,EAAAC,UAAAA,EAAAC,YAAAA,EAAAC,OAAAC,EAAAC,QAAAC,CAAAA,EAWId,EAFFW,EAAAC,IAAAG,OAAA,KAAAH,EACAC,EAAAC,IAAAC,OAAA,KAAAD,EAGF,CAAAE,EAAAC,CAAA,EAAwCC,EAAAA,SAA6BH,MAAS,EAC9EI,EAAuBX,EAAA,IAAA,IAAoB,IAAAY,EAAAnB,OAAAQ,GAG5BW,EAAAC,EAAAA,GAAG,gDAAiDZ,CAAS,EAACR,KAAAQ,EAAAR,KAAAmB,GAAAA,EAAAnB,EAAA,CAAA,EACtD,MAAAqB,EAAAf,EAAA,GAAWA,CAAK,KAAhB,OAA6B,IAAAgB,EAAAtB,OAAAqB,GAAzCC,EAAA,CAAAC,SAAYF,CAAAA,EAA+BrB,KAAAqB,EAAArB,KAAAsB,GAAAA,EAAAtB,EAAA,CAAA,EAAA,IAAAwB,EAAAxB,OAAAE,GAGjDsB,EAAAtB,GAAoBA,IAAqB,GACxCuB,EAAAA,kBAAAA,IAACC,EAAAA,EAAA,CAAO,KAAA,KAAkB,aAAA,MAAgB,UAAA,qBACvCxB,SAAAA,CAAAA,CACH,EAHD,KAIOF,KAAAE,EAAAF,KAAAwB,GAAAA,EAAAxB,EAAA,CAAA,EAAA,IAAA2B,EAAA3B,EAAA,CAAA,IAAA4B,OAAAC,IAAA,2BAAA,GACsCF,EAAA,CAAAJ,SAAY,OAAA,EAASvB,KAAA2B,GAAAA,EAAA3B,EAAA,CAAA,EAAA,IAAA8B,EAAA,GAAA9B,OAAAG,GAAAH,EAAA,CAAA,IAAAI,GAAAJ,EAAA,CAAA,IAAAe,GAAAf,EAAA,EAAA,IAAAU,GAAAV,QAAAkB,GAAAlB,EAAA,EAAA,IAAAK,EAAA,CAAA,IAAA0B,EAAA/B,EAAA,EAAA,IAAAI,GAAAJ,EAAA,EAAA,IAAAe,GAAAf,EAAA,EAAA,IAAAU,GAAAV,EAAA,EAAA,IAAAkB,GAAAlB,QAAAK,GAE9C0B,EAAAA,CAAAC,EAAAC,IACfC,EAAAA,kBAAAA,KAAA,IAAA,CAEe,YAAA,IAAA,CACXlB,EAAgBZ,EAAO6B,CAAC,CAAC,EACzB5B,EAAiBD,EAAO6B,CAAC,CAAC,CAAC,EAEf,aAAA,IAAA,CACZjB,EAAgBF,MAAS,EACzBT,EAAiBS,MAAS,CAAC,EAEnB,UAAA,iBAEV,SAAA,CAAAW,EAAAA,kBAAAA,IAAA,OAAA,CACK,EAACQ,EAAIf,EAAkBd,EAAM+B,OAAU,EACvC,EAAA,EACI,MAAAjB,EAAiBd,EAAM+B,OAAU,EAChC,OAAA,EACG,UAAA,YACTpB,IAAiBX,EAAO6B,CAAC,EAAzB,uDAAA,EAEM,GAED,MAAA,CAAAG,KACChC,EAAO6B,CAAC,EAAC,GACXlB,IAAiBX,EAAO6B,CAAC,EAAzB,CAAAI,OAAuCjC,EAAO6B,CAAC,CAAA,EAA/C,CAAA,CAAsD,EAC3D,EAEHR,EAAAA,kBAAAA,IAAA,OAAA,CACK,GAAEQ,EAAI,GAAKf,EAAkBd,EAAM+B,OACnC,EAAA,GACO,UAAA,2DACH,MAAA,CAAAG,WAAc,QAAA,EAEpBC,oCAAyBP,EAAalB,OAAW,EAAG,GAAI,GAAIJ,CAAM,CAAA,CACrE,CAAA,CAAA,EAjCKuB,CAkCP,EACDjC,MAAAI,EAAAJ,MAAAe,EAAAf,MAAAU,EAAAV,MAAAkB,EAAAlB,MAAAK,EAAAL,MAAA+B,GAAAA,EAAA/B,EAAA,EAAA,EArCA8B,EAAA3B,EAAWqC,IAAKT,CAqChB,EAAC/B,KAAAG,EAAAH,KAAAI,EAAAJ,KAAAe,EAAAf,MAAAU,EAAAV,MAAAkB,EAAAlB,MAAAK,EAAAL,MAAA8B,CAAA,MAAAA,EAAA9B,EAAA,EAAA,EAAA,IAAA+B,EAAA/B,EAAA,EAAA,IAAAG,EAAAgC,QAAAnC,EAAA,EAAA,IAAAI,GAAAJ,EAAA,EAAA,IAAAK,GAGe0B,EAAAA,IAAA,CACXf,EAAgBZ,EAAOD,EAAWgC,MAAO,CAAC,EAC1C9B,EAAiBD,EAAOD,EAAWgC,MAAO,CAAC,CAAC,EAC7CnC,EAAA,EAAA,EAAAG,EAAAgC,OAAAnC,MAAAI,EAAAJ,MAAAK,EAAAL,MAAA+B,GAAAA,EAAA/B,EAAA,EAAA,EAAA,IAAAyC,EAAAzC,QAAAK,GACaoC,EAAAA,IAAA,CACZzB,EAAgBF,MAAS,EACzBT,EAAiBS,MAAS,CAAC,EAC5Bd,MAAAK,EAAAL,MAAAyC,GAAAA,EAAAzC,EAAA,EAAA,EACE,MAAA0C,EAACvC,EAAWgC,OAAUjB,EAAkBd,EAAM+B,OAAU,EAEpDQ,EAAAzB,EAAiBd,EAAM+B,OAAU,EAE7BS,EAAA,2BACT7B,IAAiBX,EAAOD,EAAWgC,MAAO,EAA1C,uDAAA,EAEM,GAGAU,EAAAzC,EAAOD,EAAWgC,MAAO,EAAC,IAAAW,EAAA9C,EAAA,EAAA,IAAAG,EAAAgC,QAAAnC,EAAA,EAAA,IAAAI,GAAAJ,EAAA,EAAA,IAAAe,GAC5B+B,EAAA/B,IAAiBX,EAAOD,EAAWgC,MAAO,EAA1C,CAAAE,OACUjC,EAAOD,EAAWgC,MAAO,CAAA,EADnC,CAAA,EAEEnC,EAAA,EAAA,EAAAG,EAAAgC,OAAAnC,MAAAI,EAAAJ,MAAAe,EAAAf,MAAA8C,GAAAA,EAAA9C,EAAA,EAAA,EAAA,IAAA+C,EAAA/C,EAAA,EAAA,IAAA6C,GAAA7C,QAAA8C,GAJDC,EAAA,CAAAX,KACCS,EAA0B,GAC5BC,CAAAA,EAGL9C,MAAA6C,EAAA7C,MAAA8C,EAAA9C,MAAA+C,GAAAA,EAAA/C,EAAA,EAAA,EAAA,IAAAgD,EAAAhD,QAAA0C,GAAA1C,EAAA,EAAA,IAAA2C,GAAA3C,EAAA,EAAA,IAAA4C,GAAA5C,EAAA,EAAA,IAAA+C,GAAA/C,QAAA+B,GAAA/B,EAAA,EAAA,IAAAyC,GAxBLO,EAAAvB,EAAAA,kBAAAA,IAAA,KACE,SAAAA,EAAAA,kBAAAA,IAAA,OAAA,CACe,YAAAM,EAIC,aAAAU,EAIX,EAAAC,EACA,IACI,MAAAC,EACC,OAAA,EACG,UAAAC,EAKJ,MAAAG,EAKN,CAAA,CAEL,EAAI/C,MAAA0C,EAAA1C,MAAA2C,EAAA3C,MAAA4C,EAAA5C,MAAA+C,EAAA/C,MAAA+B,EAAA/B,MAAAyC,EAAAzC,MAAAgD,GAAAA,EAAAhD,EAAA,EAAA,EAAA,IAAAiD,EAAAjD,EAAA,EAAA,IAAAe,GAAAf,EAAA,EAAA,IAAAO,GAAAP,EAAA,EAAA,IAAAY,GAAAZ,EAAA,EAAA,IAAAK,GAAAL,QAAAS,GACHwC,EAAAxC,EACCyB,EAAAA,kBAAAA,KAAA,IAAA,CACe,YAAA,IAAA,CACXlB,EAAgBT,GAAA,SAAoB,EACpCF,EAAiBE,GAAA,SAAoB,CAAC,EAE1B,aAAA,IAAA,CACZS,EAAgBF,MAAS,EACzBT,EAAiBS,MAAS,CAAC,EAEnB,UAAA,iBAEV,SAAA,CAAAW,gCACK,EAAA,IACA,EAAA,EACI,MAAA,GACC,OAAA,EACG,sBACTV,IAAiBR,EAAjB,uDAAA,EAEM,GAED,MAAA,CAAA6B,KACC7B,GAAA,UAAoB,GACtBQ,IAAiBR,EAAjB,CAAA8B,OAAqC9B,CAAAA,EAArC,CAAA,EAAmD2C,YAC1C,CAAA,IAGjBzB,wBAAA,QACK,EAAA,MACA,EAAA,GACO,UAAA,2DACH,MAAA,CAAAa,WAAc,OAAA,EAEpB1B,SAAAA,CAAAA,CACH,CAAA,CAAA,CACF,EApCD,KAqCOZ,MAAAe,EAAAf,MAAAO,EAAAP,MAAAY,EAAAZ,MAAAK,EAAAL,MAAAS,EAAAT,MAAAiD,GAAAA,EAAAjD,EAAA,EAAA,EAAA,IAAAmD,EAAAnD,EAAA,EAAA,IAAAgD,GAAAhD,QAAAiD,GAAAjD,EAAA,EAAA,IAAA8B,GAxGZqB,EAAA1B,EAAAA,kBAAAA,IAAA,MAAA,CAAW,MAAA,OAAe,QAAA,aAAoB,MAAAE,EAAiC,UAAA,MAC7E,SAAAO,EAAAA,kBAAAA,KAAA,IAAA,CACGJ,SAAAA,CAAAA,EAsCDkB,EA2BCC,CAAAA,CAAAA,CAsCH,CAAA,CACF,EAAMjD,MAAAgD,EAAAhD,MAAAiD,EAAAjD,MAAA8B,EAAA9B,MAAAmD,GAAAA,EAAAnD,EAAA,EAAA,EAAA,IAAAoD,EAAA,OAAApD,EAAA,EAAA,IAAAmD,GAAAnD,EAAA,EAAA,IAAAmB,GAAAnB,EAAA,EAAA,IAAAsB,GAAAtB,QAAAwB,GApHR4B,2BAAA,MAAA,CACa,UAAAjC,EACJ,MAAAG,EACI,aAAA,eAEVE,SAAAA,CAAAA,EAKD2B,CAAAA,EA2GF,EAAMnD,MAAAmD,EAAAnD,MAAAmB,EAAAnB,MAAAsB,EAAAtB,MAAAwB,EAAAxB,MAAAoD,GAAAA,EAAApD,EAAA,EAAA,EArHNoD,CAqHM"}
|
|
1
|
+
{"version":3,"file":"ThresholdColorLegendWithMouseOver.cjs","sources":["../src/Components/Elements/ThresholdColorLegendWithMouseOver.tsx"],"sourcesContent":["import { useState } from 'react';\r\nimport { cn } from '@undp/design-system-react/cn';\r\nimport { P } from '@undp/design-system-react/Typography';\r\n\r\nimport { numberFormattingFunction } from '@/Utils/numberFormattingFunction';\r\n\r\ninterface Props {\r\n colors: string[];\r\n colorDomain: number[];\r\n colorLegendTitle?: string;\r\n setSelectedColor: (_d?: string) => void;\r\n width?: number;\r\n naColor?: string;\r\n className?: string;\r\n showNAColor: boolean;\r\n locale?: string;\r\n naLabel: string;\r\n}\r\n\r\nexport function ThresholdColorLegendWithMouseOver(props: Props) {\r\n const {\r\n colorLegendTitle,\r\n colorDomain,\r\n colors,\r\n setSelectedColor,\r\n width,\r\n naColor,\r\n className,\r\n showNAColor,\r\n locale = 'en',\r\n naLabel = 'NA',\r\n } = props;\r\n\r\n const [hoveredColor, setHoveredColor] = useState<string | undefined>(undefined);\r\n const mainColorWidth = naColor ? 320 : 360;\r\n return (\r\n <div\r\n className={cn('flex flex-wrap gap-0 justify-center leading-0', className)}\r\n style={{ maxWidth: width ? `${width}px` : 'none' }}\r\n aria-label='Color legend'\r\n >\r\n {colorLegendTitle && colorLegendTitle !== '' ? (\r\n <P size='sm' marginBottom='2xs' className='w-full text-center'>\r\n {colorLegendTitle}\r\n </P>\r\n ) : null}\r\n <svg width='100%' viewBox='0 0 360 30' style={{ maxWidth: '360px' }} direction='ltr'>\r\n <g>\r\n {colorDomain.map((d, i) => (\r\n <g\r\n key={i}\r\n onMouseOver={() => {\r\n setHoveredColor(colors[i]);\r\n setSelectedColor(colors[i]);\r\n }}\r\n onMouseLeave={() => {\r\n setHoveredColor(undefined);\r\n setSelectedColor(undefined);\r\n }}\r\n className='cursor-pointer'\r\n >\r\n <rect\r\n x={(i * mainColorWidth) / colors.length + 1}\r\n y={1}\r\n width={mainColorWidth / colors.length - 2}\r\n height={8}\r\n className={`stroke-1 ${\r\n hoveredColor === colors[i]\r\n ? 'stroke-primary-gray-700 dark:stroke-primary-gray-300'\r\n : ''\r\n }`}\r\n style={{\r\n fill: colors[i],\r\n ...(hoveredColor !== colors[i] ? { stroke: colors[i] } : {}),\r\n }}\r\n />\r\n <text\r\n x={((i + 1) * mainColorWidth) / colors.length}\r\n y={25}\r\n className='fill-primary-gray-700 dark:fill-primary-gray-300 text-sm'\r\n style={{ textAnchor: 'middle' }}\r\n >\r\n {numberFormattingFunction(d as number, undefined, 2, '', '', locale)}\r\n </text>\r\n </g>\r\n ))}\r\n <g>\r\n <rect\r\n onMouseOver={() => {\r\n setHoveredColor(colors[colorDomain.length]);\r\n setSelectedColor(colors[colorDomain.length]);\r\n }}\r\n onMouseLeave={() => {\r\n setHoveredColor(undefined);\r\n setSelectedColor(undefined);\r\n }}\r\n x={(colorDomain.length * mainColorWidth) / colors.length + 1}\r\n y={1}\r\n width={mainColorWidth / colors.length - 2}\r\n height={8}\r\n className={`cursor-pointer stroke-1 ${\r\n hoveredColor === colors[colorDomain.length]\r\n ? 'stroke-primary-gray-700 dark:stroke-primary-gray-300'\r\n : ''\r\n }`}\r\n style={{\r\n fill: colors[colorDomain.length],\r\n ...(hoveredColor !== colors[colorDomain.length]\r\n ? { stroke: colors[colorDomain.length] }\r\n : {}),\r\n }}\r\n />\r\n </g>\r\n {showNAColor ? (\r\n <g\r\n onMouseOver={() => {\r\n setHoveredColor(naColor || '#D4D6D8');\r\n setSelectedColor(naColor || '#D4D6D8');\r\n }}\r\n onMouseLeave={() => {\r\n setHoveredColor(undefined);\r\n setSelectedColor(undefined);\r\n }}\r\n className='cursor-pointer'\r\n >\r\n <rect\r\n x={335}\r\n y={1}\r\n width={24}\r\n height={8}\r\n className={`stroke-1 ${\r\n hoveredColor === naColor\r\n ? 'stroke-primary-gray-700 dark:stroke-primary-gray-300'\r\n : ''\r\n }`}\r\n style={{\r\n fill: naColor || '#D4D6D8',\r\n ...(hoveredColor !== naColor ? { stroke: naColor } : {}),\r\n strokeWidth: 1,\r\n }}\r\n />\r\n <text\r\n x={337.5}\r\n y={25}\r\n className='fill-primary-gray-700 dark:fill-primary-gray-300 text-sm'\r\n style={{ textAnchor: 'start' }}\r\n >\r\n {naLabel}\r\n </text>\r\n </g>\r\n ) : null}\r\n </g>\r\n </svg>\r\n </div>\r\n );\r\n}\r\n"],"names":["ThresholdColorLegendWithMouseOver","props","$","_c","colorLegendTitle","colorDomain","colors","setSelectedColor","width","naColor","className","showNAColor","locale","t0","naLabel","t1","undefined","hoveredColor","setHoveredColor","useState","mainColorWidth","t2","cn","t3","t4","maxWidth","t5","jsx","P","t6","Symbol","for","t7","t8","d","i","jsxs","length","fill","stroke","textAnchor","numberFormattingFunction","map","t9","t10","t11","t12","t13","t14","t15","t16","t17","strokeWidth","t18","t19"],"mappings":"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"}
|
|
@@ -1,29 +1,30 @@
|
|
|
1
|
-
import { c as
|
|
2
|
-
import { useState as
|
|
3
|
-
import {
|
|
4
|
-
import {
|
|
5
|
-
|
|
6
|
-
|
|
1
|
+
import { c as _, j as o } from "./compiler-runtime-qHgugrLy.js";
|
|
2
|
+
import { useState as z } from "react";
|
|
3
|
+
import { cn as H } from "@undp/design-system-react/cn";
|
|
4
|
+
import { P } from "@undp/design-system-react/Typography";
|
|
5
|
+
import { n as q } from "./numberFormattingFunction-BUUV_luR.js";
|
|
6
|
+
function U(R) {
|
|
7
|
+
const e = _.c(55), {
|
|
7
8
|
colorLegendTitle: j,
|
|
8
9
|
colorDomain: r,
|
|
9
10
|
colors: t,
|
|
10
11
|
setSelectedColor: l,
|
|
11
|
-
width:
|
|
12
|
+
width: B,
|
|
12
13
|
naColor: i,
|
|
13
14
|
className: L,
|
|
14
15
|
showNAColor: M,
|
|
15
|
-
locale:
|
|
16
|
-
naLabel:
|
|
17
|
-
} =
|
|
16
|
+
locale: E,
|
|
17
|
+
naLabel: F
|
|
18
|
+
} = R, N = E === void 0 ? "en" : E, b = F === void 0 ? "NA" : F, [s, c] = z(void 0), n = i ? 320 : 360;
|
|
18
19
|
let m;
|
|
19
|
-
e[0] !== L ? (m =
|
|
20
|
-
const W =
|
|
20
|
+
e[0] !== L ? (m = H("flex flex-wrap gap-0 justify-center leading-0", L), e[0] = L, e[1] = m) : m = e[1];
|
|
21
|
+
const W = B ? `${B}px` : "none";
|
|
21
22
|
let h;
|
|
22
23
|
e[2] !== W ? (h = {
|
|
23
24
|
maxWidth: W
|
|
24
25
|
}, e[2] = W, e[3] = h) : h = e[3];
|
|
25
26
|
let d;
|
|
26
|
-
e[4] !== j ? (d = j && j !== "" ? /* @__PURE__ */ o.jsx(
|
|
27
|
+
e[4] !== j ? (d = j && j !== "" ? /* @__PURE__ */ o.jsx(P, { size: "sm", marginBottom: "2xs", className: "w-full text-center", children: j }) : null, e[4] = j, e[5] = d) : d = e[5];
|
|
27
28
|
let D;
|
|
28
29
|
e[6] === /* @__PURE__ */ Symbol.for("react.memo_cache_sentinel") ? (D = {
|
|
29
30
|
maxWidth: "360px"
|
|
@@ -31,7 +32,7 @@ function Q(F) {
|
|
|
31
32
|
let g;
|
|
32
33
|
if (e[7] !== r || e[8] !== t || e[9] !== s || e[10] !== N || e[11] !== n || e[12] !== l) {
|
|
33
34
|
let C;
|
|
34
|
-
e[14] !== t || e[15] !== s || e[16] !== N || e[17] !== n || e[18] !== l ? (C = (
|
|
35
|
+
e[14] !== t || e[15] !== s || e[16] !== N || e[17] !== n || e[18] !== l ? (C = (T, a) => /* @__PURE__ */ o.jsxs("g", { onMouseOver: () => {
|
|
35
36
|
c(t[a]), l(t[a]);
|
|
36
37
|
}, onMouseLeave: () => {
|
|
37
38
|
c(void 0), l(void 0);
|
|
@@ -44,7 +45,7 @@ function Q(F) {
|
|
|
44
45
|
} }),
|
|
45
46
|
/* @__PURE__ */ o.jsx("text", { x: (a + 1) * n / t.length, y: 25, className: "fill-primary-gray-700 dark:fill-primary-gray-300 text-sm", style: {
|
|
46
47
|
textAnchor: "middle"
|
|
47
|
-
}, children:
|
|
48
|
+
}, children: q(T, void 0, 2, "", "", N) })
|
|
48
49
|
] }, a), e[14] = t, e[15] = s, e[16] = N, e[17] = n, e[18] = l, e[19] = C) : C = e[19], g = r.map(C), e[7] = r, e[8] = t, e[9] = s, e[10] = N, e[11] = n, e[12] = l, e[13] = g;
|
|
49
50
|
} else
|
|
50
51
|
g = e[13];
|
|
@@ -98,6 +99,6 @@ function Q(F) {
|
|
|
98
99
|
] }), e[50] = k, e[51] = m, e[52] = h, e[53] = d, e[54] = w) : w = e[54], w;
|
|
99
100
|
}
|
|
100
101
|
export {
|
|
101
|
-
|
|
102
|
+
U as ThresholdColorLegendWithMouseOver
|
|
102
103
|
};
|
|
103
104
|
//# sourceMappingURL=ThresholdColorLegendWithMouseOver.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ThresholdColorLegendWithMouseOver.js","sources":["../src/Components/Elements/ThresholdColorLegendWithMouseOver.tsx"],"sourcesContent":["import { useState } from 'react';\r\nimport { cn } from '@undp/design-system-react/cn';\r\nimport { P } from '@undp/design-system-react/Typography';\r\n\r\nimport { numberFormattingFunction } from '@/Utils/numberFormattingFunction';\r\n\r\ninterface Props {\r\n colors: string[];\r\n colorDomain: number[];\r\n colorLegendTitle?: string;\r\n setSelectedColor: (_d?: string) => void;\r\n width?: number;\r\n naColor?: string;\r\n className?: string;\r\n showNAColor: boolean;\r\n locale?: string;\r\n naLabel: string;\r\n}\r\n\r\nexport function ThresholdColorLegendWithMouseOver(props: Props) {\r\n const {\r\n colorLegendTitle,\r\n colorDomain,\r\n colors,\r\n setSelectedColor,\r\n width,\r\n naColor,\r\n className,\r\n showNAColor,\r\n locale = 'en',\r\n naLabel = 'NA',\r\n } = props;\r\n\r\n const [hoveredColor, setHoveredColor] = useState<string | undefined>(undefined);\r\n const mainColorWidth = naColor ? 320 : 360;\r\n return (\r\n <div\r\n className={cn('flex flex-wrap gap-0 justify-center leading-0', className)}\r\n style={{ maxWidth: width ? `${width}px` : 'none' }}\r\n aria-label='Color legend'\r\n >\r\n {colorLegendTitle && colorLegendTitle !== '' ? (\r\n <P size='sm' marginBottom='2xs' className='w-full text-center'>\r\n {colorLegendTitle}\r\n </P>\r\n ) : null}\r\n <svg width='100%' viewBox='0 0 360 30' style={{ maxWidth: '360px' }} direction='ltr'>\r\n <g>\r\n {colorDomain.map((d, i) => (\r\n <g\r\n key={i}\r\n onMouseOver={() => {\r\n setHoveredColor(colors[i]);\r\n setSelectedColor(colors[i]);\r\n }}\r\n onMouseLeave={() => {\r\n setHoveredColor(undefined);\r\n setSelectedColor(undefined);\r\n }}\r\n className='cursor-pointer'\r\n >\r\n <rect\r\n x={(i * mainColorWidth) / colors.length + 1}\r\n y={1}\r\n width={mainColorWidth / colors.length - 2}\r\n height={8}\r\n className={`stroke-1 ${\r\n hoveredColor === colors[i]\r\n ? 'stroke-primary-gray-700 dark:stroke-primary-gray-300'\r\n : ''\r\n }`}\r\n style={{\r\n fill: colors[i],\r\n ...(hoveredColor !== colors[i] ? { stroke: colors[i] } : {}),\r\n }}\r\n />\r\n <text\r\n x={((i + 1) * mainColorWidth) / colors.length}\r\n y={25}\r\n className='fill-primary-gray-700 dark:fill-primary-gray-300 text-sm'\r\n style={{ textAnchor: 'middle' }}\r\n >\r\n {numberFormattingFunction(d as number, undefined, 2, '', '', locale)}\r\n </text>\r\n </g>\r\n ))}\r\n <g>\r\n <rect\r\n onMouseOver={() => {\r\n setHoveredColor(colors[colorDomain.length]);\r\n setSelectedColor(colors[colorDomain.length]);\r\n }}\r\n onMouseLeave={() => {\r\n setHoveredColor(undefined);\r\n setSelectedColor(undefined);\r\n }}\r\n x={(colorDomain.length * mainColorWidth) / colors.length + 1}\r\n y={1}\r\n width={mainColorWidth / colors.length - 2}\r\n height={8}\r\n className={`cursor-pointer stroke-1 ${\r\n hoveredColor === colors[colorDomain.length]\r\n ? 'stroke-primary-gray-700 dark:stroke-primary-gray-300'\r\n : ''\r\n }`}\r\n style={{\r\n fill: colors[colorDomain.length],\r\n ...(hoveredColor !== colors[colorDomain.length]\r\n ? { stroke: colors[colorDomain.length] }\r\n : {}),\r\n }}\r\n />\r\n </g>\r\n {showNAColor ? (\r\n <g\r\n onMouseOver={() => {\r\n setHoveredColor(naColor || '#D4D6D8');\r\n setSelectedColor(naColor || '#D4D6D8');\r\n }}\r\n onMouseLeave={() => {\r\n setHoveredColor(undefined);\r\n setSelectedColor(undefined);\r\n }}\r\n className='cursor-pointer'\r\n >\r\n <rect\r\n x={335}\r\n y={1}\r\n width={24}\r\n height={8}\r\n className={`stroke-1 ${\r\n hoveredColor === naColor\r\n ? 'stroke-primary-gray-700 dark:stroke-primary-gray-300'\r\n : ''\r\n }`}\r\n style={{\r\n fill: naColor || '#D4D6D8',\r\n ...(hoveredColor !== naColor ? { stroke: naColor } : {}),\r\n strokeWidth: 1,\r\n }}\r\n />\r\n <text\r\n x={337.5}\r\n y={25}\r\n className='fill-primary-gray-700 dark:fill-primary-gray-300 text-sm'\r\n style={{ textAnchor: 'start' }}\r\n >\r\n {naLabel}\r\n </text>\r\n </g>\r\n ) : null}\r\n </g>\r\n </svg>\r\n </div>\r\n );\r\n}\r\n"],"names":["ThresholdColorLegendWithMouseOver","props","$","_c","colorLegendTitle","colorDomain","colors","setSelectedColor","width","naColor","className","showNAColor","locale","t0","naLabel","t1","undefined","hoveredColor","setHoveredColor","useState","mainColorWidth","t2","cn","t3","t4","maxWidth","t5","jsx","P","t6","Symbol","for","t7","t8","d","i","jsxs","length","fill","stroke","textAnchor","numberFormattingFunction","map","t9","t10","t11","t12","t13","t14","t15","t16","t17","strokeWidth","t18","t19"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"ThresholdColorLegendWithMouseOver.js","sources":["../src/Components/Elements/ThresholdColorLegendWithMouseOver.tsx"],"sourcesContent":["import { useState } from 'react';\r\nimport { cn } from '@undp/design-system-react/cn';\r\nimport { P } from '@undp/design-system-react/Typography';\r\n\r\nimport { numberFormattingFunction } from '@/Utils/numberFormattingFunction';\r\n\r\ninterface Props {\r\n colors: string[];\r\n colorDomain: number[];\r\n colorLegendTitle?: string;\r\n setSelectedColor: (_d?: string) => void;\r\n width?: number;\r\n naColor?: string;\r\n className?: string;\r\n showNAColor: boolean;\r\n locale?: string;\r\n naLabel: string;\r\n}\r\n\r\nexport function ThresholdColorLegendWithMouseOver(props: Props) {\r\n const {\r\n colorLegendTitle,\r\n colorDomain,\r\n colors,\r\n setSelectedColor,\r\n width,\r\n naColor,\r\n className,\r\n showNAColor,\r\n locale = 'en',\r\n naLabel = 'NA',\r\n } = props;\r\n\r\n const [hoveredColor, setHoveredColor] = useState<string | undefined>(undefined);\r\n const mainColorWidth = naColor ? 320 : 360;\r\n return (\r\n <div\r\n className={cn('flex flex-wrap gap-0 justify-center leading-0', className)}\r\n style={{ maxWidth: width ? `${width}px` : 'none' }}\r\n aria-label='Color legend'\r\n >\r\n {colorLegendTitle && colorLegendTitle !== '' ? (\r\n <P size='sm' marginBottom='2xs' className='w-full text-center'>\r\n {colorLegendTitle}\r\n </P>\r\n ) : null}\r\n <svg width='100%' viewBox='0 0 360 30' style={{ maxWidth: '360px' }} direction='ltr'>\r\n <g>\r\n {colorDomain.map((d, i) => (\r\n <g\r\n key={i}\r\n onMouseOver={() => {\r\n setHoveredColor(colors[i]);\r\n setSelectedColor(colors[i]);\r\n }}\r\n onMouseLeave={() => {\r\n setHoveredColor(undefined);\r\n setSelectedColor(undefined);\r\n }}\r\n className='cursor-pointer'\r\n >\r\n <rect\r\n x={(i * mainColorWidth) / colors.length + 1}\r\n y={1}\r\n width={mainColorWidth / colors.length - 2}\r\n height={8}\r\n className={`stroke-1 ${\r\n hoveredColor === colors[i]\r\n ? 'stroke-primary-gray-700 dark:stroke-primary-gray-300'\r\n : ''\r\n }`}\r\n style={{\r\n fill: colors[i],\r\n ...(hoveredColor !== colors[i] ? { stroke: colors[i] } : {}),\r\n }}\r\n />\r\n <text\r\n x={((i + 1) * mainColorWidth) / colors.length}\r\n y={25}\r\n className='fill-primary-gray-700 dark:fill-primary-gray-300 text-sm'\r\n style={{ textAnchor: 'middle' }}\r\n >\r\n {numberFormattingFunction(d as number, undefined, 2, '', '', locale)}\r\n </text>\r\n </g>\r\n ))}\r\n <g>\r\n <rect\r\n onMouseOver={() => {\r\n setHoveredColor(colors[colorDomain.length]);\r\n setSelectedColor(colors[colorDomain.length]);\r\n }}\r\n onMouseLeave={() => {\r\n setHoveredColor(undefined);\r\n setSelectedColor(undefined);\r\n }}\r\n x={(colorDomain.length * mainColorWidth) / colors.length + 1}\r\n y={1}\r\n width={mainColorWidth / colors.length - 2}\r\n height={8}\r\n className={`cursor-pointer stroke-1 ${\r\n hoveredColor === colors[colorDomain.length]\r\n ? 'stroke-primary-gray-700 dark:stroke-primary-gray-300'\r\n : ''\r\n }`}\r\n style={{\r\n fill: colors[colorDomain.length],\r\n ...(hoveredColor !== colors[colorDomain.length]\r\n ? { stroke: colors[colorDomain.length] }\r\n : {}),\r\n }}\r\n />\r\n </g>\r\n {showNAColor ? (\r\n <g\r\n onMouseOver={() => {\r\n setHoveredColor(naColor || '#D4D6D8');\r\n setSelectedColor(naColor || '#D4D6D8');\r\n }}\r\n onMouseLeave={() => {\r\n setHoveredColor(undefined);\r\n setSelectedColor(undefined);\r\n }}\r\n className='cursor-pointer'\r\n >\r\n <rect\r\n x={335}\r\n y={1}\r\n width={24}\r\n height={8}\r\n className={`stroke-1 ${\r\n hoveredColor === naColor\r\n ? 'stroke-primary-gray-700 dark:stroke-primary-gray-300'\r\n : ''\r\n }`}\r\n style={{\r\n fill: naColor || '#D4D6D8',\r\n ...(hoveredColor !== naColor ? { stroke: naColor } : {}),\r\n strokeWidth: 1,\r\n }}\r\n />\r\n <text\r\n x={337.5}\r\n y={25}\r\n className='fill-primary-gray-700 dark:fill-primary-gray-300 text-sm'\r\n style={{ textAnchor: 'start' }}\r\n >\r\n {naLabel}\r\n </text>\r\n </g>\r\n ) : null}\r\n </g>\r\n </svg>\r\n </div>\r\n );\r\n}\r\n"],"names":["ThresholdColorLegendWithMouseOver","props","$","_c","colorLegendTitle","colorDomain","colors","setSelectedColor","width","naColor","className","showNAColor","locale","t0","naLabel","t1","undefined","hoveredColor","setHoveredColor","useState","mainColorWidth","t2","cn","t3","t4","maxWidth","t5","jsx","t6","Symbol","for","t7","t8","d","i","jsxs","length","fill","stroke","textAnchor","numberFormattingFunction","map","t9","t10","t11","t12","t13","t14","t15","t16","t17","strokeWidth","t18","t19"],"mappings":"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"}
|
|
@@ -1,33 +1,34 @@
|
|
|
1
|
-
import { c as w,
|
|
1
|
+
import { c as w, j as b } from "./compiler-runtime-qHgugrLy.js";
|
|
2
|
+
import { cn as k } from "@undp/design-system-react/cn";
|
|
2
3
|
import { createPortal as v } from "react-dom";
|
|
3
4
|
import { s as j } from "./string2HTML-DL-pInUB.js";
|
|
4
|
-
function
|
|
5
|
+
function W(h) {
|
|
5
6
|
const t = w.c(22), {
|
|
6
7
|
body: r,
|
|
7
8
|
xPos: s,
|
|
8
9
|
yPos: d,
|
|
9
10
|
data: e,
|
|
10
11
|
backgroundStyle: m,
|
|
11
|
-
className:
|
|
12
|
+
className: f
|
|
12
13
|
} = h;
|
|
13
14
|
let c;
|
|
14
15
|
t[0] !== m ? (c = m === void 0 ? {
|
|
15
16
|
maxWidth: "24rem",
|
|
16
17
|
wordWrap: "break-word"
|
|
17
18
|
} : m, t[0] = m, t[1] = c) : c = t[1];
|
|
18
|
-
const
|
|
19
|
+
const y = c;
|
|
19
20
|
if (typeof r == "function" && (r(e) === null || r(e) === void 0) || r === "")
|
|
20
21
|
return null;
|
|
21
22
|
let o;
|
|
22
|
-
t[2] !==
|
|
23
|
+
t[2] !== f ? (o = k("graph-tooltip block p-2 fixed z-[1000] bg-primary-gray-200 dark:bg-primary-gray-600 border border-primary-gray-300 dark:border-primary-gray-500", f), t[2] = f, t[3] = o) : o = t[3];
|
|
23
24
|
const g = `${d < window.innerHeight / 2 ? d - 10 : d + 10}px`, u = `${s > window.innerWidth / 2 ? s - 10 : s + 10}px`, x = `translate(${s > window.innerWidth / 2 ? "-100%" : "0%"},${d > window.innerHeight / 2 ? "-100%" : "0%"})`;
|
|
24
25
|
let i;
|
|
25
|
-
t[4] !==
|
|
26
|
-
...
|
|
26
|
+
t[4] !== y || t[5] !== g || t[6] !== u || t[7] !== x ? (i = {
|
|
27
|
+
...y,
|
|
27
28
|
top: g,
|
|
28
29
|
left: u,
|
|
29
30
|
transform: x
|
|
30
|
-
}, t[4] =
|
|
31
|
+
}, t[4] = y, t[5] = g, t[6] = u, t[7] = x, t[8] = i) : i = t[8];
|
|
31
32
|
let n;
|
|
32
33
|
t[9] !== r || t[10] !== e ? (n = typeof r == "string" ? {
|
|
33
34
|
__html: j(r, e)
|
|
@@ -40,6 +41,6 @@ function T(h) {
|
|
|
40
41
|
return t[18] !== o || t[19] !== i || t[20] !== l ? (p = v(/* @__PURE__ */ b.jsx("div", { className: "undp-container", children: /* @__PURE__ */ b.jsx("div", { className: o, style: i, children: l }) }), document.body), t[18] = o, t[19] = i, t[20] = l, t[21] = p) : p = t[21], p;
|
|
41
42
|
}
|
|
42
43
|
export {
|
|
43
|
-
T
|
|
44
|
+
W as T
|
|
44
45
|
};
|
|
45
|
-
//# sourceMappingURL=Tooltip-
|
|
46
|
+
//# sourceMappingURL=Tooltip-DO56mY4b.js.map
|