@undp/data-viz 1.5.9 → 2.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (670) hide show
  1. package/dist/AreaChart.cjs +1 -1
  2. package/dist/AreaChart.cjs.map +1 -1
  3. package/dist/AreaChart.d.ts +1 -0
  4. package/dist/AreaChart.js +420 -520
  5. package/dist/AreaChart.js.map +1 -1
  6. package/dist/Axis-CRyfcLjc.js +32 -0
  7. package/dist/Axis-CRyfcLjc.js.map +1 -0
  8. package/dist/Axis-DxRV2yMi.cjs +2 -0
  9. package/dist/Axis-DxRV2yMi.cjs.map +1 -0
  10. package/dist/AxisTitle-jeI7am8o.js +29 -0
  11. package/dist/AxisTitle-jeI7am8o.js.map +1 -0
  12. package/dist/AxisTitle-sS5bLLR7.cjs +2 -0
  13. package/dist/AxisTitle-sS5bLLR7.cjs.map +1 -0
  14. package/dist/BarGraph.cjs +1 -1
  15. package/dist/BarGraph.cjs.map +1 -1
  16. package/dist/BarGraph.d.ts +1 -0
  17. package/dist/BarGraph.js +2188 -4045
  18. package/dist/BarGraph.js.map +1 -1
  19. package/dist/BasicStatCard.cjs +1 -1
  20. package/dist/BasicStatCard.cjs.map +1 -1
  21. package/dist/BasicStatCard.d.ts +1 -0
  22. package/dist/BasicStatCard.js +120 -186
  23. package/dist/BasicStatCard.js.map +1 -1
  24. package/dist/BeeSwarmChart.cjs +1 -1
  25. package/dist/BeeSwarmChart.cjs.map +1 -1
  26. package/dist/BeeSwarmChart.d.ts +5 -0
  27. package/dist/BeeSwarmChart.js +500 -1018
  28. package/dist/BeeSwarmChart.js.map +1 -1
  29. package/dist/BiVariateChoroplethMap.cjs +1 -1
  30. package/dist/BiVariateChoroplethMap.cjs.map +1 -1
  31. package/dist/BiVariateChoroplethMap.d.ts +1 -0
  32. package/dist/BiVariateChoroplethMap.js +458 -699
  33. package/dist/BiVariateChoroplethMap.js.map +1 -1
  34. package/dist/BulletChart.cjs +1 -1
  35. package/dist/BulletChart.cjs.map +1 -1
  36. package/dist/BulletChart.d.ts +1 -0
  37. package/dist/BulletChart.js +863 -1414
  38. package/dist/BulletChart.js.map +1 -1
  39. package/dist/ButterflyChart.cjs +1 -1
  40. package/dist/ButterflyChart.cjs.map +1 -1
  41. package/dist/ButterflyChart.d.ts +1 -0
  42. package/dist/ButterflyChart.js +474 -684
  43. package/dist/ButterflyChart.js.map +1 -1
  44. package/dist/ChoroplethMap.cjs +1 -1
  45. package/dist/ChoroplethMap.cjs.map +1 -1
  46. package/dist/ChoroplethMap.d.ts +1 -0
  47. package/dist/ChoroplethMap.js +466 -720
  48. package/dist/ChoroplethMap.js.map +1 -1
  49. package/dist/CirclePackingGraph.cjs +1 -1
  50. package/dist/CirclePackingGraph.d.ts +1 -0
  51. package/dist/CirclePackingGraph.js +5 -4
  52. package/dist/CirclePackingGraph.js.map +1 -1
  53. package/dist/ColorLegend.cjs +1 -1
  54. package/dist/ColorLegend.cjs.map +1 -1
  55. package/dist/ColorLegend.js +57 -44
  56. package/dist/ColorLegend.js.map +1 -1
  57. package/dist/ColorLegendWithMouseOver.cjs +1 -1
  58. package/dist/ColorLegendWithMouseOver.cjs.map +1 -1
  59. package/dist/ColorLegendWithMouseOver.js +60 -65
  60. package/dist/ColorLegendWithMouseOver.js.map +1 -1
  61. package/dist/Colors.cjs.map +1 -1
  62. package/dist/Colors.js +44 -430
  63. package/dist/Colors.js.map +1 -1
  64. package/dist/CopyTextButton.cjs +3 -3
  65. package/dist/CopyTextButton.cjs.map +1 -1
  66. package/dist/CopyTextButton.js +537 -455
  67. package/dist/CopyTextButton.js.map +1 -1
  68. package/dist/CsvDownloadButton.cjs +7 -7
  69. package/dist/CsvDownloadButton.cjs.map +1 -1
  70. package/dist/CsvDownloadButton.js +442 -447
  71. package/dist/CsvDownloadButton.js.map +1 -1
  72. package/dist/DataCards.cjs +5 -5
  73. package/dist/DataCards.cjs.map +1 -1
  74. package/dist/DataCards.d.ts +1 -0
  75. package/dist/DataCards.js +488 -581
  76. package/dist/DataCards.js.map +1 -1
  77. package/dist/DataTable.cjs +1 -1
  78. package/dist/DataTable.cjs.map +1 -1
  79. package/dist/DataTable.d.ts +1 -0
  80. package/dist/DataTable.js +183 -326
  81. package/dist/DataTable.js.map +1 -1
  82. package/dist/DifferenceLineChart.cjs +1 -1
  83. package/dist/DifferenceLineChart.cjs.map +1 -1
  84. package/dist/DifferenceLineChart.d.ts +1 -0
  85. package/dist/DifferenceLineChart.js +729 -794
  86. package/dist/DifferenceLineChart.js.map +1 -1
  87. package/dist/DonutChart.cjs +1 -1
  88. package/dist/DonutChart.cjs.map +1 -1
  89. package/dist/DonutChart.d.ts +1 -4
  90. package/dist/DonutChart.js +260 -444
  91. package/dist/DonutChart.js.map +1 -1
  92. package/dist/DotDensityMap.cjs +1 -1
  93. package/dist/DotDensityMap.cjs.map +1 -1
  94. package/dist/DotDensityMap.d.ts +1 -0
  95. package/dist/DotDensityMap.js +387 -574
  96. package/dist/DotDensityMap.js.map +1 -1
  97. package/dist/{DropdownSelect-6kjXM6oW.js → DropdownSelect-BbdPQa2k.js} +1401 -1374
  98. package/dist/DropdownSelect-BbdPQa2k.js.map +1 -0
  99. package/dist/DropdownSelect-Doz3mCrM.cjs +29 -0
  100. package/dist/DropdownSelect-Doz3mCrM.cjs.map +1 -0
  101. package/dist/DualAxisLineChart.cjs +1 -1
  102. package/dist/DualAxisLineChart.cjs.map +1 -1
  103. package/dist/DualAxisLineChart.d.ts +1 -0
  104. package/dist/DualAxisLineChart.js +617 -712
  105. package/dist/DualAxisLineChart.js.map +1 -1
  106. package/dist/DumbbellChart.cjs +1 -1
  107. package/dist/DumbbellChart.cjs.map +1 -1
  108. package/dist/DumbbellChart.d.ts +1 -0
  109. package/dist/DumbbellChart.js +789 -1499
  110. package/dist/DumbbellChart.js.map +1 -1
  111. package/dist/EmptyState-BZo1BbAn.js +15 -0
  112. package/dist/{EmptyState-36lXXyui.js.map → EmptyState-BZo1BbAn.js.map} +1 -1
  113. package/dist/EmptyState-sAEZ_5rU.cjs +2 -0
  114. package/dist/{EmptyState-B8IpKGcL.cjs.map → EmptyState-sAEZ_5rU.cjs.map} +1 -1
  115. package/dist/ExcelDownloadButton.cjs +1 -1
  116. package/dist/ExcelDownloadButton.cjs.map +1 -1
  117. package/dist/ExcelDownloadButton.js +20 -24
  118. package/dist/ExcelDownloadButton.js.map +1 -1
  119. package/dist/FootNote.cjs +1 -1
  120. package/dist/FootNote.cjs.map +1 -1
  121. package/dist/FootNote.js +26 -17
  122. package/dist/FootNote.js.map +1 -1
  123. package/dist/GeoHubCompareMaps.cjs +1 -1
  124. package/dist/GeoHubCompareMaps.cjs.map +1 -1
  125. package/dist/GeoHubCompareMaps.d.ts +1 -0
  126. package/dist/GeoHubCompareMaps.js +265 -340
  127. package/dist/GeoHubCompareMaps.js.map +1 -1
  128. package/dist/GeoHubMap.cjs +1 -1
  129. package/dist/GeoHubMap.cjs.map +1 -1
  130. package/dist/GeoHubMap.d.ts +1 -0
  131. package/dist/GeoHubMap.js +214 -379
  132. package/dist/GeoHubMap.js.map +1 -1
  133. package/dist/GeoHubMapWithLayerSelection.cjs +1 -1
  134. package/dist/GeoHubMapWithLayerSelection.cjs.map +1 -1
  135. package/dist/GeoHubMapWithLayerSelection.d.ts +1 -0
  136. package/dist/GeoHubMapWithLayerSelection.js +192 -278
  137. package/dist/GeoHubMapWithLayerSelection.js.map +1 -1
  138. package/dist/GraphContainer-CRqzdKu2.js +78 -0
  139. package/dist/GraphContainer-CRqzdKu2.js.map +1 -0
  140. package/dist/GraphContainer-d8A46BK2.cjs +2 -0
  141. package/dist/GraphContainer-d8A46BK2.cjs.map +1 -0
  142. package/dist/GraphDescription.cjs +1 -1
  143. package/dist/GraphDescription.cjs.map +1 -1
  144. package/dist/GraphDescription.js +23 -17
  145. package/dist/GraphDescription.js.map +1 -1
  146. package/dist/GraphEl-BkyLYXG5.cjs +2 -0
  147. package/dist/GraphEl-BkyLYXG5.cjs.map +1 -0
  148. package/dist/{GraphEl-2IiUDxjR.js → GraphEl-DzRon4cb.js} +181 -202
  149. package/dist/GraphEl-DzRon4cb.js.map +1 -0
  150. package/dist/GraphFooter.cjs +1 -1
  151. package/dist/GraphFooter.cjs.map +1 -1
  152. package/dist/GraphFooter.js +28 -18
  153. package/dist/GraphFooter.js.map +1 -1
  154. package/dist/GraphHeader.cjs +1 -1
  155. package/dist/GraphHeader.cjs.map +1 -1
  156. package/dist/GraphHeader.d.ts +2 -1
  157. package/dist/GraphHeader.js +45 -59
  158. package/dist/GraphHeader.js.map +1 -1
  159. package/dist/GraphTitle.cjs +1 -1
  160. package/dist/GraphTitle.cjs.map +1 -1
  161. package/dist/GraphTitle.js +29 -24
  162. package/dist/GraphTitle.js.map +1 -1
  163. package/dist/GriddedGraphs.cjs +1 -1
  164. package/dist/GriddedGraphs.cjs.map +1 -1
  165. package/dist/GriddedGraphs.d.ts +1 -0
  166. package/dist/GriddedGraphs.js +216 -450
  167. package/dist/GriddedGraphs.js.map +1 -1
  168. package/dist/GriddedGraphsFromConfig.cjs +1 -1
  169. package/dist/GriddedGraphsFromConfig.cjs.map +1 -1
  170. package/dist/GriddedGraphsFromConfig.d.ts +1 -0
  171. package/dist/GriddedGraphsFromConfig.js +22 -36
  172. package/dist/GriddedGraphsFromConfig.js.map +1 -1
  173. package/dist/HeatMap.cjs +1 -1
  174. package/dist/HeatMap.cjs.map +1 -1
  175. package/dist/HeatMap.d.ts +1 -0
  176. package/dist/HeatMap.js +278 -446
  177. package/dist/HeatMap.js.map +1 -1
  178. package/dist/Histogram.cjs +1 -1
  179. package/dist/Histogram.cjs.map +1 -1
  180. package/dist/Histogram.d.ts +1 -0
  181. package/dist/Histogram.js +154 -264
  182. package/dist/Histogram.js.map +1 -1
  183. package/dist/ImageDownloadButton.cjs +1 -1
  184. package/dist/ImageDownloadButton.cjs.map +1 -1
  185. package/dist/ImageDownloadButton.d.ts +2 -1
  186. package/dist/ImageDownloadButton.js +21 -25
  187. package/dist/ImageDownloadButton.js.map +1 -1
  188. package/dist/LineChartWithConfidenceInterval.cjs +1 -1
  189. package/dist/LineChartWithConfidenceInterval.cjs.map +1 -1
  190. package/dist/LineChartWithConfidenceInterval.d.ts +1 -0
  191. package/dist/LineChartWithConfidenceInterval.js +674 -825
  192. package/dist/LineChartWithConfidenceInterval.js.map +1 -1
  193. package/dist/LinearColorLegend.cjs +1 -1
  194. package/dist/LinearColorLegend.cjs.map +1 -1
  195. package/dist/LinearColorLegend.js +49 -30
  196. package/dist/LinearColorLegend.js.map +1 -1
  197. package/dist/Modal-DGcuAHyK.js +1047 -0
  198. package/dist/Modal-DGcuAHyK.js.map +1 -0
  199. package/dist/Modal-JW_IExO3.cjs +46 -0
  200. package/dist/Modal-JW_IExO3.cjs.map +1 -0
  201. package/dist/MultiGraphDashboard.cjs +1 -1
  202. package/dist/MultiGraphDashboard.cjs.map +1 -1
  203. package/dist/MultiGraphDashboard.d.ts +1 -0
  204. package/dist/MultiGraphDashboard.js +122 -290
  205. package/dist/MultiGraphDashboard.js.map +1 -1
  206. package/dist/MultiGraphDashboardFromConfig.cjs +1 -1
  207. package/dist/MultiGraphDashboardFromConfig.cjs.map +1 -1
  208. package/dist/MultiGraphDashboardFromConfig.d.ts +1 -0
  209. package/dist/MultiGraphDashboardFromConfig.js +22 -31
  210. package/dist/MultiGraphDashboardFromConfig.js.map +1 -1
  211. package/dist/MultiGraphDashboardWideToLongFormat.cjs +1 -1
  212. package/dist/MultiGraphDashboardWideToLongFormat.cjs.map +1 -1
  213. package/dist/MultiGraphDashboardWideToLongFormat.d.ts +1 -0
  214. package/dist/MultiGraphDashboardWideToLongFormat.js +137 -223
  215. package/dist/MultiGraphDashboardWideToLongFormat.js.map +1 -1
  216. package/dist/MultiGraphDashboardWideToLongFormatFromConfig.cjs +1 -1
  217. package/dist/MultiGraphDashboardWideToLongFormatFromConfig.cjs.map +1 -1
  218. package/dist/MultiGraphDashboardWideToLongFormatFromConfig.d.ts +1 -0
  219. package/dist/MultiGraphDashboardWideToLongFormatFromConfig.js +25 -27
  220. package/dist/MultiGraphDashboardWideToLongFormatFromConfig.js.map +1 -1
  221. package/dist/MultiLineAltChart.cjs +1 -1
  222. package/dist/MultiLineAltChart.cjs.map +1 -1
  223. package/dist/MultiLineAltChart.d.ts +1 -0
  224. package/dist/MultiLineAltChart.js +581 -659
  225. package/dist/MultiLineAltChart.js.map +1 -1
  226. package/dist/MultiLineChart.cjs +1 -1
  227. package/dist/MultiLineChart.cjs.map +1 -1
  228. package/dist/MultiLineChart.d.ts +1 -0
  229. package/dist/MultiLineChart.js +617 -725
  230. package/dist/MultiLineChart.js.map +1 -1
  231. package/dist/ParetoChart.cjs +1 -1
  232. package/dist/ParetoChart.cjs.map +1 -1
  233. package/dist/ParetoChart.d.ts +1 -0
  234. package/dist/ParetoChart.js +531 -635
  235. package/dist/ParetoChart.js.map +1 -1
  236. package/dist/PerformanceIntensiveMultiGraphDashboard.cjs +1 -1
  237. package/dist/PerformanceIntensiveMultiGraphDashboard.cjs.map +1 -1
  238. package/dist/PerformanceIntensiveMultiGraphDashboard.d.ts +1 -0
  239. package/dist/PerformanceIntensiveMultiGraphDashboard.js +147 -338
  240. package/dist/PerformanceIntensiveMultiGraphDashboard.js.map +1 -1
  241. package/dist/PerformanceIntensiveMultiGraphDashboardFromConfig.cjs +1 -1
  242. package/dist/PerformanceIntensiveMultiGraphDashboardFromConfig.cjs.map +1 -1
  243. package/dist/PerformanceIntensiveMultiGraphDashboardFromConfig.d.ts +1 -0
  244. package/dist/PerformanceIntensiveMultiGraphDashboardFromConfig.js +22 -31
  245. package/dist/PerformanceIntensiveMultiGraphDashboardFromConfig.js.map +1 -1
  246. package/dist/PerformanceIntensiveScrollStory.cjs +1 -1
  247. package/dist/PerformanceIntensiveScrollStory.cjs.map +1 -1
  248. package/dist/PerformanceIntensiveScrollStory.d.ts +1 -0
  249. package/dist/PerformanceIntensiveScrollStory.js +93 -114
  250. package/dist/PerformanceIntensiveScrollStory.js.map +1 -1
  251. package/dist/RadarChart.cjs +1 -1
  252. package/dist/RadarChart.cjs.map +1 -1
  253. package/dist/RadarChart.d.ts +1 -0
  254. package/dist/RadarChart.js +426 -575
  255. package/dist/RadarChart.js.map +1 -1
  256. package/dist/ReferenceLine-2XCwHXQ4.js +162 -0
  257. package/dist/ReferenceLine-2XCwHXQ4.js.map +1 -0
  258. package/dist/ReferenceLine-BH0qdf4R.cjs +2 -0
  259. package/dist/ReferenceLine-BH0qdf4R.cjs.map +1 -0
  260. package/dist/RegressionLine-BOTTNSrr.cjs +2 -0
  261. package/dist/RegressionLine-BOTTNSrr.cjs.map +1 -0
  262. package/dist/RegressionLine-DAcY2DjT.js +87 -0
  263. package/dist/RegressionLine-DAcY2DjT.js.map +1 -0
  264. package/dist/SVGDownloadButton.cjs +1 -1
  265. package/dist/SVGDownloadButton.cjs.map +1 -1
  266. package/dist/SVGDownloadButton.js +21 -25
  267. package/dist/SVGDownloadButton.js.map +1 -1
  268. package/dist/SankeyChart.cjs +1 -1
  269. package/dist/SankeyChart.cjs.map +1 -1
  270. package/dist/SankeyChart.d.ts +1 -0
  271. package/dist/SankeyChart.js +665 -854
  272. package/dist/SankeyChart.js.map +1 -1
  273. package/dist/ScatterPlot.cjs +1 -1
  274. package/dist/ScatterPlot.cjs.map +1 -1
  275. package/dist/ScatterPlot.d.ts +1 -0
  276. package/dist/ScatterPlot.js +675 -815
  277. package/dist/ScatterPlot.js.map +1 -1
  278. package/dist/ScrollStory.cjs +1 -1
  279. package/dist/ScrollStory.cjs.map +1 -1
  280. package/dist/ScrollStory.d.ts +1 -0
  281. package/dist/ScrollStory.js +85 -97
  282. package/dist/ScrollStory.js.map +1 -1
  283. package/dist/SimpleLineChart.cjs +1 -1
  284. package/dist/SimpleLineChart.cjs.map +1 -1
  285. package/dist/SimpleLineChart.d.ts +1 -0
  286. package/dist/SimpleLineChart.js +504 -613
  287. package/dist/SimpleLineChart.js.map +1 -1
  288. package/dist/SingleGraphDashboard.cjs +1 -1
  289. package/dist/SingleGraphDashboard.cjs.map +1 -1
  290. package/dist/SingleGraphDashboard.d.ts +2 -1
  291. package/dist/SingleGraphDashboard.js +279 -507
  292. package/dist/SingleGraphDashboard.js.map +1 -1
  293. package/dist/SingleGraphDashboardFromConfig.cjs +1 -1
  294. package/dist/SingleGraphDashboardFromConfig.cjs.map +1 -1
  295. package/dist/SingleGraphDashboardFromConfig.d.ts +2 -1
  296. package/dist/SingleGraphDashboardFromConfig.js +25 -31
  297. package/dist/SingleGraphDashboardFromConfig.js.map +1 -1
  298. package/dist/SingleGraphDashboardGeoHubMaps.cjs +1 -1
  299. package/dist/SingleGraphDashboardGeoHubMaps.cjs.map +1 -1
  300. package/dist/SingleGraphDashboardGeoHubMaps.d.ts +1 -0
  301. package/dist/SingleGraphDashboardGeoHubMaps.js +146 -168
  302. package/dist/SingleGraphDashboardGeoHubMaps.js.map +1 -1
  303. package/dist/SingleGraphDashboardGeoHubMapsFromConfig.cjs +1 -1
  304. package/dist/SingleGraphDashboardGeoHubMapsFromConfig.cjs.map +1 -1
  305. package/dist/SingleGraphDashboardGeoHubMapsFromConfig.d.ts +1 -0
  306. package/dist/SingleGraphDashboardGeoHubMapsFromConfig.js +25 -21
  307. package/dist/SingleGraphDashboardGeoHubMapsFromConfig.js.map +1 -1
  308. package/dist/SingleGraphDashboardThreeDGraphs.cjs +1 -1
  309. package/dist/SingleGraphDashboardThreeDGraphs.cjs.map +1 -1
  310. package/dist/SingleGraphDashboardThreeDGraphs.d.ts +1 -0
  311. package/dist/SingleGraphDashboardThreeDGraphs.js +357 -591
  312. package/dist/SingleGraphDashboardThreeDGraphs.js.map +1 -1
  313. package/dist/SingleGraphDashboardThreeDGraphsFromConfig.cjs +1 -1
  314. package/dist/SingleGraphDashboardThreeDGraphsFromConfig.cjs.map +1 -1
  315. package/dist/SingleGraphDashboardThreeDGraphsFromConfig.d.ts +1 -0
  316. package/dist/SingleGraphDashboardThreeDGraphsFromConfig.js +25 -31
  317. package/dist/SingleGraphDashboardThreeDGraphsFromConfig.js.map +1 -1
  318. package/dist/SlopeChart.cjs +1 -1
  319. package/dist/SlopeChart.cjs.map +1 -1
  320. package/dist/SlopeChart.d.ts +1 -0
  321. package/dist/SlopeChart.js +539 -573
  322. package/dist/SlopeChart.js.map +1 -1
  323. package/dist/Source-DYMJRrsq.cjs +2 -0
  324. package/dist/Source-DYMJRrsq.cjs.map +1 -0
  325. package/dist/Source-DwTHB8fn.js +78 -0
  326. package/dist/Source-DwTHB8fn.js.map +1 -0
  327. package/dist/Source.cjs +1 -1
  328. package/dist/Source.cjs.map +1 -1
  329. package/dist/Source.js +4 -38
  330. package/dist/Source.js.map +1 -1
  331. package/dist/SparkLine.cjs +1 -1
  332. package/dist/SparkLine.cjs.map +1 -1
  333. package/dist/SparkLine.d.ts +1 -0
  334. package/dist/SparkLine.js +286 -314
  335. package/dist/SparkLine.js.map +1 -1
  336. package/dist/Spinner-D7rnnwnA.js +47 -0
  337. package/dist/Spinner-D7rnnwnA.js.map +1 -0
  338. package/dist/Spinner-DRMBUsX7.cjs +2 -0
  339. package/dist/Spinner-DRMBUsX7.cjs.map +1 -0
  340. package/dist/StatCardFromData.cjs +1 -1
  341. package/dist/StatCardFromData.cjs.map +1 -1
  342. package/dist/StatCardFromData.d.ts +1 -0
  343. package/dist/StatCardFromData.js +163 -243
  344. package/dist/StatCardFromData.js.map +1 -1
  345. package/dist/StripChart.cjs +1 -1
  346. package/dist/StripChart.cjs.map +1 -1
  347. package/dist/StripChart.d.ts +1 -0
  348. package/dist/StripChart.js +665 -983
  349. package/dist/StripChart.js.map +1 -1
  350. package/dist/ThreeDGlobe.cjs +1 -1
  351. package/dist/ThreeDGlobe.cjs.map +1 -1
  352. package/dist/ThreeDGlobe.d.ts +1 -0
  353. package/dist/ThreeDGlobe.js +356 -519
  354. package/dist/ThreeDGlobe.js.map +1 -1
  355. package/dist/ThresholdColorLegendWithMouseOver.cjs +1 -1
  356. package/dist/ThresholdColorLegendWithMouseOver.cjs.map +1 -1
  357. package/dist/ThresholdColorLegendWithMouseOver.js +96 -126
  358. package/dist/ThresholdColorLegendWithMouseOver.js.map +1 -1
  359. package/dist/Tooltip-4dJo4_AF.cjs +2 -0
  360. package/dist/Tooltip-4dJo4_AF.cjs.map +1 -0
  361. package/dist/Tooltip-CwWUegPB.js +43 -0
  362. package/dist/Tooltip-CwWUegPB.js.map +1 -0
  363. package/dist/TreeMapGraph.cjs +1 -1
  364. package/dist/TreeMapGraph.cjs.map +1 -1
  365. package/dist/TreeMapGraph.d.ts +1 -0
  366. package/dist/TreeMapGraph.js +479 -617
  367. package/dist/TreeMapGraph.js.map +1 -1
  368. package/dist/Types.d.ts +1 -0
  369. package/dist/Typography-DX7PlgQU.cjs +2 -0
  370. package/dist/Typography-DX7PlgQU.cjs.map +1 -0
  371. package/dist/Typography-PxtFcnJb.js +142 -0
  372. package/dist/Typography-PxtFcnJb.js.map +1 -0
  373. package/dist/UnitChart.cjs +1 -1
  374. package/dist/UnitChart.cjs.map +1 -1
  375. package/dist/UnitChart.d.ts +1 -0
  376. package/dist/UnitChart.js +160 -212
  377. package/dist/UnitChart.js.map +1 -1
  378. package/dist/XAxesLabels-D5X8jngD.cjs +2 -0
  379. package/dist/XAxesLabels-D5X8jngD.cjs.map +1 -0
  380. package/dist/XAxesLabels-DNO0KmjL.js +73 -0
  381. package/dist/XAxesLabels-DNO0KmjL.js.map +1 -0
  382. package/dist/XTicksAndGridLines-B6CELS7q.cjs +2 -0
  383. package/dist/XTicksAndGridLines-B6CELS7q.cjs.map +1 -0
  384. package/dist/XTicksAndGridLines-CObVFSm4.js +38 -0
  385. package/dist/XTicksAndGridLines-CObVFSm4.js.map +1 -0
  386. package/dist/YAxesLabels-DcS85Beo.cjs +2 -0
  387. package/dist/YAxesLabels-DcS85Beo.cjs.map +1 -0
  388. package/dist/YAxesLabels-Dnnng49-.js +70 -0
  389. package/dist/YAxesLabels-Dnnng49-.js.map +1 -0
  390. package/dist/YTicksAndGridLines-4pxTRlRK.cjs +2 -0
  391. package/dist/YTicksAndGridLines-4pxTRlRK.cjs.map +1 -0
  392. package/dist/YTicksAndGridLines-Blepl7XF.js +38 -0
  393. package/dist/YTicksAndGridLines-Blepl7XF.js.map +1 -0
  394. package/dist/{band-BEjh2CHI.js → band-CyHaVft5.js} +3 -3
  395. package/dist/{band-BEjh2CHI.js.map → band-CyHaVft5.js.map} +1 -1
  396. package/dist/{band-CAApY4Pd.cjs → band-VYfcZeJ2.cjs} +2 -2
  397. package/dist/{band-CAApY4Pd.cjs.map → band-VYfcZeJ2.cjs.map} +1 -1
  398. package/dist/checkIfMultiple-Y9iKaV_u.js +950 -0
  399. package/dist/checkIfMultiple-Y9iKaV_u.js.map +1 -0
  400. package/dist/checkIfMultiple-wg6hJLXy.cjs +12 -0
  401. package/dist/checkIfMultiple-wg6hJLXy.cjs.map +1 -0
  402. package/dist/customArea-BUhPiPT6.js +163 -0
  403. package/dist/{customArea-x4L4xwLl.js.map → customArea-BUhPiPT6.js.map} +1 -1
  404. package/dist/customArea-CMF5g-C3.cjs +2 -0
  405. package/dist/{customArea-1G1S78s_.cjs.map → customArea-CMF5g-C3.cjs.map} +1 -1
  406. package/dist/delaunay-C1uAf38t.js.map +1 -1
  407. package/dist/delaunay-rcy0HhZi.cjs.map +1 -1
  408. package/dist/{ensureCompleteData-DlmibgaI.js → ensureCompleteData-DNKEGRiP.js} +12 -32
  409. package/dist/{ensureCompleteData-DlmibgaI.js.map → ensureCompleteData-DNKEGRiP.js.map} +1 -1
  410. package/dist/{ensureCompleteData-DkQYPeDa.cjs → ensureCompleteData-I6nYmT8E.cjs} +2 -2
  411. package/dist/{ensureCompleteData-DkQYPeDa.cjs.map → ensureCompleteData-I6nYmT8E.cjs.map} +1 -1
  412. package/dist/{excelDownload-BOA-lskf.js → excelDownload-BEC1AyQW.js} +12 -2
  413. package/dist/{excelDownload-BOA-lskf.js.map → excelDownload-BEC1AyQW.js.map} +1 -1
  414. package/dist/excelDownload-BQpsCa62.cjs.map +1 -1
  415. package/dist/{fetchAndParseData-sapWbnYk.js → fetchAndParseData-BpqkBPQL.js} +15 -28
  416. package/dist/{fetchAndParseData-sapWbnYk.js.map → fetchAndParseData-BpqkBPQL.js.map} +1 -1
  417. package/dist/fetchAndParseData-l5HGMAEs.cjs +16 -0
  418. package/dist/{fetchAndParseData-Ba-_CgxS.cjs.map → fetchAndParseData-l5HGMAEs.cjs.map} +1 -1
  419. package/dist/fetchAndParseData.cjs +1 -1
  420. package/dist/fetchAndParseData.js +1 -1
  421. package/dist/{filterData-9nEcQ-Jp.js → filterData-DsAiFzKY.js} +3 -5
  422. package/dist/{filterData-9nEcQ-Jp.js.map → filterData-DsAiFzKY.js.map} +1 -1
  423. package/dist/{filterData-BoYadk0l.cjs → filterData-T5DQBE9b.cjs} +2 -2
  424. package/dist/{filterData-BoYadk0l.cjs.map → filterData-T5DQBE9b.cjs.map} +1 -1
  425. package/dist/generateRandomString-B5zBiJzS.cjs.map +1 -1
  426. package/dist/generateRandomString-za3IQGfQ.js.map +1 -1
  427. package/dist/{getCentroidCoordinates-Dfk6IqEG.js → getCentroidCoordinates-D7r34N4w.js} +2 -2
  428. package/dist/{getCentroidCoordinates-Dfk6IqEG.js.map → getCentroidCoordinates-D7r34N4w.js.map} +1 -1
  429. package/dist/{getCentroidCoordinates-DxTBqzp2.cjs → getCentroidCoordinates-Dng1HVjO.cjs} +2 -2
  430. package/dist/{getCentroidCoordinates-DxTBqzp2.cjs.map → getCentroidCoordinates-Dng1HVjO.cjs.map} +1 -1
  431. package/dist/getGraphList-BpEWn1Tk.js +227 -0
  432. package/dist/{getGraphList-DuColTJM.js.map → getGraphList-BpEWn1Tk.js.map} +1 -1
  433. package/dist/getGraphList-gf02xgT2.cjs.map +1 -1
  434. package/dist/getJenks-BbngDoBQ.js.map +1 -1
  435. package/dist/getJenks-GYmdwBqm.cjs.map +1 -1
  436. package/dist/getSchema.cjs.map +1 -1
  437. package/dist/getSchema.js +445 -231
  438. package/dist/getSchema.js.map +1 -1
  439. package/dist/getSliderMarks-BmADcPQt.cjs +6 -0
  440. package/dist/getSliderMarks-BmADcPQt.cjs.map +1 -0
  441. package/dist/getSliderMarks-HIDJ0_Cd.js +1033 -0
  442. package/dist/getSliderMarks-HIDJ0_Cd.js.map +1 -0
  443. package/dist/{getTextColorBasedOnBgColor-B6Nk2WBf.js → getTextColorBasedOnBgColor-CDY808zi.js} +11 -3
  444. package/dist/{getTextColorBasedOnBgColor-B6Nk2WBf.js.map → getTextColorBasedOnBgColor-CDY808zi.js.map} +1 -1
  445. package/dist/getTextColorBasedOnBgColor-nqY-bsM_.cjs.map +1 -1
  446. package/dist/{getUniqValue-DiCh_MOD.js → getUniqValue-BKHCm3zE.js} +2 -4
  447. package/dist/{getUniqValue-DiCh_MOD.js.map → getUniqValue-BKHCm3zE.js.map} +1 -1
  448. package/dist/getUniqValue-RViz8tTw.cjs.map +1 -1
  449. package/dist/{imageDownload-Dcci2LEy.js → imageDownload-BX6SILNZ.js} +4 -2
  450. package/dist/{imageDownload-Dcci2LEy.js.map → imageDownload-BX6SILNZ.js.map} +1 -1
  451. package/dist/imageDownload-CgDcm1Sj.cjs.map +1 -1
  452. package/dist/{index-DvVprvy6.js → index-BZQYSqar.js} +7 -7
  453. package/dist/{index-DvVprvy6.js.map → index-BZQYSqar.js.map} +1 -1
  454. package/dist/index-B_sAFsEV.cjs +2 -0
  455. package/dist/{index-BHe3wsWF.cjs.map → index-B_sAFsEV.cjs.map} +1 -1
  456. package/dist/index-BqfRwk1n.js +146 -0
  457. package/dist/index-BqfRwk1n.js.map +1 -0
  458. package/dist/{index-V_JXij1_.js → index-BuwmuDFJ.js} +3 -3
  459. package/dist/{index-V_JXij1_.js.map → index-BuwmuDFJ.js.map} +1 -1
  460. package/dist/index-CHPV5EwG-CTPQjnHt.cjs +84 -0
  461. package/dist/index-CHPV5EwG-CTPQjnHt.cjs.map +1 -0
  462. package/dist/{index-CHPV5EwG-DBWUSD9b.js → index-CHPV5EwG-Curnpaqc.js} +724 -625
  463. package/dist/index-CHPV5EwG-Curnpaqc.js.map +1 -0
  464. package/dist/index-Cno4Q0YE.cjs +2 -0
  465. package/dist/{index-CQ3e6Ewi.cjs.map → index-Cno4Q0YE.cjs.map} +1 -1
  466. package/dist/{index-Cw8sCyo_-BuI_jX5Z.js → index-Cw8sCyo_-B2hEKjzG.js} +16 -16
  467. package/dist/{index-Cw8sCyo_-BuI_jX5Z.js.map → index-Cw8sCyo_-B2hEKjzG.js.map} +1 -1
  468. package/dist/{index-Cw8sCyo_-gxT8ADyn.cjs → index-Cw8sCyo_-BrHiWiRF.cjs} +2 -2
  469. package/dist/{index-Cw8sCyo_-gxT8ADyn.cjs.map → index-Cw8sCyo_-BrHiWiRF.cjs.map} +1 -1
  470. package/dist/index-CyZ1lmi_.cjs +2 -0
  471. package/dist/{index-D72cOtq7.cjs.map → index-CyZ1lmi_.cjs.map} +1 -1
  472. package/dist/index-D491FEn1.js +184 -0
  473. package/dist/index-D491FEn1.js.map +1 -0
  474. package/dist/index-DG2bgAva.cjs +10 -0
  475. package/dist/index-DG2bgAva.cjs.map +1 -0
  476. package/dist/index-DRXx7m-C.cjs +2 -0
  477. package/dist/index-DRXx7m-C.cjs.map +1 -0
  478. package/dist/index-DoY3Ga3W.cjs +2 -0
  479. package/dist/index-DoY3Ga3W.cjs.map +1 -0
  480. package/dist/index-DxXnJ8Ti.cjs +2 -0
  481. package/dist/index-DxXnJ8Ti.cjs.map +1 -0
  482. package/dist/{index-Dzc_aaI9-BKklH89r.js → index-Dzc_aaI9-Bb7gobH_.js} +2 -2
  483. package/dist/{index-Dzc_aaI9-BKklH89r.js.map → index-Dzc_aaI9-Bb7gobH_.js.map} +1 -1
  484. package/dist/{index-Dzc_aaI9-RIk2GRHD.cjs → index-Dzc_aaI9-BmkfPMyc.cjs} +2 -2
  485. package/dist/{index-Dzc_aaI9-RIk2GRHD.cjs.map → index-Dzc_aaI9-BmkfPMyc.cjs.map} +1 -1
  486. package/dist/{index-9tDEUqOZ.js → index-GEsywGxz.js} +9 -9
  487. package/dist/index-GEsywGxz.js.map +1 -0
  488. package/dist/index-SKgJALZg.js +99 -0
  489. package/dist/{index-Bw_eHBVN.js.map → index-SKgJALZg.js.map} +1 -1
  490. package/dist/index-leTnKT2q.js +329 -0
  491. package/dist/index-leTnKT2q.js.map +1 -0
  492. package/dist/index.cjs +1 -1
  493. package/dist/index.d.ts +10 -8
  494. package/dist/index.js +13 -13
  495. package/dist/{init-BhZylTFx.js → init-BJFW6EwE.js} +3 -3
  496. package/dist/{init-BhZylTFx.js.map → init-BJFW6EwE.js.map} +1 -1
  497. package/dist/{linear-BVckp9RD.cjs → linear-BwPAspcq.cjs} +2 -2
  498. package/dist/{linear-BVckp9RD.cjs.map → linear-BwPAspcq.cjs.map} +1 -1
  499. package/dist/{linear-DUdu7l2G.js → linear-BwnDd9KF.js} +3 -3
  500. package/dist/{linear-DUdu7l2G.js.map → linear-BwnDd9KF.js.map} +1 -1
  501. package/dist/numberFormattingFunction-02t-wJta.cjs.map +1 -1
  502. package/dist/numberFormattingFunction-14YCbkN2.js.map +1 -1
  503. package/dist/{ordinal-BOeNbyae.cjs → ordinal-CrsysVE-.cjs} +2 -2
  504. package/dist/ordinal-CrsysVE-.cjs.map +1 -0
  505. package/dist/{ordinal-w9Lu4Stb.js → ordinal-P77xw8aL.js} +24 -24
  506. package/dist/ordinal-P77xw8aL.js.map +1 -0
  507. package/dist/{pow-e8zx3AQJ.js → pow-DE4c7dbW.js} +3 -3
  508. package/dist/{pow-e8zx3AQJ.js.map → pow-DE4c7dbW.js.map} +1 -1
  509. package/dist/{pow-B5-jkdHU.cjs → pow-DgrUorRi.cjs} +2 -2
  510. package/dist/{pow-B5-jkdHU.cjs.map → pow-DgrUorRi.cjs.map} +1 -1
  511. package/dist/{proxy-BYIC9BuT.js → proxy-BxkFHwUw.js} +144 -134
  512. package/dist/proxy-BxkFHwUw.js.map +1 -0
  513. package/dist/proxy-BxvUI_9l.cjs +2 -0
  514. package/dist/proxy-BxvUI_9l.cjs.map +1 -0
  515. package/dist/{removeOutliers-DR48e-18.js → removeOutliers-BqW0sPqj.js} +2 -5
  516. package/dist/{removeOutliers-DR48e-18.js.map → removeOutliers-BqW0sPqj.js.map} +1 -1
  517. package/dist/removeOutliers-WELHHqiI.cjs.map +1 -1
  518. package/dist/{sort-DfK1b0F5.js → sort-BIvMlUH1.js} +5 -5
  519. package/dist/{sort-DfK1b0F5.js.map → sort-BIvMlUH1.js.map} +1 -1
  520. package/dist/{string-CRoCZCYa.cjs → string-C-kRh1bQ.cjs} +2 -2
  521. package/dist/{string-CRoCZCYa.cjs.map → string-C-kRh1bQ.cjs.map} +1 -1
  522. package/dist/{string-B8KlVSPX.js → string-C_xJ4Wg4.js} +3 -3
  523. package/dist/{string-B8KlVSPX.js.map → string-C_xJ4Wg4.js.map} +1 -1
  524. package/dist/string2HTML-CPGr_I5E.cjs +3 -0
  525. package/dist/{string2HTML-z7CwHXcx.cjs.map → string2HTML-CPGr_I5E.cjs.map} +1 -1
  526. package/dist/{string2HTML-oFCROsus.js → string2HTML-DhG75NqA.js} +15 -9
  527. package/dist/{string2HTML-oFCROsus.js.map → string2HTML-DhG75NqA.js.map} +1 -1
  528. package/dist/style.css +1 -1
  529. package/dist/{svgDownload-C2-E3yf2.js → svgDownload-BAoarWNt.js} +4 -2
  530. package/dist/{svgDownload-C2-E3yf2.js.map → svgDownload-BAoarWNt.js.map} +1 -1
  531. package/dist/svgDownload-D9zEGjTF.cjs.map +1 -1
  532. package/dist/{threshold-DFfqcDMa.js → threshold-Bgr20hik.js} +2 -2
  533. package/dist/{threshold-DFfqcDMa.js.map → threshold-Bgr20hik.js.map} +1 -1
  534. package/dist/{time-Byw_jYQ7.cjs → time-CZd5YLSP.cjs} +2 -2
  535. package/dist/{time-Byw_jYQ7.cjs.map → time-CZd5YLSP.cjs.map} +1 -1
  536. package/dist/{time-BzJP5SPC.js → time-DCCfQk3V.js} +3 -3
  537. package/dist/{time-BzJP5SPC.js.map → time-DCCfQk3V.js.map} +1 -1
  538. package/dist/transformData.cjs +1 -1
  539. package/dist/transformData.js +3 -3
  540. package/dist/transformDataForAggregation-CE3bAlHU.js +585 -0
  541. package/dist/{transformDataForAggregation-sBpdlX8n.js.map → transformDataForAggregation-CE3bAlHU.js.map} +1 -1
  542. package/dist/transformDataForAggregation-KXGm6flX.cjs.map +1 -1
  543. package/dist/transformDataForGraphFromFile-BExxcITV.js +14 -0
  544. package/dist/{transformDataForGraphFromFile-ComYvzuz.js.map → transformDataForGraphFromFile-BExxcITV.js.map} +1 -1
  545. package/dist/{transformDataForGraphFromFile-DVZodTHd.cjs → transformDataForGraphFromFile-DaJHQCsL.cjs} +2 -2
  546. package/dist/{transformDataForGraphFromFile-DVZodTHd.cjs.map → transformDataForGraphFromFile-DaJHQCsL.cjs.map} +1 -1
  547. package/dist/transformDataForSelect-D8AuvYdf.js.map +1 -1
  548. package/dist/transformDataForSelect-YmStusCI.cjs.map +1 -1
  549. package/dist/uniqBy-BHy4I8PK.js.map +1 -1
  550. package/dist/uniqBy-O05lp2S5.cjs.map +1 -1
  551. package/dist/{use-in-view-DR-UTB96.js → use-in-view-Cxa7y1TH.js} +2 -2
  552. package/dist/use-in-view-Cxa7y1TH.js.map +1 -0
  553. package/dist/use-in-view-QcfiW0w3.cjs +2 -0
  554. package/dist/use-in-view-QcfiW0w3.cjs.map +1 -0
  555. package/dist/utils.cjs +1 -1
  556. package/dist/utils.js +8 -8
  557. package/dist/validateSchema.cjs.map +1 -1
  558. package/dist/validateSchema.js +33 -29
  559. package/dist/validateSchema.js.map +1 -1
  560. package/dist/{x-BBpi7a_7-Dz2vKSfu.cjs → x-BBpi7a_7-mTo40uId.cjs} +2 -2
  561. package/dist/{x-BBpi7a_7-Dz2vKSfu.cjs.map → x-BBpi7a_7-mTo40uId.cjs.map} +1 -1
  562. package/dist/{y-D0sAaVii.js → y-BqfogMAB.js} +3 -3
  563. package/dist/{y-D0sAaVii.js.map → y-BqfogMAB.js.map} +1 -1
  564. package/dist/{zoom-QipiAl5W.js → zoom-C9MFjAaV.js} +5 -5
  565. package/dist/{zoom-QipiAl5W.js.map → zoom-C9MFjAaV.js.map} +1 -1
  566. package/dist/zoom-DPw8bba-.cjs +2 -0
  567. package/dist/{zoom-BiMNsz72.cjs.map → zoom-DPw8bba-.cjs.map} +1 -1
  568. package/package.json +7 -6
  569. package/dist/Axis-4gUOL8B7.js +0 -43
  570. package/dist/Axis-4gUOL8B7.js.map +0 -1
  571. package/dist/Axis-CkNn1wit.cjs +0 -2
  572. package/dist/Axis-CkNn1wit.cjs.map +0 -1
  573. package/dist/AxisTitle-Wkz-xeQL.cjs +0 -2
  574. package/dist/AxisTitle-Wkz-xeQL.cjs.map +0 -1
  575. package/dist/AxisTitle-v6_xcXZ-.js +0 -20
  576. package/dist/AxisTitle-v6_xcXZ-.js.map +0 -1
  577. package/dist/DropdownSelect-6kjXM6oW.js.map +0 -1
  578. package/dist/DropdownSelect-vt8yiB-g.cjs +0 -29
  579. package/dist/DropdownSelect-vt8yiB-g.cjs.map +0 -1
  580. package/dist/EmptyState-36lXXyui.js +0 -22
  581. package/dist/EmptyState-B8IpKGcL.cjs +0 -2
  582. package/dist/GraphEl-2IiUDxjR.js.map +0 -1
  583. package/dist/GraphEl-qrlfGPe3.cjs +0 -2
  584. package/dist/GraphEl-qrlfGPe3.cjs.map +0 -1
  585. package/dist/Modal-Cg8daIlV.js +0 -1030
  586. package/dist/Modal-Cg8daIlV.js.map +0 -1
  587. package/dist/Modal-CuuJdWkD.cjs +0 -46
  588. package/dist/Modal-CuuJdWkD.cjs.map +0 -1
  589. package/dist/ReferenceLine-CPMaAX0r.js +0 -128
  590. package/dist/ReferenceLine-CPMaAX0r.js.map +0 -1
  591. package/dist/ReferenceLine-D04j-zeV.cjs +0 -2
  592. package/dist/ReferenceLine-D04j-zeV.cjs.map +0 -1
  593. package/dist/RegressionLine-CW7iViH2.js +0 -49
  594. package/dist/RegressionLine-CW7iViH2.js.map +0 -1
  595. package/dist/RegressionLine-D-49RaHa.cjs +0 -2
  596. package/dist/RegressionLine-D-49RaHa.cjs.map +0 -1
  597. package/dist/Spinner-Bpz70q_g.js +0 -30
  598. package/dist/Spinner-Bpz70q_g.js.map +0 -1
  599. package/dist/Spinner-C6wLp85s.cjs +0 -2
  600. package/dist/Spinner-C6wLp85s.cjs.map +0 -1
  601. package/dist/Tooltip-6LIdPQGC.js +0 -46
  602. package/dist/Tooltip-6LIdPQGC.js.map +0 -1
  603. package/dist/Tooltip-Cpv0QohJ.cjs +0 -2
  604. package/dist/Tooltip-Cpv0QohJ.cjs.map +0 -1
  605. package/dist/Typography-BDULiwlF.cjs +0 -2
  606. package/dist/Typography-BDULiwlF.cjs.map +0 -1
  607. package/dist/Typography-LmZ9LEpe.js +0 -140
  608. package/dist/Typography-LmZ9LEpe.js.map +0 -1
  609. package/dist/XAxesLabels-CLZnBgSr.cjs +0 -2
  610. package/dist/XAxesLabels-CLZnBgSr.cjs.map +0 -1
  611. package/dist/XAxesLabels-SOSmso5J.js +0 -57
  612. package/dist/XAxesLabels-SOSmso5J.js.map +0 -1
  613. package/dist/XTicksAndGridLines-DuydSnZ_.js +0 -56
  614. package/dist/XTicksAndGridLines-DuydSnZ_.js.map +0 -1
  615. package/dist/XTicksAndGridLines-RKy7BVCO.cjs +0 -2
  616. package/dist/XTicksAndGridLines-RKy7BVCO.cjs.map +0 -1
  617. package/dist/YAxesLabels-DlDyLvhi.js +0 -52
  618. package/dist/YAxesLabels-DlDyLvhi.js.map +0 -1
  619. package/dist/YAxesLabels-Dqd259-t.cjs +0 -2
  620. package/dist/YAxesLabels-Dqd259-t.cjs.map +0 -1
  621. package/dist/YTicksAndGridLines-7t4MKtGw.js +0 -56
  622. package/dist/YTicksAndGridLines-7t4MKtGw.js.map +0 -1
  623. package/dist/YTicksAndGridLines-qGpRo_t1.cjs +0 -2
  624. package/dist/YTicksAndGridLines-qGpRo_t1.cjs.map +0 -1
  625. package/dist/checkIfMultiple-Dko_cBvE.cjs +0 -12
  626. package/dist/checkIfMultiple-Dko_cBvE.cjs.map +0 -1
  627. package/dist/checkIfMultiple-u2SmbiCf.js +0 -912
  628. package/dist/checkIfMultiple-u2SmbiCf.js.map +0 -1
  629. package/dist/customArea-1G1S78s_.cjs +0 -2
  630. package/dist/customArea-x4L4xwLl.js +0 -175
  631. package/dist/fetchAndParseData-Ba-_CgxS.cjs +0 -16
  632. package/dist/getGraphList-DuColTJM.js +0 -265
  633. package/dist/getSliderMarks-CUxPy36E.cjs +0 -6
  634. package/dist/getSliderMarks-CUxPy36E.cjs.map +0 -1
  635. package/dist/getSliderMarks-_pYOWEtO.js +0 -1023
  636. package/dist/getSliderMarks-_pYOWEtO.js.map +0 -1
  637. package/dist/index-9tDEUqOZ.js.map +0 -1
  638. package/dist/index-BHe3wsWF.cjs +0 -2
  639. package/dist/index-Bw_eHBVN.js +0 -77
  640. package/dist/index-C0bpbS4F.cjs +0 -2
  641. package/dist/index-C0bpbS4F.cjs.map +0 -1
  642. package/dist/index-CE9pmfxt.js +0 -430
  643. package/dist/index-CE9pmfxt.js.map +0 -1
  644. package/dist/index-CEJwW3lL.cjs +0 -2
  645. package/dist/index-CEJwW3lL.cjs.map +0 -1
  646. package/dist/index-CHPV5EwG-DBWUSD9b.js.map +0 -1
  647. package/dist/index-CHPV5EwG-DjM48pIC.cjs +0 -44
  648. package/dist/index-CHPV5EwG-DjM48pIC.cjs.map +0 -1
  649. package/dist/index-CQ3e6Ewi.cjs +0 -2
  650. package/dist/index-Cm8NIdOO.cjs +0 -10
  651. package/dist/index-Cm8NIdOO.cjs.map +0 -1
  652. package/dist/index-CoZbeNM9.cjs +0 -2
  653. package/dist/index-CoZbeNM9.cjs.map +0 -1
  654. package/dist/index-Cwgh7i7X.js +0 -122
  655. package/dist/index-Cwgh7i7X.js.map +0 -1
  656. package/dist/index-D72cOtq7.cjs +0 -2
  657. package/dist/index-zZjQEHlm.js +0 -342
  658. package/dist/index-zZjQEHlm.js.map +0 -1
  659. package/dist/ordinal-BOeNbyae.cjs.map +0 -1
  660. package/dist/ordinal-w9Lu4Stb.js.map +0 -1
  661. package/dist/proxy-BYIC9BuT.js.map +0 -1
  662. package/dist/proxy-CKadx4lC.cjs +0 -2
  663. package/dist/proxy-CKadx4lC.cjs.map +0 -1
  664. package/dist/string2HTML-z7CwHXcx.cjs +0 -3
  665. package/dist/transformDataForAggregation-sBpdlX8n.js +0 -755
  666. package/dist/transformDataForGraphFromFile-ComYvzuz.js +0 -24
  667. package/dist/use-in-view-CEwlc_dd.cjs +0 -2
  668. package/dist/use-in-view-CEwlc_dd.cjs.map +0 -1
  669. package/dist/use-in-view-DR-UTB96.js.map +0 -1
  670. package/dist/zoom-BiMNsz72.cjs +0 -2
@@ -1,2 +1,2 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const r=require("./index-CHPV5EwG-DjM48pIC.cjs"),p=require("react"),xe=require("./index-DQA8q5sC.cjs"),de=require("./Modal-CuuJdWkD.cjs"),ge=require("./index-CQ3e6Ewi.cjs"),fe=require("./Tooltip-Cpv0QohJ.cjs"),J=require("./checkIfNullOrUndefined-BCW3Y1ML.cjs"),ce=require("./numberFormattingFunction-02t-wJta.cjs"),u=require("./Colors.cjs"),pe=require("./string2HTML-z7CwHXcx.cjs"),me=require("./linear-BVckp9RD.cjs"),ye=require("./use-in-view-CEwlc_dd.cjs"),ne=require("./proxy-CKadx4lC.cjs"),ve=require("./index-Cm8NIdOO.cjs"),je=require("./GraphFooter.cjs"),we=require("./GraphHeader.cjs"),Oe=require("./ColorLegendWithMouseOver.cjs"),Ce=require("./EmptyState-B8IpKGcL.cjs"),ue=require("./uniqBy-O05lp2S5.cjs");function be(L,i){if(L<2)return[];const x=i/(L-1);return Array.from({length:L},(m,o)=>o*x)}function Ee(L){const{data:i,width:x,height:m,colors:o,colorDomain:n,radius:c,leftMargin:s,rightMargin:P,topMargin:W,bottomMargin:ee,tooltip:U,onSeriesMouseOver:D,highlightedDataPoints:l,selectedColor:G,minValue:z,maxValue:B,onSeriesMouseClick:I,prefix:K,suffix:C,stripType:Q,highlightColor:y,dotOpacity:v,resetSelectionOnDoubleClick:te,detailsOnClick:N,styles:E,classNames:V,valueColor:S,animate:d,noOfTicks:w,dimmedOpacity:$,precision:X,customLayers:M}=L,Y=p.useRef(null),R=ye.useInView(Y,{once:d.once,amount:d.amount}),[T,j]=p.useState(void 0),[g,q]=p.useState(void 0),[_,H]=p.useState(void 0),[f,h]=p.useState(void 0),O={top:W,bottom:ee,left:s,right:P},k=x-O.left-O.right,A=m-O.top-O.bottom,ie=i.map((e,t)=>({...e,id:`${t}`})),oe=ge.orderBy(ie,[e=>{const t=(l||[]).indexOf(e.label);return t===-1?1/0:t}],["desc"]),re=J.checkIfNullOrUndefined(B)?Math.max(...i.filter(e=>!J.checkIfNullOrUndefined(e.position)).map(e=>e.position))<0?0:Math.max(...i.filter(e=>!J.checkIfNullOrUndefined(e.position)).map(e=>e.position)):B,b=J.checkIfNullOrUndefined(z)?Math.min(...i.filter(e=>!J.checkIfNullOrUndefined(e.position)).map(e=>e.position))>=0?0:Math.min(...i.filter(e=>!J.checkIfNullOrUndefined(e.position)).map(e=>e.position)):z,F=me.linear().domain([b,re]).range([0,k]).nice(),le=be(w,k);return r.jsxRuntimeExports.jsxs(r.jsxRuntimeExports.Fragment,{children:[r.jsxRuntimeExports.jsx(ne.motion.svg,{width:`${x}px`,height:`${m}px`,viewBox:`0 0 ${x} ${m}`,direction:"ltr",ref:Y,children:r.jsxRuntimeExports.jsxs("g",{transform:`translate(${O.left},${O.top})`,children:[M.filter(e=>e.position==="before").map(e=>e.layer),r.jsxRuntimeExports.jsxs(ve.AnimatePresence,{children:[oe.map(e=>r.jsxRuntimeExports.jsxs(ne.motion.g,{className:"undp-viz-g-with-hover",variants:{initial:{opacity:0,x:F(0),y:A/2},whileInView:{x:F(e.position),y:A/2,opacity:G?e.color&&o[n.indexOf(e.color)]===G?.95:$:l.length!==0?l.indexOf(e.label)!==-1?.95:$:v,transition:{duration:d.duration}}},initial:"initial",animate:R?"whileInView":"initial",exit:{opacity:0,transition:{duration:d.duration}},onMouseEnter:t=>{j(e),h(t.clientY),H(t.clientX),D?.(e)},onClick:()=>{(I||N)&&(xe.isEqual(g,e)&&te?(q(void 0),I?.(void 0)):(q(e),I?.(e)))},onMouseMove:t=>{j(e),h(t.clientY),H(t.clientX)},onMouseLeave:()=>{j(void 0),H(void 0),h(void 0),D?.(void 0)},children:[Q==="dot"?r.jsxRuntimeExports.jsx(ne.motion.circle,{cy:0,cx:0,variants:{initial:{fill:y&&l?l.indexOf(e.label)!==-1?y:i.filter(t=>t.color).length===0?o[0]:e.color?o[n.indexOf(e.color)]:u.Colors.gray:i.filter(t=>t.color).length===0?o[0]:e.color?o[n.indexOf(e.color)]:u.Colors.gray},whileInView:{fill:y&&l?l.indexOf(e.label)!==-1?y:i.filter(t=>t.color).length===0?o[0]:e.color?o[n.indexOf(e.color)]:u.Colors.gray:i.filter(t=>t.color).length===0?o[0]:e.color?o[n.indexOf(e.color)]:u.Colors.gray,transition:{duration:d.duration}}},initial:"initial",animate:R?"whileInView":"initial",exit:{opacity:0,transition:{duration:d.duration}},r:c}):r.jsxRuntimeExports.jsx(ne.motion.rect,{x:-1,width:2,variants:{initial:{y:0-c,height:c*2,fill:y&&l?l.indexOf(e.label)!==-1?y:i.filter(t=>t.color).length===0?o[0]:e.color?o[n.indexOf(e.color)]:u.Colors.gray:i.filter(t=>t.color).length===0?o[0]:e.color?o[n.indexOf(e.color)]:u.Colors.gray},whileInView:{y:0-c,height:c*2,fill:y&&l?l.indexOf(e.label)!==-1?y:i.filter(t=>t.color).length===0?o[0]:e.color?o[n.indexOf(e.color)]:u.Colors.gray:i.filter(t=>t.color).length===0?o[0]:e.color?o[n.indexOf(e.color)]:u.Colors.gray,transition:{duration:d.duration}}},initial:"initial",animate:R?"whileInView":"initial",exit:{opacity:0,transition:{duration:d.duration}}}),l.length!==0&&l.indexOf(e.label)!==-1?r.jsxRuntimeExports.jsx(ne.motion.text,{x:0,variants:{initial:{opacity:0,y:0-c-5,fill:S||(y&&l?l.indexOf(e.label)!==-1?y:i.filter(t=>t.color).length===0?o[0]:e.color?o[n.indexOf(e.color)]:u.Colors.gray:i.filter(t=>t.color).length===0?o[0]:e.color?o[n.indexOf(e.color)]:u.Colors.gray)},whileInView:{opacity:1,y:0-c-5,fill:S||(y&&l?l.indexOf(e.label)!==-1?y:i.filter(t=>t.color).length===0?o[0]:e.color?o[n.indexOf(e.color)]:u.Colors.gray:i.filter(t=>t.color).length===0?o[0]:e.color?o[n.indexOf(e.color)]:u.Colors.gray),transition:{duration:d.duration}}},initial:"initial",animate:R?"whileInView":"initial",exit:{opacity:0,transition:{duration:d.duration}},style:{textAnchor:"middle",...E?.graphObjectValues||{}},className:r.mo("graph-value text-sm font-bold",V?.graphObjectValues),children:ce.numberFormattingFunction(e.position,"NA",X,K,C)}):null]},e.label)),le.map((e,t)=>r.jsxRuntimeExports.jsx("text",{x:e,y:A/2+c,style:{textAnchor:t===0?"start":t===le.length-1?"end":"middle",...E?.xAxis?.labels||{}},className:r.mo("fill-primary-gray-550 dark:fill-primary-gray-500 text-xs",V?.xAxis?.labels),dy:"1em",children:ce.numberFormattingFunction(F.invert(e),"NA",X,K,C)},t))]}),M.filter(e=>e.position==="after").map(e=>e.layer)]})}),T&&U&&_&&f?r.jsxRuntimeExports.jsx(fe.Tooltip,{data:T,body:U,xPos:_,yPos:f,backgroundStyle:E?.tooltip,className:V?.tooltip}):null,N&&g!==void 0?r.jsxRuntimeExports.jsx(de.G,{open:g!==void 0,onClose:()=>{q(void 0)},children:r.jsxRuntimeExports.jsx("div",{className:"graph-modal-content m-0",dangerouslySetInnerHTML:typeof N=="string"?{__html:pe.string2HTML(N,g)}:void 0,children:typeof N=="function"?N(g):null})}):null]})}function Me(L){const{data:i,graphTitle:x,colors:m,sources:o,graphDescription:n,height:c,width:s,footNote:P,colorDomain:W,colorLegendTitle:ee,radius:U=5,padding:D,backgroundColor:l=!1,leftMargin:G=5,rightMargin:z=5,topMargin:B=10,bottomMargin:I=10,tooltip:K,relativeHeight:C,onSeriesMouseOver:Q,showColorScale:y=!0,highlightedDataPoints:v=[],graphID:te,minValue:N,maxValue:E,onSeriesMouseClick:V,graphDownload:S=!1,dataDownload:d=!1,prefix:w="",suffix:$="",stripType:X="dot",language:M="en",highlightColor:Y,dotOpacity:R=.3,showNAColor:T=!0,minHeight:j=0,theme:g="light",ariaLabel:q,resetSelectionOnDoubleClick:_=!0,detailsOnClick:H,styles:f,classNames:h,valueColor:O,animate:k=!1,noOfTicks:A=2,dimmedOpacity:ie=.3,precision:oe=2,customLayers:re=[]}=L,[b,F]=p.useState(0),[le,e]=p.useState(0),[t,he]=p.useState(void 0),Z=p.useRef(null),ae=p.useRef(null);return p.useEffect(()=>{const a=new ResizeObserver(se=>{F(s||se[0].target.clientWidth||620),e(c||se[0].target.clientHeight||480)});return Z.current&&(e(Z.current.clientHeight||480),F(Z.current.clientWidth||620),s||a.observe(Z.current)),()=>a.disconnect()},[s,c]),r.jsxRuntimeExports.jsx("div",{className:`${g||"light"} flex ${s?"w-fit grow-0":"w-full grow"}`,dir:M==="he"||M==="ar"?"rtl":void 0,children:r.jsxRuntimeExports.jsx("div",{className:r.mo(`${l?l===!0?"bg-primary-gray-200 dark:bg-primary-gray-650 ":"":"bg-transparent "}ml-auto mr-auto flex flex-col grow h-inherit ${M||"en"}`,s?"w-fit":"w-full",h?.graphContainer),style:{...f?.graphContainer||{},...l&&l!==!0?{backgroundColor:l}:{}},id:te,ref:ae,"aria-label":q||`${x?`The graph shows ${x}. `:""}This is a strip chart showing distribution of data along the horizontal axis. Each dot represents an individual data point, helping to visualize the spread and clustering of values.${n?` ${n}`:""}`,children:r.jsxRuntimeExports.jsx("div",{className:"flex grow",style:{padding:l?D||"1rem":D||0},children:r.jsxRuntimeExports.jsxs("div",{className:"flex flex-col w-full gap-4 grow justify-between",children:[x||n||S||d?r.jsxRuntimeExports.jsx(we.GraphHeader,{styles:{title:f?.title,description:f?.description},classNames:{title:h?.title,description:h?.description},graphTitle:x,graphDescription:n,width:s,graphDownload:S?ae.current:void 0,dataDownload:d?i.map(a=>a.data).filter(a=>a!==void 0).length>0?i.map(a=>a.data).filter(a=>a!==void 0):i.filter(a=>a!==void 0):null}):null,r.jsxRuntimeExports.jsx("div",{className:"grow flex flex-col justify-center gap-3 w-full",children:i.length===0?r.jsxRuntimeExports.jsx(Ce.EmptyState,{}):r.jsxRuntimeExports.jsxs(r.jsxRuntimeExports.Fragment,{children:[y!==!1&&i.filter(a=>a.color).length!==0?r.jsxRuntimeExports.jsx(Oe.ColorLegendWithMouseOver,{width:s,colorLegendTitle:ee,colors:m||u.Colors[g].categoricalColors.colors,colorDomain:W||ue.uniqBy(i,"color",!0),setSelectedColor:he,showNAColor:T??!0}):null,r.jsxRuntimeExports.jsx("div",{className:"flex flex-col grow justify-center w-full leading-0",ref:Z,"aria-label":"Graph area",children:(s||b)&&(c||le)?r.jsxRuntimeExports.jsx(Ee,{data:i,width:s||b,height:Math.max(j,c||(C?j?(s||b)*C>j?(s||b)*C:j:(s||b)*C:le)),colorDomain:i.filter(a=>a.color).length===0?[]:W||ue.uniqBy(i,"color",!0),colors:i.filter(a=>a.color).length===0?m?[m]:[u.Colors.primaryColors["blue-600"]]:m||u.Colors[g].categoricalColors.colors,selectedColor:t,radius:U,leftMargin:G,rightMargin:z,topMargin:B,bottomMargin:I,tooltip:K,onSeriesMouseOver:Q,highlightedDataPoints:v,minValue:N,maxValue:E,onSeriesMouseClick:V,prefix:w,suffix:$,stripType:X,highlightColor:Y,dotOpacity:R,resetSelectionOnDoubleClick:_,detailsOnClick:H,styles:f,classNames:h,valueColor:O,animate:k===!0?{duration:.5,once:!0,amount:.5}:k||{duration:0,once:!0,amount:0},noOfTicks:A,dimmedOpacity:ie,precision:oe,customLayers:re}):null})]})}),o||P?r.jsxRuntimeExports.jsx(je.GraphFooter,{styles:{footnote:f?.footnote,source:f?.source},classNames:{footnote:h?.footnote,source:h?.source},sources:o,footNote:P,width:s}):null]})})})})}function Re(L){const{data:i,width:x,height:m,colors:o,colorDomain:n,radius:c,leftMargin:s,rightMargin:P,topMargin:W,bottomMargin:ee,tooltip:U,onSeriesMouseOver:D,highlightedDataPoints:l,selectedColor:G,minValue:z,maxValue:B,onSeriesMouseClick:I,noOfTicks:K,prefix:C,suffix:Q,stripType:y,highlightColor:v,dotOpacity:te,resetSelectionOnDoubleClick:N,detailsOnClick:E,styles:V,classNames:S,valueColor:d,animate:w,dimmedOpacity:$,precision:X,customLayers:M}=L,Y=p.useRef(null),R=ye.useInView(Y,{once:w.once,amount:w.amount}),[T,j]=p.useState(void 0),[g,q]=p.useState(void 0),[_,H]=p.useState(void 0),[f,h]=p.useState(void 0),O={top:W,bottom:ee,left:s,right:P},k=x-O.left-O.right,A=m-O.top-O.bottom,ie=i.map((e,t)=>({...e,id:`${t}`})),oe=ge.orderBy(ie,[e=>{const t=(l||[]).indexOf(e.label);return t===-1?1/0:t}],["desc"]),re=J.checkIfNullOrUndefined(B)?Math.max(...i.filter(e=>!J.checkIfNullOrUndefined(e.position)).map(e=>e.position))<0?0:Math.max(...i.filter(e=>!J.checkIfNullOrUndefined(e.position)).map(e=>e.position)):B,b=J.checkIfNullOrUndefined(z)?Math.min(...i.filter(e=>!J.checkIfNullOrUndefined(e.position)).map(e=>e.position))>=0?0:Math.min(...i.filter(e=>!J.checkIfNullOrUndefined(e.position)).map(e=>e.position)):z,F=me.linear().domain([b,re]).range([A,0]).nice(),le=be(K,A);return r.jsxRuntimeExports.jsxs(r.jsxRuntimeExports.Fragment,{children:[r.jsxRuntimeExports.jsx(ne.motion.svg,{width:`${x}px`,height:`${m}px`,viewBox:`0 0 ${x} ${m}`,direction:"ltr",ref:Y,children:r.jsxRuntimeExports.jsxs("g",{transform:`translate(${O.left},${O.top})`,children:[M.filter(e=>e.position==="before").map(e=>e.layer),r.jsxRuntimeExports.jsxs(ve.AnimatePresence,{children:[oe.map(e=>r.jsxRuntimeExports.jsxs(ne.motion.g,{className:"undp-viz-g-with-hover",variants:{initial:{opacity:0,x:k/2,y:F(0)},whileInView:{x:k/2,y:F(e.position),opacity:G?e.color&&o[n.indexOf(e.color)]===G?.95:$:l.length!==0?l.indexOf(e.label)!==-1?.95:$:te,transition:{duration:w.duration}}},initial:"initial",animate:R?"whileInView":"initial",exit:{opacity:0,transition:{duration:w.duration}},onMouseEnter:t=>{j(e),h(t.clientY),H(t.clientX),D?.(e)},onClick:()=>{(I||E)&&(xe.isEqual(g,e)&&N?(q(void 0),I?.(void 0)):(q(e),I?.(e)))},onMouseMove:t=>{j(e),h(t.clientY),H(t.clientX)},onMouseLeave:()=>{j(void 0),H(void 0),h(void 0),D?.(void 0)},children:[y==="dot"?r.jsxRuntimeExports.jsx(ne.motion.circle,{cy:0,cx:0,variants:{initial:{fill:v&&l?l.indexOf(e.label)!==-1?v:i.filter(t=>t.color).length===0?o[0]:e.color?o[n.indexOf(e.color)]:u.Colors.gray:i.filter(t=>t.color).length===0?o[0]:e.color?o[n.indexOf(e.color)]:u.Colors.gray},whileInView:{fill:v&&l?l.indexOf(e.label)!==-1?v:i.filter(t=>t.color).length===0?o[0]:e.color?o[n.indexOf(e.color)]:u.Colors.gray:i.filter(t=>t.color).length===0?o[0]:e.color?o[n.indexOf(e.color)]:u.Colors.gray,transition:{duration:w.duration}}},initial:"initial",animate:R?"whileInView":"initial",exit:{opacity:0,transition:{duration:w.duration}},r:c}):r.jsxRuntimeExports.jsx(ne.motion.rect,{y:-1,height:2,variants:{initial:{x:0-c,width:c*2,fill:v&&l?l.indexOf(e.label)!==-1?v:i.filter(t=>t.color).length===0?o[0]:e.color?o[n.indexOf(e.color)]:u.Colors.gray:i.filter(t=>t.color).length===0?o[0]:e.color?o[n.indexOf(e.color)]:u.Colors.gray},whileInView:{x:0-c,width:c*2,fill:v&&l?l.indexOf(e.label)!==-1?v:i.filter(t=>t.color).length===0?o[0]:e.color?o[n.indexOf(e.color)]:u.Colors.gray:i.filter(t=>t.color).length===0?o[0]:e.color?o[n.indexOf(e.color)]:u.Colors.gray,transition:{duration:w.duration}}},initial:"initial",animate:R?"whileInView":"initial",exit:{opacity:0,transition:{duration:w.duration}}}),l.length!==0&&l.indexOf(e.label)!==-1?r.jsxRuntimeExports.jsx(ne.motion.text,{y:0,dy:"0.33em",variants:{initial:{opacity:0,x:0+c+3,fill:d||(v&&l?l.indexOf(e.label)!==-1?v:i.filter(t=>t.color).length===0?o[0]:e.color?o[n.indexOf(e.color)]:u.Colors.gray:i.filter(t=>t.color).length===0?o[0]:e.color?o[n.indexOf(e.color)]:u.Colors.gray)},whileInView:{opacity:1,x:0+c+3,fill:d||(v&&l?l.indexOf(e.label)!==-1?v:i.filter(t=>t.color).length===0?o[0]:e.color?o[n.indexOf(e.color)]:u.Colors.gray:i.filter(t=>t.color).length===0?o[0]:e.color?o[n.indexOf(e.color)]:u.Colors.gray),transition:{duration:w.duration}}},initial:"initial",animate:R?"whileInView":"initial",exit:{opacity:0,transition:{duration:w.duration}},style:{textAnchor:"start",...V?.graphObjectValues||{}},className:r.mo("graph-value text-sm font-bold",S?.graphObjectValues),children:ce.numberFormattingFunction(e.position,"NA",X,C,Q)}):null]},e.label)),le.map((e,t)=>r.jsxRuntimeExports.jsx("text",{y:e,x:k/2+c+5,style:{textAnchor:"start",...V?.yAxis?.labels||{}},className:r.mo("fill-primary-gray-550 dark:fill-primary-gray-500 text-xs",S?.yAxis?.labels),children:ce.numberFormattingFunction(F.invert(e),"NA",X,C,Q)},t))]}),M.filter(e=>e.position==="after").map(e=>e.layer)]})}),T&&U&&_&&f?r.jsxRuntimeExports.jsx(fe.Tooltip,{data:T,body:U,xPos:_,yPos:f,backgroundStyle:V?.tooltip,className:S?.tooltip}):null,E&&g!==void 0?r.jsxRuntimeExports.jsx(de.G,{open:g!==void 0,onClose:()=>{q(void 0)},children:r.jsxRuntimeExports.jsx("div",{className:"graph-modal-content m-0",dangerouslySetInnerHTML:typeof E=="string"?{__html:pe.string2HTML(E,g)}:void 0,children:typeof E=="function"?E(g):null})}):null]})}function Ne(L){const{data:i,graphTitle:x,colors:m,sources:o,graphDescription:n,height:c,width:s,footNote:P,colorDomain:W,colorLegendTitle:ee,radius:U=5,padding:D,backgroundColor:l=!1,leftMargin:G=20,rightMargin:z=20,topMargin:B=10,bottomMargin:I=10,tooltip:K,relativeHeight:C,onSeriesMouseOver:Q,showColorScale:y=!0,highlightedDataPoints:v=[],graphID:te,minValue:N,maxValue:E,onSeriesMouseClick:V,graphDownload:S=!1,dataDownload:d=!1,prefix:w="",suffix:$="",stripType:X="dot",language:M="en",highlightColor:Y,dotOpacity:R=.3,showNAColor:T=!0,minHeight:j=0,theme:g="light",ariaLabel:q,resetSelectionOnDoubleClick:_=!0,detailsOnClick:H,styles:f,classNames:h,valueColor:O,animate:k=!1,noOfTicks:A=2,dimmedOpacity:ie=.3,precision:oe=2,customLayers:re=[]}=L,[b,F]=p.useState(0),[le,e]=p.useState(0),[t,he]=p.useState(void 0),Z=p.useRef(null),ae=p.useRef(null);return p.useEffect(()=>{const a=new ResizeObserver(se=>{F(s||se[0].target.clientWidth||620),e(c||se[0].target.clientHeight||480)});return Z.current&&(e(Z.current.clientHeight||480),F(Z.current.clientWidth||620),s||a.observe(Z.current)),()=>a.disconnect()},[s,c]),r.jsxRuntimeExports.jsx("div",{className:`${g||"light"} flex ${s?"w-fit grow-0":"w-full grow"}`,dir:M==="he"||M==="ar"?"rtl":void 0,children:r.jsxRuntimeExports.jsx("div",{className:r.mo(`${l?l===!0?"bg-primary-gray-200 dark:bg-primary-gray-650 ":"":"bg-transparent "}ml-auto mr-auto flex flex-col grow h-inherit ${M||"en"}`,s?"w-fit":"w-full",h?.graphContainer),style:{...f?.graphContainer||{},...l&&l!==!0?{backgroundColor:l}:{}},id:te,ref:ae,"aria-label":q||`${x?`The graph shows ${x}. `:""}This is a strip chart showing distribution of data along the vertical axis. Each dot represents an individual data point, helping to visualize the spread and clustering of values.${n?` ${n}`:""}`,children:r.jsxRuntimeExports.jsx("div",{className:"flex grow",style:{padding:l?D||"1rem":D||0},children:r.jsxRuntimeExports.jsxs("div",{className:"flex flex-col w-full gap-4 grow justify-between",children:[x||n||S||d?r.jsxRuntimeExports.jsx(we.GraphHeader,{styles:{title:f?.title,description:f?.description},classNames:{title:h?.title,description:h?.description},graphTitle:x,graphDescription:n,width:s,graphDownload:S?ae.current:void 0,dataDownload:d?i.map(a=>a.data).filter(a=>a!==void 0).length>0?i.map(a=>a.data).filter(a=>a!==void 0):i.filter(a=>a!==void 0):null}):null,r.jsxRuntimeExports.jsx("div",{className:"grow flex flex-col justify-center gap-3 w-full",children:i.length===0?r.jsxRuntimeExports.jsx(Ce.EmptyState,{}):r.jsxRuntimeExports.jsxs(r.jsxRuntimeExports.Fragment,{children:[y!==!1&&i.filter(a=>a.color).length!==0?r.jsxRuntimeExports.jsx(Oe.ColorLegendWithMouseOver,{width:s,colorLegendTitle:ee,colors:m||u.Colors[g].categoricalColors.colors,colorDomain:W||ue.uniqBy(i,"color",!0),setSelectedColor:he,showNAColor:T}):null,r.jsxRuntimeExports.jsx("div",{className:"flex flex-col grow justify-center w-full leading-0",ref:Z,children:(s||b)&&(c||le)?r.jsxRuntimeExports.jsx(Re,{data:i,width:s||b,height:Math.max(j,c||(C?j?(s||b)*C>j?(s||b)*C:j:(s||b)*C:le)),colorDomain:i.filter(a=>a.color).length===0?[]:W||ue.uniqBy(i,"color",!0),colors:i.filter(a=>a.color).length===0?m?[m]:[u.Colors.primaryColors["blue-600"]]:m||u.Colors[g].categoricalColors.colors,selectedColor:t,radius:U,leftMargin:G,rightMargin:z,topMargin:B,bottomMargin:I,tooltip:K,onSeriesMouseOver:Q,highlightedDataPoints:v,minValue:N,maxValue:E,onSeriesMouseClick:V,prefix:w,suffix:$,stripType:X,highlightColor:Y,dotOpacity:R,resetSelectionOnDoubleClick:_,detailsOnClick:H,styles:f,classNames:h,valueColor:O,animate:k===!0?{duration:.5,once:!0,amount:.5}:k||{duration:0,once:!0,amount:0},noOfTicks:A,dimmedOpacity:ie,precision:oe,customLayers:re}):null})]})}),o||P?r.jsxRuntimeExports.jsx(je.GraphFooter,{styles:{footnote:f?.footnote,source:f?.source},classNames:{footnote:h?.footnote,source:h?.source},sources:o,footNote:P,width:s}):null]})})})})}function Se(L){const{data:i,graphTitle:x,colors:m,sources:o,graphDescription:n,height:c,width:s,footNote:P,colorDomain:W,colorLegendTitle:ee,radius:U,padding:D,backgroundColor:l,leftMargin:G,rightMargin:z,topMargin:B,bottomMargin:I,tooltip:K,relativeHeight:C,onSeriesMouseOver:Q,showColorScale:y,highlightedDataPoints:v,graphID:te,minValue:N,maxValue:E,onSeriesMouseClick:V,noOfTicks:S,graphDownload:d,dataDownload:w,prefix:$,suffix:X,stripType:M,language:Y,highlightColor:R,dotOpacity:T,showNAColor:j,minHeight:g,theme:q,ariaLabel:_,valueColor:H,resetSelectionOnDoubleClick:f,detailsOnClick:h,orientation:O="vertical",styles:k,classNames:A,animate:ie,dimmedOpacity:oe=.3,precision:re,customLayers:b}=L;return O==="vertical"?r.jsxRuntimeExports.jsx(Ne,{data:i,graphTitle:x,colors:m,sources:o,graphDescription:n,height:c,width:s,footNote:P,colorDomain:W,colorLegendTitle:ee,radius:U,padding:D,backgroundColor:l,leftMargin:G,rightMargin:z,topMargin:B,bottomMargin:I,tooltip:K,relativeHeight:C,onSeriesMouseOver:Q,showColorScale:y,highlightedDataPoints:v,graphID:te,minValue:N,maxValue:E,onSeriesMouseClick:V,noOfTicks:S,graphDownload:d,dataDownload:w,prefix:$,suffix:X,stripType:M,language:Y,highlightColor:R,dotOpacity:T,showNAColor:j,minHeight:g,theme:q,ariaLabel:_,resetSelectionOnDoubleClick:f,styles:k,valueColor:H,detailsOnClick:h,classNames:A,animate:ie,dimmedOpacity:oe,precision:re,customLayers:b}):r.jsxRuntimeExports.jsx(Me,{data:i,graphTitle:x,colors:m,sources:o,graphDescription:n,height:c,width:s,footNote:P,colorDomain:W,colorLegendTitle:ee,radius:U,padding:D,backgroundColor:l,leftMargin:G,rightMargin:z,topMargin:B,bottomMargin:I,tooltip:K,relativeHeight:C,onSeriesMouseOver:Q,showColorScale:y,highlightedDataPoints:v,graphID:te,minValue:N,maxValue:E,onSeriesMouseClick:V,noOfTicks:S,graphDownload:d,dataDownload:w,prefix:$,suffix:X,stripType:M,language:Y,highlightColor:R,dotOpacity:T,showNAColor:j,minHeight:g,theme:q,ariaLabel:_,resetSelectionOnDoubleClick:f,styles:k,valueColor:H,detailsOnClick:h,classNames:A,animate:ie,dimmedOpacity:oe,precision:re,customLayers:b})}exports.StripChart=Se;
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const l=require("./index-CHPV5EwG-CTPQjnHt.cjs"),Y=require("react"),Bt=require("./index-DQA8q5sC.cjs"),zt=require("./Modal-JW_IExO3.cjs"),Jt=require("./index-Cno4Q0YE.cjs"),Kt=require("./Tooltip-4dJo4_AF.cjs"),pt=require("./checkIfNullOrUndefined-BCW3Y1ML.cjs"),Lt=require("./numberFormattingFunction-02t-wJta.cjs"),c=require("./Colors.cjs"),Qt=require("./string2HTML-CPGr_I5E.cjs"),Zt=require("./linear-BwPAspcq.cjs"),_t=require("./use-in-view-QcfiW0w3.cjs"),wt=require("./proxy-BxvUI_9l.cjs"),te=require("./index-DG2bgAva.cjs"),Xt=require("./uniqBy-O05lp2S5.cjs"),Yt=require("./GraphContainer-d8A46BK2.cjs"),oe=require("./EmptyState-sAEZ_5rU.cjs"),ie=require("./ColorLegendWithMouseOver.cjs"),ne=require("./GraphFooter.cjs"),re=require("./GraphHeader.cjs");function ee(e,t){if(e<2)return[];const i=t/(e-1);return Array.from({length:e},(N,C)=>C*i)}function le(e){const t=l.compilerRuntimeExports.c(97),{data:i,width:N,height:C,colors:n,colorDomain:s,radius:p,leftMargin:M,rightMargin:ht,topMargin:gt,bottomMargin:Mt,tooltip:rt,onSeriesMouseOver:_,highlightedDataPoints:r,selectedColor:tt,minValue:S,maxValue:D,onSeriesMouseClick:B,noOfTicks:lt,prefix:et,suffix:st,stripType:O,highlightColor:h,dotOpacity:mt,resetSelectionOnDoubleClick:E,detailsOnClick:x,styles:g,classNames:$,valueColor:d,animate:y,dimmedOpacity:J,precision:at,customLayers:w}=e,yt=M===void 0?20:M,xt=ht===void 0?20:ht,vt=gt===void 0?10:gt,Ot=Mt===void 0?10:Mt,Rt=Y.useRef(null);let ct;t[0]!==y.amount||t[1]!==y.once?(ct={once:y.once,amount:y.amount},t[0]=y.amount,t[1]=y.once,t[2]=ct):ct=t[2];const A=_t.useInView(Rt,ct),[ot,bt]=Y.useState(void 0),[v,jt]=Y.useState(void 0),[u,m]=Y.useState(void 0),[ut,Ct]=Y.useState(void 0);let ft;t[3]!==Ot||t[4]!==yt||t[5]!==xt||t[6]!==vt?(ft={top:vt,bottom:Ot,left:yt,right:xt},t[3]=Ot,t[4]=yt,t[5]=xt,t[6]=vt,t[7]=ft):ft=t[7];const f=ft,K=N-f.left-f.right,Q=C-f.top-f.bottom;let q,R,T,H,V,I,L,F,P,U,b;if(t[8]!==y.duration||t[9]!==$?.graphObjectValues||t[10]!==$?.yAxis?.labels||t[11]!==s||t[12]!==n||t[13]!==w||t[14]!==i||t[15]!==x||t[16]!==J||t[17]!==mt||t[18]!==Q||t[19]!==K||t[20]!==C||t[21]!==h||t[22]!==r||t[23]!==A||t[24]!==f.left||t[25]!==f.top||t[26]!==D||t[27]!==S||t[28]!==v||t[29]!==lt||t[30]!==B||t[31]!==_||t[32]!==at||t[33]!==et||t[34]!==p||t[35]!==E||t[36]!==tt||t[37]!==O||t[38]!==g?.graphObjectValues||t[39]!==g?.yAxis?.labels||t[40]!==st||t[41]!==d||t[42]!==N){const Nt=i.map(Ne);let Z;t[54]!==r?(Z=o=>{const a=(r||[]).indexOf(o.label);return a===-1?1/0:a},t[54]=r,t[55]=Z):Z=t[55];const St=Jt.orderBy(Nt,[Z],["desc"]);let nt;t[56]!==i||t[57]!==D?(nt=pt.checkIfNullOrUndefined(D)?Math.max(...i.filter(ke).map(Ie))<0?0:Math.max(...i.filter(Ve).map(Re)):D,t[56]=i,t[57]=D,t[58]=nt):nt=t[58];const Vt=nt;let dt;t[59]!==i||t[60]!==S?(dt=pt.checkIfNullOrUndefined(S)?Math.min(...i.filter(Ee).map(Me))>=0?0:Math.min(...i.filter(we).map(Ce)):S,t[59]=i,t[60]=S,t[61]=dt):dt=t[61];const It=dt,Et=Zt.linear().domain([It,Vt]).range([Q,0]).nice(),kt=ee(lt,Q);R=wt.motion.svg,T=`${N}px`,H=`${C}px`,V=`0 0 ${N} ${C}`,I="ltr",L=Rt,U=`translate(${f.left},${f.top})`,t[62]!==w?(b=w.filter(je).map(be),t[62]=w,t[63]=b):b=t[63],q=te.AnimatePresence,F=St.map(o=>l.jsxRuntimeExports.jsxs(wt.motion.g,{className:"undp-viz-g-with-hover",variants:{initial:{opacity:0,x:K/2,y:Et(0)},whileInView:{x:K/2,y:Et(o.position),opacity:tt?o.color&&n[s.indexOf(o.color)]===tt?.95:J:r.length!==0?r.indexOf(o.label)!==-1?.95:J:mt,transition:{duration:y.duration}}},initial:"initial",animate:A?"whileInView":"initial",exit:{opacity:0,transition:{duration:y.duration}},onMouseEnter:a=>{bt(o),Ct(a.clientY),m(a.clientX),_?.(o)},onClick:()=>{(B||x)&&(Bt.isEqual(v,o)&&E?(jt(void 0),B?.(void 0)):(jt(o),B?.(o)))},onMouseMove:a=>{bt(o),Ct(a.clientY),m(a.clientX)},onMouseLeave:()=>{bt(void 0),m(void 0),Ct(void 0),_?.(void 0)},children:[O==="dot"?l.jsxRuntimeExports.jsx(wt.motion.circle,{cy:0,cx:0,variants:{initial:{fill:h&&r?r.indexOf(o.label)!==-1?h:i.filter(Oe).length===0?n[0]:o.color?n[s.indexOf(o.color)]:c.Colors.gray:i.filter(ve).length===0?n[0]:o.color?n[s.indexOf(o.color)]:c.Colors.gray},whileInView:{fill:h&&r?r.indexOf(o.label)!==-1?h:i.filter(ye).length===0?n[0]:o.color?n[s.indexOf(o.color)]:c.Colors.gray:i.filter(ge).length===0?n[0]:o.color?n[s.indexOf(o.color)]:c.Colors.gray,transition:{duration:y.duration}}},initial:"initial",animate:A?"whileInView":"initial",exit:{opacity:0,transition:{duration:y.duration}},r:p}):l.jsxRuntimeExports.jsx(wt.motion.rect,{y:-1,height:2,variants:{initial:{x:0-p,width:p*2,fill:h&&r?r.indexOf(o.label)!==-1?h:i.filter(he).length===0?n[0]:o.color?n[s.indexOf(o.color)]:c.Colors.gray:i.filter(de).length===0?n[0]:o.color?n[s.indexOf(o.color)]:c.Colors.gray},whileInView:{x:0-p,width:p*2,fill:h&&r?r.indexOf(o.label)!==-1?h:i.filter(xe).length===0?n[0]:o.color?n[s.indexOf(o.color)]:c.Colors.gray:i.filter(me).length===0?n[0]:o.color?n[s.indexOf(o.color)]:c.Colors.gray,transition:{duration:y.duration}}},initial:"initial",animate:A?"whileInView":"initial",exit:{opacity:0,transition:{duration:y.duration}}}),r.length!==0&&r.indexOf(o.label)!==-1?l.jsxRuntimeExports.jsx(wt.motion.text,{y:0,dy:"0.33em",variants:{initial:{opacity:0,x:0+p+3,fill:d||(h&&r?r.indexOf(o.label)!==-1?h:i.filter(pe).length===0?n[0]:o.color?n[s.indexOf(o.color)]:c.Colors.gray:i.filter(fe).length===0?n[0]:o.color?n[s.indexOf(o.color)]:c.Colors.gray)},whileInView:{opacity:1,x:0+p+3,fill:d||(h&&r?r.indexOf(o.label)!==-1?h:i.filter(ue).length===0?n[0]:o.color?n[s.indexOf(o.color)]:c.Colors.gray:i.filter(ce).length===0?n[0]:o.color?n[s.indexOf(o.color)]:c.Colors.gray),transition:{duration:y.duration}}},initial:"initial",animate:A?"whileInView":"initial",exit:{opacity:0,transition:{duration:y.duration}},style:{textAnchor:"start",...g?.graphObjectValues||{}},className:l.mo("graph-value text-sm font-bold",$?.graphObjectValues),children:Lt.numberFormattingFunction(o.position,"NA",at,et,st)}):null]},o.label)),P=kt.map((o,a)=>l.jsxRuntimeExports.jsx("text",{y:o,x:K/2+p+5,style:{textAnchor:"start",...g?.yAxis?.labels||{}},className:l.mo("fill-primary-gray-550 dark:fill-primary-gray-500 text-xs",$?.yAxis?.labels),children:Lt.numberFormattingFunction(Et.invert(o),"NA",at,et,st)},a)),t[8]=y.duration,t[9]=$?.graphObjectValues,t[10]=$?.yAxis?.labels,t[11]=s,t[12]=n,t[13]=w,t[14]=i,t[15]=x,t[16]=J,t[17]=mt,t[18]=Q,t[19]=K,t[20]=C,t[21]=h,t[22]=r,t[23]=A,t[24]=f.left,t[25]=f.top,t[26]=D,t[27]=S,t[28]=v,t[29]=lt,t[30]=B,t[31]=_,t[32]=at,t[33]=et,t[34]=p,t[35]=E,t[36]=tt,t[37]=O,t[38]=g?.graphObjectValues,t[39]=g?.yAxis?.labels,t[40]=st,t[41]=d,t[42]=N,t[43]=q,t[44]=R,t[45]=T,t[46]=H,t[47]=V,t[48]=I,t[49]=L,t[50]=F,t[51]=P,t[52]=U,t[53]=b}else q=t[43],R=t[44],T=t[45],H=t[46],V=t[47],I=t[48],L=t[49],F=t[50],P=t[51],U=t[52],b=t[53];let G;t[64]!==q||t[65]!==F||t[66]!==P?(G=l.jsxRuntimeExports.jsxs(q,{children:[F,P]}),t[64]=q,t[65]=F,t[66]=P,t[67]=G):G=t[67];let W;t[68]!==w?(W=w.filter(ae).map(se),t[68]=w,t[69]=W):W=t[69];let j;t[70]!==G||t[71]!==W||t[72]!==U||t[73]!==b?(j=l.jsxRuntimeExports.jsxs("g",{transform:U,children:[b,G,W]}),t[70]=G,t[71]=W,t[72]=U,t[73]=b,t[74]=j):j=t[74];let X;t[75]!==R||t[76]!==T||t[77]!==H||t[78]!==V||t[79]!==I||t[80]!==L||t[81]!==j?(X=l.jsxRuntimeExports.jsx(R,{width:T,height:H,viewBox:V,direction:I,ref:L,children:j}),t[75]=R,t[76]=T,t[77]=H,t[78]=V,t[79]=I,t[80]=L,t[81]=j,t[82]=X):X=t[82];let z;t[83]!==$?.tooltip||t[84]!==u||t[85]!==ut||t[86]!==ot||t[87]!==g?.tooltip||t[88]!==rt?(z=ot&&rt&&u&&ut?l.jsxRuntimeExports.jsx(Kt.Tooltip,{data:ot,body:rt,xPos:u,yPos:ut,backgroundStyle:g?.tooltip,className:$?.tooltip}):null,t[83]=$?.tooltip,t[84]=u,t[85]=ut,t[86]=ot,t[87]=g?.tooltip,t[88]=rt,t[89]=z):z=t[89];let k;t[90]!==x||t[91]!==v?(k=x&&v!==void 0?l.jsxRuntimeExports.jsx(zt.le,{open:v!==void 0,onClose:()=>{jt(void 0)},children:l.jsxRuntimeExports.jsx("div",{className:"graph-modal-content m-0",dangerouslySetInnerHTML:typeof x=="string"?{__html:Qt.string2HTML(x,v)}:void 0,children:typeof x=="function"?x(v):null})}):null,t[90]=x,t[91]=v,t[92]=k):k=t[92];let it;return t[93]!==X||t[94]!==z||t[95]!==k?(it=l.jsxRuntimeExports.jsxs(l.jsxRuntimeExports.Fragment,{children:[X,z,k]}),t[93]=X,t[94]=z,t[95]=k,t[96]=it):it=t[96],it}function se(e){return e.layer}function ae(e){return e.position==="after"}function ce(e){return e.color}function ue(e){return e.color}function fe(e){return e.color}function pe(e){return e.color}function me(e){return e.color}function xe(e){return e.color}function de(e){return e.color}function he(e){return e.color}function ge(e){return e.color}function ye(e){return e.color}function ve(e){return e.color}function Oe(e){return e.color}function be(e){return e.layer}function je(e){return e.position==="before"}function Ce(e){return e.position}function we(e){return!pt.checkIfNullOrUndefined(e.position)}function Me(e){return e.position}function Ee(e){return!pt.checkIfNullOrUndefined(e.position)}function Re(e){return e.position}function Ve(e){return!pt.checkIfNullOrUndefined(e.position)}function Ie(e){return e.position}function ke(e){return!pt.checkIfNullOrUndefined(e.position)}function Ne(e,t){return{...e,id:`${t}`}}function Se(e){const t=l.compilerRuntimeExports.c(97),{data:i,width:N,height:C,colors:n,colorDomain:s,radius:p,leftMargin:M,rightMargin:ht,topMargin:gt,bottomMargin:Mt,tooltip:rt,onSeriesMouseOver:_,highlightedDataPoints:r,selectedColor:tt,minValue:S,maxValue:D,onSeriesMouseClick:B,prefix:lt,suffix:et,stripType:st,highlightColor:O,dotOpacity:h,resetSelectionOnDoubleClick:mt,detailsOnClick:E,styles:x,classNames:g,valueColor:$,animate:d,noOfTicks:y,dimmedOpacity:J,precision:at,customLayers:w}=e,yt=M===void 0?5:M,xt=ht===void 0?5:ht,vt=gt===void 0?10:gt,Ot=Mt===void 0?10:Mt,Rt=Y.useRef(null);let ct;t[0]!==d.amount||t[1]!==d.once?(ct={once:d.once,amount:d.amount},t[0]=d.amount,t[1]=d.once,t[2]=ct):ct=t[2];const A=_t.useInView(Rt,ct),[ot,bt]=Y.useState(void 0),[v,jt]=Y.useState(void 0),[u,m]=Y.useState(void 0),[ut,Ct]=Y.useState(void 0);let ft;t[3]!==Ot||t[4]!==yt||t[5]!==xt||t[6]!==vt?(ft={top:vt,bottom:Ot,left:yt,right:xt},t[3]=Ot,t[4]=yt,t[5]=xt,t[6]=vt,t[7]=ft):ft=t[7];const f=ft,K=N-f.left-f.right,Q=C-f.top-f.bottom;let q,R,T,H,V,I,L,F,P,U,b;if(t[8]!==d.duration||t[9]!==g?.graphObjectValues||t[10]!==g?.xAxis?.labels||t[11]!==s||t[12]!==n||t[13]!==w||t[14]!==i||t[15]!==E||t[16]!==J||t[17]!==h||t[18]!==Q||t[19]!==K||t[20]!==C||t[21]!==O||t[22]!==r||t[23]!==A||t[24]!==f.left||t[25]!==f.top||t[26]!==D||t[27]!==S||t[28]!==v||t[29]!==y||t[30]!==B||t[31]!==_||t[32]!==at||t[33]!==lt||t[34]!==p||t[35]!==mt||t[36]!==tt||t[37]!==st||t[38]!==x?.graphObjectValues||t[39]!==x?.xAxis?.labels||t[40]!==et||t[41]!==$||t[42]!==N){const Nt=i.map(io);let Z;t[54]!==r?(Z=o=>{const a=(r||[]).indexOf(o.label);return a===-1?1/0:a},t[54]=r,t[55]=Z):Z=t[55];const St=Jt.orderBy(Nt,[Z],["desc"]);let nt;t[56]!==i||t[57]!==D?(nt=pt.checkIfNullOrUndefined(D)?Math.max(...i.filter(oo).map(eo))<0?0:Math.max(...i.filter(to).map(_e)):D,t[56]=i,t[57]=D,t[58]=nt):nt=t[58];const Vt=nt;let dt;t[59]!==i||t[60]!==S?(dt=pt.checkIfNullOrUndefined(S)?Math.min(...i.filter(Ze).map(Qe))>=0?0:Math.min(...i.filter(Ke).map(Je)):S,t[59]=i,t[60]=S,t[61]=dt):dt=t[61];const It=dt,Et=Zt.linear().domain([It,Vt]).range([0,K]).nice(),kt=ee(y,K);R=wt.motion.svg,T=`${N}px`,H=`${C}px`,V=`0 0 ${N} ${C}`,I="ltr",L=Rt,U=`translate(${f.left},${f.top})`,t[62]!==w?(b=w.filter(ze).map(Be),t[62]=w,t[63]=b):b=t[63],q=te.AnimatePresence,F=St.map(o=>l.jsxRuntimeExports.jsxs(wt.motion.g,{className:"undp-viz-g-with-hover",variants:{initial:{opacity:0,x:Et(0),y:Q/2},whileInView:{x:Et(o.position),y:Q/2,opacity:tt?o.color&&n[s.indexOf(o.color)]===tt?.95:J:r.length!==0?r.indexOf(o.label)!==-1?.95:J:h,transition:{duration:d.duration}}},initial:"initial",animate:A?"whileInView":"initial",exit:{opacity:0,transition:{duration:d.duration}},onMouseEnter:a=>{bt(o),Ct(a.clientY),m(a.clientX),_?.(o)},onClick:()=>{(B||E)&&(Bt.isEqual(v,o)&&mt?(jt(void 0),B?.(void 0)):(jt(o),B?.(o)))},onMouseMove:a=>{bt(o),Ct(a.clientY),m(a.clientX)},onMouseLeave:()=>{bt(void 0),m(void 0),Ct(void 0),_?.(void 0)},children:[st==="dot"?l.jsxRuntimeExports.jsx(wt.motion.circle,{cy:0,cx:0,variants:{initial:{fill:O&&r?r.indexOf(o.label)!==-1?O:i.filter(Ye).length===0?n[0]:o.color?n[s.indexOf(o.color)]:c.Colors.gray:i.filter(Xe).length===0?n[0]:o.color?n[s.indexOf(o.color)]:c.Colors.gray},whileInView:{fill:O&&r?r.indexOf(o.label)!==-1?O:i.filter(We).length===0?n[0]:o.color?n[s.indexOf(o.color)]:c.Colors.gray:i.filter(Ge).length===0?n[0]:o.color?n[s.indexOf(o.color)]:c.Colors.gray,transition:{duration:d.duration}}},initial:"initial",animate:A?"whileInView":"initial",exit:{opacity:0,transition:{duration:d.duration}},r:p}):l.jsxRuntimeExports.jsx(wt.motion.rect,{x:-1,width:2,variants:{initial:{y:0-p,height:p*2,fill:O&&r?r.indexOf(o.label)!==-1?O:i.filter(Ue).length===0?n[0]:o.color?n[s.indexOf(o.color)]:c.Colors.gray:i.filter(Pe).length===0?n[0]:o.color?n[s.indexOf(o.color)]:c.Colors.gray},whileInView:{y:0-p,height:p*2,fill:O&&r?r.indexOf(o.label)!==-1?O:i.filter(Fe).length===0?n[0]:o.color?n[s.indexOf(o.color)]:c.Colors.gray:i.filter(Le).length===0?n[0]:o.color?n[s.indexOf(o.color)]:c.Colors.gray,transition:{duration:d.duration}}},initial:"initial",animate:A?"whileInView":"initial",exit:{opacity:0,transition:{duration:d.duration}}}),r.length!==0&&r.indexOf(o.label)!==-1?l.jsxRuntimeExports.jsx(wt.motion.text,{x:0,variants:{initial:{opacity:0,y:0-p-5,fill:$||(O&&r?r.indexOf(o.label)!==-1?O:i.filter(He).length===0?n[0]:o.color?n[s.indexOf(o.color)]:c.Colors.gray:i.filter(Te).length===0?n[0]:o.color?n[s.indexOf(o.color)]:c.Colors.gray)},whileInView:{opacity:1,y:0-p-5,fill:$||(O&&r?r.indexOf(o.label)!==-1?O:i.filter(qe).length===0?n[0]:o.color?n[s.indexOf(o.color)]:c.Colors.gray:i.filter(Ae).length===0?n[0]:o.color?n[s.indexOf(o.color)]:c.Colors.gray),transition:{duration:d.duration}}},initial:"initial",animate:A?"whileInView":"initial",exit:{opacity:0,transition:{duration:d.duration}},style:{textAnchor:"middle",...x?.graphObjectValues||{}},className:l.mo("graph-value text-sm font-bold",g?.graphObjectValues),children:Lt.numberFormattingFunction(o.position,"NA",at,lt,et)}):null]},o.label)),P=kt.map((o,a)=>l.jsxRuntimeExports.jsx("text",{x:o,y:Q/2+p,style:{textAnchor:a===0?"start":a===kt.length-1?"end":"middle",...x?.xAxis?.labels||{}},className:l.mo("fill-primary-gray-550 dark:fill-primary-gray-500 text-xs",g?.xAxis?.labels),dy:"1em",children:Lt.numberFormattingFunction(Et.invert(o),"NA",at,lt,et)},a)),t[8]=d.duration,t[9]=g?.graphObjectValues,t[10]=g?.xAxis?.labels,t[11]=s,t[12]=n,t[13]=w,t[14]=i,t[15]=E,t[16]=J,t[17]=h,t[18]=Q,t[19]=K,t[20]=C,t[21]=O,t[22]=r,t[23]=A,t[24]=f.left,t[25]=f.top,t[26]=D,t[27]=S,t[28]=v,t[29]=y,t[30]=B,t[31]=_,t[32]=at,t[33]=lt,t[34]=p,t[35]=mt,t[36]=tt,t[37]=st,t[38]=x?.graphObjectValues,t[39]=x?.xAxis?.labels,t[40]=et,t[41]=$,t[42]=N,t[43]=q,t[44]=R,t[45]=T,t[46]=H,t[47]=V,t[48]=I,t[49]=L,t[50]=F,t[51]=P,t[52]=U,t[53]=b}else q=t[43],R=t[44],T=t[45],H=t[46],V=t[47],I=t[48],L=t[49],F=t[50],P=t[51],U=t[52],b=t[53];let G;t[64]!==q||t[65]!==F||t[66]!==P?(G=l.jsxRuntimeExports.jsxs(q,{children:[F,P]}),t[64]=q,t[65]=F,t[66]=P,t[67]=G):G=t[67];let W;t[68]!==w?(W=w.filter($e).map(De),t[68]=w,t[69]=W):W=t[69];let j;t[70]!==G||t[71]!==W||t[72]!==U||t[73]!==b?(j=l.jsxRuntimeExports.jsxs("g",{transform:U,children:[b,G,W]}),t[70]=G,t[71]=W,t[72]=U,t[73]=b,t[74]=j):j=t[74];let X;t[75]!==R||t[76]!==T||t[77]!==H||t[78]!==V||t[79]!==I||t[80]!==L||t[81]!==j?(X=l.jsxRuntimeExports.jsx(R,{width:T,height:H,viewBox:V,direction:I,ref:L,children:j}),t[75]=R,t[76]=T,t[77]=H,t[78]=V,t[79]=I,t[80]=L,t[81]=j,t[82]=X):X=t[82];let z;t[83]!==g?.tooltip||t[84]!==u||t[85]!==ut||t[86]!==ot||t[87]!==x?.tooltip||t[88]!==rt?(z=ot&&rt&&u&&ut?l.jsxRuntimeExports.jsx(Kt.Tooltip,{data:ot,body:rt,xPos:u,yPos:ut,backgroundStyle:x?.tooltip,className:g?.tooltip}):null,t[83]=g?.tooltip,t[84]=u,t[85]=ut,t[86]=ot,t[87]=x?.tooltip,t[88]=rt,t[89]=z):z=t[89];let k;t[90]!==E||t[91]!==v?(k=E&&v!==void 0?l.jsxRuntimeExports.jsx(zt.le,{open:v!==void 0,onClose:()=>{jt(void 0)},children:l.jsxRuntimeExports.jsx("div",{className:"graph-modal-content m-0",dangerouslySetInnerHTML:typeof E=="string"?{__html:Qt.string2HTML(E,v)}:void 0,children:typeof E=="function"?E(v):null})}):null,t[90]=E,t[91]=v,t[92]=k):k=t[92];let it;return t[93]!==X||t[94]!==z||t[95]!==k?(it=l.jsxRuntimeExports.jsxs(l.jsxRuntimeExports.Fragment,{children:[X,z,k]}),t[93]=X,t[94]=z,t[95]=k,t[96]=it):it=t[96],it}function De(e){return e.layer}function $e(e){return e.position==="after"}function Ae(e){return e.color}function qe(e){return e.color}function Te(e){return e.color}function He(e){return e.color}function Le(e){return e.color}function Fe(e){return e.color}function Pe(e){return e.color}function Ue(e){return e.color}function Ge(e){return e.color}function We(e){return e.color}function Xe(e){return e.color}function Ye(e){return e.color}function Be(e){return e.layer}function ze(e){return e.position==="before"}function Je(e){return e.position}function Ke(e){return!pt.checkIfNullOrUndefined(e.position)}function Qe(e){return e.position}function Ze(e){return!pt.checkIfNullOrUndefined(e.position)}function _e(e){return e.position}function to(e){return!pt.checkIfNullOrUndefined(e.position)}function eo(e){return e.position}function oo(e){return!pt.checkIfNullOrUndefined(e.position)}function io(e,t){return{...e,id:`${t}`}}function no(e){const t=l.compilerRuntimeExports.c(80),{data:i,graphTitle:N,colors:C,sources:n,graphDescription:s,height:p,width:M,footNote:ht,colorDomain:gt,colorLegendTitle:Mt,radius:rt,padding:_,backgroundColor:r,leftMargin:tt,rightMargin:S,topMargin:D,bottomMargin:B,tooltip:lt,relativeHeight:et,onSeriesMouseOver:st,showColorScale:O,highlightedDataPoints:h,graphID:mt,minValue:E,maxValue:x,onSeriesMouseClick:g,noOfTicks:$,graphDownload:d,dataDownload:y,prefix:J,suffix:at,stripType:w,language:yt,highlightColor:xt,dotOpacity:vt,showNAColor:Ot,minHeight:Rt,theme:ct,ariaLabel:A,valueColor:ot,resetSelectionOnDoubleClick:bt,detailsOnClick:v,orientation:jt,styles:u,classNames:m,animate:ut,dimmedOpacity:Ct,precision:ft,customLayers:f}=e,K=rt===void 0?5:rt,Q=r===void 0?!1:r,q=O===void 0?!0:O;let R;t[0]!==h?(R=h===void 0?[]:h,t[0]=h,t[1]=R):R=t[1];const T=R,H=$===void 0?2:$,V=d===void 0?!1:d,I=y===void 0?!1:y,L=J===void 0?"":J,F=at===void 0?"":at,P=w===void 0?"dot":w,U=yt===void 0?"en":yt,b=vt===void 0?.3:vt,G=Ot===void 0?!0:Ot,W=Rt===void 0?0:Rt,j=ct===void 0?"light":ct,X=bt===void 0?!0:bt,z=jt===void 0?"vertical":jt,k=ut===void 0?!1:ut,it=Ct===void 0?.3:Ct,Nt=ft===void 0?2:ft;let Z;t[2]!==f?(Z=f===void 0?[]:f,t[2]=f,t[3]=Z):Z=t[3];const St=Z,nt=z==="horizontal"?Se:le,[Vt,dt]=Y.useState(0),[It,Et]=Y.useState(0),[kt,o]=Y.useState(void 0),a=Y.useRef(null),Ut=Y.useRef(null);let qt,Tt;t[4]===Symbol.for("react.memo_cache_sentinel")?(qt=()=>{const Gt=new ResizeObserver(Wt=>{dt(Wt[0].target.clientWidth||620),Et(Wt[0].target.clientHeight||480)});return a.current&&Gt.observe(a.current),()=>Gt.disconnect()},Tt=[],t[4]=qt,t[5]=Tt):(qt=t[4],Tt=t[5]),Y.useEffect(qt,Tt);const Ft=m?.graphContainer,Pt=u?.graphContainer;let Dt;t[6]!==m?.description||t[7]!==m?.title||t[8]!==i||t[9]!==I||t[10]!==s||t[11]!==V||t[12]!==N||t[13]!==u?.description||t[14]!==u?.title||t[15]!==M?(Dt=N||s||V||I?l.jsxRuntimeExports.jsx(re.GraphHeader,{styles:{title:u?.title,description:u?.description},classNames:{title:m?.title,description:m?.description},graphTitle:N,graphDescription:s,width:M,graphDownload:V?Ut:void 0,dataDownload:I?i.map(po).filter(fo).length>0?i.map(uo).filter(co):i.filter(ao):null}):null,t[6]=m?.description,t[7]=m?.title,t[8]=i,t[9]=I,t[10]=s,t[11]=V,t[12]=N,t[13]=u?.description,t[14]=u?.title,t[15]=M,t[16]=Dt):Dt=t[16];let $t;t[17]!==nt||t[18]!==k||t[19]!==B||t[20]!==m||t[21]!==gt||t[22]!==Mt||t[23]!==C||t[24]!==St||t[25]!==i||t[26]!==v||t[27]!==it||t[28]!==b||t[29]!==xt||t[30]!==T||t[31]!==tt||t[32]!==x||t[33]!==E||t[34]!==H||t[35]!==g||t[36]!==st||t[37]!==Nt||t[38]!==L||t[39]!==K||t[40]!==X||t[41]!==S||t[42]!==kt||t[43]!==q||t[44]!==G||t[45]!==P||t[46]!==u||t[47]!==F||t[48]!==It||t[49]!==Vt||t[50]!==j||t[51]!==lt||t[52]!==D||t[53]!==ot||t[54]!==M?($t=i.length===0?l.jsxRuntimeExports.jsx(oe.EmptyState,{}):l.jsxRuntimeExports.jsxs(l.jsxRuntimeExports.Fragment,{children:[q!==!1&&i.filter(so).length!==0?l.jsxRuntimeExports.jsx(ie.ColorLegendWithMouseOver,{width:M,colorLegendTitle:Mt,colors:C||c.Colors[j].categoricalColors.colors,colorDomain:gt||Xt.uniqBy(i,"color",!0),setSelectedColor:o,showNAColor:G,className:m?.colorLegend}):null,l.jsxRuntimeExports.jsx(Yt.GraphArea,{ref:a,children:Vt&&It?l.jsxRuntimeExports.jsx(nt,{data:i,width:Vt,height:It,colorDomain:i.filter(lo).length===0?[]:gt||Xt.uniqBy(i,"color",!0),colors:i.filter(ro).length===0?C?[C]:[c.Colors.primaryColors["blue-600"]]:C||c.Colors[j].categoricalColors.colors,selectedColor:kt,radius:K,leftMargin:tt,rightMargin:S,topMargin:D,bottomMargin:B,tooltip:lt,onSeriesMouseOver:st,highlightedDataPoints:T,minValue:E,maxValue:x,onSeriesMouseClick:g,prefix:L,suffix:F,stripType:P,highlightColor:xt,dotOpacity:b,resetSelectionOnDoubleClick:X,detailsOnClick:v,styles:u,classNames:m,valueColor:ot,animate:k===!0?{duration:.5,once:!0,amount:.5}:k||{duration:0,once:!0,amount:0},noOfTicks:H,dimmedOpacity:it,precision:Nt,customLayers:St}):null})]}),t[17]=nt,t[18]=k,t[19]=B,t[20]=m,t[21]=gt,t[22]=Mt,t[23]=C,t[24]=St,t[25]=i,t[26]=v,t[27]=it,t[28]=b,t[29]=xt,t[30]=T,t[31]=tt,t[32]=x,t[33]=E,t[34]=H,t[35]=g,t[36]=st,t[37]=Nt,t[38]=L,t[39]=K,t[40]=X,t[41]=S,t[42]=kt,t[43]=q,t[44]=G,t[45]=P,t[46]=u,t[47]=F,t[48]=It,t[49]=Vt,t[50]=j,t[51]=lt,t[52]=D,t[53]=ot,t[54]=M,t[55]=$t):$t=t[55];let At;t[56]!==m?.footnote||t[57]!==m?.source||t[58]!==ht||t[59]!==n||t[60]!==u?.footnote||t[61]!==u?.source||t[62]!==M?(At=n||ht?l.jsxRuntimeExports.jsx(ne.GraphFooter,{styles:{footnote:u?.footnote,source:u?.source},classNames:{footnote:m?.footnote,source:m?.source},sources:n,footNote:ht,width:M}):null,t[56]=m?.footnote,t[57]=m?.source,t[58]=ht,t[59]=n,t[60]=u?.footnote,t[61]=u?.source,t[62]=M,t[63]=At):At=t[63];let Ht;return t[64]!==A||t[65]!==Q||t[66]!==mt||t[67]!==p||t[68]!==U||t[69]!==W||t[70]!==_||t[71]!==et||t[72]!==Ft||t[73]!==Pt||t[74]!==Dt||t[75]!==$t||t[76]!==At||t[77]!==j||t[78]!==M?(Ht=l.jsxRuntimeExports.jsxs(Yt.GraphContainer,{className:Ft,style:Pt,id:mt,ref:Ut,"aria-label":A,backgroundColor:Q,theme:j,language:U,minHeight:W,width:M,height:p,relativeHeight:et,padding:_,children:[Dt,$t,At]}),t[64]=A,t[65]=Q,t[66]=mt,t[67]=p,t[68]=U,t[69]=W,t[70]=_,t[71]=et,t[72]=Ft,t[73]=Pt,t[74]=Dt,t[75]=$t,t[76]=At,t[77]=j,t[78]=M,t[79]=Ht):Ht=t[79],Ht}function ro(e){return e.color}function lo(e){return e.color}function so(e){return e.color}function ao(e){return e!==void 0}function co(e){return e!==void 0}function uo(e){return e.data}function fo(e){return e!==void 0}function po(e){return e.data}exports.StripChart=no;
2
2
  //# sourceMappingURL=StripChart.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"StripChart.cjs","sources":["../src/Utils/getTickPosition.ts","../src/Components/Graphs/StripChart/Horizontal/Graph.tsx","../src/Components/Graphs/StripChart/Horizontal/index.tsx","../src/Components/Graphs/StripChart/Vertical/Graph.tsx","../src/Components/Graphs/StripChart/Vertical/index.tsx","../src/Components/Graphs/StripChart/index.tsx"],"sourcesContent":["export function getTickPositions(count: number, width: number) {\r\n if (count < 2) return [];\r\n const step = width / (count - 1);\r\n return Array.from({ length: count }, (_, i) => i * step);\r\n}\r\n","import isEqual from 'fast-deep-equal';\r\nimport { useRef, useState } from 'react';\r\nimport { scaleLinear } from 'd3-scale';\r\nimport { cn } from '@undp/design-system-react/cn';\r\nimport { Modal } from '@undp/design-system-react/Modal';\r\nimport { AnimatePresence, motion, useInView } from 'motion/react';\r\nimport orderBy from 'lodash.orderby';\r\n\r\nimport {\r\n AnimateDataType,\r\n ClassNameObject,\r\n CustomLayerDataType,\r\n StripChartDataType,\r\n StyleObject,\r\n} from '@/Types';\r\nimport { Tooltip } from '@/Components/Elements/Tooltip';\r\nimport { checkIfNullOrUndefined } from '@/Utils/checkIfNullOrUndefined';\r\nimport { numberFormattingFunction } from '@/Utils/numberFormattingFunction';\r\nimport { Colors } from '@/Components/ColorPalette';\r\nimport { string2HTML } from '@/Utils/string2HTML';\r\nimport { getTickPositions } from '@/Utils/getTickPosition';\r\n\r\ninterface Props {\r\n data: StripChartDataType[];\r\n width: number;\r\n height: number;\r\n selectedColor?: string;\r\n colors: string[];\r\n colorDomain: string[];\r\n radius: number;\r\n leftMargin: number;\r\n rightMargin: number;\r\n topMargin: number;\r\n bottomMargin: number;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n tooltip?: string | ((_d: any) => React.ReactNode);\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseOver?: (_d: any) => void;\r\n highlightedDataPoints: (string | number)[];\r\n maxValue?: number;\r\n minValue?: number;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseClick?: (_d: any) => void;\r\n prefix: string;\r\n suffix: string;\r\n stripType: 'strip' | 'dot';\r\n highlightColor?: string;\r\n dotOpacity: number;\r\n resetSelectionOnDoubleClick: boolean;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n detailsOnClick?: string | ((_d: any) => React.ReactNode);\r\n styles?: StyleObject;\r\n classNames?: ClassNameObject;\r\n valueColor?: string;\r\n animate: AnimateDataType;\r\n noOfTicks: number;\r\n dimmedOpacity: number;\r\n precision: number;\r\n customLayers: CustomLayerDataType[];\r\n}\r\n\r\nexport function Graph(props: Props) {\r\n const {\r\n data,\r\n width,\r\n height,\r\n colors,\r\n colorDomain,\r\n radius,\r\n leftMargin,\r\n rightMargin,\r\n topMargin,\r\n bottomMargin,\r\n tooltip,\r\n onSeriesMouseOver,\r\n highlightedDataPoints,\r\n selectedColor,\r\n minValue,\r\n maxValue,\r\n onSeriesMouseClick,\r\n prefix,\r\n suffix,\r\n stripType,\r\n highlightColor,\r\n dotOpacity,\r\n resetSelectionOnDoubleClick,\r\n detailsOnClick,\r\n styles,\r\n classNames,\r\n valueColor,\r\n animate,\r\n noOfTicks,\r\n dimmedOpacity,\r\n precision,\r\n customLayers,\r\n } = props;\r\n const svgRef = useRef(null);\r\n const isInView = useInView(svgRef, {\r\n once: animate.once,\r\n amount: animate.amount,\r\n });\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const [mouseOverData, setMouseOverData] = useState<any>(undefined);\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const [mouseClickData, setMouseClickData] = useState<any>(undefined);\r\n const [eventX, setEventX] = useState<number | undefined>(undefined);\r\n const [eventY, setEventY] = useState<number | undefined>(undefined);\r\n const margin = {\r\n top: topMargin,\r\n bottom: bottomMargin,\r\n left: leftMargin,\r\n right: rightMargin,\r\n };\r\n const graphWidth = width - margin.left - margin.right;\r\n const graphHeight = height - margin.top - margin.bottom;\r\n\r\n const dataWithId = data.map((d, i) => ({ ...d, id: `${i}` }));\r\n\r\n const sortedData = orderBy(\r\n dataWithId,\r\n [\r\n item => {\r\n const index = (highlightedDataPoints || []).indexOf(item.label);\r\n return index === -1 ? Infinity : index;\r\n },\r\n ],\r\n ['desc'],\r\n );\r\n const xMaxValue = !checkIfNullOrUndefined(maxValue)\r\n ? (maxValue as number)\r\n : Math.max(...data.filter(d => !checkIfNullOrUndefined(d.position)).map(d => d.position)) < 0\r\n ? 0\r\n : Math.max(...data.filter(d => !checkIfNullOrUndefined(d.position)).map(d => d.position));\r\n const xMinValue = !checkIfNullOrUndefined(minValue)\r\n ? (minValue as number)\r\n : Math.min(...data.filter(d => !checkIfNullOrUndefined(d.position)).map(d => d.position)) >= 0\r\n ? 0\r\n : Math.min(...data.filter(d => !checkIfNullOrUndefined(d.position)).map(d => d.position));\r\n const x = scaleLinear().domain([xMinValue, xMaxValue]).range([0, graphWidth]).nice();\r\n const ticks = getTickPositions(noOfTicks, graphWidth);\r\n return (\r\n <>\r\n <motion.svg\r\n width={`${width}px`}\r\n height={`${height}px`}\r\n viewBox={`0 0 ${width} ${height}`}\r\n direction='ltr'\r\n ref={svgRef}\r\n >\r\n <g transform={`translate(${margin.left},${margin.top})`}>\r\n {customLayers.filter(d => d.position === 'before').map(d => d.layer)}\r\n <AnimatePresence>\r\n {sortedData.map(d => {\r\n return (\r\n <motion.g\r\n className='undp-viz-g-with-hover'\r\n key={d.label}\r\n variants={{\r\n initial: {\r\n opacity: 0,\r\n x: x(0),\r\n y: graphHeight / 2,\r\n },\r\n whileInView: {\r\n x: x(d.position),\r\n y: graphHeight / 2,\r\n opacity: selectedColor\r\n ? d.color\r\n ? colors[colorDomain.indexOf(d.color)] === selectedColor\r\n ? 0.95\r\n : dimmedOpacity\r\n : dimmedOpacity\r\n : highlightedDataPoints.length !== 0\r\n ? highlightedDataPoints.indexOf(d.label) !== -1\r\n ? 0.95\r\n : dimmedOpacity\r\n : dotOpacity,\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n onMouseEnter={event => {\r\n setMouseOverData(d);\r\n setEventY(event.clientY);\r\n setEventX(event.clientX);\r\n onSeriesMouseOver?.(d);\r\n }}\r\n onClick={() => {\r\n if (onSeriesMouseClick || detailsOnClick) {\r\n if (isEqual(mouseClickData, d) && resetSelectionOnDoubleClick) {\r\n setMouseClickData(undefined);\r\n onSeriesMouseClick?.(undefined);\r\n } else {\r\n setMouseClickData(d);\r\n onSeriesMouseClick?.(d);\r\n }\r\n }\r\n }}\r\n onMouseMove={event => {\r\n setMouseOverData(d);\r\n setEventY(event.clientY);\r\n setEventX(event.clientX);\r\n }}\r\n onMouseLeave={() => {\r\n setMouseOverData(undefined);\r\n setEventX(undefined);\r\n setEventY(undefined);\r\n onSeriesMouseOver?.(undefined);\r\n }}\r\n >\r\n {stripType === 'dot' ? (\r\n <motion.circle\r\n cy={0}\r\n cx={0}\r\n variants={{\r\n initial: {\r\n fill:\r\n highlightColor && highlightedDataPoints\r\n ? highlightedDataPoints.indexOf(d.label) !== -1\r\n ? highlightColor\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)]\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)],\r\n },\r\n whileInView: {\r\n fill:\r\n highlightColor && highlightedDataPoints\r\n ? highlightedDataPoints.indexOf(d.label) !== -1\r\n ? highlightColor\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)]\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)],\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n r={radius}\r\n />\r\n ) : (\r\n <motion.rect\r\n x={-1}\r\n width={2}\r\n variants={{\r\n initial: {\r\n y: 0 - radius,\r\n height: radius * 2,\r\n fill:\r\n highlightColor && highlightedDataPoints\r\n ? highlightedDataPoints.indexOf(d.label) !== -1\r\n ? highlightColor\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)]\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)],\r\n },\r\n whileInView: {\r\n y: 0 - radius,\r\n height: radius * 2,\r\n fill:\r\n highlightColor && highlightedDataPoints\r\n ? highlightedDataPoints.indexOf(d.label) !== -1\r\n ? highlightColor\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)]\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)],\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n />\r\n )}\r\n {highlightedDataPoints.length !== 0 ? (\r\n highlightedDataPoints.indexOf(d.label) !== -1 ? (\r\n <motion.text\r\n x={0}\r\n variants={{\r\n initial: {\r\n opacity: 0,\r\n y: 0 - radius - 5,\r\n fill:\r\n valueColor ||\r\n (highlightColor && highlightedDataPoints\r\n ? highlightedDataPoints.indexOf(d.label) !== -1\r\n ? highlightColor\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)]\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)]),\r\n },\r\n whileInView: {\r\n opacity: 1,\r\n y: 0 - radius - 5,\r\n fill:\r\n valueColor ||\r\n (highlightColor && highlightedDataPoints\r\n ? highlightedDataPoints.indexOf(d.label) !== -1\r\n ? highlightColor\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)]\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)]),\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n style={{\r\n textAnchor: 'middle',\r\n ...(styles?.graphObjectValues || {}),\r\n }}\r\n className={cn(\r\n 'graph-value text-sm font-bold',\r\n classNames?.graphObjectValues,\r\n )}\r\n >\r\n {numberFormattingFunction(d.position, 'NA', precision, prefix, suffix)}\r\n </motion.text>\r\n ) : null\r\n ) : null}\r\n </motion.g>\r\n );\r\n })}\r\n {ticks.map((tick, i) => (\r\n <text\r\n key={i}\r\n x={tick}\r\n y={graphHeight / 2 + radius}\r\n style={{\r\n textAnchor: i === 0 ? 'start' : i === ticks.length - 1 ? 'end' : 'middle',\r\n ...(styles?.xAxis?.labels || {}),\r\n }}\r\n className={cn(\r\n 'fill-primary-gray-550 dark:fill-primary-gray-500 text-xs',\r\n classNames?.xAxis?.labels,\r\n )}\r\n dy='1em'\r\n >\r\n {numberFormattingFunction(x.invert(tick), 'NA', precision, prefix, suffix)}\r\n </text>\r\n ))}\r\n </AnimatePresence>\r\n {customLayers.filter(d => d.position === 'after').map(d => d.layer)}\r\n </g>\r\n </motion.svg>\r\n {mouseOverData && tooltip && eventX && eventY ? (\r\n <Tooltip\r\n data={mouseOverData}\r\n body={tooltip}\r\n xPos={eventX}\r\n yPos={eventY}\r\n backgroundStyle={styles?.tooltip}\r\n className={classNames?.tooltip}\r\n />\r\n ) : null}\r\n {detailsOnClick && mouseClickData !== undefined ? (\r\n <Modal\r\n open={mouseClickData !== undefined}\r\n onClose={() => {\r\n setMouseClickData(undefined);\r\n }}\r\n >\r\n <div\r\n className='graph-modal-content m-0'\r\n dangerouslySetInnerHTML={\r\n typeof detailsOnClick === 'string'\r\n ? { __html: string2HTML(detailsOnClick, mouseClickData) }\r\n : undefined\r\n }\r\n >\r\n {typeof detailsOnClick === 'function' ? detailsOnClick(mouseClickData) : null}\r\n </div>\r\n </Modal>\r\n ) : null}\r\n </>\r\n );\r\n}\r\n","import { useState, useRef, useEffect } from 'react';\r\nimport { cn } from '@undp/design-system-react/cn';\r\n\r\nimport { Graph } from './Graph';\r\n\r\nimport {\r\n Languages,\r\n SourcesDataType,\r\n StripChartDataType,\r\n StyleObject,\r\n ClassNameObject,\r\n CustomLayerDataType,\r\n AnimateDataType,\r\n} from '@/Types';\r\nimport { GraphFooter } from '@/Components/Elements/GraphFooter';\r\nimport { GraphHeader } from '@/Components/Elements/GraphHeader';\r\nimport { ColorLegendWithMouseOver } from '@/Components/Elements/ColorLegendWithMouseOver';\r\nimport { Colors } from '@/Components/ColorPalette';\r\nimport { EmptyState } from '@/Components/Elements/EmptyState';\r\nimport { uniqBy } from '@/Utils/uniqBy';\r\n\r\ninterface Props {\r\n data: StripChartDataType[];\r\n graphTitle?: string | React.ReactNode;\r\n graphDescription?: string | React.ReactNode;\r\n footNote?: string | React.ReactNode;\r\n width?: number;\r\n height?: number;\r\n sources?: SourcesDataType[];\r\n stripType?: 'strip' | 'dot';\r\n colors?: string | string[];\r\n colorDomain?: string[];\r\n colorLegendTitle?: string;\r\n radius?: number;\r\n backgroundColor?: string | boolean;\r\n padding?: string;\r\n leftMargin?: number;\r\n rightMargin?: number;\r\n topMargin?: number;\r\n bottomMargin?: number;\r\n relativeHeight?: number;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n tooltip?: string | ((_d: any) => React.ReactNode);\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseOver?: (_d: any) => void;\r\n highlightedDataPoints?: (string | number)[];\r\n showColorScale?: boolean;\r\n graphID?: string;\r\n maxValue?: number;\r\n minValue?: number;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseClick?: (_d: any) => void;\r\n graphDownload?: boolean;\r\n dataDownload?: boolean;\r\n prefix?: string;\r\n suffix?: string;\r\n language?: Languages;\r\n highlightColor?: string;\r\n dotOpacity?: number;\r\n showNAColor?: boolean;\r\n minHeight?: number;\r\n theme?: 'light' | 'dark';\r\n ariaLabel?: string;\r\n resetSelectionOnDoubleClick?: boolean;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n detailsOnClick?: string | ((_d: any) => React.ReactNode);\r\n styles?: StyleObject;\r\n classNames?: ClassNameObject;\r\n valueColor?: string;\r\n animate?: boolean | AnimateDataType;\r\n noOfTicks?: number;\r\n dimmedOpacity?: number;\r\n precision?: number;\r\n customLayers?: CustomLayerDataType[];\r\n}\r\n\r\nexport function HorizontalStripChart(props: Props) {\r\n const {\r\n data,\r\n graphTitle,\r\n colors,\r\n sources,\r\n graphDescription,\r\n height,\r\n width,\r\n footNote,\r\n colorDomain,\r\n colorLegendTitle,\r\n radius = 5,\r\n padding,\r\n backgroundColor = false,\r\n leftMargin = 5,\r\n rightMargin = 5,\r\n topMargin = 10,\r\n bottomMargin = 10,\r\n tooltip,\r\n relativeHeight,\r\n onSeriesMouseOver,\r\n showColorScale = true,\r\n highlightedDataPoints = [],\r\n graphID,\r\n minValue,\r\n maxValue,\r\n onSeriesMouseClick,\r\n graphDownload = false,\r\n dataDownload = false,\r\n prefix = '',\r\n suffix = '',\r\n stripType = 'dot',\r\n language = 'en',\r\n highlightColor,\r\n dotOpacity = 0.3,\r\n showNAColor = true,\r\n minHeight = 0,\r\n theme = 'light',\r\n ariaLabel,\r\n resetSelectionOnDoubleClick = true,\r\n detailsOnClick,\r\n styles,\r\n classNames,\r\n valueColor,\r\n animate = false,\r\n noOfTicks = 2,\r\n dimmedOpacity = 0.3,\r\n precision = 2,\r\n customLayers = [],\r\n } = props;\r\n\r\n const [svgWidth, setSvgWidth] = useState(0);\r\n const [svgHeight, setSvgHeight] = useState(0);\r\n const [selectedColor, setSelectedColor] = useState<string | undefined>(undefined);\r\n\r\n const graphDiv = useRef<HTMLDivElement>(null);\r\n const graphParentDiv = useRef<HTMLDivElement>(null);\r\n useEffect(() => {\r\n const resizeObserver = new ResizeObserver(entries => {\r\n setSvgWidth(width || entries[0].target.clientWidth || 620);\r\n setSvgHeight(height || entries[0].target.clientHeight || 480);\r\n });\r\n if (graphDiv.current) {\r\n setSvgHeight(graphDiv.current.clientHeight || 480);\r\n setSvgWidth(graphDiv.current.clientWidth || 620);\r\n if (!width) resizeObserver.observe(graphDiv.current);\r\n }\r\n return () => resizeObserver.disconnect();\r\n }, [width, height]);\r\n return (\r\n <div\r\n className={`${theme || 'light'} flex ${width ? 'w-fit grow-0' : 'w-full grow'}`}\r\n dir={language === 'he' || language === 'ar' ? 'rtl' : undefined}\r\n >\r\n <div\r\n className={cn(\r\n `${\r\n !backgroundColor\r\n ? 'bg-transparent '\r\n : backgroundColor === true\r\n ? 'bg-primary-gray-200 dark:bg-primary-gray-650 '\r\n : ''\r\n }ml-auto mr-auto flex flex-col grow h-inherit ${language || 'en'}`,\r\n width ? 'w-fit' : 'w-full',\r\n classNames?.graphContainer,\r\n )}\r\n style={{\r\n ...(styles?.graphContainer || {}),\r\n ...(backgroundColor && backgroundColor !== true ? { backgroundColor } : {}),\r\n }}\r\n id={graphID}\r\n ref={graphParentDiv}\r\n aria-label={\r\n ariaLabel ||\r\n `${\r\n graphTitle ? `The graph shows ${graphTitle}. ` : ''\r\n }This is a strip chart showing distribution of data along the horizontal axis. Each dot represents an individual data point, helping to visualize the spread and clustering of values.${\r\n graphDescription ? ` ${graphDescription}` : ''\r\n }`\r\n }\r\n >\r\n <div\r\n className='flex grow'\r\n style={{ padding: backgroundColor ? padding || '1rem' : padding || 0 }}\r\n >\r\n <div className='flex flex-col w-full gap-4 grow justify-between'>\r\n {graphTitle || graphDescription || graphDownload || dataDownload ? (\r\n <GraphHeader\r\n styles={{\r\n title: styles?.title,\r\n description: styles?.description,\r\n }}\r\n classNames={{\r\n title: classNames?.title,\r\n description: classNames?.description,\r\n }}\r\n graphTitle={graphTitle}\r\n graphDescription={graphDescription}\r\n width={width}\r\n graphDownload={graphDownload ? graphParentDiv.current : undefined}\r\n dataDownload={\r\n dataDownload\r\n ? data.map(d => d.data).filter(d => d !== undefined).length > 0\r\n ? data.map(d => d.data).filter(d => d !== undefined)\r\n : data.filter(d => d !== undefined)\r\n : null\r\n }\r\n />\r\n ) : null}\r\n <div className='grow flex flex-col justify-center gap-3 w-full'>\r\n {data.length === 0 ? (\r\n <EmptyState />\r\n ) : (\r\n <>\r\n {showColorScale !== false && data.filter(el => el.color).length !== 0 ? (\r\n <ColorLegendWithMouseOver\r\n width={width}\r\n colorLegendTitle={colorLegendTitle}\r\n colors={\r\n (colors as string[] | undefined) || Colors[theme].categoricalColors.colors\r\n }\r\n colorDomain={colorDomain || (uniqBy(data, 'color', true) as string[])}\r\n setSelectedColor={setSelectedColor}\r\n showNAColor={\r\n showNAColor === undefined || showNAColor === null ? true : showNAColor\r\n }\r\n />\r\n ) : null}\r\n <div\r\n className='flex flex-col grow justify-center w-full leading-0'\r\n ref={graphDiv}\r\n aria-label='Graph area'\r\n >\r\n {(width || svgWidth) && (height || svgHeight) ? (\r\n <Graph\r\n data={data}\r\n width={width || svgWidth}\r\n height={Math.max(\r\n minHeight,\r\n height ||\r\n (relativeHeight\r\n ? minHeight\r\n ? (width || svgWidth) * relativeHeight > minHeight\r\n ? (width || svgWidth) * relativeHeight\r\n : minHeight\r\n : (width || svgWidth) * relativeHeight\r\n : svgHeight),\r\n )}\r\n colorDomain={\r\n data.filter(el => el.color).length === 0\r\n ? []\r\n : colorDomain || (uniqBy(data, 'color', true) as string[])\r\n }\r\n colors={\r\n data.filter(el => el.color).length === 0\r\n ? colors\r\n ? [colors as string]\r\n : [Colors.primaryColors['blue-600']]\r\n : (colors as string[] | undefined) ||\r\n Colors[theme].categoricalColors.colors\r\n }\r\n selectedColor={selectedColor}\r\n radius={radius}\r\n leftMargin={leftMargin}\r\n rightMargin={rightMargin}\r\n topMargin={topMargin}\r\n bottomMargin={bottomMargin}\r\n tooltip={tooltip}\r\n onSeriesMouseOver={onSeriesMouseOver}\r\n highlightedDataPoints={highlightedDataPoints}\r\n minValue={minValue}\r\n maxValue={maxValue}\r\n onSeriesMouseClick={onSeriesMouseClick}\r\n prefix={prefix}\r\n suffix={suffix}\r\n stripType={stripType}\r\n highlightColor={highlightColor}\r\n dotOpacity={dotOpacity}\r\n resetSelectionOnDoubleClick={resetSelectionOnDoubleClick}\r\n detailsOnClick={detailsOnClick}\r\n styles={styles}\r\n classNames={classNames}\r\n valueColor={valueColor}\r\n animate={\r\n animate === true\r\n ? { duration: 0.5, once: true, amount: 0.5 }\r\n : animate || { duration: 0, once: true, amount: 0 }\r\n }\r\n noOfTicks={noOfTicks}\r\n dimmedOpacity={dimmedOpacity}\r\n precision={precision}\r\n customLayers={customLayers}\r\n />\r\n ) : null}\r\n </div>\r\n </>\r\n )}\r\n </div>\r\n {sources || footNote ? (\r\n <GraphFooter\r\n styles={{ footnote: styles?.footnote, source: styles?.source }}\r\n classNames={{\r\n footnote: classNames?.footnote,\r\n source: classNames?.source,\r\n }}\r\n sources={sources}\r\n footNote={footNote}\r\n width={width}\r\n />\r\n ) : null}\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n );\r\n}\r\n","import isEqual from 'fast-deep-equal';\r\nimport { useRef, useState } from 'react';\r\nimport { scaleLinear } from 'd3-scale';\r\nimport { cn } from '@undp/design-system-react/cn';\r\nimport { Modal } from '@undp/design-system-react/Modal';\r\nimport { AnimatePresence, motion, useInView } from 'motion/react';\r\nimport orderBy from 'lodash.orderby';\r\n\r\nimport {\r\n AnimateDataType,\r\n ClassNameObject,\r\n CustomLayerDataType,\r\n StripChartDataType,\r\n StyleObject,\r\n} from '@/Types';\r\nimport { Tooltip } from '@/Components/Elements/Tooltip';\r\nimport { checkIfNullOrUndefined } from '@/Utils/checkIfNullOrUndefined';\r\nimport { numberFormattingFunction } from '@/Utils/numberFormattingFunction';\r\nimport { Colors } from '@/Components/ColorPalette';\r\nimport { string2HTML } from '@/Utils/string2HTML';\r\nimport { getTickPositions } from '@/Utils/getTickPosition';\r\n\r\ninterface Props {\r\n data: StripChartDataType[];\r\n width: number;\r\n height: number;\r\n selectedColor?: string;\r\n colors: string[];\r\n colorDomain: string[];\r\n radius: number;\r\n leftMargin: number;\r\n rightMargin: number;\r\n topMargin: number;\r\n bottomMargin: number;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n tooltip?: string | ((_d: any) => React.ReactNode);\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseOver?: (_d: any) => void;\r\n highlightedDataPoints: (string | number)[];\r\n maxValue?: number;\r\n minValue?: number;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseClick?: (_d: any) => void;\r\n prefix: string;\r\n suffix: string;\r\n stripType: 'strip' | 'dot';\r\n highlightColor?: string;\r\n dotOpacity: number;\r\n resetSelectionOnDoubleClick: boolean;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n detailsOnClick?: string | ((_d: any) => React.ReactNode);\r\n styles?: StyleObject;\r\n classNames?: ClassNameObject;\r\n valueColor?: string;\r\n animate: AnimateDataType;\r\n noOfTicks: number;\r\n dimmedOpacity: number;\r\n precision: number;\r\n customLayers: CustomLayerDataType[];\r\n}\r\n\r\nexport function Graph(props: Props) {\r\n const {\r\n data,\r\n width,\r\n height,\r\n colors,\r\n colorDomain,\r\n radius,\r\n leftMargin,\r\n rightMargin,\r\n topMargin,\r\n bottomMargin,\r\n tooltip,\r\n onSeriesMouseOver,\r\n highlightedDataPoints,\r\n selectedColor,\r\n minValue,\r\n maxValue,\r\n onSeriesMouseClick,\r\n noOfTicks,\r\n prefix,\r\n suffix,\r\n stripType,\r\n highlightColor,\r\n dotOpacity,\r\n resetSelectionOnDoubleClick,\r\n detailsOnClick,\r\n styles,\r\n classNames,\r\n valueColor,\r\n animate,\r\n dimmedOpacity,\r\n precision,\r\n customLayers,\r\n } = props;\r\n const svgRef = useRef(null);\r\n const isInView = useInView(svgRef, {\r\n once: animate.once,\r\n amount: animate.amount,\r\n });\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const [mouseOverData, setMouseOverData] = useState<any>(undefined);\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const [mouseClickData, setMouseClickData] = useState<any>(undefined);\r\n const [eventX, setEventX] = useState<number | undefined>(undefined);\r\n const [eventY, setEventY] = useState<number | undefined>(undefined);\r\n const margin = {\r\n top: topMargin,\r\n bottom: bottomMargin,\r\n left: leftMargin,\r\n right: rightMargin,\r\n };\r\n const graphWidth = width - margin.left - margin.right;\r\n const graphHeight = height - margin.top - margin.bottom;\r\n\r\n const dataWithId = data.map((d, i) => ({ ...d, id: `${i}` }));\r\n\r\n const sortedData = orderBy(\r\n dataWithId,\r\n [\r\n item => {\r\n const index = (highlightedDataPoints || []).indexOf(item.label);\r\n return index === -1 ? Infinity : index;\r\n },\r\n ],\r\n ['desc'],\r\n );\r\n const yMaxValue = !checkIfNullOrUndefined(maxValue)\r\n ? (maxValue as number)\r\n : Math.max(...data.filter(d => !checkIfNullOrUndefined(d.position)).map(d => d.position)) < 0\r\n ? 0\r\n : Math.max(...data.filter(d => !checkIfNullOrUndefined(d.position)).map(d => d.position));\r\n const yMinValue = !checkIfNullOrUndefined(minValue)\r\n ? (minValue as number)\r\n : Math.min(...data.filter(d => !checkIfNullOrUndefined(d.position)).map(d => d.position)) >= 0\r\n ? 0\r\n : Math.min(...data.filter(d => !checkIfNullOrUndefined(d.position)).map(d => d.position));\r\n const y = scaleLinear().domain([yMinValue, yMaxValue]).range([graphHeight, 0]).nice();\r\n const ticks = getTickPositions(noOfTicks, graphHeight);\r\n return (\r\n <>\r\n <motion.svg\r\n width={`${width}px`}\r\n height={`${height}px`}\r\n viewBox={`0 0 ${width} ${height}`}\r\n direction='ltr'\r\n ref={svgRef}\r\n >\r\n <g transform={`translate(${margin.left},${margin.top})`}>\r\n {customLayers.filter(d => d.position === 'before').map(d => d.layer)}\r\n <AnimatePresence>\r\n {sortedData.map(d => {\r\n return (\r\n <motion.g\r\n className='undp-viz-g-with-hover'\r\n key={d.label}\r\n variants={{\r\n initial: {\r\n opacity: 0,\r\n x: graphWidth / 2,\r\n y: y(0),\r\n },\r\n whileInView: {\r\n x: graphWidth / 2,\r\n y: y(d.position),\r\n opacity: selectedColor\r\n ? d.color\r\n ? colors[colorDomain.indexOf(d.color)] === selectedColor\r\n ? 0.95\r\n : dimmedOpacity\r\n : dimmedOpacity\r\n : highlightedDataPoints.length !== 0\r\n ? highlightedDataPoints.indexOf(d.label) !== -1\r\n ? 0.95\r\n : dimmedOpacity\r\n : dotOpacity,\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n onMouseEnter={event => {\r\n setMouseOverData(d);\r\n setEventY(event.clientY);\r\n setEventX(event.clientX);\r\n onSeriesMouseOver?.(d);\r\n }}\r\n onClick={() => {\r\n if (onSeriesMouseClick || detailsOnClick) {\r\n if (isEqual(mouseClickData, d) && resetSelectionOnDoubleClick) {\r\n setMouseClickData(undefined);\r\n onSeriesMouseClick?.(undefined);\r\n } else {\r\n setMouseClickData(d);\r\n onSeriesMouseClick?.(d);\r\n }\r\n }\r\n }}\r\n onMouseMove={event => {\r\n setMouseOverData(d);\r\n setEventY(event.clientY);\r\n setEventX(event.clientX);\r\n }}\r\n onMouseLeave={() => {\r\n setMouseOverData(undefined);\r\n setEventX(undefined);\r\n setEventY(undefined);\r\n onSeriesMouseOver?.(undefined);\r\n }}\r\n >\r\n {stripType === 'dot' ? (\r\n <motion.circle\r\n cy={0}\r\n cx={0}\r\n variants={{\r\n initial: {\r\n fill:\r\n highlightColor && highlightedDataPoints\r\n ? highlightedDataPoints.indexOf(d.label) !== -1\r\n ? highlightColor\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)]\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)],\r\n },\r\n whileInView: {\r\n fill:\r\n highlightColor && highlightedDataPoints\r\n ? highlightedDataPoints.indexOf(d.label) !== -1\r\n ? highlightColor\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)]\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)],\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n r={radius}\r\n />\r\n ) : (\r\n <motion.rect\r\n y={-1}\r\n height={2}\r\n variants={{\r\n initial: {\r\n x: 0 - radius,\r\n width: radius * 2,\r\n fill:\r\n highlightColor && highlightedDataPoints\r\n ? highlightedDataPoints.indexOf(d.label) !== -1\r\n ? highlightColor\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)]\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)],\r\n },\r\n whileInView: {\r\n x: 0 - radius,\r\n width: radius * 2,\r\n fill:\r\n highlightColor && highlightedDataPoints\r\n ? highlightedDataPoints.indexOf(d.label) !== -1\r\n ? highlightColor\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)]\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)],\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n />\r\n )}\r\n {highlightedDataPoints.length !== 0 ? (\r\n highlightedDataPoints.indexOf(d.label) !== -1 ? (\r\n <motion.text\r\n y={0}\r\n dy='0.33em'\r\n variants={{\r\n initial: {\r\n opacity: 0,\r\n x: 0 + radius + 3,\r\n fill:\r\n valueColor ||\r\n (highlightColor && highlightedDataPoints\r\n ? highlightedDataPoints.indexOf(d.label) !== -1\r\n ? highlightColor\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)]\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)]),\r\n },\r\n whileInView: {\r\n opacity: 1,\r\n x: 0 + radius + 3,\r\n fill:\r\n valueColor ||\r\n (highlightColor && highlightedDataPoints\r\n ? highlightedDataPoints.indexOf(d.label) !== -1\r\n ? highlightColor\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)]\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)]),\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n style={{\r\n textAnchor: 'start',\r\n ...(styles?.graphObjectValues || {}),\r\n }}\r\n className={cn(\r\n 'graph-value text-sm font-bold',\r\n classNames?.graphObjectValues,\r\n )}\r\n >\r\n {numberFormattingFunction(d.position, 'NA', precision, prefix, suffix)}\r\n </motion.text>\r\n ) : null\r\n ) : null}\r\n </motion.g>\r\n );\r\n })}\r\n {ticks.map((tick, i) => (\r\n <text\r\n key={i}\r\n y={tick}\r\n x={graphWidth / 2 + radius + 5}\r\n style={{\r\n textAnchor: 'start',\r\n ...(styles?.yAxis?.labels || {}),\r\n }}\r\n className={cn(\r\n 'fill-primary-gray-550 dark:fill-primary-gray-500 text-xs',\r\n classNames?.yAxis?.labels,\r\n )}\r\n >\r\n {numberFormattingFunction(y.invert(tick), 'NA', precision, prefix, suffix)}\r\n </text>\r\n ))}\r\n </AnimatePresence>\r\n {customLayers.filter(d => d.position === 'after').map(d => d.layer)}\r\n </g>\r\n </motion.svg>\r\n {mouseOverData && tooltip && eventX && eventY ? (\r\n <Tooltip\r\n data={mouseOverData}\r\n body={tooltip}\r\n xPos={eventX}\r\n yPos={eventY}\r\n backgroundStyle={styles?.tooltip}\r\n className={classNames?.tooltip}\r\n />\r\n ) : null}\r\n {detailsOnClick && mouseClickData !== undefined ? (\r\n <Modal\r\n open={mouseClickData !== undefined}\r\n onClose={() => {\r\n setMouseClickData(undefined);\r\n }}\r\n >\r\n <div\r\n className='graph-modal-content m-0'\r\n dangerouslySetInnerHTML={\r\n typeof detailsOnClick === 'string'\r\n ? { __html: string2HTML(detailsOnClick, mouseClickData) }\r\n : undefined\r\n }\r\n >\r\n {typeof detailsOnClick === 'function' ? detailsOnClick(mouseClickData) : null}\r\n </div>\r\n </Modal>\r\n ) : null}\r\n </>\r\n );\r\n}\r\n","import { useState, useRef, useEffect } from 'react';\r\nimport { cn } from '@undp/design-system-react/cn';\r\n\r\nimport { Graph } from './Graph';\r\n\r\nimport {\r\n Languages,\r\n SourcesDataType,\r\n StripChartDataType,\r\n StyleObject,\r\n ClassNameObject,\r\n CustomLayerDataType,\r\n AnimateDataType,\r\n} from '@/Types';\r\nimport { GraphFooter } from '@/Components/Elements/GraphFooter';\r\nimport { GraphHeader } from '@/Components/Elements/GraphHeader';\r\nimport { ColorLegendWithMouseOver } from '@/Components/Elements/ColorLegendWithMouseOver';\r\nimport { Colors } from '@/Components/ColorPalette';\r\nimport { EmptyState } from '@/Components/Elements/EmptyState';\r\nimport { uniqBy } from '@/Utils/uniqBy';\r\n\r\ninterface Props {\r\n data: StripChartDataType[];\r\n graphTitle?: string | React.ReactNode;\r\n graphDescription?: string | React.ReactNode;\r\n footNote?: string | React.ReactNode;\r\n width?: number;\r\n height?: number;\r\n sources?: SourcesDataType[];\r\n colors?: string | string[];\r\n colorDomain?: string[];\r\n colorLegendTitle?: string;\r\n radius?: number;\r\n backgroundColor?: string | boolean;\r\n padding?: string;\r\n leftMargin?: number;\r\n rightMargin?: number;\r\n topMargin?: number;\r\n bottomMargin?: number;\r\n relativeHeight?: number;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n tooltip?: string | ((_d: any) => React.ReactNode);\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseOver?: (_d: any) => void;\r\n highlightedDataPoints?: (string | number)[];\r\n showColorScale?: boolean;\r\n graphID?: string;\r\n maxValue?: number;\r\n minValue?: number;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseClick?: (_d: any) => void;\r\n graphDownload?: boolean;\r\n dataDownload?: boolean;\r\n prefix?: string;\r\n suffix?: string;\r\n stripType?: 'strip' | 'dot';\r\n language?: Languages;\r\n highlightColor?: string;\r\n dotOpacity?: number;\r\n showNAColor?: boolean;\r\n minHeight?: number;\r\n theme?: 'light' | 'dark';\r\n ariaLabel?: string;\r\n resetSelectionOnDoubleClick?: boolean;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n detailsOnClick?: string | ((_d: any) => React.ReactNode);\r\n styles?: StyleObject;\r\n classNames?: ClassNameObject;\r\n valueColor?: string;\r\n animate?: boolean | AnimateDataType;\r\n noOfTicks?: number;\r\n dimmedOpacity?: number;\r\n precision?: number;\r\n customLayers?: CustomLayerDataType[];\r\n}\r\n\r\nexport function VerticalStripChart(props: Props) {\r\n const {\r\n data,\r\n graphTitle,\r\n colors,\r\n sources,\r\n graphDescription,\r\n height,\r\n width,\r\n footNote,\r\n colorDomain,\r\n colorLegendTitle,\r\n radius = 5,\r\n padding,\r\n backgroundColor = false,\r\n leftMargin = 20,\r\n rightMargin = 20,\r\n topMargin = 10,\r\n bottomMargin = 10,\r\n tooltip,\r\n relativeHeight,\r\n onSeriesMouseOver,\r\n showColorScale = true,\r\n highlightedDataPoints = [],\r\n graphID,\r\n minValue,\r\n maxValue,\r\n onSeriesMouseClick,\r\n graphDownload = false,\r\n dataDownload = false,\r\n prefix = '',\r\n suffix = '',\r\n stripType = 'dot',\r\n language = 'en',\r\n highlightColor,\r\n dotOpacity = 0.3,\r\n showNAColor = true,\r\n minHeight = 0,\r\n theme = 'light',\r\n ariaLabel,\r\n resetSelectionOnDoubleClick = true,\r\n detailsOnClick,\r\n styles,\r\n classNames,\r\n valueColor,\r\n animate = false,\r\n noOfTicks = 2,\r\n dimmedOpacity = 0.3,\r\n precision = 2,\r\n customLayers = [],\r\n } = props;\r\n\r\n const [svgWidth, setSvgWidth] = useState(0);\r\n const [svgHeight, setSvgHeight] = useState(0);\r\n const [selectedColor, setSelectedColor] = useState<string | undefined>(undefined);\r\n\r\n const graphDiv = useRef<HTMLDivElement>(null);\r\n const graphParentDiv = useRef<HTMLDivElement>(null);\r\n useEffect(() => {\r\n const resizeObserver = new ResizeObserver(entries => {\r\n setSvgWidth(width || entries[0].target.clientWidth || 620);\r\n setSvgHeight(height || entries[0].target.clientHeight || 480);\r\n });\r\n if (graphDiv.current) {\r\n setSvgHeight(graphDiv.current.clientHeight || 480);\r\n setSvgWidth(graphDiv.current.clientWidth || 620);\r\n if (!width) resizeObserver.observe(graphDiv.current);\r\n }\r\n return () => resizeObserver.disconnect();\r\n }, [width, height]);\r\n return (\r\n <div\r\n className={`${theme || 'light'} flex ${width ? 'w-fit grow-0' : 'w-full grow'}`}\r\n dir={language === 'he' || language === 'ar' ? 'rtl' : undefined}\r\n >\r\n <div\r\n className={cn(\r\n `${\r\n !backgroundColor\r\n ? 'bg-transparent '\r\n : backgroundColor === true\r\n ? 'bg-primary-gray-200 dark:bg-primary-gray-650 '\r\n : ''\r\n }ml-auto mr-auto flex flex-col grow h-inherit ${language || 'en'}`,\r\n width ? 'w-fit' : 'w-full',\r\n classNames?.graphContainer,\r\n )}\r\n style={{\r\n ...(styles?.graphContainer || {}),\r\n ...(backgroundColor && backgroundColor !== true ? { backgroundColor } : {}),\r\n }}\r\n id={graphID}\r\n ref={graphParentDiv}\r\n aria-label={\r\n ariaLabel ||\r\n `${\r\n graphTitle ? `The graph shows ${graphTitle}. ` : ''\r\n }This is a strip chart showing distribution of data along the vertical axis. Each dot represents an individual data point, helping to visualize the spread and clustering of values.${\r\n graphDescription ? ` ${graphDescription}` : ''\r\n }`\r\n }\r\n >\r\n <div\r\n className='flex grow'\r\n style={{ padding: backgroundColor ? padding || '1rem' : padding || 0 }}\r\n >\r\n <div className='flex flex-col w-full gap-4 grow justify-between'>\r\n {graphTitle || graphDescription || graphDownload || dataDownload ? (\r\n <GraphHeader\r\n styles={{\r\n title: styles?.title,\r\n description: styles?.description,\r\n }}\r\n classNames={{\r\n title: classNames?.title,\r\n description: classNames?.description,\r\n }}\r\n graphTitle={graphTitle}\r\n graphDescription={graphDescription}\r\n width={width}\r\n graphDownload={graphDownload ? graphParentDiv.current : undefined}\r\n dataDownload={\r\n dataDownload\r\n ? data.map(d => d.data).filter(d => d !== undefined).length > 0\r\n ? data.map(d => d.data).filter(d => d !== undefined)\r\n : data.filter(d => d !== undefined)\r\n : null\r\n }\r\n />\r\n ) : null}\r\n <div className='grow flex flex-col justify-center gap-3 w-full'>\r\n {data.length === 0 ? (\r\n <EmptyState />\r\n ) : (\r\n <>\r\n {showColorScale !== false && data.filter(el => el.color).length !== 0 ? (\r\n <ColorLegendWithMouseOver\r\n width={width}\r\n colorLegendTitle={colorLegendTitle}\r\n colors={\r\n (colors as string[] | undefined) || Colors[theme].categoricalColors.colors\r\n }\r\n colorDomain={colorDomain || (uniqBy(data, 'color', true) as string[])}\r\n setSelectedColor={setSelectedColor}\r\n showNAColor={showNAColor}\r\n />\r\n ) : null}\r\n <div\r\n className='flex flex-col grow justify-center w-full leading-0'\r\n ref={graphDiv}\r\n >\r\n {(width || svgWidth) && (height || svgHeight) ? (\r\n <Graph\r\n data={data}\r\n width={width || svgWidth}\r\n height={Math.max(\r\n minHeight,\r\n height ||\r\n (relativeHeight\r\n ? minHeight\r\n ? (width || svgWidth) * relativeHeight > minHeight\r\n ? (width || svgWidth) * relativeHeight\r\n : minHeight\r\n : (width || svgWidth) * relativeHeight\r\n : svgHeight),\r\n )}\r\n colorDomain={\r\n data.filter(el => el.color).length === 0\r\n ? []\r\n : colorDomain || (uniqBy(data, 'color', true) as string[])\r\n }\r\n colors={\r\n data.filter(el => el.color).length === 0\r\n ? colors\r\n ? [colors as string]\r\n : [Colors.primaryColors['blue-600']]\r\n : (colors as string[] | undefined) ||\r\n Colors[theme].categoricalColors.colors\r\n }\r\n selectedColor={selectedColor}\r\n radius={radius}\r\n leftMargin={leftMargin}\r\n rightMargin={rightMargin}\r\n topMargin={topMargin}\r\n bottomMargin={bottomMargin}\r\n tooltip={tooltip}\r\n onSeriesMouseOver={onSeriesMouseOver}\r\n highlightedDataPoints={highlightedDataPoints}\r\n minValue={minValue}\r\n maxValue={maxValue}\r\n onSeriesMouseClick={onSeriesMouseClick}\r\n prefix={prefix}\r\n suffix={suffix}\r\n stripType={stripType}\r\n highlightColor={highlightColor}\r\n dotOpacity={dotOpacity}\r\n resetSelectionOnDoubleClick={resetSelectionOnDoubleClick}\r\n detailsOnClick={detailsOnClick}\r\n styles={styles}\r\n classNames={classNames}\r\n valueColor={valueColor}\r\n animate={\r\n animate === true\r\n ? { duration: 0.5, once: true, amount: 0.5 }\r\n : animate || { duration: 0, once: true, amount: 0 }\r\n }\r\n noOfTicks={noOfTicks}\r\n dimmedOpacity={dimmedOpacity}\r\n precision={precision}\r\n customLayers={customLayers}\r\n />\r\n ) : null}\r\n </div>\r\n </>\r\n )}\r\n </div>\r\n {sources || footNote ? (\r\n <GraphFooter\r\n styles={{ footnote: styles?.footnote, source: styles?.source }}\r\n classNames={{\r\n footnote: classNames?.footnote,\r\n source: classNames?.source,\r\n }}\r\n sources={sources}\r\n footNote={footNote}\r\n width={width}\r\n />\r\n ) : null}\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n );\r\n}\r\n","import { HorizontalStripChart } from './Horizontal';\r\nimport { VerticalStripChart } from './Vertical';\r\n\r\nimport {\r\n SourcesDataType,\r\n Languages,\r\n StripChartDataType,\r\n StyleObject,\r\n ClassNameObject,\r\n CustomLayerDataType,\r\n AnimateDataType,\r\n} from '@/Types';\r\n\r\ninterface Props {\r\n // Data\r\n /** Array of data objects */\r\n data: StripChartDataType[];\r\n\r\n /** Orientation of the graph */\r\n orientation?: 'vertical' | 'horizontal';\r\n\r\n // Titles, Labels, and Sources\r\n /** Title of the graph */\r\n graphTitle?: string | React.ReactNode;\r\n /** Description of the graph */\r\n graphDescription?: string | React.ReactNode;\r\n /** Footnote for the graph */\r\n footNote?: string | React.ReactNode;\r\n /** Source data for the graph */\r\n sources?: SourcesDataType[];\r\n /** Accessibility label */\r\n ariaLabel?: string;\r\n\r\n // Colors and Styling\r\n /** Color or array of colors for circles */\r\n colors?: string | string[];\r\n /** Color of the highlighted data points */\r\n highlightColor?: string;\r\n /** Domain of colors for the graph */\r\n colorDomain?: string[];\r\n /** Title for the color legend */\r\n colorLegendTitle?: string;\r\n /** Color of value labels */\r\n valueColor?: string;\r\n /** Background color of the graph */\r\n backgroundColor?: string | boolean;\r\n /** Custom styles for the graph. Each object should be a valid React CSS style object. */\r\n styles?: StyleObject;\r\n /** Custom class names */\r\n classNames?: ClassNameObject;\r\n\r\n // Size and Spacing\r\n /** Width of the graph */\r\n width?: number;\r\n /** Height of the graph */\r\n height?: number;\r\n /** Minimum height of the graph */\r\n minHeight?: number;\r\n /** Relative height scaling factor. This overwrites the height props */\r\n relativeHeight?: number;\r\n /** Padding around the graph. Defaults to 0 if no backgroundColor is mentioned else defaults to 1rem */\r\n padding?: string;\r\n /** Left margin of the graph */\r\n leftMargin?: number;\r\n /** Right margin of the graph */\r\n rightMargin?: number;\r\n /** Top margin of the graph */\r\n topMargin?: number;\r\n /** Bottom margin of the graph */\r\n bottomMargin?: number;\r\n\r\n // Values and Ticks\r\n /** Prefix for values */\r\n prefix?: string;\r\n /** Suffix for values */\r\n suffix?: string;\r\n /** Maximum value for the chart */\r\n maxValue?: number;\r\n /** Minimum value for the chart */\r\n minValue?: number;\r\n\r\n // Graph Parameters\r\n /** Number of ticks on the axis */\r\n noOfTicks?: number;\r\n /** Radius of the dots or width of the strips */\r\n radius?: number;\r\n /** Opacity of each dot or strip */\r\n dotOpacity?: number;\r\n /** Type of strip */\r\n stripType?: 'strip' | 'dot';\r\n /** Toggle visibility of color scale. This is only applicable if the data props hae color parameter */\r\n showColorScale?: boolean;\r\n /** Toggle visibility of NA color in the color scale. This is only applicable if the data props hae color parameter and showColorScale prop is true */\r\n showNAColor?: boolean;\r\n /** Data points to highlight. Use the label value from data to highlight the data point */\r\n highlightedDataPoints?: (string | number)[];\r\n /** Defines the opacity of the non-highlighted data */\r\n dimmedOpacity?: number;\r\n /** Toggles if the graph animates in when loaded. */\r\n animate?: boolean | AnimateDataType;\r\n /** Specifies the number of decimal places to display in the value. */\r\n precision?: number;\r\n /** Optional SVG <g> element or function that renders custom content behind or in front of the graph. */\r\n customLayers?: CustomLayerDataType[];\r\n /** Enable graph download option as png */\r\n graphDownload?: boolean;\r\n /** Enable data download option as a csv */\r\n dataDownload?: boolean;\r\n /** Reset selection on double-click. Only applicable when used in a dashboard context with filters. */\r\n resetSelectionOnDoubleClick?: boolean;\r\n\r\n // Interactions and Callbacks\r\n /** Tooltip content. If the type is string then this uses the [handlebar](../?path=/docs/misc-handlebars-templates-and-custom-helpers--docs) template to display the data */\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n tooltip?: string | ((_d: any) => React.ReactNode);\r\n /** Details displayed on the modal when user clicks of a data point. If the type is string then this uses the [handlebar](../?path=/docs/misc-handlebars-templates-and-custom-helpers--docs) template to display the data */\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n detailsOnClick?: string | ((_d: any) => React.ReactNode);\r\n /** Callback for mouse over event */\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseOver?: (_d: any) => void;\r\n /** Callback for mouse click event */\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseClick?: (_d: any) => void;\r\n\r\n // Configuration and Options\r\n /** Language setting */\r\n language?: Languages;\r\n /** Color theme */\r\n theme?: 'light' | 'dark';\r\n /** Unique ID for the graph */\r\n graphID?: string;\r\n}\r\n\r\nexport function StripChart(props: Props) {\r\n const {\r\n data,\r\n graphTitle,\r\n colors,\r\n sources,\r\n graphDescription,\r\n height,\r\n width,\r\n footNote,\r\n colorDomain,\r\n colorLegendTitle,\r\n radius,\r\n padding,\r\n backgroundColor,\r\n leftMargin,\r\n rightMargin,\r\n topMargin,\r\n bottomMargin,\r\n tooltip,\r\n relativeHeight,\r\n onSeriesMouseOver,\r\n showColorScale,\r\n highlightedDataPoints,\r\n graphID,\r\n minValue,\r\n maxValue,\r\n onSeriesMouseClick,\r\n noOfTicks,\r\n graphDownload,\r\n dataDownload,\r\n prefix,\r\n suffix,\r\n stripType,\r\n language,\r\n highlightColor,\r\n dotOpacity,\r\n showNAColor,\r\n minHeight,\r\n theme,\r\n ariaLabel,\r\n valueColor,\r\n resetSelectionOnDoubleClick,\r\n detailsOnClick,\r\n orientation = 'vertical',\r\n styles,\r\n classNames,\r\n animate,\r\n dimmedOpacity = 0.3,\r\n precision,\r\n customLayers,\r\n } = props;\r\n\r\n if (orientation === 'vertical')\r\n return (\r\n <VerticalStripChart\r\n data={data}\r\n graphTitle={graphTitle}\r\n colors={colors}\r\n sources={sources}\r\n graphDescription={graphDescription}\r\n height={height}\r\n width={width}\r\n footNote={footNote}\r\n colorDomain={colorDomain}\r\n colorLegendTitle={colorLegendTitle}\r\n radius={radius}\r\n padding={padding}\r\n backgroundColor={backgroundColor}\r\n leftMargin={leftMargin}\r\n rightMargin={rightMargin}\r\n topMargin={topMargin}\r\n bottomMargin={bottomMargin}\r\n tooltip={tooltip}\r\n relativeHeight={relativeHeight}\r\n onSeriesMouseOver={onSeriesMouseOver}\r\n showColorScale={showColorScale}\r\n highlightedDataPoints={highlightedDataPoints}\r\n graphID={graphID}\r\n minValue={minValue}\r\n maxValue={maxValue}\r\n onSeriesMouseClick={onSeriesMouseClick}\r\n noOfTicks={noOfTicks}\r\n graphDownload={graphDownload}\r\n dataDownload={dataDownload}\r\n prefix={prefix}\r\n suffix={suffix}\r\n stripType={stripType}\r\n language={language}\r\n highlightColor={highlightColor}\r\n dotOpacity={dotOpacity}\r\n showNAColor={showNAColor}\r\n minHeight={minHeight}\r\n theme={theme}\r\n ariaLabel={ariaLabel}\r\n resetSelectionOnDoubleClick={resetSelectionOnDoubleClick}\r\n styles={styles}\r\n valueColor={valueColor}\r\n detailsOnClick={detailsOnClick}\r\n classNames={classNames}\r\n animate={animate}\r\n dimmedOpacity={dimmedOpacity}\r\n precision={precision}\r\n customLayers={customLayers}\r\n />\r\n );\r\n return (\r\n <HorizontalStripChart\r\n data={data}\r\n graphTitle={graphTitle}\r\n colors={colors}\r\n sources={sources}\r\n graphDescription={graphDescription}\r\n height={height}\r\n width={width}\r\n footNote={footNote}\r\n colorDomain={colorDomain}\r\n colorLegendTitle={colorLegendTitle}\r\n radius={radius}\r\n padding={padding}\r\n backgroundColor={backgroundColor}\r\n leftMargin={leftMargin}\r\n rightMargin={rightMargin}\r\n topMargin={topMargin}\r\n bottomMargin={bottomMargin}\r\n tooltip={tooltip}\r\n relativeHeight={relativeHeight}\r\n onSeriesMouseOver={onSeriesMouseOver}\r\n showColorScale={showColorScale}\r\n highlightedDataPoints={highlightedDataPoints}\r\n graphID={graphID}\r\n minValue={minValue}\r\n maxValue={maxValue}\r\n onSeriesMouseClick={onSeriesMouseClick}\r\n noOfTicks={noOfTicks}\r\n graphDownload={graphDownload}\r\n dataDownload={dataDownload}\r\n prefix={prefix}\r\n suffix={suffix}\r\n stripType={stripType}\r\n language={language}\r\n highlightColor={highlightColor}\r\n dotOpacity={dotOpacity}\r\n showNAColor={showNAColor}\r\n minHeight={minHeight}\r\n theme={theme}\r\n ariaLabel={ariaLabel}\r\n resetSelectionOnDoubleClick={resetSelectionOnDoubleClick}\r\n styles={styles}\r\n valueColor={valueColor}\r\n detailsOnClick={detailsOnClick}\r\n classNames={classNames}\r\n animate={animate}\r\n dimmedOpacity={dimmedOpacity}\r\n precision={precision}\r\n customLayers={customLayers}\r\n />\r\n );\r\n}\r\n"],"names":["getTickPositions","count","width","step","_","i","Graph","props","data","height","colors","colorDomain","radius","leftMargin","rightMargin","topMargin","bottomMargin","tooltip","onSeriesMouseOver","highlightedDataPoints","selectedColor","minValue","maxValue","onSeriesMouseClick","prefix","suffix","stripType","highlightColor","dotOpacity","resetSelectionOnDoubleClick","detailsOnClick","styles","classNames","valueColor","animate","noOfTicks","dimmedOpacity","precision","customLayers","svgRef","useRef","isInView","useInView","mouseOverData","setMouseOverData","useState","mouseClickData","setMouseClickData","eventX","setEventX","eventY","setEventY","margin","graphWidth","graphHeight","dataWithId","d","sortedData","orderBy","item","index","xMaxValue","checkIfNullOrUndefined","xMinValue","x","scaleLinear","ticks","jsxs","Fragment","jsx","motion","AnimatePresence","event","isEqual","el","Colors","cn","tick","numberFormattingFunction","Tooltip","Modal","string2HTML","HorizontalStripChart","graphTitle","sources","graphDescription","footNote","colorLegendTitle","padding","backgroundColor","relativeHeight","showColorScale","graphID","graphDownload","dataDownload","language","showNAColor","minHeight","theme","ariaLabel","svgWidth","setSvgWidth","svgHeight","setSvgHeight","setSelectedColor","graphDiv","graphParentDiv","useEffect","resizeObserver","entries","GraphHeader","EmptyState","ColorLegendWithMouseOver","uniqBy","GraphFooter","yMaxValue","yMinValue","y","VerticalStripChart","StripChart","orientation"],"mappings":"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"}
1
+ {"version":3,"file":"StripChart.cjs","sources":["../src/Utils/getTickPosition.ts","../src/Components/Graphs/StripChart/Graph.tsx","../src/Components/Graphs/StripChart/index.tsx"],"sourcesContent":["export function getTickPositions(count: number, width: number) {\r\n if (count < 2) return [];\r\n const step = width / (count - 1);\r\n return Array.from({ length: count }, (_, i) => i * step);\r\n}\r\n","import isEqual from 'fast-deep-equal';\r\nimport { useRef, useState } from 'react';\r\nimport { scaleLinear } from 'd3-scale';\r\nimport { cn } from '@undp/design-system-react/cn';\r\nimport { Modal } from '@undp/design-system-react/Modal';\r\nimport { AnimatePresence, motion, useInView } from 'motion/react';\r\nimport orderBy from 'lodash.orderby';\r\n\r\nimport {\r\n AnimateDataType,\r\n ClassNameObject,\r\n CustomLayerDataType,\r\n StripChartDataType,\r\n StyleObject,\r\n} from '@/Types';\r\nimport { Tooltip } from '@/Components/Elements/Tooltip';\r\nimport { checkIfNullOrUndefined } from '@/Utils/checkIfNullOrUndefined';\r\nimport { numberFormattingFunction } from '@/Utils/numberFormattingFunction';\r\nimport { Colors } from '@/Components/ColorPalette';\r\nimport { string2HTML } from '@/Utils/string2HTML';\r\nimport { getTickPositions } from '@/Utils/getTickPosition';\r\n\r\ninterface Props {\r\n data: StripChartDataType[];\r\n width: number;\r\n height: number;\r\n selectedColor?: string;\r\n colors: string[];\r\n colorDomain: string[];\r\n radius: number;\r\n leftMargin?: number;\r\n rightMargin?: number;\r\n topMargin?: number;\r\n bottomMargin?: number;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n tooltip?: string | ((_d: any) => React.ReactNode);\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseOver?: (_d: any) => void;\r\n highlightedDataPoints: (string | number)[];\r\n maxValue?: number;\r\n minValue?: number;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseClick?: (_d: any) => void;\r\n prefix: string;\r\n suffix: string;\r\n stripType: 'strip' | 'dot';\r\n highlightColor?: string;\r\n dotOpacity: number;\r\n resetSelectionOnDoubleClick: boolean;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n detailsOnClick?: string | ((_d: any) => React.ReactNode);\r\n styles?: StyleObject;\r\n classNames?: ClassNameObject;\r\n valueColor?: string;\r\n animate: AnimateDataType;\r\n noOfTicks: number;\r\n dimmedOpacity: number;\r\n precision: number;\r\n customLayers: CustomLayerDataType[];\r\n}\r\n\r\nexport function VerticalGraph(props: Props) {\r\n const {\r\n data,\r\n width,\r\n height,\r\n colors,\r\n colorDomain,\r\n radius,\r\n leftMargin = 20,\r\n rightMargin = 20,\r\n topMargin = 10,\r\n bottomMargin = 10,\r\n tooltip,\r\n onSeriesMouseOver,\r\n highlightedDataPoints,\r\n selectedColor,\r\n minValue,\r\n maxValue,\r\n onSeriesMouseClick,\r\n noOfTicks,\r\n prefix,\r\n suffix,\r\n stripType,\r\n highlightColor,\r\n dotOpacity,\r\n resetSelectionOnDoubleClick,\r\n detailsOnClick,\r\n styles,\r\n classNames,\r\n valueColor,\r\n animate,\r\n dimmedOpacity,\r\n precision,\r\n customLayers,\r\n } = props;\r\n const svgRef = useRef(null);\r\n const isInView = useInView(svgRef, {\r\n once: animate.once,\r\n amount: animate.amount,\r\n });\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const [mouseOverData, setMouseOverData] = useState<any>(undefined);\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const [mouseClickData, setMouseClickData] = useState<any>(undefined);\r\n const [eventX, setEventX] = useState<number | undefined>(undefined);\r\n const [eventY, setEventY] = useState<number | undefined>(undefined);\r\n const margin = {\r\n top: topMargin,\r\n bottom: bottomMargin,\r\n left: leftMargin,\r\n right: rightMargin,\r\n };\r\n const graphWidth = width - margin.left - margin.right;\r\n const graphHeight = height - margin.top - margin.bottom;\r\n\r\n const dataWithId = data.map((d, i) => ({ ...d, id: `${i}` }));\r\n\r\n const sortedData = orderBy(\r\n dataWithId,\r\n [\r\n item => {\r\n const index = (highlightedDataPoints || []).indexOf(item.label);\r\n return index === -1 ? Infinity : index;\r\n },\r\n ],\r\n ['desc'],\r\n );\r\n const yMaxValue = !checkIfNullOrUndefined(maxValue)\r\n ? (maxValue as number)\r\n : Math.max(...data.filter(d => !checkIfNullOrUndefined(d.position)).map(d => d.position)) < 0\r\n ? 0\r\n : Math.max(...data.filter(d => !checkIfNullOrUndefined(d.position)).map(d => d.position));\r\n const yMinValue = !checkIfNullOrUndefined(minValue)\r\n ? (minValue as number)\r\n : Math.min(...data.filter(d => !checkIfNullOrUndefined(d.position)).map(d => d.position)) >= 0\r\n ? 0\r\n : Math.min(...data.filter(d => !checkIfNullOrUndefined(d.position)).map(d => d.position));\r\n const y = scaleLinear().domain([yMinValue, yMaxValue]).range([graphHeight, 0]).nice();\r\n const ticks = getTickPositions(noOfTicks, graphHeight);\r\n return (\r\n <>\r\n <motion.svg\r\n width={`${width}px`}\r\n height={`${height}px`}\r\n viewBox={`0 0 ${width} ${height}`}\r\n direction='ltr'\r\n ref={svgRef}\r\n >\r\n <g transform={`translate(${margin.left},${margin.top})`}>\r\n {customLayers.filter(d => d.position === 'before').map(d => d.layer)}\r\n <AnimatePresence>\r\n {sortedData.map(d => {\r\n return (\r\n <motion.g\r\n className='undp-viz-g-with-hover'\r\n key={d.label}\r\n variants={{\r\n initial: {\r\n opacity: 0,\r\n x: graphWidth / 2,\r\n y: y(0),\r\n },\r\n whileInView: {\r\n x: graphWidth / 2,\r\n y: y(d.position),\r\n opacity: selectedColor\r\n ? d.color\r\n ? colors[colorDomain.indexOf(d.color)] === selectedColor\r\n ? 0.95\r\n : dimmedOpacity\r\n : dimmedOpacity\r\n : highlightedDataPoints.length !== 0\r\n ? highlightedDataPoints.indexOf(d.label) !== -1\r\n ? 0.95\r\n : dimmedOpacity\r\n : dotOpacity,\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n onMouseEnter={event => {\r\n setMouseOverData(d);\r\n setEventY(event.clientY);\r\n setEventX(event.clientX);\r\n onSeriesMouseOver?.(d);\r\n }}\r\n onClick={() => {\r\n if (onSeriesMouseClick || detailsOnClick) {\r\n if (isEqual(mouseClickData, d) && resetSelectionOnDoubleClick) {\r\n setMouseClickData(undefined);\r\n onSeriesMouseClick?.(undefined);\r\n } else {\r\n setMouseClickData(d);\r\n onSeriesMouseClick?.(d);\r\n }\r\n }\r\n }}\r\n onMouseMove={event => {\r\n setMouseOverData(d);\r\n setEventY(event.clientY);\r\n setEventX(event.clientX);\r\n }}\r\n onMouseLeave={() => {\r\n setMouseOverData(undefined);\r\n setEventX(undefined);\r\n setEventY(undefined);\r\n onSeriesMouseOver?.(undefined);\r\n }}\r\n >\r\n {stripType === 'dot' ? (\r\n <motion.circle\r\n cy={0}\r\n cx={0}\r\n variants={{\r\n initial: {\r\n fill:\r\n highlightColor && highlightedDataPoints\r\n ? highlightedDataPoints.indexOf(d.label) !== -1\r\n ? highlightColor\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)]\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)],\r\n },\r\n whileInView: {\r\n fill:\r\n highlightColor && highlightedDataPoints\r\n ? highlightedDataPoints.indexOf(d.label) !== -1\r\n ? highlightColor\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)]\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)],\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n r={radius}\r\n />\r\n ) : (\r\n <motion.rect\r\n y={-1}\r\n height={2}\r\n variants={{\r\n initial: {\r\n x: 0 - radius,\r\n width: radius * 2,\r\n fill:\r\n highlightColor && highlightedDataPoints\r\n ? highlightedDataPoints.indexOf(d.label) !== -1\r\n ? highlightColor\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)]\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)],\r\n },\r\n whileInView: {\r\n x: 0 - radius,\r\n width: radius * 2,\r\n fill:\r\n highlightColor && highlightedDataPoints\r\n ? highlightedDataPoints.indexOf(d.label) !== -1\r\n ? highlightColor\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)]\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)],\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n />\r\n )}\r\n {highlightedDataPoints.length !== 0 ? (\r\n highlightedDataPoints.indexOf(d.label) !== -1 ? (\r\n <motion.text\r\n y={0}\r\n dy='0.33em'\r\n variants={{\r\n initial: {\r\n opacity: 0,\r\n x: 0 + radius + 3,\r\n fill:\r\n valueColor ||\r\n (highlightColor && highlightedDataPoints\r\n ? highlightedDataPoints.indexOf(d.label) !== -1\r\n ? highlightColor\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)]\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)]),\r\n },\r\n whileInView: {\r\n opacity: 1,\r\n x: 0 + radius + 3,\r\n fill:\r\n valueColor ||\r\n (highlightColor && highlightedDataPoints\r\n ? highlightedDataPoints.indexOf(d.label) !== -1\r\n ? highlightColor\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)]\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)]),\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n style={{\r\n textAnchor: 'start',\r\n ...(styles?.graphObjectValues || {}),\r\n }}\r\n className={cn(\r\n 'graph-value text-sm font-bold',\r\n classNames?.graphObjectValues,\r\n )}\r\n >\r\n {numberFormattingFunction(d.position, 'NA', precision, prefix, suffix)}\r\n </motion.text>\r\n ) : null\r\n ) : null}\r\n </motion.g>\r\n );\r\n })}\r\n {ticks.map((tick, i) => (\r\n <text\r\n key={i}\r\n y={tick}\r\n x={graphWidth / 2 + radius + 5}\r\n style={{\r\n textAnchor: 'start',\r\n ...(styles?.yAxis?.labels || {}),\r\n }}\r\n className={cn(\r\n 'fill-primary-gray-550 dark:fill-primary-gray-500 text-xs',\r\n classNames?.yAxis?.labels,\r\n )}\r\n >\r\n {numberFormattingFunction(y.invert(tick), 'NA', precision, prefix, suffix)}\r\n </text>\r\n ))}\r\n </AnimatePresence>\r\n {customLayers.filter(d => d.position === 'after').map(d => d.layer)}\r\n </g>\r\n </motion.svg>\r\n {mouseOverData && tooltip && eventX && eventY ? (\r\n <Tooltip\r\n data={mouseOverData}\r\n body={tooltip}\r\n xPos={eventX}\r\n yPos={eventY}\r\n backgroundStyle={styles?.tooltip}\r\n className={classNames?.tooltip}\r\n />\r\n ) : null}\r\n {detailsOnClick && mouseClickData !== undefined ? (\r\n <Modal\r\n open={mouseClickData !== undefined}\r\n onClose={() => {\r\n setMouseClickData(undefined);\r\n }}\r\n >\r\n <div\r\n className='graph-modal-content m-0'\r\n dangerouslySetInnerHTML={\r\n typeof detailsOnClick === 'string'\r\n ? { __html: string2HTML(detailsOnClick, mouseClickData) }\r\n : undefined\r\n }\r\n >\r\n {typeof detailsOnClick === 'function' ? detailsOnClick(mouseClickData) : null}\r\n </div>\r\n </Modal>\r\n ) : null}\r\n </>\r\n );\r\n}\r\n\r\nexport function HorizontalGraph(props: Props) {\r\n const {\r\n data,\r\n width,\r\n height,\r\n colors,\r\n colorDomain,\r\n radius,\r\n leftMargin = 5,\r\n rightMargin = 5,\r\n topMargin = 10,\r\n bottomMargin = 10,\r\n tooltip,\r\n onSeriesMouseOver,\r\n highlightedDataPoints,\r\n selectedColor,\r\n minValue,\r\n maxValue,\r\n onSeriesMouseClick,\r\n prefix,\r\n suffix,\r\n stripType,\r\n highlightColor,\r\n dotOpacity,\r\n resetSelectionOnDoubleClick,\r\n detailsOnClick,\r\n styles,\r\n classNames,\r\n valueColor,\r\n animate,\r\n noOfTicks,\r\n dimmedOpacity,\r\n precision,\r\n customLayers,\r\n } = props;\r\n const svgRef = useRef(null);\r\n const isInView = useInView(svgRef, {\r\n once: animate.once,\r\n amount: animate.amount,\r\n });\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const [mouseOverData, setMouseOverData] = useState<any>(undefined);\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const [mouseClickData, setMouseClickData] = useState<any>(undefined);\r\n const [eventX, setEventX] = useState<number | undefined>(undefined);\r\n const [eventY, setEventY] = useState<number | undefined>(undefined);\r\n const margin = {\r\n top: topMargin,\r\n bottom: bottomMargin,\r\n left: leftMargin,\r\n right: rightMargin,\r\n };\r\n const graphWidth = width - margin.left - margin.right;\r\n const graphHeight = height - margin.top - margin.bottom;\r\n\r\n const dataWithId = data.map((d, i) => ({ ...d, id: `${i}` }));\r\n\r\n const sortedData = orderBy(\r\n dataWithId,\r\n [\r\n item => {\r\n const index = (highlightedDataPoints || []).indexOf(item.label);\r\n return index === -1 ? Infinity : index;\r\n },\r\n ],\r\n ['desc'],\r\n );\r\n const xMaxValue = !checkIfNullOrUndefined(maxValue)\r\n ? (maxValue as number)\r\n : Math.max(...data.filter(d => !checkIfNullOrUndefined(d.position)).map(d => d.position)) < 0\r\n ? 0\r\n : Math.max(...data.filter(d => !checkIfNullOrUndefined(d.position)).map(d => d.position));\r\n const xMinValue = !checkIfNullOrUndefined(minValue)\r\n ? (minValue as number)\r\n : Math.min(...data.filter(d => !checkIfNullOrUndefined(d.position)).map(d => d.position)) >= 0\r\n ? 0\r\n : Math.min(...data.filter(d => !checkIfNullOrUndefined(d.position)).map(d => d.position));\r\n const x = scaleLinear().domain([xMinValue, xMaxValue]).range([0, graphWidth]).nice();\r\n const ticks = getTickPositions(noOfTicks, graphWidth);\r\n return (\r\n <>\r\n <motion.svg\r\n width={`${width}px`}\r\n height={`${height}px`}\r\n viewBox={`0 0 ${width} ${height}`}\r\n direction='ltr'\r\n ref={svgRef}\r\n >\r\n <g transform={`translate(${margin.left},${margin.top})`}>\r\n {customLayers.filter(d => d.position === 'before').map(d => d.layer)}\r\n <AnimatePresence>\r\n {sortedData.map(d => {\r\n return (\r\n <motion.g\r\n className='undp-viz-g-with-hover'\r\n key={d.label}\r\n variants={{\r\n initial: {\r\n opacity: 0,\r\n x: x(0),\r\n y: graphHeight / 2,\r\n },\r\n whileInView: {\r\n x: x(d.position),\r\n y: graphHeight / 2,\r\n opacity: selectedColor\r\n ? d.color\r\n ? colors[colorDomain.indexOf(d.color)] === selectedColor\r\n ? 0.95\r\n : dimmedOpacity\r\n : dimmedOpacity\r\n : highlightedDataPoints.length !== 0\r\n ? highlightedDataPoints.indexOf(d.label) !== -1\r\n ? 0.95\r\n : dimmedOpacity\r\n : dotOpacity,\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n onMouseEnter={event => {\r\n setMouseOverData(d);\r\n setEventY(event.clientY);\r\n setEventX(event.clientX);\r\n onSeriesMouseOver?.(d);\r\n }}\r\n onClick={() => {\r\n if (onSeriesMouseClick || detailsOnClick) {\r\n if (isEqual(mouseClickData, d) && resetSelectionOnDoubleClick) {\r\n setMouseClickData(undefined);\r\n onSeriesMouseClick?.(undefined);\r\n } else {\r\n setMouseClickData(d);\r\n onSeriesMouseClick?.(d);\r\n }\r\n }\r\n }}\r\n onMouseMove={event => {\r\n setMouseOverData(d);\r\n setEventY(event.clientY);\r\n setEventX(event.clientX);\r\n }}\r\n onMouseLeave={() => {\r\n setMouseOverData(undefined);\r\n setEventX(undefined);\r\n setEventY(undefined);\r\n onSeriesMouseOver?.(undefined);\r\n }}\r\n >\r\n {stripType === 'dot' ? (\r\n <motion.circle\r\n cy={0}\r\n cx={0}\r\n variants={{\r\n initial: {\r\n fill:\r\n highlightColor && highlightedDataPoints\r\n ? highlightedDataPoints.indexOf(d.label) !== -1\r\n ? highlightColor\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)]\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)],\r\n },\r\n whileInView: {\r\n fill:\r\n highlightColor && highlightedDataPoints\r\n ? highlightedDataPoints.indexOf(d.label) !== -1\r\n ? highlightColor\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)]\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)],\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n r={radius}\r\n />\r\n ) : (\r\n <motion.rect\r\n x={-1}\r\n width={2}\r\n variants={{\r\n initial: {\r\n y: 0 - radius,\r\n height: radius * 2,\r\n fill:\r\n highlightColor && highlightedDataPoints\r\n ? highlightedDataPoints.indexOf(d.label) !== -1\r\n ? highlightColor\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)]\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)],\r\n },\r\n whileInView: {\r\n y: 0 - radius,\r\n height: radius * 2,\r\n fill:\r\n highlightColor && highlightedDataPoints\r\n ? highlightedDataPoints.indexOf(d.label) !== -1\r\n ? highlightColor\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)]\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)],\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n />\r\n )}\r\n {highlightedDataPoints.length !== 0 ? (\r\n highlightedDataPoints.indexOf(d.label) !== -1 ? (\r\n <motion.text\r\n x={0}\r\n variants={{\r\n initial: {\r\n opacity: 0,\r\n y: 0 - radius - 5,\r\n fill:\r\n valueColor ||\r\n (highlightColor && highlightedDataPoints\r\n ? highlightedDataPoints.indexOf(d.label) !== -1\r\n ? highlightColor\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)]\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)]),\r\n },\r\n whileInView: {\r\n opacity: 1,\r\n y: 0 - radius - 5,\r\n fill:\r\n valueColor ||\r\n (highlightColor && highlightedDataPoints\r\n ? highlightedDataPoints.indexOf(d.label) !== -1\r\n ? highlightColor\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)]\r\n : data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)]),\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n style={{\r\n textAnchor: 'middle',\r\n ...(styles?.graphObjectValues || {}),\r\n }}\r\n className={cn(\r\n 'graph-value text-sm font-bold',\r\n classNames?.graphObjectValues,\r\n )}\r\n >\r\n {numberFormattingFunction(d.position, 'NA', precision, prefix, suffix)}\r\n </motion.text>\r\n ) : null\r\n ) : null}\r\n </motion.g>\r\n );\r\n })}\r\n {ticks.map((tick, i) => (\r\n <text\r\n key={i}\r\n x={tick}\r\n y={graphHeight / 2 + radius}\r\n style={{\r\n textAnchor: i === 0 ? 'start' : i === ticks.length - 1 ? 'end' : 'middle',\r\n ...(styles?.xAxis?.labels || {}),\r\n }}\r\n className={cn(\r\n 'fill-primary-gray-550 dark:fill-primary-gray-500 text-xs',\r\n classNames?.xAxis?.labels,\r\n )}\r\n dy='1em'\r\n >\r\n {numberFormattingFunction(x.invert(tick), 'NA', precision, prefix, suffix)}\r\n </text>\r\n ))}\r\n </AnimatePresence>\r\n {customLayers.filter(d => d.position === 'after').map(d => d.layer)}\r\n </g>\r\n </motion.svg>\r\n {mouseOverData && tooltip && eventX && eventY ? (\r\n <Tooltip\r\n data={mouseOverData}\r\n body={tooltip}\r\n xPos={eventX}\r\n yPos={eventY}\r\n backgroundStyle={styles?.tooltip}\r\n className={classNames?.tooltip}\r\n />\r\n ) : null}\r\n {detailsOnClick && mouseClickData !== undefined ? (\r\n <Modal\r\n open={mouseClickData !== undefined}\r\n onClose={() => {\r\n setMouseClickData(undefined);\r\n }}\r\n >\r\n <div\r\n className='graph-modal-content m-0'\r\n dangerouslySetInnerHTML={\r\n typeof detailsOnClick === 'string'\r\n ? { __html: string2HTML(detailsOnClick, mouseClickData) }\r\n : undefined\r\n }\r\n >\r\n {typeof detailsOnClick === 'function' ? detailsOnClick(mouseClickData) : null}\r\n </div>\r\n </Modal>\r\n ) : null}\r\n </>\r\n );\r\n}\r\n","import { useEffect, useRef, useState } from 'react';\r\n\r\nimport { HorizontalGraph, VerticalGraph } from './Graph';\r\n\r\nimport { uniqBy } from '@/Utils/uniqBy';\r\nimport { Colors } from '@/Components/ColorPalette';\r\nimport {\r\n SourcesDataType,\r\n Languages,\r\n StripChartDataType,\r\n StyleObject,\r\n ClassNameObject,\r\n CustomLayerDataType,\r\n AnimateDataType,\r\n} from '@/Types';\r\nimport { GraphArea, GraphContainer } from '@/Components/Elements/GraphContainer';\r\nimport { EmptyState } from '@/Components/Elements/EmptyState';\r\nimport { ColorLegendWithMouseOver } from '@/Components/Elements/ColorLegendWithMouseOver';\r\nimport { GraphFooter } from '@/Components/Elements/GraphFooter';\r\nimport { GraphHeader } from '@/Components/Elements/GraphHeader';\r\n\r\ninterface Props {\r\n // Data\r\n /** Array of data objects */\r\n data: StripChartDataType[];\r\n\r\n /** Orientation of the graph */\r\n orientation?: 'vertical' | 'horizontal';\r\n\r\n // Titles, Labels, and Sources\r\n /** Title of the graph */\r\n graphTitle?: string | React.ReactNode;\r\n /** Description of the graph */\r\n graphDescription?: string | React.ReactNode;\r\n /** Footnote for the graph */\r\n footNote?: string | React.ReactNode;\r\n /** Source data for the graph */\r\n sources?: SourcesDataType[];\r\n /** Accessibility label */\r\n ariaLabel?: string;\r\n\r\n // Colors and Styling\r\n /** Color or array of colors for circles */\r\n colors?: string | string[];\r\n /** Color of the highlighted data points */\r\n highlightColor?: string;\r\n /** Domain of colors for the graph */\r\n colorDomain?: string[];\r\n /** Title for the color legend */\r\n colorLegendTitle?: string;\r\n /** Color of value labels */\r\n valueColor?: string;\r\n /** Background color of the graph */\r\n backgroundColor?: string | boolean;\r\n /** Custom styles for the graph. Each object should be a valid React CSS style object. */\r\n styles?: StyleObject;\r\n /** Custom class names */\r\n classNames?: ClassNameObject;\r\n\r\n // Size and Spacing\r\n /** Width of the graph */\r\n width?: number;\r\n /** Height of the graph */\r\n height?: number;\r\n /** Minimum height of the graph */\r\n minHeight?: number;\r\n /** Relative height scaling factor. This overwrites the height props */\r\n relativeHeight?: number;\r\n /** Padding around the graph. Defaults to 0 if no backgroundColor is mentioned else defaults to 1rem */\r\n padding?: string;\r\n /** Left margin of the graph */\r\n leftMargin?: number;\r\n /** Right margin of the graph */\r\n rightMargin?: number;\r\n /** Top margin of the graph */\r\n topMargin?: number;\r\n /** Bottom margin of the graph */\r\n bottomMargin?: number;\r\n\r\n // Values and Ticks\r\n /** Prefix for values */\r\n prefix?: string;\r\n /** Suffix for values */\r\n suffix?: string;\r\n /** Maximum value for the chart */\r\n maxValue?: number;\r\n /** Minimum value for the chart */\r\n minValue?: number;\r\n\r\n // Graph Parameters\r\n /** Number of ticks on the axis */\r\n noOfTicks?: number;\r\n /** Radius of the dots or width of the strips */\r\n radius?: number;\r\n /** Opacity of each dot or strip */\r\n dotOpacity?: number;\r\n /** Type of strip */\r\n stripType?: 'strip' | 'dot';\r\n /** Toggle visibility of color scale. This is only applicable if the data props hae color parameter */\r\n showColorScale?: boolean;\r\n /** Toggle visibility of NA color in the color scale. This is only applicable if the data props hae color parameter and showColorScale prop is true */\r\n showNAColor?: boolean;\r\n /** Data points to highlight. Use the label value from data to highlight the data point */\r\n highlightedDataPoints?: (string | number)[];\r\n /** Defines the opacity of the non-highlighted data */\r\n dimmedOpacity?: number;\r\n /** Toggles if the graph animates in when loaded. */\r\n animate?: boolean | AnimateDataType;\r\n /** Specifies the number of decimal places to display in the value. */\r\n precision?: number;\r\n /** Optional SVG <g> element or function that renders custom content behind or in front of the graph. */\r\n customLayers?: CustomLayerDataType[];\r\n /** Enable graph download option as png */\r\n graphDownload?: boolean;\r\n /** Enable data download option as a csv */\r\n dataDownload?: boolean;\r\n /** Reset selection on double-click. Only applicable when used in a dashboard context with filters. */\r\n resetSelectionOnDoubleClick?: boolean;\r\n\r\n // Interactions and Callbacks\r\n /** Tooltip content. If the type is string then this uses the [handlebar](../?path=/docs/misc-handlebars-templates-and-custom-helpers--docs) template to display the data */\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n tooltip?: string | ((_d: any) => React.ReactNode);\r\n /** Details displayed on the modal when user clicks of a data point. If the type is string then this uses the [handlebar](../?path=/docs/misc-handlebars-templates-and-custom-helpers--docs) template to display the data */\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n detailsOnClick?: string | ((_d: any) => React.ReactNode);\r\n /** Callback for mouse over event */\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseOver?: (_d: any) => void;\r\n /** Callback for mouse click event */\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseClick?: (_d: any) => void;\r\n\r\n // Configuration and Options\r\n /** Language setting */\r\n language?: Languages;\r\n /** Color theme */\r\n theme?: 'light' | 'dark';\r\n /** Unique ID for the graph */\r\n graphID?: string;\r\n}\r\n\r\nexport function StripChart(props: Props) {\r\n const {\r\n data,\r\n graphTitle,\r\n colors,\r\n sources,\r\n graphDescription,\r\n height,\r\n width,\r\n footNote,\r\n colorDomain,\r\n colorLegendTitle,\r\n radius = 5,\r\n padding,\r\n backgroundColor = false,\r\n leftMargin,\r\n rightMargin,\r\n topMargin,\r\n bottomMargin,\r\n tooltip,\r\n relativeHeight,\r\n onSeriesMouseOver,\r\n showColorScale = true,\r\n highlightedDataPoints = [],\r\n graphID,\r\n minValue,\r\n maxValue,\r\n onSeriesMouseClick,\r\n noOfTicks = 2,\r\n graphDownload = false,\r\n dataDownload = false,\r\n prefix = '',\r\n suffix = '',\r\n stripType = 'dot',\r\n language = 'en',\r\n highlightColor,\r\n dotOpacity = 0.3,\r\n showNAColor = true,\r\n minHeight = 0,\r\n theme = 'light',\r\n ariaLabel,\r\n valueColor,\r\n resetSelectionOnDoubleClick = true,\r\n detailsOnClick,\r\n orientation = 'vertical',\r\n styles,\r\n classNames,\r\n animate = false,\r\n dimmedOpacity = 0.3,\r\n precision = 2,\r\n customLayers = [],\r\n } = props;\r\n\r\n const Comp = orientation === 'horizontal' ? HorizontalGraph : VerticalGraph;\r\n\r\n const [svgWidth, setSvgWidth] = useState(0);\r\n const [svgHeight, setSvgHeight] = useState(0);\r\n const [selectedColor, setSelectedColor] = useState<string | undefined>(undefined);\r\n\r\n const graphDiv = useRef<HTMLDivElement>(null);\r\n const graphParentDiv = useRef<HTMLDivElement>(null);\r\n useEffect(() => {\r\n const resizeObserver = new ResizeObserver(entries => {\r\n setSvgWidth(entries[0].target.clientWidth || 620);\r\n setSvgHeight(entries[0].target.clientHeight || 480);\r\n });\r\n if (graphDiv.current) {\r\n resizeObserver.observe(graphDiv.current);\r\n }\r\n return () => resizeObserver.disconnect();\r\n }, []);\r\n return (\r\n <GraphContainer\r\n className={classNames?.graphContainer}\r\n style={styles?.graphContainer}\r\n id={graphID}\r\n ref={graphParentDiv}\r\n aria-label={ariaLabel}\r\n backgroundColor={backgroundColor}\r\n theme={theme}\r\n language={language}\r\n minHeight={minHeight}\r\n width={width}\r\n height={height}\r\n relativeHeight={relativeHeight}\r\n padding={padding}\r\n >\r\n {graphTitle || graphDescription || graphDownload || dataDownload ? (\r\n <GraphHeader\r\n styles={{\r\n title: styles?.title,\r\n description: styles?.description,\r\n }}\r\n classNames={{\r\n title: classNames?.title,\r\n description: classNames?.description,\r\n }}\r\n graphTitle={graphTitle}\r\n graphDescription={graphDescription}\r\n width={width}\r\n graphDownload={graphDownload ? graphParentDiv : undefined}\r\n dataDownload={\r\n dataDownload\r\n ? data.map(d => d.data).filter(d => d !== undefined).length > 0\r\n ? data.map(d => d.data).filter(d => d !== undefined)\r\n : data.filter(d => d !== undefined)\r\n : null\r\n }\r\n />\r\n ) : null}\r\n {data.length === 0 ? (\r\n <EmptyState />\r\n ) : (\r\n <>\r\n {showColorScale !== false && data.filter(el => el.color).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 />\r\n ) : null}\r\n <GraphArea ref={graphDiv}>\r\n {svgWidth && svgHeight ? (\r\n <Comp\r\n data={data}\r\n width={svgWidth}\r\n height={svgHeight}\r\n colorDomain={\r\n data.filter(el => el.color).length === 0\r\n ? []\r\n : colorDomain || (uniqBy(data, 'color', true) as string[])\r\n }\r\n colors={\r\n data.filter(el => el.color).length === 0\r\n ? colors\r\n ? [colors as string]\r\n : [Colors.primaryColors['blue-600']]\r\n : (colors as string[] | undefined) || Colors[theme].categoricalColors.colors\r\n }\r\n selectedColor={selectedColor}\r\n radius={radius}\r\n leftMargin={leftMargin}\r\n rightMargin={rightMargin}\r\n topMargin={topMargin}\r\n bottomMargin={bottomMargin}\r\n tooltip={tooltip}\r\n onSeriesMouseOver={onSeriesMouseOver}\r\n highlightedDataPoints={highlightedDataPoints}\r\n minValue={minValue}\r\n maxValue={maxValue}\r\n onSeriesMouseClick={onSeriesMouseClick}\r\n prefix={prefix}\r\n suffix={suffix}\r\n stripType={stripType}\r\n highlightColor={highlightColor}\r\n dotOpacity={dotOpacity}\r\n resetSelectionOnDoubleClick={resetSelectionOnDoubleClick}\r\n detailsOnClick={detailsOnClick}\r\n styles={styles}\r\n classNames={classNames}\r\n valueColor={valueColor}\r\n animate={\r\n animate === true\r\n ? { duration: 0.5, once: true, amount: 0.5 }\r\n : animate || { duration: 0, once: true, amount: 0 }\r\n }\r\n noOfTicks={noOfTicks}\r\n dimmedOpacity={dimmedOpacity}\r\n precision={precision}\r\n customLayers={customLayers}\r\n />\r\n ) : null}\r\n </GraphArea>\r\n </>\r\n )}\r\n {sources || footNote ? (\r\n <GraphFooter\r\n styles={{ footnote: styles?.footnote, source: styles?.source }}\r\n classNames={{\r\n footnote: classNames?.footnote,\r\n source: classNames?.source,\r\n }}\r\n sources={sources}\r\n footNote={footNote}\r\n width={width}\r\n />\r\n ) : null}\r\n </GraphContainer>\r\n );\r\n}\r\n"],"names":["getTickPositions","count","width","step","Array","from","length","_","i","VerticalGraph","props","$","_c","data","height","colors","colorDomain","radius","leftMargin","t0","rightMargin","t1","topMargin","t2","bottomMargin","t3","tooltip","onSeriesMouseOver","highlightedDataPoints","selectedColor","minValue","maxValue","onSeriesMouseClick","noOfTicks","prefix","suffix","stripType","highlightColor","dotOpacity","resetSelectionOnDoubleClick","detailsOnClick","styles","classNames","valueColor","animate","dimmedOpacity","precision","customLayers","undefined","svgRef","useRef","t4","amount","once","isInView","useInView","mouseOverData","setMouseOverData","useState","mouseClickData","setMouseClickData","eventX","setEventX","eventY","setEventY","t5","top","bottom","left","right","margin","graphWidth","graphHeight","T0","T1","t10","t11","t12","t13","t14","t6","t7","t8","t9","duration","graphObjectValues","yAxis","labels","dataWithId","map","_temp","t15","item","index","indexOf","label","Infinity","sortedData","orderBy","t16","checkIfNullOrUndefined","Math","max","filter","_temp2","_temp3","_temp4","_temp5","yMaxValue","t17","min","_temp6","_temp7","_temp8","_temp9","yMinValue","y","scaleLinear","domain","range","nice","ticks","motion","svg","_temp0","_temp1","AnimatePresence","d_10","jsxs","initial","opacity","x","whileInView","d","position","color","transition","event","clientY","clientX","isEqual","event_0","fill","_temp10","Colors","gray","_temp11","_temp12","_temp13","jsx","_temp14","_temp15","_temp16","_temp17","_temp18","_temp19","_temp20","_temp21","textAnchor","cn","numberFormattingFunction","tick","i_0","invert","_temp22","_temp23","t18","t19","Tooltip","t20","Modal","__html","string2HTML","t21","Fragment","d_12","layer","d_11","el_10","el","el_9","el_8","el_7","el_6","el_5","el_4","el_3","el_2","el_1","el_0","d_9","d_8","d_5","d_4","d_7","d_6","d_1","d_0","d_3","d_2","id","HorizontalGraph","xAxis","_temp24","_temp25","_temp26","_temp27","_temp28","xMaxValue","_temp29","_temp30","_temp31","_temp32","xMinValue","_temp33","_temp34","_temp35","_temp36","_temp37","_temp38","_temp39","_temp40","_temp41","_temp42","_temp43","_temp44","_temp45","_temp46","_temp47","_temp48","StripChart","graphTitle","sources","graphDescription","footNote","colorLegendTitle","padding","backgroundColor","relativeHeight","showColorScale","graphID","graphDownload","dataDownload","language","showNAColor","minHeight","theme","ariaLabel","orientation","t22","Comp","svgWidth","setSvgWidth","svgHeight","setSvgHeight","setSelectedColor","graphDiv","graphParentDiv","t23","t24","Symbol","for","resizeObserver","ResizeObserver","entries","target","clientWidth","clientHeight","current","observe","disconnect","useEffect","t25","graphContainer","t26","t27","description","title","GraphHeader","t28","EmptyState","ColorLegendWithMouseOver","categoricalColors","uniqBy","colorLegend","GraphArea","primaryColors","t29","footnote","source","GraphFooter","t30","GraphContainer"],"mappings":"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"}
@@ -35,6 +35,7 @@ declare interface ClassNameObject {
35
35
  mouseOverLine?: string;
36
36
  regLine?: string;
37
37
  dataCards?: string;
38
+ colorLegend?: string;
38
39
  }
39
40
 
40
41
  declare interface CustomLayerDataType {