@undp/data-viz 1.5.9 → 2.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- 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 +2185 -4042
- 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 +118 -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 +518 -1016
- 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 +1 -0
- package/dist/BiVariateChoroplethMap.js +456 -697
- 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 +1 -0
- package/dist/ChoroplethMap.js +468 -722
- 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 -6
- 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 +3 -3
- 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/Data/barChart.json +70 -0
- package/dist/Data/basic.csv +20 -0
- 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 +731 -795
- 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 +1 -0
- package/dist/DotDensityMap.js +387 -574
- package/dist/DotDensityMap.js.map +1 -1
- package/dist/{DropdownSelect-6kjXM6oW.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 +620 -714
- 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-36lXXyui.js.map → EmptyState-BZo1BbAn.js.map} +1 -1
- package/dist/EmptyState-sAEZ_5rU.cjs +2 -0
- package/dist/{EmptyState-B8IpKGcL.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 +267 -342
- 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 -379
- 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 -278
- 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-2IiUDxjR.js → GraphEl-BZne2JIx.js} +181 -202
- package/dist/GraphEl-BZne2JIx.js.map +1 -0
- package/dist/GraphEl-D5MUfp45.cjs +2 -0
- package/dist/GraphEl-D5MUfp45.cjs.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 +1 -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 +1 -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 +677 -827
- 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 +1 -0
- package/dist/MultiGraphDashboard.js +126 -292
- 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 +1 -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 +139 -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 +582 -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 -724
- 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 +1 -0
- package/dist/PerformanceIntensiveMultiGraphDashboard.js +148 -337
- 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 +1 -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 +1 -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 +1 -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 +505 -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 +2 -1
- package/dist/SingleGraphDashboard.js +284 -508
- 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 +2 -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 +1 -0
- package/dist/SingleGraphDashboardGeoHubMaps.js +150 -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 +1 -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 +1 -0
- package/dist/SingleGraphDashboardThreeDGraphs.js +363 -593
- 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 +1 -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 +161 -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 +1 -0
- package/dist/ThreeDGlobe.js +356 -519
- 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 +1 -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-x4L4xwLl.js.map → customArea-BUhPiPT6.js.map} +1 -1
- package/dist/customArea-CMF5g-C3.cjs +2 -0
- package/dist/{customArea-1G1S78s_.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/getNoOfTicks-C_1CFXv_.cjs +2 -0
- package/dist/getNoOfTicks-C_1CFXv_.cjs.map +1 -0
- package/dist/getNoOfTicks-CpmRjcRF.js +7 -0
- package/dist/getNoOfTicks-CpmRjcRF.js.map +1 -0
- 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-BHe3wsWF.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-C6LorfZ-.cjs +2 -0
- package/dist/index-C6LorfZ-.cjs.map +1 -0
- package/dist/index-CHPV5EwG-CTPQjnHt.cjs +84 -0
- package/dist/index-CHPV5EwG-CTPQjnHt.cjs.map +1 -0
- package/dist/{index-CHPV5EwG-DBWUSD9b.js → index-CHPV5EwG-Curnpaqc.js} +724 -625
- package/dist/index-CHPV5EwG-Curnpaqc.js.map +1 -0
- package/dist/index-Ceppbd8C.js +342 -0
- package/dist/index-Ceppbd8C.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-Cw8sCyo_-BuI_jX5Z.js → index-Cw8sCyo_-B2hEKjzG.js} +16 -16
- package/dist/{index-Cw8sCyo_-BuI_jX5Z.js.map → index-Cw8sCyo_-B2hEKjzG.js.map} +1 -1
- package/dist/{index-Cw8sCyo_-gxT8ADyn.cjs → index-Cw8sCyo_-BrHiWiRF.cjs} +2 -2
- package/dist/{index-Cw8sCyo_-gxT8ADyn.cjs.map → index-Cw8sCyo_-BrHiWiRF.cjs.map} +1 -1
- 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-DxXnJ8Ti.cjs +2 -0
- package/dist/index-DxXnJ8Ti.cjs.map +1 -0
- package/dist/{index-Dzc_aaI9-BKklH89r.js → index-Dzc_aaI9-Bb7gobH_.js} +2 -2
- package/dist/{index-Dzc_aaI9-BKklH89r.js.map → index-Dzc_aaI9-Bb7gobH_.js.map} +1 -1
- package/dist/{index-Dzc_aaI9-RIk2GRHD.cjs → index-Dzc_aaI9-BmkfPMyc.cjs} +2 -2
- package/dist/{index-Dzc_aaI9-RIk2GRHD.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-Bw_eHBVN.js.map → index-SKgJALZg.js.map} +1 -1
- package/dist/index.cjs +1 -1
- package/dist/index.d.ts +10 -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-BYIC9BuT.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-DR-UTB96.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 +7 -6
- package/dist/Axis-4gUOL8B7.js +0 -43
- package/dist/Axis-4gUOL8B7.js.map +0 -1
- package/dist/Axis-CkNn1wit.cjs +0 -2
- package/dist/Axis-CkNn1wit.cjs.map +0 -1
- package/dist/AxisTitle-Wkz-xeQL.cjs +0 -2
- package/dist/AxisTitle-Wkz-xeQL.cjs.map +0 -1
- package/dist/AxisTitle-v6_xcXZ-.js +0 -20
- package/dist/AxisTitle-v6_xcXZ-.js.map +0 -1
- package/dist/DropdownSelect-6kjXM6oW.js.map +0 -1
- package/dist/DropdownSelect-vt8yiB-g.cjs +0 -29
- package/dist/DropdownSelect-vt8yiB-g.cjs.map +0 -1
- package/dist/EmptyState-36lXXyui.js +0 -22
- package/dist/EmptyState-B8IpKGcL.cjs +0 -2
- package/dist/GraphEl-2IiUDxjR.js.map +0 -1
- package/dist/GraphEl-qrlfGPe3.cjs +0 -2
- package/dist/GraphEl-qrlfGPe3.cjs.map +0 -1
- package/dist/Modal-Cg8daIlV.js +0 -1030
- package/dist/Modal-Cg8daIlV.js.map +0 -1
- package/dist/Modal-CuuJdWkD.cjs +0 -46
- package/dist/Modal-CuuJdWkD.cjs.map +0 -1
- package/dist/ReferenceLine-CPMaAX0r.js +0 -128
- package/dist/ReferenceLine-CPMaAX0r.js.map +0 -1
- package/dist/ReferenceLine-D04j-zeV.cjs +0 -2
- package/dist/ReferenceLine-D04j-zeV.cjs.map +0 -1
- package/dist/RegressionLine-CW7iViH2.js +0 -49
- package/dist/RegressionLine-CW7iViH2.js.map +0 -1
- package/dist/RegressionLine-D-49RaHa.cjs +0 -2
- package/dist/RegressionLine-D-49RaHa.cjs.map +0 -1
- package/dist/Spinner-Bpz70q_g.js +0 -30
- package/dist/Spinner-Bpz70q_g.js.map +0 -1
- package/dist/Spinner-C6wLp85s.cjs +0 -2
- package/dist/Spinner-C6wLp85s.cjs.map +0 -1
- package/dist/Tooltip-6LIdPQGC.js +0 -46
- package/dist/Tooltip-6LIdPQGC.js.map +0 -1
- package/dist/Tooltip-Cpv0QohJ.cjs +0 -2
- package/dist/Tooltip-Cpv0QohJ.cjs.map +0 -1
- package/dist/Typography-BDULiwlF.cjs +0 -2
- package/dist/Typography-BDULiwlF.cjs.map +0 -1
- package/dist/Typography-LmZ9LEpe.js +0 -140
- package/dist/Typography-LmZ9LEpe.js.map +0 -1
- package/dist/XAxesLabels-CLZnBgSr.cjs +0 -2
- package/dist/XAxesLabels-CLZnBgSr.cjs.map +0 -1
- package/dist/XAxesLabels-SOSmso5J.js +0 -57
- package/dist/XAxesLabels-SOSmso5J.js.map +0 -1
- package/dist/XTicksAndGridLines-DuydSnZ_.js +0 -56
- package/dist/XTicksAndGridLines-DuydSnZ_.js.map +0 -1
- package/dist/XTicksAndGridLines-RKy7BVCO.cjs +0 -2
- package/dist/XTicksAndGridLines-RKy7BVCO.cjs.map +0 -1
- package/dist/YAxesLabels-DlDyLvhi.js +0 -52
- package/dist/YAxesLabels-DlDyLvhi.js.map +0 -1
- package/dist/YAxesLabels-Dqd259-t.cjs +0 -2
- package/dist/YAxesLabels-Dqd259-t.cjs.map +0 -1
- package/dist/YTicksAndGridLines-7t4MKtGw.js +0 -56
- package/dist/YTicksAndGridLines-7t4MKtGw.js.map +0 -1
- package/dist/YTicksAndGridLines-qGpRo_t1.cjs +0 -2
- package/dist/YTicksAndGridLines-qGpRo_t1.cjs.map +0 -1
- package/dist/checkIfMultiple-Dko_cBvE.cjs +0 -12
- package/dist/checkIfMultiple-Dko_cBvE.cjs.map +0 -1
- package/dist/checkIfMultiple-u2SmbiCf.js +0 -912
- package/dist/checkIfMultiple-u2SmbiCf.js.map +0 -1
- package/dist/customArea-1G1S78s_.cjs +0 -2
- package/dist/customArea-x4L4xwLl.js +0 -175
- package/dist/fetchAndParseData-Ba-_CgxS.cjs +0 -16
- package/dist/getGraphList-DuColTJM.js +0 -265
- package/dist/getSliderMarks-CUxPy36E.cjs +0 -6
- package/dist/getSliderMarks-CUxPy36E.cjs.map +0 -1
- package/dist/getSliderMarks-_pYOWEtO.js +0 -1023
- package/dist/getSliderMarks-_pYOWEtO.js.map +0 -1
- package/dist/index-9tDEUqOZ.js.map +0 -1
- package/dist/index-BHe3wsWF.cjs +0 -2
- package/dist/index-Bw_eHBVN.js +0 -77
- package/dist/index-C0bpbS4F.cjs +0 -2
- package/dist/index-C0bpbS4F.cjs.map +0 -1
- package/dist/index-CE9pmfxt.js +0 -430
- package/dist/index-CE9pmfxt.js.map +0 -1
- package/dist/index-CEJwW3lL.cjs +0 -2
- package/dist/index-CEJwW3lL.cjs.map +0 -1
- package/dist/index-CHPV5EwG-DBWUSD9b.js.map +0 -1
- package/dist/index-CHPV5EwG-DjM48pIC.cjs +0 -44
- package/dist/index-CHPV5EwG-DjM48pIC.cjs.map +0 -1
- package/dist/index-CQ3e6Ewi.cjs +0 -2
- package/dist/index-Cm8NIdOO.cjs +0 -10
- package/dist/index-Cm8NIdOO.cjs.map +0 -1
- package/dist/index-CoZbeNM9.cjs +0 -2
- package/dist/index-CoZbeNM9.cjs.map +0 -1
- package/dist/index-Cwgh7i7X.js +0 -122
- package/dist/index-Cwgh7i7X.js.map +0 -1
- package/dist/index-D72cOtq7.cjs +0 -2
- package/dist/index-zZjQEHlm.js +0 -342
- package/dist/index-zZjQEHlm.js.map +0 -1
- package/dist/ordinal-BOeNbyae.cjs.map +0 -1
- package/dist/ordinal-w9Lu4Stb.js.map +0 -1
- package/dist/proxy-BYIC9BuT.js.map +0 -1
- package/dist/proxy-CKadx4lC.cjs +0 -2
- package/dist/proxy-CKadx4lC.cjs.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-CEwlc_dd.cjs +0 -2
- package/dist/use-in-view-CEwlc_dd.cjs.map +0 -1
- package/dist/use-in-view-DR-UTB96.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-DjM48pIC.cjs"),h=require("react"),F=require("./parse-hMnG_lRV.cjs"),Ne=require("./index-CQ3e6Ewi.cjs"),ae=require("./numberFormattingFunction-02t-wJta.cjs"),Ie=require("./Tooltip-Cpv0QohJ.cjs"),f=require("./checkIfNullOrUndefined-BCW3Y1ML.cjs"),Oe=require("./XTicksAndGridLines-RKy7BVCO.cjs"),ye=require("./Axis-CkNn1wit.cjs"),we=require("./AxisTitle-Wkz-xeQL.cjs"),Le=require("./index-BHe3wsWF.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-CEwlc_dd.cjs"),b=require("./proxy-CKadx4lC.cjs"),Ve=require("./GraphFooter.cjs"),$e=require("./GraphHeader.cjs"),Fe=require("./ColorLegend.cjs"),Re=require("./Colors.cjs"),Ce=require("./EmptyState-B8IpKGcL.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"),E=require("react"),Vt=require("./parse-hMnG_lRV.cjs"),be=require("./index-Cno4Q0YE.cjs"),ae=require("./numberFormattingFunction-02t-wJta.cjs"),ke=require("./Tooltip-4dJo4_AF.cjs"),L=require("./checkIfNullOrUndefined-BCW3Y1ML.cjs"),Ne=require("./XTicksAndGridLines-B6CELS7q.cjs"),he=require("./Axis-DxRV2yMi.cjs"),ve=require("./AxisTitle-sS5bLLR7.cjs"),Oe=require("./index-B_sAFsEV.cjs"),Ie=require("./time-CZd5YLSP.cjs"),je=require("./linear-BwPAspcq.cjs"),ye=require("./line-DHV4JwCR.cjs"),ce=require("./step-BZ3C8QFW.cjs"),Le=require("./select-Bnfk0lJx.cjs"),Se=require("./init-DU0ybBc_.cjs"),De=require("./pointer-Dkq5NV1q.cjs"),qe=require("./use-in-view-QcfiW0w3.cjs"),ct=require("./proxy-BxvUI_9l.cjs"),Me=require("./GraphFooter.cjs"),Te=require("./GraphHeader.cjs"),Ce=require("./ColorLegend.cjs"),Ae=require("./Colors.cjs"),Ve=require("./EmptyState-sAEZ_5rU.cjs"),we=require("./GraphContainer-d8A46BK2.cjs"),Fe=require("./getNoOfTicks-C_1CFXv_.cjs");function $e(e){const t=n.compilerRuntimeExports.c(117),{data:b,width:B,height:z,lineColors:o,labels:v,sameAxes:j,dateFormat:p,showValues:Rt,noOfXTicks:zt,rightMargin:Jt,leftMargin:Ft,topMargin:J,bottomMargin:bt,tooltip:ut,highlightAreaSettings:kt,onSeriesMouseOver:Nt,animate:s,strokeWidth:V,showDots:xt,noOfYTicks:mt,lineSuffixes:F,linePrefixes:K,minDate:pt,maxDate:Ot,curveType:Q,styles:a,classNames:c,precision:Z,customLayers:$,showAxisLabels:P}=e,$t=E.useRef(null);let ft;t[0]!==s.amount||t[1]!==s.once?(ft={once:s.once,amount:s.amount},t[0]=s.amount,t[1]=s.once,t[2]=ft):ft=t[2];const d=qe.useInView($t,ft),[y,Pt]=E.useState(!1);let dt,_;t[3]!==s.duration||t[4]!==y||t[5]!==d?(dt=()=>{if(d&&!y){const i=setTimeout(()=>{Pt(!0)},(s.duration+.5)*1e3);return()=>clearTimeout(i)}},_=[d,y,s.duration],t[3]=s.duration,t[4]=y,t[5]=d,t[6]=dt,t[7]=_):(dt=t[6],_=t[7]),E.useEffect(dt,_);const Gt=Q==="linear"?ye.curveLinear:Q==="step"?ce.curveStep:Q==="stepAfter"?ce.stepAfter:Q==="stepBefore"?ce.stepBefore:ce.monotoneX,[k,It]=E.useState(void 0),[ht,f]=E.useState(void 0),[m,Ht]=E.useState(void 0),tt=Ft+50,Lt=Jt+65;let et;t[8]!==bt||t[9]!==tt||t[10]!==Lt||t[11]!==J?(et={top:J,bottom:bt,left:tt,right:Lt},t[8]=bt,t[9]=tt,t[10]=Lt,t[11]=J,t[12]=et):et=t[12];const h=et,G=E.useRef(null);let H;t[13]!==p?(H=i=>({...i,date:Vt.parse(`${i.date}`,p,new Date)}),t[13]=p,t[14]=H):H=t[14];const r=be.orderBy(b.map(H),["date"],["asc"]);let it;if(t[15]!==p||t[16]!==kt){let i;t[18]!==p?(i=w=>({...w,coordinates:[w.coordinates[0]===null?null:Vt.parse(`${w.coordinates[0]}`,p,new Date),w.coordinates[1]===null?null:Vt.parse(`${w.coordinates[1]}`,p,new Date)]}),t[18]=p,t[19]=i):i=t[19],it=kt.map(i),t[15]=p,t[16]=kt,t[17]=it}else it=t[17];const yt=it,u=B-h.left-h.right,l=z-h.top-h.bottom,Ut=pt?Vt.parse(`${pt}`,p,new Date):r[0].date,St=Ot?Vt.parse(`${Ot}`,p,new Date):r[r.length-1].date,gt=Math.min(...r.map(yi).filter(hi))!==1/0?Math.min(...r.map(di).filter(fi))>0?0:Math.min(...r.map(pi).filter(mi)):0,nt=Math.min(...r.map(xi).filter(ui))!==1/0?Math.min(...r.map(ci).filter(ai))>0?0:Math.min(...r.map(li).filter(ri)):0,st=Math.max(...r.map(oi).filter(si))!==1/0?Math.max(...r.map(ni).filter(ii)):0,U=Math.max(...r.map(ei).filter(ti))!==1/0?Math.max(...r.map(_e).filter(Ze)):0,Dt=gt<nt?gt:nt,W=st>U?st:U,x=Ie.time().domain([Ut,St]).range([0,u]),R=je.linear().domain([j?Dt:gt,j?W>0?W:0:st>0?st:0]).range([l,0]).nice(),g=je.linear().domain([j?Dt:nt,j?W>0?W:0:U>0?U:0]).range([l,0]).nice(),qt=ye.line().defined(Qe).x(i=>x(i.date)).y(i=>R(i.y1)).curve(Gt),vt=ye.line().defined(Ke).x(i=>x(i.date)).y(i=>g(i.y2)).curve(Gt),Wt=R.ticks(mt),Xt=g.ticks(mt),Mt=x.ticks(zt);E.useEffect(()=>{const i=de=>{const ge=r[Se.bisectCenter(r.map(Je),x.invert(De.pointer(de)[0]),0)];It(ge||r[r.length-1]),Nt?.(ge||r[r.length-1]),Ht(de.clientY),f(de.clientX)},w=()=>{It(void 0),f(void 0),Ht(void 0),Nt?.(void 0)};Le.select(G.current).on("mousemove",i).on("mouseout",w)},[x,r,Nt]);let ot;t[20]!==s||t[21]!==l||t[22]!==u||t[23]!==yt||t[24]!==d||t[25]!==x?(ot=n.jsxRuntimeExports.jsx(Oe.HighlightArea,{areaSettings:yt,width:u,height:l,scale:x,animate:s,isInView:d}),t[20]=s,t[21]=l,t[22]=u,t[23]=yt,t[24]=d,t[25]=x,t[26]=ot):ot=t[26];const jt=c?.xAxis?.axis;let S;t[27]!==jt?(S={axis:jt},t[27]=jt,t[28]=S):S=t[28];let N;t[29]!==a?.xAxis?.axis?(N=a?.xAxis?.axis||{},t[29]=a?.xAxis?.axis,t[30]=N):N=t[30];let D;t[31]!==o[0]||t[32]!==N?(D={axis:{stroke:o[0],...N}},t[31]=o[0],t[32]=N,t[33]=D):D=t[33];let rt;t[34]!==l||t[35]!==S||t[36]!==D?(rt=n.jsxRuntimeExports.jsx(he.Axis,{y1:0,y2:l,x1:-15,x2:-15,classNames:S,styles:D}),t[34]=l,t[35]=S,t[36]=D,t[37]=rt):rt=t[37];let q;t[38]!==c?.yAxis?.title||t[39]!==l||t[40]!==v||t[41]!==o[0]||t[42]!==h.left||t[43]!==P||t[44]!==a?.yAxis?.title?(q=P?n.jsxRuntimeExports.jsx(ve.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]=P,t[44]=a?.yAxis?.title,t[45]=q):q=t[45];const Yt=u+15,lt=u+15,Bt=c?.xAxis?.axis;let M;t[46]!==Bt?(M={axis:Bt},t[46]=Bt,t[47]=M):M=t[47];let X;t[48]!==a?.xAxis?.axis?(X=a?.xAxis?.axis||{},t[48]=a?.xAxis?.axis,t[49]=X):X=t[49];let O;t[50]!==o[1]||t[51]!==X?(O={axis:{stroke:o[1],...X}},t[50]=o[1],t[51]=X,t[52]=O):O=t[52];let Y;t[53]!==l||t[54]!==Yt||t[55]!==lt||t[56]!==M||t[57]!==O?(Y=n.jsxRuntimeExports.jsx(he.Axis,{y1:0,y2:l,x1:Yt,x2:lt,classNames:M,styles:O}),t[53]=l,t[54]=Yt,t[55]=lt,t[56]=M,t[57]=O,t[58]=Y):Y=t[58];let at;t[59]!==c?.yAxis?.title||t[60]!==l||t[61]!==u||t[62]!==v||t[63]!==o[1]||t[64]!==h.right||t[65]!==P||t[66]!==a?.yAxis?.title?(at=P?n.jsxRuntimeExports.jsx(ve.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]=P,t[66]=a?.yAxis?.title,t[67]=at):at=t[67];const At=u+15,T=c?.xAxis?.axis;let A;t[68]!==T?(A={axis:T},t[68]=T,t[69]=A):A=t[69];const C=a?.xAxis?.axis;let I;t[70]!==C?(I={axis:C},t[70]=C,t[71]=I):I=t[71];let wt;t[72]!==l||t[73]!==At||t[74]!==A||t[75]!==I?(wt=n.jsxRuntimeExports.jsx(he.Axis,{y1:l,y2:l,x1:-15,x2:At,classNames:A,styles:I}),t[72]=l,t[73]=At,t[74]=A,t[75]=I,t[76]=wt):wt=t[76];let Et;t[77]!==p?(Et=i=>Vt.format(i,p),t[77]=p,t[78]=Et):Et=t[78];const Ee=Mt.map(Et),Re=Mt.map(i=>x(i)),ue=a?.xAxis?.gridLines,xe=a?.xAxis?.labels;let Kt;t[79]!==ue||t[80]!==xe?(Kt={gridLines:ue,labels:xe},t[79]=ue,t[80]=xe,t[81]=Kt):Kt=t[81];const me=c?.xAxis?.gridLines;let Tt;t[82]!==me?(Tt=n.mo("opacity-0",me),t[82]=me,t[83]=Tt):Tt=t[83];const pe=c?.xAxis?.labels;let Ct;t[84]!==pe?(Ct=n.mo("fill-primary-gray-700 dark:fill-primary-gray-300 xs:max-[360px]:hidden text-[9px] md:text-[10px] lg:text-xs",pe),t[84]=pe,t[85]=Ct):Ct=t[85];let Qt;t[86]!==Tt||t[87]!==Ct?(Qt={gridLines:Tt,labels:Ct},t[86]=Tt,t[87]=Ct,t[88]=Qt):Qt=t[88];let Zt;t[89]!==$?(Zt=$.filter(ze).map(Be),t[89]=$,t[90]=Zt):Zt=t[90];let _t;t[91]!==o[0]||t[92]!==V?(_t={stroke:o[0],strokeWidth:V,fill:"none"},t[91]=o[0],t[92]=V,t[93]=_t):_t=t[93];let te;t[94]!==s.duration?(te={opacity:0,transition:{duration:s.duration}},t[94]=s.duration,t[95]=te):te=t[95];let ee;t[96]!==o[1]||t[97]!==V?(ee={stroke:o[1],strokeWidth:V,fill:"none"},t[96]=o[1],t[97]=V,t[98]=ee):ee=t[98];let ie;t[99]!==s.duration?(ie={opacity:0,transition:{duration:s.duration}},t[99]=s.duration,t[100]=ie):ie=t[100];const fe=r.map((i,w)=>n.jsxRuntimeExports.jsxs(ct.motion.g,{children:[L.checkIfNullOrUndefined(i.y1)?null:n.jsxRuntimeExports.jsxs(n.jsxRuntimeExports.Fragment,{children:[xt?n.jsxRuntimeExports.jsx(ct.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:R(i.y1),fill:o[0]},whileInView:{opacity:1,fill:o[0],transition:{duration:y?s.duration:.5,delay:y?0:s.duration},cx:x(i.date),cy:R(i.y1)}},initial:"initial",animate:d?"whileInView":"initial"}):null,Rt?n.jsxRuntimeExports.jsx(ct.motion.text,{dy:L.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:g(i.y1),fill:o[0]},whileInView:{opacity:1,x:x(i.date),fill:o[0],y:g(i.y1),transition:{duration:y?s.duration:.5,delay:y?0:s.duration}}},initial:"initial",animate:d?"whileInView":"initial",children:ae.numberFormattingFunction(i.y1,"NA",Z,K[0],F[0])}):null]}),L.checkIfNullOrUndefined(i.y2)?null:n.jsxRuntimeExports.jsxs(n.jsxRuntimeExports.Fragment,{children:[xt?n.jsxRuntimeExports.jsx(ct.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:g(i.y2),fill:o[1]},whileInView:{opacity:1,transition:{duration:y?s.duration:.5,delay:y?0:s.duration},fill:o[1],cx:x(i.date),cy:g(i.y2)}},initial:"initial",animate:d?"whileInView":"initial"}):null,Rt?n.jsxRuntimeExports.jsx(ct.motion.text,{dy:L.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:g(i.y2),fill:o[1]},whileInView:{opacity:1,x:x(i.date),y:g(i.y2),fill:o[1],transition:{duration:y?s.duration:.5,delay:y?0:s.duration}}},initial:"initial",animate:d?"whileInView":"initial",children:ae.numberFormattingFunction(i.y2,"NA",Z,K[1],F[1])}):null]})]},w));let ne;t[101]!==fe?(ne=n.jsxRuntimeExports.jsx("g",{children:fe}),t[101]=fe,t[102]=ne):ne=t[102];let se;t[103]!==$?(se=$.filter(Ge).map(Pe),t[103]=$,t[104]=se):se=t[104];let oe;t[105]===Symbol.for("react.memo_cache_sentinel")?(oe={fill:"none",pointerEvents:"all"},t[105]=oe):oe=t[105];let re;t[106]!==G||t[107]!==l||t[108]!==u?(re=n.jsxRuntimeExports.jsx("rect",{ref:G,style:oe,width:u,height:l}),t[106]=G,t[107]=l,t[108]=u,t[109]=re):re=t[109];let le;return t[110]!==c?.tooltip||t[111]!==ht||t[112]!==m||t[113]!==k||t[114]!==a?.tooltip||t[115]!==ut?(le=k&&ut&&ht&&m?n.jsxRuntimeExports.jsx(ke.Tooltip,{data:k,body:ut,xPos:ht,yPos:m,backgroundStyle:a?.tooltip,className:c?.tooltip}):null,t[110]=c?.tooltip,t[111]=ht,t[112]=m,t[113]=k,t[114]=a?.tooltip,t[115]=ut,t[116]=le):le=t[116],n.jsxRuntimeExports.jsxs(n.jsxRuntimeExports.Fragment,{children:[n.jsxRuntimeExports.jsx(ct.motion.svg,{width:`${B}px`,height:`${z}px`,viewBox:`0 0 ${B} ${z}`,direction:"ltr",ref:$t,children:n.jsxRuntimeExports.jsxs("g",{transform:`translate(${h.left},${h.top})`,children:[ot,n.jsxRuntimeExports.jsxs("g",{children:[Wt.map((i,w)=>n.jsxRuntimeExports.jsxs("g",{children:[n.jsxRuntimeExports.jsx("line",{y1:R(i),y2:R(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:R(i),dy:"0.33em",className:n.mo("text-xs",c?.yAxis?.labels),style:{textAnchor:"end",fill:o[0],...a?.yAxis?.labels||{}},children:ae.numberFormattingFunction(i,"NA",Z,K[0],F[0])})]},w)),rt,q]}),n.jsxRuntimeExports.jsxs("g",{children:[Xt.map((i,w)=>n.jsxRuntimeExports.jsxs("g",{children:[n.jsxRuntimeExports.jsx("line",{y1:g(i),y2:g(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:g(i),dy:"0.33em",dx:-2,style:{textAnchor:"start",fill:o[1],...a?.yAxis?.labels||{}},className:n.mo("text-xs",c?.yAxis?.labels),children:ae.numberFormattingFunction(i,"NA",Z,K[1],F[1])})]},w)),Y,at]}),n.jsxRuntimeExports.jsxs("g",{children:[wt,n.jsxRuntimeExports.jsx(Ne.XTicksAndGridLines,{values:Ee,x:Re,y1:0,y2:l,styles:Kt,classNames:Qt,labelType:"primary",showGridLines:!0,precision:Z})]}),Zt,n.jsxRuntimeExports.jsxs("g",{children:[n.jsxRuntimeExports.jsx(ct.motion.path,{style:_t,exit:te,variants:{initial:{pathLength:0,d:qt(r.filter(Ye))||"",opacity:1},whileInView:{pathLength:1,d:qt(r.filter(Xe))||"",opacity:1,transition:{duration:s.duration}}},initial:"initial",animate:d?"whileInView":"initial"}),n.jsxRuntimeExports.jsx(ct.motion.path,{d:vt(r.filter(We))||"",style:ee,exit:ie,variants:{initial:{pathLength:0,d:vt(r.filter(Ue))||"",opacity:1},whileInView:{pathLength:1,d:vt(r.filter(He))||"",opacity:1,transition:{duration:s.duration}}},initial:"initial",animate:d?"whileInView":"initial"}),k?n.jsxRuntimeExports.jsx("line",{y1:0,y2:l,x1:x(k.date),x2:x(k.date),className:n.mo("undp-tick-line stroke-primary-gray-700 dark:stroke-primary-gray-100",c?.mouseOverLine),style:a?.mouseOverLine}):null]}),ne,se,re]})}),le]})}function Pe(e){return e.layer}function Ge(e){return e.position==="after"}function He(e){return!L.checkIfNullOrUndefined(e.y2)}function Ue(e){return!L.checkIfNullOrUndefined(e.y2)}function We(e){return!L.checkIfNullOrUndefined(e.y2)}function Xe(e){return!L.checkIfNullOrUndefined(e.y1)}function Ye(e){return!L.checkIfNullOrUndefined(e.y1)}function Be(e){return e.layer}function ze(e){return e.position==="before"}function Je(e){return e.date}function Ke(e){return!L.checkIfNullOrUndefined(e.y2)}function Qe(e){return!L.checkIfNullOrUndefined(e.y1)}function Ze(e){return e!=null}function _e(e){return e.y2}function ti(e){return e!=null}function ei(e){return e.y2}function ii(e){return e!=null}function ni(e){return e.y1}function si(e){return e!=null}function oi(e){return e.y1}function ri(e){return e!=null}function li(e){return e.y2}function ai(e){return e!=null}function ci(e){return e.y2}function ui(e){return e!=null}function xi(e){return e.y2}function mi(e){return e!=null}function pi(e){return e.y1}function fi(e){return e!=null}function di(e){return e.y2}function hi(e){return e!=null}function yi(e){return e.y1}function gi(e){const t=n.compilerRuntimeExports.c(80),{data:b,graphTitle:B,sources:z,graphDescription:o,height:v,width:j,footNote:p,noOfXTicks:Rt,dateFormat:zt,showValues:Jt,padding:Ft,lineColors:J,sameAxes:bt,backgroundColor:ut,leftMargin:kt,rightMargin:Nt,topMargin:s,bottomMargin:V,labels:xt,lineSuffixes:mt,linePrefixes:F,tooltip:K,highlightAreaSettings:pt,relativeHeight:Ot,onSeriesMouseOver:Q,graphID:a,graphDownload:c,dataDownload:Z,animate:$,strokeWidth:P,showDots:$t,language:ft,showColorScale:d,minHeight:y,colorLegendTitle:Pt,theme:dt,ariaLabel:_,noOfYTicks:Gt,maxDate:k,minDate:It,curveType:ht,styles:f,classNames:m,precision:Ht,customLayers:tt,showAxisLabels:Lt}=e,et=zt===void 0?"yyyy":zt,h=Jt===void 0?!1:Jt;let G;t[0]!==J?(G=J===void 0?[Ae.Colors.light.categoricalColors.colors[0],Ae.Colors.light.categoricalColors.colors[1]]:J,t[0]=J,t[1]=G):G=t[1];const H=G,r=bt===void 0?!1:bt,it=ut===void 0?!1:ut,yt=kt===void 0?80:kt,u=Nt===void 0?80:Nt,l=s===void 0?20:s,Ut=V===void 0?25:V;let St;t[2]!==mt?(St=mt===void 0?["",""]:mt,t[2]=mt,t[3]=St):St=t[3];const gt=St;let nt;t[4]!==F?(nt=F===void 0?["",""]:F,t[4]=F,t[5]=nt):nt=t[5];const st=nt;let U;t[6]!==pt?(U=pt===void 0?[]:pt,t[6]=pt,t[7]=U):U=t[7];const Dt=U,W=c===void 0?!1:c,x=Z===void 0?!1:Z,R=$===void 0?!1:$,g=P===void 0?2:P,qt=$t===void 0?!0:$t,vt=ft===void 0?"en":ft,Wt=d===void 0?!0:d,Xt=y===void 0?0:y,Mt=dt===void 0?"light":dt,ot=Gt===void 0?5:Gt,jt=ht===void 0?"curve":ht,S=Ht===void 0?2:Ht;let N;t[8]!==tt?(N=tt===void 0?[]:tt,t[8]=tt,t[9]=N):N=t[9];const D=N,rt=Lt===void 0?!0:Lt,[q,Yt]=E.useState(0),[lt,Bt]=E.useState(0),M=E.useRef(null),X=E.useRef(null);let O,Y;t[10]===Symbol.for("react.memo_cache_sentinel")?(O=()=>{const wt=new ResizeObserver(Et=>{Yt(Et[0].target.clientWidth||620),Bt(Et[0].target.clientHeight||480)});return M.current&&wt.observe(M.current),()=>wt.disconnect()},Y=[],t[10]=O,t[11]=Y):(O=t[10],Y=t[11]),E.useEffect(O,Y);const at=m?.graphContainer,At=f?.graphContainer;let T;t[12]!==m?.description||t[13]!==m?.title||t[14]!==b||t[15]!==x||t[16]!==o||t[17]!==W||t[18]!==B||t[19]!==f?.description||t[20]!==f?.title||t[21]!==j?(T=B||o||W||x?n.jsxRuntimeExports.jsx(Te.GraphHeader,{styles:{title:f?.title,description:f?.description},classNames:{title:m?.title,description:m?.description},graphTitle:B,graphDescription:o,width:j,graphDownload:W?X:void 0,dataDownload:x?b.map(Ei).filter(wi).length>0?b.map(Ai).filter(ji):b.filter(vi):null}):null,t[12]=m?.description,t[13]=m?.title,t[14]=b,t[15]=x,t[16]=o,t[17]=W,t[18]=B,t[19]=f?.description,t[20]=f?.title,t[21]=j,t[22]=T):T=t[22];let A;t[23]!==R||t[24]!==Ut||t[25]!==m||t[26]!==Pt||t[27]!==jt||t[28]!==D||t[29]!==b||t[30]!==et||t[31]!==Dt||t[32]!==xt||t[33]!==yt||t[34]!==H||t[35]!==st||t[36]!==gt||t[37]!==k||t[38]!==It||t[39]!==Rt||t[40]!==ot||t[41]!==Q||t[42]!==S||t[43]!==u||t[44]!==r||t[45]!==rt||t[46]!==Wt||t[47]!==qt||t[48]!==h||t[49]!==g||t[50]!==f||t[51]!==lt||t[52]!==q||t[53]!==K||t[54]!==l?(A=b.length===0?n.jsxRuntimeExports.jsx(Ve.EmptyState,{}):n.jsxRuntimeExports.jsxs(n.jsxRuntimeExports.Fragment,{children:[Wt?n.jsxRuntimeExports.jsx(Ce.ColorLegend,{colorDomain:xt,colorLegendTitle:Pt,colors:H,showNAColor:!1,className:m?.colorLegend}):null,n.jsxRuntimeExports.jsx(we.GraphArea,{ref:M,children:q&<?n.jsxRuntimeExports.jsx($e,{data:b,sameAxes:r,lineColors:H,width:q,height:lt,dateFormat:et,showValues:h,noOfXTicks:Rt??Fe.getNoOfTicks(q),leftMargin:yt,rightMargin:u,topMargin:l,bottomMargin:Ut,labels:xt,highlightAreaSettings:Dt,tooltip:K,onSeriesMouseOver:Q,animate:R===!0?{duration:.5,once:!0,amount:.5}:R||{duration:0,once:!0,amount:0},strokeWidth:g,showDots:qt,noOfYTicks:ot,lineSuffixes:gt,linePrefixes:st,minDate:It,maxDate:k,curveType:jt,styles:f,classNames:m,precision:S,customLayers:D,showAxisLabels:rt}):null})]}),t[23]=R,t[24]=Ut,t[25]=m,t[26]=Pt,t[27]=jt,t[28]=D,t[29]=b,t[30]=et,t[31]=Dt,t[32]=xt,t[33]=yt,t[34]=H,t[35]=st,t[36]=gt,t[37]=k,t[38]=It,t[39]=Rt,t[40]=ot,t[41]=Q,t[42]=S,t[43]=u,t[44]=r,t[45]=rt,t[46]=Wt,t[47]=qt,t[48]=h,t[49]=g,t[50]=f,t[51]=lt,t[52]=q,t[53]=K,t[54]=l,t[55]=A):A=t[55];let C;t[56]!==m?.footnote||t[57]!==m?.source||t[58]!==p||t[59]!==z||t[60]!==f?.footnote||t[61]!==f?.source||t[62]!==j?(C=z||p?n.jsxRuntimeExports.jsx(Me.GraphFooter,{styles:{footnote:f?.footnote,source:f?.source},classNames:{footnote:m?.footnote,source:m?.source},sources:z,footNote:p,width:j}):null,t[56]=m?.footnote,t[57]=m?.source,t[58]=p,t[59]=z,t[60]=f?.footnote,t[61]=f?.source,t[62]=j,t[63]=C):C=t[63];let I;return t[64]!==_||t[65]!==it||t[66]!==a||t[67]!==v||t[68]!==vt||t[69]!==Xt||t[70]!==Ft||t[71]!==Ot||t[72]!==at||t[73]!==At||t[74]!==T||t[75]!==A||t[76]!==C||t[77]!==Mt||t[78]!==j?(I=n.jsxRuntimeExports.jsxs(we.GraphContainer,{className:at,style:At,id:a,ref:X,"aria-label":_,backgroundColor:it,theme:Mt,language:vt,minHeight:Xt,width:j,height:v,relativeHeight:Ot,padding:Ft,children:[T,A,C]}),t[64]=_,t[65]=it,t[66]=a,t[67]=v,t[68]=vt,t[69]=Xt,t[70]=Ft,t[71]=Ot,t[72]=at,t[73]=At,t[74]=T,t[75]=A,t[76]=C,t[77]=Mt,t[78]=j,t[79]=I):I=t[79],I}function vi(e){return e!==void 0}function ji(e){return e!==void 0}function Ai(e){return e.data}function wi(e){return e!==void 0}function Ei(e){return e.data}exports.DualAxisLineChart=gi;
|
|
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":"s+BA4EO,SAASA,GAAMC,GAAc,CAClC,KAAM,CACJ,KAAAC,EACA,MAAAC,EACA,OAAAC,EACA,WAAAC,EACA,OAAAC,EACA,SAAAC,EACA,WAAAC,EACA,WAAAC,EACA,WAAAC,GACA,YAAAC,GACA,WAAAC,EACA,UAAAC,EACA,aAAAC,GACA,QAAAC,EACA,sBAAAC,GACA,kBAAAC,EACA,QAAAC,EACA,YAAAC,EACA,SAAAC,EACA,WAAAC,EACA,aAAAC,EACA,aAAAC,EACA,QAAAC,EACA,QAAAC,EACA,UAAAC,EACA,OAAAC,EACA,WAAAC,EACA,UAAAC,EACA,aAAAC,EACA,eAAAC,CAAA,EACE9B,GACE+B,EAASC,EAAAA,OAAO,IAAI,EACpBC,EAAWC,GAAAA,UAAUH,EAAQ,CACjC,KAAMd,EAAQ,KACd,OAAQA,EAAQ,MAAA,CACjB,EACK,CAACkB,EAAiBC,CAAkB,EAAIC,EAAAA,SAAS,EAAK,EAE5DC,EAAAA,UAAU,IAAM,CACd,GAAIL,GAAY,CAACE,EAAiB,CAChC,MAAMI,EAAU,WACd,IAAM,CACJH,EAAmB,EAAI,CACzB,GACCnB,EAAQ,SAAW,IAAO,GAAA,EAE7B,MAAO,IAAM,aAAasB,CAAO,CACnC,CACF,EAAG,CAACN,EAAUE,EAAiBlB,EAAQ,QAAQ,CAAC,EAChD,MAAMuB,EACJf,IAAc,SACVgB,GAAAA,YACAhB,IAAc,OACZiB,GAAAA,UACAjB,IAAc,YACZkB,GAAAA,UACAlB,IAAc,aACZmB,GAAAA,WACAC,GAAAA,UAEN,CAACC,EAAeC,CAAgB,EAAIV,EAAAA,SAAc,MAAS,EAC3D,CAACW,EAAQC,EAAS,EAAIZ,EAAAA,SAA6B,MAAS,EAC5D,CAACa,GAAQC,EAAS,EAAId,EAAAA,SAA6B,MAAS,EAC5De,EAAS,CACb,IAAKxC,EACL,OAAQC,GACR,KAAMF,EAAa,GACnB,MAAOD,GAAc,EAAA,EAEjB2C,EAAmBrB,EAAAA,OAAO,IAAI,EAC9BsB,EAAgBC,GAAAA,QACpBtD,EAAK,IAAIuD,IAAM,CACb,GAAGA,EACH,KAAMC,EAAAA,MAAM,GAAGD,EAAE,IAAI,GAAIjD,EAAY,IAAI,IAAM,CAAA,EAC/C,EACF,CAAC,MAAM,EACP,CAAC,KAAK,CAAA,EAEFmD,GAAiC3C,GAAsB,IAAIyC,IAAM,CACrE,GAAGA,EACH,YAAa,CACXA,EAAE,YAAY,CAAC,IAAM,KAAO,KAAOC,EAAAA,MAAM,GAAGD,EAAE,YAAY,CAAC,CAAC,GAAIjD,EAAY,IAAI,IAAM,EACtFiD,EAAE,YAAY,CAAC,IAAM,KAAO,KAAOC,EAAAA,MAAM,GAAGD,EAAE,YAAY,CAAC,CAAC,GAAIjD,EAAY,IAAI,IAAM,CAAA,CACxF,EACA,EACIoD,EAAazD,EAAQkD,EAAO,KAAOA,EAAO,MAC1CQ,EAAczD,EAASiD,EAAO,IAAMA,EAAO,OAC3CS,GAAUtC,EAAUkC,QAAM,GAAGlC,CAAO,GAAIhB,EAAY,IAAI,IAAM,EAAI+C,EAAc,CAAC,EAAE,KACnFQ,GAAUtC,EACZiC,EAAAA,MAAM,GAAGjC,CAAO,GAAIjB,EAAY,IAAI,IAAM,EAC1C+C,EAAcA,EAAc,OAAS,CAAC,EAAE,KACtCS,EACJ,KAAK,IAAI,GAAGT,EAAc,IAAIE,GAAKA,EAAE,EAAE,EAAE,OAAOA,GAAwBA,GAAM,IAAI,CAAC,IACnF,IACI,KAAK,IAAI,GAAGF,EAAc,IAAIE,GAAKA,EAAE,EAAE,EAAE,OAAOA,GAAwBA,GAAM,IAAI,CAAC,EAAI,EACrF,EACA,KAAK,IAAI,GAAGF,EAAc,IAAIE,GAAKA,EAAE,EAAE,EAAE,OAAOA,GAAwBA,GAAM,IAAI,CAAC,EACrF,EACAQ,EACJ,KAAK,IAAI,GAAGV,EAAc,IAAIE,GAAKA,EAAE,EAAE,EAAE,OAAOA,GAAwBA,GAAM,IAAI,CAAC,IACnF,IACI,KAAK,IAAI,GAAGF,EAAc,IAAIE,GAAKA,EAAE,EAAE,EAAE,OAAOA,GAAwBA,GAAM,IAAI,CAAC,EAAI,EACrF,EACA,KAAK,IAAI,GAAGF,EAAc,IAAIE,GAAKA,EAAE,EAAE,EAAE,OAAOA,GAAwBA,GAAM,IAAI,CAAC,EACrF,EACAS,EACJ,KAAK,IAAI,GAAGX,EAAc,IAAIE,GAAKA,EAAE,EAAE,EAAE,OAAOA,GAAwBA,GAAM,IAAI,CAAC,IACnF,IACI,KAAK,IAAI,GAAGF,EAAc,OAASE,EAAE,EAAE,EAAE,UAA+BA,GAAM,IAAI,CAAC,EACnF,EACAU,EACJ,KAAK,IAAI,GAAGZ,EAAc,IAAIE,GAAKA,EAAE,EAAE,EAAE,OAAOA,GAAwBA,GAAM,IAAI,CAAC,IACnF,IACI,KAAK,IAAI,GAAGF,EAAc,OAASE,EAAE,EAAE,EAAE,UAA+BA,GAAM,IAAI,CAAC,EACnF,EAEAW,EAAWJ,EAAYC,EAAYD,EAAYC,EAC/CI,GAAWH,EAAYC,EAAYD,EAAYC,EAC/CG,EAAIC,GAAAA,OAAY,OAAO,CAACT,GAASC,EAAO,CAAC,EAAE,MAAM,CAAC,EAAGH,CAAU,CAAC,EAEhEY,EAAKC,UAAA,EACR,OAAO,CACNlE,EAAW6D,EAAWJ,EACtBzD,EAAY8D,GAAW,EAAIA,GAAW,EAAKH,EAAY,EAAIA,EAAY,CAAA,CACxE,EACA,MAAM,CAACL,EAAa,CAAC,CAAC,EACtB,KAAA,EACGa,EAAKD,UAAA,EACR,OAAO,CACNlE,EAAW6D,EAAWH,EACtB1D,EAAY8D,GAAW,EAAIA,GAAW,EAAKF,EAAY,EAAIA,EAAY,CAAA,CACxE,EACA,MAAM,CAACN,EAAa,CAAC,CAAC,EACtB,KAAA,EAEGc,GAAaC,GAAAA,OAChB,QAAQnB,GAAK,CAACoB,EAAAA,uBAAuBpB,EAAE,EAAE,CAAC,EAC1C,EAAEA,GAAKa,EAAEb,EAAE,IAAI,CAAC,EAChB,EAAEA,GAAKe,EAAGf,EAAE,EAAE,CAAC,EACf,MAAMhB,CAAK,EAERqC,GAAaF,GAAAA,OAChB,QAAQnB,GAAK,CAACoB,EAAAA,uBAAuBpB,EAAE,EAAE,CAAC,EAC1C,EAAEA,GAAKa,EAAEb,EAAE,IAAI,CAAC,EAChB,EAAEA,GAAKiB,EAAGjB,EAAE,EAAE,CAAC,EACf,MAAMhB,CAAK,EACRsC,GAAUP,EAAG,MAAMnD,CAAU,EAC7B2D,GAAUN,EAAG,MAAMrD,CAAU,EAC7B4D,GAASX,EAAE,MAAM5D,EAAU,EACjC6B,OAAAA,EAAAA,UAAU,IAAM,CAEd,MAAM2C,EAAaC,IAAe,CAChC,MAAMC,GACJ7B,EACE8B,GAAAA,aACE9B,EAAc,IAAIE,IAAKA,GAAE,IAAI,EAC7Ba,EAAE,OAAOgB,GAAAA,QAAQH,EAAK,EAAE,CAAC,CAAC,EAC1B,CAAA,CAEJ,EACFnC,EAAiBoC,IAAgB7B,EAAcA,EAAc,OAAS,CAAC,CAAC,EACxEtC,IAAoBmE,IAAgB7B,EAAcA,EAAc,OAAS,CAAC,CAAC,EAC3EH,GAAU+B,GAAM,OAAO,EACvBjC,GAAUiC,GAAM,OAAO,CACzB,EACMI,EAAW,IAAM,CACrBvC,EAAiB,MAAS,EAC1BE,GAAU,MAAS,EACnBE,GAAU,MAAS,EACnBnC,IAAoB,MAAS,CAC/B,EACAuE,UAAOlC,EAAiB,OAAO,EAAE,GAAG,YAAa4B,CAAS,EAAE,GAAG,WAAYK,CAAQ,CACrF,EAAG,CAACjB,EAAGf,EAAetC,CAAiB,CAAC,EAGtCwE,EAAAA,kBAAAA,KAAAC,6BAAA,CACE,SAAA,CAAAC,EAAAA,kBAAAA,IAACC,EAAAA,OAAO,IAAP,CACC,MAAO,GAAGzF,CAAK,KACf,OAAQ,GAAGC,CAAM,KACjB,QAAS,OAAOD,CAAK,IAAIC,CAAM,GAC/B,UAAU,MACV,IAAK4B,EAEL,SAAAyD,EAAAA,kBAAAA,KAAC,KAAE,UAAW,aAAapC,EAAO,IAAI,IAAIA,EAAO,GAAG,IAClD,SAAA,CAAAsC,EAAAA,kBAAAA,IAACE,GAAAA,cAAA,CACC,aAAclC,GACd,MAAOC,EACP,OAAQC,EACR,MAAOS,EACP,QAAApD,EACA,SAAAgB,CAAA,CAAA,2BAED,IAAA,CACE,SAAA,CAAA6C,GAAQ,IAAI,CAACtB,EAAGqC,6BACd,IAAA,CACC,SAAA,CAAAH,EAAAA,kBAAAA,IAAC,OAAA,CACC,GAAInB,EAAGf,CAAC,EACR,GAAIe,EAAGf,CAAC,EACR,GAAI,IACJ,GAAI,IACJ,MAAO,CACL,OAAQpD,EAAW,CAAC,EACpB,YAAa,EACb,GAAIsB,GAAQ,OAAO,WAAa,CAAA,CAAC,EAEnC,UAAWC,GAAY,OAAO,SAAA,CAAA,EAEhC+D,EAAAA,kBAAAA,IAAC,OAAA,CACC,EAAG,IACH,EAAGnB,EAAGf,CAAC,EACP,GAAG,SACH,UAAWsC,EAAAA,GAAG,UAAWnE,GAAY,OAAO,MAAM,EAClD,MAAO,CACL,WAAY,MACZ,KAAMvB,EAAW,CAAC,EAClB,GAAIsB,GAAQ,OAAO,QAAU,CAAA,CAAC,EAG/B,SAAAqE,GAAAA,yBAAyBvC,EAAG,KAAM5B,EAAWN,EAAa,CAAC,EAAGD,EAAa,CAAC,CAAC,CAAA,CAAA,CAChF,CAAA,EAzBMwE,CA0BR,CACD,EACDH,EAAAA,kBAAAA,IAACM,GAAAA,KAAA,CACC,GAAI,EACJ,GAAIpC,EACJ,GAAI,IACJ,GAAI,IACJ,WAAY,CAAE,KAAMjC,GAAY,OAAO,IAAA,EACvC,OAAQ,CAAE,KAAM,CAAE,OAAQvB,EAAW,CAAC,EAAG,GAAIsB,GAAQ,OAAO,MAAQ,CAAA,EAAI,CAAE,CAAA,EAG3EI,EACC4D,EAAAA,kBAAAA,IAACO,GAAAA,UAAA,CACC,EAAG,GAAK7C,EAAO,KACf,EAAGQ,EAAc,EACjB,MAAO,CAAE,KAAMxD,EAAW,CAAC,EAAG,GAAIsB,GAAQ,OAAO,OAAS,EAAC,EAC3D,UAAWC,GAAY,OAAO,MAC9B,KAAMtB,EAAO,CAAC,EAAE,OAAS,IAAM,GAAGA,EAAO,CAAC,EAAE,UAAU,EAAG,GAAG,CAAC,MAAQA,EAAO,CAAC,EAC7E,SAAQ,EAAA,CAAA,EAER,IAAA,EACN,2BACC,IAAA,CACE,SAAA,CAAA0E,GAAQ,IAAI,CAACvB,EAAGqC,6BACd,IAAA,CACC,SAAA,CAAAH,EAAAA,kBAAAA,IAAC,OAAA,CACC,GAAIjB,EAAGjB,CAAC,EACR,GAAIiB,EAAGjB,CAAC,EACR,GAAIG,EAAa,GACjB,GAAIA,EAAa,GACjB,MAAO,CACL,OAAQvD,EAAW,CAAC,EACpB,YAAa,EACb,GAAIsB,GAAQ,OAAO,WAAa,CAAA,CAAC,EAEnC,UAAWC,GAAY,OAAO,SAAA,CAAA,EAEhC+D,EAAAA,kBAAAA,IAAC,OAAA,CACC,EAAG/B,EAAa,GAChB,EAAGc,EAAGjB,CAAC,EACP,GAAG,SACH,GAAI,GACJ,MAAO,CACL,WAAY,QACZ,KAAMpD,EAAW,CAAC,EAClB,GAAIsB,GAAQ,OAAO,QAAU,CAAA,CAAC,EAEhC,UAAWoE,EAAAA,GAAG,UAAWnE,GAAY,OAAO,MAAM,EAEjD,SAAAoE,GAAAA,yBAAyBvC,EAAG,KAAM5B,EAAWN,EAAa,CAAC,EAAGD,EAAa,CAAC,CAAC,CAAA,CAAA,CAChF,CAAA,EA1BMwE,CA2BR,CACD,EACDH,EAAAA,kBAAAA,IAACM,GAAAA,KAAA,CACC,GAAI,EACJ,GAAIpC,EACJ,GAAID,EAAa,GACjB,GAAIA,EAAa,GACjB,WAAY,CAAE,KAAMhC,GAAY,OAAO,IAAA,EACvC,OAAQ,CAAE,KAAM,CAAE,OAAQvB,EAAW,CAAC,EAAG,GAAIsB,GAAQ,OAAO,MAAQ,CAAA,EAAI,CAAE,CAAA,EAE3EI,EACC4D,EAAAA,kBAAAA,IAACO,GAAAA,UAAA,CACC,EAAGtC,EAAaP,EAAO,MAAQ,GAC/B,EAAGQ,EAAc,EACjB,MAAO,CAAE,KAAMxD,EAAW,CAAC,EAAG,GAAIsB,GAAQ,OAAO,OAAS,EAAC,EAC3D,UAAWC,GAAY,OAAO,MAC9B,KAAMtB,EAAO,CAAC,EAAE,OAAS,IAAM,GAAGA,EAAO,CAAC,EAAE,UAAU,EAAG,GAAG,CAAC,MAAQA,EAAO,CAAC,EAC7E,SAAQ,EAAA,CAAA,EAER,IAAA,EACN,2BACC,IAAA,CACC,SAAA,CAAAqF,EAAAA,kBAAAA,IAACM,GAAAA,KAAA,CACC,GAAIpC,EACJ,GAAIA,EACJ,GAAI,IACJ,GAAID,EAAa,GACjB,WAAY,CAAE,KAAMhC,GAAY,OAAO,IAAA,EACvC,OAAQ,CAAE,KAAMD,GAAQ,OAAO,IAAA,CAAK,CAAA,EAEtCgE,EAAAA,kBAAAA,IAACQ,GAAAA,mBAAA,CACC,OAAQlB,GAAO,OAASmB,SAAO3C,EAAGjD,CAAU,CAAC,EAC7C,EAAGyE,GAAO,IAAIxB,GAAKa,EAAEb,CAAC,CAAC,EACvB,GAAI,EACJ,GAAII,EACJ,OAAQ,CACN,UAAWlC,GAAQ,OAAO,UAC1B,OAAQA,GAAQ,OAAO,MAAA,EAEzB,WAAY,CACV,UAAWoE,EAAAA,GAAG,YAAanE,GAAY,OAAO,SAAS,EACvD,OAAQmE,EAAAA,GACN,8GACAnE,GAAY,OAAO,MAAA,CACrB,EAEF,UAAU,UACV,cAAa,GACb,UAAAC,CAAA,CAAA,CACF,EACF,EACCC,EAAa,OAAO2B,GAAKA,EAAE,WAAa,QAAQ,EAAE,IAAIA,GAAKA,EAAE,KAAK,2BAClE,IAAA,CACC,SAAA,CAAAkC,EAAAA,kBAAAA,IAACC,EAAAA,OAAO,KAAP,CACC,MAAO,CACL,OAAQvF,EAAW,CAAC,EACpB,YAAAc,EACA,KAAM,MAAA,EAER,KAAM,CAAE,QAAS,EAAG,WAAY,CAAE,SAAUD,EAAQ,SAAS,EAC7D,SAAU,CACR,QAAS,CACP,WAAY,EACZ,EACEyD,GACEpB,EAAc,OACX8C,GAAgC,CAACxB,yBAAuBwB,EAAG,EAAE,CAAA,CAChE,GACG,GACP,QAAS,CAAA,EAEX,YAAa,CACX,WAAY,EACZ,EACE1B,GACEpB,EAAc,OACX8C,GAAgC,CAACxB,yBAAuBwB,EAAG,EAAE,CAAA,CAChE,GACG,GACP,QAAS,EACT,WAAY,CAAE,SAAUnF,EAAQ,QAAA,CAAS,CAC3C,EAEF,QAAQ,UACR,QAASgB,EAAW,cAAgB,SAAA,CAAA,EAEtCyD,EAAAA,kBAAAA,IAACC,EAAAA,OAAO,KAAP,CACC,EACEd,GACEvB,EAAc,OACX8C,GAAgC,CAACxB,yBAAuBwB,EAAG,EAAE,CAAA,CAChE,GACG,GAEP,MAAO,CACL,OAAQhG,EAAW,CAAC,EACpB,YAAAc,EACA,KAAM,MAAA,EAER,KAAM,CAAE,QAAS,EAAG,WAAY,CAAE,SAAUD,EAAQ,SAAS,EAC7D,SAAU,CACR,QAAS,CACP,WAAY,EACZ,EACE4D,GACEvB,EAAc,OACX8C,GAAgC,CAACxB,yBAAuBwB,EAAG,EAAE,CAAA,CAChE,GACG,GACP,QAAS,CAAA,EAEX,YAAa,CACX,WAAY,EACZ,EACEvB,GACEvB,EAAc,OACX8C,GAAgC,CAACxB,yBAAuBwB,EAAG,EAAE,CAAA,CAChE,GACG,GACP,QAAS,EACT,WAAY,CAAE,SAAUnF,EAAQ,QAAA,CAAS,CAC3C,EAEF,QAAQ,UACR,QAASgB,EAAW,cAAgB,SAAA,CAAA,EAErCa,EACC4C,EAAAA,kBAAAA,IAAC,OAAA,CACC,GAAI,EACJ,GAAI9B,EACJ,GAAIS,EAAEvB,EAAc,IAAI,EACxB,GAAIuB,EAAEvB,EAAc,IAAI,EACxB,UAAWgD,EAAAA,GACT,sEACAnE,GAAY,aAAA,EAEd,MAAOD,GAAQ,aAAA,CAAA,EAEf,IAAA,EACN,EACAgE,EAAAA,kBAAAA,IAAC,IAAA,CACE,SAAApC,EAAc,IAAI,CAACE,EAAGqC,IACrBL,EAAAA,kBAAAA,KAACG,EAAAA,OAAO,EAAP,CACE,SAAA,CAACf,EAAAA,uBAAuBpB,EAAE,EAAE,EAmFzB,KAlFFgC,EAAAA,kBAAAA,KAAAC,EAAAA,kBAAAA,SAAA,CACG,SAAA,CAAAtE,EACCuE,EAAAA,kBAAAA,IAACC,EAAAA,OAAO,OAAP,CACC,EACEhC,EAAaL,EAAc,OAAS,EAChC,EACAK,EAAaL,EAAc,OAAS,GAClC,EACA,EAER,KAAM,CAAE,QAAS,EAAG,WAAY,CAAE,SAAUrC,EAAQ,SAAS,EAC7D,SAAU,CACR,QAAS,CACP,QAAS,EACT,GAAIoD,EAAEb,EAAE,IAAI,EACZ,GAAIe,EAAGf,EAAE,EAAY,EACrB,KAAMpD,EAAW,CAAC,CAAA,EAEpB,YAAa,CACX,QAAS,EACT,KAAMA,EAAW,CAAC,EAClB,WAAY,CACV,SAAU+B,EAAkBlB,EAAQ,SAAW,GAC/C,MAAOkB,EAAkB,EAAIlB,EAAQ,QAAA,EAEvC,GAAIoD,EAAEb,EAAE,IAAI,EACZ,GAAIe,EAAGf,EAAE,EAAY,CAAA,CACvB,EAEF,QAAQ,UACR,QAASvB,EAAW,cAAgB,SAAA,CAAA,EAEpC,KACHzB,EACCkF,EAAAA,kBAAAA,IAACC,EAAAA,OAAO,KAAP,CACC,GACEf,EAAAA,uBAAuBpB,EAAE,EAAE,GAEtBA,EAAE,GAAiBA,EAAE,GADtB,GAGE,MAER,MAAO,CACL,WAAY,SACZ,GAAI9B,GAAQ,mBAAqB,CAAA,CAAC,EAEpC,UAAWoE,EAAAA,GACT,mDACAnE,GAAY,iBAAA,EAEd,KAAM,CAAE,QAAS,EAAG,WAAY,CAAE,SAAUV,EAAQ,SAAS,EAC7D,SAAU,CACR,QAAS,CACP,QAAS,EACT,EAAGoD,EAAEb,EAAE,IAAI,EACX,EAAGiB,EAAGjB,EAAE,EAAY,EACpB,KAAMpD,EAAW,CAAC,CAAA,EAEpB,YAAa,CACX,QAAS,EACT,EAAGiE,EAAEb,EAAE,IAAI,EACX,KAAMpD,EAAW,CAAC,EAClB,EAAGqE,EAAGjB,EAAE,EAAY,EACpB,WAAY,CACV,SAAUrB,EAAkBlB,EAAQ,SAAW,GAC/C,MAAOkB,EAAkB,EAAIlB,EAAQ,QAAA,CACvC,CACF,EAEF,QAAQ,UACR,QAASgB,EAAW,cAAgB,UAEnC,SAAA8D,GAAAA,yBACCvC,EAAE,GACF,KACA5B,EACAN,EAAa,CAAC,EACdD,EAAa,CAAC,CAAA,CAChB,CAAA,EAEA,IAAA,CAAA,CACN,EAEAuD,EAAAA,uBAAuBpB,EAAE,EAAE,EAmFzB,KAlFFgC,EAAAA,kBAAAA,KAAAC,EAAAA,kBAAAA,SAAA,CACG,SAAA,CAAAtE,EACCuE,EAAAA,kBAAAA,IAACC,EAAAA,OAAO,OAAP,CACC,EACEhC,EAAaL,EAAc,OAAS,EAChC,EACAK,EAAaL,EAAc,OAAS,GAClC,EACA,EAER,KAAM,CAAE,QAAS,EAAG,WAAY,CAAE,SAAUrC,EAAQ,SAAS,EAC7D,SAAU,CACR,QAAS,CACP,QAAS,EACT,GAAIoD,EAAEb,EAAE,IAAI,EACZ,GAAIiB,EAAGjB,EAAE,EAAY,EACrB,KAAMpD,EAAW,CAAC,CAAA,EAEpB,YAAa,CACX,QAAS,EACT,WAAY,CACV,SAAU+B,EAAkBlB,EAAQ,SAAW,GAC/C,MAAOkB,EAAkB,EAAIlB,EAAQ,QAAA,EAEvC,KAAMb,EAAW,CAAC,EAClB,GAAIiE,EAAEb,EAAE,IAAI,EACZ,GAAIiB,EAAGjB,EAAE,EAAY,CAAA,CACvB,EAEF,QAAQ,UACR,QAASvB,EAAW,cAAgB,SAAA,CAAA,EAEpC,KACHzB,EACCkF,EAAAA,kBAAAA,IAACC,EAAAA,OAAO,KAAP,CACC,GACEf,EAAAA,uBAAuBpB,EAAE,EAAE,GAEtBA,EAAE,GAAiBA,EAAE,GADtB,GAGE,MAER,MAAO,CACL,WAAY,SACZ,GAAI9B,GAAQ,mBAAqB,CAAA,CAAC,EAEpC,UAAWoE,EAAAA,GACT,mDACAnE,GAAY,iBAAA,EAEd,KAAM,CAAE,QAAS,EAAG,WAAY,CAAE,SAAUV,EAAQ,SAAS,EAC7D,SAAU,CACR,QAAS,CACP,QAAS,EACT,EAAGoD,EAAEb,EAAE,IAAI,EACX,EAAGiB,EAAGjB,EAAE,EAAY,EACpB,KAAMpD,EAAW,CAAC,CAAA,EAEpB,YAAa,CACX,QAAS,EACT,EAAGiE,EAAEb,EAAE,IAAI,EACX,EAAGiB,EAAGjB,EAAE,EAAY,EACpB,KAAMpD,EAAW,CAAC,EAClB,WAAY,CACV,SAAU+B,EAAkBlB,EAAQ,SAAW,GAC/C,MAAOkB,EAAkB,EAAIlB,EAAQ,QAAA,CACvC,CACF,EAEF,QAAQ,UACR,QAASgB,EAAW,cAAgB,UAEnC,SAAA8D,GAAAA,yBACCvC,EAAE,GACF,KACA5B,EACAN,EAAa,CAAC,EACdD,EAAa,CAAC,CAAA,CAChB,CAAA,EAEA,IAAA,CAAA,CACN,CACE,GAxKSwE,CAyKf,CACD,EACH,EACChE,EAAa,OAAO2B,GAAKA,EAAE,WAAa,OAAO,EAAE,IAAIA,GAAKA,EAAE,KAAK,EAClEkC,EAAAA,kBAAAA,IAAC,OAAA,CACC,IAAKrC,EACL,MAAO,CACL,KAAM,OACN,cAAe,KAAA,EAEjB,MAAOM,EACP,OAAQC,CAAA,CAAA,CACV,CAAA,CACF,CAAA,CAAA,EAEDd,GAAiBhC,GAAWkC,GAAUE,GACrCwC,EAAAA,kBAAAA,IAACW,GAAAA,QAAA,CACC,KAAMvD,EACN,KAAMhC,EACN,KAAMkC,EACN,KAAME,GACN,gBAAiBxB,GAAQ,QACzB,UAAWC,GAAY,OAAA,CAAA,EAEvB,IAAA,EACN,CAEJ,CCziBO,SAAS2E,GAAkBtG,GAAc,CAC9C,KAAM,CACJ,KAAAC,EACA,WAAAsG,EACA,QAAAC,EACA,iBAAAC,EACA,OAAAtG,EACA,MAAAD,EACA,SAAAwG,EACA,WAAAjG,EAAa,GACb,WAAAF,GAAa,OACb,WAAAC,GAAa,GACb,QAAAmG,EACA,WAAAvG,EAAa,CACXwG,GAAAA,OAAO,MAAM,kBAAkB,OAAO,CAAC,EACvCA,GAAAA,OAAO,MAAM,kBAAkB,OAAO,CAAC,CAAA,EAEzC,SAAAtG,GAAW,GACX,gBAAAuG,EAAkB,GAClB,WAAAlG,GAAa,GACb,YAAAD,EAAc,GACd,UAAAE,EAAY,GACZ,aAAAC,EAAe,GACf,OAAAR,EACA,aAAAgB,EAAe,CAAC,GAAI,EAAE,EACtB,aAAAC,EAAe,CAAC,GAAI,EAAE,EACtB,QAAAR,EACA,sBAAAC,EAAwB,CAAA,EACxB,eAAA+F,EACA,kBAAA9F,EACA,QAAA+F,EACA,cAAAC,EAAgB,GAChB,aAAAC,EAAe,GACf,QAAAhG,EAAU,GACV,YAAAC,EAAc,EACd,SAAAC,EAAW,GACX,SAAA+F,EAAW,KACX,eAAAC,EAAiB,GACjB,UAAAC,EAAY,EACZ,iBAAAC,EACA,MAAAC,EAAQ,QACR,UAAAC,EACA,WAAAnG,EAAa,EACb,QAAAI,GACA,QAAAD,GACA,UAAAE,GAAY,QACZ,OAAAC,EACA,WAAAC,EACA,UAAAC,EAAY,EACZ,aAAAC,GAAe,CAAA,EACf,eAAAC,EAAiB,EAAA,EACf9B,GAEE,CAACwH,EAAUC,EAAW,EAAIpF,EAAAA,SAAS,CAAC,EACpC,CAACqF,GAAWC,CAAY,EAAItF,EAAAA,SAAS,CAAC,EAEtCuF,EAAW5F,EAAAA,OAAuB,IAAI,EACtC6F,EAAiB7F,EAAAA,OAAuB,IAAI,EAClDM,OAAAA,EAAAA,UAAU,IAAM,CACd,MAAMwF,EAAiB,IAAI,eAAeC,GAAW,CACnDN,GAAYvH,GAAS6H,EAAQ,CAAC,EAAE,OAAO,aAAe,GAAG,EACzDJ,EAAaxH,GAAU4H,EAAQ,CAAC,EAAE,OAAO,cAAgB,GAAG,CAC9D,CAAC,EACD,OAAIH,EAAS,UACXD,EAAaC,EAAS,QAAQ,cAAgB,GAAG,EACjDH,GAAYG,EAAS,QAAQ,aAAe,GAAG,EAC1C1H,GAAO4H,EAAe,QAAQF,EAAS,OAAO,GAE9C,IAAME,EAAe,WAAA,CAC9B,EAAG,CAAC5H,EAAOC,CAAM,CAAC,EAGhBuF,EAAAA,kBAAAA,IAAC,MAAA,CACC,UAAW,GAAG4B,GAAS,OAAO,UAAUpH,EAAQ,eAAiB,aAAa,GAC9E,IAAKgH,IAAa,MAAQA,IAAa,KAAO,MAAQ,OAEtD,SAAAxB,EAAAA,kBAAAA,IAAC,MAAA,CACC,UAAWI,EAAAA,GACT,GACGe,EAEGA,IAAoB,GAClB,gDACA,GAHF,iBAIN,gDAAgDK,GAAY,IAAI,GAChEhH,EAAQ,QAAU,SAClByB,GAAY,cAAA,EAEd,MAAO,CACL,GAAID,GAAQ,gBAAkB,CAAA,EAC9B,GAAImF,GAAmBA,IAAoB,GAAO,CAAE,gBAAAA,CAAA,EAAoB,CAAA,CAAC,EAE3E,GAAIE,EACJ,IAAKc,EACL,aACEN,GACA,GACEhB,EAAa,mBAAmBA,CAAU,KAAO,EACnD,oEACEE,EAAmB,IAAIA,CAAgB,GAAK,EAC9C,GAGF,SAAAf,EAAAA,kBAAAA,IAAC,MAAA,CACC,UAAU,YACV,MAAO,CAAE,QAASmB,EAAkBF,GAAW,OAASA,GAAW,CAAA,EAEnE,SAAAnB,EAAAA,kBAAAA,KAAC,MAAA,CAAI,UAAU,kDACZ,SAAA,CAAAe,GAAcE,GAAoBO,GAAiBC,EAClDvB,EAAAA,kBAAAA,IAACsC,GAAAA,YAAA,CACC,OAAQ,CACN,MAAOtG,GAAQ,MACf,YAAaA,GAAQ,WAAA,EAEvB,WAAY,CACV,MAAOC,GAAY,MACnB,YAAaA,GAAY,WAAA,EAE3B,WAAA4E,EACA,iBAAAE,EACA,MAAAvG,EACA,cAAe8G,EAAgBa,EAAe,QAAU,OACxD,aACEZ,EACIhH,EAAK,IAAIuD,GAAKA,EAAE,IAAI,EAAE,OAAOA,GAAKA,IAAM,MAAS,EAAE,OAAS,EAC1DvD,EAAK,IAAIuD,GAAKA,EAAE,IAAI,EAAE,OAAOA,GAAKA,IAAM,MAAS,EACjDvD,EAAK,OAAOuD,GAAKA,IAAM,MAAS,EAClC,IAAA,CAAA,EAGN,KACJkC,EAAAA,kBAAAA,IAAC,MAAA,CAAI,UAAU,iDACZ,SAAAzF,EAAK,SAAW,EACfyF,EAAAA,kBAAAA,IAACuC,GAAAA,WAAA,CAAA,CAAW,EAEZzC,EAAAA,kBAAAA,KAAAC,EAAAA,kBAAAA,SAAA,CACG,SAAA,CAAC0B,EACAzB,EAAAA,kBAAAA,IAACwC,GAAAA,YAAA,CACC,YAAa7H,EACb,iBAAAgH,EACA,OAAQjH,EACR,YAAa,EAAA,CAAA,EALE,KAQnBsF,EAAAA,kBAAAA,IAAC,MAAA,CACC,UAAU,8CACV,IAAKkC,EACL,aAAW,aAET,UAAA1H,GAASsH,KAAcrH,GAAUuH,IACjChC,EAAAA,kBAAAA,IAAC3F,GAAA,CACC,KAAAE,EACA,SAAAK,GACA,WAAAF,EACA,MAAOF,GAASsH,EAChB,OAAQ,KAAK,IACXJ,EACAjH,IACG2G,EACGM,GACGlH,GAASsH,GAAYV,EAAiBM,GACpClH,GAASsH,GAAYV,EACtBM,GACDlH,GAASsH,GAAYV,EACxBY,GAAA,EAER,WAAAnH,GACA,WAAAC,GACA,WAAAC,EACA,WAAAE,GACA,YAAAD,EACA,UAAAE,EACA,aAAAC,EACA,OAAAR,EACA,sBAAAU,EACA,QAAAD,EACA,kBAAAE,EACA,QACEC,IAAY,GACR,CAAE,SAAU,GAAK,KAAM,GAAM,OAAQ,EAAA,EACrCA,GAAW,CAAE,SAAU,EAAG,KAAM,GAAM,OAAQ,CAAA,EAEpD,YAAAC,EACA,SAAAC,EACA,WAAAC,EACA,aAAAC,EACA,aAAAC,EACA,QAAAC,GACA,QAAAC,GACA,UAAAC,GACA,OAAAC,EACA,WAAAC,EACA,UAAAC,EACA,aAAAC,GACA,eAAAC,CAAA,CAAA,EAEA,IAAA,CAAA,CACN,CAAA,CACF,CAAA,CAEJ,EACC0E,GAAWE,EACVhB,EAAAA,kBAAAA,IAACyC,GAAAA,YAAA,CACC,OAAQ,CAAE,SAAUzG,GAAQ,SAAU,OAAQA,GAAQ,MAAA,EACtD,WAAY,CACV,SAAUC,GAAY,SACtB,OAAQA,GAAY,MAAA,EAEtB,QAAA6E,EACA,SAAAE,EACA,MAAAxG,CAAA,CAAA,EAEA,IAAA,CAAA,CACN,CAAA,CAAA,CACF,CAAA,CACF,CAAA,CAGN"}
|
|
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\nimport { getNoOfTicks } from '@/Utils/getNoOfTicks';\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,\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 ?? getNoOfTicks(svgWidth)}\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","getNoOfTicks","footnote","source","GraphFooter","GraphContainer"],"mappings":"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"}
|