@undp/data-viz 1.5.8 → 2.0.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.d.ts +1 -0
- package/dist/AreaChart.js +420 -520
- package/dist/AreaChart.js.map +1 -1
- package/dist/Axis-CRyfcLjc.js +32 -0
- package/dist/Axis-CRyfcLjc.js.map +1 -0
- package/dist/Axis-DxRV2yMi.cjs +2 -0
- package/dist/Axis-DxRV2yMi.cjs.map +1 -0
- package/dist/AxisTitle-jeI7am8o.js +29 -0
- package/dist/AxisTitle-jeI7am8o.js.map +1 -0
- package/dist/AxisTitle-sS5bLLR7.cjs +2 -0
- package/dist/AxisTitle-sS5bLLR7.cjs.map +1 -0
- package/dist/BarGraph.cjs +1 -1
- package/dist/BarGraph.cjs.map +1 -1
- package/dist/BarGraph.d.ts +1 -0
- package/dist/BarGraph.js +2188 -4045
- package/dist/BarGraph.js.map +1 -1
- package/dist/BasicStatCard.cjs +1 -1
- package/dist/BasicStatCard.cjs.map +1 -1
- package/dist/BasicStatCard.d.ts +1 -0
- package/dist/BasicStatCard.js +120 -186
- package/dist/BasicStatCard.js.map +1 -1
- package/dist/BeeSwarmChart.cjs +1 -1
- package/dist/BeeSwarmChart.cjs.map +1 -1
- package/dist/BeeSwarmChart.d.ts +5 -0
- package/dist/BeeSwarmChart.js +501 -1019
- package/dist/BeeSwarmChart.js.map +1 -1
- package/dist/BiVariateChoroplethMap.cjs +1 -1
- package/dist/BiVariateChoroplethMap.cjs.map +1 -1
- package/dist/BiVariateChoroplethMap.d.ts +3 -0
- package/dist/BiVariateChoroplethMap.js +458 -706
- package/dist/BiVariateChoroplethMap.js.map +1 -1
- package/dist/BulletChart.cjs +1 -1
- package/dist/BulletChart.cjs.map +1 -1
- package/dist/BulletChart.d.ts +1 -0
- package/dist/BulletChart.js +863 -1414
- package/dist/BulletChart.js.map +1 -1
- package/dist/ButterflyChart.cjs +1 -1
- package/dist/ButterflyChart.cjs.map +1 -1
- package/dist/ButterflyChart.d.ts +1 -0
- package/dist/ButterflyChart.js +474 -684
- package/dist/ButterflyChart.js.map +1 -1
- package/dist/ChoroplethMap.cjs +1 -1
- package/dist/ChoroplethMap.cjs.map +1 -1
- package/dist/ChoroplethMap.d.ts +3 -0
- package/dist/ChoroplethMap.js +469 -731
- package/dist/ChoroplethMap.js.map +1 -1
- package/dist/CirclePackingGraph.cjs +1 -1
- package/dist/CirclePackingGraph.d.ts +1 -0
- package/dist/CirclePackingGraph.js +5 -4
- package/dist/CirclePackingGraph.js.map +1 -1
- package/dist/ColorLegend.cjs +1 -1
- package/dist/ColorLegend.cjs.map +1 -1
- package/dist/ColorLegend.js +57 -44
- package/dist/ColorLegend.js.map +1 -1
- package/dist/ColorLegendWithMouseOver.cjs +1 -1
- package/dist/ColorLegendWithMouseOver.cjs.map +1 -1
- package/dist/ColorLegendWithMouseOver.js +60 -65
- package/dist/ColorLegendWithMouseOver.js.map +1 -1
- package/dist/Colors.cjs.map +1 -1
- package/dist/Colors.js +44 -430
- package/dist/Colors.js.map +1 -1
- package/dist/CopyTextButton.cjs +4 -4
- package/dist/CopyTextButton.cjs.map +1 -1
- package/dist/CopyTextButton.js +537 -455
- package/dist/CopyTextButton.js.map +1 -1
- package/dist/CsvDownloadButton.cjs +7 -7
- package/dist/CsvDownloadButton.cjs.map +1 -1
- package/dist/CsvDownloadButton.js +442 -447
- package/dist/CsvDownloadButton.js.map +1 -1
- package/dist/DataCards.cjs +5 -5
- package/dist/DataCards.cjs.map +1 -1
- package/dist/DataCards.d.ts +1 -0
- package/dist/DataCards.js +488 -581
- package/dist/DataCards.js.map +1 -1
- package/dist/DataTable.cjs +1 -1
- package/dist/DataTable.cjs.map +1 -1
- package/dist/DataTable.d.ts +1 -0
- package/dist/DataTable.js +183 -326
- package/dist/DataTable.js.map +1 -1
- package/dist/DifferenceLineChart.cjs +1 -1
- package/dist/DifferenceLineChart.cjs.map +1 -1
- package/dist/DifferenceLineChart.d.ts +1 -0
- package/dist/DifferenceLineChart.js +729 -794
- package/dist/DifferenceLineChart.js.map +1 -1
- package/dist/DonutChart.cjs +1 -1
- package/dist/DonutChart.cjs.map +1 -1
- package/dist/DonutChart.d.ts +1 -4
- package/dist/DonutChart.js +260 -444
- package/dist/DonutChart.js.map +1 -1
- package/dist/DotDensityMap.cjs +1 -1
- package/dist/DotDensityMap.cjs.map +1 -1
- package/dist/DotDensityMap.d.ts +3 -0
- package/dist/DotDensityMap.js +388 -582
- package/dist/DotDensityMap.js.map +1 -1
- package/dist/{DropdownSelect-CtOKZHD0.js → DropdownSelect-BbdPQa2k.js} +1401 -1374
- package/dist/DropdownSelect-BbdPQa2k.js.map +1 -0
- package/dist/DropdownSelect-Doz3mCrM.cjs +29 -0
- package/dist/DropdownSelect-Doz3mCrM.cjs.map +1 -0
- package/dist/DualAxisLineChart.cjs +1 -1
- package/dist/DualAxisLineChart.cjs.map +1 -1
- package/dist/DualAxisLineChart.d.ts +1 -0
- package/dist/DualAxisLineChart.js +617 -712
- package/dist/DualAxisLineChart.js.map +1 -1
- package/dist/DumbbellChart.cjs +1 -1
- package/dist/DumbbellChart.cjs.map +1 -1
- package/dist/DumbbellChart.d.ts +1 -0
- package/dist/DumbbellChart.js +789 -1499
- package/dist/DumbbellChart.js.map +1 -1
- package/dist/EmptyState-BZo1BbAn.js +15 -0
- package/dist/{EmptyState-DdTp-Mdn.js.map → EmptyState-BZo1BbAn.js.map} +1 -1
- package/dist/EmptyState-sAEZ_5rU.cjs +2 -0
- package/dist/{EmptyState-d8_8SxeW.cjs.map → EmptyState-sAEZ_5rU.cjs.map} +1 -1
- package/dist/ExcelDownloadButton.cjs +1 -1
- package/dist/ExcelDownloadButton.cjs.map +1 -1
- package/dist/ExcelDownloadButton.js +20 -24
- package/dist/ExcelDownloadButton.js.map +1 -1
- package/dist/FootNote.cjs +1 -1
- package/dist/FootNote.cjs.map +1 -1
- package/dist/FootNote.js +26 -17
- package/dist/FootNote.js.map +1 -1
- package/dist/GeoHubCompareMaps.cjs +1 -1
- package/dist/GeoHubCompareMaps.cjs.map +1 -1
- package/dist/GeoHubCompareMaps.d.ts +1 -0
- package/dist/GeoHubCompareMaps.js +264 -354
- package/dist/GeoHubCompareMaps.js.map +1 -1
- package/dist/GeoHubMap.cjs +1 -1
- package/dist/GeoHubMap.cjs.map +1 -1
- package/dist/GeoHubMap.d.ts +1 -0
- package/dist/GeoHubMap.js +214 -409
- package/dist/GeoHubMap.js.map +1 -1
- package/dist/GeoHubMapWithLayerSelection.cjs +1 -1
- package/dist/GeoHubMapWithLayerSelection.cjs.map +1 -1
- package/dist/GeoHubMapWithLayerSelection.d.ts +1 -0
- package/dist/GeoHubMapWithLayerSelection.js +192 -293
- package/dist/GeoHubMapWithLayerSelection.js.map +1 -1
- package/dist/GraphContainer-CRqzdKu2.js +78 -0
- package/dist/GraphContainer-CRqzdKu2.js.map +1 -0
- package/dist/GraphContainer-d8A46BK2.cjs +2 -0
- package/dist/GraphContainer-d8A46BK2.cjs.map +1 -0
- package/dist/GraphDescription.cjs +1 -1
- package/dist/GraphDescription.cjs.map +1 -1
- package/dist/GraphDescription.js +23 -17
- package/dist/GraphDescription.js.map +1 -1
- package/dist/GraphEl-BkyLYXG5.cjs +2 -0
- package/dist/GraphEl-BkyLYXG5.cjs.map +1 -0
- package/dist/{GraphEl-CqWzvOyr.js → GraphEl-DzRon4cb.js} +184 -202
- package/dist/GraphEl-DzRon4cb.js.map +1 -0
- package/dist/GraphFooter.cjs +1 -1
- package/dist/GraphFooter.cjs.map +1 -1
- package/dist/GraphFooter.js +28 -18
- package/dist/GraphFooter.js.map +1 -1
- package/dist/GraphHeader.cjs +1 -1
- package/dist/GraphHeader.cjs.map +1 -1
- package/dist/GraphHeader.d.ts +2 -1
- package/dist/GraphHeader.js +45 -59
- package/dist/GraphHeader.js.map +1 -1
- package/dist/GraphTitle.cjs +1 -1
- package/dist/GraphTitle.cjs.map +1 -1
- package/dist/GraphTitle.js +29 -24
- package/dist/GraphTitle.js.map +1 -1
- package/dist/GriddedGraphs.cjs +1 -1
- package/dist/GriddedGraphs.cjs.map +1 -1
- package/dist/GriddedGraphs.d.ts +2 -0
- package/dist/GriddedGraphs.js +216 -450
- package/dist/GriddedGraphs.js.map +1 -1
- package/dist/GriddedGraphsFromConfig.cjs +1 -1
- package/dist/GriddedGraphsFromConfig.cjs.map +1 -1
- package/dist/GriddedGraphsFromConfig.d.ts +2 -0
- package/dist/GriddedGraphsFromConfig.js +22 -36
- package/dist/GriddedGraphsFromConfig.js.map +1 -1
- package/dist/HeatMap.cjs +1 -1
- package/dist/HeatMap.cjs.map +1 -1
- package/dist/HeatMap.d.ts +1 -0
- package/dist/HeatMap.js +278 -446
- package/dist/HeatMap.js.map +1 -1
- package/dist/Histogram.cjs +1 -1
- package/dist/Histogram.cjs.map +1 -1
- package/dist/Histogram.d.ts +1 -0
- package/dist/Histogram.js +154 -264
- package/dist/Histogram.js.map +1 -1
- package/dist/ImageDownloadButton.cjs +1 -1
- package/dist/ImageDownloadButton.cjs.map +1 -1
- package/dist/ImageDownloadButton.d.ts +2 -1
- package/dist/ImageDownloadButton.js +21 -25
- package/dist/ImageDownloadButton.js.map +1 -1
- package/dist/LineChartWithConfidenceInterval.cjs +1 -1
- package/dist/LineChartWithConfidenceInterval.cjs.map +1 -1
- package/dist/LineChartWithConfidenceInterval.d.ts +1 -0
- package/dist/LineChartWithConfidenceInterval.js +674 -825
- package/dist/LineChartWithConfidenceInterval.js.map +1 -1
- package/dist/LinearColorLegend.cjs +1 -1
- package/dist/LinearColorLegend.cjs.map +1 -1
- package/dist/LinearColorLegend.js +49 -30
- package/dist/LinearColorLegend.js.map +1 -1
- package/dist/Modal-DGcuAHyK.js +1047 -0
- package/dist/Modal-DGcuAHyK.js.map +1 -0
- package/dist/Modal-JW_IExO3.cjs +46 -0
- package/dist/Modal-JW_IExO3.cjs.map +1 -0
- package/dist/MultiGraphDashboard.cjs +1 -1
- package/dist/MultiGraphDashboard.cjs.map +1 -1
- package/dist/MultiGraphDashboard.d.ts +2 -0
- package/dist/MultiGraphDashboard.js +122 -290
- package/dist/MultiGraphDashboard.js.map +1 -1
- package/dist/MultiGraphDashboardFromConfig.cjs +1 -1
- package/dist/MultiGraphDashboardFromConfig.cjs.map +1 -1
- package/dist/MultiGraphDashboardFromConfig.d.ts +2 -0
- package/dist/MultiGraphDashboardFromConfig.js +22 -31
- package/dist/MultiGraphDashboardFromConfig.js.map +1 -1
- package/dist/MultiGraphDashboardWideToLongFormat.cjs +1 -1
- package/dist/MultiGraphDashboardWideToLongFormat.cjs.map +1 -1
- package/dist/MultiGraphDashboardWideToLongFormat.d.ts +1 -0
- package/dist/MultiGraphDashboardWideToLongFormat.js +137 -223
- package/dist/MultiGraphDashboardWideToLongFormat.js.map +1 -1
- package/dist/MultiGraphDashboardWideToLongFormatFromConfig.cjs +1 -1
- package/dist/MultiGraphDashboardWideToLongFormatFromConfig.cjs.map +1 -1
- package/dist/MultiGraphDashboardWideToLongFormatFromConfig.d.ts +1 -0
- package/dist/MultiGraphDashboardWideToLongFormatFromConfig.js +25 -27
- package/dist/MultiGraphDashboardWideToLongFormatFromConfig.js.map +1 -1
- package/dist/MultiLineAltChart.cjs +1 -1
- package/dist/MultiLineAltChart.cjs.map +1 -1
- package/dist/MultiLineAltChart.d.ts +1 -0
- package/dist/MultiLineAltChart.js +581 -659
- package/dist/MultiLineAltChart.js.map +1 -1
- package/dist/MultiLineChart.cjs +1 -1
- package/dist/MultiLineChart.cjs.map +1 -1
- package/dist/MultiLineChart.d.ts +1 -0
- package/dist/MultiLineChart.js +617 -725
- package/dist/MultiLineChart.js.map +1 -1
- package/dist/ParetoChart.cjs +1 -1
- package/dist/ParetoChart.cjs.map +1 -1
- package/dist/ParetoChart.d.ts +1 -0
- package/dist/ParetoChart.js +531 -635
- package/dist/ParetoChart.js.map +1 -1
- package/dist/PerformanceIntensiveMultiGraphDashboard.cjs +1 -1
- package/dist/PerformanceIntensiveMultiGraphDashboard.cjs.map +1 -1
- package/dist/PerformanceIntensiveMultiGraphDashboard.d.ts +2 -0
- package/dist/PerformanceIntensiveMultiGraphDashboard.js +147 -338
- package/dist/PerformanceIntensiveMultiGraphDashboard.js.map +1 -1
- package/dist/PerformanceIntensiveMultiGraphDashboardFromConfig.cjs +1 -1
- package/dist/PerformanceIntensiveMultiGraphDashboardFromConfig.cjs.map +1 -1
- package/dist/PerformanceIntensiveMultiGraphDashboardFromConfig.d.ts +2 -0
- package/dist/PerformanceIntensiveMultiGraphDashboardFromConfig.js +22 -31
- package/dist/PerformanceIntensiveMultiGraphDashboardFromConfig.js.map +1 -1
- package/dist/PerformanceIntensiveScrollStory.cjs +1 -1
- package/dist/PerformanceIntensiveScrollStory.cjs.map +1 -1
- package/dist/PerformanceIntensiveScrollStory.d.ts +2 -0
- package/dist/PerformanceIntensiveScrollStory.js +93 -114
- package/dist/PerformanceIntensiveScrollStory.js.map +1 -1
- package/dist/RadarChart.cjs +1 -1
- package/dist/RadarChart.cjs.map +1 -1
- package/dist/RadarChart.d.ts +1 -0
- package/dist/RadarChart.js +426 -575
- package/dist/RadarChart.js.map +1 -1
- package/dist/ReferenceLine-2XCwHXQ4.js +162 -0
- package/dist/ReferenceLine-2XCwHXQ4.js.map +1 -0
- package/dist/ReferenceLine-BH0qdf4R.cjs +2 -0
- package/dist/ReferenceLine-BH0qdf4R.cjs.map +1 -0
- package/dist/RegressionLine-BOTTNSrr.cjs +2 -0
- package/dist/RegressionLine-BOTTNSrr.cjs.map +1 -0
- package/dist/RegressionLine-DAcY2DjT.js +87 -0
- package/dist/RegressionLine-DAcY2DjT.js.map +1 -0
- package/dist/SVGDownloadButton.cjs +1 -1
- package/dist/SVGDownloadButton.cjs.map +1 -1
- package/dist/SVGDownloadButton.js +21 -25
- package/dist/SVGDownloadButton.js.map +1 -1
- package/dist/SankeyChart.cjs +1 -1
- package/dist/SankeyChart.cjs.map +1 -1
- package/dist/SankeyChart.d.ts +1 -0
- package/dist/SankeyChart.js +665 -854
- package/dist/SankeyChart.js.map +1 -1
- package/dist/ScatterPlot.cjs +1 -1
- package/dist/ScatterPlot.cjs.map +1 -1
- package/dist/ScatterPlot.d.ts +1 -0
- package/dist/ScatterPlot.js +675 -815
- package/dist/ScatterPlot.js.map +1 -1
- package/dist/ScrollStory.cjs +1 -1
- package/dist/ScrollStory.cjs.map +1 -1
- package/dist/ScrollStory.d.ts +2 -0
- package/dist/ScrollStory.js +85 -97
- package/dist/ScrollStory.js.map +1 -1
- package/dist/SimpleLineChart.cjs +1 -1
- package/dist/SimpleLineChart.cjs.map +1 -1
- package/dist/SimpleLineChart.d.ts +1 -0
- package/dist/SimpleLineChart.js +504 -613
- package/dist/SimpleLineChart.js.map +1 -1
- package/dist/SingleGraphDashboard.cjs +1 -1
- package/dist/SingleGraphDashboard.cjs.map +1 -1
- package/dist/SingleGraphDashboard.d.ts +3 -1
- package/dist/SingleGraphDashboard.js +279 -507
- package/dist/SingleGraphDashboard.js.map +1 -1
- package/dist/SingleGraphDashboardFromConfig.cjs +1 -1
- package/dist/SingleGraphDashboardFromConfig.cjs.map +1 -1
- package/dist/SingleGraphDashboardFromConfig.d.ts +3 -1
- package/dist/SingleGraphDashboardFromConfig.js +25 -31
- package/dist/SingleGraphDashboardFromConfig.js.map +1 -1
- package/dist/SingleGraphDashboardGeoHubMaps.cjs +1 -1
- package/dist/SingleGraphDashboardGeoHubMaps.cjs.map +1 -1
- package/dist/SingleGraphDashboardGeoHubMaps.d.ts +2 -0
- package/dist/SingleGraphDashboardGeoHubMaps.js +146 -168
- package/dist/SingleGraphDashboardGeoHubMaps.js.map +1 -1
- package/dist/SingleGraphDashboardGeoHubMapsFromConfig.cjs +1 -1
- package/dist/SingleGraphDashboardGeoHubMapsFromConfig.cjs.map +1 -1
- package/dist/SingleGraphDashboardGeoHubMapsFromConfig.d.ts +2 -0
- package/dist/SingleGraphDashboardGeoHubMapsFromConfig.js +25 -21
- package/dist/SingleGraphDashboardGeoHubMapsFromConfig.js.map +1 -1
- package/dist/SingleGraphDashboardThreeDGraphs.cjs +1 -1
- package/dist/SingleGraphDashboardThreeDGraphs.cjs.map +1 -1
- package/dist/SingleGraphDashboardThreeDGraphs.d.ts +2 -0
- package/dist/SingleGraphDashboardThreeDGraphs.js +356 -589
- package/dist/SingleGraphDashboardThreeDGraphs.js.map +1 -1
- package/dist/SingleGraphDashboardThreeDGraphsFromConfig.cjs +1 -1
- package/dist/SingleGraphDashboardThreeDGraphsFromConfig.cjs.map +1 -1
- package/dist/SingleGraphDashboardThreeDGraphsFromConfig.d.ts +2 -0
- package/dist/SingleGraphDashboardThreeDGraphsFromConfig.js +25 -31
- package/dist/SingleGraphDashboardThreeDGraphsFromConfig.js.map +1 -1
- package/dist/SlopeChart.cjs +1 -1
- package/dist/SlopeChart.cjs.map +1 -1
- package/dist/SlopeChart.d.ts +1 -0
- package/dist/SlopeChart.js +539 -573
- package/dist/SlopeChart.js.map +1 -1
- package/dist/Source-DYMJRrsq.cjs +2 -0
- package/dist/Source-DYMJRrsq.cjs.map +1 -0
- package/dist/Source-DwTHB8fn.js +78 -0
- package/dist/Source-DwTHB8fn.js.map +1 -0
- package/dist/Source.cjs +1 -1
- package/dist/Source.cjs.map +1 -1
- package/dist/Source.js +4 -38
- package/dist/Source.js.map +1 -1
- package/dist/SparkLine.cjs +1 -1
- package/dist/SparkLine.cjs.map +1 -1
- package/dist/SparkLine.d.ts +1 -0
- package/dist/SparkLine.js +286 -314
- package/dist/SparkLine.js.map +1 -1
- package/dist/Spinner-D7rnnwnA.js +47 -0
- package/dist/Spinner-D7rnnwnA.js.map +1 -0
- package/dist/Spinner-DRMBUsX7.cjs +2 -0
- package/dist/Spinner-DRMBUsX7.cjs.map +1 -0
- package/dist/StatCardFromData.cjs +1 -1
- package/dist/StatCardFromData.cjs.map +1 -1
- package/dist/StatCardFromData.d.ts +1 -0
- package/dist/StatCardFromData.js +163 -243
- package/dist/StatCardFromData.js.map +1 -1
- package/dist/StripChart.cjs +1 -1
- package/dist/StripChart.cjs.map +1 -1
- package/dist/StripChart.d.ts +1 -0
- package/dist/StripChart.js +665 -983
- package/dist/StripChart.js.map +1 -1
- package/dist/ThreeDGlobe.cjs +1 -1
- package/dist/ThreeDGlobe.cjs.map +1 -1
- package/dist/ThreeDGlobe.d.ts +3 -0
- package/dist/ThreeDGlobe.js +355 -526
- package/dist/ThreeDGlobe.js.map +1 -1
- package/dist/ThresholdColorLegendWithMouseOver.cjs +1 -1
- package/dist/ThresholdColorLegendWithMouseOver.cjs.map +1 -1
- package/dist/ThresholdColorLegendWithMouseOver.js +96 -126
- package/dist/ThresholdColorLegendWithMouseOver.js.map +1 -1
- package/dist/Tooltip-4dJo4_AF.cjs +2 -0
- package/dist/Tooltip-4dJo4_AF.cjs.map +1 -0
- package/dist/Tooltip-CwWUegPB.js +43 -0
- package/dist/Tooltip-CwWUegPB.js.map +1 -0
- package/dist/TreeMapGraph.cjs +1 -1
- package/dist/TreeMapGraph.cjs.map +1 -1
- package/dist/TreeMapGraph.d.ts +1 -0
- package/dist/TreeMapGraph.js +479 -617
- package/dist/TreeMapGraph.js.map +1 -1
- package/dist/Types.d.ts +2 -0
- package/dist/Typography-DX7PlgQU.cjs +2 -0
- package/dist/Typography-DX7PlgQU.cjs.map +1 -0
- package/dist/Typography-PxtFcnJb.js +142 -0
- package/dist/Typography-PxtFcnJb.js.map +1 -0
- package/dist/UnitChart.cjs +1 -1
- package/dist/UnitChart.cjs.map +1 -1
- package/dist/UnitChart.d.ts +1 -0
- package/dist/UnitChart.js +160 -212
- package/dist/UnitChart.js.map +1 -1
- package/dist/XAxesLabels-D5X8jngD.cjs +2 -0
- package/dist/XAxesLabels-D5X8jngD.cjs.map +1 -0
- package/dist/XAxesLabels-DNO0KmjL.js +73 -0
- package/dist/XAxesLabels-DNO0KmjL.js.map +1 -0
- package/dist/XTicksAndGridLines-B6CELS7q.cjs +2 -0
- package/dist/XTicksAndGridLines-B6CELS7q.cjs.map +1 -0
- package/dist/XTicksAndGridLines-CObVFSm4.js +38 -0
- package/dist/XTicksAndGridLines-CObVFSm4.js.map +1 -0
- package/dist/YAxesLabels-DcS85Beo.cjs +2 -0
- package/dist/YAxesLabels-DcS85Beo.cjs.map +1 -0
- package/dist/YAxesLabels-Dnnng49-.js +70 -0
- package/dist/YAxesLabels-Dnnng49-.js.map +1 -0
- package/dist/YTicksAndGridLines-4pxTRlRK.cjs +2 -0
- package/dist/YTicksAndGridLines-4pxTRlRK.cjs.map +1 -0
- package/dist/YTicksAndGridLines-Blepl7XF.js +38 -0
- package/dist/YTicksAndGridLines-Blepl7XF.js.map +1 -0
- package/dist/{band-BEjh2CHI.js → band-CyHaVft5.js} +3 -3
- package/dist/{band-BEjh2CHI.js.map → band-CyHaVft5.js.map} +1 -1
- package/dist/{band-CAApY4Pd.cjs → band-VYfcZeJ2.cjs} +2 -2
- package/dist/{band-CAApY4Pd.cjs.map → band-VYfcZeJ2.cjs.map} +1 -1
- package/dist/checkIfMultiple-Y9iKaV_u.js +950 -0
- package/dist/checkIfMultiple-Y9iKaV_u.js.map +1 -0
- package/dist/checkIfMultiple-wg6hJLXy.cjs +12 -0
- package/dist/checkIfMultiple-wg6hJLXy.cjs.map +1 -0
- package/dist/customArea-BUhPiPT6.js +163 -0
- package/dist/{customArea-B-dWU0zZ.js.map → customArea-BUhPiPT6.js.map} +1 -1
- package/dist/customArea-CMF5g-C3.cjs +2 -0
- package/dist/{customArea-CK768gCn.cjs.map → customArea-CMF5g-C3.cjs.map} +1 -1
- package/dist/delaunay-C1uAf38t.js.map +1 -1
- package/dist/delaunay-rcy0HhZi.cjs.map +1 -1
- package/dist/{ensureCompleteData-DlmibgaI.js → ensureCompleteData-DNKEGRiP.js} +12 -32
- package/dist/{ensureCompleteData-DlmibgaI.js.map → ensureCompleteData-DNKEGRiP.js.map} +1 -1
- package/dist/{ensureCompleteData-DkQYPeDa.cjs → ensureCompleteData-I6nYmT8E.cjs} +2 -2
- package/dist/{ensureCompleteData-DkQYPeDa.cjs.map → ensureCompleteData-I6nYmT8E.cjs.map} +1 -1
- package/dist/{excelDownload-BOA-lskf.js → excelDownload-BEC1AyQW.js} +12 -2
- package/dist/{excelDownload-BOA-lskf.js.map → excelDownload-BEC1AyQW.js.map} +1 -1
- package/dist/excelDownload-BQpsCa62.cjs.map +1 -1
- package/dist/{fetchAndParseData-sapWbnYk.js → fetchAndParseData-BpqkBPQL.js} +15 -28
- package/dist/{fetchAndParseData-sapWbnYk.js.map → fetchAndParseData-BpqkBPQL.js.map} +1 -1
- package/dist/fetchAndParseData-l5HGMAEs.cjs +16 -0
- package/dist/{fetchAndParseData-Ba-_CgxS.cjs.map → fetchAndParseData-l5HGMAEs.cjs.map} +1 -1
- package/dist/fetchAndParseData.cjs +1 -1
- package/dist/fetchAndParseData.js +1 -1
- package/dist/{filterData-9nEcQ-Jp.js → filterData-DsAiFzKY.js} +3 -5
- package/dist/{filterData-9nEcQ-Jp.js.map → filterData-DsAiFzKY.js.map} +1 -1
- package/dist/{filterData-BoYadk0l.cjs → filterData-T5DQBE9b.cjs} +2 -2
- package/dist/{filterData-BoYadk0l.cjs.map → filterData-T5DQBE9b.cjs.map} +1 -1
- package/dist/generateRandomString-B5zBiJzS.cjs.map +1 -1
- package/dist/generateRandomString-za3IQGfQ.js.map +1 -1
- package/dist/{getCentroidCoordinates-Dfk6IqEG.js → getCentroidCoordinates-D7r34N4w.js} +2 -2
- package/dist/{getCentroidCoordinates-Dfk6IqEG.js.map → getCentroidCoordinates-D7r34N4w.js.map} +1 -1
- package/dist/{getCentroidCoordinates-DxTBqzp2.cjs → getCentroidCoordinates-Dng1HVjO.cjs} +2 -2
- package/dist/{getCentroidCoordinates-DxTBqzp2.cjs.map → getCentroidCoordinates-Dng1HVjO.cjs.map} +1 -1
- package/dist/getGraphList-BpEWn1Tk.js +227 -0
- package/dist/{getGraphList-DuColTJM.js.map → getGraphList-BpEWn1Tk.js.map} +1 -1
- package/dist/getGraphList-gf02xgT2.cjs.map +1 -1
- package/dist/getJenks-BbngDoBQ.js.map +1 -1
- package/dist/getJenks-GYmdwBqm.cjs.map +1 -1
- package/dist/getSchema.cjs.map +1 -1
- package/dist/getSchema.js +445 -231
- package/dist/getSchema.js.map +1 -1
- package/dist/getSliderMarks-BmADcPQt.cjs +6 -0
- package/dist/getSliderMarks-BmADcPQt.cjs.map +1 -0
- package/dist/getSliderMarks-HIDJ0_Cd.js +1033 -0
- package/dist/getSliderMarks-HIDJ0_Cd.js.map +1 -0
- package/dist/{getTextColorBasedOnBgColor-B6Nk2WBf.js → getTextColorBasedOnBgColor-CDY808zi.js} +11 -3
- package/dist/{getTextColorBasedOnBgColor-B6Nk2WBf.js.map → getTextColorBasedOnBgColor-CDY808zi.js.map} +1 -1
- package/dist/getTextColorBasedOnBgColor-nqY-bsM_.cjs.map +1 -1
- package/dist/{getUniqValue-DiCh_MOD.js → getUniqValue-BKHCm3zE.js} +2 -4
- package/dist/{getUniqValue-DiCh_MOD.js.map → getUniqValue-BKHCm3zE.js.map} +1 -1
- package/dist/getUniqValue-RViz8tTw.cjs.map +1 -1
- package/dist/{imageDownload-Dcci2LEy.js → imageDownload-BX6SILNZ.js} +4 -2
- package/dist/{imageDownload-Dcci2LEy.js.map → imageDownload-BX6SILNZ.js.map} +1 -1
- package/dist/imageDownload-CgDcm1Sj.cjs.map +1 -1
- package/dist/{index-DvVprvy6.js → index-BZQYSqar.js} +7 -7
- package/dist/{index-DvVprvy6.js.map → index-BZQYSqar.js.map} +1 -1
- package/dist/index-B_sAFsEV.cjs +2 -0
- package/dist/{index-BYzIB5V6.cjs.map → index-B_sAFsEV.cjs.map} +1 -1
- package/dist/index-BqfRwk1n.js +146 -0
- package/dist/index-BqfRwk1n.js.map +1 -0
- package/dist/{index-V_JXij1_.js → index-BuwmuDFJ.js} +3 -3
- package/dist/{index-V_JXij1_.js.map → index-BuwmuDFJ.js.map} +1 -1
- package/dist/index-CHPV5EwG-CTPQjnHt.cjs +84 -0
- package/dist/index-CHPV5EwG-CTPQjnHt.cjs.map +1 -0
- package/dist/{index-CHPV5EwG-BPSP-7Jg.js → index-CHPV5EwG-Curnpaqc.js} +937 -842
- package/dist/index-CHPV5EwG-Curnpaqc.js.map +1 -0
- package/dist/index-Cno4Q0YE.cjs +2 -0
- package/dist/{index-CQ3e6Ewi.cjs.map → index-Cno4Q0YE.cjs.map} +1 -1
- package/dist/{index-tvAyXPPW-DBlMKnNB.js → index-Cw8sCyo_-B2hEKjzG.js} +16 -16
- package/dist/{index-tvAyXPPW-DBlMKnNB.js.map → index-Cw8sCyo_-B2hEKjzG.js.map} +1 -1
- package/dist/index-Cw8sCyo_-BrHiWiRF.cjs +2 -0
- package/dist/index-Cw8sCyo_-BrHiWiRF.cjs.map +1 -0
- package/dist/index-CyZ1lmi_.cjs +2 -0
- package/dist/{index-D72cOtq7.cjs.map → index-CyZ1lmi_.cjs.map} +1 -1
- package/dist/index-D491FEn1.js +184 -0
- package/dist/index-D491FEn1.js.map +1 -0
- package/dist/index-DG2bgAva.cjs +10 -0
- package/dist/index-DG2bgAva.cjs.map +1 -0
- package/dist/index-DRXx7m-C.cjs +2 -0
- package/dist/index-DRXx7m-C.cjs.map +1 -0
- package/dist/index-DoY3Ga3W.cjs +2 -0
- package/dist/index-DoY3Ga3W.cjs.map +1 -0
- package/dist/index-DxXnJ8Ti.cjs +2 -0
- package/dist/index-DxXnJ8Ti.cjs.map +1 -0
- package/dist/{index-DG3YrCr5-D3FrrXj8.js → index-Dzc_aaI9-Bb7gobH_.js} +2 -2
- package/dist/{index-DG3YrCr5-D3FrrXj8.js.map → index-Dzc_aaI9-Bb7gobH_.js.map} +1 -1
- package/dist/{index-DG3YrCr5-v7rayV3N.cjs → index-Dzc_aaI9-BmkfPMyc.cjs} +2 -2
- package/dist/{index-DG3YrCr5-v7rayV3N.cjs.map → index-Dzc_aaI9-BmkfPMyc.cjs.map} +1 -1
- package/dist/{index-9tDEUqOZ.js → index-GEsywGxz.js} +9 -9
- package/dist/index-GEsywGxz.js.map +1 -0
- package/dist/index-SKgJALZg.js +99 -0
- package/dist/{index-DKCxu1Gh.js.map → index-SKgJALZg.js.map} +1 -1
- package/dist/index-leTnKT2q.js +329 -0
- package/dist/index-leTnKT2q.js.map +1 -0
- package/dist/index.cjs +1 -1
- package/dist/index.d.ts +19 -8
- package/dist/index.js +13 -13
- package/dist/{init-BhZylTFx.js → init-BJFW6EwE.js} +3 -3
- package/dist/{init-BhZylTFx.js.map → init-BJFW6EwE.js.map} +1 -1
- package/dist/{linear-BVckp9RD.cjs → linear-BwPAspcq.cjs} +2 -2
- package/dist/{linear-BVckp9RD.cjs.map → linear-BwPAspcq.cjs.map} +1 -1
- package/dist/{linear-DUdu7l2G.js → linear-BwnDd9KF.js} +3 -3
- package/dist/{linear-DUdu7l2G.js.map → linear-BwnDd9KF.js.map} +1 -1
- package/dist/numberFormattingFunction-02t-wJta.cjs.map +1 -1
- package/dist/numberFormattingFunction-14YCbkN2.js.map +1 -1
- package/dist/{ordinal-BOeNbyae.cjs → ordinal-CrsysVE-.cjs} +2 -2
- package/dist/ordinal-CrsysVE-.cjs.map +1 -0
- package/dist/{ordinal-w9Lu4Stb.js → ordinal-P77xw8aL.js} +24 -24
- package/dist/ordinal-P77xw8aL.js.map +1 -0
- package/dist/{pow-e8zx3AQJ.js → pow-DE4c7dbW.js} +3 -3
- package/dist/{pow-e8zx3AQJ.js.map → pow-DE4c7dbW.js.map} +1 -1
- package/dist/{pow-B5-jkdHU.cjs → pow-DgrUorRi.cjs} +2 -2
- package/dist/{pow-B5-jkdHU.cjs.map → pow-DgrUorRi.cjs.map} +1 -1
- package/dist/{proxy-CkpFesk1.js → proxy-BxkFHwUw.js} +144 -134
- package/dist/proxy-BxkFHwUw.js.map +1 -0
- package/dist/proxy-BxvUI_9l.cjs +2 -0
- package/dist/proxy-BxvUI_9l.cjs.map +1 -0
- package/dist/{removeOutliers-DR48e-18.js → removeOutliers-BqW0sPqj.js} +2 -5
- package/dist/{removeOutliers-DR48e-18.js.map → removeOutliers-BqW0sPqj.js.map} +1 -1
- package/dist/removeOutliers-WELHHqiI.cjs.map +1 -1
- package/dist/{sort-DfK1b0F5.js → sort-BIvMlUH1.js} +5 -5
- package/dist/{sort-DfK1b0F5.js.map → sort-BIvMlUH1.js.map} +1 -1
- package/dist/{string-CRoCZCYa.cjs → string-C-kRh1bQ.cjs} +2 -2
- package/dist/{string-CRoCZCYa.cjs.map → string-C-kRh1bQ.cjs.map} +1 -1
- package/dist/{string-B8KlVSPX.js → string-C_xJ4Wg4.js} +3 -3
- package/dist/{string-B8KlVSPX.js.map → string-C_xJ4Wg4.js.map} +1 -1
- package/dist/string2HTML-CPGr_I5E.cjs +3 -0
- package/dist/{string2HTML-z7CwHXcx.cjs.map → string2HTML-CPGr_I5E.cjs.map} +1 -1
- package/dist/{string2HTML-oFCROsus.js → string2HTML-DhG75NqA.js} +15 -9
- package/dist/{string2HTML-oFCROsus.js.map → string2HTML-DhG75NqA.js.map} +1 -1
- package/dist/style.css +1 -1
- package/dist/{svgDownload-C2-E3yf2.js → svgDownload-BAoarWNt.js} +4 -2
- package/dist/{svgDownload-C2-E3yf2.js.map → svgDownload-BAoarWNt.js.map} +1 -1
- package/dist/svgDownload-D9zEGjTF.cjs.map +1 -1
- package/dist/{threshold-DFfqcDMa.js → threshold-Bgr20hik.js} +2 -2
- package/dist/{threshold-DFfqcDMa.js.map → threshold-Bgr20hik.js.map} +1 -1
- package/dist/{time-Byw_jYQ7.cjs → time-CZd5YLSP.cjs} +2 -2
- package/dist/{time-Byw_jYQ7.cjs.map → time-CZd5YLSP.cjs.map} +1 -1
- package/dist/{time-BzJP5SPC.js → time-DCCfQk3V.js} +3 -3
- package/dist/{time-BzJP5SPC.js.map → time-DCCfQk3V.js.map} +1 -1
- package/dist/transformData.cjs +1 -1
- package/dist/transformData.js +3 -3
- package/dist/transformDataForAggregation-CE3bAlHU.js +585 -0
- package/dist/{transformDataForAggregation-sBpdlX8n.js.map → transformDataForAggregation-CE3bAlHU.js.map} +1 -1
- package/dist/transformDataForAggregation-KXGm6flX.cjs.map +1 -1
- package/dist/transformDataForGraphFromFile-BExxcITV.js +14 -0
- package/dist/{transformDataForGraphFromFile-ComYvzuz.js.map → transformDataForGraphFromFile-BExxcITV.js.map} +1 -1
- package/dist/{transformDataForGraphFromFile-DVZodTHd.cjs → transformDataForGraphFromFile-DaJHQCsL.cjs} +2 -2
- package/dist/{transformDataForGraphFromFile-DVZodTHd.cjs.map → transformDataForGraphFromFile-DaJHQCsL.cjs.map} +1 -1
- package/dist/transformDataForSelect-D8AuvYdf.js.map +1 -1
- package/dist/transformDataForSelect-YmStusCI.cjs.map +1 -1
- package/dist/uniqBy-BHy4I8PK.js.map +1 -1
- package/dist/uniqBy-O05lp2S5.cjs.map +1 -1
- package/dist/{use-in-view-yS6jzJAp.js → use-in-view-Cxa7y1TH.js} +2 -2
- package/dist/use-in-view-Cxa7y1TH.js.map +1 -0
- package/dist/use-in-view-QcfiW0w3.cjs +2 -0
- package/dist/use-in-view-QcfiW0w3.cjs.map +1 -0
- package/dist/utils.cjs +1 -1
- package/dist/utils.js +8 -8
- package/dist/validateSchema.cjs.map +1 -1
- package/dist/validateSchema.js +33 -29
- package/dist/validateSchema.js.map +1 -1
- package/dist/{x-BBpi7a_7-Dz2vKSfu.cjs → x-BBpi7a_7-mTo40uId.cjs} +2 -2
- package/dist/{x-BBpi7a_7-Dz2vKSfu.cjs.map → x-BBpi7a_7-mTo40uId.cjs.map} +1 -1
- package/dist/{y-D0sAaVii.js → y-BqfogMAB.js} +3 -3
- package/dist/{y-D0sAaVii.js.map → y-BqfogMAB.js.map} +1 -1
- package/dist/{zoom-QipiAl5W.js → zoom-C9MFjAaV.js} +5 -5
- package/dist/{zoom-QipiAl5W.js.map → zoom-C9MFjAaV.js.map} +1 -1
- package/dist/zoom-DPw8bba-.cjs +2 -0
- package/dist/{zoom-BiMNsz72.cjs.map → zoom-DPw8bba-.cjs.map} +1 -1
- package/package.json +9 -8
- package/dist/Axis-DE7dSn1_.cjs +0 -2
- package/dist/Axis-DE7dSn1_.cjs.map +0 -1
- package/dist/Axis-Ddg-seDi.js +0 -43
- package/dist/Axis-Ddg-seDi.js.map +0 -1
- package/dist/AxisTitle-BmHLMRJZ.js +0 -20
- package/dist/AxisTitle-BmHLMRJZ.js.map +0 -1
- package/dist/AxisTitle-CK9YeovX.cjs +0 -2
- package/dist/AxisTitle-CK9YeovX.cjs.map +0 -1
- package/dist/DropdownSelect-CtOKZHD0.js.map +0 -1
- package/dist/DropdownSelect-DBDM64B5.cjs +0 -29
- package/dist/DropdownSelect-DBDM64B5.cjs.map +0 -1
- package/dist/EmptyState-DdTp-Mdn.js +0 -22
- package/dist/EmptyState-d8_8SxeW.cjs +0 -2
- package/dist/GraphEl-C6yjl1VM.cjs +0 -2
- package/dist/GraphEl-C6yjl1VM.cjs.map +0 -1
- package/dist/GraphEl-CqWzvOyr.js.map +0 -1
- package/dist/Modal-DVVwpKhP.js +0 -1019
- package/dist/Modal-DVVwpKhP.js.map +0 -1
- package/dist/Modal-tXZlLE5s.cjs +0 -46
- package/dist/Modal-tXZlLE5s.cjs.map +0 -1
- package/dist/ReferenceLine-CFVBBN__.cjs +0 -2
- package/dist/ReferenceLine-CFVBBN__.cjs.map +0 -1
- package/dist/ReferenceLine-CfAW3vKJ.js +0 -128
- package/dist/ReferenceLine-CfAW3vKJ.js.map +0 -1
- package/dist/RegressionLine-C2--oMQq.js +0 -49
- package/dist/RegressionLine-C2--oMQq.js.map +0 -1
- package/dist/RegressionLine-Dj0GSiAp.cjs +0 -2
- package/dist/RegressionLine-Dj0GSiAp.cjs.map +0 -1
- package/dist/Spinner-C85UF28E.js +0 -30
- package/dist/Spinner-C85UF28E.js.map +0 -1
- package/dist/Spinner-DA6Z5E4n.cjs +0 -2
- package/dist/Spinner-DA6Z5E4n.cjs.map +0 -1
- package/dist/Tooltip-CVCGWyzw.js +0 -46
- package/dist/Tooltip-CVCGWyzw.js.map +0 -1
- package/dist/Tooltip-De16GWhY.cjs +0 -2
- package/dist/Tooltip-De16GWhY.cjs.map +0 -1
- package/dist/Typography-Ctgfl1J5.js +0 -140
- package/dist/Typography-Ctgfl1J5.js.map +0 -1
- package/dist/Typography-k-kOjICQ.cjs +0 -2
- package/dist/Typography-k-kOjICQ.cjs.map +0 -1
- package/dist/XAxesLabels-Drf7M3YK.cjs +0 -2
- package/dist/XAxesLabels-Drf7M3YK.cjs.map +0 -1
- package/dist/XAxesLabels-loO78vUO.js +0 -57
- package/dist/XAxesLabels-loO78vUO.js.map +0 -1
- package/dist/XTicksAndGridLines-Bn9u5gOM.js +0 -56
- package/dist/XTicksAndGridLines-Bn9u5gOM.js.map +0 -1
- package/dist/XTicksAndGridLines-CCzXIV8d.cjs +0 -2
- package/dist/XTicksAndGridLines-CCzXIV8d.cjs.map +0 -1
- package/dist/YAxesLabels-DECkMgq8.js +0 -52
- package/dist/YAxesLabels-DECkMgq8.js.map +0 -1
- package/dist/YAxesLabels-yRFFdx1s.cjs +0 -2
- package/dist/YAxesLabels-yRFFdx1s.cjs.map +0 -1
- package/dist/YTicksAndGridLines-B6ah7CRf.js +0 -56
- package/dist/YTicksAndGridLines-B6ah7CRf.js.map +0 -1
- package/dist/YTicksAndGridLines-DBDuz6vb.cjs +0 -2
- package/dist/YTicksAndGridLines-DBDuz6vb.cjs.map +0 -1
- package/dist/checkIfMultiple-BXbHUCWM.cjs +0 -12
- package/dist/checkIfMultiple-BXbHUCWM.cjs.map +0 -1
- package/dist/checkIfMultiple-ChTJk2Tk.js +0 -912
- package/dist/checkIfMultiple-ChTJk2Tk.js.map +0 -1
- package/dist/customArea-B-dWU0zZ.js +0 -175
- package/dist/customArea-CK768gCn.cjs +0 -2
- package/dist/fetchAndParseData-Ba-_CgxS.cjs +0 -16
- package/dist/getGraphList-DuColTJM.js +0 -265
- package/dist/getSliderMarks-9cNoRkDx.js +0 -1023
- package/dist/getSliderMarks-9cNoRkDx.js.map +0 -1
- package/dist/getSliderMarks-CRIbTGYV.cjs +0 -6
- package/dist/getSliderMarks-CRIbTGYV.cjs.map +0 -1
- package/dist/index-37q0ULNQ.js +0 -430
- package/dist/index-37q0ULNQ.js.map +0 -1
- package/dist/index-9tDEUqOZ.js.map +0 -1
- package/dist/index-BW8iNx7E.cjs +0 -10
- package/dist/index-BW8iNx7E.cjs.map +0 -1
- package/dist/index-BW_-wD2k.cjs +0 -2
- package/dist/index-BW_-wD2k.cjs.map +0 -1
- package/dist/index-BYzIB5V6.cjs +0 -2
- package/dist/index-BmCqpO1B.js +0 -342
- package/dist/index-BmCqpO1B.js.map +0 -1
- package/dist/index-CHPV5EwG-BPSP-7Jg.js.map +0 -1
- package/dist/index-CHPV5EwG-DDoeWRVt.cjs +0 -44
- package/dist/index-CHPV5EwG-DDoeWRVt.cjs.map +0 -1
- package/dist/index-CNvov0eg.js +0 -122
- package/dist/index-CNvov0eg.js.map +0 -1
- package/dist/index-CQ3e6Ewi.cjs +0 -2
- package/dist/index-CVlCtJbC.cjs +0 -2
- package/dist/index-CVlCtJbC.cjs.map +0 -1
- package/dist/index-CoZbeNM9.cjs +0 -2
- package/dist/index-CoZbeNM9.cjs.map +0 -1
- package/dist/index-D72cOtq7.cjs +0 -2
- package/dist/index-DKCxu1Gh.js +0 -77
- package/dist/index-tvAyXPPW-DPOG-C2i.cjs +0 -2
- package/dist/index-tvAyXPPW-DPOG-C2i.cjs.map +0 -1
- package/dist/ordinal-BOeNbyae.cjs.map +0 -1
- package/dist/ordinal-w9Lu4Stb.js.map +0 -1
- package/dist/proxy-BHRoeZgd.cjs +0 -2
- package/dist/proxy-BHRoeZgd.cjs.map +0 -1
- package/dist/proxy-CkpFesk1.js.map +0 -1
- package/dist/string2HTML-z7CwHXcx.cjs +0 -3
- package/dist/transformDataForAggregation-sBpdlX8n.js +0 -755
- package/dist/transformDataForGraphFromFile-ComYvzuz.js +0 -24
- package/dist/use-in-view-sQJZ_xDO.cjs +0 -2
- package/dist/use-in-view-sQJZ_xDO.cjs.map +0 -1
- package/dist/use-in-view-yS6jzJAp.js.map +0 -1
- package/dist/zoom-BiMNsz72.cjs +0 -2
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const t=require("./index-CHPV5EwG-DDoeWRVt.cjs"),h=require("react"),F=require("./parse-hMnG_lRV.cjs"),Ne=require("./index-CQ3e6Ewi.cjs"),ae=require("./numberFormattingFunction-02t-wJta.cjs"),Ie=require("./Tooltip-De16GWhY.cjs"),f=require("./checkIfNullOrUndefined-BCW3Y1ML.cjs"),Oe=require("./XTicksAndGridLines-CCzXIV8d.cjs"),ye=require("./Axis-DE7dSn1_.cjs"),we=require("./AxisTitle-CK9YeovX.cjs"),Le=require("./index-BYzIB5V6.cjs"),qe=require("./time-Byw_jYQ7.cjs"),Ee=require("./linear-BVckp9RD.cjs"),ge=require("./line-DHV4JwCR.cjs"),oe=require("./step-BZ3C8QFW.cjs"),De=require("./select-Bnfk0lJx.cjs"),Se=require("./init-DU0ybBc_.cjs"),Me=require("./pointer-Dkq5NV1q.cjs"),Te=require("./use-in-view-sQJZ_xDO.cjs"),b=require("./proxy-BHRoeZgd.cjs"),Ve=require("./GraphFooter.cjs"),$e=require("./GraphHeader.cjs"),Fe=require("./ColorLegend.cjs"),Re=require("./Colors.cjs"),Ce=require("./EmptyState-d8_8SxeW.cjs");function Pe(le){const{data:k,width:R,height:D,lineColors:s,labels:y,sameAxes:o,dateFormat:j,showValues:G,noOfXTicks:xe,rightMargin:ce,leftMargin:W,topMargin:X,bottomMargin:ue,tooltip:v,highlightAreaSettings:me,onSeriesMouseOver:C,animate:n,strokeWidth:Y,showDots:P,noOfYTicks:B,lineSuffixes:S,linePrefixes:M,minDate:z,maxDate:N,curveType:T,styles:l,classNames:r,precision:A,customLayers:H,showAxisLabels:J}=le,K=h.useRef(null),d=Te.useInView(K,{once:n.once,amount:n.amount}),[p,V]=h.useState(!1);h.useEffect(()=>{if(d&&!p){const e=setTimeout(()=>{V(!0)},(n.duration+.5)*1e3);return()=>clearTimeout(e)}},[d,p,n.duration]);const Q=T==="linear"?ge.curveLinear:T==="step"?oe.curveStep:T==="stepAfter"?oe.stepAfter:T==="stepBefore"?oe.stepBefore:oe.monotoneX,[I,Z]=h.useState(void 0),[_,ee]=h.useState(void 0),[te,ie]=h.useState(void 0),m={top:X,bottom:ue,left:W+50,right:ce+65},w=h.useRef(null),i=Ne.orderBy(k.map(e=>({...e,date:F.parse(`${e.date}`,j,new Date)})),["date"],["asc"]),de=me.map(e=>({...e,coordinates:[e.coordinates[0]===null?null:F.parse(`${e.coordinates[0]}`,j,new Date),e.coordinates[1]===null?null:F.parse(`${e.coordinates[1]}`,j,new Date)]})),u=R-m.left-m.right,a=D-m.top-m.bottom,se=z?F.parse(`${z}`,j,new Date):i[0].date,ne=N?F.parse(`${N}`,j,new Date):i[i.length-1].date,$=Math.min(...i.map(e=>e.y1).filter(e=>e!=null))!==1/0?Math.min(...i.map(e=>e.y2).filter(e=>e!=null))>0?0:Math.min(...i.map(e=>e.y1).filter(e=>e!=null)):0,E=Math.min(...i.map(e=>e.y2).filter(e=>e!=null))!==1/0?Math.min(...i.map(e=>e.y2).filter(e=>e!=null))>0?0:Math.min(...i.map(e=>e.y2).filter(e=>e!=null)):0,O=Math.max(...i.map(e=>e.y1).filter(e=>e!=null))!==1/0?Math.max(...i.map(e=>e.y1).filter(e=>e!=null)):0,x=Math.max(...i.map(e=>e.y2).filter(e=>e!=null))!==1/0?Math.max(...i.map(e=>e.y2).filter(e=>e!=null)):0,U=$<E?$:E,re=O>x?O:x,c=qe.time().domain([se,ne]).range([0,u]),L=Ee.linear().domain([o?U:$,o?re>0?re:0:O>0?O:0]).range([a,0]).nice(),g=Ee.linear().domain([o?U:E,o?re>0?re:0:x>0?x:0]).range([a,0]).nice(),fe=ge.line().defined(e=>!f.checkIfNullOrUndefined(e.y1)).x(e=>c(e.date)).y(e=>L(e.y1)).curve(Q),he=ge.line().defined(e=>!f.checkIfNullOrUndefined(e.y2)).x(e=>c(e.date)).y(e=>g(e.y2)).curve(Q),Ae=L.ticks(B),be=g.ticks(B),je=c.ticks(xe);return h.useEffect(()=>{const e=pe=>{const ve=i[Se.bisectCenter(i.map(ke=>ke.date),c.invert(Me.pointer(pe)[0]),0)];Z(ve||i[i.length-1]),C?.(ve||i[i.length-1]),ie(pe.clientY),ee(pe.clientX)},q=()=>{Z(void 0),ee(void 0),ie(void 0),C?.(void 0)};De.select(w.current).on("mousemove",e).on("mouseout",q)},[c,i,C]),t.jsxRuntimeExports.jsxs(t.jsxRuntimeExports.Fragment,{children:[t.jsxRuntimeExports.jsx(b.motion.svg,{width:`${R}px`,height:`${D}px`,viewBox:`0 0 ${R} ${D}`,direction:"ltr",ref:K,children:t.jsxRuntimeExports.jsxs("g",{transform:`translate(${m.left},${m.top})`,children:[t.jsxRuntimeExports.jsx(Le.HighlightArea,{areaSettings:de,width:u,height:a,scale:c,animate:n,isInView:d}),t.jsxRuntimeExports.jsxs("g",{children:[Ae.map((e,q)=>t.jsxRuntimeExports.jsxs("g",{children:[t.jsxRuntimeExports.jsx("line",{y1:L(e),y2:L(e),x1:-15,x2:-20,style:{stroke:s[0],strokeWidth:1,...l?.yAxis?.gridLines||{}},className:r?.yAxis?.gridLines}),t.jsxRuntimeExports.jsx("text",{x:-25,y:L(e),dy:"0.33em",className:t.mo("text-xs",r?.yAxis?.labels),style:{textAnchor:"end",fill:s[0],...l?.yAxis?.labels||{}},children:ae.numberFormattingFunction(e,"NA",A,M[0],S[0])})]},q)),t.jsxRuntimeExports.jsx(ye.Axis,{y1:0,y2:a,x1:-15,x2:-15,classNames:{axis:r?.xAxis?.axis},styles:{axis:{stroke:s[0],...l?.xAxis?.axis||{}}}}),J?t.jsxRuntimeExports.jsx(we.AxisTitle,{x:10-m.left,y:a/2,style:{fill:s[0],...l?.yAxis?.title||{}},className:r?.yAxis?.title,text:y[0].length>100?`${y[0].substring(0,100)}...`:y[0],rotate90:!0}):null]}),t.jsxRuntimeExports.jsxs("g",{children:[be.map((e,q)=>t.jsxRuntimeExports.jsxs("g",{children:[t.jsxRuntimeExports.jsx("line",{y1:g(e),y2:g(e),x1:u+15,x2:u+20,style:{stroke:s[1],strokeWidth:1,...l?.yAxis?.gridLines||{}},className:r?.yAxis?.gridLines}),t.jsxRuntimeExports.jsx("text",{x:u+25,y:g(e),dy:"0.33em",dx:-2,style:{textAnchor:"start",fill:s[1],...l?.yAxis?.labels||{}},className:t.mo("text-xs",r?.yAxis?.labels),children:ae.numberFormattingFunction(e,"NA",A,M[1],S[1])})]},q)),t.jsxRuntimeExports.jsx(ye.Axis,{y1:0,y2:a,x1:u+15,x2:u+15,classNames:{axis:r?.xAxis?.axis},styles:{axis:{stroke:s[1],...l?.xAxis?.axis||{}}}}),J?t.jsxRuntimeExports.jsx(we.AxisTitle,{x:u+m.right-15,y:a/2,style:{fill:s[1],...l?.yAxis?.title||{}},className:r?.yAxis?.title,text:y[1].length>100?`${y[1].substring(0,100)}...`:y[1],rotate90:!0}):null]}),t.jsxRuntimeExports.jsxs("g",{children:[t.jsxRuntimeExports.jsx(ye.Axis,{y1:a,y2:a,x1:-15,x2:u+15,classNames:{axis:r?.xAxis?.axis},styles:{axis:l?.xAxis?.axis}}),t.jsxRuntimeExports.jsx(Oe.XTicksAndGridLines,{values:je.map(e=>F.format(e,j)),x:je.map(e=>c(e)),y1:0,y2:a,styles:{gridLines:l?.xAxis?.gridLines,labels:l?.xAxis?.labels},classNames:{gridLines:t.mo("opacity-0",r?.xAxis?.gridLines),labels:t.mo("fill-primary-gray-700 dark:fill-primary-gray-300 xs:max-[360px]:hidden text-[9px] md:text-[10px] lg:text-xs",r?.xAxis?.labels)},labelType:"primary",showGridLines:!0,precision:A})]}),H.filter(e=>e.position==="before").map(e=>e.layer),t.jsxRuntimeExports.jsxs("g",{children:[t.jsxRuntimeExports.jsx(b.motion.path,{style:{stroke:s[0],strokeWidth:Y,fill:"none"},exit:{opacity:0,transition:{duration:n.duration}},variants:{initial:{pathLength:0,d:fe(i.filter(e=>!f.checkIfNullOrUndefined(e.y1)))||"",opacity:1},whileInView:{pathLength:1,d:fe(i.filter(e=>!f.checkIfNullOrUndefined(e.y1)))||"",opacity:1,transition:{duration:n.duration}}},initial:"initial",animate:d?"whileInView":"initial"}),t.jsxRuntimeExports.jsx(b.motion.path,{d:he(i.filter(e=>!f.checkIfNullOrUndefined(e.y2)))||"",style:{stroke:s[1],strokeWidth:Y,fill:"none"},exit:{opacity:0,transition:{duration:n.duration}},variants:{initial:{pathLength:0,d:he(i.filter(e=>!f.checkIfNullOrUndefined(e.y2)))||"",opacity:1},whileInView:{pathLength:1,d:he(i.filter(e=>!f.checkIfNullOrUndefined(e.y2)))||"",opacity:1,transition:{duration:n.duration}}},initial:"initial",animate:d?"whileInView":"initial"}),I?t.jsxRuntimeExports.jsx("line",{y1:0,y2:a,x1:c(I.date),x2:c(I.date),className:t.mo("undp-tick-line stroke-primary-gray-700 dark:stroke-primary-gray-100",r?.mouseOverLine),style:l?.mouseOverLine}):null]}),t.jsxRuntimeExports.jsx("g",{children:i.map((e,q)=>t.jsxRuntimeExports.jsxs(b.motion.g,{children:[f.checkIfNullOrUndefined(e.y1)?null:t.jsxRuntimeExports.jsxs(t.jsxRuntimeExports.Fragment,{children:[P?t.jsxRuntimeExports.jsx(b.motion.circle,{r:u/i.length<5?0:u/i.length<20?2:4,exit:{opacity:0,transition:{duration:n.duration}},variants:{initial:{opacity:0,cx:c(e.date),cy:L(e.y1),fill:s[0]},whileInView:{opacity:1,fill:s[0],transition:{duration:p?n.duration:.5,delay:p?0:n.duration},cx:c(e.date),cy:L(e.y1)}},initial:"initial",animate:d?"whileInView":"initial"}):null,G?t.jsxRuntimeExports.jsx(b.motion.text,{dy:f.checkIfNullOrUndefined(e.y2)||e.y2<e.y1?-8:"1em",style:{textAnchor:"middle",...l?.graphObjectValues||{}},className:t.mo("graph-value graph-value-line-1 text-xs font-bold",r?.graphObjectValues),exit:{opacity:0,transition:{duration:n.duration}},variants:{initial:{opacity:0,x:c(e.date),y:g(e.y1),fill:s[0]},whileInView:{opacity:1,x:c(e.date),fill:s[0],y:g(e.y1),transition:{duration:p?n.duration:.5,delay:p?0:n.duration}}},initial:"initial",animate:d?"whileInView":"initial",children:ae.numberFormattingFunction(e.y1,"NA",A,M[0],S[0])}):null]}),f.checkIfNullOrUndefined(e.y2)?null:t.jsxRuntimeExports.jsxs(t.jsxRuntimeExports.Fragment,{children:[P?t.jsxRuntimeExports.jsx(b.motion.circle,{r:u/i.length<5?0:u/i.length<20?2:4,exit:{opacity:0,transition:{duration:n.duration}},variants:{initial:{opacity:0,cx:c(e.date),cy:g(e.y2),fill:s[1]},whileInView:{opacity:1,transition:{duration:p?n.duration:.5,delay:p?0:n.duration},fill:s[1],cx:c(e.date),cy:g(e.y2)}},initial:"initial",animate:d?"whileInView":"initial"}):null,G?t.jsxRuntimeExports.jsx(b.motion.text,{dy:f.checkIfNullOrUndefined(e.y1)||e.y1<e.y2?-8:"1em",style:{textAnchor:"middle",...l?.graphObjectValues||{}},className:t.mo("graph-value graph-value-line-2 text-xs font-bold",r?.graphObjectValues),exit:{opacity:0,transition:{duration:n.duration}},variants:{initial:{opacity:0,x:c(e.date),y:g(e.y2),fill:s[1]},whileInView:{opacity:1,x:c(e.date),y:g(e.y2),fill:s[1],transition:{duration:p?n.duration:.5,delay:p?0:n.duration}}},initial:"initial",animate:d?"whileInView":"initial",children:ae.numberFormattingFunction(e.y2,"NA",A,M[1],S[1])}):null]})]},q))}),H.filter(e=>e.position==="after").map(e=>e.layer),t.jsxRuntimeExports.jsx("rect",{ref:w,style:{fill:"none",pointerEvents:"all"},width:u,height:a})]})}),I&&v&&_&&te?t.jsxRuntimeExports.jsx(Ie.Tooltip,{data:I,body:v,xPos:_,yPos:te,backgroundStyle:l?.tooltip,className:r?.tooltip}):null]})}function He(le){const{data:k,graphTitle:R,sources:D,graphDescription:s,height:y,width:o,footNote:j,noOfXTicks:G=10,dateFormat:xe="yyyy",showValues:ce=!1,padding:W,lineColors:X=[Re.Colors.light.categoricalColors.colors[0],Re.Colors.light.categoricalColors.colors[1]],sameAxes:ue=!1,backgroundColor:v=!1,leftMargin:me=80,rightMargin:C=80,topMargin:n=20,bottomMargin:Y=25,labels:P,lineSuffixes:B=["",""],linePrefixes:S=["",""],tooltip:M,highlightAreaSettings:z=[],relativeHeight:N,onSeriesMouseOver:T,graphID:l,graphDownload:r=!1,dataDownload:A=!1,animate:H=!1,strokeWidth:J=2,showDots:K=!0,language:d="en",showColorScale:p=!0,minHeight:V=0,colorLegendTitle:Q,theme:I="light",ariaLabel:Z,noOfYTicks:_=5,maxDate:ee,minDate:te,curveType:ie="curve",styles:m,classNames:w,precision:i=2,customLayers:de=[],showAxisLabels:u=!0}=le,[a,se]=h.useState(0),[ne,$]=h.useState(0),E=h.useRef(null),O=h.useRef(null);return h.useEffect(()=>{const x=new ResizeObserver(U=>{se(o||U[0].target.clientWidth||620),$(y||U[0].target.clientHeight||480)});return E.current&&($(E.current.clientHeight||480),se(E.current.clientWidth||620),o||x.observe(E.current)),()=>x.disconnect()},[o,y]),t.jsxRuntimeExports.jsx("div",{className:`${I||"light"} flex ${o?"w-fit grow-0":"w-full grow"}`,dir:d==="he"||d==="ar"?"rtl":void 0,children:t.jsxRuntimeExports.jsx("div",{className:t.mo(`${v?v===!0?"bg-primary-gray-200 dark:bg-primary-gray-650 ":"":"bg-transparent "}ml-auto mr-auto flex flex-col grow h-inherit ${d||"en"}`,o?"w-fit":"w-full",w?.graphContainer),style:{...m?.graphContainer||{},...v&&v!==!0?{backgroundColor:v}:{}},id:l,ref:O,"aria-label":Z||`${R?`The graph shows ${R}. `:""}This is a line chart that show trends for two datasets over time.${s?` ${s}`:""}`,children:t.jsxRuntimeExports.jsx("div",{className:"flex grow",style:{padding:v?W||"1rem":W||0},children:t.jsxRuntimeExports.jsxs("div",{className:"flex flex-col w-full gap-4 grow justify-between",children:[R||s||r||A?t.jsxRuntimeExports.jsx($e.GraphHeader,{styles:{title:m?.title,description:m?.description},classNames:{title:w?.title,description:w?.description},graphTitle:R,graphDescription:s,width:o,graphDownload:r?O.current:void 0,dataDownload:A?k.map(x=>x.data).filter(x=>x!==void 0).length>0?k.map(x=>x.data).filter(x=>x!==void 0):k.filter(x=>x!==void 0):null}):null,t.jsxRuntimeExports.jsx("div",{className:"grow flex flex-col justify-center gap-3 w-full",children:k.length===0?t.jsxRuntimeExports.jsx(Ce.EmptyState,{}):t.jsxRuntimeExports.jsxs(t.jsxRuntimeExports.Fragment,{children:[p?t.jsxRuntimeExports.jsx(Fe.ColorLegend,{colorDomain:P,colorLegendTitle:Q,colors:X,showNAColor:!1}):null,t.jsxRuntimeExports.jsx("div",{className:"flex flex-col grow justify-center leading-0",ref:E,"aria-label":"Graph area",children:(o||a)&&(y||ne)?t.jsxRuntimeExports.jsx(Pe,{data:k,sameAxes:ue,lineColors:X,width:o||a,height:Math.max(V,y||(N?V?(o||a)*N>V?(o||a)*N:V:(o||a)*N:ne)),dateFormat:xe,showValues:ce,noOfXTicks:G,leftMargin:me,rightMargin:C,topMargin:n,bottomMargin:Y,labels:P,highlightAreaSettings:z,tooltip:M,onSeriesMouseOver:T,animate:H===!0?{duration:.5,once:!0,amount:.5}:H||{duration:0,once:!0,amount:0},strokeWidth:J,showDots:K,noOfYTicks:_,lineSuffixes:B,linePrefixes:S,minDate:te,maxDate:ee,curveType:ie,styles:m,classNames:w,precision:i,customLayers:de,showAxisLabels:u}):null})]})}),D||j?t.jsxRuntimeExports.jsx(Ve.GraphFooter,{styles:{footnote:m?.footnote,source:m?.source},classNames:{footnote:w?.footnote,source:w?.source},sources:D,footNote:j,width:o}):null]})})})})}exports.DualAxisLineChart=He;
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const n=require("./index-CHPV5EwG-CTPQjnHt.cjs"),R=require("react"),Ct=require("./parse-hMnG_lRV.cjs"),be=require("./index-Cno4Q0YE.cjs"),ce=require("./numberFormattingFunction-02t-wJta.cjs"),ke=require("./Tooltip-4dJo4_AF.cjs"),I=require("./checkIfNullOrUndefined-BCW3Y1ML.cjs"),Ne=require("./XTicksAndGridLines-B6CELS7q.cjs"),ye=require("./Axis-DxRV2yMi.cjs"),je=require("./AxisTitle-sS5bLLR7.cjs"),Oe=require("./index-B_sAFsEV.cjs"),Ie=require("./time-CZd5YLSP.cjs"),Ae=require("./linear-BwPAspcq.cjs"),ge=require("./line-DHV4JwCR.cjs"),ue=require("./step-BZ3C8QFW.cjs"),Le=require("./select-Bnfk0lJx.cjs"),Se=require("./init-DU0ybBc_.cjs"),De=require("./pointer-Dkq5NV1q.cjs"),Me=require("./use-in-view-QcfiW0w3.cjs"),ut=require("./proxy-BxvUI_9l.cjs"),qe=require("./GraphFooter.cjs"),Te=require("./GraphHeader.cjs"),Ce=require("./ColorLegend.cjs"),we=require("./Colors.cjs"),Ve=require("./EmptyState-sAEZ_5rU.cjs"),Ee=require("./GraphContainer-d8A46BK2.cjs");function Fe(e){const t=n.compilerRuntimeExports.c(117),{data:k,width:W,height:X,lineColors:o,labels:v,sameAxes:j,dateFormat:p,showValues:Vt,noOfXTicks:zt,rightMargin:Jt,leftMargin:Ft,topMargin:Y,bottomMargin:kt,tooltip:xt,highlightAreaSettings:Nt,onSeriesMouseOver:Ot,animate:s,strokeWidth:q,showDots:mt,noOfYTicks:pt,lineSuffixes:T,linePrefixes:B,minDate:ft,maxDate:It,curveType:z,styles:a,classNames:c,precision:J,customLayers:C,showAxisLabels:V}=e,$t=R.useRef(null);let dt;t[0]!==s.amount||t[1]!==s.once?(dt={once:s.once,amount:s.amount},t[0]=s.amount,t[1]=s.once,t[2]=dt):dt=t[2];const d=Me.useInView($t,dt),[g,Pt]=R.useState(!1);let ht,K;t[3]!==s.duration||t[4]!==g||t[5]!==d?(ht=()=>{if(d&&!g){const i=setTimeout(()=>{Pt(!0)},(s.duration+.5)*1e3);return()=>clearTimeout(i)}},K=[d,g,s.duration],t[3]=s.duration,t[4]=g,t[5]=d,t[6]=ht,t[7]=K):(ht=t[6],K=t[7]),R.useEffect(ht,K);const Gt=z==="linear"?ge.curveLinear:z==="step"?ue.curveStep:z==="stepAfter"?ue.stepAfter:z==="stepBefore"?ue.stepBefore:ue.monotoneX,[N,Lt]=R.useState(void 0),[yt,f]=R.useState(void 0),[m,Ht]=R.useState(void 0),Q=Ft+50,St=Jt+65;let Z;t[8]!==kt||t[9]!==Q||t[10]!==St||t[11]!==Y?(Z={top:Y,bottom:kt,left:Q,right:St},t[8]=kt,t[9]=Q,t[10]=St,t[11]=Y,t[12]=Z):Z=t[12];const h=Z,_=R.useRef(null);let F;t[13]!==p?(F=i=>({...i,date:Ct.parse(`${i.date}`,p,new Date)}),t[13]=p,t[14]=F):F=t[14];const r=be.orderBy(k.map(F),["date"],["asc"]);let tt;if(t[15]!==p||t[16]!==Nt){let i;t[18]!==p?(i=E=>({...E,coordinates:[E.coordinates[0]===null?null:Ct.parse(`${E.coordinates[0]}`,p,new Date),E.coordinates[1]===null?null:Ct.parse(`${E.coordinates[1]}`,p,new Date)]}),t[18]=p,t[19]=i):i=t[19],tt=Nt.map(i),t[15]=p,t[16]=Nt,t[17]=tt}else tt=t[17];const gt=tt,u=W-h.left-h.right,l=X-h.top-h.bottom,Ut=ft?Ct.parse(`${ft}`,p,new Date):r[0].date,Wt=It?Ct.parse(`${It}`,p,new Date):r[r.length-1].date,et=Math.min(...r.map(hi).filter(di))!==1/0?Math.min(...r.map(fi).filter(pi))>0?0:Math.min(...r.map(mi).filter(xi)):0,vt=Math.min(...r.map(ui).filter(ci))!==1/0?Math.min(...r.map(ai).filter(li))>0?0:Math.min(...r.map(ri).filter(oi)):0,$=Math.max(...r.map(si).filter(ni))!==1/0?Math.max(...r.map(ii).filter(ei)):0,it=Math.max(...r.map(ti).filter(_e))!==1/0?Math.max(...r.map(Ze).filter(Qe)):0,jt=et<vt?et:vt,nt=$>it?$:it,x=Ie.time().domain([Ut,Wt]).range([0,u]),b=Ae.linear().domain([j?jt:et,j?nt>0?nt:0:$>0?$:0]).range([l,0]).nice(),y=Ae.linear().domain([j?jt:vt,j?nt>0?nt:0:it>0?it:0]).range([l,0]).nice(),Dt=ge.line().defined(Ke).x(i=>x(i.date)).y(i=>b(i.y1)).curve(Gt),At=ge.line().defined(Je).x(i=>x(i.date)).y(i=>y(i.y2)).curve(Gt),Xt=b.ticks(pt),Yt=y.ticks(pt),Mt=x.ticks(zt);R.useEffect(()=>{const i=he=>{const ve=r[Se.bisectCenter(r.map(ze),x.invert(De.pointer(he)[0]),0)];Lt(ve||r[r.length-1]),Ot?.(ve||r[r.length-1]),Ht(he.clientY),f(he.clientX)},E=()=>{Lt(void 0),f(void 0),Ht(void 0),Ot?.(void 0)};Le.select(_.current).on("mousemove",i).on("mouseout",E)},[x,r,Ot]);let st;t[20]!==s||t[21]!==l||t[22]!==u||t[23]!==gt||t[24]!==d||t[25]!==x?(st=n.jsxRuntimeExports.jsx(Oe.HighlightArea,{areaSettings:gt,width:u,height:l,scale:x,animate:s,isInView:d}),t[20]=s,t[21]=l,t[22]=u,t[23]=gt,t[24]=d,t[25]=x,t[26]=st):st=t[26];const wt=c?.xAxis?.axis;let L;t[27]!==wt?(L={axis:wt},t[27]=wt,t[28]=L):L=t[28];let S;t[29]!==a?.xAxis?.axis?(S=a?.xAxis?.axis||{},t[29]=a?.xAxis?.axis,t[30]=S):S=t[30];let O;t[31]!==o[0]||t[32]!==S?(O={axis:{stroke:o[0],...S}},t[31]=o[0],t[32]=S,t[33]=O):O=t[33];let ot;t[34]!==l||t[35]!==L||t[36]!==O?(ot=n.jsxRuntimeExports.jsx(ye.Axis,{y1:0,y2:l,x1:-15,x2:-15,classNames:L,styles:O}),t[34]=l,t[35]=L,t[36]=O,t[37]=ot):ot=t[37];let rt;t[38]!==c?.yAxis?.title||t[39]!==l||t[40]!==v||t[41]!==o[0]||t[42]!==h.left||t[43]!==V||t[44]!==a?.yAxis?.title?(rt=V?n.jsxRuntimeExports.jsx(je.AxisTitle,{x:10-h.left,y:l/2,style:{fill:o[0],...a?.yAxis?.title||{}},className:c?.yAxis?.title,text:v[0].length>100?`${v[0].substring(0,100)}...`:v[0],rotate90:!0}):null,t[38]=c?.yAxis?.title,t[39]=l,t[40]=v,t[41]=o[0],t[42]=h.left,t[43]=V,t[44]=a?.yAxis?.title,t[45]=rt):rt=t[45];const lt=u+15,Bt=u+15,at=c?.xAxis?.axis;let ct;t[46]!==at?(ct={axis:at},t[46]=at,t[47]=ct):ct=t[47];let D;t[48]!==a?.xAxis?.axis?(D=a?.xAxis?.axis||{},t[48]=a?.xAxis?.axis,t[49]=D):D=t[49];let P;t[50]!==o[1]||t[51]!==D?(P={axis:{stroke:o[1],...D}},t[50]=o[1],t[51]=D,t[52]=P):P=t[52];let G;t[53]!==l||t[54]!==lt||t[55]!==Bt||t[56]!==ct||t[57]!==P?(G=n.jsxRuntimeExports.jsx(ye.Axis,{y1:0,y2:l,x1:lt,x2:Bt,classNames:ct,styles:P}),t[53]=l,t[54]=lt,t[55]=Bt,t[56]=ct,t[57]=P,t[58]=G):G=t[58];let H;t[59]!==c?.yAxis?.title||t[60]!==l||t[61]!==u||t[62]!==v||t[63]!==o[1]||t[64]!==h.right||t[65]!==V||t[66]!==a?.yAxis?.title?(H=V?n.jsxRuntimeExports.jsx(je.AxisTitle,{x:u+h.right-15,y:l/2,style:{fill:o[1],...a?.yAxis?.title||{}},className:c?.yAxis?.title,text:v[1].length>100?`${v[1].substring(0,100)}...`:v[1],rotate90:!0}):null,t[59]=c?.yAxis?.title,t[60]=l,t[61]=u,t[62]=v,t[63]=o[1],t[64]=h.right,t[65]=V,t[66]=a?.yAxis?.title,t[67]=H):H=t[67];const Et=u+15,Rt=c?.xAxis?.axis;let A;t[68]!==Rt?(A={axis:Rt},t[68]=Rt,t[69]=A):A=t[69];const M=a?.xAxis?.axis;let w;t[70]!==M?(w={axis:M},t[70]=M,t[71]=w):w=t[71];let U;t[72]!==l||t[73]!==Et||t[74]!==A||t[75]!==w?(U=n.jsxRuntimeExports.jsx(ye.Axis,{y1:l,y2:l,x1:-15,x2:Et,classNames:A,styles:w}),t[72]=l,t[73]=Et,t[74]=A,t[75]=w,t[76]=U):U=t[76];let bt;t[77]!==p?(bt=i=>Ct.format(i,p),t[77]=p,t[78]=bt):bt=t[78];const Kt=Mt.map(bt),Re=Mt.map(i=>x(i)),xe=a?.xAxis?.gridLines,me=a?.xAxis?.labels;let Qt;t[79]!==xe||t[80]!==me?(Qt={gridLines:xe,labels:me},t[79]=xe,t[80]=me,t[81]=Qt):Qt=t[81];const pe=c?.xAxis?.gridLines;let qt;t[82]!==pe?(qt=n.mo("opacity-0",pe),t[82]=pe,t[83]=qt):qt=t[83];const fe=c?.xAxis?.labels;let Tt;t[84]!==fe?(Tt=n.mo("fill-primary-gray-700 dark:fill-primary-gray-300 xs:max-[360px]:hidden text-[9px] md:text-[10px] lg:text-xs",fe),t[84]=fe,t[85]=Tt):Tt=t[85];let Zt;t[86]!==qt||t[87]!==Tt?(Zt={gridLines:qt,labels:Tt},t[86]=qt,t[87]=Tt,t[88]=Zt):Zt=t[88];let _t;t[89]!==C?(_t=C.filter(Be).map(Ye),t[89]=C,t[90]=_t):_t=t[90];let te;t[91]!==o[0]||t[92]!==q?(te={stroke:o[0],strokeWidth:q,fill:"none"},t[91]=o[0],t[92]=q,t[93]=te):te=t[93];let ee;t[94]!==s.duration?(ee={opacity:0,transition:{duration:s.duration}},t[94]=s.duration,t[95]=ee):ee=t[95];let ie;t[96]!==o[1]||t[97]!==q?(ie={stroke:o[1],strokeWidth:q,fill:"none"},t[96]=o[1],t[97]=q,t[98]=ie):ie=t[98];let ne;t[99]!==s.duration?(ne={opacity:0,transition:{duration:s.duration}},t[99]=s.duration,t[100]=ne):ne=t[100];const de=r.map((i,E)=>n.jsxRuntimeExports.jsxs(ut.motion.g,{children:[I.checkIfNullOrUndefined(i.y1)?null:n.jsxRuntimeExports.jsxs(n.jsxRuntimeExports.Fragment,{children:[mt?n.jsxRuntimeExports.jsx(ut.motion.circle,{r:u/r.length<5?0:u/r.length<20?2:4,exit:{opacity:0,transition:{duration:s.duration}},variants:{initial:{opacity:0,cx:x(i.date),cy:b(i.y1),fill:o[0]},whileInView:{opacity:1,fill:o[0],transition:{duration:g?s.duration:.5,delay:g?0:s.duration},cx:x(i.date),cy:b(i.y1)}},initial:"initial",animate:d?"whileInView":"initial"}):null,Vt?n.jsxRuntimeExports.jsx(ut.motion.text,{dy:I.checkIfNullOrUndefined(i.y2)||i.y2<i.y1?-8:"1em",style:{textAnchor:"middle",...a?.graphObjectValues||{}},className:n.mo("graph-value graph-value-line-1 text-xs font-bold",c?.graphObjectValues),exit:{opacity:0,transition:{duration:s.duration}},variants:{initial:{opacity:0,x:x(i.date),y:y(i.y1),fill:o[0]},whileInView:{opacity:1,x:x(i.date),fill:o[0],y:y(i.y1),transition:{duration:g?s.duration:.5,delay:g?0:s.duration}}},initial:"initial",animate:d?"whileInView":"initial",children:ce.numberFormattingFunction(i.y1,"NA",J,B[0],T[0])}):null]}),I.checkIfNullOrUndefined(i.y2)?null:n.jsxRuntimeExports.jsxs(n.jsxRuntimeExports.Fragment,{children:[mt?n.jsxRuntimeExports.jsx(ut.motion.circle,{r:u/r.length<5?0:u/r.length<20?2:4,exit:{opacity:0,transition:{duration:s.duration}},variants:{initial:{opacity:0,cx:x(i.date),cy:y(i.y2),fill:o[1]},whileInView:{opacity:1,transition:{duration:g?s.duration:.5,delay:g?0:s.duration},fill:o[1],cx:x(i.date),cy:y(i.y2)}},initial:"initial",animate:d?"whileInView":"initial"}):null,Vt?n.jsxRuntimeExports.jsx(ut.motion.text,{dy:I.checkIfNullOrUndefined(i.y1)||i.y1<i.y2?-8:"1em",style:{textAnchor:"middle",...a?.graphObjectValues||{}},className:n.mo("graph-value graph-value-line-2 text-xs font-bold",c?.graphObjectValues),exit:{opacity:0,transition:{duration:s.duration}},variants:{initial:{opacity:0,x:x(i.date),y:y(i.y2),fill:o[1]},whileInView:{opacity:1,x:x(i.date),y:y(i.y2),fill:o[1],transition:{duration:g?s.duration:.5,delay:g?0:s.duration}}},initial:"initial",animate:d?"whileInView":"initial",children:ce.numberFormattingFunction(i.y2,"NA",J,B[1],T[1])}):null]})]},E));let se;t[101]!==de?(se=n.jsxRuntimeExports.jsx("g",{children:de}),t[101]=de,t[102]=se):se=t[102];let oe;t[103]!==C?(oe=C.filter(Pe).map($e),t[103]=C,t[104]=oe):oe=t[104];let re;t[105]===Symbol.for("react.memo_cache_sentinel")?(re={fill:"none",pointerEvents:"all"},t[105]=re):re=t[105];let le;t[106]!==_||t[107]!==l||t[108]!==u?(le=n.jsxRuntimeExports.jsx("rect",{ref:_,style:re,width:u,height:l}),t[106]=_,t[107]=l,t[108]=u,t[109]=le):le=t[109];let ae;return t[110]!==c?.tooltip||t[111]!==yt||t[112]!==m||t[113]!==N||t[114]!==a?.tooltip||t[115]!==xt?(ae=N&&xt&&yt&&m?n.jsxRuntimeExports.jsx(ke.Tooltip,{data:N,body:xt,xPos:yt,yPos:m,backgroundStyle:a?.tooltip,className:c?.tooltip}):null,t[110]=c?.tooltip,t[111]=yt,t[112]=m,t[113]=N,t[114]=a?.tooltip,t[115]=xt,t[116]=ae):ae=t[116],n.jsxRuntimeExports.jsxs(n.jsxRuntimeExports.Fragment,{children:[n.jsxRuntimeExports.jsx(ut.motion.svg,{width:`${W}px`,height:`${X}px`,viewBox:`0 0 ${W} ${X}`,direction:"ltr",ref:$t,children:n.jsxRuntimeExports.jsxs("g",{transform:`translate(${h.left},${h.top})`,children:[st,n.jsxRuntimeExports.jsxs("g",{children:[Xt.map((i,E)=>n.jsxRuntimeExports.jsxs("g",{children:[n.jsxRuntimeExports.jsx("line",{y1:b(i),y2:b(i),x1:-15,x2:-20,style:{stroke:o[0],strokeWidth:1,...a?.yAxis?.gridLines||{}},className:c?.yAxis?.gridLines}),n.jsxRuntimeExports.jsx("text",{x:-25,y:b(i),dy:"0.33em",className:n.mo("text-xs",c?.yAxis?.labels),style:{textAnchor:"end",fill:o[0],...a?.yAxis?.labels||{}},children:ce.numberFormattingFunction(i,"NA",J,B[0],T[0])})]},E)),ot,rt]}),n.jsxRuntimeExports.jsxs("g",{children:[Yt.map((i,E)=>n.jsxRuntimeExports.jsxs("g",{children:[n.jsxRuntimeExports.jsx("line",{y1:y(i),y2:y(i),x1:u+15,x2:u+20,style:{stroke:o[1],strokeWidth:1,...a?.yAxis?.gridLines||{}},className:c?.yAxis?.gridLines}),n.jsxRuntimeExports.jsx("text",{x:u+25,y:y(i),dy:"0.33em",dx:-2,style:{textAnchor:"start",fill:o[1],...a?.yAxis?.labels||{}},className:n.mo("text-xs",c?.yAxis?.labels),children:ce.numberFormattingFunction(i,"NA",J,B[1],T[1])})]},E)),G,H]}),n.jsxRuntimeExports.jsxs("g",{children:[U,n.jsxRuntimeExports.jsx(Ne.XTicksAndGridLines,{values:Kt,x:Re,y1:0,y2:l,styles:Qt,classNames:Zt,labelType:"primary",showGridLines:!0,precision:J})]}),_t,n.jsxRuntimeExports.jsxs("g",{children:[n.jsxRuntimeExports.jsx(ut.motion.path,{style:te,exit:ee,variants:{initial:{pathLength:0,d:Dt(r.filter(Xe))||"",opacity:1},whileInView:{pathLength:1,d:Dt(r.filter(We))||"",opacity:1,transition:{duration:s.duration}}},initial:"initial",animate:d?"whileInView":"initial"}),n.jsxRuntimeExports.jsx(ut.motion.path,{d:At(r.filter(Ue))||"",style:ie,exit:ne,variants:{initial:{pathLength:0,d:At(r.filter(He))||"",opacity:1},whileInView:{pathLength:1,d:At(r.filter(Ge))||"",opacity:1,transition:{duration:s.duration}}},initial:"initial",animate:d?"whileInView":"initial"}),N?n.jsxRuntimeExports.jsx("line",{y1:0,y2:l,x1:x(N.date),x2:x(N.date),className:n.mo("undp-tick-line stroke-primary-gray-700 dark:stroke-primary-gray-100",c?.mouseOverLine),style:a?.mouseOverLine}):null]}),se,oe,le]})}),ae]})}function $e(e){return e.layer}function Pe(e){return e.position==="after"}function Ge(e){return!I.checkIfNullOrUndefined(e.y2)}function He(e){return!I.checkIfNullOrUndefined(e.y2)}function Ue(e){return!I.checkIfNullOrUndefined(e.y2)}function We(e){return!I.checkIfNullOrUndefined(e.y1)}function Xe(e){return!I.checkIfNullOrUndefined(e.y1)}function Ye(e){return e.layer}function Be(e){return e.position==="before"}function ze(e){return e.date}function Je(e){return!I.checkIfNullOrUndefined(e.y2)}function Ke(e){return!I.checkIfNullOrUndefined(e.y1)}function Qe(e){return e!=null}function Ze(e){return e.y2}function _e(e){return e!=null}function ti(e){return e.y2}function ei(e){return e!=null}function ii(e){return e.y1}function ni(e){return e!=null}function si(e){return e.y1}function oi(e){return e!=null}function ri(e){return e.y2}function li(e){return e!=null}function ai(e){return e.y2}function ci(e){return e!=null}function ui(e){return e.y2}function xi(e){return e!=null}function mi(e){return e.y1}function pi(e){return e!=null}function fi(e){return e.y2}function di(e){return e!=null}function hi(e){return e.y1}function yi(e){const t=n.compilerRuntimeExports.c(80),{data:k,graphTitle:W,sources:X,graphDescription:o,height:v,width:j,footNote:p,noOfXTicks:Vt,dateFormat:zt,showValues:Jt,padding:Ft,lineColors:Y,sameAxes:kt,backgroundColor:xt,leftMargin:Nt,rightMargin:Ot,topMargin:s,bottomMargin:q,labels:mt,lineSuffixes:pt,linePrefixes:T,tooltip:B,highlightAreaSettings:ft,relativeHeight:It,onSeriesMouseOver:z,graphID:a,graphDownload:c,dataDownload:J,animate:C,strokeWidth:V,showDots:$t,language:dt,showColorScale:d,minHeight:g,colorLegendTitle:Pt,theme:ht,ariaLabel:K,noOfYTicks:Gt,maxDate:N,minDate:Lt,curveType:yt,styles:f,classNames:m,precision:Ht,customLayers:Q,showAxisLabels:St}=e,Z=Vt===void 0?10:Vt,h=zt===void 0?"yyyy":zt,_=Jt===void 0?!1:Jt;let F;t[0]!==Y?(F=Y===void 0?[we.Colors.light.categoricalColors.colors[0],we.Colors.light.categoricalColors.colors[1]]:Y,t[0]=Y,t[1]=F):F=t[1];const r=F,tt=kt===void 0?!1:kt,gt=xt===void 0?!1:xt,u=Nt===void 0?80:Nt,l=Ot===void 0?80:Ot,Ut=s===void 0?20:s,Wt=q===void 0?25:q;let et;t[2]!==pt?(et=pt===void 0?["",""]:pt,t[2]=pt,t[3]=et):et=t[3];const vt=et;let $;t[4]!==T?($=T===void 0?["",""]:T,t[4]=T,t[5]=$):$=t[5];const it=$;let jt;t[6]!==ft?(jt=ft===void 0?[]:ft,t[6]=ft,t[7]=jt):jt=t[7];const nt=jt,x=c===void 0?!1:c,b=J===void 0?!1:J,y=C===void 0?!1:C,Dt=V===void 0?2:V,At=$t===void 0?!0:$t,Xt=dt===void 0?"en":dt,Yt=d===void 0?!0:d,Mt=g===void 0?0:g,st=ht===void 0?"light":ht,wt=Gt===void 0?5:Gt,L=yt===void 0?"curve":yt,S=Ht===void 0?2:Ht;let O;t[8]!==Q?(O=Q===void 0?[]:Q,t[8]=Q,t[9]=O):O=t[9];const ot=O,rt=St===void 0?!0:St,[lt,Bt]=R.useState(0),[at,ct]=R.useState(0),D=R.useRef(null),P=R.useRef(null);let G,H;t[10]===Symbol.for("react.memo_cache_sentinel")?(G=()=>{const bt=new ResizeObserver(Kt=>{Bt(Kt[0].target.clientWidth||620),ct(Kt[0].target.clientHeight||480)});return D.current&&bt.observe(D.current),()=>bt.disconnect()},H=[],t[10]=G,t[11]=H):(G=t[10],H=t[11]),R.useEffect(G,H);const Et=m?.graphContainer,Rt=f?.graphContainer;let A;t[12]!==m?.description||t[13]!==m?.title||t[14]!==k||t[15]!==b||t[16]!==o||t[17]!==x||t[18]!==W||t[19]!==f?.description||t[20]!==f?.title||t[21]!==j?(A=W||o||x||b?n.jsxRuntimeExports.jsx(Te.GraphHeader,{styles:{title:f?.title,description:f?.description},classNames:{title:m?.title,description:m?.description},graphTitle:W,graphDescription:o,width:j,graphDownload:x?P:void 0,dataDownload:b?k.map(wi).filter(Ai).length>0?k.map(ji).filter(vi):k.filter(gi):null}):null,t[12]=m?.description,t[13]=m?.title,t[14]=k,t[15]=b,t[16]=o,t[17]=x,t[18]=W,t[19]=f?.description,t[20]=f?.title,t[21]=j,t[22]=A):A=t[22];let M;t[23]!==y||t[24]!==Wt||t[25]!==m||t[26]!==Pt||t[27]!==L||t[28]!==ot||t[29]!==k||t[30]!==h||t[31]!==nt||t[32]!==mt||t[33]!==u||t[34]!==r||t[35]!==it||t[36]!==vt||t[37]!==N||t[38]!==Lt||t[39]!==Z||t[40]!==wt||t[41]!==z||t[42]!==S||t[43]!==l||t[44]!==tt||t[45]!==rt||t[46]!==Yt||t[47]!==At||t[48]!==_||t[49]!==Dt||t[50]!==f||t[51]!==at||t[52]!==lt||t[53]!==B||t[54]!==Ut?(M=k.length===0?n.jsxRuntimeExports.jsx(Ve.EmptyState,{}):n.jsxRuntimeExports.jsxs(n.jsxRuntimeExports.Fragment,{children:[Yt?n.jsxRuntimeExports.jsx(Ce.ColorLegend,{colorDomain:mt,colorLegendTitle:Pt,colors:r,showNAColor:!1,className:m?.colorLegend}):null,n.jsxRuntimeExports.jsx(Ee.GraphArea,{ref:D,children:lt&&at?n.jsxRuntimeExports.jsx(Fe,{data:k,sameAxes:tt,lineColors:r,width:lt,height:at,dateFormat:h,showValues:_,noOfXTicks:Z,leftMargin:u,rightMargin:l,topMargin:Ut,bottomMargin:Wt,labels:mt,highlightAreaSettings:nt,tooltip:B,onSeriesMouseOver:z,animate:y===!0?{duration:.5,once:!0,amount:.5}:y||{duration:0,once:!0,amount:0},strokeWidth:Dt,showDots:At,noOfYTicks:wt,lineSuffixes:vt,linePrefixes:it,minDate:Lt,maxDate:N,curveType:L,styles:f,classNames:m,precision:S,customLayers:ot,showAxisLabels:rt}):null})]}),t[23]=y,t[24]=Wt,t[25]=m,t[26]=Pt,t[27]=L,t[28]=ot,t[29]=k,t[30]=h,t[31]=nt,t[32]=mt,t[33]=u,t[34]=r,t[35]=it,t[36]=vt,t[37]=N,t[38]=Lt,t[39]=Z,t[40]=wt,t[41]=z,t[42]=S,t[43]=l,t[44]=tt,t[45]=rt,t[46]=Yt,t[47]=At,t[48]=_,t[49]=Dt,t[50]=f,t[51]=at,t[52]=lt,t[53]=B,t[54]=Ut,t[55]=M):M=t[55];let w;t[56]!==m?.footnote||t[57]!==m?.source||t[58]!==p||t[59]!==X||t[60]!==f?.footnote||t[61]!==f?.source||t[62]!==j?(w=X||p?n.jsxRuntimeExports.jsx(qe.GraphFooter,{styles:{footnote:f?.footnote,source:f?.source},classNames:{footnote:m?.footnote,source:m?.source},sources:X,footNote:p,width:j}):null,t[56]=m?.footnote,t[57]=m?.source,t[58]=p,t[59]=X,t[60]=f?.footnote,t[61]=f?.source,t[62]=j,t[63]=w):w=t[63];let U;return t[64]!==K||t[65]!==gt||t[66]!==a||t[67]!==v||t[68]!==Xt||t[69]!==Mt||t[70]!==Ft||t[71]!==It||t[72]!==Et||t[73]!==Rt||t[74]!==A||t[75]!==M||t[76]!==w||t[77]!==st||t[78]!==j?(U=n.jsxRuntimeExports.jsxs(Ee.GraphContainer,{className:Et,style:Rt,id:a,ref:P,"aria-label":K,backgroundColor:gt,theme:st,language:Xt,minHeight:Mt,width:j,height:v,relativeHeight:It,padding:Ft,children:[A,M,w]}),t[64]=K,t[65]=gt,t[66]=a,t[67]=v,t[68]=Xt,t[69]=Mt,t[70]=Ft,t[71]=It,t[72]=Et,t[73]=Rt,t[74]=A,t[75]=M,t[76]=w,t[77]=st,t[78]=j,t[79]=U):U=t[79],U}function gi(e){return e!==void 0}function vi(e){return e!==void 0}function ji(e){return e.data}function Ai(e){return e!==void 0}function wi(e){return e.data}exports.DualAxisLineChart=yi;
|
|
2
2
|
//# sourceMappingURL=DualAxisLineChart.cjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"DualAxisLineChart.cjs","sources":["../src/Components/Graphs/LineCharts/DualAxisLineChart/Graph.tsx","../src/Components/Graphs/LineCharts/DualAxisLineChart/index.tsx"],"sourcesContent":["import { useEffect, useRef, useState } from 'react';\r\nimport {\r\n line,\r\n curveMonotoneX,\r\n curveLinear,\r\n curveStep,\r\n curveStepAfter,\r\n curveStepBefore,\r\n} from 'd3-shape';\r\nimport { scaleLinear, scaleTime } from 'd3-scale';\r\nimport { format } from 'date-fns/format';\r\nimport { parse } from 'date-fns/parse';\r\nimport { bisectCenter } from 'd3-array';\r\nimport { pointer, select } from 'd3-selection';\r\nimport { motion, useInView } from 'motion/react';\r\nimport { cn } from '@undp/design-system-react/cn';\r\nimport orderBy from 'lodash.orderby';\r\n\r\nimport {\r\n AnimateDataType,\r\n ClassNameObject,\r\n CurveTypes,\r\n CustomLayerDataType,\r\n DualAxisLineChartDataType,\r\n HighlightAreaSettingsDataType,\r\n StyleObject,\r\n} from '@/Types';\r\nimport { numberFormattingFunction } from '@/Utils/numberFormattingFunction';\r\nimport { Tooltip } from '@/Components/Elements/Tooltip';\r\nimport { checkIfNullOrUndefined } from '@/Utils/checkIfNullOrUndefined';\r\nimport { XTicksAndGridLines } from '@/Components/Elements/Axes/XTicksAndGridLines';\r\nimport { Axis } from '@/Components/Elements/Axes/Axis';\r\nimport { AxisTitle } from '@/Components/Elements/Axes/AxisTitle';\r\nimport { HighlightArea } from '@/Components/Elements/HighlightArea';\r\n\r\ninterface Props {\r\n data: DualAxisLineChartDataType[];\r\n lineColors: [string, string];\r\n labels: [string, string];\r\n width: number;\r\n height: number;\r\n dateFormat: string;\r\n showValues: boolean;\r\n noOfXTicks: number;\r\n rightMargin: number;\r\n leftMargin: number;\r\n topMargin: number;\r\n bottomMargin: number;\r\n sameAxes: boolean;\r\n highlightAreaSettings: HighlightAreaSettingsDataType[];\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n tooltip?: string | ((_d: any) => React.ReactNode);\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseOver?: (_d: any) => void;\r\n animate: AnimateDataType;\r\n strokeWidth: number;\r\n showDots: boolean;\r\n noOfYTicks: number;\r\n lineSuffixes: [string, string];\r\n linePrefixes: [string, string];\r\n minDate?: string | number;\r\n maxDate?: string | number;\r\n curveType: CurveTypes;\r\n styles?: StyleObject;\r\n classNames?: ClassNameObject;\r\n precision: number;\r\n customLayers: CustomLayerDataType[];\r\n showAxisLabels: boolean;\r\n}\r\n\r\ninterface FormattedDataType {\r\n y1: number;\r\n y2: number;\r\n date: Date;\r\n}\r\n\r\nexport function Graph(props: Props) {\r\n const {\r\n data,\r\n width,\r\n height,\r\n lineColors,\r\n labels,\r\n sameAxes,\r\n dateFormat,\r\n showValues,\r\n noOfXTicks,\r\n rightMargin,\r\n leftMargin,\r\n topMargin,\r\n bottomMargin,\r\n tooltip,\r\n highlightAreaSettings,\r\n onSeriesMouseOver,\r\n animate,\r\n strokeWidth,\r\n showDots,\r\n noOfYTicks,\r\n lineSuffixes,\r\n linePrefixes,\r\n minDate,\r\n maxDate,\r\n curveType,\r\n styles,\r\n classNames,\r\n precision,\r\n customLayers,\r\n showAxisLabels,\r\n } = props;\r\n const svgRef = useRef(null);\r\n const isInView = useInView(svgRef, {\r\n once: animate.once,\r\n amount: animate.amount,\r\n });\r\n const [hasAnimatedOnce, setHasAnimatedOnce] = useState(false);\r\n\r\n useEffect(() => {\r\n if (isInView && !hasAnimatedOnce) {\r\n const timeout = setTimeout(\r\n () => {\r\n setHasAnimatedOnce(true);\r\n },\r\n (animate.duration + 0.5) * 1000,\r\n );\r\n return () => clearTimeout(timeout);\r\n }\r\n }, [isInView, hasAnimatedOnce, animate.duration]);\r\n const curve =\r\n curveType === 'linear'\r\n ? curveLinear\r\n : curveType === 'step'\r\n ? curveStep\r\n : curveType === 'stepAfter'\r\n ? curveStepAfter\r\n : curveType === 'stepBefore'\r\n ? curveStepBefore\r\n : curveMonotoneX;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const [mouseOverData, setMouseOverData] = useState<any>(undefined);\r\n const [eventX, setEventX] = useState<number | undefined>(undefined);\r\n const [eventY, setEventY] = useState<number | undefined>(undefined);\r\n const margin = {\r\n top: topMargin,\r\n bottom: bottomMargin,\r\n left: leftMargin + 50,\r\n right: rightMargin + 65,\r\n };\r\n const MouseoverRectRef = useRef(null);\r\n const dataFormatted = orderBy(\r\n data.map(d => ({\r\n ...d,\r\n date: parse(`${d.date}`, dateFormat, new Date()),\r\n })),\r\n ['date'],\r\n ['asc'],\r\n );\r\n const highlightAreaSettingsFormatted = highlightAreaSettings.map(d => ({\r\n ...d,\r\n coordinates: [\r\n d.coordinates[0] === null ? null : parse(`${d.coordinates[0]}`, dateFormat, new Date()),\r\n d.coordinates[1] === null ? null : parse(`${d.coordinates[1]}`, dateFormat, new Date()),\r\n ],\r\n }));\r\n const graphWidth = width - margin.left - margin.right;\r\n const graphHeight = height - margin.top - margin.bottom;\r\n const minYear = minDate ? parse(`${minDate}`, dateFormat, new Date()) : dataFormatted[0].date;\r\n const maxYear = maxDate\r\n ? parse(`${maxDate}`, dateFormat, new Date())\r\n : dataFormatted[dataFormatted.length - 1].date;\r\n const minParam1 =\r\n Math.min(...dataFormatted.map(d => d.y1).filter(d => d !== undefined && d !== null)) !==\r\n Infinity\r\n ? Math.min(...dataFormatted.map(d => d.y2).filter(d => d !== undefined && d !== null)) > 0\r\n ? 0\r\n : Math.min(...dataFormatted.map(d => d.y1).filter(d => d !== undefined && d !== null))\r\n : 0;\r\n const minParam2 =\r\n Math.min(...dataFormatted.map(d => d.y2).filter(d => d !== undefined && d !== null)) !==\r\n Infinity\r\n ? Math.min(...dataFormatted.map(d => d.y2).filter(d => d !== undefined && d !== null)) > 0\r\n ? 0\r\n : Math.min(...dataFormatted.map(d => d.y2).filter(d => d !== undefined && d !== null))\r\n : 0;\r\n const maxParam1 =\r\n Math.max(...dataFormatted.map(d => d.y1).filter(d => d !== undefined && d !== null)) !==\r\n Infinity\r\n ? Math.max(...dataFormatted.map(d => d.y1).filter(d => d !== undefined && d !== null))\r\n : 0;\r\n const maxParam2 =\r\n Math.max(...dataFormatted.map(d => d.y2).filter(d => d !== undefined && d !== null)) !==\r\n Infinity\r\n ? Math.max(...dataFormatted.map(d => d.y2).filter(d => d !== undefined && d !== null))\r\n : 0;\r\n\r\n const minParam = minParam1 < minParam2 ? minParam1 : minParam2;\r\n const maxParam = maxParam1 > maxParam2 ? maxParam1 : maxParam2;\r\n const x = scaleTime().domain([minYear, maxYear]).range([0, graphWidth]);\r\n\r\n const y1 = scaleLinear()\r\n .domain([\r\n sameAxes ? minParam : minParam1,\r\n sameAxes ? (maxParam > 0 ? maxParam : 0) : maxParam1 > 0 ? maxParam1 : 0,\r\n ])\r\n .range([graphHeight, 0])\r\n .nice();\r\n const y2 = scaleLinear()\r\n .domain([\r\n sameAxes ? minParam : minParam2,\r\n sameAxes ? (maxParam > 0 ? maxParam : 0) : maxParam2 > 0 ? maxParam2 : 0,\r\n ])\r\n .range([graphHeight, 0])\r\n .nice();\r\n\r\n const lineShape1 = line<FormattedDataType>()\r\n .defined(d => !checkIfNullOrUndefined(d.y1))\r\n .x(d => x(d.date))\r\n .y(d => y1(d.y1))\r\n .curve(curve);\r\n\r\n const lineShape2 = line<FormattedDataType>()\r\n .defined(d => !checkIfNullOrUndefined(d.y2))\r\n .x(d => x(d.date))\r\n .y(d => y2(d.y2))\r\n .curve(curve);\r\n const y1Ticks = y1.ticks(noOfYTicks);\r\n const y2Ticks = y2.ticks(noOfYTicks);\r\n const xTicks = x.ticks(noOfXTicks);\r\n useEffect(() => {\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const mousemove = (event: any) => {\r\n const selectedData =\r\n dataFormatted[\r\n bisectCenter(\r\n dataFormatted.map(d => d.date),\r\n x.invert(pointer(event)[0]),\r\n 0,\r\n )\r\n ];\r\n setMouseOverData(selectedData || dataFormatted[dataFormatted.length - 1]);\r\n onSeriesMouseOver?.(selectedData || dataFormatted[dataFormatted.length - 1]);\r\n setEventY(event.clientY);\r\n setEventX(event.clientX);\r\n };\r\n const mouseout = () => {\r\n setMouseOverData(undefined);\r\n setEventX(undefined);\r\n setEventY(undefined);\r\n onSeriesMouseOver?.(undefined);\r\n };\r\n select(MouseoverRectRef.current).on('mousemove', mousemove).on('mouseout', mouseout);\r\n }, [x, dataFormatted, onSeriesMouseOver]);\r\n\r\n return (\r\n <>\r\n <motion.svg\r\n width={`${width}px`}\r\n height={`${height}px`}\r\n viewBox={`0 0 ${width} ${height}`}\r\n direction='ltr'\r\n ref={svgRef}\r\n >\r\n <g transform={`translate(${margin.left},${margin.top})`}>\r\n <HighlightArea\r\n areaSettings={highlightAreaSettingsFormatted}\r\n width={graphWidth}\r\n height={graphHeight}\r\n scale={x}\r\n animate={animate}\r\n isInView={isInView}\r\n />\r\n <g>\r\n {y1Ticks.map((d, i) => (\r\n <g key={i}>\r\n <line\r\n y1={y1(d)}\r\n y2={y1(d)}\r\n x1={-15}\r\n x2={-20}\r\n style={{\r\n stroke: lineColors[0],\r\n strokeWidth: 1,\r\n ...(styles?.yAxis?.gridLines || {}),\r\n }}\r\n className={classNames?.yAxis?.gridLines}\r\n />\r\n <text\r\n x={0 - 25}\r\n y={y1(d)}\r\n dy='0.33em'\r\n className={cn('text-xs', classNames?.yAxis?.labels)}\r\n style={{\r\n textAnchor: 'end',\r\n fill: lineColors[0],\r\n ...(styles?.yAxis?.labels || {}),\r\n }}\r\n >\r\n {numberFormattingFunction(d, 'NA', precision, linePrefixes[0], lineSuffixes[0])}\r\n </text>\r\n </g>\r\n ))}\r\n <Axis\r\n y1={0}\r\n y2={graphHeight}\r\n x1={-15}\r\n x2={-15}\r\n classNames={{ axis: classNames?.xAxis?.axis }}\r\n styles={{ axis: { stroke: lineColors[0], ...(styles?.xAxis?.axis || {}) } }}\r\n />\r\n\r\n {showAxisLabels ? (\r\n <AxisTitle\r\n x={10 - margin.left}\r\n y={graphHeight / 2}\r\n style={{ fill: lineColors[0], ...(styles?.yAxis?.title || {}) }}\r\n className={classNames?.yAxis?.title}\r\n text={labels[0].length > 100 ? `${labels[0].substring(0, 100)}...` : labels[0]}\r\n rotate90\r\n />\r\n ) : null}\r\n </g>\r\n <g>\r\n {y2Ticks.map((d, i) => (\r\n <g key={i}>\r\n <line\r\n y1={y2(d)}\r\n y2={y2(d)}\r\n x1={graphWidth + 15}\r\n x2={graphWidth + 20}\r\n style={{\r\n stroke: lineColors[1],\r\n strokeWidth: 1,\r\n ...(styles?.yAxis?.gridLines || {}),\r\n }}\r\n className={classNames?.yAxis?.gridLines}\r\n />\r\n <text\r\n x={graphWidth + 25}\r\n y={y2(d)}\r\n dy='0.33em'\r\n dx={-2}\r\n style={{\r\n textAnchor: 'start',\r\n fill: lineColors[1],\r\n ...(styles?.yAxis?.labels || {}),\r\n }}\r\n className={cn('text-xs', classNames?.yAxis?.labels)}\r\n >\r\n {numberFormattingFunction(d, 'NA', precision, linePrefixes[1], lineSuffixes[1])}\r\n </text>\r\n </g>\r\n ))}\r\n <Axis\r\n y1={0}\r\n y2={graphHeight}\r\n x1={graphWidth + 15}\r\n x2={graphWidth + 15}\r\n classNames={{ axis: classNames?.xAxis?.axis }}\r\n styles={{ axis: { stroke: lineColors[1], ...(styles?.xAxis?.axis || {}) } }}\r\n />\r\n {showAxisLabels ? (\r\n <AxisTitle\r\n x={graphWidth + margin.right - 15}\r\n y={graphHeight / 2}\r\n style={{ fill: lineColors[1], ...(styles?.yAxis?.title || {}) }}\r\n className={classNames?.yAxis?.title}\r\n text={labels[1].length > 100 ? `${labels[1].substring(0, 100)}...` : labels[1]}\r\n rotate90\r\n />\r\n ) : null}\r\n </g>\r\n <g>\r\n <Axis\r\n y1={graphHeight}\r\n y2={graphHeight}\r\n x1={-15}\r\n x2={graphWidth + 15}\r\n classNames={{ axis: classNames?.xAxis?.axis }}\r\n styles={{ axis: styles?.xAxis?.axis }}\r\n />\r\n <XTicksAndGridLines\r\n values={xTicks.map(d => format(d, dateFormat))}\r\n x={xTicks.map(d => x(d))}\r\n y1={0}\r\n y2={graphHeight}\r\n styles={{\r\n gridLines: styles?.xAxis?.gridLines,\r\n labels: styles?.xAxis?.labels,\r\n }}\r\n classNames={{\r\n gridLines: cn('opacity-0', classNames?.xAxis?.gridLines),\r\n labels: cn(\r\n 'fill-primary-gray-700 dark:fill-primary-gray-300 xs:max-[360px]:hidden text-[9px] md:text-[10px] lg:text-xs',\r\n classNames?.xAxis?.labels,\r\n ),\r\n }}\r\n labelType='primary'\r\n showGridLines\r\n precision={precision}\r\n />\r\n </g>\r\n {customLayers.filter(d => d.position === 'before').map(d => d.layer)}\r\n <g>\r\n <motion.path\r\n style={{\r\n stroke: lineColors[0],\r\n strokeWidth,\r\n fill: 'none',\r\n }}\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n variants={{\r\n initial: {\r\n pathLength: 0,\r\n d:\r\n lineShape1(\r\n dataFormatted.filter(\r\n (el): el is FormattedDataType => !checkIfNullOrUndefined(el.y1),\r\n ),\r\n ) || '',\r\n opacity: 1,\r\n },\r\n whileInView: {\r\n pathLength: 1,\r\n d:\r\n lineShape1(\r\n dataFormatted.filter(\r\n (el): el is FormattedDataType => !checkIfNullOrUndefined(el.y1),\r\n ),\r\n ) || '',\r\n opacity: 1,\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n />\r\n <motion.path\r\n d={\r\n lineShape2(\r\n dataFormatted.filter(\r\n (el): el is FormattedDataType => !checkIfNullOrUndefined(el.y2),\r\n ),\r\n ) || ''\r\n }\r\n style={{\r\n stroke: lineColors[1],\r\n strokeWidth,\r\n fill: 'none',\r\n }}\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n variants={{\r\n initial: {\r\n pathLength: 0,\r\n d:\r\n lineShape2(\r\n dataFormatted.filter(\r\n (el): el is FormattedDataType => !checkIfNullOrUndefined(el.y2),\r\n ),\r\n ) || '',\r\n opacity: 1,\r\n },\r\n whileInView: {\r\n pathLength: 1,\r\n d:\r\n lineShape2(\r\n dataFormatted.filter(\r\n (el): el is FormattedDataType => !checkIfNullOrUndefined(el.y2),\r\n ),\r\n ) || '',\r\n opacity: 1,\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n />\r\n {mouseOverData ? (\r\n <line\r\n y1={0}\r\n y2={graphHeight}\r\n x1={x(mouseOverData.date)}\r\n x2={x(mouseOverData.date)}\r\n className={cn(\r\n 'undp-tick-line stroke-primary-gray-700 dark:stroke-primary-gray-100',\r\n classNames?.mouseOverLine,\r\n )}\r\n style={styles?.mouseOverLine}\r\n />\r\n ) : null}\r\n </g>\r\n <g>\r\n {dataFormatted.map((d, i) => (\r\n <motion.g key={i}>\r\n {!checkIfNullOrUndefined(d.y1) ? (\r\n <>\r\n {showDots ? (\r\n <motion.circle\r\n r={\r\n graphWidth / dataFormatted.length < 5\r\n ? 0\r\n : graphWidth / dataFormatted.length < 20\r\n ? 2\r\n : 4\r\n }\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n variants={{\r\n initial: {\r\n opacity: 0,\r\n cx: x(d.date),\r\n cy: y1(d.y1 as number),\r\n fill: lineColors[0],\r\n },\r\n whileInView: {\r\n opacity: 1,\r\n fill: lineColors[0],\r\n transition: {\r\n duration: hasAnimatedOnce ? animate.duration : 0.5,\r\n delay: hasAnimatedOnce ? 0 : animate.duration,\r\n },\r\n cx: x(d.date),\r\n cy: y1(d.y1 as number),\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n />\r\n ) : null}\r\n {showValues ? (\r\n <motion.text\r\n dy={\r\n checkIfNullOrUndefined(d.y2)\r\n ? -8\r\n : (d.y2 as number) < (d.y1 as number)\r\n ? -8\r\n : '1em'\r\n }\r\n style={{\r\n textAnchor: 'middle',\r\n ...(styles?.graphObjectValues || {}),\r\n }}\r\n className={cn(\r\n 'graph-value graph-value-line-1 text-xs font-bold',\r\n classNames?.graphObjectValues,\r\n )}\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n variants={{\r\n initial: {\r\n opacity: 0,\r\n x: x(d.date),\r\n y: y2(d.y1 as number),\r\n fill: lineColors[0],\r\n },\r\n whileInView: {\r\n opacity: 1,\r\n x: x(d.date),\r\n fill: lineColors[0],\r\n y: y2(d.y1 as number),\r\n transition: {\r\n duration: hasAnimatedOnce ? animate.duration : 0.5,\r\n delay: hasAnimatedOnce ? 0 : animate.duration,\r\n },\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n >\r\n {numberFormattingFunction(\r\n d.y1,\r\n 'NA',\r\n precision,\r\n linePrefixes[0],\r\n lineSuffixes[0],\r\n )}\r\n </motion.text>\r\n ) : null}\r\n </>\r\n ) : null}\r\n {!checkIfNullOrUndefined(d.y2) ? (\r\n <>\r\n {showDots ? (\r\n <motion.circle\r\n r={\r\n graphWidth / dataFormatted.length < 5\r\n ? 0\r\n : graphWidth / dataFormatted.length < 20\r\n ? 2\r\n : 4\r\n }\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n variants={{\r\n initial: {\r\n opacity: 0,\r\n cx: x(d.date),\r\n cy: y2(d.y2 as number),\r\n fill: lineColors[1],\r\n },\r\n whileInView: {\r\n opacity: 1,\r\n transition: {\r\n duration: hasAnimatedOnce ? animate.duration : 0.5,\r\n delay: hasAnimatedOnce ? 0 : animate.duration,\r\n },\r\n fill: lineColors[1],\r\n cx: x(d.date),\r\n cy: y2(d.y2 as number),\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n />\r\n ) : null}\r\n {showValues ? (\r\n <motion.text\r\n dy={\r\n checkIfNullOrUndefined(d.y1)\r\n ? -8\r\n : (d.y1 as number) < (d.y2 as number)\r\n ? -8\r\n : '1em'\r\n }\r\n style={{\r\n textAnchor: 'middle',\r\n ...(styles?.graphObjectValues || {}),\r\n }}\r\n className={cn(\r\n 'graph-value graph-value-line-2 text-xs font-bold',\r\n classNames?.graphObjectValues,\r\n )}\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n variants={{\r\n initial: {\r\n opacity: 0,\r\n x: x(d.date),\r\n y: y2(d.y2 as number),\r\n fill: lineColors[1],\r\n },\r\n whileInView: {\r\n opacity: 1,\r\n x: x(d.date),\r\n y: y2(d.y2 as number),\r\n fill: lineColors[1],\r\n transition: {\r\n duration: hasAnimatedOnce ? animate.duration : 0.5,\r\n delay: hasAnimatedOnce ? 0 : animate.duration,\r\n },\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n >\r\n {numberFormattingFunction(\r\n d.y2,\r\n 'NA',\r\n precision,\r\n linePrefixes[1],\r\n lineSuffixes[1],\r\n )}\r\n </motion.text>\r\n ) : null}\r\n </>\r\n ) : null}\r\n </motion.g>\r\n ))}\r\n </g>\r\n {customLayers.filter(d => d.position === 'after').map(d => d.layer)}\r\n <rect\r\n ref={MouseoverRectRef}\r\n style={{\r\n fill: 'none',\r\n pointerEvents: 'all',\r\n }}\r\n width={graphWidth}\r\n height={graphHeight}\r\n />\r\n </g>\r\n </motion.svg>\r\n {mouseOverData && tooltip && eventX && eventY ? (\r\n <Tooltip\r\n data={mouseOverData}\r\n body={tooltip}\r\n xPos={eventX}\r\n yPos={eventY}\r\n backgroundStyle={styles?.tooltip}\r\n className={classNames?.tooltip}\r\n />\r\n ) : null}\r\n </>\r\n );\r\n}\r\n","import { useState, useRef, useEffect } from 'react';\r\nimport { cn } from '@undp/design-system-react/cn';\r\n\r\nimport { Graph } from './Graph';\r\n\r\nimport { GraphFooter } from '@/Components/Elements/GraphFooter';\r\nimport { GraphHeader } from '@/Components/Elements/GraphHeader';\r\nimport { ColorLegend } from '@/Components/Elements/ColorLegend';\r\nimport {\r\n DualAxisLineChartDataType,\r\n Languages,\r\n SourcesDataType,\r\n StyleObject,\r\n ClassNameObject,\r\n HighlightAreaSettingsDataType,\r\n CurveTypes,\r\n CustomLayerDataType,\r\n AnimateDataType,\r\n} from '@/Types';\r\nimport { Colors } from '@/Components/ColorPalette';\r\nimport { EmptyState } from '@/Components/Elements/EmptyState';\r\n\r\ninterface Props {\r\n // Data\r\n /** Array of data objects */\r\n data: DualAxisLineChartDataType[];\r\n\r\n // Titles, Labels, and Sources\r\n /** Title of the graph */\r\n graphTitle?: string | React.ReactNode;\r\n /** Description of the graph */\r\n graphDescription?: string | React.ReactNode;\r\n /** Footnote for the graph */\r\n footNote?: string | React.ReactNode;\r\n /** Source data for the graph */\r\n sources?: SourcesDataType[];\r\n /** Accessibility label */\r\n ariaLabel?: string;\r\n\r\n // Colors and Styling\r\n /** Array of colors for the 2 lines */\r\n lineColors?: [string, string];\r\n /** Title for the color legend */\r\n colorLegendTitle?: string;\r\n /** Background color of the graph */\r\n backgroundColor?: string | boolean;\r\n /** Custom styles for the graph. Each object should be a valid React CSS style object. */\r\n styles?: StyleObject;\r\n /** Custom class names */\r\n classNames?: ClassNameObject;\r\n\r\n // Size and Spacing\r\n /** Width of the graph */\r\n width?: number;\r\n /** Height of the graph */\r\n height?: number;\r\n /** Minimum height of the graph */\r\n minHeight?: number;\r\n /** Relative height scaling factor. This overwrites the height props */\r\n relativeHeight?: number;\r\n /** Padding around the graph. Defaults to 0 if no backgroundColor is mentioned else defaults to 1rem */\r\n padding?: string;\r\n /** Left margin of the graph */\r\n leftMargin?: number;\r\n /** Right margin of the graph */\r\n rightMargin?: number;\r\n /** Top margin of the graph */\r\n topMargin?: number;\r\n /** Bottom margin of the graph */\r\n bottomMargin?: number;\r\n\r\n // Values and Ticks\r\n /** Prefix for values of the lines */\r\n linePrefixes?: [string, string];\r\n /** Suffix for values of the lines */\r\n lineSuffixes?: [string, string];\r\n /** Maximum value of the date for the chart */\r\n maxDate?: string | number;\r\n /** Minimum value of the date for the chart */\r\n minDate?: string | number;\r\n /** No. of ticks on the x-axis */\r\n noOfXTicks?: number;\r\n /** No. of ticks on the y-axis */\r\n noOfYTicks?: number;\r\n\r\n // Graph Parameters\r\n /** Toggle visibility of values */\r\n showValues?: boolean;\r\n /** Toggle visibility of dots on the line */\r\n showDots?: boolean;\r\n /** Stroke width of the line */\r\n strokeWidth?: number;\r\n /** Toggle the initial animation of the line. If the type is number then it uses the number as the time in seconds for animation. */\r\n animate?: boolean | AnimateDataType;\r\n /** Enables same axis for the 2 lines */\r\n sameAxes?: boolean;\r\n /** Toggle visibility of color scale. */\r\n showColorScale?: boolean;\r\n /** Toggle visibility of labels of the axis. */\r\n showAxisLabels?: boolean;\r\n /** Labels for the lines */\r\n labels: [string, string];\r\n /** Format of the date in the data object. Available formats can be found [here](https://date-fns.org/docs/format) */\r\n dateFormat?: string;\r\n /** Highlighted area(square) on the chart */\r\n highlightAreaSettings?: HighlightAreaSettingsDataType[];\r\n /** Curve type for the line */\r\n curveType?: CurveTypes;\r\n /** Specifies the number of decimal places to display in the value. */\r\n precision?: number;\r\n /** Optional SVG <g> element or function that renders custom content behind or in front of the graph. */\r\n customLayers?: CustomLayerDataType[];\r\n /** Enable graph download option as png */\r\n graphDownload?: boolean;\r\n /** Enable data download option as a csv */\r\n dataDownload?: boolean;\r\n\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 /** Callback for mouse over event */\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseOver?: (_d: any) => void;\r\n\r\n // Configuration and Options\r\n /** Language setting */\r\n language?: Languages;\r\n /** Color theme */\r\n theme?: 'light' | 'dark';\r\n /** Unique ID for the graph */\r\n graphID?: string;\r\n}\r\n\r\nexport function DualAxisLineChart(props: Props) {\r\n const {\r\n data,\r\n graphTitle,\r\n sources,\r\n graphDescription,\r\n height,\r\n width,\r\n footNote,\r\n noOfXTicks = 10,\r\n dateFormat = 'yyyy',\r\n showValues = false,\r\n padding,\r\n lineColors = [\r\n Colors.light.categoricalColors.colors[0],\r\n Colors.light.categoricalColors.colors[1],\r\n ],\r\n sameAxes = false,\r\n backgroundColor = false,\r\n leftMargin = 80,\r\n rightMargin = 80,\r\n topMargin = 20,\r\n bottomMargin = 25,\r\n labels,\r\n lineSuffixes = ['', ''],\r\n linePrefixes = ['', ''],\r\n tooltip,\r\n highlightAreaSettings = [],\r\n relativeHeight,\r\n onSeriesMouseOver,\r\n graphID,\r\n graphDownload = false,\r\n dataDownload = false,\r\n animate = false,\r\n strokeWidth = 2,\r\n showDots = true,\r\n language = 'en',\r\n showColorScale = true,\r\n minHeight = 0,\r\n colorLegendTitle,\r\n theme = 'light',\r\n ariaLabel,\r\n noOfYTicks = 5,\r\n maxDate,\r\n minDate,\r\n curveType = 'curve',\r\n styles,\r\n classNames,\r\n precision = 2,\r\n customLayers = [],\r\n showAxisLabels = true,\r\n } = props;\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 useEffect(() => {\r\n const resizeObserver = new ResizeObserver(entries => {\r\n setSvgWidth(width || entries[0].target.clientWidth || 620);\r\n setSvgHeight(height || entries[0].target.clientHeight || 480);\r\n });\r\n if (graphDiv.current) {\r\n setSvgHeight(graphDiv.current.clientHeight || 480);\r\n setSvgWidth(graphDiv.current.clientWidth || 620);\r\n if (!width) resizeObserver.observe(graphDiv.current);\r\n }\r\n return () => resizeObserver.disconnect();\r\n }, [width, height]);\r\n\r\n return (\r\n <div\r\n className={`${theme || 'light'} flex ${width ? 'w-fit grow-0' : 'w-full grow'}`}\r\n dir={language === 'he' || language === 'ar' ? 'rtl' : undefined}\r\n >\r\n <div\r\n className={cn(\r\n `${\r\n !backgroundColor\r\n ? 'bg-transparent '\r\n : backgroundColor === true\r\n ? 'bg-primary-gray-200 dark:bg-primary-gray-650 '\r\n : ''\r\n }ml-auto mr-auto flex flex-col grow h-inherit ${language || 'en'}`,\r\n width ? 'w-fit' : 'w-full',\r\n classNames?.graphContainer,\r\n )}\r\n style={{\r\n ...(styles?.graphContainer || {}),\r\n ...(backgroundColor && backgroundColor !== true ? { backgroundColor } : {}),\r\n }}\r\n id={graphID}\r\n ref={graphParentDiv}\r\n aria-label={\r\n ariaLabel ||\r\n `${\r\n graphTitle ? `The graph shows ${graphTitle}. ` : ''\r\n }This is a line chart that show trends for two datasets over time.${\r\n graphDescription ? ` ${graphDescription}` : ''\r\n }`\r\n }\r\n >\r\n <div\r\n className='flex grow'\r\n style={{ padding: backgroundColor ? padding || '1rem' : padding || 0 }}\r\n >\r\n <div className='flex flex-col w-full gap-4 grow justify-between'>\r\n {graphTitle || graphDescription || graphDownload || dataDownload ? (\r\n <GraphHeader\r\n styles={{\r\n title: styles?.title,\r\n description: styles?.description,\r\n }}\r\n classNames={{\r\n title: classNames?.title,\r\n description: classNames?.description,\r\n }}\r\n graphTitle={graphTitle}\r\n graphDescription={graphDescription}\r\n width={width}\r\n graphDownload={graphDownload ? graphParentDiv.current : undefined}\r\n dataDownload={\r\n dataDownload\r\n ? data.map(d => d.data).filter(d => d !== undefined).length > 0\r\n ? data.map(d => d.data).filter(d => d !== undefined)\r\n : data.filter(d => d !== undefined)\r\n : null\r\n }\r\n />\r\n ) : null}\r\n <div className='grow flex flex-col justify-center gap-3 w-full'>\r\n {data.length === 0 ? (\r\n <EmptyState />\r\n ) : (\r\n <>\r\n {!showColorScale ? null : (\r\n <ColorLegend\r\n colorDomain={labels}\r\n colorLegendTitle={colorLegendTitle}\r\n colors={lineColors}\r\n showNAColor={false}\r\n />\r\n )}\r\n <div\r\n className='flex flex-col grow justify-center leading-0'\r\n ref={graphDiv}\r\n aria-label='Graph area'\r\n >\r\n {(width || svgWidth) && (height || svgHeight) ? (\r\n <Graph\r\n data={data}\r\n sameAxes={sameAxes}\r\n lineColors={lineColors}\r\n width={width || svgWidth}\r\n height={Math.max(\r\n minHeight,\r\n height ||\r\n (relativeHeight\r\n ? minHeight\r\n ? (width || svgWidth) * relativeHeight > minHeight\r\n ? (width || svgWidth) * relativeHeight\r\n : minHeight\r\n : (width || svgWidth) * relativeHeight\r\n : svgHeight),\r\n )}\r\n dateFormat={dateFormat}\r\n showValues={showValues}\r\n noOfXTicks={noOfXTicks}\r\n leftMargin={leftMargin}\r\n rightMargin={rightMargin}\r\n topMargin={topMargin}\r\n bottomMargin={bottomMargin}\r\n labels={labels}\r\n highlightAreaSettings={highlightAreaSettings}\r\n tooltip={tooltip}\r\n onSeriesMouseOver={onSeriesMouseOver}\r\n animate={\r\n animate === true\r\n ? { duration: 0.5, once: true, amount: 0.5 }\r\n : animate || { duration: 0, once: true, amount: 0 }\r\n }\r\n strokeWidth={strokeWidth}\r\n showDots={showDots}\r\n noOfYTicks={noOfYTicks}\r\n lineSuffixes={lineSuffixes}\r\n linePrefixes={linePrefixes}\r\n minDate={minDate}\r\n maxDate={maxDate}\r\n curveType={curveType}\r\n styles={styles}\r\n classNames={classNames}\r\n precision={precision}\r\n customLayers={customLayers}\r\n showAxisLabels={showAxisLabels}\r\n />\r\n ) : null}\r\n </div>\r\n </>\r\n )}\r\n </div>\r\n {sources || footNote ? (\r\n <GraphFooter\r\n styles={{ footnote: styles?.footnote, source: styles?.source }}\r\n classNames={{\r\n footnote: classNames?.footnote,\r\n source: classNames?.source,\r\n }}\r\n sources={sources}\r\n footNote={footNote}\r\n width={width}\r\n />\r\n ) : null}\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n );\r\n}\r\n"],"names":["Graph","props","data","width","height","lineColors","labels","sameAxes","dateFormat","showValues","noOfXTicks","rightMargin","leftMargin","topMargin","bottomMargin","tooltip","highlightAreaSettings","onSeriesMouseOver","animate","strokeWidth","showDots","noOfYTicks","lineSuffixes","linePrefixes","minDate","maxDate","curveType","styles","classNames","precision","customLayers","showAxisLabels","svgRef","useRef","isInView","useInView","hasAnimatedOnce","setHasAnimatedOnce","useState","useEffect","timeout","curve","curveLinear","curveStep","curveStepAfter","curveStepBefore","curveMonotoneX","mouseOverData","setMouseOverData","eventX","setEventX","eventY","setEventY","margin","MouseoverRectRef","dataFormatted","orderBy","d","parse","highlightAreaSettingsFormatted","graphWidth","graphHeight","minYear","maxYear","minParam1","minParam2","maxParam1","maxParam2","minParam","maxParam","x","scaleTime","y1","scaleLinear","y2","lineShape1","line","checkIfNullOrUndefined","lineShape2","y1Ticks","y2Ticks","xTicks","mousemove","event","selectedData","bisectCenter","pointer","mouseout","select","jsxs","Fragment","jsx","motion","HighlightArea","i","cn","numberFormattingFunction","Axis","AxisTitle","XTicksAndGridLines","format","el","Tooltip","DualAxisLineChart","graphTitle","sources","graphDescription","footNote","padding","Colors","backgroundColor","relativeHeight","graphID","graphDownload","dataDownload","language","showColorScale","minHeight","colorLegendTitle","theme","ariaLabel","svgWidth","setSvgWidth","svgHeight","setSvgHeight","graphDiv","graphParentDiv","resizeObserver","entries","GraphHeader","EmptyState","ColorLegend","GraphFooter"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"DualAxisLineChart.cjs","sources":["../src/Components/Graphs/LineCharts/DualAxisLineChart/Graph.tsx","../src/Components/Graphs/LineCharts/DualAxisLineChart/index.tsx"],"sourcesContent":["import { useEffect, useRef, useState } from 'react';\r\nimport {\r\n line,\r\n curveMonotoneX,\r\n curveLinear,\r\n curveStep,\r\n curveStepAfter,\r\n curveStepBefore,\r\n} from 'd3-shape';\r\nimport { scaleLinear, scaleTime } from 'd3-scale';\r\nimport { format } from 'date-fns/format';\r\nimport { parse } from 'date-fns/parse';\r\nimport { bisectCenter } from 'd3-array';\r\nimport { pointer, select } from 'd3-selection';\r\nimport { motion, useInView } from 'motion/react';\r\nimport { cn } from '@undp/design-system-react/cn';\r\nimport orderBy from 'lodash.orderby';\r\n\r\nimport {\r\n AnimateDataType,\r\n ClassNameObject,\r\n CurveTypes,\r\n CustomLayerDataType,\r\n DualAxisLineChartDataType,\r\n HighlightAreaSettingsDataType,\r\n StyleObject,\r\n} from '@/Types';\r\nimport { numberFormattingFunction } from '@/Utils/numberFormattingFunction';\r\nimport { Tooltip } from '@/Components/Elements/Tooltip';\r\nimport { checkIfNullOrUndefined } from '@/Utils/checkIfNullOrUndefined';\r\nimport { XTicksAndGridLines } from '@/Components/Elements/Axes/XTicksAndGridLines';\r\nimport { Axis } from '@/Components/Elements/Axes/Axis';\r\nimport { AxisTitle } from '@/Components/Elements/Axes/AxisTitle';\r\nimport { HighlightArea } from '@/Components/Elements/HighlightArea';\r\n\r\ninterface Props {\r\n data: DualAxisLineChartDataType[];\r\n lineColors: [string, string];\r\n labels: [string, string];\r\n width: number;\r\n height: number;\r\n dateFormat: string;\r\n showValues: boolean;\r\n noOfXTicks: number;\r\n rightMargin: number;\r\n leftMargin: number;\r\n topMargin: number;\r\n bottomMargin: number;\r\n sameAxes: boolean;\r\n highlightAreaSettings: HighlightAreaSettingsDataType[];\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n tooltip?: string | ((_d: any) => React.ReactNode);\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseOver?: (_d: any) => void;\r\n animate: AnimateDataType;\r\n strokeWidth: number;\r\n showDots: boolean;\r\n noOfYTicks: number;\r\n lineSuffixes: [string, string];\r\n linePrefixes: [string, string];\r\n minDate?: string | number;\r\n maxDate?: string | number;\r\n curveType: CurveTypes;\r\n styles?: StyleObject;\r\n classNames?: ClassNameObject;\r\n precision: number;\r\n customLayers: CustomLayerDataType[];\r\n showAxisLabels: boolean;\r\n}\r\n\r\ninterface FormattedDataType {\r\n y1: number;\r\n y2: number;\r\n date: Date;\r\n}\r\n\r\nexport function Graph(props: Props) {\r\n const {\r\n data,\r\n width,\r\n height,\r\n lineColors,\r\n labels,\r\n sameAxes,\r\n dateFormat,\r\n showValues,\r\n noOfXTicks,\r\n rightMargin,\r\n leftMargin,\r\n topMargin,\r\n bottomMargin,\r\n tooltip,\r\n highlightAreaSettings,\r\n onSeriesMouseOver,\r\n animate,\r\n strokeWidth,\r\n showDots,\r\n noOfYTicks,\r\n lineSuffixes,\r\n linePrefixes,\r\n minDate,\r\n maxDate,\r\n curveType,\r\n styles,\r\n classNames,\r\n precision,\r\n customLayers,\r\n showAxisLabels,\r\n } = props;\r\n const svgRef = useRef(null);\r\n const isInView = useInView(svgRef, {\r\n once: animate.once,\r\n amount: animate.amount,\r\n });\r\n const [hasAnimatedOnce, setHasAnimatedOnce] = useState(false);\r\n\r\n useEffect(() => {\r\n if (isInView && !hasAnimatedOnce) {\r\n const timeout = setTimeout(\r\n () => {\r\n setHasAnimatedOnce(true);\r\n },\r\n (animate.duration + 0.5) * 1000,\r\n );\r\n return () => clearTimeout(timeout);\r\n }\r\n }, [isInView, hasAnimatedOnce, animate.duration]);\r\n const curve =\r\n curveType === 'linear'\r\n ? curveLinear\r\n : curveType === 'step'\r\n ? curveStep\r\n : curveType === 'stepAfter'\r\n ? curveStepAfter\r\n : curveType === 'stepBefore'\r\n ? curveStepBefore\r\n : curveMonotoneX;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const [mouseOverData, setMouseOverData] = useState<any>(undefined);\r\n const [eventX, setEventX] = useState<number | undefined>(undefined);\r\n const [eventY, setEventY] = useState<number | undefined>(undefined);\r\n const margin = {\r\n top: topMargin,\r\n bottom: bottomMargin,\r\n left: leftMargin + 50,\r\n right: rightMargin + 65,\r\n };\r\n const MouseoverRectRef = useRef(null);\r\n const dataFormatted = orderBy(\r\n data.map(d => ({\r\n ...d,\r\n date: parse(`${d.date}`, dateFormat, new Date()),\r\n })),\r\n ['date'],\r\n ['asc'],\r\n );\r\n const highlightAreaSettingsFormatted = highlightAreaSettings.map(d => ({\r\n ...d,\r\n coordinates: [\r\n d.coordinates[0] === null ? null : parse(`${d.coordinates[0]}`, dateFormat, new Date()),\r\n d.coordinates[1] === null ? null : parse(`${d.coordinates[1]}`, dateFormat, new Date()),\r\n ],\r\n }));\r\n const graphWidth = width - margin.left - margin.right;\r\n const graphHeight = height - margin.top - margin.bottom;\r\n const minYear = minDate ? parse(`${minDate}`, dateFormat, new Date()) : dataFormatted[0].date;\r\n const maxYear = maxDate\r\n ? parse(`${maxDate}`, dateFormat, new Date())\r\n : dataFormatted[dataFormatted.length - 1].date;\r\n const minParam1 =\r\n Math.min(...dataFormatted.map(d => d.y1).filter(d => d !== undefined && d !== null)) !==\r\n Infinity\r\n ? Math.min(...dataFormatted.map(d => d.y2).filter(d => d !== undefined && d !== null)) > 0\r\n ? 0\r\n : Math.min(...dataFormatted.map(d => d.y1).filter(d => d !== undefined && d !== null))\r\n : 0;\r\n const minParam2 =\r\n Math.min(...dataFormatted.map(d => d.y2).filter(d => d !== undefined && d !== null)) !==\r\n Infinity\r\n ? Math.min(...dataFormatted.map(d => d.y2).filter(d => d !== undefined && d !== null)) > 0\r\n ? 0\r\n : Math.min(...dataFormatted.map(d => d.y2).filter(d => d !== undefined && d !== null))\r\n : 0;\r\n const maxParam1 =\r\n Math.max(...dataFormatted.map(d => d.y1).filter(d => d !== undefined && d !== null)) !==\r\n Infinity\r\n ? Math.max(...dataFormatted.map(d => d.y1).filter(d => d !== undefined && d !== null))\r\n : 0;\r\n const maxParam2 =\r\n Math.max(...dataFormatted.map(d => d.y2).filter(d => d !== undefined && d !== null)) !==\r\n Infinity\r\n ? Math.max(...dataFormatted.map(d => d.y2).filter(d => d !== undefined && d !== null))\r\n : 0;\r\n\r\n const minParam = minParam1 < minParam2 ? minParam1 : minParam2;\r\n const maxParam = maxParam1 > maxParam2 ? maxParam1 : maxParam2;\r\n const x = scaleTime().domain([minYear, maxYear]).range([0, graphWidth]);\r\n\r\n const y1 = scaleLinear()\r\n .domain([\r\n sameAxes ? minParam : minParam1,\r\n sameAxes ? (maxParam > 0 ? maxParam : 0) : maxParam1 > 0 ? maxParam1 : 0,\r\n ])\r\n .range([graphHeight, 0])\r\n .nice();\r\n const y2 = scaleLinear()\r\n .domain([\r\n sameAxes ? minParam : minParam2,\r\n sameAxes ? (maxParam > 0 ? maxParam : 0) : maxParam2 > 0 ? maxParam2 : 0,\r\n ])\r\n .range([graphHeight, 0])\r\n .nice();\r\n\r\n const lineShape1 = line<FormattedDataType>()\r\n .defined(d => !checkIfNullOrUndefined(d.y1))\r\n .x(d => x(d.date))\r\n .y(d => y1(d.y1))\r\n .curve(curve);\r\n\r\n const lineShape2 = line<FormattedDataType>()\r\n .defined(d => !checkIfNullOrUndefined(d.y2))\r\n .x(d => x(d.date))\r\n .y(d => y2(d.y2))\r\n .curve(curve);\r\n const y1Ticks = y1.ticks(noOfYTicks);\r\n const y2Ticks = y2.ticks(noOfYTicks);\r\n const xTicks = x.ticks(noOfXTicks);\r\n useEffect(() => {\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const mousemove = (event: any) => {\r\n const selectedData =\r\n dataFormatted[\r\n bisectCenter(\r\n dataFormatted.map(d => d.date),\r\n x.invert(pointer(event)[0]),\r\n 0,\r\n )\r\n ];\r\n setMouseOverData(selectedData || dataFormatted[dataFormatted.length - 1]);\r\n onSeriesMouseOver?.(selectedData || dataFormatted[dataFormatted.length - 1]);\r\n setEventY(event.clientY);\r\n setEventX(event.clientX);\r\n };\r\n const mouseout = () => {\r\n setMouseOverData(undefined);\r\n setEventX(undefined);\r\n setEventY(undefined);\r\n onSeriesMouseOver?.(undefined);\r\n };\r\n select(MouseoverRectRef.current).on('mousemove', mousemove).on('mouseout', mouseout);\r\n }, [x, dataFormatted, onSeriesMouseOver]);\r\n\r\n return (\r\n <>\r\n <motion.svg\r\n width={`${width}px`}\r\n height={`${height}px`}\r\n viewBox={`0 0 ${width} ${height}`}\r\n direction='ltr'\r\n ref={svgRef}\r\n >\r\n <g transform={`translate(${margin.left},${margin.top})`}>\r\n <HighlightArea\r\n areaSettings={highlightAreaSettingsFormatted}\r\n width={graphWidth}\r\n height={graphHeight}\r\n scale={x}\r\n animate={animate}\r\n isInView={isInView}\r\n />\r\n <g>\r\n {y1Ticks.map((d, i) => (\r\n <g key={i}>\r\n <line\r\n y1={y1(d)}\r\n y2={y1(d)}\r\n x1={-15}\r\n x2={-20}\r\n style={{\r\n stroke: lineColors[0],\r\n strokeWidth: 1,\r\n ...(styles?.yAxis?.gridLines || {}),\r\n }}\r\n className={classNames?.yAxis?.gridLines}\r\n />\r\n <text\r\n x={0 - 25}\r\n y={y1(d)}\r\n dy='0.33em'\r\n className={cn('text-xs', classNames?.yAxis?.labels)}\r\n style={{\r\n textAnchor: 'end',\r\n fill: lineColors[0],\r\n ...(styles?.yAxis?.labels || {}),\r\n }}\r\n >\r\n {numberFormattingFunction(d, 'NA', precision, linePrefixes[0], lineSuffixes[0])}\r\n </text>\r\n </g>\r\n ))}\r\n <Axis\r\n y1={0}\r\n y2={graphHeight}\r\n x1={-15}\r\n x2={-15}\r\n classNames={{ axis: classNames?.xAxis?.axis }}\r\n styles={{ axis: { stroke: lineColors[0], ...(styles?.xAxis?.axis || {}) } }}\r\n />\r\n\r\n {showAxisLabels ? (\r\n <AxisTitle\r\n x={10 - margin.left}\r\n y={graphHeight / 2}\r\n style={{ fill: lineColors[0], ...(styles?.yAxis?.title || {}) }}\r\n className={classNames?.yAxis?.title}\r\n text={labels[0].length > 100 ? `${labels[0].substring(0, 100)}...` : labels[0]}\r\n rotate90\r\n />\r\n ) : null}\r\n </g>\r\n <g>\r\n {y2Ticks.map((d, i) => (\r\n <g key={i}>\r\n <line\r\n y1={y2(d)}\r\n y2={y2(d)}\r\n x1={graphWidth + 15}\r\n x2={graphWidth + 20}\r\n style={{\r\n stroke: lineColors[1],\r\n strokeWidth: 1,\r\n ...(styles?.yAxis?.gridLines || {}),\r\n }}\r\n className={classNames?.yAxis?.gridLines}\r\n />\r\n <text\r\n x={graphWidth + 25}\r\n y={y2(d)}\r\n dy='0.33em'\r\n dx={-2}\r\n style={{\r\n textAnchor: 'start',\r\n fill: lineColors[1],\r\n ...(styles?.yAxis?.labels || {}),\r\n }}\r\n className={cn('text-xs', classNames?.yAxis?.labels)}\r\n >\r\n {numberFormattingFunction(d, 'NA', precision, linePrefixes[1], lineSuffixes[1])}\r\n </text>\r\n </g>\r\n ))}\r\n <Axis\r\n y1={0}\r\n y2={graphHeight}\r\n x1={graphWidth + 15}\r\n x2={graphWidth + 15}\r\n classNames={{ axis: classNames?.xAxis?.axis }}\r\n styles={{ axis: { stroke: lineColors[1], ...(styles?.xAxis?.axis || {}) } }}\r\n />\r\n {showAxisLabels ? (\r\n <AxisTitle\r\n x={graphWidth + margin.right - 15}\r\n y={graphHeight / 2}\r\n style={{ fill: lineColors[1], ...(styles?.yAxis?.title || {}) }}\r\n className={classNames?.yAxis?.title}\r\n text={labels[1].length > 100 ? `${labels[1].substring(0, 100)}...` : labels[1]}\r\n rotate90\r\n />\r\n ) : null}\r\n </g>\r\n <g>\r\n <Axis\r\n y1={graphHeight}\r\n y2={graphHeight}\r\n x1={-15}\r\n x2={graphWidth + 15}\r\n classNames={{ axis: classNames?.xAxis?.axis }}\r\n styles={{ axis: styles?.xAxis?.axis }}\r\n />\r\n <XTicksAndGridLines\r\n values={xTicks.map(d => format(d, dateFormat))}\r\n x={xTicks.map(d => x(d))}\r\n y1={0}\r\n y2={graphHeight}\r\n styles={{\r\n gridLines: styles?.xAxis?.gridLines,\r\n labels: styles?.xAxis?.labels,\r\n }}\r\n classNames={{\r\n gridLines: cn('opacity-0', classNames?.xAxis?.gridLines),\r\n labels: cn(\r\n 'fill-primary-gray-700 dark:fill-primary-gray-300 xs:max-[360px]:hidden text-[9px] md:text-[10px] lg:text-xs',\r\n classNames?.xAxis?.labels,\r\n ),\r\n }}\r\n labelType='primary'\r\n showGridLines\r\n precision={precision}\r\n />\r\n </g>\r\n {customLayers.filter(d => d.position === 'before').map(d => d.layer)}\r\n <g>\r\n <motion.path\r\n style={{\r\n stroke: lineColors[0],\r\n strokeWidth,\r\n fill: 'none',\r\n }}\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n variants={{\r\n initial: {\r\n pathLength: 0,\r\n d:\r\n lineShape1(\r\n dataFormatted.filter(\r\n (el): el is FormattedDataType => !checkIfNullOrUndefined(el.y1),\r\n ),\r\n ) || '',\r\n opacity: 1,\r\n },\r\n whileInView: {\r\n pathLength: 1,\r\n d:\r\n lineShape1(\r\n dataFormatted.filter(\r\n (el): el is FormattedDataType => !checkIfNullOrUndefined(el.y1),\r\n ),\r\n ) || '',\r\n opacity: 1,\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n />\r\n <motion.path\r\n d={\r\n lineShape2(\r\n dataFormatted.filter(\r\n (el): el is FormattedDataType => !checkIfNullOrUndefined(el.y2),\r\n ),\r\n ) || ''\r\n }\r\n style={{\r\n stroke: lineColors[1],\r\n strokeWidth,\r\n fill: 'none',\r\n }}\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n variants={{\r\n initial: {\r\n pathLength: 0,\r\n d:\r\n lineShape2(\r\n dataFormatted.filter(\r\n (el): el is FormattedDataType => !checkIfNullOrUndefined(el.y2),\r\n ),\r\n ) || '',\r\n opacity: 1,\r\n },\r\n whileInView: {\r\n pathLength: 1,\r\n d:\r\n lineShape2(\r\n dataFormatted.filter(\r\n (el): el is FormattedDataType => !checkIfNullOrUndefined(el.y2),\r\n ),\r\n ) || '',\r\n opacity: 1,\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n />\r\n {mouseOverData ? (\r\n <line\r\n y1={0}\r\n y2={graphHeight}\r\n x1={x(mouseOverData.date)}\r\n x2={x(mouseOverData.date)}\r\n className={cn(\r\n 'undp-tick-line stroke-primary-gray-700 dark:stroke-primary-gray-100',\r\n classNames?.mouseOverLine,\r\n )}\r\n style={styles?.mouseOverLine}\r\n />\r\n ) : null}\r\n </g>\r\n <g>\r\n {dataFormatted.map((d, i) => (\r\n <motion.g key={i}>\r\n {!checkIfNullOrUndefined(d.y1) ? (\r\n <>\r\n {showDots ? (\r\n <motion.circle\r\n r={\r\n graphWidth / dataFormatted.length < 5\r\n ? 0\r\n : graphWidth / dataFormatted.length < 20\r\n ? 2\r\n : 4\r\n }\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n variants={{\r\n initial: {\r\n opacity: 0,\r\n cx: x(d.date),\r\n cy: y1(d.y1 as number),\r\n fill: lineColors[0],\r\n },\r\n whileInView: {\r\n opacity: 1,\r\n fill: lineColors[0],\r\n transition: {\r\n duration: hasAnimatedOnce ? animate.duration : 0.5,\r\n delay: hasAnimatedOnce ? 0 : animate.duration,\r\n },\r\n cx: x(d.date),\r\n cy: y1(d.y1 as number),\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n />\r\n ) : null}\r\n {showValues ? (\r\n <motion.text\r\n dy={\r\n checkIfNullOrUndefined(d.y2)\r\n ? -8\r\n : (d.y2 as number) < (d.y1 as number)\r\n ? -8\r\n : '1em'\r\n }\r\n style={{\r\n textAnchor: 'middle',\r\n ...(styles?.graphObjectValues || {}),\r\n }}\r\n className={cn(\r\n 'graph-value graph-value-line-1 text-xs font-bold',\r\n classNames?.graphObjectValues,\r\n )}\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n variants={{\r\n initial: {\r\n opacity: 0,\r\n x: x(d.date),\r\n y: y2(d.y1 as number),\r\n fill: lineColors[0],\r\n },\r\n whileInView: {\r\n opacity: 1,\r\n x: x(d.date),\r\n fill: lineColors[0],\r\n y: y2(d.y1 as number),\r\n transition: {\r\n duration: hasAnimatedOnce ? animate.duration : 0.5,\r\n delay: hasAnimatedOnce ? 0 : animate.duration,\r\n },\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n >\r\n {numberFormattingFunction(\r\n d.y1,\r\n 'NA',\r\n precision,\r\n linePrefixes[0],\r\n lineSuffixes[0],\r\n )}\r\n </motion.text>\r\n ) : null}\r\n </>\r\n ) : null}\r\n {!checkIfNullOrUndefined(d.y2) ? (\r\n <>\r\n {showDots ? (\r\n <motion.circle\r\n r={\r\n graphWidth / dataFormatted.length < 5\r\n ? 0\r\n : graphWidth / dataFormatted.length < 20\r\n ? 2\r\n : 4\r\n }\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n variants={{\r\n initial: {\r\n opacity: 0,\r\n cx: x(d.date),\r\n cy: y2(d.y2 as number),\r\n fill: lineColors[1],\r\n },\r\n whileInView: {\r\n opacity: 1,\r\n transition: {\r\n duration: hasAnimatedOnce ? animate.duration : 0.5,\r\n delay: hasAnimatedOnce ? 0 : animate.duration,\r\n },\r\n fill: lineColors[1],\r\n cx: x(d.date),\r\n cy: y2(d.y2 as number),\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n />\r\n ) : null}\r\n {showValues ? (\r\n <motion.text\r\n dy={\r\n checkIfNullOrUndefined(d.y1)\r\n ? -8\r\n : (d.y1 as number) < (d.y2 as number)\r\n ? -8\r\n : '1em'\r\n }\r\n style={{\r\n textAnchor: 'middle',\r\n ...(styles?.graphObjectValues || {}),\r\n }}\r\n className={cn(\r\n 'graph-value graph-value-line-2 text-xs font-bold',\r\n classNames?.graphObjectValues,\r\n )}\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n variants={{\r\n initial: {\r\n opacity: 0,\r\n x: x(d.date),\r\n y: y2(d.y2 as number),\r\n fill: lineColors[1],\r\n },\r\n whileInView: {\r\n opacity: 1,\r\n x: x(d.date),\r\n y: y2(d.y2 as number),\r\n fill: lineColors[1],\r\n transition: {\r\n duration: hasAnimatedOnce ? animate.duration : 0.5,\r\n delay: hasAnimatedOnce ? 0 : animate.duration,\r\n },\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n >\r\n {numberFormattingFunction(\r\n d.y2,\r\n 'NA',\r\n precision,\r\n linePrefixes[1],\r\n lineSuffixes[1],\r\n )}\r\n </motion.text>\r\n ) : null}\r\n </>\r\n ) : null}\r\n </motion.g>\r\n ))}\r\n </g>\r\n {customLayers.filter(d => d.position === 'after').map(d => d.layer)}\r\n <rect\r\n ref={MouseoverRectRef}\r\n style={{\r\n fill: 'none',\r\n pointerEvents: 'all',\r\n }}\r\n width={graphWidth}\r\n height={graphHeight}\r\n />\r\n </g>\r\n </motion.svg>\r\n {mouseOverData && tooltip && eventX && eventY ? (\r\n <Tooltip\r\n data={mouseOverData}\r\n body={tooltip}\r\n xPos={eventX}\r\n yPos={eventY}\r\n backgroundStyle={styles?.tooltip}\r\n className={classNames?.tooltip}\r\n />\r\n ) : null}\r\n </>\r\n );\r\n}\r\n","import { useState, useRef, useEffect } from 'react';\r\n\r\nimport { Graph } from './Graph';\r\n\r\nimport { GraphFooter } from '@/Components/Elements/GraphFooter';\r\nimport { GraphHeader } from '@/Components/Elements/GraphHeader';\r\nimport { ColorLegend } from '@/Components/Elements/ColorLegend';\r\nimport {\r\n DualAxisLineChartDataType,\r\n Languages,\r\n SourcesDataType,\r\n StyleObject,\r\n ClassNameObject,\r\n HighlightAreaSettingsDataType,\r\n CurveTypes,\r\n CustomLayerDataType,\r\n AnimateDataType,\r\n} from '@/Types';\r\nimport { Colors } from '@/Components/ColorPalette';\r\nimport { EmptyState } from '@/Components/Elements/EmptyState';\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: DualAxisLineChartDataType[];\r\n\r\n // Titles, Labels, and Sources\r\n /** Title of the graph */\r\n graphTitle?: string | React.ReactNode;\r\n /** Description of the graph */\r\n graphDescription?: string | React.ReactNode;\r\n /** Footnote for the graph */\r\n footNote?: string | React.ReactNode;\r\n /** Source data for the graph */\r\n sources?: SourcesDataType[];\r\n /** Accessibility label */\r\n ariaLabel?: string;\r\n\r\n // Colors and Styling\r\n /** Array of colors for the 2 lines */\r\n lineColors?: [string, string];\r\n /** Title for the color legend */\r\n colorLegendTitle?: string;\r\n /** Background color of the graph */\r\n backgroundColor?: string | boolean;\r\n /** Custom styles for the graph. Each object should be a valid React CSS style object. */\r\n styles?: StyleObject;\r\n /** Custom class names */\r\n classNames?: ClassNameObject;\r\n\r\n // Size and Spacing\r\n /** Width of the graph */\r\n width?: number;\r\n /** Height of the graph */\r\n height?: number;\r\n /** Minimum height of the graph */\r\n minHeight?: number;\r\n /** Relative height scaling factor. This overwrites the height props */\r\n relativeHeight?: number;\r\n /** Padding around the graph. Defaults to 0 if no backgroundColor is mentioned else defaults to 1rem */\r\n padding?: string;\r\n /** Left margin of the graph */\r\n leftMargin?: number;\r\n /** Right margin of the graph */\r\n rightMargin?: number;\r\n /** Top margin of the graph */\r\n topMargin?: number;\r\n /** Bottom margin of the graph */\r\n bottomMargin?: number;\r\n\r\n // Values and Ticks\r\n /** Prefix for values of the lines */\r\n linePrefixes?: [string, string];\r\n /** Suffix for values of the lines */\r\n lineSuffixes?: [string, string];\r\n /** Maximum value of the date for the chart */\r\n maxDate?: string | number;\r\n /** Minimum value of the date for the chart */\r\n minDate?: string | number;\r\n /** No. of ticks on the x-axis */\r\n noOfXTicks?: number;\r\n /** No. of ticks on the y-axis */\r\n noOfYTicks?: number;\r\n\r\n // Graph Parameters\r\n /** Toggle visibility of values */\r\n showValues?: boolean;\r\n /** Toggle visibility of dots on the line */\r\n showDots?: boolean;\r\n /** Stroke width of the line */\r\n strokeWidth?: number;\r\n /** Toggle the initial animation of the line. If the type is number then it uses the number as the time in seconds for animation. */\r\n animate?: boolean | AnimateDataType;\r\n /** Enables same axis for the 2 lines */\r\n sameAxes?: boolean;\r\n /** Toggle visibility of color scale. */\r\n showColorScale?: boolean;\r\n /** Toggle visibility of labels of the axis. */\r\n showAxisLabels?: boolean;\r\n /** Labels for the lines */\r\n labels: [string, string];\r\n /** Format of the date in the data object. Available formats can be found [here](https://date-fns.org/docs/format) */\r\n dateFormat?: string;\r\n /** Highlighted area(square) on the chart */\r\n highlightAreaSettings?: HighlightAreaSettingsDataType[];\r\n /** Curve type for the line */\r\n curveType?: CurveTypes;\r\n /** Specifies the number of decimal places to display in the value. */\r\n precision?: number;\r\n /** Optional SVG <g> element or function that renders custom content behind or in front of the graph. */\r\n customLayers?: CustomLayerDataType[];\r\n /** Enable graph download option as png */\r\n graphDownload?: boolean;\r\n /** Enable data download option as a csv */\r\n dataDownload?: boolean;\r\n\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 /** Callback for mouse over event */\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseOver?: (_d: any) => void;\r\n\r\n // Configuration and Options\r\n /** Language setting */\r\n language?: Languages;\r\n /** Color theme */\r\n theme?: 'light' | 'dark';\r\n /** Unique ID for the graph */\r\n graphID?: string;\r\n}\r\n\r\nexport function DualAxisLineChart(props: Props) {\r\n const {\r\n data,\r\n graphTitle,\r\n sources,\r\n graphDescription,\r\n height,\r\n width,\r\n footNote,\r\n noOfXTicks = 10,\r\n dateFormat = 'yyyy',\r\n showValues = false,\r\n padding,\r\n lineColors = [\r\n Colors.light.categoricalColors.colors[0],\r\n Colors.light.categoricalColors.colors[1],\r\n ],\r\n sameAxes = false,\r\n backgroundColor = false,\r\n leftMargin = 80,\r\n rightMargin = 80,\r\n topMargin = 20,\r\n bottomMargin = 25,\r\n labels,\r\n lineSuffixes = ['', ''],\r\n linePrefixes = ['', ''],\r\n tooltip,\r\n highlightAreaSettings = [],\r\n relativeHeight,\r\n onSeriesMouseOver,\r\n graphID,\r\n graphDownload = false,\r\n dataDownload = false,\r\n animate = false,\r\n strokeWidth = 2,\r\n showDots = true,\r\n language = 'en',\r\n showColorScale = true,\r\n minHeight = 0,\r\n colorLegendTitle,\r\n theme = 'light',\r\n ariaLabel,\r\n noOfYTicks = 5,\r\n maxDate,\r\n minDate,\r\n curveType = 'curve',\r\n styles,\r\n classNames,\r\n precision = 2,\r\n customLayers = [],\r\n showAxisLabels = true,\r\n } = props;\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 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\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 || graphDownload || dataDownload ? (\r\n <GraphHeader\r\n styles={{\r\n title: styles?.title,\r\n description: styles?.description,\r\n }}\r\n classNames={{\r\n title: classNames?.title,\r\n description: classNames?.description,\r\n }}\r\n graphTitle={graphTitle}\r\n graphDescription={graphDescription}\r\n width={width}\r\n graphDownload={graphDownload ? graphParentDiv : 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 {data.length === 0 ? (\r\n <EmptyState />\r\n ) : (\r\n <>\r\n {!showColorScale ? null : (\r\n <ColorLegend\r\n colorDomain={labels}\r\n colorLegendTitle={colorLegendTitle}\r\n colors={lineColors}\r\n showNAColor={false}\r\n className={classNames?.colorLegend}\r\n />\r\n )}\r\n <GraphArea ref={graphDiv}>\r\n {svgWidth && svgHeight ? (\r\n <Graph\r\n data={data}\r\n sameAxes={sameAxes}\r\n lineColors={lineColors}\r\n width={svgWidth}\r\n height={svgHeight}\r\n dateFormat={dateFormat}\r\n showValues={showValues}\r\n noOfXTicks={noOfXTicks}\r\n leftMargin={leftMargin}\r\n rightMargin={rightMargin}\r\n topMargin={topMargin}\r\n bottomMargin={bottomMargin}\r\n labels={labels}\r\n highlightAreaSettings={highlightAreaSettings}\r\n tooltip={tooltip}\r\n onSeriesMouseOver={onSeriesMouseOver}\r\n animate={\r\n animate === true\r\n ? { duration: 0.5, once: true, amount: 0.5 }\r\n : animate || { duration: 0, once: true, amount: 0 }\r\n }\r\n strokeWidth={strokeWidth}\r\n showDots={showDots}\r\n noOfYTicks={noOfYTicks}\r\n lineSuffixes={lineSuffixes}\r\n linePrefixes={linePrefixes}\r\n minDate={minDate}\r\n maxDate={maxDate}\r\n curveType={curveType}\r\n styles={styles}\r\n classNames={classNames}\r\n precision={precision}\r\n customLayers={customLayers}\r\n showAxisLabels={showAxisLabels}\r\n />\r\n ) : null}\r\n </GraphArea>\r\n </>\r\n )}\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":["Graph","props","$","_c","data","width","height","lineColors","labels","sameAxes","dateFormat","showValues","noOfXTicks","rightMargin","leftMargin","topMargin","bottomMargin","tooltip","highlightAreaSettings","onSeriesMouseOver","animate","strokeWidth","showDots","noOfYTicks","lineSuffixes","linePrefixes","minDate","maxDate","curveType","styles","classNames","precision","customLayers","showAxisLabels","svgRef","useRef","t0","amount","once","isInView","useInView","hasAnimatedOnce","setHasAnimatedOnce","useState","t1","t2","duration","timeout","setTimeout","clearTimeout","useEffect","curve","curveLinear","curveStep","curveStepAfter","curveStepBefore","curveMonotoneX","mouseOverData","setMouseOverData","undefined","eventX","setEventX","eventY","setEventY","t3","t4","t5","top","bottom","left","right","margin","MouseoverRectRef","t6","d","date","parse","Date","dataFormatted","orderBy","map","t7","t8","d_0","coordinates","highlightAreaSettingsFormatted","graphWidth","graphHeight","minYear","maxYear","length","minParam1","Math","min","_temp","filter","_temp2","Infinity","_temp3","_temp4","_temp5","_temp6","minParam2","_temp7","_temp8","_temp9","_temp0","_temp1","_temp10","maxParam1","max","_temp11","_temp12","_temp13","_temp14","maxParam2","_temp15","_temp16","_temp17","_temp18","minParam","maxParam","x","scaleTime","domain","range","y1","scaleLinear","nice","y2","lineShape1","line","defined","_temp19","y","d_23","lineShape2","_temp20","d_26","y1Ticks","ticks","y2Ticks","xTicks","mousemove","event","selectedData","bisectCenter","_temp21","invert","pointer","clientY","clientX","mouseout","select","current","on","jsx","HighlightArea","t9","xAxis","axis","t10","t11","t12","stroke","t13","Axis","t14","yAxis","title","AxisTitle","fill","substring","t15","t16","t17","t18","t19","t20","t21","t22","t23","t24","t25","t26","t27","t28","t29","d_30","format","t30","t31","d_31","t32","gridLines","t33","t34","t35","t36","cn","t37","t38","t39","t40","_temp22","_temp23","t41","t42","opacity","transition","t43","t44","t45","d_34","i_1","jsxs","motion","checkIfNullOrUndefined","Fragment","initial","cx","cy","whileInView","delay","textAnchor","graphObjectValues","numberFormattingFunction","i","t46","t47","_temp29","_temp30","t48","Symbol","for","pointerEvents","t49","t50","Tooltip","d_28","d_29","i_0","XTicksAndGridLines","pathLength","_temp24","_temp25","_temp26","_temp27","_temp28","mouseOverLine","d_36","layer","d_35","position","el_3","el","el_2","el_1","el_0","d_33","d_32","d_27","d_24","d_21","d_18","d_17","d_20","d_19","d_14","d_13","d_16","d_15","d_8","d_7","d_10","d_9","d_12","d_11","d_2","d_1","d_4","d_3","d_6","d_5","DualAxisLineChart","graphTitle","sources","graphDescription","footNote","padding","backgroundColor","relativeHeight","graphID","graphDownload","dataDownload","language","showColorScale","minHeight","colorLegendTitle","theme","ariaLabel","Colors","light","categoricalColors","colors","svgWidth","setSvgWidth","svgHeight","setSvgHeight","graphDiv","graphParentDiv","resizeObserver","ResizeObserver","entries","target","clientWidth","clientHeight","observe","disconnect","graphContainer","description","GraphHeader","EmptyState","ColorLegend","colorLegend","GraphArea","footnote","source","GraphFooter","GraphContainer"],"mappings":"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"}
|