@undp/data-viz 2.4.1 → 2.5.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.
Files changed (271) hide show
  1. package/dist/AreaChart.cjs +1 -1
  2. package/dist/AreaChart.cjs.map +1 -1
  3. package/dist/AreaChart.d.ts +11 -9
  4. package/dist/AreaChart.js +320 -322
  5. package/dist/AreaChart.js.map +1 -1
  6. package/dist/BarGraph.cjs +1 -1
  7. package/dist/BarGraph.cjs.map +1 -1
  8. package/dist/BarGraph.d.ts +15 -25
  9. package/dist/BarGraph.js +1694 -1694
  10. package/dist/BarGraph.js.map +1 -1
  11. package/dist/BasicStatCard.cjs +1 -1
  12. package/dist/BasicStatCard.cjs.map +1 -1
  13. package/dist/BasicStatCard.d.ts +13 -9
  14. package/dist/BasicStatCard.js +79 -81
  15. package/dist/BasicStatCard.js.map +1 -1
  16. package/dist/BeeSwarmChart.cjs +1 -1
  17. package/dist/BeeSwarmChart.cjs.map +1 -1
  18. package/dist/BeeSwarmChart.d.ts +11 -9
  19. package/dist/BeeSwarmChart.js +335 -336
  20. package/dist/BeeSwarmChart.js.map +1 -1
  21. package/dist/BiVariateChoroplethMap.cjs +1 -1
  22. package/dist/BiVariateChoroplethMap.cjs.map +1 -1
  23. package/dist/BiVariateChoroplethMap.d.ts +13 -3
  24. package/dist/BiVariateChoroplethMap.js +309 -304
  25. package/dist/BiVariateChoroplethMap.js.map +1 -1
  26. package/dist/BulletChart.cjs +1 -1
  27. package/dist/BulletChart.cjs.map +1 -1
  28. package/dist/BulletChart.d.ts +11 -5
  29. package/dist/BulletChart.js +560 -559
  30. package/dist/BulletChart.js.map +1 -1
  31. package/dist/ButterflyChart.cjs +1 -1
  32. package/dist/ButterflyChart.cjs.map +1 -1
  33. package/dist/ButterflyChart.d.ts +11 -9
  34. package/dist/ButterflyChart.js +348 -350
  35. package/dist/ButterflyChart.js.map +1 -1
  36. package/dist/ChoroplethMap.cjs +1 -1
  37. package/dist/ChoroplethMap.cjs.map +1 -1
  38. package/dist/ChoroplethMap.d.ts +11 -3
  39. package/dist/ChoroplethMap.js +314 -311
  40. package/dist/ChoroplethMap.js.map +1 -1
  41. package/dist/CirclePackingGraph.cjs +1 -1
  42. package/dist/CirclePackingGraph.d.ts +11 -9
  43. package/dist/CirclePackingGraph.js +1 -1
  44. package/dist/DataCards.cjs +1 -1
  45. package/dist/DataCards.d.ts +1 -1
  46. package/dist/DataCards.js +1 -1
  47. package/dist/DataTable.cjs +1 -1
  48. package/dist/DataTable.cjs.map +1 -1
  49. package/dist/DataTable.d.ts +4 -5
  50. package/dist/DataTable.js +114 -116
  51. package/dist/DataTable.js.map +1 -1
  52. package/dist/{DetailsModal-jmmKRMRM.cjs → DetailsModal-Du8Fr1QD.cjs} +2 -2
  53. package/dist/{DetailsModal-jmmKRMRM.cjs.map → DetailsModal-Du8Fr1QD.cjs.map} +1 -1
  54. package/dist/{DetailsModal-B2XBWR7w.js → DetailsModal-GqEbGHY2.js} +2 -2
  55. package/dist/{DetailsModal-B2XBWR7w.js.map → DetailsModal-GqEbGHY2.js.map} +1 -1
  56. package/dist/DifferenceLineChart.cjs +1 -1
  57. package/dist/DifferenceLineChart.cjs.map +1 -1
  58. package/dist/DifferenceLineChart.d.ts +11 -9
  59. package/dist/DifferenceLineChart.js +502 -504
  60. package/dist/DifferenceLineChart.js.map +1 -1
  61. package/dist/DonutChart.cjs +1 -1
  62. package/dist/DonutChart.cjs.map +1 -1
  63. package/dist/DonutChart.d.ts +14 -9
  64. package/dist/DonutChart.js +174 -179
  65. package/dist/DonutChart.js.map +1 -1
  66. package/dist/DotDensityMap.cjs +1 -1
  67. package/dist/DotDensityMap.cjs.map +1 -1
  68. package/dist/DotDensityMap.d.ts +1 -1
  69. package/dist/DotDensityMap.js +270 -267
  70. package/dist/DotDensityMap.js.map +1 -1
  71. package/dist/DualAxisLineChart.cjs +1 -1
  72. package/dist/DualAxisLineChart.cjs.map +1 -1
  73. package/dist/DualAxisLineChart.d.ts +13 -9
  74. package/dist/DualAxisLineChart.js +341 -351
  75. package/dist/DualAxisLineChart.js.map +1 -1
  76. package/dist/DumbbellChart.cjs +1 -1
  77. package/dist/DumbbellChart.cjs.map +1 -1
  78. package/dist/DumbbellChart.d.ts +11 -9
  79. package/dist/DumbbellChart.js +592 -593
  80. package/dist/DumbbellChart.js.map +1 -1
  81. package/dist/GeoHubCompareMaps.cjs +1 -1
  82. package/dist/GeoHubCompareMaps.d.ts +1 -1
  83. package/dist/GeoHubCompareMaps.js +1 -1
  84. package/dist/GeoHubMap.cjs +1 -1
  85. package/dist/GeoHubMap.d.ts +1 -1
  86. package/dist/GeoHubMap.js +1 -1
  87. package/dist/GeoHubMapWithLayerSelection.cjs +1 -1
  88. package/dist/GeoHubMapWithLayerSelection.d.ts +1 -1
  89. package/dist/GeoHubMapWithLayerSelection.js +1 -1
  90. package/dist/GraphEl-BgkDbq50.cjs +2 -0
  91. package/dist/GraphEl-BgkDbq50.cjs.map +1 -0
  92. package/dist/GraphEl-Ch0uAeZw.js +1830 -0
  93. package/dist/GraphEl-Ch0uAeZw.js.map +1 -0
  94. package/dist/GriddedGraphs.cjs +1 -1
  95. package/dist/GriddedGraphs.d.ts +29 -16
  96. package/dist/GriddedGraphs.js +1 -1
  97. package/dist/GriddedGraphsFromConfig.d.ts +29 -16
  98. package/dist/HeatMap.cjs +1 -1
  99. package/dist/HeatMap.cjs.map +1 -1
  100. package/dist/HeatMap.d.ts +11 -9
  101. package/dist/HeatMap.js +203 -205
  102. package/dist/HeatMap.js.map +1 -1
  103. package/dist/Histogram.cjs +1 -1
  104. package/dist/Histogram.cjs.map +1 -1
  105. package/dist/Histogram.d.ts +11 -5
  106. package/dist/Histogram.js +88 -89
  107. package/dist/Histogram.js.map +1 -1
  108. package/dist/HybridMap.cjs +1 -1
  109. package/dist/HybridMap.cjs.map +1 -1
  110. package/dist/HybridMap.d.ts +11 -3
  111. package/dist/HybridMap.js +339 -336
  112. package/dist/HybridMap.js.map +1 -1
  113. package/dist/ImageDownloadButton.cjs +1 -1
  114. package/dist/ImageDownloadButton.js +1 -1
  115. package/dist/LineChartWithConfidenceInterval.cjs +1 -1
  116. package/dist/LineChartWithConfidenceInterval.cjs.map +1 -1
  117. package/dist/LineChartWithConfidenceInterval.d.ts +11 -9
  118. package/dist/LineChartWithConfidenceInterval.js +393 -395
  119. package/dist/LineChartWithConfidenceInterval.js.map +1 -1
  120. package/dist/LinearColorLegend.cjs +1 -1
  121. package/dist/LinearColorLegend.js +1 -1
  122. package/dist/MultiGraphDashboard.d.ts +29 -16
  123. package/dist/MultiGraphDashboardFromConfig.d.ts +29 -16
  124. package/dist/MultiGraphDashboardWideToLongFormat.d.ts +1 -1
  125. package/dist/MultiGraphDashboardWideToLongFormatFromConfig.d.ts +1 -1
  126. package/dist/MultiLineAltChart.cjs +1 -1
  127. package/dist/MultiLineAltChart.cjs.map +1 -1
  128. package/dist/MultiLineAltChart.d.ts +11 -9
  129. package/dist/MultiLineAltChart.js +411 -413
  130. package/dist/MultiLineAltChart.js.map +1 -1
  131. package/dist/MultiLineChart.cjs +1 -1
  132. package/dist/MultiLineChart.cjs.map +1 -1
  133. package/dist/MultiLineChart.d.ts +11 -9
  134. package/dist/MultiLineChart.js +438 -440
  135. package/dist/MultiLineChart.js.map +1 -1
  136. package/dist/ParetoChart.cjs +1 -1
  137. package/dist/ParetoChart.cjs.map +1 -1
  138. package/dist/ParetoChart.d.ts +13 -13
  139. package/dist/ParetoChart.js +347 -355
  140. package/dist/ParetoChart.js.map +1 -1
  141. package/dist/PerformanceIntensiveMultiGraphDashboard.d.ts +29 -16
  142. package/dist/PerformanceIntensiveMultiGraphDashboardFromConfig.d.ts +29 -16
  143. package/dist/PerformanceIntensiveScrollStory.d.ts +29 -16
  144. package/dist/RadarChart.cjs +1 -1
  145. package/dist/RadarChart.cjs.map +1 -1
  146. package/dist/RadarChart.d.ts +11 -5
  147. package/dist/RadarChart.js +213 -213
  148. package/dist/RadarChart.js.map +1 -1
  149. package/dist/SankeyChart.cjs +1 -1
  150. package/dist/SankeyChart.cjs.map +1 -1
  151. package/dist/SankeyChart.d.ts +11 -9
  152. package/dist/SankeyChart.js +448 -450
  153. package/dist/SankeyChart.js.map +1 -1
  154. package/dist/ScatterPlot.cjs +1 -1
  155. package/dist/ScatterPlot.cjs.map +1 -1
  156. package/dist/ScatterPlot.d.ts +15 -13
  157. package/dist/ScatterPlot.js +477 -483
  158. package/dist/ScatterPlot.js.map +1 -1
  159. package/dist/ScrollStory.d.ts +29 -16
  160. package/dist/SimpleLineChart.cjs +1 -1
  161. package/dist/SimpleLineChart.cjs.map +1 -1
  162. package/dist/SimpleLineChart.d.ts +11 -9
  163. package/dist/SimpleLineChart.js +362 -364
  164. package/dist/SimpleLineChart.js.map +1 -1
  165. package/dist/SingleGraphDashboard.cjs +1 -1
  166. package/dist/SingleGraphDashboard.d.ts +29 -16
  167. package/dist/SingleGraphDashboard.js +1 -1
  168. package/dist/SingleGraphDashboardFromConfig.d.ts +29 -16
  169. package/dist/SingleGraphDashboardGeoHubMaps.d.ts +29 -16
  170. package/dist/SingleGraphDashboardGeoHubMapsFromConfig.d.ts +29 -16
  171. package/dist/SingleGraphDashboardThreeDGraphs.cjs +1 -1
  172. package/dist/SingleGraphDashboardThreeDGraphs.cjs.map +1 -1
  173. package/dist/SingleGraphDashboardThreeDGraphs.d.ts +29 -16
  174. package/dist/SingleGraphDashboardThreeDGraphs.js +40 -39
  175. package/dist/SingleGraphDashboardThreeDGraphs.js.map +1 -1
  176. package/dist/SingleGraphDashboardThreeDGraphsFromConfig.d.ts +29 -16
  177. package/dist/SlopeChart.cjs +1 -1
  178. package/dist/SlopeChart.d.ts +1 -1
  179. package/dist/SlopeChart.js +2 -2
  180. package/dist/SparkLine.cjs +1 -1
  181. package/dist/SparkLine.d.ts +1 -1
  182. package/dist/SparkLine.js +1 -1
  183. package/dist/StatCardFromData.cjs +1 -1
  184. package/dist/StatCardFromData.cjs.map +1 -1
  185. package/dist/StatCardFromData.d.ts +11 -9
  186. package/dist/StatCardFromData.js +113 -116
  187. package/dist/StatCardFromData.js.map +1 -1
  188. package/dist/StripChart.cjs +1 -1
  189. package/dist/StripChart.cjs.map +1 -1
  190. package/dist/StripChart.d.ts +11 -9
  191. package/dist/StripChart.js +434 -435
  192. package/dist/StripChart.js.map +1 -1
  193. package/dist/ThreeDGlobe.cjs +1 -1
  194. package/dist/ThreeDGlobe.cjs.map +1 -1
  195. package/dist/ThreeDGlobe.d.ts +11 -3
  196. package/dist/ThreeDGlobe.js +143 -143
  197. package/dist/ThreeDGlobe.js.map +1 -1
  198. package/dist/ThresholdColorLegendWithMouseOver.cjs +1 -1
  199. package/dist/ThresholdColorLegendWithMouseOver.js +1 -1
  200. package/dist/{Tooltip-Bj-s__cI.js → Tooltip-3EYDVa3w.js} +2 -2
  201. package/dist/{Tooltip-Bj-s__cI.js.map → Tooltip-3EYDVa3w.js.map} +1 -1
  202. package/dist/{Tooltip-Hr46paWP.cjs → Tooltip-C9F3uYG0.cjs} +2 -2
  203. package/dist/{Tooltip-Hr46paWP.cjs.map → Tooltip-C9F3uYG0.cjs.map} +1 -1
  204. package/dist/TreeMapGraph.cjs +1 -1
  205. package/dist/TreeMapGraph.cjs.map +1 -1
  206. package/dist/TreeMapGraph.d.ts +11 -9
  207. package/dist/TreeMapGraph.js +369 -371
  208. package/dist/TreeMapGraph.js.map +1 -1
  209. package/dist/Types.d.ts +29 -16
  210. package/dist/UnitChart.cjs +1 -1
  211. package/dist/UnitChart.cjs.map +1 -1
  212. package/dist/UnitChart.d.ts +11 -5
  213. package/dist/UnitChart.js +118 -119
  214. package/dist/UnitChart.js.map +1 -1
  215. package/dist/WaterfallChart.cjs +1 -1
  216. package/dist/WaterfallChart.cjs.map +1 -1
  217. package/dist/WaterfallChart.d.ts +11 -9
  218. package/dist/WaterfallChart.js +306 -308
  219. package/dist/WaterfallChart.js.map +1 -1
  220. package/dist/XTicksAndGridLines-B4UhDVyU.cjs +2 -0
  221. package/dist/XTicksAndGridLines-B4UhDVyU.cjs.map +1 -0
  222. package/dist/XTicksAndGridLines-CkYwVshF.js +40 -0
  223. package/dist/XTicksAndGridLines-CkYwVshF.js.map +1 -0
  224. package/dist/YTicksAndGridLines-BbujwxOB.js +40 -0
  225. package/dist/YTicksAndGridLines-BbujwxOB.js.map +1 -0
  226. package/dist/YTicksAndGridLines-sT3zdCs6.cjs +2 -0
  227. package/dist/YTicksAndGridLines-sT3zdCs6.cjs.map +1 -0
  228. package/dist/{imageDownload-Diofs_vY.js → imageDownload-BYsNEtMS.js} +11 -11
  229. package/dist/{imageDownload-Diofs_vY.js.map → imageDownload-BYsNEtMS.js.map} +1 -1
  230. package/dist/{imageDownload-61q6jyJW.cjs → imageDownload-CkMwA7Cw.cjs} +4 -4
  231. package/dist/{imageDownload-61q6jyJW.cjs.map → imageDownload-CkMwA7Cw.cjs.map} +1 -1
  232. package/dist/index-BPyj_6hG.js +375 -0
  233. package/dist/index-BPyj_6hG.js.map +1 -0
  234. package/dist/index-DuLvdHo2.cjs +2 -0
  235. package/dist/index-DuLvdHo2.cjs.map +1 -0
  236. package/dist/index.cjs +1 -1
  237. package/dist/index.d.ts +108 -245
  238. package/dist/index.js +3 -3
  239. package/dist/numberFormattingFunction-BUUV_luR.js +28 -0
  240. package/dist/numberFormattingFunction-BUUV_luR.js.map +1 -0
  241. package/dist/numberFormattingFunction-u2iNHL_c.cjs +2 -0
  242. package/dist/numberFormattingFunction-u2iNHL_c.cjs.map +1 -0
  243. package/dist/{string2HTML-ZoGd08P_.cjs → string2HTML-30nfIm8R.cjs} +2 -2
  244. package/dist/{string2HTML-ZoGd08P_.cjs.map → string2HTML-30nfIm8R.cjs.map} +1 -1
  245. package/dist/{string2HTML-BrFperRM.js → string2HTML-DL-pInUB.js} +2 -2
  246. package/dist/{string2HTML-BrFperRM.js.map → string2HTML-DL-pInUB.js.map} +1 -1
  247. package/dist/style.css +1 -1
  248. package/dist/utils.cjs +1 -1
  249. package/dist/utils.d.ts +1 -1
  250. package/dist/utils.js +2 -2
  251. package/package.json +2 -2
  252. package/dist/GraphEl-B73N4RIA.js +0 -1906
  253. package/dist/GraphEl-B73N4RIA.js.map +0 -1
  254. package/dist/GraphEl-Lt1og0C-.cjs +0 -2
  255. package/dist/GraphEl-Lt1og0C-.cjs.map +0 -1
  256. package/dist/XTicksAndGridLines-C5DuC5oY.cjs +0 -2
  257. package/dist/XTicksAndGridLines-C5DuC5oY.cjs.map +0 -1
  258. package/dist/XTicksAndGridLines-gdbGX2rm.js +0 -39
  259. package/dist/XTicksAndGridLines-gdbGX2rm.js.map +0 -1
  260. package/dist/YTicksAndGridLines-CsNSq9W9.js +0 -39
  261. package/dist/YTicksAndGridLines-CsNSq9W9.js.map +0 -1
  262. package/dist/YTicksAndGridLines-DFjm8RCc.cjs +0 -2
  263. package/dist/YTicksAndGridLines-DFjm8RCc.cjs.map +0 -1
  264. package/dist/index-B0Awa_de.js +0 -377
  265. package/dist/index-B0Awa_de.js.map +0 -1
  266. package/dist/index-CP8cmNzt.cjs +0 -2
  267. package/dist/index-CP8cmNzt.cjs.map +0 -1
  268. package/dist/numberFormattingFunction-Cn9R7CM9.cjs +0 -2
  269. package/dist/numberFormattingFunction-Cn9R7CM9.cjs.map +0 -1
  270. package/dist/numberFormattingFunction-DqMf_v1m.js +0 -28
  271. package/dist/numberFormattingFunction-DqMf_v1m.js.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"RadarChart.js","sources":["../node_modules/d3-shape/src/curve/radial.js","../node_modules/d3-shape/src/lineRadial.js","../node_modules/d3-shape/src/noop.js","../node_modules/d3-shape/src/curve/cardinal.js","../node_modules/d3-shape/src/curve/cardinalClosed.js","../node_modules/d3-shape/src/curve/linearClosed.js","../src/Components/Graphs/RadarChart/Graph.tsx","../src/Components/Graphs/RadarChart/index.tsx"],"sourcesContent":["import curveLinear from \"./linear.js\";\n\nexport var curveRadialLinear = curveRadial(curveLinear);\n\nfunction Radial(curve) {\n this._curve = curve;\n}\n\nRadial.prototype = {\n areaStart: function() {\n this._curve.areaStart();\n },\n areaEnd: function() {\n this._curve.areaEnd();\n },\n lineStart: function() {\n this._curve.lineStart();\n },\n lineEnd: function() {\n this._curve.lineEnd();\n },\n point: function(a, r) {\n this._curve.point(r * Math.sin(a), r * -Math.cos(a));\n }\n};\n\nexport default function curveRadial(curve) {\n\n function radial(context) {\n return new Radial(curve(context));\n }\n\n radial._curve = curve;\n\n return radial;\n}\n","import curveRadial, {curveRadialLinear} from \"./curve/radial.js\";\nimport line from \"./line.js\";\n\nexport function lineRadial(l) {\n var c = l.curve;\n\n l.angle = l.x, delete l.x;\n l.radius = l.y, delete l.y;\n\n l.curve = function(_) {\n return arguments.length ? c(curveRadial(_)) : c()._curve;\n };\n\n return l;\n}\n\nexport default function() {\n return lineRadial(line().curve(curveRadialLinear));\n}\n","export default function() {}\n","export function point(that, x, y) {\n that._context.bezierCurveTo(\n that._x1 + that._k * (that._x2 - that._x0),\n that._y1 + that._k * (that._y2 - that._y0),\n that._x2 + that._k * (that._x1 - x),\n that._y2 + that._k * (that._y1 - y),\n that._x2,\n that._y2\n );\n}\n\nexport function Cardinal(context, tension) {\n this._context = context;\n this._k = (1 - tension) / 6;\n}\n\nCardinal.prototype = {\n areaStart: function() {\n this._line = 0;\n },\n areaEnd: function() {\n this._line = NaN;\n },\n lineStart: function() {\n this._x0 = this._x1 = this._x2 =\n this._y0 = this._y1 = this._y2 = NaN;\n this._point = 0;\n },\n lineEnd: function() {\n switch (this._point) {\n case 2: this._context.lineTo(this._x2, this._y2); break;\n case 3: point(this, this._x1, this._y1); break;\n }\n if (this._line || (this._line !== 0 && this._point === 1)) this._context.closePath();\n this._line = 1 - this._line;\n },\n point: function(x, y) {\n x = +x, y = +y;\n switch (this._point) {\n case 0: this._point = 1; this._line ? this._context.lineTo(x, y) : this._context.moveTo(x, y); break;\n case 1: this._point = 2; this._x1 = x, this._y1 = y; break;\n case 2: this._point = 3; // falls through\n default: point(this, x, y); break;\n }\n this._x0 = this._x1, this._x1 = this._x2, this._x2 = x;\n this._y0 = this._y1, this._y1 = this._y2, this._y2 = y;\n }\n};\n\nexport default (function custom(tension) {\n\n function cardinal(context) {\n return new Cardinal(context, tension);\n }\n\n cardinal.tension = function(tension) {\n return custom(+tension);\n };\n\n return cardinal;\n})(0);\n","import noop from \"../noop.js\";\nimport {point} from \"./cardinal.js\";\n\nexport function CardinalClosed(context, tension) {\n this._context = context;\n this._k = (1 - tension) / 6;\n}\n\nCardinalClosed.prototype = {\n areaStart: noop,\n areaEnd: noop,\n lineStart: function() {\n this._x0 = this._x1 = this._x2 = this._x3 = this._x4 = this._x5 =\n this._y0 = this._y1 = this._y2 = this._y3 = this._y4 = this._y5 = NaN;\n this._point = 0;\n },\n lineEnd: function() {\n switch (this._point) {\n case 1: {\n this._context.moveTo(this._x3, this._y3);\n this._context.closePath();\n break;\n }\n case 2: {\n this._context.lineTo(this._x3, this._y3);\n this._context.closePath();\n break;\n }\n case 3: {\n this.point(this._x3, this._y3);\n this.point(this._x4, this._y4);\n this.point(this._x5, this._y5);\n break;\n }\n }\n },\n point: function(x, y) {\n x = +x, y = +y;\n switch (this._point) {\n case 0: this._point = 1; this._x3 = x, this._y3 = y; break;\n case 1: this._point = 2; this._context.moveTo(this._x4 = x, this._y4 = y); break;\n case 2: this._point = 3; this._x5 = x, this._y5 = y; break;\n default: point(this, x, y); break;\n }\n this._x0 = this._x1, this._x1 = this._x2, this._x2 = x;\n this._y0 = this._y1, this._y1 = this._y2, this._y2 = y;\n }\n};\n\nexport default (function custom(tension) {\n\n function cardinal(context) {\n return new CardinalClosed(context, tension);\n }\n\n cardinal.tension = function(tension) {\n return custom(+tension);\n };\n\n return cardinal;\n})(0);\n","import noop from \"../noop.js\";\n\nfunction LinearClosed(context) {\n this._context = context;\n}\n\nLinearClosed.prototype = {\n areaStart: noop,\n areaEnd: noop,\n lineStart: function() {\n this._point = 0;\n },\n lineEnd: function() {\n if (this._point) this._context.closePath();\n },\n point: function(x, y) {\n x = +x, y = +y;\n if (this._point) this._context.lineTo(x, y);\n else this._point = 1, this._context.moveTo(x, y);\n }\n};\n\nexport default function(context) {\n return new LinearClosed(context);\n}\n","/* eslint-disable @typescript-eslint/no-explicit-any */\r\nimport isEqual from 'fast-deep-equal';\r\nimport { lineRadial, curveLinearClosed, curveCardinalClosed } from 'd3-shape';\r\nimport { useRef, useState } from 'react';\r\nimport { cn } from '@undp/design-system-react/cn';\r\nimport { scaleLinear } from 'd3-scale';\r\nimport { AnimatePresence, motion, useInView } from 'motion/react';\r\n\r\nimport {\r\n AnimateDataType,\r\n ClassNameObject,\r\n CustomLayerDataType,\r\n RadarChartDataType,\r\n StyleObject,\r\n} from '@/Types';\r\nimport { Tooltip } from '@/Components/Elements/Tooltip';\r\nimport { Colors } from '@/Components/ColorPalette';\r\nimport { numberFormattingFunction } from '@/Utils/numberFormattingFunction';\r\nimport { checkIfNullOrUndefined } from '@/Utils/checkIfNullOrUndefined';\r\nimport { DetailsModal } from '@/Components/Elements/DetailsModal';\r\n\r\ninterface Props {\r\n radius: number;\r\n lineColors: string[];\r\n axisLabels: (string | number)[];\r\n data: RadarChartDataType[];\r\n\r\n tooltip?: string | ((_d: any) => React.ReactNode);\r\n selectedColor?: string;\r\n onSeriesMouseOver?: (_d: any) => void;\r\n onSeriesMouseClick?: (_d: any) => void;\r\n colorDomain: string[];\r\n\r\n detailsOnClick?: string | ((_d: any) => React.ReactNode);\r\n strokeWidth: number;\r\n styles?: StyleObject;\r\n classNames?: ClassNameObject;\r\n showValues: boolean;\r\n showDots: boolean;\r\n topMargin: number;\r\n bottomMargin: number;\r\n leftMargin: number;\r\n rightMargin: number;\r\n curveType: 'linear' | 'curve';\r\n noOfTicks: number;\r\n maxValue?: number;\r\n minValue?: number;\r\n fillShape: boolean;\r\n resetSelectionOnDoubleClick: boolean;\r\n highlightedLines?: (string | number)[];\r\n animate: AnimateDataType;\r\n dimmedOpacity: number;\r\n precision: number;\r\n customLayers: CustomLayerDataType[];\r\n locale: string;\r\n}\r\n\r\nexport function Graph(props: Props) {\r\n const {\r\n data,\r\n radius,\r\n lineColors,\r\n tooltip,\r\n onSeriesMouseOver,\r\n onSeriesMouseClick,\r\n colorDomain,\r\n detailsOnClick,\r\n styles,\r\n classNames,\r\n selectedColor,\r\n axisLabels,\r\n strokeWidth,\r\n showValues,\r\n showDots,\r\n rightMargin,\r\n topMargin,\r\n bottomMargin,\r\n leftMargin,\r\n curveType,\r\n noOfTicks,\r\n minValue,\r\n maxValue,\r\n resetSelectionOnDoubleClick,\r\n fillShape,\r\n highlightedLines,\r\n animate,\r\n dimmedOpacity,\r\n precision,\r\n customLayers,\r\n locale,\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 curve = curveType === 'linear' ? curveLinearClosed : curveCardinalClosed;\r\n const margin = {\r\n top: topMargin,\r\n bottom: bottomMargin,\r\n left: leftMargin,\r\n right: rightMargin,\r\n };\r\n const radiusWithoutMargin = Math.min(\r\n (2 * radius - leftMargin - rightMargin) / 2,\r\n (2 * radius - topMargin - bottomMargin) / 2,\r\n );\r\n const [mouseOverData, setMouseOverData] = useState<any>(undefined);\r\n\r\n const [mouseClickData, setMouseClickData] = useState<any>(undefined);\r\n const [eventX, setEventX] = useState<number | undefined>(undefined);\r\n const [eventY, setEventY] = useState<number | undefined>(undefined);\r\n const angleScale = scaleLinear()\r\n .domain([0, data[0].values.length])\r\n .range([0, 2 * Math.PI]);\r\n\r\n const maxVal = !checkIfNullOrUndefined(maxValue)\r\n ? (maxValue as number)\r\n : Math.max(\r\n ...data.map(d =>\r\n Math.max(...(d.values.filter(l => !checkIfNullOrUndefined(l)) as number[])),\r\n ),\r\n ) < 0\r\n ? 0\r\n : Math.max(\r\n ...data.map(d =>\r\n Math.max(...(d.values.filter(l => !checkIfNullOrUndefined(l)) as number[])),\r\n ),\r\n );\r\n\r\n const minVal = !checkIfNullOrUndefined(minValue)\r\n ? (minValue as number)\r\n : Math.min(\r\n ...data.map(d =>\r\n Math.min(...(d.values.filter(l => !checkIfNullOrUndefined(l)) as number[])),\r\n ),\r\n ) >= 0\r\n ? 0\r\n : Math.min(\r\n ...data.map(d =>\r\n Math.min(...(d.values.filter(l => !checkIfNullOrUndefined(l)) as number[])),\r\n ),\r\n );\r\n const scale = scaleLinear().domain([minVal, maxVal]).range([0, radiusWithoutMargin]).nice();\r\n const ticksArray = scale.ticks(noOfTicks);\r\n const lineShape = lineRadial<number>()\r\n .radius(d => scale(d))\r\n .angle((_, i) => angleScale(i))\r\n .curve(curve);\r\n return (\r\n <>\r\n <motion.svg\r\n width={`${radius * 2}px`}\r\n height={`${radius * 2}px`}\r\n viewBox={`0 0 ${radius * 2} ${radius * 2}`}\r\n direction='ltr'\r\n ref={svgRef}\r\n className='mx-auto'\r\n >\r\n <g transform={`translate(${margin.left},${margin.top})`}>\r\n {customLayers.filter(d => d.position === 'before').map(d => d.layer)}\r\n <g transform={`translate(${radiusWithoutMargin},${radiusWithoutMargin})`}>\r\n {axisLabels.map((d, i) => (\r\n <g key={i}>\r\n <line\r\n x1={0}\r\n y1={0}\r\n x2={Math.cos(angleScale(i) - Math.PI / 2) * radiusWithoutMargin}\r\n y2={Math.sin(angleScale(i) - Math.PI / 2) * radiusWithoutMargin}\r\n key={i}\r\n className={cn(\r\n 'stroke-1 stroke-primary-gray-500 dark:stroke-primary-gray-550',\r\n classNames?.xAxis?.axis,\r\n )}\r\n style={styles?.xAxis?.axis}\r\n />\r\n <text\r\n x={Math.cos(angleScale(i) - Math.PI / 2) * (radiusWithoutMargin + 6)}\r\n y={Math.sin(angleScale(i) - Math.PI / 2) * (radiusWithoutMargin + 6)}\r\n style={{\r\n textAnchor:\r\n Math.cos(angleScale(i) - Math.PI / 2) < 0\r\n ? 'end'\r\n : Math.cos(angleScale(i) - Math.PI / 2) < 0.00001\r\n ? 'middle'\r\n : 'start',\r\n ...(styles?.xAxis?.labels || ''),\r\n }}\r\n dy={\r\n Math.sin(angleScale(i) - Math.PI / 2) < 0\r\n ? 0\r\n : Math.sin(angleScale(i) - Math.PI / 2) < 0.00001\r\n ? 5\r\n : 10\r\n }\r\n className={cn(\r\n 'fill-primary-gray-700 dark:fill-primary-gray-300 text-xs',\r\n classNames?.xAxis?.labels,\r\n )}\r\n >\r\n {d}\r\n </text>\r\n </g>\r\n ))}\r\n {ticksArray.map((d, i) => (\r\n <g key={i}>\r\n <path\r\n d={lineShape(Array(axisLabels.length).fill(d)) || ''}\r\n className={cn(\r\n 'stroke-primary-gray-500 dark:stroke-primary-gray-550',\r\n classNames?.xAxis?.gridLines,\r\n )}\r\n style={{\r\n ...styles?.xAxis?.gridLines,\r\n fill: 'none',\r\n }}\r\n />\r\n <foreignObject\r\n x={-25}\r\n y={\r\n Math.sin(-Math.PI / 2) * scale(d) > -0.0001\r\n ? Math.sin(-Math.PI / 2) * scale(d) - 7\r\n : Math.sin(-Math.PI / 2) * scale(d) - 5\r\n }\r\n width={50}\r\n height={12}\r\n >\r\n <div className='flex justify-center'>\r\n <p\r\n className={cn(\r\n 'fill-primary-gray-500 dark:fill-primary-gray-550 text-xs m-0 py-0 px-1.5 text-center leading-none bg-primary-white dark:bg-primary-gray-700',\r\n classNames?.xAxis?.labels,\r\n )}\r\n style={styles?.xAxis?.labels}\r\n >\r\n {numberFormattingFunction(\r\n d,\r\n undefined,\r\n precision,\r\n undefined,\r\n undefined,\r\n locale,\r\n )}\r\n </p>\r\n </div>\r\n </foreignObject>\r\n </g>\r\n ))}\r\n <AnimatePresence>\r\n {data.map((d, i) => (\r\n <motion.g\r\n key={d.label || i}\r\n variants={{\r\n initial: {\r\n opacity: mouseOverData\r\n ? d.label === mouseOverData.label\r\n ? 1\r\n : dimmedOpacity\r\n : selectedColor\r\n ? d.color\r\n ? lineColors[colorDomain.indexOf(d.color)] === selectedColor\r\n ? 1\r\n : dimmedOpacity\r\n : dimmedOpacity\r\n : highlightedLines\r\n ? d.label\r\n ? highlightedLines.indexOf(d.label) !== -1\r\n ? 1\r\n : 0.3\r\n : 0.3\r\n : 1,\r\n },\r\n whileInView: {\r\n opacity: mouseOverData\r\n ? d.label === mouseOverData.label\r\n ? 1\r\n : dimmedOpacity\r\n : selectedColor\r\n ? d.color\r\n ? lineColors[colorDomain.indexOf(d.color)] === selectedColor\r\n ? 1\r\n : dimmedOpacity\r\n : dimmedOpacity\r\n : highlightedLines\r\n ? d.label\r\n ? highlightedLines.indexOf(d.label) !== -1\r\n ? 1\r\n : dimmedOpacity\r\n : dimmedOpacity\r\n : 1,\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n onMouseEnter={event => {\r\n setMouseOverData(d);\r\n setEventY(event.clientY);\r\n setEventX(event.clientX);\r\n onSeriesMouseOver?.(d);\r\n }}\r\n onMouseMove={event => {\r\n setMouseOverData(d);\r\n setEventY(event.clientY);\r\n setEventX(event.clientX);\r\n }}\r\n onMouseLeave={() => {\r\n setMouseOverData(undefined);\r\n setEventX(undefined);\r\n setEventY(undefined);\r\n onSeriesMouseOver?.(undefined);\r\n }}\r\n onClick={() => {\r\n if (onSeriesMouseClick || detailsOnClick) {\r\n if (isEqual(mouseClickData, d) && resetSelectionOnDoubleClick) {\r\n setMouseClickData(undefined);\r\n onSeriesMouseClick?.(undefined);\r\n } else {\r\n setMouseClickData(d);\r\n onSeriesMouseClick?.(d);\r\n }\r\n }\r\n }}\r\n >\r\n <motion.path\r\n d={lineShape(d.values) || ''}\r\n variants={{\r\n initial: {\r\n d: lineShape(d.values.map(_el => 0)) || '',\r\n stroke:\r\n data.filter(el => el.color).length === 0\r\n ? lineColors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : lineColors[colorDomain.indexOf(d.color)],\r\n fill: fillShape\r\n ? data.filter(el => el.color).length === 0\r\n ? lineColors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : lineColors[colorDomain.indexOf(d.color)]\r\n : 'none',\r\n strokeWidth,\r\n },\r\n whileInView: {\r\n d: lineShape(d.values) || '',\r\n transition: { duration: animate.duration },\r\n stroke:\r\n data.filter(el => el.color).length === 0\r\n ? lineColors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : lineColors[colorDomain.indexOf(d.color)],\r\n fill: fillShape\r\n ? data.filter(el => el.color).length === 0\r\n ? lineColors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : lineColors[colorDomain.indexOf(d.color)]\r\n : 'none',\r\n strokeWidth,\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n style={{\r\n fillOpacity: 0.1,\r\n }}\r\n />\r\n <g>\r\n {d.values.map((el, j) => (\r\n <g key={j}>\r\n {!checkIfNullOrUndefined(el) ? (\r\n <>\r\n {showDots ? (\r\n <motion.circle\r\n r={4}\r\n variants={{\r\n initial: {\r\n cx: 0,\r\n cy: 0,\r\n opacity: 0,\r\n fill:\r\n data.filter(el => el.color).length === 0\r\n ? lineColors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : lineColors[colorDomain.indexOf(d.color)],\r\n },\r\n whileInView: {\r\n cx: Math.cos(angleScale(j) - Math.PI / 2) * scale(el),\r\n cy: Math.sin(angleScale(j) - Math.PI / 2) * scale(el),\r\n opacity: 1,\r\n transition: { duration: animate.duration },\r\n fill:\r\n data.filter(el => el.color).length === 0\r\n ? lineColors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : lineColors[colorDomain.indexOf(d.color)],\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n />\r\n ) : null}\r\n {showValues ? (\r\n <motion.text\r\n style={{\r\n ...(styles?.graphObjectValues || {}),\r\n }}\r\n dy={\r\n Math.sin(angleScale(j) - Math.PI / 2) < 0\r\n ? 10\r\n : Math.sin(angleScale(j) - Math.PI / 2) < 0.00001\r\n ? 0\r\n : 0\r\n }\r\n className={cn(\r\n 'graph-value text-xs font-bold',\r\n classNames?.graphObjectValues,\r\n )}\r\n variants={{\r\n initial: {\r\n opacity: 0,\r\n x: Math.cos(angleScale(j) - Math.PI / 2) * (scale(el) + 6),\r\n y: Math.sin(angleScale(j) - Math.PI / 2) * (scale(el) + 6),\r\n fill: lineColors[i],\r\n textAnchor:\r\n Math.cos(angleScale(j) - Math.PI / 2) < 0\r\n ? 'end'\r\n : Math.cos(angleScale(j) - Math.PI / 2) < 0.00001\r\n ? 'middle'\r\n : 'start',\r\n },\r\n whileInView: {\r\n opacity: 1,\r\n x: Math.cos(angleScale(j) - Math.PI / 2) * (scale(el) + 6),\r\n y: Math.sin(angleScale(j) - Math.PI / 2) * (scale(el) + 6),\r\n fill: lineColors[i],\r\n textAnchor:\r\n Math.cos(angleScale(j) - Math.PI / 2) < 0\r\n ? 'end'\r\n : Math.cos(angleScale(j) - Math.PI / 2) < 0.00001\r\n ? 'middle'\r\n : 'start',\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n >\r\n {numberFormattingFunction(\r\n el,\r\n undefined,\r\n precision,\r\n undefined,\r\n undefined,\r\n locale,\r\n )}\r\n </motion.text>\r\n ) : null}\r\n </>\r\n ) : null}\r\n </g>\r\n ))}\r\n </g>\r\n </motion.g>\r\n ))}\r\n </AnimatePresence>\r\n </g>\r\n {customLayers.filter(d => d.position === 'after').map(d => d.layer)}\r\n </g>\r\n </motion.svg>\r\n {mouseOverData && tooltip && eventX && eventY ? (\r\n <Tooltip\r\n data={mouseOverData}\r\n body={tooltip}\r\n xPos={eventX}\r\n yPos={eventY}\r\n backgroundStyle={styles?.tooltip}\r\n className={classNames?.tooltip}\r\n />\r\n ) : null}\r\n {detailsOnClick && mouseClickData !== undefined ? (\r\n <DetailsModal\r\n body={detailsOnClick}\r\n data={mouseClickData}\r\n setData={setMouseClickData}\r\n className={classNames?.modal}\r\n />\r\n ) : null}\r\n </>\r\n );\r\n}\r\n","import { useEffect, useRef, useState } from 'react';\r\n\r\nimport { Graph } from './Graph';\r\n\r\nimport {\r\n RadarChartDataType,\r\n Languages,\r\n SourcesDataType,\r\n StyleObject,\r\n ClassNameObject,\r\n CustomLayerDataType,\r\n AnimateDataType,\r\n} from '@/Types';\r\nimport { GraphFooter } from '@/Components/Elements/GraphFooter';\r\nimport { GraphHeader } from '@/Components/Elements/GraphHeader';\r\nimport { Colors } from '@/Components/ColorPalette';\r\nimport { EmptyState } from '@/Components/Elements/EmptyState';\r\nimport { ColorLegendWithMouseOver } from '@/Components/Elements/ColorLegendWithMouseOver';\r\nimport { uniqBy } from '@/Utils/uniqBy';\r\nimport { GraphArea, GraphContainer } from '@/Components/Elements/GraphContainer';\r\n\r\ninterface Props {\r\n // Data\r\n /** Array of data objects */\r\n data: RadarChartDataType[];\r\n\r\n // Titles, Labels, and Sources\r\n /** Title of the graph */\r\n graphTitle?: string | React.ReactNode;\r\n /** Description of the graph */\r\n graphDescription?: string | React.ReactNode;\r\n /** Footnote for the graph */\r\n footNote?: string | React.ReactNode;\r\n /** Source data for the graph */\r\n sources?: SourcesDataType[];\r\n /** Accessibility label */\r\n ariaLabel?: string;\r\n\r\n // Colors and Styling\r\n /** Color or array of colors for each line */\r\n colors?: string | string[];\r\n /** Domain of colors for the graph */\r\n colorDomain?: string[];\r\n /** Title for the color legend */\r\n colorLegendTitle?: string;\r\n /** 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 /** Radius of the radar chart */\r\n radius?: number;\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 /** Maximum value for the chart */\r\n maxValue?: number;\r\n /** Minimum value for the chart */\r\n minValue?: number;\r\n\r\n // Graph Parameters\r\n /** 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 is the shape is filled or not */\r\n fillShape?: boolean;\r\n /** No. of ticks on the x-axis */\r\n noOfTicks?: number;\r\n /** Toggle visibility of color scale. This is only applicable if the data props hae color parameter */\r\n showColorScale?: boolean;\r\n /** Toggle visibility of NA color in the color scale. This is only applicable if the data props hae color parameter and showColorScale prop is true */\r\n showNAColor?: boolean;\r\n /** Data points to highlight. Use the label value from data to highlight the data point */\r\n highlightedLines?: (string | number)[];\r\n /** Defines the opacity of the non-highlighted data */\r\n dimmedOpacity?: number;\r\n /** Toggles if the graph animates in when loaded. */\r\n animate?: boolean | AnimateDataType;\r\n /** Labels for the axes */\r\n axisLabels: (string | number)[];\r\n /** Curve type for the line */\r\n curveType?: 'linear' | 'curve';\r\n /** Reset selection on double-click. Only applicable when used in a dashboard context with filters. */\r\n resetSelectionOnDoubleClick?: boolean;\r\n /** Specifies the number of decimal places to display in the value. */\r\n precision?: number;\r\n /** Locale for number formatting. Must matches what `Intl.NumberFormat` expects. */\r\n locale?: string;\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 /** Details displayed on the modal when user clicks of a data point. If the type is string then this uses the [handlebar](../?path=/docs/misc-handlebars-templates-and-custom-helpers--docs) template to display the data */\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n detailsOnClick?: string | ((_d: any) => React.ReactNode);\r\n /** Callback for mouse over event */\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseOver?: (_d: any) => void;\r\n /** Callback for mouse click event */\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseClick?: (_d: any) => void;\r\n\r\n // Configuration and Options\r\n /** Language setting */\r\n language?: Languages;\r\n /** Color theme */\r\n theme?: 'light' | 'dark';\r\n /** Unique ID for the graph */\r\n graphID?: string;\r\n}\r\n\r\nexport function RadarChart(props: Props) {\r\n const {\r\n graphTitle,\r\n colors,\r\n sources,\r\n graphDescription,\r\n footNote,\r\n radius,\r\n data,\r\n showColorScale = true,\r\n padding,\r\n backgroundColor = false,\r\n tooltip,\r\n onSeriesMouseOver,\r\n graphID,\r\n onSeriesMouseClick,\r\n topMargin = 75,\r\n bottomMargin = 75,\r\n leftMargin = 75,\r\n rightMargin = 75,\r\n graphDownload = false,\r\n dataDownload = false,\r\n colorDomain,\r\n language = 'en',\r\n theme = 'light',\r\n highlightedLines,\r\n width,\r\n height,\r\n minHeight = 0,\r\n strokeWidth = 2,\r\n relativeHeight,\r\n ariaLabel,\r\n colorLegendTitle,\r\n detailsOnClick,\r\n styles,\r\n classNames,\r\n showNAColor = true,\r\n axisLabels,\r\n showDots = true,\r\n showValues = false,\r\n curveType = 'curve',\r\n noOfTicks = 5,\r\n minValue,\r\n maxValue,\r\n fillShape = false,\r\n resetSelectionOnDoubleClick = true,\r\n animate = false,\r\n dimmedOpacity = 0.3,\r\n precision = 2,\r\n customLayers = [],\r\n locale = 'en',\r\n } = props;\r\n\r\n const [graphRadius, setGraphRadius] = useState(0);\r\n const [selectedColor, setSelectedColor] = useState<string | undefined>(undefined);\r\n\r\n const graphDiv = useRef<HTMLDivElement>(null);\r\n const graphParentDiv = useRef<HTMLDivElement>(null);\r\n\r\n useEffect(() => {\r\n const resizeObserver = new ResizeObserver(entries => {\r\n setGraphRadius(\r\n (Math.min(\r\n ...[\r\n entries[0].target.clientWidth || 620,\r\n entries[0].target.clientHeight || 480,\r\n radius || Infinity,\r\n ],\r\n ) || 420) / 2,\r\n );\r\n });\r\n if (graphDiv.current) {\r\n resizeObserver.observe(graphDiv.current);\r\n }\r\n return () => resizeObserver.disconnect();\r\n }, [radius]);\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 {showColorScale && data.filter(el => el.color).length !== 0 && data.length > 0 ? (\r\n <ColorLegendWithMouseOver\r\n width={width}\r\n colorLegendTitle={colorLegendTitle}\r\n colors={(colors as string[] | undefined) || Colors[theme].categoricalColors.colors}\r\n colorDomain={colorDomain || (uniqBy(data, 'color', true) as string[])}\r\n setSelectedColor={setSelectedColor}\r\n showNAColor={showNAColor}\r\n className={classNames?.colorLegend}\r\n isCenter\r\n />\r\n ) : null}\r\n <GraphArea ref={graphDiv}>\r\n {data.length === 0 && <EmptyState />}\r\n {graphRadius && data.length > 0 ? (\r\n <Graph\r\n data={data}\r\n lineColors={\r\n data.filter(el => el.color).length === 0\r\n ? colors\r\n ? [colors as string]\r\n : [Colors.primaryColors['blue-600']]\r\n : (colors as string[] | undefined) || Colors[theme].categoricalColors.colors\r\n }\r\n radius={graphRadius}\r\n tooltip={tooltip}\r\n colorDomain={colorDomain || (uniqBy(data, 'color', true) as string[])}\r\n onSeriesMouseOver={onSeriesMouseOver}\r\n onSeriesMouseClick={onSeriesMouseClick}\r\n styles={styles}\r\n detailsOnClick={detailsOnClick}\r\n selectedColor={selectedColor}\r\n axisLabels={axisLabels}\r\n strokeWidth={strokeWidth}\r\n showValues={showValues}\r\n showDots={showDots}\r\n topMargin={topMargin}\r\n bottomMargin={bottomMargin}\r\n leftMargin={leftMargin}\r\n rightMargin={rightMargin}\r\n curveType={curveType}\r\n noOfTicks={noOfTicks}\r\n minValue={minValue}\r\n maxValue={maxValue}\r\n fillShape={fillShape}\r\n highlightedLines={highlightedLines}\r\n resetSelectionOnDoubleClick={resetSelectionOnDoubleClick}\r\n animate={\r\n animate === true\r\n ? { duration: 0.5, once: true, amount: 0.5 }\r\n : animate || { duration: 0, once: true, amount: 0 }\r\n }\r\n dimmedOpacity={dimmedOpacity}\r\n precision={precision}\r\n customLayers={customLayers}\r\n locale={locale}\r\n />\r\n ) : null}\r\n </GraphArea>\r\n {sources || footNote ? (\r\n <GraphFooter\r\n styles={{ footnote: styles?.footnote, source: styles?.source }}\r\n classNames={{\r\n footnote: classNames?.footnote,\r\n source: classNames?.source,\r\n }}\r\n sources={sources}\r\n footNote={footNote}\r\n width={width}\r\n />\r\n ) : null}\r\n </GraphContainer>\r\n );\r\n}\r\n"],"names":["curveRadialLinear","curveRadial","curveLinear","Radial","curve","a","r","radial","context","lineRadial","l","c","_","lineRadial$1","line","noop","point","that","x","y","Cardinal","tension","custom","cardinal","CardinalClosed","curveCardinalClosed","LinearClosed","curveLinearClosed","Graph","props","$","_c","data","radius","lineColors","tooltip","onSeriesMouseOver","onSeriesMouseClick","colorDomain","detailsOnClick","styles","classNames","selectedColor","axisLabels","strokeWidth","showValues","showDots","rightMargin","topMargin","bottomMargin","leftMargin","curveType","noOfTicks","minValue","maxValue","resetSelectionOnDoubleClick","fillShape","highlightedLines","animate","dimmedOpacity","precision","customLayers","locale","svgRef","useRef","t0","amount","once","isInView","useInView","t1","top","bottom","left","right","margin","radiusWithoutMargin","Math","min","mouseOverData","setMouseOverData","useState","undefined","mouseClickData","setMouseClickData","eventX","setEventX","eventY","setEventY","T0","T1","t10","t11","t12","t13","t2","t3","t4","t5","t6","t7","t8","t9","duration","graphObjectValues","xAxis","axis","gridLines","labels","angleScale","scaleLinear","domain","values","length","range","PI","t14","checkIfNullOrUndefined","max","map","_temp2","_temp4","maxVal","t15","_temp6","_temp8","minVal","scale","nice","ticksArray","ticks","lineShape","d_3","d","angle","i","motion","svg","filter","_temp9","_temp0","d_6","i_0","jsx","cos","sin","cn","textAnchor","d_7","i_1","Array","fill","numberFormattingFunction","AnimatePresence","d_8","i_2","jsxs","initial","opacity","label","color","indexOf","whileInView","transition","event","clientY","clientX","event_0","isEqual","_temp1","stroke","_temp10","Colors","gray","_temp11","_temp12","_temp13","fillOpacity","el_3","j","el","Fragment","cx","cy","_temp14","_temp15","t16","_temp16","_temp17","t17","t18","t19","Tooltip","t20","modal","DetailsModal","t21","d_10","layer","d_9","position","el_5","el_4","el_2","el_1","el_0","_el","d_5","d_4","d_1","_temp7","l_1","d_2","_temp5","l_2","_temp3","d_0","_temp","l_0","RadarChart","graphTitle","colors","sources","graphDescription","footNote","showColorScale","padding","backgroundColor","graphID","graphDownload","dataDownload","language","theme","width","height","minHeight","relativeHeight","ariaLabel","colorLegendTitle","showNAColor","graphRadius","setGraphRadius","setSelectedColor","graphDiv","graphParentDiv","useEffect","resizeObserver","ResizeObserver","entries","target","clientWidth","clientHeight","Infinity","current","observe","disconnect","GraphContainer","graphContainer","GraphHeader","title","description","ColorLegendWithMouseOver","categoricalColors","uniqBy","colorLegend","GraphArea","EmptyState","primaryColors","GraphFooter","footnote","source"],"mappings":"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","x_google_ignoreList":[0,1,2,3,4,5]}
1
+ {"version":3,"file":"RadarChart.js","sources":["../node_modules/d3-shape/src/curve/radial.js","../node_modules/d3-shape/src/lineRadial.js","../node_modules/d3-shape/src/noop.js","../node_modules/d3-shape/src/curve/cardinal.js","../node_modules/d3-shape/src/curve/cardinalClosed.js","../node_modules/d3-shape/src/curve/linearClosed.js","../src/Components/Graphs/RadarChart/Graph.tsx","../src/Components/Graphs/RadarChart/index.tsx"],"sourcesContent":["import curveLinear from \"./linear.js\";\n\nexport var curveRadialLinear = curveRadial(curveLinear);\n\nfunction Radial(curve) {\n this._curve = curve;\n}\n\nRadial.prototype = {\n areaStart: function() {\n this._curve.areaStart();\n },\n areaEnd: function() {\n this._curve.areaEnd();\n },\n lineStart: function() {\n this._curve.lineStart();\n },\n lineEnd: function() {\n this._curve.lineEnd();\n },\n point: function(a, r) {\n this._curve.point(r * Math.sin(a), r * -Math.cos(a));\n }\n};\n\nexport default function curveRadial(curve) {\n\n function radial(context) {\n return new Radial(curve(context));\n }\n\n radial._curve = curve;\n\n return radial;\n}\n","import curveRadial, {curveRadialLinear} from \"./curve/radial.js\";\nimport line from \"./line.js\";\n\nexport function lineRadial(l) {\n var c = l.curve;\n\n l.angle = l.x, delete l.x;\n l.radius = l.y, delete l.y;\n\n l.curve = function(_) {\n return arguments.length ? c(curveRadial(_)) : c()._curve;\n };\n\n return l;\n}\n\nexport default function() {\n return lineRadial(line().curve(curveRadialLinear));\n}\n","export default function() {}\n","export function point(that, x, y) {\n that._context.bezierCurveTo(\n that._x1 + that._k * (that._x2 - that._x0),\n that._y1 + that._k * (that._y2 - that._y0),\n that._x2 + that._k * (that._x1 - x),\n that._y2 + that._k * (that._y1 - y),\n that._x2,\n that._y2\n );\n}\n\nexport function Cardinal(context, tension) {\n this._context = context;\n this._k = (1 - tension) / 6;\n}\n\nCardinal.prototype = {\n areaStart: function() {\n this._line = 0;\n },\n areaEnd: function() {\n this._line = NaN;\n },\n lineStart: function() {\n this._x0 = this._x1 = this._x2 =\n this._y0 = this._y1 = this._y2 = NaN;\n this._point = 0;\n },\n lineEnd: function() {\n switch (this._point) {\n case 2: this._context.lineTo(this._x2, this._y2); break;\n case 3: point(this, this._x1, this._y1); break;\n }\n if (this._line || (this._line !== 0 && this._point === 1)) this._context.closePath();\n this._line = 1 - this._line;\n },\n point: function(x, y) {\n x = +x, y = +y;\n switch (this._point) {\n case 0: this._point = 1; this._line ? this._context.lineTo(x, y) : this._context.moveTo(x, y); break;\n case 1: this._point = 2; this._x1 = x, this._y1 = y; break;\n case 2: this._point = 3; // falls through\n default: point(this, x, y); break;\n }\n this._x0 = this._x1, this._x1 = this._x2, this._x2 = x;\n this._y0 = this._y1, this._y1 = this._y2, this._y2 = y;\n }\n};\n\nexport default (function custom(tension) {\n\n function cardinal(context) {\n return new Cardinal(context, tension);\n }\n\n cardinal.tension = function(tension) {\n return custom(+tension);\n };\n\n return cardinal;\n})(0);\n","import noop from \"../noop.js\";\nimport {point} from \"./cardinal.js\";\n\nexport function CardinalClosed(context, tension) {\n this._context = context;\n this._k = (1 - tension) / 6;\n}\n\nCardinalClosed.prototype = {\n areaStart: noop,\n areaEnd: noop,\n lineStart: function() {\n this._x0 = this._x1 = this._x2 = this._x3 = this._x4 = this._x5 =\n this._y0 = this._y1 = this._y2 = this._y3 = this._y4 = this._y5 = NaN;\n this._point = 0;\n },\n lineEnd: function() {\n switch (this._point) {\n case 1: {\n this._context.moveTo(this._x3, this._y3);\n this._context.closePath();\n break;\n }\n case 2: {\n this._context.lineTo(this._x3, this._y3);\n this._context.closePath();\n break;\n }\n case 3: {\n this.point(this._x3, this._y3);\n this.point(this._x4, this._y4);\n this.point(this._x5, this._y5);\n break;\n }\n }\n },\n point: function(x, y) {\n x = +x, y = +y;\n switch (this._point) {\n case 0: this._point = 1; this._x3 = x, this._y3 = y; break;\n case 1: this._point = 2; this._context.moveTo(this._x4 = x, this._y4 = y); break;\n case 2: this._point = 3; this._x5 = x, this._y5 = y; break;\n default: point(this, x, y); break;\n }\n this._x0 = this._x1, this._x1 = this._x2, this._x2 = x;\n this._y0 = this._y1, this._y1 = this._y2, this._y2 = y;\n }\n};\n\nexport default (function custom(tension) {\n\n function cardinal(context) {\n return new CardinalClosed(context, tension);\n }\n\n cardinal.tension = function(tension) {\n return custom(+tension);\n };\n\n return cardinal;\n})(0);\n","import noop from \"../noop.js\";\n\nfunction LinearClosed(context) {\n this._context = context;\n}\n\nLinearClosed.prototype = {\n areaStart: noop,\n areaEnd: noop,\n lineStart: function() {\n this._point = 0;\n },\n lineEnd: function() {\n if (this._point) this._context.closePath();\n },\n point: function(x, y) {\n x = +x, y = +y;\n if (this._point) this._context.lineTo(x, y);\n else this._point = 1, this._context.moveTo(x, y);\n }\n};\n\nexport default function(context) {\n return new LinearClosed(context);\n}\n","/* eslint-disable @typescript-eslint/no-explicit-any */\r\nimport isEqual from 'fast-deep-equal';\r\nimport { lineRadial, curveLinearClosed, curveCardinalClosed } from 'd3-shape';\r\nimport { useRef, useState } from 'react';\r\nimport { cn } from '@undp/design-system-react/cn';\r\nimport { scaleLinear } from 'd3-scale';\r\nimport { AnimatePresence, motion, useInView } from 'motion/react';\r\n\r\nimport {\r\n AnimateDataType,\r\n ClassNameObject,\r\n CustomLayerDataType,\r\n RadarChartDataType,\r\n StyleObject,\r\n} from '@/Types';\r\nimport { Tooltip } from '@/Components/Elements/Tooltip';\r\nimport { Colors } from '@/Components/ColorPalette';\r\nimport { numberFormattingFunction } from '@/Utils/numberFormattingFunction';\r\nimport { checkIfNullOrUndefined } from '@/Utils/checkIfNullOrUndefined';\r\nimport { DetailsModal } from '@/Components/Elements/DetailsModal';\r\n\r\ninterface Props {\r\n radius: number;\r\n lineColors: string[];\r\n axisLabels: (string | number)[];\r\n data: RadarChartDataType[];\r\n\r\n tooltip?: string | ((_d: any) => React.ReactNode);\r\n selectedColor?: string;\r\n onSeriesMouseOver?: (_d: any) => void;\r\n onSeriesMouseClick?: (_d: any) => void;\r\n colorDomain: string[];\r\n\r\n detailsOnClick?: string | ((_d: any) => React.ReactNode);\r\n strokeWidth: number;\r\n styles?: StyleObject;\r\n classNames?: ClassNameObject;\r\n showValues: boolean;\r\n showDots: boolean;\r\n topMargin: number;\r\n bottomMargin: number;\r\n leftMargin: number;\r\n rightMargin: number;\r\n curveType: 'linear' | 'curve';\r\n noOfTicks: number;\r\n maxValue?: number;\r\n minValue?: number;\r\n fillShape: boolean;\r\n resetSelectionOnDoubleClick: boolean;\r\n highlightedLines?: (string | number)[];\r\n animate: AnimateDataType;\r\n dimmedOpacity: number;\r\n precision: number;\r\n customLayers: CustomLayerDataType[];\r\n locale: string;\r\n padZeros: boolean;\r\n}\r\n\r\nexport function Graph(props: Props) {\r\n const {\r\n data,\r\n radius,\r\n lineColors,\r\n tooltip,\r\n onSeriesMouseOver,\r\n onSeriesMouseClick,\r\n colorDomain,\r\n detailsOnClick,\r\n styles,\r\n classNames,\r\n selectedColor,\r\n axisLabels,\r\n strokeWidth,\r\n showValues,\r\n showDots,\r\n rightMargin,\r\n topMargin,\r\n bottomMargin,\r\n leftMargin,\r\n curveType,\r\n noOfTicks,\r\n minValue,\r\n maxValue,\r\n resetSelectionOnDoubleClick,\r\n fillShape,\r\n highlightedLines,\r\n animate,\r\n dimmedOpacity,\r\n precision,\r\n customLayers,\r\n locale,\r\n padZeros,\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 curve = curveType === 'linear' ? curveLinearClosed : curveCardinalClosed;\r\n const margin = {\r\n top: topMargin,\r\n bottom: bottomMargin,\r\n left: leftMargin,\r\n right: rightMargin,\r\n };\r\n const radiusWithoutMargin = Math.min(\r\n (2 * radius - leftMargin - rightMargin) / 2,\r\n (2 * radius - topMargin - bottomMargin) / 2,\r\n );\r\n const [mouseOverData, setMouseOverData] = useState<any>(undefined);\r\n\r\n const [mouseClickData, setMouseClickData] = useState<any>(undefined);\r\n const [eventX, setEventX] = useState<number | undefined>(undefined);\r\n const [eventY, setEventY] = useState<number | undefined>(undefined);\r\n const angleScale = scaleLinear()\r\n .domain([0, data[0].values.length])\r\n .range([0, 2 * Math.PI]);\r\n\r\n const maxVal = !checkIfNullOrUndefined(maxValue)\r\n ? (maxValue as number)\r\n : Math.max(\r\n ...data.map(d =>\r\n Math.max(...(d.values.filter(l => !checkIfNullOrUndefined(l)) as number[])),\r\n ),\r\n ) < 0\r\n ? 0\r\n : Math.max(\r\n ...data.map(d =>\r\n Math.max(...(d.values.filter(l => !checkIfNullOrUndefined(l)) as number[])),\r\n ),\r\n );\r\n\r\n const minVal = !checkIfNullOrUndefined(minValue)\r\n ? (minValue as number)\r\n : Math.min(\r\n ...data.map(d =>\r\n Math.min(...(d.values.filter(l => !checkIfNullOrUndefined(l)) as number[])),\r\n ),\r\n ) >= 0\r\n ? 0\r\n : Math.min(\r\n ...data.map(d =>\r\n Math.min(...(d.values.filter(l => !checkIfNullOrUndefined(l)) as number[])),\r\n ),\r\n );\r\n const scale = scaleLinear().domain([minVal, maxVal]).range([0, radiusWithoutMargin]).nice();\r\n const ticksArray = scale.ticks(noOfTicks);\r\n const lineShape = lineRadial<number>()\r\n .radius(d => scale(d))\r\n .angle((_, i) => angleScale(i))\r\n .curve(curve);\r\n return (\r\n <>\r\n <motion.svg\r\n width={`${radius * 2}px`}\r\n height={`${radius * 2}px`}\r\n viewBox={`0 0 ${radius * 2} ${radius * 2}`}\r\n direction='ltr'\r\n ref={svgRef}\r\n className='mx-auto'\r\n >\r\n <g transform={`translate(${margin.left},${margin.top})`}>\r\n {customLayers.filter(d => d.position === 'before').map(d => d.layer)}\r\n <g transform={`translate(${radiusWithoutMargin},${radiusWithoutMargin})`}>\r\n {axisLabels.map((d, i) => (\r\n <g key={i}>\r\n <line\r\n x1={0}\r\n y1={0}\r\n x2={Math.cos(angleScale(i) - Math.PI / 2) * radiusWithoutMargin}\r\n y2={Math.sin(angleScale(i) - Math.PI / 2) * radiusWithoutMargin}\r\n key={i}\r\n className={cn(\r\n 'stroke-1 stroke-primary-gray-500 dark:stroke-primary-gray-550',\r\n classNames?.xAxis?.axis,\r\n )}\r\n style={styles?.xAxis?.axis}\r\n />\r\n <text\r\n x={Math.cos(angleScale(i) - Math.PI / 2) * (radiusWithoutMargin + 6)}\r\n y={Math.sin(angleScale(i) - Math.PI / 2) * (radiusWithoutMargin + 6)}\r\n style={{\r\n textAnchor:\r\n Math.cos(angleScale(i) - Math.PI / 2) < 0\r\n ? 'end'\r\n : Math.cos(angleScale(i) - Math.PI / 2) < 0.00001\r\n ? 'middle'\r\n : 'start',\r\n ...(styles?.xAxis?.labels || ''),\r\n }}\r\n dy={\r\n Math.sin(angleScale(i) - Math.PI / 2) < 0\r\n ? 0\r\n : Math.sin(angleScale(i) - Math.PI / 2) < 0.00001\r\n ? 5\r\n : 10\r\n }\r\n className={cn(\r\n 'fill-primary-gray-700 dark:fill-primary-gray-300 text-xs',\r\n classNames?.xAxis?.labels,\r\n )}\r\n >\r\n {d}\r\n </text>\r\n </g>\r\n ))}\r\n {ticksArray.map((d, i) => (\r\n <g key={i}>\r\n <path\r\n d={lineShape(Array(axisLabels.length).fill(d)) || ''}\r\n className={cn(\r\n 'stroke-primary-gray-500 dark:stroke-primary-gray-550',\r\n classNames?.xAxis?.gridLines,\r\n )}\r\n style={{\r\n ...styles?.xAxis?.gridLines,\r\n fill: 'none',\r\n }}\r\n />\r\n <foreignObject\r\n x={-25}\r\n y={\r\n Math.sin(-Math.PI / 2) * scale(d) > -0.0001\r\n ? Math.sin(-Math.PI / 2) * scale(d) - 7\r\n : Math.sin(-Math.PI / 2) * scale(d) - 5\r\n }\r\n width={50}\r\n height={12}\r\n >\r\n <div className='flex justify-center'>\r\n <p\r\n className={cn(\r\n 'fill-primary-gray-500 dark:fill-primary-gray-550 text-xs m-0 py-0 px-1.5 text-center leading-none bg-primary-white dark:bg-primary-gray-700',\r\n classNames?.xAxis?.labels,\r\n )}\r\n style={styles?.xAxis?.labels}\r\n >\r\n {numberFormattingFunction(\r\n d,\r\n undefined,\r\n precision,\r\n undefined,\r\n undefined,\r\n locale,\r\n padZeros,\r\n )}\r\n </p>\r\n </div>\r\n </foreignObject>\r\n </g>\r\n ))}\r\n <AnimatePresence>\r\n {data.map((d, i) => (\r\n <motion.g\r\n key={d.label || i}\r\n variants={{\r\n initial: {\r\n opacity: mouseOverData\r\n ? d.label === mouseOverData.label\r\n ? 1\r\n : dimmedOpacity\r\n : selectedColor\r\n ? d.color\r\n ? lineColors[colorDomain.indexOf(d.color)] === selectedColor\r\n ? 1\r\n : dimmedOpacity\r\n : dimmedOpacity\r\n : highlightedLines\r\n ? d.label\r\n ? highlightedLines.indexOf(d.label) !== -1\r\n ? 1\r\n : 0.3\r\n : 0.3\r\n : 1,\r\n },\r\n whileInView: {\r\n opacity: mouseOverData\r\n ? d.label === mouseOverData.label\r\n ? 1\r\n : dimmedOpacity\r\n : selectedColor\r\n ? d.color\r\n ? lineColors[colorDomain.indexOf(d.color)] === selectedColor\r\n ? 1\r\n : dimmedOpacity\r\n : dimmedOpacity\r\n : highlightedLines\r\n ? d.label\r\n ? highlightedLines.indexOf(d.label) !== -1\r\n ? 1\r\n : dimmedOpacity\r\n : dimmedOpacity\r\n : 1,\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n onMouseEnter={event => {\r\n setMouseOverData(d);\r\n setEventY(event.clientY);\r\n setEventX(event.clientX);\r\n onSeriesMouseOver?.(d);\r\n }}\r\n onMouseMove={event => {\r\n setMouseOverData(d);\r\n setEventY(event.clientY);\r\n setEventX(event.clientX);\r\n }}\r\n onMouseLeave={() => {\r\n setMouseOverData(undefined);\r\n setEventX(undefined);\r\n setEventY(undefined);\r\n onSeriesMouseOver?.(undefined);\r\n }}\r\n onClick={() => {\r\n if (onSeriesMouseClick || detailsOnClick) {\r\n if (isEqual(mouseClickData, d) && resetSelectionOnDoubleClick) {\r\n setMouseClickData(undefined);\r\n onSeriesMouseClick?.(undefined);\r\n } else {\r\n setMouseClickData(d);\r\n onSeriesMouseClick?.(d);\r\n }\r\n }\r\n }}\r\n >\r\n <motion.path\r\n d={lineShape(d.values) || ''}\r\n variants={{\r\n initial: {\r\n d: lineShape(d.values.map(_el => 0)) || '',\r\n stroke:\r\n data.filter(el => el.color).length === 0\r\n ? lineColors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : lineColors[colorDomain.indexOf(d.color)],\r\n fill: fillShape\r\n ? data.filter(el => el.color).length === 0\r\n ? lineColors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : lineColors[colorDomain.indexOf(d.color)]\r\n : 'none',\r\n strokeWidth,\r\n },\r\n whileInView: {\r\n d: lineShape(d.values) || '',\r\n transition: { duration: animate.duration },\r\n stroke:\r\n data.filter(el => el.color).length === 0\r\n ? lineColors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : lineColors[colorDomain.indexOf(d.color)],\r\n fill: fillShape\r\n ? data.filter(el => el.color).length === 0\r\n ? lineColors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : lineColors[colorDomain.indexOf(d.color)]\r\n : 'none',\r\n strokeWidth,\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n style={{\r\n fillOpacity: 0.1,\r\n }}\r\n />\r\n <g>\r\n {d.values.map((el, j) => (\r\n <g key={j}>\r\n {!checkIfNullOrUndefined(el) ? (\r\n <>\r\n {showDots ? (\r\n <motion.circle\r\n r={4}\r\n variants={{\r\n initial: {\r\n cx: 0,\r\n cy: 0,\r\n opacity: 0,\r\n fill:\r\n data.filter(el => el.color).length === 0\r\n ? lineColors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : lineColors[colorDomain.indexOf(d.color)],\r\n },\r\n whileInView: {\r\n cx: Math.cos(angleScale(j) - Math.PI / 2) * scale(el),\r\n cy: Math.sin(angleScale(j) - Math.PI / 2) * scale(el),\r\n opacity: 1,\r\n transition: { duration: animate.duration },\r\n fill:\r\n data.filter(el => el.color).length === 0\r\n ? lineColors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : lineColors[colorDomain.indexOf(d.color)],\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n />\r\n ) : null}\r\n {showValues ? (\r\n <motion.text\r\n style={{\r\n ...(styles?.graphObjectValues || {}),\r\n }}\r\n dy={\r\n Math.sin(angleScale(j) - Math.PI / 2) < 0\r\n ? 10\r\n : Math.sin(angleScale(j) - Math.PI / 2) < 0.00001\r\n ? 0\r\n : 0\r\n }\r\n className={cn(\r\n 'graph-value text-xs font-bold',\r\n classNames?.graphObjectValues,\r\n )}\r\n variants={{\r\n initial: {\r\n opacity: 0,\r\n x: Math.cos(angleScale(j) - Math.PI / 2) * (scale(el) + 6),\r\n y: Math.sin(angleScale(j) - Math.PI / 2) * (scale(el) + 6),\r\n fill: lineColors[i],\r\n textAnchor:\r\n Math.cos(angleScale(j) - Math.PI / 2) < 0\r\n ? 'end'\r\n : Math.cos(angleScale(j) - Math.PI / 2) < 0.00001\r\n ? 'middle'\r\n : 'start',\r\n },\r\n whileInView: {\r\n opacity: 1,\r\n x: Math.cos(angleScale(j) - Math.PI / 2) * (scale(el) + 6),\r\n y: Math.sin(angleScale(j) - Math.PI / 2) * (scale(el) + 6),\r\n fill: lineColors[i],\r\n textAnchor:\r\n Math.cos(angleScale(j) - Math.PI / 2) < 0\r\n ? 'end'\r\n : Math.cos(angleScale(j) - Math.PI / 2) < 0.00001\r\n ? 'middle'\r\n : 'start',\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n >\r\n {numberFormattingFunction(\r\n el,\r\n undefined,\r\n precision,\r\n undefined,\r\n undefined,\r\n locale,\r\n padZeros,\r\n )}\r\n </motion.text>\r\n ) : null}\r\n </>\r\n ) : null}\r\n </g>\r\n ))}\r\n </g>\r\n </motion.g>\r\n ))}\r\n </AnimatePresence>\r\n </g>\r\n {customLayers.filter(d => d.position === 'after').map(d => d.layer)}\r\n </g>\r\n </motion.svg>\r\n {mouseOverData && tooltip && eventX && eventY ? (\r\n <Tooltip\r\n data={mouseOverData}\r\n body={tooltip}\r\n xPos={eventX}\r\n yPos={eventY}\r\n backgroundStyle={styles?.tooltip}\r\n className={classNames?.tooltip}\r\n />\r\n ) : null}\r\n {detailsOnClick && mouseClickData !== undefined ? (\r\n <DetailsModal\r\n body={detailsOnClick}\r\n data={mouseClickData}\r\n setData={setMouseClickData}\r\n className={classNames?.modal}\r\n />\r\n ) : null}\r\n </>\r\n );\r\n}\r\n","import { useEffect, useRef, useState } from 'react';\r\n\r\nimport { Graph } from './Graph';\r\n\r\nimport {\r\n RadarChartDataType,\r\n Languages,\r\n SourcesDataType,\r\n StyleObject,\r\n ClassNameObject,\r\n CustomLayerDataType,\r\n AnimateDataType,\r\n NumberFormatOptions,\r\n} from '@/Types';\r\nimport { GraphFooter } from '@/Components/Elements/GraphFooter';\r\nimport { GraphHeader } from '@/Components/Elements/GraphHeader';\r\nimport { Colors } from '@/Components/ColorPalette';\r\nimport { EmptyState } from '@/Components/Elements/EmptyState';\r\nimport { ColorLegendWithMouseOver } from '@/Components/Elements/ColorLegendWithMouseOver';\r\nimport { uniqBy } from '@/Utils/uniqBy';\r\nimport { GraphArea, GraphContainer } from '@/Components/Elements/GraphContainer';\r\n\r\ninterface Props {\r\n // Data\r\n /** Array of data objects */\r\n data: RadarChartDataType[];\r\n\r\n // Titles, Labels, and Sources\r\n /** Title of the graph */\r\n graphTitle?: string | React.ReactNode;\r\n /** Description of the graph */\r\n graphDescription?: string | React.ReactNode;\r\n /** Footnote for the graph */\r\n footNote?: string | React.ReactNode;\r\n /** Source data for the graph */\r\n sources?: SourcesDataType[];\r\n /** Accessibility label */\r\n ariaLabel?: string;\r\n\r\n // Colors and Styling\r\n /** Color or array of colors for each line */\r\n colors?: string | string[];\r\n /** Domain of colors for the graph */\r\n colorDomain?: string[];\r\n /** Title for the color legend */\r\n colorLegendTitle?: string;\r\n /** 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 /** Radius of the radar chart */\r\n radius?: number;\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 /** Maximum value for the chart */\r\n maxValue?: number;\r\n /** Minimum value for the chart */\r\n minValue?: number;\r\n\r\n // Graph Parameters\r\n /** 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 is the shape is filled or not */\r\n fillShape?: boolean;\r\n /** No. of ticks on the x-axis */\r\n noOfTicks?: number;\r\n /** Toggle visibility of color scale. This is only applicable if the data props hae color parameter */\r\n showColorScale?: boolean;\r\n /** Toggle visibility of NA color in the color scale. This is only applicable if the data props hae color parameter and showColorScale prop is true */\r\n showNAColor?: boolean;\r\n /** Data points to highlight. Use the label value from data to highlight the data point */\r\n highlightedLines?: (string | number)[];\r\n /** Defines the opacity of the non-highlighted data */\r\n dimmedOpacity?: number;\r\n /** Toggles if the graph animates in when loaded. */\r\n animate?: boolean | AnimateDataType;\r\n /** Labels for the axes */\r\n axisLabels: (string | number)[];\r\n /** Curve type for the line */\r\n curveType?: 'linear' | 'curve';\r\n /** Reset selection on double-click. Only applicable when used in a dashboard context with filters. */\r\n resetSelectionOnDoubleClick?: boolean;\r\n /** Configuration options for controlling number formatting, localization, precision, and zero padding. */\r\n numberDisplayOptions?: Omit<NumberFormatOptions, 'suffix' | 'prefix'>;\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 /** Details displayed on the modal when user clicks of a data point. If the type is string then this uses the [handlebar](../?path=/docs/misc-handlebars-templates-and-custom-helpers--docs) template to display the data */\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n detailsOnClick?: string | ((_d: any) => React.ReactNode);\r\n /** Callback for mouse over event */\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseOver?: (_d: any) => void;\r\n /** Callback for mouse click event */\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseClick?: (_d: any) => void;\r\n\r\n // Configuration and Options\r\n /** Language setting */\r\n language?: Languages;\r\n /** Color theme */\r\n theme?: 'light' | 'dark';\r\n /** Unique ID for the graph */\r\n graphID?: string;\r\n}\r\n\r\nexport function RadarChart(props: Props) {\r\n const {\r\n graphTitle,\r\n colors,\r\n sources,\r\n graphDescription,\r\n footNote,\r\n radius,\r\n data,\r\n showColorScale = true,\r\n padding,\r\n backgroundColor = false,\r\n tooltip,\r\n onSeriesMouseOver,\r\n graphID,\r\n onSeriesMouseClick,\r\n topMargin = 75,\r\n bottomMargin = 75,\r\n leftMargin = 75,\r\n rightMargin = 75,\r\n graphDownload = false,\r\n dataDownload = false,\r\n colorDomain,\r\n language = 'en',\r\n theme = 'light',\r\n highlightedLines,\r\n width,\r\n height,\r\n minHeight = 0,\r\n strokeWidth = 2,\r\n relativeHeight,\r\n ariaLabel,\r\n colorLegendTitle,\r\n detailsOnClick,\r\n styles,\r\n classNames,\r\n showNAColor = true,\r\n axisLabels,\r\n showDots = true,\r\n showValues = false,\r\n curveType = 'curve',\r\n noOfTicks = 5,\r\n minValue,\r\n maxValue,\r\n fillShape = false,\r\n resetSelectionOnDoubleClick = true,\r\n animate = false,\r\n dimmedOpacity = 0.3,\r\n customLayers = [],\r\n numberDisplayOptions,\r\n } = props;\r\n\r\n const [graphRadius, setGraphRadius] = useState(0);\r\n const [selectedColor, setSelectedColor] = useState<string | undefined>(undefined);\r\n\r\n const graphDiv = useRef<HTMLDivElement>(null);\r\n const graphParentDiv = useRef<HTMLDivElement>(null);\r\n\r\n useEffect(() => {\r\n const resizeObserver = new ResizeObserver(entries => {\r\n setGraphRadius(\r\n (Math.min(\r\n ...[\r\n entries[0].target.clientWidth || 620,\r\n entries[0].target.clientHeight || 480,\r\n radius || Infinity,\r\n ],\r\n ) || 420) / 2,\r\n );\r\n });\r\n if (graphDiv.current) {\r\n resizeObserver.observe(graphDiv.current);\r\n }\r\n return () => resizeObserver.disconnect();\r\n }, [radius]);\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 {showColorScale && data.filter(el => el.color).length !== 0 && data.length > 0 ? (\r\n <ColorLegendWithMouseOver\r\n width={width}\r\n colorLegendTitle={colorLegendTitle}\r\n colors={(colors as string[] | undefined) || Colors[theme].categoricalColors.colors}\r\n colorDomain={colorDomain || (uniqBy(data, 'color', true) as string[])}\r\n setSelectedColor={setSelectedColor}\r\n showNAColor={showNAColor}\r\n className={classNames?.colorLegend}\r\n isCenter\r\n />\r\n ) : null}\r\n <GraphArea ref={graphDiv}>\r\n {data.length === 0 && <EmptyState />}\r\n {graphRadius && data.length > 0 ? (\r\n <Graph\r\n data={data}\r\n lineColors={\r\n data.filter(el => el.color).length === 0\r\n ? colors\r\n ? [colors as string]\r\n : [Colors.primaryColors['blue-600']]\r\n : (colors as string[] | undefined) || Colors[theme].categoricalColors.colors\r\n }\r\n radius={graphRadius}\r\n tooltip={tooltip}\r\n colorDomain={colorDomain || (uniqBy(data, 'color', true) as string[])}\r\n onSeriesMouseOver={onSeriesMouseOver}\r\n onSeriesMouseClick={onSeriesMouseClick}\r\n styles={styles}\r\n detailsOnClick={detailsOnClick}\r\n selectedColor={selectedColor}\r\n axisLabels={axisLabels}\r\n strokeWidth={strokeWidth}\r\n showValues={showValues}\r\n showDots={showDots}\r\n topMargin={topMargin}\r\n bottomMargin={bottomMargin}\r\n leftMargin={leftMargin}\r\n rightMargin={rightMargin}\r\n curveType={curveType}\r\n noOfTicks={noOfTicks}\r\n minValue={minValue}\r\n maxValue={maxValue}\r\n fillShape={fillShape}\r\n highlightedLines={highlightedLines}\r\n resetSelectionOnDoubleClick={resetSelectionOnDoubleClick}\r\n animate={\r\n animate === true\r\n ? { duration: 0.5, once: true, amount: 0.5 }\r\n : animate || { duration: 0, once: true, amount: 0 }\r\n }\r\n dimmedOpacity={dimmedOpacity}\r\n precision={numberDisplayOptions?.precision ?? 2}\r\n customLayers={customLayers}\r\n locale={numberDisplayOptions?.locale || 'en'}\r\n padZeros={numberDisplayOptions?.padZeros || false}\r\n />\r\n ) : null}\r\n </GraphArea>\r\n {sources || footNote ? (\r\n <GraphFooter\r\n styles={{ footnote: styles?.footnote, source: styles?.source }}\r\n classNames={{\r\n footnote: classNames?.footnote,\r\n source: classNames?.source,\r\n }}\r\n sources={sources}\r\n footNote={footNote}\r\n width={width}\r\n />\r\n ) : null}\r\n </GraphContainer>\r\n );\r\n}\r\n"],"names":["curveRadialLinear","curveRadial","curveLinear","Radial","curve","a","r","radial","context","lineRadial","l","c","_","lineRadial$1","line","noop","point","that","x","y","Cardinal","tension","custom","cardinal","CardinalClosed","curveCardinalClosed","LinearClosed","curveLinearClosed","Graph","props","$","_c","data","radius","lineColors","tooltip","onSeriesMouseOver","onSeriesMouseClick","colorDomain","detailsOnClick","styles","classNames","selectedColor","axisLabels","strokeWidth","showValues","showDots","rightMargin","topMargin","bottomMargin","leftMargin","curveType","noOfTicks","minValue","maxValue","resetSelectionOnDoubleClick","fillShape","highlightedLines","animate","dimmedOpacity","precision","customLayers","locale","padZeros","svgRef","useRef","t0","amount","once","isInView","useInView","t1","top","bottom","left","right","margin","radiusWithoutMargin","Math","min","mouseOverData","setMouseOverData","useState","undefined","mouseClickData","setMouseClickData","eventX","setEventX","eventY","setEventY","T0","T1","t10","t11","t12","t13","t2","t3","t4","t5","t6","t7","t8","t9","duration","graphObjectValues","xAxis","axis","gridLines","labels","angleScale","scaleLinear","domain","values","length","range","PI","t14","checkIfNullOrUndefined","max","map","_temp2","_temp4","maxVal","t15","_temp6","_temp8","minVal","scale","nice","ticksArray","ticks","lineShape","d_3","d","angle","i","motion","svg","filter","_temp9","_temp0","d_6","i_0","jsx","cos","sin","cn","textAnchor","d_7","i_1","Array","fill","numberFormattingFunction","AnimatePresence","d_8","i_2","jsxs","initial","opacity","label","color","indexOf","whileInView","transition","event","clientY","clientX","event_0","isEqual","_temp1","stroke","_temp10","Colors","gray","_temp11","_temp12","_temp13","fillOpacity","el_3","j","el","Fragment","cx","cy","_temp14","_temp15","t16","_temp16","_temp17","t17","t18","t19","Tooltip","t20","modal","DetailsModal","t21","d_10","layer","d_9","position","el_5","el_4","el_2","el_1","el_0","_el","d_5","d_4","d_1","_temp7","l_1","d_2","_temp5","l_2","_temp3","d_0","_temp","l_0","RadarChart","graphTitle","colors","sources","graphDescription","footNote","showColorScale","padding","backgroundColor","graphID","graphDownload","dataDownload","language","theme","width","height","minHeight","relativeHeight","ariaLabel","colorLegendTitle","showNAColor","numberDisplayOptions","graphRadius","setGraphRadius","setSelectedColor","graphDiv","graphParentDiv","useEffect","resizeObserver","ResizeObserver","entries","target","clientWidth","clientHeight","Infinity","current","observe","disconnect","GraphContainer","graphContainer","GraphHeader","title","description","ColorLegendWithMouseOver","categoricalColors","uniqBy","colorLegend","GraphArea","EmptyState","primaryColors","GraphFooter","footnote","source"],"mappings":"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","x_google_ignoreList":[0,1,2,3,4,5]}
@@ -1,2 +1,2 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const g=require("./index-CHPV5EwG-D4pAp7u0.cjs"),I=require("react"),ge=require("./index-CSNtgibC.cjs"),pe=require("./index-Cno4Q0YE.cjs"),Se=require("./index-DQA8q5sC.cjs"),Ut=require("./Typography-BqmyF1gP.cjs"),me=require("./numberFormattingFunction-Cn9R7CM9.cjs"),Re=require("./Tooltip-Hr46paWP.cjs"),Oe=require("./DetailsModal-jmmKRMRM.cjs"),ie=require("./proxy-CqH8m8IQ.cjs"),Ce=require("./use-in-view-dnRv_qqF.cjs"),Ve=require("./index-FXfr51ZM.cjs"),Ne=require("./GraphHeader.cjs"),De=require("./GraphFooter.cjs"),xe=require("./Colors.cjs"),Te=require("./generateRandomString-B5zBiJzS.cjs"),qe=require("./EmptyState-CFmiFPHz.cjs"),zt=require("./uniqBy-O05lp2S5.cjs"),ye=require("./GraphContainer-Cul9b74X.cjs");function ve(e,t){let o;if(t===void 0)for(const s of e)s!=null&&(o<s||o===void 0&&s>=s)&&(o=s);else{let s=-1;for(let a of e)(a=t(a,++s,e))!=null&&(o<a||o===void 0&&a>=a)&&(o=a)}return o}function Ee(e,t){let o;if(t===void 0)for(const s of e)s!=null&&(o>s||o===void 0&&s>=s)&&(o=s);else{let s=-1;for(let a of e)(a=t(a,++s,e))!=null&&(o>a||o===void 0&&a>=a)&&(o=a)}return o}function re(e,t){let o=0;if(t===void 0)for(let s of e)(s=+s)&&(o+=s);else{let s=-1;for(let a of e)(a=+t(a,++s,e))&&(o+=a)}return o}function Be(e){return e.target.depth}function Pe(e,t){return e.sourceLinks.length?e.depth:t-1}function se(e){return e.targetLinks.length?e.depth:e.sourceLinks.length?Ee(e.sourceLinks,Be)-1:0}function Zt(e){return function(){return e}}function je(e,t){return Qt(e.source,t.source)||e.index-t.index}function ke(e,t){return Qt(e.target,t.target)||e.index-t.index}function Qt(e,t){return e.y0-t.y0}function le(e){return e.value}function ze(e){return e.index}function Ie(e){return e.nodes}function Ae(e){return e.links}function be(e,t){const o=e.get(t);if(!o)throw new Error("missing: "+t);return o}function we({nodes:e}){for(const t of e){let o=t.y0,s=o;for(const a of t.sourceLinks)a.y0=o+a.width/2,o+=a.width;for(const a of t.targetLinks)a.y1=s+a.width/2,s+=a.width}}function ae(){let e=0,t=0,o=1,s=1,a=24,m=8,h,d=ze,y=Pe,k,b,$=Ie,T=Ae,v=6;function p(){const n={nodes:$.apply(null,arguments),links:T.apply(null,arguments)};return S(n),A(n),w(n),C(n),X(n),we(n),n}p.update=function(n){return we(n),n},p.nodeId=function(n){return arguments.length?(d=typeof n=="function"?n:Zt(n),p):d},p.nodeAlign=function(n){return arguments.length?(y=typeof n=="function"?n:Zt(n),p):y},p.nodeSort=function(n){return arguments.length?(k=n,p):k},p.nodeWidth=function(n){return arguments.length?(a=+n,p):a},p.nodePadding=function(n){return arguments.length?(m=h=+n,p):m},p.nodes=function(n){return arguments.length?($=typeof n=="function"?n:Zt(n),p):$},p.links=function(n){return arguments.length?(T=typeof n=="function"?n:Zt(n),p):T},p.linkSort=function(n){return arguments.length?(b=n,p):b},p.size=function(n){return arguments.length?(e=t=0,o=+n[0],s=+n[1],p):[o-e,s-t]},p.extent=function(n){return arguments.length?(e=+n[0][0],o=+n[1][0],t=+n[0][1],s=+n[1][1],p):[[e,t],[o,s]]},p.iterations=function(n){return arguments.length?(v=+n,p):v};function S({nodes:n,links:l}){for(const[u,i]of n.entries())i.index=u,i.sourceLinks=[],i.targetLinks=[];const r=new Map(n.map((u,i)=>[d(u,i,n),u]));for(const[u,i]of l.entries()){i.index=u;let{source:f,target:x}=i;typeof f!="object"&&(f=i.source=be(r,f)),typeof x!="object"&&(x=i.target=be(r,x)),f.sourceLinks.push(i),x.targetLinks.push(i)}if(b!=null)for(const{sourceLinks:u,targetLinks:i}of n)u.sort(b),i.sort(b)}function A({nodes:n}){for(const l of n)l.value=l.fixedValue===void 0?Math.max(re(l.sourceLinks,le),re(l.targetLinks,le)):l.fixedValue}function w({nodes:n}){const l=n.length;let r=new Set(n),u=new Set,i=0;for(;r.size;){for(const f of r){f.depth=i;for(const{target:x}of f.sourceLinks)u.add(x)}if(++i>l)throw new Error("circular link");r=u,u=new Set}}function C({nodes:n}){const l=n.length;let r=new Set(n),u=new Set,i=0;for(;r.size;){for(const f of r){f.height=i;for(const{source:x}of f.targetLinks)u.add(x)}if(++i>l)throw new Error("circular link");r=u,u=new Set}}function B({nodes:n}){const l=ve(n,i=>i.depth)+1,r=(o-e-a)/(l-1),u=new Array(l);for(const i of n){const f=Math.max(0,Math.min(l-1,Math.floor(y.call(null,i,l))));i.layer=f,i.x0=e+f*r,i.x1=i.x0+a,u[f]?u[f].push(i):u[f]=[i]}if(k)for(const i of u)i.sort(k);return u}function z(n){const l=Ee(n,r=>(s-t-(r.length-1)*h)/re(r,le));for(const r of n){let u=t;for(const i of r){i.y0=u,i.y1=u+i.value*l,u=i.y1+h;for(const f of i.sourceLinks)f.width=f.value*l}u=(s-u+h)/(r.length+1);for(let i=0;i<r.length;++i){const f=r[i];f.y0+=u*(i+1),f.y1+=u*(i+1)}U(r)}}function X(n){const l=B(n);h=Math.min(m,(s-t)/(ve(l,r=>r.length)-1)),z(l);for(let r=0;r<v;++r){const u=Math.pow(.99,r),i=Math.max(1-u,(r+1)/v);Y(l,u,i),H(l,u,i)}}function H(n,l,r){for(let u=1,i=n.length;u<i;++u){const f=n[u];for(const x of f){let W=0,O=0;for(const{source:D,value:Q}of x.targetLinks){let F=Q*(x.layer-D.layer);W+=N(D,x)*F,O+=F}if(!(O>0))continue;let Z=(W/O-x.y0)*l;x.y0+=Z,x.y1+=Z,kt(x)}k===void 0&&f.sort(Qt),G(f,r)}}function Y(n,l,r){for(let u=n.length,i=u-2;i>=0;--i){const f=n[i];for(const x of f){let W=0,O=0;for(const{target:D,value:Q}of x.sourceLinks){let F=Q*(D.layer-x.layer);W+=E(x,D)*F,O+=F}if(!(O>0))continue;let Z=(W/O-x.y0)*l;x.y0+=Z,x.y1+=Z,kt(x)}k===void 0&&f.sort(Qt),G(f,r)}}function G(n,l){const r=n.length>>1,u=n[r];nt(n,u.y0-h,r-1,l),V(n,u.y1+h,r+1,l),nt(n,s,n.length-1,l),V(n,t,0,l)}function V(n,l,r,u){for(;r<n.length;++r){const i=n[r],f=(l-i.y0)*u;f>1e-6&&(i.y0+=f,i.y1+=f),l=i.y1+h}}function nt(n,l,r,u){for(;r>=0;--r){const i=n[r],f=(i.y1-l)*u;f>1e-6&&(i.y0-=f,i.y1-=f),l=i.y0-h}}function kt({sourceLinks:n,targetLinks:l}){if(b===void 0){for(const{source:{sourceLinks:r}}of l)r.sort(ke);for(const{target:{targetLinks:r}}of n)r.sort(je)}}function U(n){if(b===void 0)for(const{sourceLinks:l,targetLinks:r}of n)l.sort(ke),r.sort(je)}function N(n,l){let r=n.y0-(n.sourceLinks.length-1)*h/2;for(const{target:u,width:i}of n.sourceLinks){if(u===l)break;r+=i+h}for(const{source:u,width:i}of l.targetLinks){if(u===n)break;r-=i}return r}function E(n,l){let r=l.y0-(l.targetLinks.length-1)*h/2;for(const{source:u,width:i}of l.targetLinks){if(u===n)break;r+=i+h}for(const{target:u,width:i}of n.sourceLinks){if(u===l)break;r-=i}return r}return p}var ue=Math.PI,ce=2*ue,Ot=1e-6,He=ce-Ot;function fe(){this._x0=this._y0=this._x1=this._y1=null,this._=""}function Le(){return new fe}fe.prototype=Le.prototype={constructor:fe,moveTo:function(e,t){this._+="M"+(this._x0=this._x1=+e)+","+(this._y0=this._y1=+t)},closePath:function(){this._x1!==null&&(this._x1=this._x0,this._y1=this._y0,this._+="Z")},lineTo:function(e,t){this._+="L"+(this._x1=+e)+","+(this._y1=+t)},quadraticCurveTo:function(e,t,o,s){this._+="Q"+ +e+","+ +t+","+(this._x1=+o)+","+(this._y1=+s)},bezierCurveTo:function(e,t,o,s,a,m){this._+="C"+ +e+","+ +t+","+ +o+","+ +s+","+(this._x1=+a)+","+(this._y1=+m)},arcTo:function(e,t,o,s,a){e=+e,t=+t,o=+o,s=+s,a=+a;var m=this._x1,h=this._y1,d=o-e,y=s-t,k=m-e,b=h-t,$=k*k+b*b;if(a<0)throw new Error("negative radius: "+a);if(this._x1===null)this._+="M"+(this._x1=e)+","+(this._y1=t);else if($>Ot)if(!(Math.abs(b*d-y*k)>Ot)||!a)this._+="L"+(this._x1=e)+","+(this._y1=t);else{var T=o-m,v=s-h,p=d*d+y*y,S=T*T+v*v,A=Math.sqrt(p),w=Math.sqrt($),C=a*Math.tan((ue-Math.acos((p+$-S)/(2*A*w)))/2),B=C/w,z=C/A;Math.abs(B-1)>Ot&&(this._+="L"+(e+B*k)+","+(t+B*b)),this._+="A"+a+","+a+",0,0,"+ +(b*T>k*v)+","+(this._x1=e+z*d)+","+(this._y1=t+z*y)}},arc:function(e,t,o,s,a,m){e=+e,t=+t,o=+o,m=!!m;var h=o*Math.cos(s),d=o*Math.sin(s),y=e+h,k=t+d,b=1^m,$=m?s-a:a-s;if(o<0)throw new Error("negative radius: "+o);this._x1===null?this._+="M"+y+","+k:(Math.abs(this._x1-y)>Ot||Math.abs(this._y1-k)>Ot)&&(this._+="L"+y+","+k),o&&($<0&&($=$%ce+ce),$>He?this._+="A"+o+","+o+",0,1,"+b+","+(e-h)+","+(t-d)+"A"+o+","+o+",0,1,"+b+","+(this._x1=y)+","+(this._y1=k):$>Ot&&(this._+="A"+o+","+o+",0,"+ +($>=ue)+","+b+","+(this._x1=e+o*Math.cos(a))+","+(this._y1=t+o*Math.sin(a))))},rect:function(e,t,o,s){this._+="M"+(this._x0=this._x1=+e)+","+(this._y0=this._y1=+t)+"h"+ +o+"v"+ +s+"h"+-o+"Z"},toString:function(){return this._}};function $e(e){return function(){return e}}function Ge(e){return e[0]}function We(e){return e[1]}var Fe=Array.prototype.slice;function _e(e){return e.source}function Xe(e){return e.target}function Ye(e){var t=_e,o=Xe,s=Ge,a=We,m=null;function h(){var d,y=Fe.call(arguments),k=t.apply(this,y),b=o.apply(this,y);if(m||(m=d=Le()),e(m,+s.apply(this,(y[0]=k,y)),+a.apply(this,y),+s.apply(this,(y[0]=b,y)),+a.apply(this,y)),d)return m=null,d+""||null}return h.source=function(d){return arguments.length?(t=d,h):t},h.target=function(d){return arguments.length?(o=d,h):o},h.x=function(d){return arguments.length?(s=typeof d=="function"?d:$e(+d),h):s},h.y=function(d){return arguments.length?(a=typeof d=="function"?d:$e(+d),h):a},h.context=function(d){return arguments.length?(m=d??null,h):m},h}function Ue(e,t,o,s,a){e.moveTo(t,o),e.bezierCurveTo(t=(t+s)/2,o,t,a,s,a)}function Ze(){return Ye(Ue)}function Qe(e){return[e.source.x1,e.y0]}function Je(e){return[e.target.x0,e.y1]}function Ke(){return Ze().source(Qe).target(Je)}function tn(e){const t=g.compilerRuntimeExports.c(139),{data:o,showLabels:s,leftMargin:a,rightMargin:m,truncateBy:h,width:d,height:y,topMargin:k,bottomMargin:b,tooltip:$,onSeriesMouseOver:T,suffix:v,prefix:p,showValues:S,onSeriesMouseClick:A,nodePadding:w,nodeWidth:C,id:B,highlightedSourceDataPoints:z,highlightedTargetDataPoints:X,defaultLinkOpacity:H,sourceTitle:Y,targetTitle:G,animate:V,sortNodes:nt,resetSelectionOnDoubleClick:kt,detailsOnClick:U,styles:N,classNames:E,precision:n,customLayers:l,locale:r}=e,u=I.useRef(null);let i;t[0]!==V.amount||t[1]!==V.once?(i={once:V.once,amount:V.amount},t[0]=V.amount,t[1]=V.once,t[2]=i):i=t[2];const f=Ce.useInView(u,i),[x,W]=I.useState(void 0),[O,Z]=I.useState(void 0),[D,Q]=I.useState(void 0),[F,Ct]=I.useState(void 0),[Et,R]=I.useState(void 0);let L;t[3]!==b||t[4]!==a||t[5]!==m||t[6]!==k?(L={top:k,bottom:b,left:a,right:m},t[3]=b,t[4]=a,t[5]=m,t[6]=k,t[7]=L):L=t[7];const j=L,Lt=d-j.left-j.right,lt=y-j.top-j.bottom;let bt,at,ut,J,ct,ft,K,tt,ht,dt,et,ot,it,rt,gt,pt;if(t[8]!==V.duration||t[9]!==E?.graphObjectValues||t[10]!==l||t[11]!==o||t[12]!==H||t[13]!==U||t[14]!==lt||t[15]!==Lt||t[16]!==y||t[17]!==z||t[18]!==X||t[19]!==B||t[20]!==f||t[21]!==a||t[22]!==r||t[23]!==j.left||t[24]!==j.right||t[25]!==j.top||t[26]!==O||t[27]!==w||t[28]!==C||t[29]!==A||t[30]!==T||t[31]!==n||t[32]!==p||t[33]!==kt||t[34]!==m||t[35]!==D||t[36]!==s||t[37]!==S||t[38]!==nt||t[39]!==Y||t[40]!==N?.graphObjectValues||t[41]!==v||t[42]!==G||t[43]!==h||t[44]!==d){const It=nt==="mostReadable"?ae().nodeWidth(C).nodePadding(w).size([Lt,lt]).nodeAlign(se):nt==="none"?ae().nodeWidth(C).nodePadding(w).size([Lt,lt]).nodeAlign(se).nodeSort(null).linkSort(null):ae().nodeWidth(C).nodePadding(w).size([Lt,lt]).nodeAlign(se).nodeSort(nt==="desc"?un:an),{nodes:Mt,links:Vt}=It(o),At=Ke();at=ie.motion.svg,gt=`${d}px`,pt=`${y}px`,ut=`0 0 ${d} ${y}`,t[61]===Symbol.for("react.memo_cache_sentinel")?(J={marginLeft:"auto",marginRight:"auto"},t[61]=J):J=t[61],ct="ltr",ft=u,t[62]!==j.left||t[63]!==j.top||t[64]!==Y?(K=Y?g.jsxRuntimeExports.jsx("text",{x:j.left,y:j.top-10,className:"text-base font-bold fill-primary-gray-700 dark:fill-primary-gray-100",style:{textAnchor:"start"},children:Y}):null,t[62]=j.left,t[63]=j.top,t[64]=Y,t[65]=K):K=t[65],t[66]!==j.right||t[67]!==j.top||t[68]!==G||t[69]!==d?(tt=G?g.jsxRuntimeExports.jsx("text",{x:d-j.right,y:j.top-10,className:"text-base font-bold fill-primary-gray-700 dark:fill-primary-gray-100",style:{textAnchor:"end"},children:G}):null,t[66]=j.right,t[67]=j.top,t[68]=G,t[69]=d,t[70]=tt):tt=t[70],dt=`translate(${j.left},${j.top})`,t[71]!==l?(et=l.filter(ln).map(sn),t[71]=l,t[72]=et):et=t[72];let st;t[73]!==E?.graphObjectValues||t[74]!==a||t[75]!==r||t[76]!==w||t[77]!==n||t[78]!==p||t[79]!==s||t[80]!==S||t[81]!==N?.graphObjectValues||t[82]!==v||t[83]!==h?(st=(c,_)=>g.jsxRuntimeExports.jsx("g",{onMouseEnter:()=>{Q(c)},onMouseLeave:()=>{Q(void 0)},children:g.jsxRuntimeExports.jsxs("g",{transform:`translate(${c.x0},${c.y0})`,children:[g.jsxRuntimeExports.jsx("rect",{x:0,y:0,width:(c.x1||0)-(c.x0||0),height:(c.y1||0)-(c.y0||0),style:{fill:c.color}}),s||S?g.jsxRuntimeExports.jsx("foreignObject",{y:0-w/2,x:0-a,width:a,height:(c.y1||0)-(c.y0||0)+w,children:g.jsxRuntimeExports.jsxs("div",{className:"flex flex-col gap-0.5 justify-center py-0 px-1.5",style:{height:`${(c.y1||0)-(c.y0||0)+w}px`,overflow:"visible"},children:[s?g.jsxRuntimeExports.jsx(Ut._,{marginBottom:S?"3xs":"none",size:"sm",leading:"none",className:g.mo("sankey-right-label text-right",E?.graphObjectValues),style:{hyphens:"auto",color:c.color,...N?.graphObjectValues},children:`${c.label}`.length<h?`${c.label}`:`${`${c.label}`.substring(0,h)}...`}):null,S?g.jsxRuntimeExports.jsx(Ut._,{marginBottom:"none",size:"sm",leading:"none",className:g.mo("sankey-right-value text-right font-bold",E?.graphObjectValues),style:{hyphens:"auto",color:c.color,...N?.graphObjectValues},children:me.numberFormattingFunction(c.value,void 0,n,p,v,r)}):null]})}):null]})},_),t[73]=E?.graphObjectValues,t[74]=a,t[75]=r,t[76]=w,t[77]=n,t[78]=p,t[79]=s,t[80]=S,t[81]=N?.graphObjectValues,t[82]=v,t[83]=h,t[84]=st):st=t[84],ot=Mt.filter(rn).map(st);let Nt;t[85]!==E?.graphObjectValues||t[86]!==r||t[87]!==w||t[88]!==C||t[89]!==n||t[90]!==p||t[91]!==m||t[92]!==s||t[93]!==S||t[94]!==N?.graphObjectValues||t[95]!==v||t[96]!==h?(Nt=(c,_)=>g.jsxRuntimeExports.jsx("g",{onMouseEnter:()=>{Q(c)},onMouseLeave:()=>{Q(void 0)},children:g.jsxRuntimeExports.jsxs("g",{transform:`translate(${c.x0},${c.y0})`,children:[g.jsxRuntimeExports.jsx("rect",{x:0,y:0,width:(c.x1||0)-(c.x0||0),height:(c.y1||0)-(c.y0||0),style:{fill:c.color}}),s||S?g.jsxRuntimeExports.jsx("foreignObject",{y:0-w/2,x:C,width:m-C,height:(c.y1||0)-(c.y0||0)+w,children:g.jsxRuntimeExports.jsxs("div",{className:"flex flex-col gap-0.5 justify-center py-0 px-1.5",style:{height:`${(c.y1||0)-(c.y0||0)+w}px`},children:[s?g.jsxRuntimeExports.jsx(Ut._,{marginBottom:S?"3xs":"none",size:"sm",leading:"none",className:g.mo("sankey-left-label text-left",E?.graphObjectValues),style:{hyphens:"auto",color:c.color,...N?.graphObjectValues},children:`${c.label}`.length<h?`${c.label}`:`${`${c.label}`.substring(0,h)}...`}):null,S?g.jsxRuntimeExports.jsx(Ut._,{size:"sm",leading:"none",marginBottom:"none",className:g.mo("sankey-left-value text-left font-bold",E?.graphObjectValues),style:{hyphens:"auto",color:c.color,...N?.graphObjectValues},children:me.numberFormattingFunction(c.value,void 0,n,p,v,r)}):null]})}):null]})},_),t[85]=E?.graphObjectValues,t[86]=r,t[87]=w,t[88]=C,t[89]=n,t[90]=p,t[91]=m,t[92]=s,t[93]=S,t[94]=N?.graphObjectValues,t[95]=v,t[96]=h,t[97]=Nt):Nt=t[97],it=Mt.filter(on).map(Nt);let $t;t[98]!==B?($t=(c,_)=>g.jsxRuntimeExports.jsxs("linearGradient",{id:`${B}-gradient-${_}`,x1:"0%",y1:"0%",x2:"100%",y2:"0%",gradientUnits:"userSpaceOnUse",children:[g.jsxRuntimeExports.jsx("stop",{offset:"0%",style:{stopColor:c.source.color,stopOpacity:1}}),g.jsxRuntimeExports.jsx("stop",{offset:"100%",style:{stopColor:c.target.color,stopOpacity:1}})]},_),t[98]=B,t[99]=$t):$t=t[99],rt=g.jsxRuntimeExports.jsx("defs",{children:Vt.map($t)}),bt=Ve.AnimatePresence,ht=Vt.map((c,_)=>g.jsxRuntimeExports.jsx(ie.motion.g,{className:"undp-viz-g-with-hover",onMouseEnter:St=>{W(c.data),R(St.clientY),Ct(St.clientX),T?.(c)},onMouseMove:St=>{W(c.data),R(St.clientY),Ct(St.clientX)},onClick:()=>{(A||U)&&(Se.isEqual(O,c.data)&&kt?(Z(void 0),A?.(void 0)):(Z(c.data),A?.(c.data)))},onMouseLeave:()=>{W(void 0),Ct(void 0),R(void 0),T?.(void 0)},variants:{initial:{opacity:D?c.source.name===D.name||c.target.name===D.name?.85:H:(z||X)&&(z?.indexOf(c.source.label)!==-1||X?.indexOf(c.target.label)!==-1)?.85:H},whileInView:{opacity:D?c.source.name===D.name||c.target.name===D.name?.85:H:(z||X)&&(z?.indexOf(c.source.label)!==-1||X?.indexOf(c.target.label)!==-1)?.85:H,transition:{duration:V.duration}}},initial:"initial",animate:f?"whileInView":"initial",exit:{opacity:0,transition:{duration:V.duration}},children:g.jsxRuntimeExports.jsx(ie.motion.path,{d:At(c)||"",style:{stroke:`url(#${B}-gradient-${_})`,strokeWidth:c.width,fill:"none"},exit:{opacity:0,transition:{duration:V.duration}},variants:{initial:{pathLength:0,opacity:1},whileInView:{pathLength:1,opacity:1,transition:{duration:V.duration}}},initial:"initial",animate:f?"whileInView":"initial"},`${c.source}-${c.target}`)},`${c.source}-${c.target}`)),t[8]=V.duration,t[9]=E?.graphObjectValues,t[10]=l,t[11]=o,t[12]=H,t[13]=U,t[14]=lt,t[15]=Lt,t[16]=y,t[17]=z,t[18]=X,t[19]=B,t[20]=f,t[21]=a,t[22]=r,t[23]=j.left,t[24]=j.right,t[25]=j.top,t[26]=O,t[27]=w,t[28]=C,t[29]=A,t[30]=T,t[31]=n,t[32]=p,t[33]=kt,t[34]=m,t[35]=D,t[36]=s,t[37]=S,t[38]=nt,t[39]=Y,t[40]=N?.graphObjectValues,t[41]=v,t[42]=G,t[43]=h,t[44]=d,t[45]=bt,t[46]=at,t[47]=ut,t[48]=J,t[49]=ct,t[50]=ft,t[51]=K,t[52]=tt,t[53]=ht,t[54]=dt,t[55]=et,t[56]=ot,t[57]=it,t[58]=rt,t[59]=gt,t[60]=pt}else bt=t[45],at=t[46],ut=t[47],J=t[48],ct=t[49],ft=t[50],K=t[51],tt=t[52],ht=t[53],dt=t[54],et=t[55],ot=t[56],it=t[57],rt=t[58],gt=t[59],pt=t[60];let mt;t[100]!==bt||t[101]!==ht?(mt=g.jsxRuntimeExports.jsx("g",{children:g.jsxRuntimeExports.jsx(bt,{children:ht})}),t[100]=bt,t[101]=ht,t[102]=mt):mt=t[102];let xt;t[103]!==l?(xt=l.filter(nn).map(en),t[103]=l,t[104]=xt):xt=t[104];let yt;t[105]!==mt||t[106]!==xt||t[107]!==dt||t[108]!==et||t[109]!==ot||t[110]!==it||t[111]!==rt?(yt=g.jsxRuntimeExports.jsxs("g",{transform:dt,children:[et,ot,it,rt,mt,xt]}),t[105]=mt,t[106]=xt,t[107]=dt,t[108]=et,t[109]=ot,t[110]=it,t[111]=rt,t[112]=yt):yt=t[112];let vt;t[113]!==at||t[114]!==ut||t[115]!==J||t[116]!==ct||t[117]!==ft||t[118]!==K||t[119]!==tt||t[120]!==yt||t[121]!==gt||t[122]!==pt?(vt=g.jsxRuntimeExports.jsxs(at,{width:gt,height:pt,viewBox:ut,style:J,direction:ct,ref:ft,children:[K,tt,yt]}),t[113]=at,t[114]=ut,t[115]=J,t[116]=ct,t[117]=ft,t[118]=K,t[119]=tt,t[120]=yt,t[121]=gt,t[122]=pt,t[123]=vt):vt=t[123];let M;t[124]!==E?.tooltip||t[125]!==F||t[126]!==Et||t[127]!==x||t[128]!==N?.tooltip||t[129]!==$?(M=x&&$&&F&&Et?g.jsxRuntimeExports.jsx(Re.Tooltip,{data:x,body:$,xPos:F,yPos:Et,backgroundStyle:N?.tooltip,className:E?.tooltip}):null,t[124]=E?.tooltip,t[125]=F,t[126]=Et,t[127]=x,t[128]=N?.tooltip,t[129]=$,t[130]=M):M=t[130];let jt;t[131]!==E?.modal||t[132]!==U||t[133]!==O?(jt=U&&O!==void 0?g.jsxRuntimeExports.jsx(Oe.DetailsModal,{body:U,data:O,setData:Z,className:E?.modal}):null,t[131]=E?.modal,t[132]=U,t[133]=O,t[134]=jt):jt=t[134];let wt;return t[135]!==vt||t[136]!==M||t[137]!==jt?(wt=g.jsxRuntimeExports.jsxs(g.jsxRuntimeExports.Fragment,{children:[vt,M,jt]}),t[135]=vt,t[136]=M,t[137]=jt,t[138]=wt):wt=t[138],wt}function en(e){return e.layer}function nn(e){return e.position==="after"}function on(e){return e.type==="target"}function rn(e){return e.type==="source"}function sn(e){return e.layer}function ln(e){return e.position==="before"}function an(e,t){return(e.value||0)-(t.value||0)}function un(e,t){return(t.value||0)-(e.value||0)}function cn(e){const t=g.compilerRuntimeExports.c(95),{data:o,graphTitle:s,sources:a,graphDescription:m,showLabels:h,leftMargin:d,rightMargin:y,topMargin:k,bottomMargin:b,truncateBy:$,height:T,width:v,footNote:p,padding:S,backgroundColor:A,tooltip:w,onSeriesMouseOver:C,suffix:B,prefix:z,relativeHeight:X,showValues:H,graphID:Y,onSeriesMouseClick:G,graphDownload:V,dataDownload:nt,fillContainer:kt,language:U,minHeight:N,theme:E,ariaLabel:n,sourceColors:l,targetColors:r,sourceColorDomain:u,targetColorDomain:i,nodePadding:f,nodeWidth:x,highlightedSourceDataPoints:W,highlightedTargetDataPoints:O,defaultLinkOpacity:Z,sourceTitle:D,targetTitle:Q,sortNodes:F,resetSelectionOnDoubleClick:Ct,detailsOnClick:Et,styles:R,classNames:L,animate:j,precision:Lt,customLayers:lt,locale:bt}=e,at=h===void 0?!0:h,ut=d===void 0?75:d,J=y===void 0?75:y,ct=k===void 0?30:k,ft=b===void 0?10:b,K=$===void 0?999:$,tt=A===void 0?!1:A,ht=B===void 0?"":B,dt=z===void 0?"":z,et=H===void 0?!0:H,ot=V===void 0?!1:V,it=nt===void 0?!1:nt,rt=kt===void 0?!0:kt,gt=U===void 0?"en":U,pt=N===void 0?0:N,mt=E===void 0?"light":E,xt=f===void 0?5:f,yt=x===void 0?5:x,vt=Z===void 0?.3:Z,M=F===void 0?"mostReadable":F,jt=Ct===void 0?!0:Ct,wt=j===void 0?!1:j,It=Lt===void 0?2:Lt;let Mt;t[0]!==lt?(Mt=lt===void 0?[]:lt,t[0]=lt,t[1]=Mt):Mt=t[1];const Vt=Mt,At=bt===void 0?"en":bt,[st,Nt]=I.useState(0),[$t,c]=I.useState(0),[_,St]=I.useState(void 0),Jt=I.useRef(null),he=I.useRef(null);let Ht;t[2]===Symbol.for("react.memo_cache_sentinel")?(Ht=Rt=>{St(Rt)},t[2]=Ht):Ht=t[2];const Kt=I.useEffectEvent(Ht);let Gt;t[3]!==o||t[4]!==M||t[5]!==u||t[6]!==l||t[7]!==i||t[8]!==r||t[9]!==Kt?(Gt=()=>{const Rt=zt.uniqBy(o,"source",!0).map(q=>({name:`source_${q}`,type:"source",label:`${q}`,color:typeof l=="string"||!l?l||xe.Colors.graphMainColor:l[(u||zt.uniqBy(o,"source",!0)).findIndex(P=>`${P}`==`${q}`)>l.length?l.length-1:(u||zt.uniqBy(o,"source",!0)).findIndex(P=>`${P}`==`${q}`)],totalValue:ge.sum(o.filter(P=>`${P.source}`==`${q}`).map(vn))})),Yt=M==="asc"||M==="desc"?pe.orderBy(Rt,["totalValue"],[M]):Rt,de=zt.uniqBy(o,"target",!0).map(q=>({name:`target_${q}`,type:"target",label:`${q}`,color:typeof r=="string"||!r?r||xe.Colors.graphMainColor:r[(i||zt.uniqBy(o,"target",!0)).findIndex(P=>`${P}`==`${q}`)>r.length?r.length-1:(i||zt.uniqBy(o,"target",!0)).findIndex(P=>`${P}`==`${q}`)],totalValue:ge.sum(o.filter(P=>`${P.target}`==`${q}`).map(yn))})),Me=M==="asc"||M==="desc"?pe.orderBy(de,["totalValue"],[M]):de,oe=[...Yt,...Me];Kt({nodes:oe,links:o.map(q=>({source:oe.findIndex(P=>P.name===`source_${q.source}`),target:oe.findIndex(P=>P.name===`target_${q.target}`),value:q.value,data:{...q}}))})},t[3]=o,t[4]=M,t[5]=u,t[6]=l,t[7]=i,t[8]=r,t[9]=Kt,t[10]=Gt):Gt=t[10];let Wt;t[11]!==o||t[12]!==M||t[13]!==u||t[14]!==l||t[15]!==i||t[16]!==r?(Wt=[o,M,u,l,i,r],t[11]=o,t[12]=M,t[13]=u,t[14]=l,t[15]=i,t[16]=r,t[17]=Wt):Wt=t[17],I.useEffect(Gt,Wt);let Ft,_t;t[18]===Symbol.for("react.memo_cache_sentinel")?(Ft=()=>{const Rt=new ResizeObserver(Yt=>{Nt(Yt[0].target.clientWidth||620),c(Yt[0].target.clientHeight||480)});return Jt.current&&Rt.observe(Jt.current),()=>Rt.disconnect()},_t=[],t[18]=Ft,t[19]=_t):(Ft=t[18],_t=t[19]),I.useEffect(Ft,_t);const te=L?.graphContainer,ee=R?.graphContainer,ne=rt?void 0:v;let Dt;t[20]!==L?.description||t[21]!==L?.title||t[22]!==o||t[23]!==it||t[24]!==m||t[25]!==ot||t[26]!==s||t[27]!==R?.description||t[28]!==R?.title||t[29]!==v?(Dt=s||m||ot||it?g.jsxRuntimeExports.jsx(Ne.GraphHeader,{styles:{title:R?.title,description:R?.description},classNames:{title:L?.title,description:L?.description},graphTitle:s,graphDescription:m,width:v,graphDownload:ot?he:void 0,dataDownload:it?o.map(xn).filter(mn).length>0?o.map(pn).filter(gn):o.filter(dn):null}):null,t[20]=L?.description,t[21]=L?.title,t[22]=o,t[23]=it,t[24]=m,t[25]=ot,t[26]=s,t[27]=R?.description,t[28]=R?.title,t[29]=v,t[30]=Dt):Dt=t[30];let Tt;t[31]!==o.length?(Tt=o.length===0&&g.jsxRuntimeExports.jsx(qe.EmptyState,{}),t[31]=o.length,t[32]=Tt):Tt=t[32];let qt;t[33]!==wt||t[34]!==ft||t[35]!==L||t[36]!==Vt||t[37]!==o.length||t[38]!==vt||t[39]!==Et||t[40]!==rt||t[41]!==W||t[42]!==O||t[43]!==ut||t[44]!==At||t[45]!==xt||t[46]!==yt||t[47]!==G||t[48]!==C||t[49]!==It||t[50]!==dt||t[51]!==jt||t[52]!==J||t[53]!==_||t[54]!==at||t[55]!==et||t[56]!==M||t[57]!==D||t[58]!==R||t[59]!==ht||t[60]!==$t||t[61]!==st||t[62]!==Q||t[63]!==w||t[64]!==ct||t[65]!==K||t[66]!==v?(qt=st&&$t&&_&&o.length>0?g.jsxRuntimeExports.jsx(tn,{data:_,nodePadding:xt,nodeWidth:yt,width:rt||!v||st<v?st:v,height:$t,showLabels:at,leftMargin:ut,rightMargin:J,topMargin:ct,bottomMargin:ft,truncateBy:K,tooltip:w,onSeriesMouseOver:C,showValues:et,suffix:ht,prefix:dt,onSeriesMouseClick:G,id:Te.generateRandomString(8),highlightedSourceDataPoints:W?.map(hn),highlightedTargetDataPoints:O?.map(fn),defaultLinkOpacity:vt,sourceTitle:D,targetTitle:Q,sortNodes:M,resetSelectionOnDoubleClick:jt,styles:R,classNames:L,detailsOnClick:Et,animate:wt===!0?{duration:.5,once:!0,amount:.5}:wt||{duration:0,once:!0,amount:0},precision:It,customLayers:Vt,locale:At}):null,t[33]=wt,t[34]=ft,t[35]=L,t[36]=Vt,t[37]=o.length,t[38]=vt,t[39]=Et,t[40]=rt,t[41]=W,t[42]=O,t[43]=ut,t[44]=At,t[45]=xt,t[46]=yt,t[47]=G,t[48]=C,t[49]=It,t[50]=dt,t[51]=jt,t[52]=J,t[53]=_,t[54]=at,t[55]=et,t[56]=M,t[57]=D,t[58]=R,t[59]=ht,t[60]=$t,t[61]=st,t[62]=Q,t[63]=w,t[64]=ct,t[65]=K,t[66]=v,t[67]=qt):qt=t[67];let Bt;t[68]!==Tt||t[69]!==qt?(Bt=g.jsxRuntimeExports.jsxs(ye.GraphArea,{ref:Jt,children:[Tt,qt]}),t[68]=Tt,t[69]=qt,t[70]=Bt):Bt=t[70];let Pt;t[71]!==L?.footnote||t[72]!==L?.source||t[73]!==p||t[74]!==a||t[75]!==R?.footnote||t[76]!==R?.source||t[77]!==v?(Pt=a||p?g.jsxRuntimeExports.jsx(De.GraphFooter,{styles:{footnote:R?.footnote,source:R?.source},classNames:{footnote:L?.footnote,source:L?.source},sources:a,footNote:p,width:v}):null,t[71]=L?.footnote,t[72]=L?.source,t[73]=p,t[74]=a,t[75]=R?.footnote,t[76]=R?.source,t[77]=v,t[78]=Pt):Pt=t[78];let Xt;return t[79]!==n||t[80]!==tt||t[81]!==Y||t[82]!==T||t[83]!==gt||t[84]!==pt||t[85]!==S||t[86]!==X||t[87]!==te||t[88]!==ee||t[89]!==ne||t[90]!==Dt||t[91]!==Bt||t[92]!==Pt||t[93]!==mt?(Xt=g.jsxRuntimeExports.jsxs(ye.GraphContainer,{className:te,style:ee,id:Y,ref:he,"aria-label":n,backgroundColor:tt,theme:mt,language:gt,minHeight:pt,width:ne,height:T,relativeHeight:X,padding:S,children:[Dt,Bt,Pt]}),t[79]=n,t[80]=tt,t[81]=Y,t[82]=T,t[83]=gt,t[84]=pt,t[85]=S,t[86]=X,t[87]=te,t[88]=ee,t[89]=ne,t[90]=Dt,t[91]=Bt,t[92]=Pt,t[93]=mt,t[94]=Xt):Xt=t[94],Xt}function fn(e){return`${e}`}function hn(e){return`${e}`}function dn(e){return e!==void 0}function gn(e){return e!==void 0}function pn(e){return e.data}function mn(e){return e!==void 0}function xn(e){return e.data}function yn(e){return e.value}function vn(e){return e.value}exports.SankeyChart=cn;
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const g=require("./index-CHPV5EwG-D4pAp7u0.cjs"),W=require("react"),le=require("./index-CSNtgibC.cjs"),ae=require("./index-Cno4Q0YE.cjs"),ke=require("./index-DQA8q5sC.cjs"),Ft=require("./Typography-BqmyF1gP.cjs"),ue=require("./numberFormattingFunction-u2iNHL_c.cjs"),be=require("./Tooltip-C9F3uYG0.cjs"),we=require("./DetailsModal-Du8Fr1QD.cjs"),Jt=require("./proxy-CqH8m8IQ.cjs"),$e=require("./use-in-view-dnRv_qqF.cjs"),Ee=require("./index-FXfr51ZM.cjs"),Le=require("./GraphHeader.cjs"),Me=require("./GraphFooter.cjs"),ce=require("./Colors.cjs"),Se=require("./generateRandomString-B5zBiJzS.cjs"),Re=require("./EmptyState-CFmiFPHz.cjs"),It=require("./uniqBy-O05lp2S5.cjs"),fe=require("./GraphContainer-Cul9b74X.cjs");function he(e,t){let o;if(t===void 0)for(const s of e)s!=null&&(o<s||o===void 0&&s>=s)&&(o=s);else{let s=-1;for(let l of e)(l=t(l,++s,e))!=null&&(o<l||o===void 0&&l>=l)&&(o=l)}return o}function ye(e,t){let o;if(t===void 0)for(const s of e)s!=null&&(o>s||o===void 0&&s>=s)&&(o=s);else{let s=-1;for(let l of e)(l=t(l,++s,e))!=null&&(o>l||o===void 0&&l>=l)&&(o=l)}return o}function Kt(e,t){let o=0;if(t===void 0)for(let s of e)(s=+s)&&(o+=s);else{let s=-1;for(let l of e)(l=+t(l,++s,e))&&(o+=l)}return o}function Oe(e){return e.target.depth}function Ce(e,t){return e.sourceLinks.length?e.depth:t-1}function te(e){return e.targetLinks.length?e.depth:e.sourceLinks.length?ye(e.sourceLinks,Oe)-1:0}function Zt(e){return function(){return e}}function de(e,t){return _t(e.source,t.source)||e.index-t.index}function ge(e,t){return _t(e.target,t.target)||e.index-t.index}function _t(e,t){return e.y0-t.y0}function ee(e){return e.value}function Ve(e){return e.index}function Ne(e){return e.nodes}function De(e){return e.links}function pe(e,t){const o=e.get(t);if(!o)throw new Error("missing: "+t);return o}function me({nodes:e}){for(const t of e){let o=t.y0,s=o;for(const l of t.sourceLinks)l.y0=o+l.width/2,o+=l.width;for(const l of t.targetLinks)l.y1=s+l.width/2,s+=l.width}}function ne(){let e=0,t=0,o=1,s=1,l=24,m=8,h,d=Ve,y=Ce,b,w,E=Ne,T=De,v=6;function p(){const n={nodes:E.apply(null,arguments),links:T.apply(null,arguments)};return S(n),F(n),$(n),V(n),Q(n),me(n),n}p.update=function(n){return me(n),n},p.nodeId=function(n){return arguments.length?(d=typeof n=="function"?n:Zt(n),p):d},p.nodeAlign=function(n){return arguments.length?(y=typeof n=="function"?n:Zt(n),p):y},p.nodeSort=function(n){return arguments.length?(b=n,p):b},p.nodeWidth=function(n){return arguments.length?(l=+n,p):l},p.nodePadding=function(n){return arguments.length?(m=h=+n,p):m},p.nodes=function(n){return arguments.length?(E=typeof n=="function"?n:Zt(n),p):E},p.links=function(n){return arguments.length?(T=typeof n=="function"?n:Zt(n),p):T},p.linkSort=function(n){return arguments.length?(w=n,p):w},p.size=function(n){return arguments.length?(e=t=0,o=+n[0],s=+n[1],p):[o-e,s-t]},p.extent=function(n){return arguments.length?(e=+n[0][0],o=+n[1][0],t=+n[0][1],s=+n[1][1],p):[[e,t],[o,s]]},p.iterations=function(n){return arguments.length?(v=+n,p):v};function S({nodes:n,links:a}){for(const[u,i]of n.entries())i.index=u,i.sourceLinks=[],i.targetLinks=[];const r=new Map(n.map((u,i)=>[d(u,i,n),u]));for(const[u,i]of a.entries()){i.index=u;let{source:f,target:x}=i;typeof f!="object"&&(f=i.source=pe(r,f)),typeof x!="object"&&(x=i.target=pe(r,x)),f.sourceLinks.push(i),x.targetLinks.push(i)}if(w!=null)for(const{sourceLinks:u,targetLinks:i}of n)u.sort(w),i.sort(w)}function F({nodes:n}){for(const a of n)a.value=a.fixedValue===void 0?Math.max(Kt(a.sourceLinks,ee),Kt(a.targetLinks,ee)):a.fixedValue}function $({nodes:n}){const a=n.length;let r=new Set(n),u=new Set,i=0;for(;r.size;){for(const f of r){f.depth=i;for(const{target:x}of f.sourceLinks)u.add(x)}if(++i>a)throw new Error("circular link");r=u,u=new Set}}function V({nodes:n}){const a=n.length;let r=new Set(n),u=new Set,i=0;for(;r.size;){for(const f of r){f.height=i;for(const{source:x}of f.targetLinks)u.add(x)}if(++i>a)throw new Error("circular link");r=u,u=new Set}}function q({nodes:n}){const a=he(n,i=>i.depth)+1,r=(o-e-l)/(a-1),u=new Array(a);for(const i of n){const f=Math.max(0,Math.min(a-1,Math.floor(y.call(null,i,a))));i.layer=f,i.x0=e+f*r,i.x1=i.x0+l,u[f]?u[f].push(i):u[f]=[i]}if(b)for(const i of u)i.sort(b);return u}function A(n){const a=ye(n,r=>(s-t-(r.length-1)*h)/Kt(r,ee));for(const r of n){let u=t;for(const i of r){i.y0=u,i.y1=u+i.value*a,u=i.y1+h;for(const f of i.sourceLinks)f.width=f.value*a}u=(s-u+h)/(r.length+1);for(let i=0;i<r.length;++i){const f=r[i];f.y0+=u*(i+1),f.y1+=u*(i+1)}K(r)}}function Q(n){const a=q(n);h=Math.min(m,(s-t)/(he(a,r=>r.length)-1)),A(a);for(let r=0;r<v;++r){const u=Math.pow(.99,r),i=Math.max(1-u,(r+1)/v);ot(a,u,i),H(a,u,i)}}function H(n,a,r){for(let u=1,i=n.length;u<i;++u){const f=n[u];for(const x of f){let Z=0,P=0;for(const{source:tt,value:z}of x.targetLinks){let G=z*(x.layer-tt.layer);Z+=C(tt,x)*G,P+=G}if(!(P>0))continue;let D=(Z/P-x.y0)*a;x.y0+=D,x.y1+=D,kt(x)}b===void 0&&f.sort(_t),J(f,r)}}function ot(n,a,r){for(let u=n.length,i=u-2;i>=0;--i){const f=n[i];for(const x of f){let Z=0,P=0;for(const{target:tt,value:z}of x.sourceLinks){let G=z*(tt.layer-x.layer);Z+=j(x,tt)*G,P+=G}if(!(P>0))continue;let D=(Z/P-x.y0)*a;x.y0+=D,x.y1+=D,kt(x)}b===void 0&&f.sort(_t),J(f,r)}}function J(n,a){const r=n.length>>1,u=n[r];it(n,u.y0-h,r-1,a),N(n,u.y1+h,r+1,a),it(n,s,n.length-1,a),N(n,t,0,a)}function N(n,a,r,u){for(;r<n.length;++r){const i=n[r],f=(a-i.y0)*u;f>1e-6&&(i.y0+=f,i.y1+=f),a=i.y1+h}}function it(n,a,r,u){for(;r>=0;--r){const i=n[r],f=(i.y1-a)*u;f>1e-6&&(i.y0-=f,i.y1-=f),a=i.y0-h}}function kt({sourceLinks:n,targetLinks:a}){if(w===void 0){for(const{source:{sourceLinks:r}}of a)r.sort(ge);for(const{target:{targetLinks:r}}of n)r.sort(de)}}function K(n){if(w===void 0)for(const{sourceLinks:a,targetLinks:r}of n)a.sort(ge),r.sort(de)}function C(n,a){let r=n.y0-(n.sourceLinks.length-1)*h/2;for(const{target:u,width:i}of n.sourceLinks){if(u===a)break;r+=i+h}for(const{source:u,width:i}of a.targetLinks){if(u===n)break;r-=i}return r}function j(n,a){let r=a.y0-(a.targetLinks.length-1)*h/2;for(const{source:u,width:i}of a.targetLinks){if(u===n)break;r+=i+h}for(const{target:u,width:i}of n.sourceLinks){if(u===a)break;r-=i}return r}return p}var oe=Math.PI,ie=2*oe,Ct=1e-6,Te=ie-Ct;function re(){this._x0=this._y0=this._x1=this._y1=null,this._=""}function ve(){return new re}re.prototype=ve.prototype={constructor:re,moveTo:function(e,t){this._+="M"+(this._x0=this._x1=+e)+","+(this._y0=this._y1=+t)},closePath:function(){this._x1!==null&&(this._x1=this._x0,this._y1=this._y0,this._+="Z")},lineTo:function(e,t){this._+="L"+(this._x1=+e)+","+(this._y1=+t)},quadraticCurveTo:function(e,t,o,s){this._+="Q"+ +e+","+ +t+","+(this._x1=+o)+","+(this._y1=+s)},bezierCurveTo:function(e,t,o,s,l,m){this._+="C"+ +e+","+ +t+","+ +o+","+ +s+","+(this._x1=+l)+","+(this._y1=+m)},arcTo:function(e,t,o,s,l){e=+e,t=+t,o=+o,s=+s,l=+l;var m=this._x1,h=this._y1,d=o-e,y=s-t,b=m-e,w=h-t,E=b*b+w*w;if(l<0)throw new Error("negative radius: "+l);if(this._x1===null)this._+="M"+(this._x1=e)+","+(this._y1=t);else if(E>Ct)if(!(Math.abs(w*d-y*b)>Ct)||!l)this._+="L"+(this._x1=e)+","+(this._y1=t);else{var T=o-m,v=s-h,p=d*d+y*y,S=T*T+v*v,F=Math.sqrt(p),$=Math.sqrt(E),V=l*Math.tan((oe-Math.acos((p+E-S)/(2*F*$)))/2),q=V/$,A=V/F;Math.abs(q-1)>Ct&&(this._+="L"+(e+q*b)+","+(t+q*w)),this._+="A"+l+","+l+",0,0,"+ +(w*T>b*v)+","+(this._x1=e+A*d)+","+(this._y1=t+A*y)}},arc:function(e,t,o,s,l,m){e=+e,t=+t,o=+o,m=!!m;var h=o*Math.cos(s),d=o*Math.sin(s),y=e+h,b=t+d,w=1^m,E=m?s-l:l-s;if(o<0)throw new Error("negative radius: "+o);this._x1===null?this._+="M"+y+","+b:(Math.abs(this._x1-y)>Ct||Math.abs(this._y1-b)>Ct)&&(this._+="L"+y+","+b),o&&(E<0&&(E=E%ie+ie),E>Te?this._+="A"+o+","+o+",0,1,"+w+","+(e-h)+","+(t-d)+"A"+o+","+o+",0,1,"+w+","+(this._x1=y)+","+(this._y1=b):E>Ct&&(this._+="A"+o+","+o+",0,"+ +(E>=oe)+","+w+","+(this._x1=e+o*Math.cos(l))+","+(this._y1=t+o*Math.sin(l))))},rect:function(e,t,o,s){this._+="M"+(this._x0=this._x1=+e)+","+(this._y0=this._y1=+t)+"h"+ +o+"v"+ +s+"h"+-o+"Z"},toString:function(){return this._}};function xe(e){return function(){return e}}function qe(e){return e[0]}function Be(e){return e[1]}var Pe=Array.prototype.slice;function ze(e){return e.source}function Ie(e){return e.target}function Ae(e){var t=ze,o=Ie,s=qe,l=Be,m=null;function h(){var d,y=Pe.call(arguments),b=t.apply(this,y),w=o.apply(this,y);if(m||(m=d=ve()),e(m,+s.apply(this,(y[0]=b,y)),+l.apply(this,y),+s.apply(this,(y[0]=w,y)),+l.apply(this,y)),d)return m=null,d+""||null}return h.source=function(d){return arguments.length?(t=d,h):t},h.target=function(d){return arguments.length?(o=d,h):o},h.x=function(d){return arguments.length?(s=typeof d=="function"?d:xe(+d),h):s},h.y=function(d){return arguments.length?(l=typeof d=="function"?d:xe(+d),h):l},h.context=function(d){return arguments.length?(m=d??null,h):m},h}function He(e,t,o,s,l){e.moveTo(t,o),e.bezierCurveTo(t=(t+s)/2,o,t,l,s,l)}function Ge(){return Ae(He)}function We(e){return[e.source.x1,e.y0]}function Fe(e){return[e.target.x0,e.y1]}function Ze(){return Ge().source(We).target(Fe)}function _e(e){const t=g.compilerRuntimeExports.c(142),{data:o,showLabels:s,leftMargin:l,rightMargin:m,truncateBy:h,width:d,height:y,topMargin:b,bottomMargin:w,tooltip:E,onSeriesMouseOver:T,suffix:v,prefix:p,showValues:S,onSeriesMouseClick:F,nodePadding:$,nodeWidth:V,id:q,highlightedSourceDataPoints:A,highlightedTargetDataPoints:Q,defaultLinkOpacity:H,sourceTitle:ot,targetTitle:J,animate:N,sortNodes:it,resetSelectionOnDoubleClick:kt,detailsOnClick:K,styles:C,classNames:j,precision:n,customLayers:a,locale:r,padZeros:u}=e,i=W.useRef(null);let f;t[0]!==N.amount||t[1]!==N.once?(f={once:N.once,amount:N.amount},t[0]=N.amount,t[1]=N.once,t[2]=f):f=t[2];const x=$e.useInView(i,f),[Z,P]=W.useState(void 0),[D,tt]=W.useState(void 0),[z,G]=W.useState(void 0),[L,R]=W.useState(void 0),[Rt,Lt]=W.useState(void 0);let O;t[3]!==w||t[4]!==l||t[5]!==m||t[6]!==b?(O={top:b,bottom:w,left:l,right:m},t[3]=w,t[4]=l,t[5]=m,t[6]=b,t[7]=O):O=t[7];const k=O,bt=d-k.left-k.right,wt=y-k.top-k.bottom;let ut,ct,ft,et,ht,rt,_,X,dt,gt,nt,pt,mt,xt,M,yt;if(t[8]!==N.duration||t[9]!==j?.graphObjectValues||t[10]!==a||t[11]!==o||t[12]!==H||t[13]!==K||t[14]!==wt||t[15]!==bt||t[16]!==y||t[17]!==A||t[18]!==Q||t[19]!==q||t[20]!==x||t[21]!==l||t[22]!==r||t[23]!==k.left||t[24]!==k.right||t[25]!==k.top||t[26]!==D||t[27]!==$||t[28]!==V||t[29]!==F||t[30]!==T||t[31]!==u||t[32]!==n||t[33]!==p||t[34]!==kt||t[35]!==m||t[36]!==z||t[37]!==s||t[38]!==S||t[39]!==it||t[40]!==ot||t[41]!==C?.graphObjectValues||t[42]!==v||t[43]!==J||t[44]!==h||t[45]!==d){const Nt=it==="mostReadable"?ne().nodeWidth(V).nodePadding($).size([bt,wt]).nodeAlign(te):it==="none"?ne().nodeWidth(V).nodePadding($).size([bt,wt]).nodeAlign(te).nodeSort(null).linkSort(null):ne().nodeWidth(V).nodePadding($).size([bt,wt]).nodeAlign(te).nodeSort(it==="desc"?en:tn),{nodes:At,links:Dt}=Nt(o),Ht=Ze();ct=Jt.motion.svg,M=`${d}px`,yt=`${y}px`,ft=`0 0 ${d} ${y}`,t[62]===Symbol.for("react.memo_cache_sentinel")?(et={marginLeft:"auto",marginRight:"auto"},t[62]=et):et=t[62],ht="ltr",rt=i,t[63]!==k.left||t[64]!==k.top||t[65]!==ot?(_=ot?g.jsxRuntimeExports.jsx("text",{x:k.left,y:k.top-10,className:"text-base font-bold fill-primary-gray-700 dark:fill-primary-gray-100",style:{textAnchor:"start"},children:ot}):null,t[63]=k.left,t[64]=k.top,t[65]=ot,t[66]=_):_=t[66],t[67]!==k.right||t[68]!==k.top||t[69]!==J||t[70]!==d?(X=J?g.jsxRuntimeExports.jsx("text",{x:d-k.right,y:k.top-10,className:"text-base font-bold fill-primary-gray-700 dark:fill-primary-gray-100",style:{textAnchor:"end"},children:J}):null,t[67]=k.right,t[68]=k.top,t[69]=J,t[70]=d,t[71]=X):X=t[71],gt=`translate(${k.left},${k.top})`,t[72]!==a?(nt=a.filter(Ke).map(Je),t[72]=a,t[73]=nt):nt=t[73];let $t;t[74]!==j?.graphObjectValues||t[75]!==l||t[76]!==r||t[77]!==$||t[78]!==u||t[79]!==n||t[80]!==p||t[81]!==s||t[82]!==S||t[83]!==C?.graphObjectValues||t[84]!==v||t[85]!==h?($t=(c,U)=>g.jsxRuntimeExports.jsx("g",{onMouseEnter:()=>{G(c)},onMouseLeave:()=>{G(void 0)},children:g.jsxRuntimeExports.jsxs("g",{transform:`translate(${c.x0},${c.y0})`,children:[g.jsxRuntimeExports.jsx("rect",{x:0,y:0,width:(c.x1||0)-(c.x0||0),height:(c.y1||0)-(c.y0||0),style:{fill:c.color}}),s||S?g.jsxRuntimeExports.jsx("foreignObject",{y:0-$/2,x:0-l,width:l,height:(c.y1||0)-(c.y0||0)+$,children:g.jsxRuntimeExports.jsxs("div",{className:"flex flex-col gap-0.5 justify-center py-0 px-1.5",style:{height:`${(c.y1||0)-(c.y0||0)+$}px`,overflow:"visible"},children:[s?g.jsxRuntimeExports.jsx(Ft._,{marginBottom:S?"3xs":"none",size:"sm",leading:"none",className:g.mo("sankey-right-label text-right",j?.graphObjectValues),style:{hyphens:"auto",color:c.color,...C?.graphObjectValues},children:`${c.label}`.length<h?`${c.label}`:`${`${c.label}`.substring(0,h)}...`}):null,S?g.jsxRuntimeExports.jsx(Ft._,{marginBottom:"none",size:"sm",leading:"none",className:g.mo("sankey-right-value text-right font-bold",j?.graphObjectValues),style:{hyphens:"auto",color:c.color,...C?.graphObjectValues},children:ue.numberFormattingFunction(c.value,void 0,n,p,v,r,u)}):null]})}):null]})},U),t[74]=j?.graphObjectValues,t[75]=l,t[76]=r,t[77]=$,t[78]=u,t[79]=n,t[80]=p,t[81]=s,t[82]=S,t[83]=C?.graphObjectValues,t[84]=v,t[85]=h,t[86]=$t):$t=t[86],pt=At.filter(Qe).map($t);let St;t[87]!==j?.graphObjectValues||t[88]!==r||t[89]!==$||t[90]!==V||t[91]!==u||t[92]!==n||t[93]!==p||t[94]!==m||t[95]!==s||t[96]!==S||t[97]!==C?.graphObjectValues||t[98]!==v||t[99]!==h?(St=(c,U)=>g.jsxRuntimeExports.jsx("g",{onMouseEnter:()=>{G(c)},onMouseLeave:()=>{G(void 0)},children:g.jsxRuntimeExports.jsxs("g",{transform:`translate(${c.x0},${c.y0})`,children:[g.jsxRuntimeExports.jsx("rect",{x:0,y:0,width:(c.x1||0)-(c.x0||0),height:(c.y1||0)-(c.y0||0),style:{fill:c.color}}),s||S?g.jsxRuntimeExports.jsx("foreignObject",{y:0-$/2,x:V,width:m-V,height:(c.y1||0)-(c.y0||0)+$,children:g.jsxRuntimeExports.jsxs("div",{className:"flex flex-col gap-0.5 justify-center py-0 px-1.5",style:{height:`${(c.y1||0)-(c.y0||0)+$}px`},children:[s?g.jsxRuntimeExports.jsx(Ft._,{marginBottom:S?"3xs":"none",size:"sm",leading:"none",className:g.mo("sankey-left-label text-left",j?.graphObjectValues),style:{hyphens:"auto",color:c.color,...C?.graphObjectValues},children:`${c.label}`.length<h?`${c.label}`:`${`${c.label}`.substring(0,h)}...`}):null,S?g.jsxRuntimeExports.jsx(Ft._,{size:"sm",leading:"none",marginBottom:"none",className:g.mo("sankey-left-value text-left font-bold",j?.graphObjectValues),style:{hyphens:"auto",color:c.color,...C?.graphObjectValues},children:ue.numberFormattingFunction(c.value,void 0,n,p,v,r,u)}):null]})}):null]})},U),t[87]=j?.graphObjectValues,t[88]=r,t[89]=$,t[90]=V,t[91]=u,t[92]=n,t[93]=p,t[94]=m,t[95]=s,t[96]=S,t[97]=C?.graphObjectValues,t[98]=v,t[99]=h,t[100]=St):St=t[100],mt=At.filter(Ue).map(St);let Et;t[101]!==q?(Et=(c,U)=>g.jsxRuntimeExports.jsxs("linearGradient",{id:`${q}-gradient-${U}`,x1:"0%",y1:"0%",x2:"100%",y2:"0%",gradientUnits:"userSpaceOnUse",children:[g.jsxRuntimeExports.jsx("stop",{offset:"0%",style:{stopColor:c.source.color,stopOpacity:1}}),g.jsxRuntimeExports.jsx("stop",{offset:"100%",style:{stopColor:c.target.color,stopOpacity:1}})]},U),t[101]=q,t[102]=Et):Et=t[102],xt=g.jsxRuntimeExports.jsx("defs",{children:Dt.map(Et)}),ut=Ee.AnimatePresence,dt=Dt.map((c,U)=>g.jsxRuntimeExports.jsx(Jt.motion.g,{className:"undp-viz-g-with-hover",onMouseEnter:jt=>{P(c.data),Lt(jt.clientY),R(jt.clientX),T?.(c)},onMouseMove:jt=>{P(c.data),Lt(jt.clientY),R(jt.clientX)},onClick:()=>{(F||K)&&(ke.isEqual(D,c.data)&&kt?(tt(void 0),F?.(void 0)):(tt(c.data),F?.(c.data)))},onMouseLeave:()=>{P(void 0),R(void 0),Lt(void 0),T?.(void 0)},variants:{initial:{opacity:z?c.source.name===z.name||c.target.name===z.name?.85:H:(A||Q)&&(A?.indexOf(c.source.label)!==-1||Q?.indexOf(c.target.label)!==-1)?.85:H},whileInView:{opacity:z?c.source.name===z.name||c.target.name===z.name?.85:H:(A||Q)&&(A?.indexOf(c.source.label)!==-1||Q?.indexOf(c.target.label)!==-1)?.85:H,transition:{duration:N.duration}}},initial:"initial",animate:x?"whileInView":"initial",exit:{opacity:0,transition:{duration:N.duration}},children:g.jsxRuntimeExports.jsx(Jt.motion.path,{d:Ht(c)||"",style:{stroke:`url(#${q}-gradient-${U})`,strokeWidth:c.width,fill:"none"},exit:{opacity:0,transition:{duration:N.duration}},variants:{initial:{pathLength:0,opacity:1},whileInView:{pathLength:1,opacity:1,transition:{duration:N.duration}}},initial:"initial",animate:x?"whileInView":"initial"},`${c.source}-${c.target}`)},`${c.source}-${c.target}`)),t[8]=N.duration,t[9]=j?.graphObjectValues,t[10]=a,t[11]=o,t[12]=H,t[13]=K,t[14]=wt,t[15]=bt,t[16]=y,t[17]=A,t[18]=Q,t[19]=q,t[20]=x,t[21]=l,t[22]=r,t[23]=k.left,t[24]=k.right,t[25]=k.top,t[26]=D,t[27]=$,t[28]=V,t[29]=F,t[30]=T,t[31]=u,t[32]=n,t[33]=p,t[34]=kt,t[35]=m,t[36]=z,t[37]=s,t[38]=S,t[39]=it,t[40]=ot,t[41]=C?.graphObjectValues,t[42]=v,t[43]=J,t[44]=h,t[45]=d,t[46]=ut,t[47]=ct,t[48]=ft,t[49]=et,t[50]=ht,t[51]=rt,t[52]=_,t[53]=X,t[54]=dt,t[55]=gt,t[56]=nt,t[57]=pt,t[58]=mt,t[59]=xt,t[60]=M,t[61]=yt}else ut=t[46],ct=t[47],ft=t[48],et=t[49],ht=t[50],rt=t[51],_=t[52],X=t[53],dt=t[54],gt=t[55],nt=t[56],pt=t[57],mt=t[58],xt=t[59],M=t[60],yt=t[61];let st;t[103]!==ut||t[104]!==dt?(st=g.jsxRuntimeExports.jsx("g",{children:g.jsxRuntimeExports.jsx(ut,{children:dt})}),t[103]=ut,t[104]=dt,t[105]=st):st=t[105];let lt;t[106]!==a?(lt=a.filter(Ye).map(Xe),t[106]=a,t[107]=lt):lt=t[107];let vt;t[108]!==st||t[109]!==lt||t[110]!==gt||t[111]!==nt||t[112]!==pt||t[113]!==mt||t[114]!==xt?(vt=g.jsxRuntimeExports.jsxs("g",{transform:gt,children:[nt,pt,mt,xt,st,lt]}),t[108]=st,t[109]=lt,t[110]=gt,t[111]=nt,t[112]=pt,t[113]=mt,t[114]=xt,t[115]=vt):vt=t[115];let Y;t[116]!==ct||t[117]!==ft||t[118]!==et||t[119]!==ht||t[120]!==rt||t[121]!==_||t[122]!==X||t[123]!==vt||t[124]!==M||t[125]!==yt?(Y=g.jsxRuntimeExports.jsxs(ct,{width:M,height:yt,viewBox:ft,style:et,direction:ht,ref:rt,children:[_,X,vt]}),t[116]=ct,t[117]=ft,t[118]=et,t[119]=ht,t[120]=rt,t[121]=_,t[122]=X,t[123]=vt,t[124]=M,t[125]=yt,t[126]=Y):Y=t[126];let Mt;t[127]!==j?.tooltip||t[128]!==L||t[129]!==Rt||t[130]!==Z||t[131]!==C?.tooltip||t[132]!==E?(Mt=Z&&E&&L&&Rt?g.jsxRuntimeExports.jsx(be.Tooltip,{data:Z,body:E,xPos:L,yPos:Rt,backgroundStyle:C?.tooltip,className:j?.tooltip}):null,t[127]=j?.tooltip,t[128]=L,t[129]=Rt,t[130]=Z,t[131]=C?.tooltip,t[132]=E,t[133]=Mt):Mt=t[133];let at;t[134]!==j?.modal||t[135]!==K||t[136]!==D?(at=K&&D!==void 0?g.jsxRuntimeExports.jsx(we.DetailsModal,{body:K,data:D,setData:tt,className:j?.modal}):null,t[134]=j?.modal,t[135]=K,t[136]=D,t[137]=at):at=t[137];let Vt;return t[138]!==Y||t[139]!==Mt||t[140]!==at?(Vt=g.jsxRuntimeExports.jsxs(g.jsxRuntimeExports.Fragment,{children:[Y,Mt,at]}),t[138]=Y,t[139]=Mt,t[140]=at,t[141]=Vt):Vt=t[141],Vt}function Xe(e){return e.layer}function Ye(e){return e.position==="after"}function Ue(e){return e.type==="target"}function Qe(e){return e.type==="source"}function Je(e){return e.layer}function Ke(e){return e.position==="before"}function tn(e,t){return(e.value||0)-(t.value||0)}function en(e,t){return(t.value||0)-(e.value||0)}function nn(e){const t=g.compilerRuntimeExports.c(96),{data:o,graphTitle:s,sources:l,graphDescription:m,showLabels:h,leftMargin:d,rightMargin:y,topMargin:b,bottomMargin:w,truncateBy:E,height:T,width:v,footNote:p,padding:S,backgroundColor:F,tooltip:$,onSeriesMouseOver:V,relativeHeight:q,showValues:A,graphID:Q,onSeriesMouseClick:H,graphDownload:ot,dataDownload:J,fillContainer:N,language:it,minHeight:kt,theme:K,ariaLabel:C,sourceColors:j,targetColors:n,sourceColorDomain:a,targetColorDomain:r,nodePadding:u,nodeWidth:i,highlightedSourceDataPoints:f,highlightedTargetDataPoints:x,defaultLinkOpacity:Z,sourceTitle:P,targetTitle:D,sortNodes:tt,resetSelectionOnDoubleClick:z,detailsOnClick:G,styles:L,classNames:R,animate:Rt,customLayers:Lt,numberDisplayOptions:O}=e,k=h===void 0?!0:h,bt=d===void 0?75:d,wt=y===void 0?75:y,ut=b===void 0?30:b,ct=w===void 0?10:w,ft=E===void 0?999:E,et=F===void 0?!1:F,ht=A===void 0?!0:A,rt=ot===void 0?!1:ot,_=J===void 0?!1:J,X=N===void 0?!0:N,dt=it===void 0?"en":it,gt=kt===void 0?0:kt,nt=K===void 0?"light":K,pt=u===void 0?5:u,mt=i===void 0?5:i,xt=Z===void 0?.3:Z,M=tt===void 0?"mostReadable":tt,yt=z===void 0?!0:z,st=Rt===void 0?!1:Rt;let lt;t[0]!==Lt?(lt=Lt===void 0?[]:Lt,t[0]=Lt,t[1]=lt):lt=t[1];const vt=lt,[Y,Mt]=W.useState(0),[at,Vt]=W.useState(0),[Nt,At]=W.useState(void 0),Dt=W.useRef(null),Ht=W.useRef(null);let $t;t[2]===Symbol.for("react.memo_cache_sentinel")?($t=Ot=>{At(Ot)},t[2]=$t):$t=t[2];const St=W.useEffectEvent($t);let Et;t[3]!==o||t[4]!==M||t[5]!==a||t[6]!==j||t[7]!==r||t[8]!==n||t[9]!==St?(Et=()=>{const Ot=It.uniqBy(o,"source",!0).map(B=>({name:`source_${B}`,type:"source",label:`${B}`,color:typeof j=="string"||!j?j||ce.Colors.graphMainColor:j[(a||It.uniqBy(o,"source",!0)).findIndex(I=>`${I}`==`${B}`)>j.length?j.length-1:(a||It.uniqBy(o,"source",!0)).findIndex(I=>`${I}`==`${B}`)],totalValue:le.sum(o.filter(I=>`${I.source}`==`${B}`).map(hn))})),Wt=M==="asc"||M==="desc"?ae.orderBy(Ot,["totalValue"],[M]):Ot,se=It.uniqBy(o,"target",!0).map(B=>({name:`target_${B}`,type:"target",label:`${B}`,color:typeof n=="string"||!n?n||ce.Colors.graphMainColor:n[(r||It.uniqBy(o,"target",!0)).findIndex(I=>`${I}`==`${B}`)>n.length?n.length-1:(r||It.uniqBy(o,"target",!0)).findIndex(I=>`${I}`==`${B}`)],totalValue:le.sum(o.filter(I=>`${I.target}`==`${B}`).map(fn))})),je=M==="asc"||M==="desc"?ae.orderBy(se,["totalValue"],[M]):se,Qt=[...Wt,...je];St({nodes:Qt,links:o.map(B=>({source:Qt.findIndex(I=>I.name===`source_${B.source}`),target:Qt.findIndex(I=>I.name===`target_${B.target}`),value:B.value,data:{...B}}))})},t[3]=o,t[4]=M,t[5]=a,t[6]=j,t[7]=r,t[8]=n,t[9]=St,t[10]=Et):Et=t[10];let c;t[11]!==o||t[12]!==M||t[13]!==a||t[14]!==j||t[15]!==r||t[16]!==n?(c=[o,M,a,j,r,n],t[11]=o,t[12]=M,t[13]=a,t[14]=j,t[15]=r,t[16]=n,t[17]=c):c=t[17],W.useEffect(Et,c);let U,jt;t[18]===Symbol.for("react.memo_cache_sentinel")?(U=()=>{const Ot=new ResizeObserver(Wt=>{Mt(Wt[0].target.clientWidth||620),Vt(Wt[0].target.clientHeight||480)});return Dt.current&&Ot.observe(Dt.current),()=>Ot.disconnect()},jt=[],t[18]=U,t[19]=jt):(U=t[18],jt=t[19]),W.useEffect(U,jt);const Xt=R?.graphContainer,Yt=L?.graphContainer,Ut=X?void 0:v;let Tt;t[20]!==R?.description||t[21]!==R?.title||t[22]!==o||t[23]!==_||t[24]!==m||t[25]!==rt||t[26]!==s||t[27]!==L?.description||t[28]!==L?.title||t[29]!==v?(Tt=s||m||rt||_?g.jsxRuntimeExports.jsx(Le.GraphHeader,{styles:{title:L?.title,description:L?.description},classNames:{title:R?.title,description:R?.description},graphTitle:s,graphDescription:m,width:v,graphDownload:rt?Ht:void 0,dataDownload:_?o.map(cn).filter(un).length>0?o.map(an).filter(ln):o.filter(sn):null}):null,t[20]=R?.description,t[21]=R?.title,t[22]=o,t[23]=_,t[24]=m,t[25]=rt,t[26]=s,t[27]=L?.description,t[28]=L?.title,t[29]=v,t[30]=Tt):Tt=t[30];let qt;t[31]!==o.length?(qt=o.length===0&&g.jsxRuntimeExports.jsx(Re.EmptyState,{}),t[31]=o.length,t[32]=qt):qt=t[32];let Bt;t[33]!==st||t[34]!==ct||t[35]!==R||t[36]!==vt||t[37]!==o.length||t[38]!==xt||t[39]!==G||t[40]!==X||t[41]!==f||t[42]!==x||t[43]!==bt||t[44]!==pt||t[45]!==mt||t[46]!==O?.locale||t[47]!==O?.padZeros||t[48]!==O?.precision||t[49]!==O?.prefix||t[50]!==O?.suffix||t[51]!==H||t[52]!==V||t[53]!==yt||t[54]!==wt||t[55]!==Nt||t[56]!==k||t[57]!==ht||t[58]!==M||t[59]!==P||t[60]!==L||t[61]!==at||t[62]!==Y||t[63]!==D||t[64]!==$||t[65]!==ut||t[66]!==ft||t[67]!==v?(Bt=Y&&at&&Nt&&o.length>0?g.jsxRuntimeExports.jsx(_e,{data:Nt,nodePadding:pt,nodeWidth:mt,width:X||!v||Y<v?Y:v,height:at,showLabels:k,leftMargin:bt,rightMargin:wt,topMargin:ut,bottomMargin:ct,truncateBy:ft,tooltip:$,onSeriesMouseOver:V,showValues:ht,onSeriesMouseClick:H,id:Se.generateRandomString(8),highlightedSourceDataPoints:f?.map(rn),highlightedTargetDataPoints:x?.map(on),defaultLinkOpacity:xt,sourceTitle:P,targetTitle:D,sortNodes:M,resetSelectionOnDoubleClick:yt,styles:L,classNames:R,detailsOnClick:G,animate:st===!0?{duration:.5,once:!0,amount:.5}:st||{duration:0,once:!0,amount:0},customLayers:vt,locale:O?.locale||"en",padZeros:O?.padZeros||!1,suffix:O?.suffix||"",prefix:O?.prefix||"",precision:O?.precision??2}):null,t[33]=st,t[34]=ct,t[35]=R,t[36]=vt,t[37]=o.length,t[38]=xt,t[39]=G,t[40]=X,t[41]=f,t[42]=x,t[43]=bt,t[44]=pt,t[45]=mt,t[46]=O?.locale,t[47]=O?.padZeros,t[48]=O?.precision,t[49]=O?.prefix,t[50]=O?.suffix,t[51]=H,t[52]=V,t[53]=yt,t[54]=wt,t[55]=Nt,t[56]=k,t[57]=ht,t[58]=M,t[59]=P,t[60]=L,t[61]=at,t[62]=Y,t[63]=D,t[64]=$,t[65]=ut,t[66]=ft,t[67]=v,t[68]=Bt):Bt=t[68];let Pt;t[69]!==qt||t[70]!==Bt?(Pt=g.jsxRuntimeExports.jsxs(fe.GraphArea,{ref:Dt,children:[qt,Bt]}),t[69]=qt,t[70]=Bt,t[71]=Pt):Pt=t[71];let zt;t[72]!==R?.footnote||t[73]!==R?.source||t[74]!==p||t[75]!==l||t[76]!==L?.footnote||t[77]!==L?.source||t[78]!==v?(zt=l||p?g.jsxRuntimeExports.jsx(Me.GraphFooter,{styles:{footnote:L?.footnote,source:L?.source},classNames:{footnote:R?.footnote,source:R?.source},sources:l,footNote:p,width:v}):null,t[72]=R?.footnote,t[73]=R?.source,t[74]=p,t[75]=l,t[76]=L?.footnote,t[77]=L?.source,t[78]=v,t[79]=zt):zt=t[79];let Gt;return t[80]!==C||t[81]!==et||t[82]!==Q||t[83]!==T||t[84]!==dt||t[85]!==gt||t[86]!==S||t[87]!==q||t[88]!==Xt||t[89]!==Yt||t[90]!==Ut||t[91]!==Tt||t[92]!==Pt||t[93]!==zt||t[94]!==nt?(Gt=g.jsxRuntimeExports.jsxs(fe.GraphContainer,{className:Xt,style:Yt,id:Q,ref:Ht,"aria-label":C,backgroundColor:et,theme:nt,language:dt,minHeight:gt,width:Ut,height:T,relativeHeight:q,padding:S,children:[Tt,Pt,zt]}),t[80]=C,t[81]=et,t[82]=Q,t[83]=T,t[84]=dt,t[85]=gt,t[86]=S,t[87]=q,t[88]=Xt,t[89]=Yt,t[90]=Ut,t[91]=Tt,t[92]=Pt,t[93]=zt,t[94]=nt,t[95]=Gt):Gt=t[95],Gt}function on(e){return`${e}`}function rn(e){return`${e}`}function sn(e){return e!==void 0}function ln(e){return e!==void 0}function an(e){return e.data}function un(e){return e!==void 0}function cn(e){return e.data}function fn(e){return e.value}function hn(e){return e.value}exports.SankeyChart=nn;
2
2
  //# sourceMappingURL=SankeyChart.cjs.map