@undp/data-viz 2.4.1 → 2.5.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (271) hide show
  1. package/dist/AreaChart.cjs +1 -1
  2. package/dist/AreaChart.cjs.map +1 -1
  3. package/dist/AreaChart.d.ts +11 -9
  4. package/dist/AreaChart.js +320 -322
  5. package/dist/AreaChart.js.map +1 -1
  6. package/dist/BarGraph.cjs +1 -1
  7. package/dist/BarGraph.cjs.map +1 -1
  8. package/dist/BarGraph.d.ts +15 -25
  9. package/dist/BarGraph.js +1694 -1694
  10. package/dist/BarGraph.js.map +1 -1
  11. package/dist/BasicStatCard.cjs +1 -1
  12. package/dist/BasicStatCard.cjs.map +1 -1
  13. package/dist/BasicStatCard.d.ts +13 -9
  14. package/dist/BasicStatCard.js +79 -81
  15. package/dist/BasicStatCard.js.map +1 -1
  16. package/dist/BeeSwarmChart.cjs +1 -1
  17. package/dist/BeeSwarmChart.cjs.map +1 -1
  18. package/dist/BeeSwarmChart.d.ts +11 -9
  19. package/dist/BeeSwarmChart.js +335 -336
  20. package/dist/BeeSwarmChart.js.map +1 -1
  21. package/dist/BiVariateChoroplethMap.cjs +1 -1
  22. package/dist/BiVariateChoroplethMap.cjs.map +1 -1
  23. package/dist/BiVariateChoroplethMap.d.ts +13 -3
  24. package/dist/BiVariateChoroplethMap.js +309 -304
  25. package/dist/BiVariateChoroplethMap.js.map +1 -1
  26. package/dist/BulletChart.cjs +1 -1
  27. package/dist/BulletChart.cjs.map +1 -1
  28. package/dist/BulletChart.d.ts +11 -5
  29. package/dist/BulletChart.js +560 -559
  30. package/dist/BulletChart.js.map +1 -1
  31. package/dist/ButterflyChart.cjs +1 -1
  32. package/dist/ButterflyChart.cjs.map +1 -1
  33. package/dist/ButterflyChart.d.ts +11 -9
  34. package/dist/ButterflyChart.js +348 -350
  35. package/dist/ButterflyChart.js.map +1 -1
  36. package/dist/ChoroplethMap.cjs +1 -1
  37. package/dist/ChoroplethMap.cjs.map +1 -1
  38. package/dist/ChoroplethMap.d.ts +11 -3
  39. package/dist/ChoroplethMap.js +314 -311
  40. package/dist/ChoroplethMap.js.map +1 -1
  41. package/dist/CirclePackingGraph.cjs +1 -1
  42. package/dist/CirclePackingGraph.d.ts +11 -9
  43. package/dist/CirclePackingGraph.js +1 -1
  44. package/dist/DataCards.cjs +1 -1
  45. package/dist/DataCards.d.ts +1 -1
  46. package/dist/DataCards.js +1 -1
  47. package/dist/DataTable.cjs +1 -1
  48. package/dist/DataTable.cjs.map +1 -1
  49. package/dist/DataTable.d.ts +4 -5
  50. package/dist/DataTable.js +114 -116
  51. package/dist/DataTable.js.map +1 -1
  52. package/dist/{DetailsModal-jmmKRMRM.cjs → DetailsModal-Du8Fr1QD.cjs} +2 -2
  53. package/dist/{DetailsModal-jmmKRMRM.cjs.map → DetailsModal-Du8Fr1QD.cjs.map} +1 -1
  54. package/dist/{DetailsModal-B2XBWR7w.js → DetailsModal-GqEbGHY2.js} +2 -2
  55. package/dist/{DetailsModal-B2XBWR7w.js.map → DetailsModal-GqEbGHY2.js.map} +1 -1
  56. package/dist/DifferenceLineChart.cjs +1 -1
  57. package/dist/DifferenceLineChart.cjs.map +1 -1
  58. package/dist/DifferenceLineChart.d.ts +11 -9
  59. package/dist/DifferenceLineChart.js +502 -504
  60. package/dist/DifferenceLineChart.js.map +1 -1
  61. package/dist/DonutChart.cjs +1 -1
  62. package/dist/DonutChart.cjs.map +1 -1
  63. package/dist/DonutChart.d.ts +14 -9
  64. package/dist/DonutChart.js +174 -179
  65. package/dist/DonutChart.js.map +1 -1
  66. package/dist/DotDensityMap.cjs +1 -1
  67. package/dist/DotDensityMap.cjs.map +1 -1
  68. package/dist/DotDensityMap.d.ts +1 -1
  69. package/dist/DotDensityMap.js +270 -267
  70. package/dist/DotDensityMap.js.map +1 -1
  71. package/dist/DualAxisLineChart.cjs +1 -1
  72. package/dist/DualAxisLineChart.cjs.map +1 -1
  73. package/dist/DualAxisLineChart.d.ts +13 -9
  74. package/dist/DualAxisLineChart.js +341 -351
  75. package/dist/DualAxisLineChart.js.map +1 -1
  76. package/dist/DumbbellChart.cjs +1 -1
  77. package/dist/DumbbellChart.cjs.map +1 -1
  78. package/dist/DumbbellChart.d.ts +11 -9
  79. package/dist/DumbbellChart.js +592 -593
  80. package/dist/DumbbellChart.js.map +1 -1
  81. package/dist/GeoHubCompareMaps.cjs +1 -1
  82. package/dist/GeoHubCompareMaps.d.ts +1 -1
  83. package/dist/GeoHubCompareMaps.js +1 -1
  84. package/dist/GeoHubMap.cjs +1 -1
  85. package/dist/GeoHubMap.d.ts +1 -1
  86. package/dist/GeoHubMap.js +1 -1
  87. package/dist/GeoHubMapWithLayerSelection.cjs +1 -1
  88. package/dist/GeoHubMapWithLayerSelection.d.ts +1 -1
  89. package/dist/GeoHubMapWithLayerSelection.js +1 -1
  90. package/dist/GraphEl-BgkDbq50.cjs +2 -0
  91. package/dist/GraphEl-BgkDbq50.cjs.map +1 -0
  92. package/dist/GraphEl-Ch0uAeZw.js +1830 -0
  93. package/dist/GraphEl-Ch0uAeZw.js.map +1 -0
  94. package/dist/GriddedGraphs.cjs +1 -1
  95. package/dist/GriddedGraphs.d.ts +29 -16
  96. package/dist/GriddedGraphs.js +1 -1
  97. package/dist/GriddedGraphsFromConfig.d.ts +29 -16
  98. package/dist/HeatMap.cjs +1 -1
  99. package/dist/HeatMap.cjs.map +1 -1
  100. package/dist/HeatMap.d.ts +11 -9
  101. package/dist/HeatMap.js +203 -205
  102. package/dist/HeatMap.js.map +1 -1
  103. package/dist/Histogram.cjs +1 -1
  104. package/dist/Histogram.cjs.map +1 -1
  105. package/dist/Histogram.d.ts +11 -5
  106. package/dist/Histogram.js +88 -89
  107. package/dist/Histogram.js.map +1 -1
  108. package/dist/HybridMap.cjs +1 -1
  109. package/dist/HybridMap.cjs.map +1 -1
  110. package/dist/HybridMap.d.ts +11 -3
  111. package/dist/HybridMap.js +339 -336
  112. package/dist/HybridMap.js.map +1 -1
  113. package/dist/ImageDownloadButton.cjs +1 -1
  114. package/dist/ImageDownloadButton.js +1 -1
  115. package/dist/LineChartWithConfidenceInterval.cjs +1 -1
  116. package/dist/LineChartWithConfidenceInterval.cjs.map +1 -1
  117. package/dist/LineChartWithConfidenceInterval.d.ts +11 -9
  118. package/dist/LineChartWithConfidenceInterval.js +393 -395
  119. package/dist/LineChartWithConfidenceInterval.js.map +1 -1
  120. package/dist/LinearColorLegend.cjs +1 -1
  121. package/dist/LinearColorLegend.js +1 -1
  122. package/dist/MultiGraphDashboard.d.ts +29 -16
  123. package/dist/MultiGraphDashboardFromConfig.d.ts +29 -16
  124. package/dist/MultiGraphDashboardWideToLongFormat.d.ts +1 -1
  125. package/dist/MultiGraphDashboardWideToLongFormatFromConfig.d.ts +1 -1
  126. package/dist/MultiLineAltChart.cjs +1 -1
  127. package/dist/MultiLineAltChart.cjs.map +1 -1
  128. package/dist/MultiLineAltChart.d.ts +11 -9
  129. package/dist/MultiLineAltChart.js +411 -413
  130. package/dist/MultiLineAltChart.js.map +1 -1
  131. package/dist/MultiLineChart.cjs +1 -1
  132. package/dist/MultiLineChart.cjs.map +1 -1
  133. package/dist/MultiLineChart.d.ts +11 -9
  134. package/dist/MultiLineChart.js +438 -440
  135. package/dist/MultiLineChart.js.map +1 -1
  136. package/dist/ParetoChart.cjs +1 -1
  137. package/dist/ParetoChart.cjs.map +1 -1
  138. package/dist/ParetoChart.d.ts +13 -13
  139. package/dist/ParetoChart.js +347 -355
  140. package/dist/ParetoChart.js.map +1 -1
  141. package/dist/PerformanceIntensiveMultiGraphDashboard.d.ts +29 -16
  142. package/dist/PerformanceIntensiveMultiGraphDashboardFromConfig.d.ts +29 -16
  143. package/dist/PerformanceIntensiveScrollStory.d.ts +29 -16
  144. package/dist/RadarChart.cjs +1 -1
  145. package/dist/RadarChart.cjs.map +1 -1
  146. package/dist/RadarChart.d.ts +11 -5
  147. package/dist/RadarChart.js +213 -213
  148. package/dist/RadarChart.js.map +1 -1
  149. package/dist/SankeyChart.cjs +1 -1
  150. package/dist/SankeyChart.cjs.map +1 -1
  151. package/dist/SankeyChart.d.ts +11 -9
  152. package/dist/SankeyChart.js +448 -450
  153. package/dist/SankeyChart.js.map +1 -1
  154. package/dist/ScatterPlot.cjs +1 -1
  155. package/dist/ScatterPlot.cjs.map +1 -1
  156. package/dist/ScatterPlot.d.ts +15 -13
  157. package/dist/ScatterPlot.js +477 -483
  158. package/dist/ScatterPlot.js.map +1 -1
  159. package/dist/ScrollStory.d.ts +29 -16
  160. package/dist/SimpleLineChart.cjs +1 -1
  161. package/dist/SimpleLineChart.cjs.map +1 -1
  162. package/dist/SimpleLineChart.d.ts +11 -9
  163. package/dist/SimpleLineChart.js +362 -364
  164. package/dist/SimpleLineChart.js.map +1 -1
  165. package/dist/SingleGraphDashboard.cjs +1 -1
  166. package/dist/SingleGraphDashboard.d.ts +29 -16
  167. package/dist/SingleGraphDashboard.js +1 -1
  168. package/dist/SingleGraphDashboardFromConfig.d.ts +29 -16
  169. package/dist/SingleGraphDashboardGeoHubMaps.d.ts +29 -16
  170. package/dist/SingleGraphDashboardGeoHubMapsFromConfig.d.ts +29 -16
  171. package/dist/SingleGraphDashboardThreeDGraphs.cjs +1 -1
  172. package/dist/SingleGraphDashboardThreeDGraphs.cjs.map +1 -1
  173. package/dist/SingleGraphDashboardThreeDGraphs.d.ts +29 -16
  174. package/dist/SingleGraphDashboardThreeDGraphs.js +40 -39
  175. package/dist/SingleGraphDashboardThreeDGraphs.js.map +1 -1
  176. package/dist/SingleGraphDashboardThreeDGraphsFromConfig.d.ts +29 -16
  177. package/dist/SlopeChart.cjs +1 -1
  178. package/dist/SlopeChart.d.ts +1 -1
  179. package/dist/SlopeChart.js +2 -2
  180. package/dist/SparkLine.cjs +1 -1
  181. package/dist/SparkLine.d.ts +1 -1
  182. package/dist/SparkLine.js +1 -1
  183. package/dist/StatCardFromData.cjs +1 -1
  184. package/dist/StatCardFromData.cjs.map +1 -1
  185. package/dist/StatCardFromData.d.ts +11 -9
  186. package/dist/StatCardFromData.js +113 -116
  187. package/dist/StatCardFromData.js.map +1 -1
  188. package/dist/StripChart.cjs +1 -1
  189. package/dist/StripChart.cjs.map +1 -1
  190. package/dist/StripChart.d.ts +11 -9
  191. package/dist/StripChart.js +434 -435
  192. package/dist/StripChart.js.map +1 -1
  193. package/dist/ThreeDGlobe.cjs +1 -1
  194. package/dist/ThreeDGlobe.cjs.map +1 -1
  195. package/dist/ThreeDGlobe.d.ts +11 -3
  196. package/dist/ThreeDGlobe.js +143 -143
  197. package/dist/ThreeDGlobe.js.map +1 -1
  198. package/dist/ThresholdColorLegendWithMouseOver.cjs +1 -1
  199. package/dist/ThresholdColorLegendWithMouseOver.js +1 -1
  200. package/dist/{Tooltip-Bj-s__cI.js → Tooltip-3EYDVa3w.js} +2 -2
  201. package/dist/{Tooltip-Bj-s__cI.js.map → Tooltip-3EYDVa3w.js.map} +1 -1
  202. package/dist/{Tooltip-Hr46paWP.cjs → Tooltip-C9F3uYG0.cjs} +2 -2
  203. package/dist/{Tooltip-Hr46paWP.cjs.map → Tooltip-C9F3uYG0.cjs.map} +1 -1
  204. package/dist/TreeMapGraph.cjs +1 -1
  205. package/dist/TreeMapGraph.cjs.map +1 -1
  206. package/dist/TreeMapGraph.d.ts +11 -9
  207. package/dist/TreeMapGraph.js +369 -371
  208. package/dist/TreeMapGraph.js.map +1 -1
  209. package/dist/Types.d.ts +29 -16
  210. package/dist/UnitChart.cjs +1 -1
  211. package/dist/UnitChart.cjs.map +1 -1
  212. package/dist/UnitChart.d.ts +11 -5
  213. package/dist/UnitChart.js +118 -119
  214. package/dist/UnitChart.js.map +1 -1
  215. package/dist/WaterfallChart.cjs +1 -1
  216. package/dist/WaterfallChart.cjs.map +1 -1
  217. package/dist/WaterfallChart.d.ts +11 -9
  218. package/dist/WaterfallChart.js +306 -308
  219. package/dist/WaterfallChart.js.map +1 -1
  220. package/dist/XTicksAndGridLines-B4UhDVyU.cjs +2 -0
  221. package/dist/XTicksAndGridLines-B4UhDVyU.cjs.map +1 -0
  222. package/dist/XTicksAndGridLines-CkYwVshF.js +40 -0
  223. package/dist/XTicksAndGridLines-CkYwVshF.js.map +1 -0
  224. package/dist/YTicksAndGridLines-BbujwxOB.js +40 -0
  225. package/dist/YTicksAndGridLines-BbujwxOB.js.map +1 -0
  226. package/dist/YTicksAndGridLines-sT3zdCs6.cjs +2 -0
  227. package/dist/YTicksAndGridLines-sT3zdCs6.cjs.map +1 -0
  228. package/dist/{imageDownload-Diofs_vY.js → imageDownload-BYsNEtMS.js} +11 -11
  229. package/dist/{imageDownload-Diofs_vY.js.map → imageDownload-BYsNEtMS.js.map} +1 -1
  230. package/dist/{imageDownload-61q6jyJW.cjs → imageDownload-CkMwA7Cw.cjs} +4 -4
  231. package/dist/{imageDownload-61q6jyJW.cjs.map → imageDownload-CkMwA7Cw.cjs.map} +1 -1
  232. package/dist/index-BPyj_6hG.js +375 -0
  233. package/dist/index-BPyj_6hG.js.map +1 -0
  234. package/dist/index-DuLvdHo2.cjs +2 -0
  235. package/dist/index-DuLvdHo2.cjs.map +1 -0
  236. package/dist/index.cjs +1 -1
  237. package/dist/index.d.ts +108 -245
  238. package/dist/index.js +3 -3
  239. package/dist/numberFormattingFunction-BUUV_luR.js +28 -0
  240. package/dist/numberFormattingFunction-BUUV_luR.js.map +1 -0
  241. package/dist/numberFormattingFunction-u2iNHL_c.cjs +2 -0
  242. package/dist/numberFormattingFunction-u2iNHL_c.cjs.map +1 -0
  243. package/dist/{string2HTML-ZoGd08P_.cjs → string2HTML-30nfIm8R.cjs} +2 -2
  244. package/dist/{string2HTML-ZoGd08P_.cjs.map → string2HTML-30nfIm8R.cjs.map} +1 -1
  245. package/dist/{string2HTML-BrFperRM.js → string2HTML-DL-pInUB.js} +2 -2
  246. package/dist/{string2HTML-BrFperRM.js.map → string2HTML-DL-pInUB.js.map} +1 -1
  247. package/dist/style.css +1 -1
  248. package/dist/utils.cjs +1 -1
  249. package/dist/utils.d.ts +1 -1
  250. package/dist/utils.js +2 -2
  251. package/package.json +2 -2
  252. package/dist/GraphEl-B73N4RIA.js +0 -1906
  253. package/dist/GraphEl-B73N4RIA.js.map +0 -1
  254. package/dist/GraphEl-Lt1og0C-.cjs +0 -2
  255. package/dist/GraphEl-Lt1og0C-.cjs.map +0 -1
  256. package/dist/XTicksAndGridLines-C5DuC5oY.cjs +0 -2
  257. package/dist/XTicksAndGridLines-C5DuC5oY.cjs.map +0 -1
  258. package/dist/XTicksAndGridLines-gdbGX2rm.js +0 -39
  259. package/dist/XTicksAndGridLines-gdbGX2rm.js.map +0 -1
  260. package/dist/YTicksAndGridLines-CsNSq9W9.js +0 -39
  261. package/dist/YTicksAndGridLines-CsNSq9W9.js.map +0 -1
  262. package/dist/YTicksAndGridLines-DFjm8RCc.cjs +0 -2
  263. package/dist/YTicksAndGridLines-DFjm8RCc.cjs.map +0 -1
  264. package/dist/index-B0Awa_de.js +0 -377
  265. package/dist/index-B0Awa_de.js.map +0 -1
  266. package/dist/index-CP8cmNzt.cjs +0 -2
  267. package/dist/index-CP8cmNzt.cjs.map +0 -1
  268. package/dist/numberFormattingFunction-Cn9R7CM9.cjs +0 -2
  269. package/dist/numberFormattingFunction-Cn9R7CM9.cjs.map +0 -1
  270. package/dist/numberFormattingFunction-DqMf_v1m.js +0 -28
  271. package/dist/numberFormattingFunction-DqMf_v1m.js.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"BeeSwarmChart.js","sources":["../src/Components/Graphs/BeeSwarmChart/Graph.tsx","../src/Components/Graphs/BeeSwarmChart/index.tsx"],"sourcesContent":["import isEqual from 'fast-deep-equal';\r\nimport { scaleLinear, scaleSqrt } from 'd3-scale';\r\nimport { forceCollide, forceManyBody, forceSimulation, forceX, forceY } from 'd3-force';\r\nimport { useEffect, useRef, useState } from 'react';\r\nimport orderBy from 'lodash.orderby';\r\nimport { cn } from '@undp/design-system-react/cn';\r\nimport { Spinner } from '@undp/design-system-react/Spinner';\r\nimport { P } from '@undp/design-system-react/Typography';\r\n\r\nimport {\r\n BeeSwarmChartDataType,\r\n ClassNameObject,\r\n CustomLayerDataType,\r\n ReferenceDataType,\r\n StyleObject,\r\n} from '@/Types';\r\nimport { numberFormattingFunction } from '@/Utils/numberFormattingFunction';\r\nimport { Tooltip } from '@/Components/Elements/Tooltip';\r\nimport { checkIfNullOrUndefined } from '@/Utils/checkIfNullOrUndefined';\r\nimport { getTextColorBasedOnBgColor } from '@/Utils/getTextColorBasedOnBgColor';\r\nimport { Colors } from '@/Components/ColorPalette';\r\nimport { Axis } from '@/Components/Elements/Axes/Axis';\r\nimport { RefLineX, RefLineY } from '@/Components/Elements/ReferenceLine';\r\nimport { YTicksAndGridLines } from '@/Components/Elements/Axes/YTicksAndGridLines';\r\nimport { XTicksAndGridLines } from '@/Components/Elements/Axes/XTicksAndGridLines';\r\nimport { DetailsModal } from '@/Components/Elements/DetailsModal';\r\n\r\ninterface BeeSwarmChartDataTypeForBubbleChart extends BeeSwarmChartDataType {\r\n x: number;\r\n y: number;\r\n vx: number;\r\n vy: number;\r\n}\r\n\r\ninterface Props {\r\n data: BeeSwarmChartDataType[];\r\n circleColors: string[];\r\n colorDomain: string[];\r\n showTicks: boolean;\r\n leftMargin?: number;\r\n rightMargin?: number;\r\n topMargin?: number;\r\n bottomMargin?: number;\r\n showLabels: boolean;\r\n width: number;\r\n height: number;\r\n suffix: string;\r\n prefix: string;\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 refValues?: ReferenceDataType[];\r\n selectedColor?: string;\r\n startFromZero: boolean;\r\n radius: number;\r\n maxRadiusValue?: number;\r\n maxValue?: number;\r\n minValue?: number;\r\n highlightedDataPoints?: (string | number)[];\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseClick?: (_d: any) => void;\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 noOfTicks: number;\r\n dimmedOpacity: number;\r\n precision: number;\r\n customLayers: CustomLayerDataType[];\r\n rtl?: boolean;\r\n hideAxisLine: boolean;\r\n locale: string;\r\n}\r\n\r\nexport function VerticalGraph(props: Props) {\r\n const {\r\n data,\r\n circleColors,\r\n showTicks,\r\n width,\r\n height,\r\n colorDomain,\r\n topMargin = 25,\r\n bottomMargin = 10,\r\n leftMargin = 100,\r\n rightMargin = 40,\r\n suffix,\r\n prefix,\r\n showLabels,\r\n tooltip,\r\n onSeriesMouseOver,\r\n refValues,\r\n selectedColor,\r\n startFromZero,\r\n radius,\r\n maxRadiusValue,\r\n maxValue,\r\n minValue,\r\n highlightedDataPoints,\r\n onSeriesMouseClick,\r\n resetSelectionOnDoubleClick,\r\n detailsOnClick,\r\n styles,\r\n classNames,\r\n noOfTicks,\r\n dimmedOpacity,\r\n precision,\r\n customLayers,\r\n hideAxisLine,\r\n locale,\r\n } = props;\r\n const svgRef = useRef(null);\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 [finalData, setFinalData] = useState<BeeSwarmChartDataTypeForBubbleChart[] | null>(null);\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 dataOrdered =\r\n data.filter(d => !checkIfNullOrUndefined(d.radius)).length === 0\r\n ? data\r\n : orderBy(\r\n data.filter(d => !checkIfNullOrUndefined(d.radius)),\r\n 'radius',\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 !startFromZero\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)) >=\r\n 0 && !startFromZero\r\n ? 0\r\n : Math.min(...data.filter(d => !checkIfNullOrUndefined(d.position)).map(d => d.position));\r\n\r\n const radiusScale =\r\n data.filter(d => d.radius === undefined || d.radius === null).length !== data.length\r\n ? scaleSqrt()\r\n .domain([\r\n 0,\r\n checkIfNullOrUndefined(maxRadiusValue)\r\n ? Math.max(...data.map(d => d.radius).filter(d => d !== undefined && d !== null))\r\n : (maxRadiusValue as number),\r\n ])\r\n .range([0.25, radius])\r\n .nice()\r\n : undefined;\r\n const y = scaleLinear().domain([yMinValue, yMaxValue]).range([graphHeight, 0]).nice();\r\n const yTicks = y.ticks(noOfTicks);\r\n\r\n useEffect(() => {\r\n const dataTemp = (\r\n dataOrdered.map(d => ({\r\n ...d,\r\n ...(d.data && { data: { ...d.data } }),\r\n })) as BeeSwarmChartDataType[]\r\n ).filter(d => d.position);\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n forceSimulation(dataTemp as any)\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n .force('y', forceY((d: any) => y(d.position as number)).strength(5))\r\n .force('x', forceX(_d => graphWidth / 2).strength(1))\r\n .force(\r\n 'collide',\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n forceCollide((d: any) => (radiusScale ? radiusScale(d.radius || 0) + 1 : radius + 1)),\r\n )\r\n .force('charge', forceManyBody().strength(-15))\r\n .alphaDecay(0.05)\r\n .tick(10000)\r\n .on('tick', () => {\r\n setFinalData(dataTemp as BeeSwarmChartDataTypeForBubbleChart[]);\r\n })\r\n .on('end', () => {\r\n setFinalData(dataTemp as BeeSwarmChartDataTypeForBubbleChart[]);\r\n });\r\n }, [data, radius, graphHeight, graphWidth, yMinValue, yMaxValue, dataOrdered, y, radiusScale]);\r\n\r\n return (\r\n <>\r\n {finalData ? (\r\n <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 {showTicks ? (\r\n <>\r\n <Axis\r\n hideAxisLine={hideAxisLine}\r\n y1={y(yMinValue < 0 ? 0 : yMinValue)}\r\n y2={y(yMinValue < 0 ? 0 : yMinValue)}\r\n x1={0 - margin.left}\r\n x2={graphWidth + margin.right}\r\n label={\r\n showTicks\r\n ? numberFormattingFunction(\r\n yMinValue < 0 ? 0 : yMinValue,\r\n undefined,\r\n precision,\r\n prefix,\r\n suffix,\r\n locale,\r\n )\r\n : undefined\r\n }\r\n labelPos={{\r\n x: 0 - margin.left,\r\n y: y(yMinValue < 0 ? 0 : yMinValue),\r\n dx: 0,\r\n dy: yMaxValue < 0 ? '1em' : -5,\r\n }}\r\n classNames={{\r\n axis: classNames?.xAxis?.axis,\r\n label: classNames?.yAxis?.labels,\r\n }}\r\n styles={{\r\n axis: styles?.xAxis?.axis,\r\n label: styles?.yAxis?.labels,\r\n }}\r\n />\r\n <YTicksAndGridLines\r\n values={yTicks.filter(d => d !== 0)}\r\n y={yTicks.filter(d => d !== 0).map(d => y(d))}\r\n x1={0 - margin.left}\r\n x2={graphWidth + margin.right}\r\n styles={{\r\n gridLines: styles?.yAxis?.gridLines,\r\n labels: styles?.yAxis?.labels,\r\n }}\r\n classNames={{\r\n gridLines: classNames?.yAxis?.gridLines,\r\n labels: classNames?.yAxis?.labels,\r\n }}\r\n suffix={suffix}\r\n prefix={prefix}\r\n labelType='secondary'\r\n showGridLines\r\n labelPos='vertical'\r\n precision={precision}\r\n locale={locale}\r\n />\r\n </>\r\n ) : null}\r\n {customLayers.filter(d => d.position === 'before').map(d => d.layer)}\r\n {finalData.map(d => (\r\n <g\r\n className='undp-viz-g-with-hover'\r\n key={d.label}\r\n transform={`translate(${d.x},${d.y})`}\r\n opacity={\r\n selectedColor\r\n ? d.color\r\n ? circleColors[colorDomain.indexOf(d.color)] === selectedColor\r\n ? 1\r\n : dimmedOpacity\r\n : dimmedOpacity\r\n : highlightedDataPoints\r\n ? highlightedDataPoints.indexOf(d.label) !== -1\r\n ? 0.85\r\n : dimmedOpacity\r\n : 0.85\r\n }\r\n onMouseEnter={event => {\r\n setMouseOverData(d);\r\n setEventY(event.clientY);\r\n setEventX(event.clientX);\r\n onSeriesMouseOver?.(d);\r\n }}\r\n onMouseMove={event => {\r\n setMouseOverData(d);\r\n setEventY(event.clientY);\r\n setEventX(event.clientX);\r\n }}\r\n 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 onMouseLeave={() => {\r\n setMouseOverData(undefined);\r\n setEventX(undefined);\r\n setEventY(undefined);\r\n onSeriesMouseOver?.(undefined);\r\n }}\r\n >\r\n <circle\r\n cx={0}\r\n cy={0}\r\n r={radiusScale ? radiusScale(d.radius || 0) : radius}\r\n fill={\r\n data.filter(el => el.color).length === 0\r\n ? circleColors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : circleColors[colorDomain.indexOf(d.color)]\r\n }\r\n />\r\n {(radiusScale ? radiusScale(d.radius || 0) : radius) > 10 && showLabels ? (\r\n <g>\r\n <foreignObject\r\n y={0 - (radiusScale ? radiusScale(d.radius || 0) : radius)}\r\n x={0 - (radiusScale ? radiusScale(d.radius || 0) : radius)}\r\n width={2 * (radiusScale ? radiusScale(d.radius || 0) : radius)}\r\n height={2 * (radiusScale ? radiusScale(d.radius || 0) : radius)}\r\n >\r\n <div className='flex flex-col justify-center items-center h-inherit py-0 px-1.5'>\r\n {showLabels ? (\r\n <p\r\n className={cn(\r\n 'text-center leading-none m-0',\r\n classNames?.graphObjectValues,\r\n )}\r\n style={{\r\n fontSize: `${Math.min(\r\n Math.max(\r\n Math.round(\r\n (radiusScale ? radiusScale(d.radius || 0) : radius) / 4,\r\n ),\r\n 10,\r\n ),\r\n Math.max(\r\n Math.round(\r\n ((radiusScale ? radiusScale(d.radius || 0) : radius) * 12) /\r\n `${d.label}`.length,\r\n ),\r\n 10,\r\n ),\r\n 20,\r\n )}px`,\r\n hyphens: 'auto',\r\n color: getTextColorBasedOnBgColor(\r\n data.filter(el => el.color).length === 0\r\n ? circleColors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : circleColors[colorDomain.indexOf(d.color)],\r\n ),\r\n ...(styles?.graphObjectValues || {}),\r\n }}\r\n >\r\n {d.label}\r\n </p>\r\n ) : null}\r\n </div>\r\n </foreignObject>\r\n </g>\r\n ) : null}\r\n </g>\r\n ))}\r\n {refValues ? (\r\n <>\r\n {refValues.map((el, i) => (\r\n <RefLineY\r\n key={i}\r\n text={el.text}\r\n color={el.color}\r\n y={y(el.value as number)}\r\n x1={0 - margin.left}\r\n x2={graphWidth + margin.right}\r\n classNames={el.classNames}\r\n styles={el.styles}\r\n isInView={true}\r\n />\r\n ))}\r\n </>\r\n ) : null}\r\n {customLayers.filter(d => d.position === 'after').map(d => d.layer)}\r\n </g>\r\n </svg>\r\n ) : (\r\n <div style={{ width: `${width}px`, height: `${height}px` }}>\r\n <div className='flex m-auto items-center justify-center p-0 leading-none text-base h-40'>\r\n <Spinner />\r\n </div>\r\n </div>\r\n )}\r\n {mouseOverData && tooltip && eventX && eventY ? (\r\n <Tooltip\r\n data={mouseOverData}\r\n body={tooltip}\r\n xPos={eventX}\r\n yPos={eventY}\r\n backgroundStyle={styles?.tooltip}\r\n className={classNames?.tooltip}\r\n />\r\n ) : null}\r\n {detailsOnClick && mouseClickData !== undefined ? (\r\n <DetailsModal\r\n body={detailsOnClick}\r\n data={mouseClickData}\r\n setData={setMouseClickData}\r\n className={classNames?.modal}\r\n />\r\n ) : null}\r\n </>\r\n );\r\n}\r\n\r\nexport function HorizontalGraph(props: Props) {\r\n const {\r\n data,\r\n circleColors,\r\n showTicks,\r\n width,\r\n height,\r\n colorDomain,\r\n topMargin = 25,\r\n bottomMargin = 10,\r\n leftMargin = 10,\r\n rightMargin = 10,\r\n showLabels,\r\n tooltip,\r\n onSeriesMouseOver,\r\n refValues,\r\n selectedColor,\r\n startFromZero,\r\n radius,\r\n maxRadiusValue,\r\n maxValue,\r\n minValue,\r\n highlightedDataPoints,\r\n onSeriesMouseClick,\r\n rtl,\r\n resetSelectionOnDoubleClick,\r\n detailsOnClick,\r\n suffix,\r\n prefix,\r\n styles,\r\n classNames,\r\n noOfTicks,\r\n dimmedOpacity,\r\n precision,\r\n customLayers,\r\n hideAxisLine,\r\n locale,\r\n } = props;\r\n const svgRef = useRef(null);\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 [finalData, setFinalData] = useState<BeeSwarmChartDataTypeForBubbleChart[] | null>(null);\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 dataOrdered =\r\n data.filter(d => !checkIfNullOrUndefined(d.radius)).length === 0\r\n ? data\r\n : orderBy(\r\n data.filter(d => !checkIfNullOrUndefined(d.radius)),\r\n 'radius',\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 !startFromZero\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)) >=\r\n 0 && !startFromZero\r\n ? 0\r\n : Math.min(...data.filter(d => !checkIfNullOrUndefined(d.position)).map(d => d.position));\r\n\r\n const radiusScale =\r\n data.filter(d => d.radius === undefined || d.radius === null).length !== data.length\r\n ? scaleSqrt()\r\n .domain([\r\n 0,\r\n checkIfNullOrUndefined(maxRadiusValue)\r\n ? Math.max(...data.map(d => d.radius).filter(d => d !== undefined && d !== null))\r\n : (maxRadiusValue as number),\r\n ])\r\n .range([0.25, radius])\r\n .nice()\r\n : undefined;\r\n const x = scaleLinear().domain([xMinValue, xMaxValue]).range([0, graphWidth]).nice();\r\n const xTicks = x.ticks(noOfTicks);\r\n\r\n useEffect(() => {\r\n const dataTemp = (\r\n dataOrdered.map(d => ({\r\n ...d,\r\n ...(d.data && { data: { ...d.data } }),\r\n })) as BeeSwarmChartDataType[]\r\n ).filter(d => d.position);\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n forceSimulation(dataTemp as any)\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n .force('x', forceX((d: any) => x(d.position as number)).strength(5))\r\n .force('y', forceY(_d => graphHeight / 2).strength(1))\r\n .force(\r\n 'collide',\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n forceCollide((d: any) => (radiusScale ? radiusScale(d.radius || 0) + 1 : radius + 1)),\r\n )\r\n .force('charge', forceManyBody().strength(-15))\r\n .alphaDecay(0.05)\r\n .tick(10000)\r\n .on('tick', () => {\r\n setFinalData(dataTemp as BeeSwarmChartDataTypeForBubbleChart[]);\r\n })\r\n .on('end', () => {\r\n setFinalData(dataTemp as BeeSwarmChartDataTypeForBubbleChart[]);\r\n });\r\n }, [data, radius, graphHeight, graphWidth, xMinValue, xMaxValue, dataOrdered, x, radiusScale]);\r\n\r\n return (\r\n <>\r\n {finalData ? (\r\n <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 {showTicks ? (\r\n <>\r\n <Axis\r\n hideAxisLine={hideAxisLine}\r\n x1={x(xMinValue < 0 ? 0 : xMinValue)}\r\n x2={x(xMinValue < 0 ? 0 : xMinValue)}\r\n y1={0 - margin.top}\r\n y2={graphHeight + margin.bottom}\r\n label={\r\n showTicks\r\n ? numberFormattingFunction(\r\n xMinValue < 0 ? 0 : xMinValue,\r\n undefined,\r\n precision,\r\n prefix,\r\n suffix,\r\n locale,\r\n )\r\n : undefined\r\n }\r\n labelPos={{\r\n x: x(xMinValue < 0 ? 0 : xMinValue),\r\n y: 0 - topMargin,\r\n dy: '0.75em',\r\n dx: 3,\r\n }}\r\n classNames={{\r\n axis: classNames?.xAxis?.axis,\r\n label: classNames?.yAxis?.labels,\r\n }}\r\n styles={{\r\n axis: styles?.xAxis?.axis,\r\n label: styles?.yAxis?.labels,\r\n }}\r\n />\r\n <XTicksAndGridLines\r\n values={xTicks.filter(d => d !== 0)}\r\n x={xTicks.filter(d => d !== 0).map(d => x(d))}\r\n y1={0 - topMargin}\r\n y2={graphHeight + margin.bottom}\r\n styles={{\r\n gridLines: styles?.xAxis?.gridLines,\r\n labels: styles?.xAxis?.labels,\r\n }}\r\n classNames={{\r\n gridLines: classNames?.xAxis?.gridLines,\r\n labels: classNames?.xAxis?.labels,\r\n }}\r\n suffix={suffix}\r\n prefix={prefix}\r\n labelType='secondary'\r\n showGridLines\r\n precision={precision}\r\n locale={locale}\r\n />\r\n </>\r\n ) : null}\r\n {customLayers.filter(d => d.position === 'before').map(d => d.layer)}\r\n {finalData.map(d => (\r\n <g\r\n className='undp-viz-g-with-hover'\r\n key={d.label}\r\n transform={`translate(${d.x},${d.y})`}\r\n opacity={\r\n selectedColor\r\n ? d.color\r\n ? circleColors[colorDomain.indexOf(d.color)] === selectedColor\r\n ? 1\r\n : dimmedOpacity\r\n : dimmedOpacity\r\n : highlightedDataPoints\r\n ? highlightedDataPoints.indexOf(d.label) !== -1\r\n ? 0.85\r\n : dimmedOpacity\r\n : 0.85\r\n }\r\n onMouseEnter={event => {\r\n setMouseOverData(d);\r\n setEventY(event.clientY);\r\n setEventX(event.clientX);\r\n onSeriesMouseOver?.(d);\r\n }}\r\n onMouseMove={event => {\r\n setMouseOverData(d);\r\n setEventY(event.clientY);\r\n setEventX(event.clientX);\r\n }}\r\n 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 onMouseLeave={() => {\r\n setMouseOverData(undefined);\r\n setEventX(undefined);\r\n setEventY(undefined);\r\n onSeriesMouseOver?.(undefined);\r\n }}\r\n >\r\n <circle\r\n cx={0}\r\n cy={0}\r\n fill={\r\n data.filter(el => el.color).length === 0\r\n ? circleColors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : circleColors[colorDomain.indexOf(d.color)]\r\n }\r\n radius={radiusScale ? radiusScale(d.radius || 0) : radius}\r\n />\r\n {(radiusScale ? radiusScale(d.radius || 0) : radius) > 10 && showLabels ? (\r\n <g>\r\n <foreignObject\r\n y={0 - (radiusScale ? radiusScale(d.radius || 0) : radius)}\r\n x={0 - (radiusScale ? radiusScale(d.radius || 0) : radius)}\r\n width={2 * (radiusScale ? radiusScale(d.radius || 0) : radius)}\r\n height={2 * (radiusScale ? radiusScale(d.radius || 0) : radius)}\r\n >\r\n <div className='flex flex-col gap-0.5 justify-center items-center h-inherit py-0 px-1.5'>\r\n {showLabels ? (\r\n <P\r\n className={cn(\r\n 'text-center leading-none m-0',\r\n classNames?.graphObjectValues,\r\n )}\r\n marginBottom='none'\r\n style={{\r\n fontSize: `${Math.min(\r\n Math.max(\r\n Math.round(\r\n (radiusScale ? radiusScale(d.radius || 0) : radius) / 4,\r\n ),\r\n 10,\r\n ),\r\n Math.max(\r\n Math.round(\r\n ((radiusScale ? radiusScale(d.radius || 0) : radius) * 12) /\r\n `${d.label}`.length,\r\n ),\r\n 10,\r\n ),\r\n 20,\r\n )}px`,\r\n color: getTextColorBasedOnBgColor(\r\n data.filter(el => el.color).length === 0\r\n ? circleColors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : circleColors[colorDomain.indexOf(d.color)],\r\n ),\r\n hyphens: 'auto',\r\n ...(styles?.graphObjectValues || {}),\r\n }}\r\n >\r\n {d.label}\r\n </P>\r\n ) : null}\r\n </div>\r\n </foreignObject>\r\n </g>\r\n ) : null}\r\n </g>\r\n ))}\r\n {refValues ? (\r\n <>\r\n {refValues.map((el, i) => (\r\n <RefLineX\r\n key={i}\r\n text={el.text}\r\n color={el.color}\r\n x={x(el.value as number)}\r\n y1={0 - margin.top}\r\n y2={graphHeight + margin.bottom}\r\n textSide={x(el.value as number) > graphWidth * 0.75 || rtl ? 'left' : 'right'}\r\n classNames={el.classNames}\r\n styles={el.styles}\r\n isInView={true}\r\n />\r\n ))}\r\n </>\r\n ) : null}\r\n {customLayers.filter(d => d.position === 'after').map(d => d.layer)}\r\n </g>\r\n </svg>\r\n ) : (\r\n <div style={{ width: `${width}px`, height: `${height}px` }}>\r\n <div className='flex m-auto items-center justify-center p-0 leading-none text-base h-40'>\r\n <Spinner />\r\n </div>\r\n </div>\r\n )}\r\n {mouseOverData && tooltip && eventX && eventY ? (\r\n <Tooltip\r\n data={mouseOverData}\r\n body={tooltip}\r\n xPos={eventX}\r\n yPos={eventY}\r\n backgroundStyle={styles?.tooltip}\r\n className={classNames?.tooltip}\r\n />\r\n ) : null}\r\n {detailsOnClick && mouseClickData !== undefined ? (\r\n <DetailsModal\r\n body={detailsOnClick}\r\n data={mouseClickData}\r\n setData={setMouseClickData}\r\n className={classNames?.modal}\r\n />\r\n ) : null}\r\n </>\r\n );\r\n}\r\n","import { useEffect, useRef, useState } from 'react';\r\n\r\nimport { HorizontalGraph, VerticalGraph } from './Graph';\r\n\r\nimport { uniqBy } from '@/Utils/uniqBy';\r\nimport {\r\n ReferenceDataType,\r\n SourcesDataType,\r\n Languages,\r\n BeeSwarmChartDataType,\r\n StyleObject,\r\n ClassNameObject,\r\n CustomLayerDataType,\r\n} from '@/Types';\r\nimport { Colors } from '@/Components/ColorPalette';\r\nimport { GraphHeader } from '@/Components/Elements/GraphHeader';\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\n\r\ninterface Props {\r\n // Data\r\n /** Array of data objects */\r\n data: BeeSwarmChartDataType[];\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 circle */\r\n colors?: string | string[];\r\n /** Domain of colors for the graph */\r\n colorDomain?: string[];\r\n /** Title for the color legend */\r\n colorLegendTitle?: string;\r\n /** Background color of the graph */\r\n backgroundColor?: string | boolean;\r\n /** Custom styles for the graph. Each object should be a valid React CSS style object. */\r\n styles?: StyleObject;\r\n /** Custom class names */\r\n classNames?: ClassNameObject;\r\n\r\n // Size and Spacing\r\n /** Width of the graph */\r\n width?: number;\r\n /** Height of the graph */\r\n height?: number;\r\n /** Minimum height of the graph */\r\n minHeight?: number;\r\n /** Relative height scaling factor. This overwrites the height props */\r\n relativeHeight?: number;\r\n /** Padding around the graph. Defaults to 0 if no backgroundColor is mentioned else defaults to 1rem */\r\n padding?: string;\r\n /** 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 radius of the circle */\r\n maxRadiusValue?: number;\r\n /** Minimum value for position of the circle */\r\n minValue?: number;\r\n /** Maximum value for position of the circle */\r\n maxValue?: number;\r\n /** Reference values for comparison */\r\n refValues?: ReferenceDataType[];\r\n /** Number of ticks on the axis */\r\n noOfTicks?: number;\r\n\r\n // Graph Parameters\r\n /** Toggle visibility of labels */\r\n showLabels?: boolean;\r\n /** Toggle visibility of values */\r\n showTicks?: boolean;\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 /** Toggle visibility of axis line for the main axis */\r\n hideAxisLine?: 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 /** Maximum radius of the circles */\r\n radius?: number;\r\n /** Specifies the number of decimal places to display in the value. */\r\n precision?: number;\r\n /** Locale for number formatting. Must matches what `Intl.NumberFormat` expects. */\r\n locale?: string;\r\n /** Optional SVG <g> element or function that renders custom content behind or in front of the graph. */\r\n customLayers?: CustomLayerDataType[];\r\n /** Enable graph download option as png */\r\n graphDownload?: boolean;\r\n /** Enable data download option as a csv */\r\n dataDownload?: boolean;\r\n /** 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 BeeSwarmChart(props: Props) {\r\n const {\r\n data,\r\n graphTitle,\r\n topMargin,\r\n bottomMargin,\r\n leftMargin,\r\n rightMargin,\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 padding,\r\n relativeHeight,\r\n tooltip,\r\n onSeriesMouseOver,\r\n refValues,\r\n showColorScale,\r\n graphID,\r\n radius = 5,\r\n showLabels = true,\r\n showTicks = true,\r\n maxRadiusValue,\r\n maxValue,\r\n minValue,\r\n highlightedDataPoints,\r\n onSeriesMouseClick,\r\n ariaLabel,\r\n backgroundColor = false,\r\n graphDownload = false,\r\n dataDownload = false,\r\n language = 'en',\r\n showNAColor = true,\r\n minHeight = 0,\r\n theme = 'light',\r\n resetSelectionOnDoubleClick = true,\r\n detailsOnClick,\r\n orientation = 'vertical',\r\n suffix = '',\r\n prefix = '',\r\n styles,\r\n classNames,\r\n noOfTicks = 5,\r\n dimmedOpacity = 0.3,\r\n precision = 2,\r\n customLayers = [],\r\n hideAxisLine = false,\r\n locale = 'en',\r\n } = props;\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 const Comp = orientation === 'horizontal' ? HorizontalGraph : VerticalGraph;\r\n\r\n useEffect(() => {\r\n const resizeObserver = new ResizeObserver(entries => {\r\n setSvgWidth(entries[0].target.clientWidth || 620);\r\n setSvgHeight(entries[0].target.clientHeight || 480);\r\n });\r\n if (graphDiv.current) {\r\n resizeObserver.observe(graphDiv.current);\r\n }\r\n return () => resizeObserver.disconnect();\r\n }, []);\r\n return (\r\n <GraphContainer\r\n className={classNames?.graphContainer}\r\n style={styles?.graphContainer}\r\n id={graphID}\r\n ref={graphParentDiv}\r\n aria-label={ariaLabel}\r\n backgroundColor={backgroundColor}\r\n theme={theme}\r\n language={language}\r\n minHeight={minHeight}\r\n width={width}\r\n height={height}\r\n relativeHeight={relativeHeight}\r\n padding={padding}\r\n >\r\n {graphTitle || graphDescription || graphDownload || dataDownload ? (\r\n <GraphHeader\r\n styles={{\r\n title: styles?.title,\r\n description: styles?.description,\r\n }}\r\n classNames={{\r\n title: classNames?.title,\r\n description: classNames?.description,\r\n }}\r\n graphTitle={graphTitle}\r\n graphDescription={graphDescription}\r\n width={width}\r\n graphDownload={graphDownload ? graphParentDiv : undefined}\r\n dataDownload={\r\n dataDownload\r\n ? data.map(d => d.data).filter(d => d !== undefined).length > 0\r\n ? data.map(d => d.data).filter(d => d !== undefined)\r\n : data.filter(d => d !== undefined)\r\n : null\r\n }\r\n />\r\n ) : null}\r\n {showColorScale !== false && data.filter(el => el.color).length !== 0 && data.length > 0 ? (\r\n <ColorLegendWithMouseOver\r\n width={width}\r\n colorLegendTitle={colorLegendTitle}\r\n colors={(colors as string[] | undefined) || Colors[theme].categoricalColors.colors}\r\n colorDomain={colorDomain || (uniqBy(data, 'color', true) as string[])}\r\n setSelectedColor={setSelectedColor}\r\n showNAColor={showNAColor}\r\n className={classNames?.colorLegend}\r\n />\r\n ) : null}\r\n <GraphArea ref={graphDiv}>\r\n {data.length === 0 && <EmptyState />}\r\n {svgWidth && svgHeight && data.length > 0 ? (\r\n <Comp\r\n hideAxisLine={hideAxisLine}\r\n data={data}\r\n circleColors={\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 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 width={svgWidth}\r\n selectedColor={selectedColor}\r\n height={svgHeight}\r\n showTicks={showTicks}\r\n leftMargin={leftMargin}\r\n rightMargin={rightMargin}\r\n topMargin={topMargin}\r\n bottomMargin={bottomMargin}\r\n showLabels={showLabels}\r\n tooltip={tooltip}\r\n onSeriesMouseOver={onSeriesMouseOver}\r\n refValues={refValues}\r\n startFromZero={false}\r\n radius={radius}\r\n maxRadiusValue={maxRadiusValue}\r\n maxValue={maxValue}\r\n minValue={minValue}\r\n highlightedDataPoints={highlightedDataPoints}\r\n onSeriesMouseClick={onSeriesMouseClick}\r\n resetSelectionOnDoubleClick={resetSelectionOnDoubleClick}\r\n detailsOnClick={detailsOnClick}\r\n styles={styles}\r\n classNames={classNames}\r\n suffix={suffix}\r\n prefix={prefix}\r\n noOfTicks={noOfTicks || 5}\r\n dimmedOpacity={dimmedOpacity}\r\n precision={precision}\r\n customLayers={customLayers}\r\n locale={locale}\r\n />\r\n ) : null}\r\n </GraphArea>\r\n {sources || footNote ? (\r\n <GraphFooter\r\n styles={{ footnote: styles?.footnote, source: styles?.source }}\r\n classNames={{\r\n footnote: classNames?.footnote,\r\n source: classNames?.source,\r\n }}\r\n sources={sources}\r\n footNote={footNote}\r\n width={width}\r\n />\r\n ) : null}\r\n </GraphContainer>\r\n );\r\n}\r\n"],"names":["VerticalGraph","props","$","_c","data","circleColors","showTicks","width","height","colorDomain","topMargin","t0","bottomMargin","t1","leftMargin","t2","rightMargin","t3","suffix","prefix","showLabels","tooltip","onSeriesMouseOver","refValues","selectedColor","startFromZero","radius","maxRadiusValue","maxValue","minValue","highlightedDataPoints","onSeriesMouseClick","resetSelectionOnDoubleClick","detailsOnClick","styles","classNames","noOfTicks","dimmedOpacity","precision","customLayers","hideAxisLine","locale","undefined","svgRef","useRef","mouseOverData","setMouseOverData","useState","mouseClickData","setMouseClickData","finalData","setFinalData","eventX","setEventX","eventY","setEventY","t4","top","bottom","left","right","margin","graphWidth","graphHeight","dataOrdered","filter","_temp","length","orderBy","_temp2","t5","checkIfNullOrUndefined","Math","max","_temp3","map","_temp4","_temp5","_temp6","yMaxValue","t6","min","_temp7","_temp8","_temp9","_temp0","yMinValue","radiusScale","_temp1","scaleSqrt","domain","_temp10","_temp11","range","nice","y","scaleLinear","yTicks","ticks","useEffect","dataTemp","_temp12","_temp13","forceSimulation","force","forceY","d_14","d","position","strength","forceX","_d","forceCollide","d_15","forceManyBody","alphaDecay","tick","on","t7","jsx","jsxs","Fragment","Axis","numberFormattingFunction","x","dx","dy","axis","xAxis","label","yAxis","labels","YTicksAndGridLines","_temp14","_temp15","d_18","gridLines","_temp16","_temp17","d_21","color","indexOf","event","clientY","clientX","event_0","isEqual","_temp18","Colors","gray","cn","graphObjectValues","fontSize","round","hyphens","getTextColorBasedOnBgColor","_temp19","el_1","i","RefLineY","el","text","value","_temp20","_temp21","Spinner","t8","Tooltip","t9","modal","DetailsModal","t10","d_23","layer","d_22","el_0","d_20","d_19","d_17","d_16","d_13","d_12","d_10","d_9","d_11","d_6","d_5","d_8","d_7","d_2","d_1","d_4","d_3","d_0","HorizontalGraph","rtl","_temp22","_temp23","_temp24","_temp25","_temp26","_temp27","xMaxValue","_temp28","_temp29","_temp30","_temp31","xMinValue","_temp32","_temp33","_temp34","xTicks","_temp35","_temp36","XTicksAndGridLines","_temp37","_temp38","_temp39","_temp40","_temp41","P","_temp42","RefLineX","_temp43","_temp44","BeeSwarmChart","graphTitle","colors","sources","graphDescription","footNote","colorLegendTitle","padding","relativeHeight","showColorScale","graphID","ariaLabel","backgroundColor","graphDownload","dataDownload","language","showNAColor","minHeight","theme","orientation","t11","t12","t13","t14","t15","t16","t17","t18","t19","t20","svgWidth","setSvgWidth","svgHeight","setSvgHeight","setSelectedColor","graphDiv","graphParentDiv","Comp","t21","t22","Symbol","for","resizeObserver","ResizeObserver","entries","target","clientWidth","clientHeight","current","observe","disconnect","t23","graphContainer","t24","t25","description","title","GraphHeader","t26","colorLegend","ColorLegendWithMouseOver","categoricalColors","uniqBy","t27","EmptyState","t28","primaryColors","t29","GraphArea","t30","footnote","source","GraphFooter","t31","GraphContainer"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;AA4EO,SAAAA,GAAAC,GAAA;AAAA,QAAAC,IAAAC,GAAAA,EAAA,EAAA,GACL;AAAA,IAAAC,MAAAA;AAAAA,IAAAC,cAAAA;AAAAA,IAAAC,WAAAA;AAAAA,IAAAC,OAAAA;AAAAA,IAAAC,QAAAA;AAAAA,IAAAC,aAAAA;AAAAA,IAAAC,WAAAC;AAAAA,IAAAC,cAAAC;AAAAA,IAAAC,YAAAC;AAAAA,IAAAC,aAAAC;AAAAA,IAAAC,QAAAA;AAAAA,IAAAC,QAAAA;AAAAA,IAAAC,YAAAA;AAAAA,IAAAC,SAAAA;AAAAA,IAAAC,mBAAAA;AAAAA,IAAAC,WAAAA;AAAAA,IAAAC,eAAAA;AAAAA,IAAAC,eAAAA;AAAAA,IAAAC,QAAAA;AAAAA,IAAAC,gBAAAA;AAAAA,IAAAC,UAAAA;AAAAA,IAAAC,UAAAA;AAAAA,IAAAC,uBAAAA;AAAAA,IAAAC,oBAAAA;AAAAA,IAAAC,6BAAAA;AAAAA,IAAAC,gBAAAA;AAAAA,IAAAC,QAAAA;AAAAA,IAAAC,YAAAA;AAAAA,IAAAC,WAAAA;AAAAA,IAAAC,eAAAA;AAAAA,IAAAC,WAAAA;AAAAA,IAAAC,cAAAA;AAAAA,IAAAC,cAAAA;AAAAA,IAAAC,QAAAA;AAAAA,EAAAA,IAmCIxC,GA5BFS,KAAAC,MAAA+B,SAAA,KAAA/B,GACAC,IAAAC,MAAA6B,SAAA,KAAA7B,GACAC,KAAAC,MAAA2B,SAAA,MAAA3B,GACAC,KAAAC,OAAAyB,SAAA,KAAAzB,IA0BF0B,KAAeC,GAAO,IAAI,GAE1B,CAAAC,IAAAC,CAAA,IAA0CC,EAAcL,MAAS,GAEjE,CAAAM,GAAAC,CAAA,IAA4CF,EAAcL,MAAS,GACnE,CAAAQ,GAAAC,EAAA,IAAkCJ,EAAuD,IAAI,GAC7F,CAAAK,IAAAC,CAAA,IAA4BN,EAA6BL,MAAS,GAClE,CAAAY,GAAAC,CAAA,IAA4BR,EAA6BL,MAAS;AAAE,MAAAc;AAAA,EAAAtD,EAAA,CAAA,MAAAU,KAAAV,EAAA,CAAA,MAAAY,MAAAZ,EAAA,CAAA,MAAAc,MAAAd,SAAAQ,MACrD8C,IAAA;AAAA,IAAAC,KACR/C;AAAAA,IAASgD,QACN9C;AAAAA,IAAY+C,MACd7C;AAAAA,IAAU8C,OACT5C;AAAAA,EAAAA,GACRd,OAAAU,GAAAV,OAAAY,IAAAZ,OAAAc,IAAAd,OAAAQ,IAAAR,OAAAsD,KAAAA,IAAAtD,EAAA,CAAA;AALD,QAAA2D,IAAeL,GAMfM,IAAmBvD,IAAQsD,EAAMF,OAAQE,EAAMD,OAC/CG,KAAoBvD,IAASqD,EAAMJ,MAAOI,EAAMH,QAEhDM,IACE5D,EAAI6D,OAAQC,EAAsC,EAACC,WAAY,IAA/D/D,IAEIgE,GACEhE,EAAI6D,OAAQI,EAAsC,GAClD,UACA,MACF;AAAE,MAAAC;AAAA,EAAApE,EAAA,CAAA,MAAAE,KAAAF,SAAA0B,KAAA1B,EAAA,CAAA,MAAAuB,KACU6C,IAACC,EAAuB3C,CAAQ,IAE9C4C,KAAIC,IAAI,GAAIrE,EAAI6D,OAAQS,EAAwC,EAACC,IAAKC,EAAe,CAAC,IAAI,KAA1F,CACGnD,IADH,IAGE+C,KAAIC,OAAQrE,EAAI6D,OAAQY,EAAwC,EAACF,IAAKG,EAAe,CAAC,IAJvFlD,GAIwF1B,OAAAE,GAAAF,OAAA0B,GAAA1B,OAAAuB,GAAAvB,OAAAoE,KAAAA,IAAApE,EAAA,CAAA;AAL7F,QAAA6E,IAAkBT;AAK4E,MAAAU;AAAA,EAAA9E,EAAA,CAAA,MAAAE,KAAAF,UAAA2B,KAAA3B,EAAA,EAAA,MAAAuB,KAC5EuD,IAACT,EAAuB1C,CAAQ,IAE9C2C,KAAIS,IAAI,GAAI7E,EAAI6D,OAAQiB,EAAwC,EAACP,IAAKQ,EAAe,CAAC,KAClF,KADJ,CACU1D,IADV,IAGE+C,KAAIS,OAAQ7E,EAAI6D,OAAQmB,EAAwC,EAACT,IAAKU,EAAe,CAAC,IAJvFxD,GAIwF3B,OAAAE,GAAAF,QAAA2B,GAAA3B,QAAAuB,GAAAvB,QAAA8E,KAAAA,IAAA9E,EAAA,EAAA;AAL7F,QAAAoF,IAAkBN,GAOlBO,IACEnF,EAAI6D,OAAQuB,EAAgD,EAACrB,WAAY/D,EAAI+D,SACzEsB,GAAAA,EAAWC,OACD,CACN,GACAnB,EAAuB5C,CAEM,IADzB6C,KAAIC,IAAI,GAAIrE,EAAIuE,IAAKgB,EAAa,EAAC1B,OAAQ2B,EAAkC,CACpD,IAAxBjE,CAAyB,CAC/B,EAACkE,MACK,CAAC,MAAMnE,CAAM,CAAC,EAACoE,SAR5BpD,QAWFqD,IAAUC,GAAAA,EAAaN,OAAQ,CAACJ,GAAWP,CAAS,CAAC,EAACc,MAAO,CAAC9B,IAAa,CAAC,CAAC,EAAC+B,KAAAA,GAC9EG,IAAeF,EAACG,MAAO9D,CAAS;AAEhC+D,EAAAA,GAAU,MAAA;AACR,UAAAC,IACEpC,EAAWW,IAAK0B,EAGd,EAA4BpC,OACvBqC,EAAe;AAExBC,IAAAA,GAAgBH,CAAe,EAACI,MAEvB,KAAKC,GAAOC,CAAAA,MAAYX,EAAEY,EAACC,QAAmB,CAAC,EAACC,SAAU,CAAC,CAAC,EAACL,MAC7D,KAAKM,GAAOC,CAAAA,MAAMjD,IAAa,CAAC,EAAC+C,SAAU,CAAC,CAAC,EAACL,MAEnD,WAEAQ,GAAaC,CAAAA,MAAa1B,IAAcA,EAAYoB,EAACjF,UAAD,CAAa,IAAI,IAAIA,IAAS,CAAE,CACtF,EAAC8E,MACM,UAAUU,KAAeL,SAAU,GAAG,CAAC,EAACM,WACnC,IAAI,EAACC,KACX,GAAK,EAACC,GACR,QAAQ,MAAA;AACVlE,MAAAA,GAAaiD,CAAiD;AAAA,IAAC,CAChE,EAACiB,GACE,OAAO,MAAA;AACTlE,MAAAA,GAAaiD,CAAiD;AAAA,IAAC,CAChE;AAAA,EAAC,GACH,CAAChG,GAAMsB,GAAQqC,IAAaD,GAAYwB,GAAWP,GAAWf,GAAa+B,GAAGR,CAAW,CAAC;AAIxF,QAAA+B,KAAApE,IACCqE,gBAAAA,EAAAA,aACS,OAAA,GAAGhH,CAAK,MACP,QAAA,GAAGC,CAAM,MACR,gBAAOD,CAAK,IAAIC,CAAM,IACrB,WAAA,OACLmC,KAAAA,IAEL,UAAA6E,gBAAAA,EAAAA,KAAA,KAAA,EAAc,WAAA,aAAa3D,EAAMF,IAAK,IAAIE,EAAMJ,GAAI,KACjDnD,UAAAA;AAAAA,IAAAA,KAAAkH,gBAAAA,EAAAA,KAAAC,YAAA,EAEG,UAAA;AAAA,MAAAF,gBAAAA,MAACG,MACelF,cAAAA,IACV,IAAAuD,EAAET,IAAY,IAAZ,IAAAA,CAA6B,GAC/B,IAAAS,EAAET,IAAY,IAAZ,IAAAA,CAA6B,GAC/B,QAAIzB,EAAMF,MACV,IAAAG,IAAaD,EAAMD,OAErB,OAAAtD,KACIqH,GACErC,IAAY,IAAZ,IAAAA,GACA5C,QACAJ,IACAnB,GACAD,GACAuB,EAEM,IATZC,QAWQ,UAAA;AAAA,QAAAkF,GACL,IAAI/D,EAAMF;AAAAA,QAAKoC,GACfA,EAAET,IAAY,IAAZ,IAAAA,CAA6B;AAAA,QAACuC,IAC/B;AAAA,QAACC,IACD/C,IAAY,IAAZ,QAAA;AAAA,MAAA,GAEM,YAAA;AAAA,QAAAgD,MACJ5F,GAAU6F,OAAaD;AAAAA,QAAAE,OACtB9F,GAAU+F,OAAeC;AAAAA,MAAAA,GAE1B,QAAA;AAAA,QAAAJ,MACA7F,GAAM8F,OAAaD;AAAAA,QAAAE,OAClB/F,GAAMgG,OAAeC;AAAAA,MAAAA,GAC7B;AAAA,MAEHZ,gBAAAA,EAAAA,IAACa,IAAA,EACS,QAAAnC,EAAMhC,OAAQoE,EAAY,GAC/B,GAAApC,EAAMhC,OAAQqE,EAAY,EAAC3D,IAAK4D,OAAKxC,EAAEY,CAAC,CAAC,GACxC,IAAA,IAAI9C,EAAMF,MACV,IAAAG,IAAaD,EAAMD,OACf,QAAA;AAAA,QAAA4E,WACKtG,GAAMgG,OAAkBM;AAAAA,QAAAL,QAC3BjG,GAAMgG,OAAeC;AAAAA,MAAAA,GAEnB,YAAA;AAAA,QAAAK,WACCrG,GAAU+F,OAAkBM;AAAAA,QAAAL,QAC/BhG,GAAU+F,OAAeC;AAAAA,MAAAA,GAE3BjH,QAAAA,GACAC,QAAAA,GACE,WAAA,aACV,eAAA,IACS,UAAA,YACEmB,WAAAA,IACHG,QAAAA,GAAAA,CAAM;AAAA,IAAA,EAAA,CACd,IAvDL;AAAA,IA0DAF,GAAY0B,OAAQwE,EAA4B,EAAC9D,IAAK+D,EAAY;AAAA,IAClExF,EAASyB,IAAKgE,CAAAA,6BACb,KAAA,EACY,WAAA,yBAEC,WAAA,aAAahC,EAACiB,CAAE,IAAIjB,EAACZ,CAAE,KAEhC,SAAAvE,IACImF,EAACiC,SACCvI,EAAaI,EAAWoI,QAASlC,EAACiC,KAAM,CAAC,MAAMpH,IAA/C,IADFa,KAKAP,KACEA,GAAqB+G,QAASlC,EAACsB,KAAM,MAAM,KAA3C,OAAA5F,KADF,MAMQ,cAAAyG,CAAAA,MAAA;AACZhG,MAAAA,EAAiB6D,CAAC,GAClBpD,EAAUuF,EAAKC,OAAQ,GACvB1F,EAAUyF,EAAKE,OAAQ,GACvB1H,KAAoBqF,CAAC;AAAA,IAAC,GAEX,aAAAsC,CAAAA,MAAA;AACXnG,MAAAA,EAAiB6D,CAAC,GAClBpD,EAAUuF,EAAKC,OAAQ,GACvB1F,EAAUyF,EAAKE,OAAQ;AAAA,IAAC,GAEjB,SAAA,MAAA;AACP,OAAIjH,MAAAE,OACEiH,GAAQlG,GAAgB2D,CAAgC,KAAxD3E,KACFiB,EAAkBP,MAAS,GAC3BX,KAAqBW,MAAS,MAE9BO,EAAkB0D,CAAC,GACnB5E,KAAqB4E,CAAC;AAAA,IAEzB,GAEW,cAAA,MAAA;AACZ7D,MAAAA,EAAiBJ,MAAS,GAC1BW,EAAUX,MAAS,GACnBa,EAAUb,MAAS,GACnBpB,KAAoBoB,MAAS;AAAA,IAAC,GAGhC,UAAA;AAAA,MAAA6E,gBAAAA,EAAAA,IAAA,UAAA,EACM,OACA,IAAA,GACD,GAAAhC,IAAcA,EAAYoB,EAACjF,UAAD,CAAsB,IAAhDA,GAED,MAAAtB,EAAI6D,OAAQkF,EAAc,EAAChF,WAAY,IACnC9D,EAAY,CAAA,IACXsG,EAACiC,QAEAvI,EAAaI,EAAWoI,QAASlC,EAACiC,KAAM,CAAC,IADzCQ,GAAMC,MACoC;AAAA,OAGlD9D,IAAcA,EAAYoB,EAACjF,UAAD,CAAsB,IAAhDA,KAAqD,MAAtDN,IACCmG,gBAAAA,EAAAA,IAAA,KAAA,EACE,UAAAA,gBAAAA,EAAAA,IAAA,iBAAA,EACK,GAAA,KAAKhC,IAAcA,EAAYoB,EAACjF,UAAD,CAAsB,IAAhDA,IACL,QAAK6D,IAAcA,EAAYoB,EAACjF,UAAD,CAAsB,IAAhDA,IACD,YAAK6D,IAAcA,EAAYoB,EAACjF,UAAD,CAAsB,IAAhDA,IACJ,aAAK6D,IAAcA,EAAYoB,EAACjF,UAAD,CAAsB,IAAhDA,IAEb,UAAA6F,gBAAAA,EAAAA,IAAA,OAAA,EAAe,WAAA,mEACZnG,UAAAA,IACCmG,gBAAAA,EAAAA,IAAA,KAAA,EACa,WAAA+B,GACT,gCACAnH,GAAUoH,iBACZ,GACO,OAAA;AAAA,QAAAC,UACK,GAAGhF,KAAIS,IACfT,KAAIC,IACFD,KAAIiF,OACDlE,IAAcA,EAAYoB,EAACjF,UAAD,CAAsB,IAAhDA,KAAqD,CACxD,GACA,EACF,GACA8C,KAAIC,IACFD,KAAIiF,OACAlE,IAAcA,EAAYoB,EAACjF,UAAD,CAAsB,IAAhDA,KAAqD,KACrD,GAAGiF,EAACsB,KAAM,GAAE9D,MAChB,GACA,EACF,GACA,EACF,CAAC;AAAA,QAAIuF,SACI;AAAA,QAAMd,OACRe,GACLvJ,EAAI6D,OAAQ2F,EAAc,EAACzF,WAAY,IACnC9D,OACCsG,EAACiC,QAEAvI,EAAaI,EAAWoI,QAASlC,EAACiC,KAAM,CAAC,IADzCQ,GAAMC,IAEd;AAAA,QAAC,GACGnH,GAAMqH,qBAAN,CAAA;AAAA,MAA8B,GAGnC5C,UAAAA,EAACsB,MAAAA,CACJ,IAnCD,MAqCH,EAAA,CACF,GACF,IAhDD;AAAA,IAAA,KAxDItB,EAACsB,KA0GR,CACD;AAAA,IACA1G,IAAAgG,gBAAAA,EAAAA,IAAAE,EAAAA,UAAA,EAEIlG,UAAAA,EAASoD,IAAK,CAAAkF,GAAAC,MACbvC,gBAAAA,EAAAA,IAACwC,IAAA,EAEO,MAAAC,EAAEC,MACD,OAAAD,EAAEpB,OACN,GAAA7C,EAAEiE,EAAEE,KAAgB,GACnB,IAAA,IAAIrG,EAAMF,MACV,IAAAG,IAAaD,EAAMD,OACX,YAAAoG,EAAE7H,YACN,QAAA6H,EAAE9H,QACA,gBARL4H,CAQS,CAEjB,GAAC,IAdL;AAAA,IAiBAvH,GAAY0B,OAAQkG,EAA2B,EAACxF,IAAKyF,EAAY;AAAA,EAAA,EAAA,CACpE,EAAA,CACF,IAEA7C,gBAAAA,EAAAA,IAAA,OAAA,EAAY,OAAA;AAAA,IAAAhH,OAAS,GAAGA,CAAK;AAAA,IAAIC,QAAU,GAAGA,CAAM;AAAA,EAAA,GAClD,gCAAA,OAAA,EAAe,WAAA,2EACb,UAAA+G,gBAAAA,EAAAA,IAAC8C,IAAA,KACH,EAAA,CACF;AACD,MAAAC;AAAA,EAAApK,EAAA,EAAA,MAAAiC,GAAAd,WAAAnB,EAAA,EAAA,MAAAkD,MAAAlD,EAAA,EAAA,MAAAoD,KAAApD,EAAA,EAAA,MAAA2C,MAAA3C,EAAA,EAAA,MAAAgC,GAAAb,WAAAnB,EAAA,EAAA,MAAAmB,KACAiJ,IAAAzH,MAAAxB,KAAA+B,MAAAE,0BACEiH,IAAA,EACO1H,UACAxB,MAAAA,GACA+B,UACAE,MAAAA,GACW,iBAAApB,GAAMb,SACZ,WAAAc,GAAUd,SAAS,IAPjC,MASOnB,EAAA,EAAA,IAAAiC,GAAAd,SAAAnB,QAAAkD,IAAAlD,QAAAoD,GAAApD,QAAA2C,IAAA3C,EAAA,EAAA,IAAAgC,GAAAb,SAAAnB,QAAAmB,GAAAnB,QAAAoK,KAAAA,IAAApK,EAAA,EAAA;AAAA,MAAAsK;AAAA,EAAAtK,EAAA,EAAA,MAAAiC,GAAAsI,SAAAvK,EAAA,EAAA,MAAA+B,KAAA/B,EAAA,EAAA,MAAA8C,KACPwH,IAAAvI,KAAkBe,MAAmBN,SACpC6E,gBAAAA,EAAAA,IAACmD,MACOzI,MAAAA,GACAe,MAAAA,GACGC,SAAAA,GACE,WAAAd,GAAUsI,OAAO,IAL/B,MAOOvK,EAAA,EAAA,IAAAiC,GAAAsI,OAAAvK,QAAA+B,GAAA/B,QAAA8C,GAAA9C,QAAAsK,KAAAA,IAAAtK,EAAA,EAAA;AAAA,MAAAyK;AAAA,SAAAzK,EAAA,EAAA,MAAAoH,MAAApH,UAAAoK,KAAApK,EAAA,EAAA,MAAAsK,KAhOVG,IAAAnD,gBAAAA,EAAAA,KAAAC,YAAA,EACGH,UAAAA;AAAAA,IAAAA;AAAAA,IA8MAgD;AAAAA,IAUAE;AAAAA,EAAAA,GAOO,GACPtK,QAAAoH,IAAApH,QAAAoK,GAAApK,QAAAsK,GAAAtK,QAAAyK,KAAAA,IAAAzK,EAAA,EAAA,GAjOHyK;AAiOG;AAxVA,SAAAP,GAAAQ,GAAA;AAAA,SA4TgEjE,EAACkE;AAAM;AA5TvE,SAAAV,GAAAW,GAAA;AAAA,SA4T+BnE,EAACC,aAAc;AAAO;AA5TrD,SAAAgD,GAAAmB,GAAA;AAAA,SAyR2Cf,EAAEpB;AAAM;AAzRnD,SAAAO,GAAAa,GAAA;AAAA,SAgP+BA,EAAEpB;AAAM;AAhPvC,SAAAF,GAAAsC,GAAA;AAAA,SA2LiErE,EAACkE;AAAM;AA3LxE,SAAApC,GAAAwC,GAAA;AAAA,SA2L+BtE,EAACC,aAAc;AAAQ;AA3LtD,SAAA0B,GAAA4C,GAAA;AAAA,SAsKiCvE,MAAM;AAAC;AAtKxC,SAAA0B,GAAA8C,GAAA;AAAA,SAqKsCxE,MAAM;AAAC;AArK7C,SAAAL,GAAA8E,GAAA;AAAA,SAgGWzE,EAACC;AAAS;AAhGrB,SAAAP,GAAAgF,GAAA;AAAA,SA4FqB;AAAA,IAAA,GACjB1E;AAAAA,IAAC,GACAA,EAACvG,QAAD;AAAA,MAAAA,MAAkB;AAAA,QAAA,GAAKuG,EAACvG;AAAAA,MAAAA;AAAAA,IAAM;AAAA,EAAE;AACrC;AA/FA,SAAAwF,GAAA0F,GAAA;AAAA,SAiF4E3E,KAAM;AAAI;AAjFtF,SAAAhB,GAAA4F,GAAA;AAAA,SAiFmC5E,EAACjF;AAAO;AAjF3C,SAAA8D,GAAAgG,GAAA;AAAA,SA4Ec7E,EAACjF,WAAYgB,UAAaiE,EAACjF,WAAY;AAAI;AA5EzD,SAAA2D,GAAAoG,GAAA;AAAA,SAyE4E9E,EAACC;AAAS;AAzEtF,SAAAxB,GAAAsG,GAAA;AAAA,SAyE8B,CAACnH,EAAuBoC,EAACC,QAAS;AAAC;AAzEjE,SAAAzB,GAAAwG,GAAA;AAAA,SAsE0EhF,EAACC;AAAS;AAtEpF,SAAA1B,GAAA0G,GAAA;AAAA,SAsE4B,CAACrH,EAAuBoC,EAACC,QAAS;AAAC;AAtE/D,SAAA9B,GAAA+G,GAAA;AAAA,SAmE4ElF,EAACC;AAAS;AAnEtF,SAAA/B,GAAAiH,GAAA;AAAA,SAmE8B,CAACvH,EAAuBoC,EAACC,QAAS;AAAC;AAnEjE,SAAAhC,GAAAmH,GAAA;AAAA,SAgE0EpF,EAACC;AAAS;AAhEpF,SAAAlC,GAAAsH,GAAA;AAAA,SAgE4B,CAACzH,EAAuBoC,EAACC,QAAS;AAAC;AAhE/D,SAAAvC,GAAAsC,GAAA;AAAA,SA0DoB,CAACpC,EAAuBoC,EAACjF,MAAO;AAAC;AA1DrD,SAAAwC,GAAA+H,GAAA;AAAA,SAuDc,CAAC1H,EAAuBoC,EAACjF,MAAO;AAAC;AAqS/C,SAAAwK,GAAAjM,GAAA;AAAA,QAAAC,IAAAC,GAAAA,EAAA,EAAA,GACL;AAAA,IAAAC,MAAAA;AAAAA,IAAAC,cAAAA;AAAAA,IAAAC,WAAAA;AAAAA,IAAAC,OAAAA;AAAAA,IAAAC,QAAAA;AAAAA,IAAAC,aAAAA;AAAAA,IAAAC,WAAAC;AAAAA,IAAAC,cAAAC;AAAAA,IAAAC,YAAAC;AAAAA,IAAAC,aAAAC;AAAAA,IAAAG,YAAAA;AAAAA,IAAAC,SAAAA;AAAAA,IAAAC,mBAAAA;AAAAA,IAAAC,WAAAA;AAAAA,IAAAC,eAAAA;AAAAA,IAAAC,eAAAA;AAAAA,IAAAC,QAAAA;AAAAA,IAAAC,gBAAAA;AAAAA,IAAAC,UAAAA;AAAAA,IAAAC,UAAAA;AAAAA,IAAAC,uBAAAA;AAAAA,IAAAC,oBAAAA;AAAAA,IAAAoK,KAAAA;AAAAA,IAAAnK,6BAAAA;AAAAA,IAAAC,gBAAAA;AAAAA,IAAAf,QAAAA;AAAAA,IAAAC,QAAAA;AAAAA,IAAAe,QAAAA;AAAAA,IAAAC,YAAAA;AAAAA,IAAAC,WAAAA;AAAAA,IAAAC,eAAAA;AAAAA,IAAAC,WAAAA;AAAAA,IAAAC,cAAAA;AAAAA,IAAAC,cAAAA;AAAAA,IAAAC,QAAAA;AAAAA,EAAAA,IAoCIxC,GA7BFS,IAAAC,MAAA+B,SAAA,KAAA/B,GACAC,KAAAC,MAAA6B,SAAA,KAAA7B,GACAC,KAAAC,MAAA2B,SAAA,KAAA3B,GACAC,KAAAC,OAAAyB,SAAA,KAAAzB,IA2BF0B,KAAeC,GAAO,IAAI,GAE1B,CAAAC,GAAAC,CAAA,IAA0CC,EAAcL,MAAS,GAEjE,CAAAM,GAAAC,CAAA,IAA4CF,EAAcL,MAAS,GACnE,CAAAQ,IAAAC,EAAA,IAAkCJ,EAAuD,IAAI,GAC7F,CAAAK,GAAAC,CAAA,IAA4BN,EAA6BL,MAAS,GAClE,CAAAY,GAAAC,CAAA,IAA4BR,EAA6BL,MAAS;AAAE,MAAAc;AAAA,EAAAtD,EAAA,CAAA,MAAAU,MAAAV,EAAA,CAAA,MAAAY,MAAAZ,EAAA,CAAA,MAAAc,MAAAd,SAAAQ,KACrD8C,IAAA;AAAA,IAAAC,KACR/C;AAAAA,IAASgD,QACN9C;AAAAA,IAAY+C,MACd7C;AAAAA,IAAU8C,OACT5C;AAAAA,EAAAA,GACRd,OAAAU,IAAAV,OAAAY,IAAAZ,OAAAc,IAAAd,OAAAQ,GAAAR,OAAAsD,KAAAA,IAAAtD,EAAA,CAAA;AALD,QAAA2D,IAAeL,GAMfM,KAAmBvD,IAAQsD,EAAMF,OAAQE,EAAMD,OAC/CG,IAAoBvD,IAASqD,EAAMJ,MAAOI,EAAMH,QAEhDM,IACE5D,EAAI6D,OAAQmI,EAAsC,EAACjI,WAAY,IAA/D/D,IAEIgE,GACEhE,EAAI6D,OAAQoI,EAAsC,GAClD,UACA,MACF;AAAE,MAAA/H;AAAA,EAAApE,EAAA,CAAA,MAAAE,KAAAF,SAAA0B,KAAA1B,EAAA,CAAA,MAAAuB,KACU6C,IAACC,EAAuB3C,CAAQ,IAE9C4C,KAAIC,IAAI,GAAIrE,EAAI6D,OAAQqI,EAAwC,EAAC3H,IAAK4H,EAAe,CAAC,IAAI,KAA1F,CACG9K,IADH,IAGE+C,KAAIC,OAAQrE,EAAI6D,OAAQuI,EAAwC,EAAC7H,IAAK8H,EAAe,CAAC,IAJvF7K,GAIwF1B,OAAAE,GAAAF,OAAA0B,GAAA1B,OAAAuB,GAAAvB,OAAAoE,KAAAA,IAAApE,EAAA,CAAA;AAL7F,QAAAwM,IAAkBpI;AAK4E,MAAAU;AAAA,EAAA9E,EAAA,CAAA,MAAAE,KAAAF,UAAA2B,KAAA3B,EAAA,EAAA,MAAAuB,KAC5EuD,IAACT,EAAuB1C,CAAQ,IAE9C2C,KAAIS,IAAI,GAAI7E,EAAI6D,OAAQ0I,EAAwC,EAAChI,IAAKiI,EAAe,CAAC,KAClF,KADJ,CACUnL,IADV,IAGE+C,KAAIS,OAAQ7E,EAAI6D,OAAQ4I,EAAwC,EAAClI,IAAKmI,EAAe,CAAC,IAJvFjL,GAIwF3B,OAAAE,GAAAF,QAAA2B,GAAA3B,QAAAuB,GAAAvB,QAAA8E,KAAAA,IAAA9E,EAAA,EAAA;AAL7F,QAAA6M,IAAkB/H,GAOlBO,IACEnF,EAAI6D,OAAQ+I,EAAgD,EAAC7I,WAAY/D,EAAI+D,SACzEsB,GAAAA,EAAWC,OACD,CACN,GACAnB,EAAuB5C,CAEM,IADzB6C,KAAIC,IAAI,GAAIrE,EAAIuE,IAAKsI,EAAa,EAAChJ,OAAQiJ,EAAkC,CACpD,IAAxBvL,CAAyB,CAC/B,EAACkE,MACK,CAAC,MAAMnE,CAAM,CAAC,EAACoE,SAR5BpD,QAWFkF,IAAU5B,GAAAA,EAAaN,OAAQ,CAACqH,GAAWL,CAAS,CAAC,EAAC7G,MAAO,CAAC,GAAG/B,EAAU,CAAC,EAACgC,KAAAA,GAC7EqH,KAAevF,EAAC1B,MAAO9D,EAAS;AAEhC+D,EAAAA,GAAU,MAAA;AACR,UAAAC,IACEpC,EAAWW,IAAKyI,EAGd,EAA4BnJ,OACvBoJ,EAAe;AAExB9G,IAAAA,GAAgBH,CAAe,EAACI,MAEvB,KAAKM,GAAOJ,CAAAA,MAAYkB,EAAEjB,EAACC,QAAmB,CAAC,EAACC,SAAU,CAAC,CAAC,EAACL,MAC7D,KAAKC,GAAOM,CAAAA,MAAMhD,IAAc,CAAC,EAAC8C,SAAU,CAAC,CAAC,EAACL,MAEpD,WAEAQ,GAAaC,CAAAA,MAAa1B,IAAcA,EAAYoB,EAACjF,UAAD,CAAa,IAAI,IAAIA,IAAS,CAAE,CACtF,EAAC8E,MACM,UAAUU,KAAeL,SAAU,GAAG,CAAC,EAACM,WACnC,IAAI,EAACC,KACX,GAAK,EAACC,GACR,QAAQ,MAAA;AACVlE,MAAAA,GAAaiD,CAAiD;AAAA,IAAC,CAChE,EAACiB,GACE,OAAO,MAAA;AACTlE,MAAAA,GAAaiD,CAAiD;AAAA,IAAC,CAChE;AAAA,EAAC,GACH,CAAChG,GAAMsB,GAAQqC,GAAaD,IAAYiJ,GAAWL,GAAW1I,GAAa4D,GAAGrC,CAAW,CAAC;AAIxF,QAAA+B,IAAApE,KACCqE,gBAAAA,EAAAA,aACS,OAAA,GAAGhH,CAAK,MACP,QAAA,GAAGC,CAAM,MACR,gBAAOD,CAAK,IAAIC,CAAM,IACrB,WAAA,OACLmC,KAAAA,IAEL,UAAA6E,gBAAAA,EAAAA,KAAA,KAAA,EAAc,WAAA,aAAa3D,EAAMF,IAAK,IAAIE,EAAMJ,GAAI,KACjDnD,UAAAA;AAAAA,IAAAA,KAAAkH,gBAAAA,EAAAA,KAAAC,YAAA,EAEG,UAAA;AAAA,MAAAF,gBAAAA,MAACG,MACelF,cAAAA,IACV,IAAAoF,EAAEmF,IAAY,IAAZ,IAAAA,CAA6B,GAC/B,IAAAnF,EAAEmF,IAAY,IAAZ,IAAAA,CAA6B,GAC/B,QAAIlJ,EAAMJ,KACV,IAAAM,IAAcF,EAAMH,QAEtB,OAAApD,KACIqH,GACEoF,IAAY,IAAZ,IAAAA,GACArK,QACAJ,IACAnB,GACAD,GACAuB,EAEM,IATZC,QAWQ,UAAA;AAAA,QAAAkF,GACLA,EAAEmF,IAAY,IAAZ,IAAAA,CAA6B;AAAA,QAAChH,GAChC,IAAIrF;AAAAA,QAASoH,IACZ;AAAA,QAAQD,IACR;AAAA,MAAA,GAEM,YAAA;AAAA,QAAAE,MACJ5F,GAAU6F,OAAaD;AAAAA,QAAAE,OACtB9F,GAAU+F,OAAeC;AAAAA,MAAAA,GAE1B,QAAA;AAAA,QAAAJ,MACA7F,GAAM8F,OAAaD;AAAAA,QAAAE,OAClB/F,GAAMgG,OAAeC;AAAAA,MAAAA,GAC7B;AAAA,MAEHZ,gBAAAA,EAAAA,IAAC+F,IAAA,EACS,QAAAH,GAAMlJ,OAAQsJ,EAAY,GAC/B,GAAAJ,GAAMlJ,OAAQuJ,EAAY,EAAC7I,IAAK4D,CAAAA,MAAKX,EAAEjB,CAAC,CAAC,GACxC,IAAA,IAAIjG,GACJ,IAAAqD,IAAcF,EAAMH,QAChB,QAAA;AAAA,QAAA8E,WACKtG,GAAM8F,OAAkBQ;AAAAA,QAAAL,QAC3BjG,GAAM8F,OAAeG;AAAAA,MAAAA,GAEnB,YAAA;AAAA,QAAAK,WACCrG,GAAU6F,OAAkBQ;AAAAA,QAAAL,QAC/BhG,GAAU6F,OAAeG;AAAAA,MAAAA,GAE3BjH,QAAAA,GACAC,QAAAA,GACE,WAAA,aACV,eAAA,IACWmB,WAAAA,IACHG,QAAAA,GAAAA;OACR,IAtDL;AAAA,IAyDAF,GAAY0B,OAAQwJ,EAA4B,EAAC9I,IAAK+I,EAAY;AAAA,IAClExK,GAASyB,IAAKgE,CAAAA,6BACb,KAAA,EACY,WAAA,yBAEC,WAAA,aAAahC,EAACiB,CAAE,IAAIjB,EAACZ,CAAE,KAEhC,SAAAvE,KACImF,EAACiC,SACCvI,EAAaI,EAAWoI,QAASlC,EAACiC,KAAM,CAAC,MAAMpH,KAA/C,IADFa,KAKAP,IACEA,EAAqB+G,QAASlC,EAACsB,KAAM,MAAM,KAA3C,OAAA5F,KADF,MAMQ,cAAAyG,CAAAA,MAAA;AACZhG,MAAAA,EAAiB6D,CAAC,GAClBpD,EAAUuF,EAAKC,OAAQ,GACvB1F,EAAUyF,EAAKE,OAAQ,GACvB1H,IAAoBqF,CAAC;AAAA,IAAC,GAEX,aAAAsC,CAAAA,MAAA;AACXnG,MAAAA,EAAiB6D,CAAC,GAClBpD,EAAUuF,EAAKC,OAAQ,GACvB1F,EAAUyF,EAAKE,OAAQ;AAAA,IAAC,GAEjB,SAAA,MAAA;AACP,OAAIjH,KAAAE,OACEiH,GAAQlG,GAAgB2D,CAAgC,KAAxD3E,MACFiB,EAAkBP,MAAS,GAC3BX,IAAqBW,MAAS,MAE9BO,EAAkB0D,CAAC,GACnB5E,IAAqB4E,CAAC;AAAA,IAEzB,GAEW,cAAA,MAAA;AACZ7D,MAAAA,EAAiBJ,MAAS,GAC1BW,EAAUX,MAAS,GACnBa,EAAUb,MAAS,GACnBpB,IAAoBoB,MAAS;AAAA,IAAC,GAGhC,UAAA;AAAA,MAAA6E,gBAAAA,EAAAA,IAAA,UAAA,EACM,IAAA,GACA,OAEF,MAAAnH,EAAI6D,OAAQ0J,EAAc,EAACxJ,WAAY,IACnC9D,EAAY,CAAA,IACXsG,EAACiC,QAEAvI,EAAaI,EAAWoI,QAASlC,EAACiC,KAAM,CAAC,IADzCQ,GAAMC,MAGN,QAAA9D,IAAcA,EAAYoB,EAACjF,UAAD,CAAsB,IAAhDA,GAAiD;AAAA,OAEzD6D,IAAcA,EAAYoB,EAACjF,UAAD,CAAsB,IAAhDA,KAAqD,MAAtDN,IACCmG,gBAAAA,EAAAA,WACE,UAAAA,gBAAAA,EAAAA,IAAA,mBACK,GAAA,KAAKhC,IAAcA,EAAYoB,EAACjF,UAAD,CAAsB,IAAhDA,IACL,GAAA,KAAK6D,IAAcA,EAAYoB,EAACjF,UAAD,CAAsB,IAAhDA,IACD,OAAA,KAAK6D,IAAcA,EAAYoB,EAACjF,UAAD,CAAsB,IAAhDA,IACJ,QAAA,KAAK6D,IAAcA,EAAYoB,EAACjF,UAAD,CAAsB,IAAhDA,IAEb,UAAA6F,gBAAAA,EAAAA,aAAe,WAAA,2EACZnG,UAAAA,IACCmG,gBAAAA,EAAAA,IAACqG,IAAA,EACY,WAAAtE,GACT,gCACAnH,GAAUoH,iBACZ,GACa,cAAA,QACN,OAAA;AAAA,QAAAC,UACK,GAAGhF,KAAIS,IACfT,KAAIC,IACFD,KAAIiF,OACDlE,IAAcA,EAAYoB,EAACjF,UAAD,CAAsB,IAAhDA,KAAqD,CACxD,GACA,EACF,GACA8C,KAAIC,IACFD,KAAIiF,OACAlE,IAAcA,EAAYoB,EAACjF,UAAD,CAAsB,IAAhDA,KAAqD,KACrD,GAAGiF,EAACsB,KAAM,GAAE9D,MAChB,GACA,EACF,GACA,EACF,CAAC;AAAA,QAAIyE,OACEe,GACLvJ,EAAI6D,OAAQ4J,EAAc,EAAC1J,WAAY,IACnC9D,OACCsG,EAACiC,QAEAvI,EAAaI,EAAWoI,QAASlC,EAACiC,KAAM,CAAC,IADzCQ,GAAMC,IAEd;AAAA,QAACK,SACQ;AAAA,QAAM,GACXxH,GAAMqH,qBAAN,CAAA;AAAA,MAA8B,GAGnC5C,UAAAA,EAACsB,MAAAA,CACJ,IApCD,MAsCH,EAAA,CACF,GACF,IAjDD;AAAA,IAAA,KAxDItB,EAACsB,KA2GR,CACD;AAAA,IACA1G,wCAEIA,UAAAA,EAASoD,IAAK,CAAAkF,GAAAC,MACbvC,gBAAAA,EAAAA,IAACuG,IAAA,EAEO,MAAA9D,EAAEC,MACD,OAAAD,EAAEpB,OACN,GAAAhB,EAAEoC,EAAEE,KAAgB,GACnB,IAAA,IAAIrG,EAAMJ,KACV,IAAAM,IAAcF,EAAMH,QACd,UAAAkE,EAAEoC,EAAEE,KAAgB,IAAIpG,KAAa,QAArCqI,KAAA,SAAA,SACE,YAAAnC,EAAE7H,YACN,QAAA6H,EAAE9H,QACA,UAAA,GAAA,GATL4H,CASS,CAEjB,EAAA,CAAC,IAfL;AAAA,IAkBAvH,GAAY0B,OAAQ8J,EAA2B,EAACpJ,IAAKqJ,EAAY;AAAA,EAAA,EAAA,CACpE,EAAA,CACF,IAEAzG,gBAAAA,EAAAA,IAAA,OAAA,EAAY,OAAA;AAAA,IAAAhH,OAAS,GAAGA,CAAK;AAAA,IAAIC,QAAU,GAAGA,CAAM;AAAA,EAAA,GAClD,gCAAA,OAAA,EAAe,WAAA,2EACb,UAAA+G,gBAAAA,EAAAA,IAAC8C,IAAA,KACH,EAAA,CACF;AACD,MAAAC;AAAA,EAAApK,EAAA,EAAA,MAAAiC,GAAAd,WAAAnB,EAAA,EAAA,MAAAkD,KAAAlD,EAAA,EAAA,MAAAoD,KAAApD,EAAA,EAAA,MAAA2C,KAAA3C,EAAA,EAAA,MAAAgC,GAAAb,WAAAnB,EAAA,EAAA,MAAAmB,KACAiJ,IAAAzH,KAAAxB,KAAA+B,KAAAE,0BACEiH,IAAA,EACO1H,SACAxB,MAAAA,GACA+B,SACAE,MAAAA,GACW,iBAAApB,GAAMb,SACZ,WAAAc,GAAUd,SAAS,IAPjC,MASOnB,EAAA,EAAA,IAAAiC,GAAAd,SAAAnB,QAAAkD,GAAAlD,QAAAoD,GAAApD,QAAA2C,GAAA3C,EAAA,EAAA,IAAAgC,GAAAb,SAAAnB,QAAAmB,GAAAnB,QAAAoK,KAAAA,IAAApK,EAAA,EAAA;AAAA,MAAAsK;AAAA,EAAAtK,EAAA,EAAA,MAAAiC,GAAAsI,SAAAvK,EAAA,EAAA,MAAA+B,KAAA/B,EAAA,EAAA,MAAA8C,KACPwH,IAAAvI,KAAkBe,MAAmBN,SACpC6E,gBAAAA,EAAAA,IAACmD,MACOzI,MAAAA,GACAe,MAAAA,GACGC,SAAAA,GACE,WAAAd,GAAUsI,OAAO,IAL/B,MAOOvK,EAAA,EAAA,IAAAiC,GAAAsI,OAAAvK,QAAA+B,GAAA/B,QAAA8C,GAAA9C,QAAAsK,KAAAA,IAAAtK,EAAA,EAAA;AAAA,MAAAyK;AAAA,SAAAzK,EAAA,EAAA,MAAAoH,KAAApH,UAAAoK,KAAApK,EAAA,EAAA,MAAAsK,KAjOVG,IAAAnD,gBAAAA,EAAAA,KAAAC,YAAA,EACGH,UAAAA;AAAAA,IAAAA;AAAAA,IA+MAgD;AAAAA,IAUAE;AAAAA,EAAAA,GAOO,GACPtK,QAAAoH,GAAApH,QAAAoK,GAAApK,QAAAsK,GAAAtK,QAAAyK,KAAAA,IAAAzK,EAAA,EAAA,GAlOHyK;AAkOG;AA1VA,SAAAqD,GAAApD,GAAA;AAAA,SA8TgEjE,EAACkE;AAAM;AA9TvE,SAAAkD,GAAAjD,GAAA;AAAA,SA8T+BnE,EAACC,aAAc;AAAO;AA9TrD,SAAAiH,GAAA9C,GAAA;AAAA,SAyR2Cf,EAAEpB;AAAM;AAzRnD,SAAA+E,GAAA3D,GAAA;AAAA,SA+O+BA,EAAEpB;AAAM;AA/OvC,SAAA8E,GAAA1C,GAAA;AAAA,SA2LiErE,EAACkE;AAAM;AA3LxE,SAAA4C,GAAAxC,GAAA;AAAA,SA2L+BtE,EAACC,aAAc;AAAQ;AA3LtD,SAAA4G,GAAAtC,GAAA;AAAA,SAuKiCvE,MAAM;AAAC;AAvKxC,SAAA4G,GAAApC,GAAA;AAAA,SAsKsCxE,MAAM;AAAC;AAtK7C,SAAA0G,GAAAjC,GAAA;AAAA,SAiGWzE,EAACC;AAAS;AAjGrB,SAAAwG,GAAA/B,GAAA;AAAA,SA6FqB;AAAA,IAAA,GACjB1E;AAAAA,IAAC,GACAA,EAACvG,QAAD;AAAA,MAAAA,MAAkB;AAAA,QAAA,GAAKuG,EAACvG;AAAAA,MAAAA;AAAAA,IAAM;AAAA,EAAE;AACrC;AAhGA,SAAA8M,GAAA5B,GAAA;AAAA,SAkF4E3E,KAAM;AAAI;AAlFtF,SAAAsG,GAAA1B,GAAA;AAAA,SAkFmC5E,EAACjF;AAAO;AAlF3C,SAAAsL,GAAAxB,GAAA;AAAA,SA6Ec7E,EAACjF,WAAYgB,UAAaiE,EAACjF,WAAY;AAAI;AA7EzD,SAAAoL,GAAArB,GAAA;AAAA,SA0E4E9E,EAACC;AAAS;AA1EtF,SAAAiG,GAAAnB,GAAA;AAAA,SA0E8B,CAACnH,EAAuBoC,EAACC,QAAS;AAAC;AA1EjE,SAAAgG,GAAAjB,GAAA;AAAA,SAuE0EhF,EAACC;AAAS;AAvEpF,SAAA+F,GAAAf,GAAA;AAAA,SAuE4B,CAACrH,EAAuBoC,EAACC,QAAS;AAAC;AAvE/D,SAAA6F,GAAAZ,GAAA;AAAA,SAoE4ElF,EAACC;AAAS;AApEtF,SAAA4F,GAAAV,GAAA;AAAA,SAoE8B,CAACvH,EAAuBoC,EAACC,QAAS;AAAC;AApEjE,SAAA2F,GAAAR,GAAA;AAAA,SAiE0EpF,EAACC;AAAS;AAjEpF,SAAA0F,GAAAN,GAAA;AAAA,SAiE4B,CAACzH,EAAuBoC,EAACC,QAAS;AAAC;AAjE/D,SAAAyF,GAAA1F,GAAA;AAAA,SA2DoB,CAACpC,EAAuBoC,EAACjF,MAAO;AAAC;AA3DrD,SAAA0K,GAAAH,GAAA;AAAA,SAwDc,CAAC1H,EAAuBoC,EAACjF,MAAO;AAAC;AChV/C,SAAAuM,GAAAhO,GAAA;AAAA,QAAAC,IAAAC,GAAAA,EAAA,EAAA,GACL;AAAA,IAAAC,MAAAA;AAAAA,IAAA8N,YAAAA;AAAAA,IAAAxN,WAAAA;AAAAA,IAAAE,cAAAA;AAAAA,IAAAE,YAAAA;AAAAA,IAAAE,aAAAA;AAAAA,IAAAmN,QAAAA;AAAAA,IAAAC,SAAAA;AAAAA,IAAAC,kBAAAA;AAAAA,IAAA7N,QAAAA;AAAAA,IAAAD,OAAAA;AAAAA,IAAA+N,UAAAA;AAAAA,IAAA7N,aAAAA;AAAAA,IAAA8N,kBAAAA;AAAAA,IAAAC,SAAAA;AAAAA,IAAAC,gBAAAA;AAAAA,IAAApN,SAAAA;AAAAA,IAAAC,mBAAAA;AAAAA,IAAAC,WAAAA;AAAAA,IAAAmN,gBAAAA;AAAAA,IAAAC,SAAAA;AAAAA,IAAAjN,QAAAf;AAAAA,IAAAS,YAAAP;AAAAA,IAAAP,WAAAS;AAAAA,IAAAY,gBAAAA;AAAAA,IAAAC,UAAAA;AAAAA,IAAAC,UAAAA;AAAAA,IAAAC,uBAAAA;AAAAA,IAAAC,oBAAAA;AAAAA,IAAA6M,WAAAA;AAAAA,IAAAC,iBAAA5N;AAAAA,IAAA6N,eAAAtL;AAAAA,IAAAuL,cAAAzK;AAAAA,IAAA0K,UAAAhK;AAAAA,IAAAiK,aAAA3H;AAAAA,IAAA4H,WAAA5E;AAAAA,IAAA6E,OAAA3E;AAAAA,IAAAxI,6BAAA2I;AAAAA,IAAA1I,gBAAAA;AAAAA,IAAAmN,aAAAC;AAAAA,IAAAnO,QAAAoO;AAAAA,IAAAnO,QAAAoO;AAAAA,IAAArN,QAAAA;AAAAA,IAAAC,YAAAA;AAAAA,IAAAC,WAAAoN;AAAAA,IAAAnN,eAAAoN;AAAAA,IAAAnN,WAAAoN;AAAAA,IAAAnN,cAAAoN;AAAAA,IAAAnN,cAAAoN;AAAAA,IAAAnN,QAAAoN;AAAAA,EAAAA,IAmDI5P,GA7BFyB,IAAAf,MAAA+B,SAAA,IAAA/B,GACAS,IAAAP,OAAA6B,SAAA,KAAA7B,IACAP,KAAAS,OAAA2B,SAAA,KAAA3B,IAOA8N,IAAA5N,OAAAyB,SAAA,KAAAzB,IACA6N,IAAAtL,OAAAd,SAAA,KAAAc,IACAuL,IAAAzK,OAAA5B,SAAA,KAAA4B,IACA0K,IAAAhK,OAAAtC,SAAA,OAAAsC,IACAiK,IAAA3H,OAAA5E,SAAA,KAAA4E,IACA4H,IAAA5E,MAAA5H,SAAA,IAAA4H,GACA6E,IAAA3E,OAAA9H,SAAA,UAAA8H,IACAxI,IAAA2I,OAAAjI,SAAA,KAAAiI,IAEAyE,KAAAC,OAAA3M,SAAA,aAAA2M,IACAnO,IAAAoO,MAAA5M,SAAA,KAAA4M,GACAnO,IAAAoO,MAAA7M,SAAA,KAAA6M,GAGAnN,IAAAoN,OAAA9M,SAAA,IAAA8M,IACAnN,IAAAoN,OAAA/M,SAAA,MAAA+M,IACAnN,IAAAoN,MAAAhN,SAAA,IAAAgN;AAAa,MAAAI;AAAA,EAAA5P,SAAAyP,KACbG,IAAAH,MAAAjN,SAAA,CAAA,IAAAiN,GAAiBzP,OAAAyP,GAAAzP,OAAA4P,KAAAA,IAAA5P,EAAA,CAAA;AAAjB,QAAAqC,KAAAuN,GACAtN,KAAAoN,MAAAlN,SAAA,KAAAkN,GACAnN,KAAAoN,MAAAnN,SAAA,OAAAmN,GAEF,CAAAE,IAAAC,EAAA,IAAgCjN,EAAS,CAAC,GAC1C,CAAAkN,IAAAC,EAAA,IAAkCnN,EAAS,CAAC,GAC5C,CAAAvB,IAAA2O,EAAA,IAA0CpN,EAA6BL,MAAS,GAEhF0N,KAAiBxN,GAAuB,IAAI,GAC5CyN,KAAuBzN,GAAuB,IAAI,GAClD0N,KAAalB,OAAgB,eAAhBlD,KAAAlM;AAA+D,MAAAuQ,IAAAC;AAAA,EAAAtQ,EAAA,CAAA,MAAAuQ,uBAAAC,IAAA,2BAAA,KAElEH,KAAAA,MAAA;AACR,UAAAI,KAAuB,IAAIC,eAAeC,CAAAA,OAAA;AACxCb,MAAAA,GAAYa,GAAO,CAAA,EAAGC,OAAOC,eAAjB,GAAoC,GAChDb,GAAaW,GAAO,CAAA,EAAGC,OAAOE,gBAAjB,GAAqC;AAAA,IAAC,CACpD;AACD,WAAIZ,GAAQa,WACVN,GAAcO,QAASd,GAAQa,OAAQ,GAElC,MAAMN,GAAcQ,WAAAA;AAAAA,EAAa,GACvCX,KAAA,CAAA,GAAEtQ,OAAAqQ,IAAArQ,OAAAsQ,OAAAD,KAAArQ,EAAA,CAAA,GAAAsQ,KAAAtQ,EAAA,CAAA,IATLiG,GAAUoK,IASPC,EAAE;AAGU,QAAAY,KAAAjP,GAAUkP,gBACdC,KAAApP,GAAMmP;AAAgB,MAAAE;AAAA,EAAArR,SAAAiC,GAAAqP,eAAAtR,SAAAiC,GAAAsP,SAAAvR,SAAAE,KAAAF,EAAA,CAAA,MAAA6O,KAAA7O,EAAA,CAAA,MAAAmO,KAAAnO,EAAA,CAAA,MAAA4O,KAAA5O,UAAAgO,KAAAhO,EAAA,EAAA,MAAAgC,GAAAsP,eAAAtR,EAAA,EAAA,MAAAgC,GAAAuP,SAAAvR,EAAA,EAAA,MAAAK,KAa5BgR,KAAArD,KAAAG,KAAAS,KAAAC,IACCxH,gBAAAA,MAACmK,MACS,QAAA;AAAA,IAAAD,OACCvP,GAAMuP;AAAAA,IAAOD,aACPtP,GAAMsP;AAAAA,EAAAA,GAET,YAAA;AAAA,IAAAC,OACHtP,GAAUsP;AAAAA,IAAOD,aACXrP,GAAUqP;AAAAA,EAAAA,GAEbtD,YAAAA,GACMG,kBAAAA,GACX9N,OAAAA,GACQ,eAAAuO,IAAAuB,KAAA3N,QAEb,cAAAqM,IACI3O,EAAIuE,IAAKT,EAAW,EAACD,OAAQI,EAAoB,EAACF,SAAU,IAC1D/D,EAAIuE,IAAKD,EAAW,EAACT,OAAQW,EACG,IAAhCxE,EAAI6D,OAAQY,EAAoB,IAHtC,MAIQ,IAnBb,MAsBO3E,EAAA,CAAA,IAAAiC,GAAAqP,aAAAtR,EAAA,CAAA,IAAAiC,GAAAsP,OAAAvR,OAAAE,GAAAF,OAAA6O,GAAA7O,OAAAmO,GAAAnO,OAAA4O,GAAA5O,QAAAgO,GAAAhO,EAAA,EAAA,IAAAgC,GAAAsP,aAAAtR,EAAA,EAAA,IAAAgC,GAAAuP,OAAAvR,QAAAK,GAAAL,QAAAqR,MAAAA,KAAArR,EAAA,EAAA;AAAA,MAAAyR;AAAA,EAAAzR,EAAA,EAAA,MAAAiC,GAAAyP,eAAA1R,EAAA,EAAA,MAAAO,KAAAP,EAAA,EAAA,MAAAqO,KAAArO,UAAAiO,KAAAjO,EAAA,EAAA,MAAAE,KAAAF,EAAA,EAAA,MAAAwO,KAAAxO,EAAA,EAAA,MAAA+O,KAAA/O,EAAA,EAAA,MAAAiP,KAAAjP,UAAAK,KACPoR,KAAAjD,MAAmB,MAAStO,EAAI6D,OAAQa,EAAc,EAACX,WAAY,KAAK/D,EAAI+D,SAAU,IACrFoD,gBAAAA,EAAAA,IAACsK,IAAA,EACQtR,OAAAA,GACWgO,kBAAAA,GACV,QAACJ,KAAmC/E,GAAO+F,CAAK,EAAC2C,kBAAkB3D,QAC9D,aAAA1N,KAAgBsR,GAAO3R,GAAM,SAAS,EAAI,GACrC+P,kBAAAA,IACLlB,aAAAA,GACF,WAAA9M,GAAUyP,aAAa,IARrC,MAUO1R,EAAA,EAAA,IAAAiC,GAAAyP,aAAA1R,QAAAO,GAAAP,QAAAqO,GAAArO,QAAAiO,GAAAjO,QAAAE,GAAAF,QAAAwO,GAAAxO,QAAA+O,GAAA/O,QAAAiP,GAAAjP,QAAAK,GAAAL,QAAAyR,MAAAA,KAAAzR,EAAA,EAAA;AAAA,MAAA8R;AAAA,EAAA9R,EAAA,EAAA,MAAAE,EAAA+D,UAEL6N,KAAA5R,EAAI+D,WAAY,KAAKoD,gBAAAA,EAAAA,IAAC0K,IAAA,EAAU,GAAG/R,EAAA,EAAA,IAAAE,EAAA+D,QAAAjE,QAAA8R,MAAAA,KAAA9R,EAAA,EAAA;AAAA,MAAAgS;AAAA,EAAAhS,EAAA,EAAA,MAAAoQ,MAAApQ,EAAA,EAAA,MAAAU,KAAAV,EAAA,EAAA,MAAAiC,KAAAjC,EAAA,EAAA,MAAAO,KAAAP,EAAA,EAAA,MAAAiO,KAAAjO,UAAAqC,MAAArC,EAAA,EAAA,MAAAE,KAAAF,EAAA,EAAA,MAAA+B,MAAA/B,EAAA,EAAA,MAAAmC,KAAAnC,EAAA,EAAA,MAAAsC,MAAAtC,EAAA,EAAA,MAAA4B,KAAA5B,EAAA,EAAA,MAAAY,KAAAZ,EAAA,EAAA,MAAAuC,MAAAvC,EAAA,EAAA,MAAAyB,KAAAzB,UAAA0B,KAAA1B,EAAA,EAAA,MAAA2B,KAAA3B,EAAA,EAAA,MAAAkC,KAAAlC,EAAA,EAAA,MAAA6B,KAAA7B,EAAA,EAAA,MAAAoB,KAAApB,EAAA,EAAA,MAAAoC,KAAApC,EAAA,EAAA,MAAAiB,KAAAjB,EAAA,EAAA,MAAAwB,KAAAxB,EAAA,EAAA,MAAAqB,KAAArB,EAAA,EAAA,MAAA8B,KAAA9B,EAAA,EAAA,MAAAc,KAAAd,UAAAsB,MAAAtB,EAAA,EAAA,MAAAkB,KAAAlB,EAAA,EAAA,MAAAI,MAAAJ,EAAA,EAAA,MAAAgC,KAAAhC,EAAA,EAAA,MAAAgB,KAAAhB,EAAA,EAAA,MAAA+P,MAAA/P,EAAA,EAAA,MAAA6P,MAAA7P,EAAA,EAAA,MAAAiP,KAAAjP,EAAA,EAAA,MAAAmB,KAAAnB,UAAAQ,MACnCwR,KAAAnC,MAAAE,MAAyB7P,EAAI+D,SAAU,0BACrCmM,IAAA,EACe9N,cAAAA,IACRpC,MAAAA,GAEJ,cAAAA,EAAI6D,OAAQiB,EAAc,EAACf,WAAY,IACnCgK,IAAA,CACGA,CAAgB,IADnB,CAEG/E,GAAM+I,cAAe,UAAU,CAAC,IAClChE,KAAmC/E,GAAO+F,CAAK,EAAC2C,kBAAkB3D,QAGvE,aAAA/N,EAAI6D,OAAQkB,EAAc,EAAChB,WAAY,IAAvC,KAEI1D,KAAgBsR,GAAO3R,GAAM,SAAS,EAAI,GAEzC2P,OAAAA,IACQvO,eAAAA,IACPyO,QAAAA,IACG3P,WAAAA,IACCQ,YAAAA,GACCE,aAAAA,GACFN,WAAAA,IACGE,cAAAA,GACFQ,YAAAA,GACHC,SAAAA,GACUC,mBAAAA,GACRC,WAAAA,GACI,eAAA,IACPG,QAAAA,GACQC,gBAAAA,GACNC,UAAAA,GACAC,UAAAA,GACaC,uBAAAA,GACHC,oBAAAA,GACSC,6BAAAA,GACbC,gBAAAA,IACRC,QAAAA,GACIC,YAAAA,GACJjB,QAAAA,GACAC,QAAAA,GACG,WAAAiB,KAAA,GACIC,eAAAA,GACJC,WAAAA,GACGC,cAAAA,IACNE,QAAAA,IAAM,IA7CjB,MA+COvC,QAAAoQ,IAAApQ,QAAAU,GAAAV,QAAAiC,GAAAjC,QAAAO,GAAAP,QAAAiO,GAAAjO,QAAAqC,IAAArC,QAAAE,GAAAF,QAAA+B,IAAA/B,QAAAmC,GAAAnC,QAAAsC,IAAAtC,QAAA4B,GAAA5B,QAAAY,GAAAZ,QAAAuC,IAAAvC,QAAAyB,GAAAzB,QAAA0B,GAAA1B,QAAA2B,GAAA3B,QAAAkC,GAAAlC,QAAA6B,GAAA7B,QAAAoB,GAAApB,QAAAoC,GAAApC,QAAAiB,GAAAjB,QAAAwB,GAAAxB,QAAAqB,GAAArB,QAAA8B,GAAA9B,QAAAc,GAAAd,QAAAsB,IAAAtB,QAAAkB,GAAAlB,QAAAI,IAAAJ,QAAAgC,GAAAhC,QAAAgB,GAAAhB,QAAA+P,IAAA/P,QAAA6P,IAAA7P,QAAAiP,GAAAjP,QAAAmB,GAAAnB,QAAAQ,IAAAR,QAAAgS,MAAAA,KAAAhS,EAAA,EAAA;AAAA,MAAAkS;AAAA,EAAAlS,EAAA,EAAA,MAAA8R,MAAA9R,UAAAgS,MAjDVE,4BAACC,IAAA,EAAejC,SACb4B,UAAAA;AAAAA,IAAAA;AAAAA,IACAE;AAAAA,EAAAA,GAgDH,GAAYhS,QAAA8R,IAAA9R,QAAAgS,IAAAhS,QAAAkS,MAAAA,KAAAlS,EAAA,EAAA;AAAA,MAAAoS;AAAA,EAAApS,EAAA,EAAA,MAAAiC,GAAAoQ,YAAArS,EAAA,EAAA,MAAAiC,GAAAqQ,UAAAtS,EAAA,EAAA,MAAAoO,KAAApO,EAAA,EAAA,MAAAkO,KAAAlO,EAAA,EAAA,MAAAgC,GAAAqQ,YAAArS,EAAA,EAAA,MAAAgC,GAAAsQ,UAAAtS,UAAAK,KACX+R,KAAAlE,KAAAE,IACC/G,gBAAAA,EAAAA,IAACkL,IAAA,EACS,QAAA;AAAA,IAAAF,UAAYrQ,GAAMqQ;AAAAA,IAAUC,QAAUtQ,GAAMsQ;AAAAA,EAAAA,GACxC,YAAA;AAAA,IAAAD,UACApQ,GAAUoQ;AAAAA,IAAUC,QACtBrQ,GAAUqQ;AAAAA,EAAAA,GAEXpE,SAAAA,GACCE,UAAAA,GACH/N,OAAAA,EAAAA,CAAK,IATf,MAWOL,EAAA,EAAA,IAAAiC,GAAAoQ,UAAArS,EAAA,EAAA,IAAAiC,GAAAqQ,QAAAtS,QAAAoO,GAAApO,QAAAkO,GAAAlO,EAAA,EAAA,IAAAgC,GAAAqQ,UAAArS,EAAA,EAAA,IAAAgC,GAAAsQ,QAAAtS,QAAAK,GAAAL,QAAAoS,MAAAA,KAAApS,EAAA,EAAA;AAAA,MAAAwS;AAAA,SAAAxS,EAAA,EAAA,MAAA0O,MAAA1O,EAAA,EAAA,MAAA2O,KAAA3O,EAAA,EAAA,MAAAyO,KAAAzO,EAAA,EAAA,MAAAM,MAAAN,EAAA,EAAA,MAAA8O,KAAA9O,EAAA,EAAA,MAAAgP,KAAAhP,EAAA,EAAA,MAAAsO,MAAAtO,EAAA,EAAA,MAAAuO,KAAAvO,EAAA,EAAA,MAAAkR,MAAAlR,EAAA,EAAA,MAAAoR,MAAApR,EAAA,EAAA,MAAAqR,MAAArR,EAAA,EAAA,MAAAyR,MAAAzR,EAAA,EAAA,MAAAkS,MAAAlS,EAAA,EAAA,MAAAoS,MAAApS,EAAA,EAAA,MAAAiP,KAAAjP,UAAAK,KA/GVmS,4BAACC,IAAA,EACY,WAAAvB,IACJ,OAAAE,IACH3C,OACC0B,SACOzB,cAAAA,IACKC,iBAAAA,GACVM,OAAAA,GACGH,UAAAA,GACCE,WAAAA,GACJ3O,OAAAA,GACCC,QAAAA,IACQiO,gBAAAA,GACPD,SAAAA,IAER+C,UAAAA;AAAAA,IAAAA;AAAAA,IAuBAI;AAAAA,IAWDS;AAAAA,IAmDCE;AAAAA,EAAAA,GAYH,GAAiBpS,QAAA0O,IAAA1O,QAAA2O,GAAA3O,QAAAyO,GAAAzO,QAAAM,IAAAN,QAAA8O,GAAA9O,QAAAgP,GAAAhP,QAAAsO,IAAAtO,QAAAuO,GAAAvO,QAAAkR,IAAAlR,QAAAoR,IAAApR,QAAAqR,IAAArR,QAAAyR,IAAAzR,QAAAkS,IAAAlS,QAAAoS,IAAApS,QAAAiP,GAAAjP,QAAAK,GAAAL,QAAAwS,MAAAA,KAAAxS,EAAA,EAAA,GAhHjBwS;AAgHiB;AAxLd,SAAAvN,GAAA0E,GAAA;AAAA,SAuIyBG,EAAEpB;AAAM;AAvIjC,SAAA1D,GAAA6F,GAAA;AAAA,SAgIyBf,EAAEpB;AAAM;AAhIjC,SAAA9D,GAAAkF,GAAA;AAAA,SA8G8CA,EAAEpB;AAAM;AA9GtD,SAAA/D,GAAAiH,GAAA;AAAA,SAyG4BnF,MAAMjE;AAAS;AAzG3C,SAAAkC,GAAAqH,GAAA;AAAA,SAwG6CtF,MAAMjE;AAAS;AAxG5D,SAAAgC,GAAAiC,GAAA;AAAA,SAwGyBA,EAACvG;AAAK;AAxG/B,SAAAiE,GAAA2H,GAAA;AAAA,SAuG2CrF,MAAMjE;AAAS;AAvG1D,SAAAwB,GAAA2H,GAAA;AAAA,SAuGuBlF,EAACvG;AAAK;"}
1
+ {"version":3,"file":"BeeSwarmChart.js","sources":["../src/Components/Graphs/BeeSwarmChart/Graph.tsx","../src/Components/Graphs/BeeSwarmChart/index.tsx"],"sourcesContent":["import isEqual from 'fast-deep-equal';\r\nimport { scaleLinear, scaleSqrt } from 'd3-scale';\r\nimport { forceCollide, forceManyBody, forceSimulation, forceX, forceY } from 'd3-force';\r\nimport { useEffect, useRef, useState } from 'react';\r\nimport orderBy from 'lodash.orderby';\r\nimport { cn } from '@undp/design-system-react/cn';\r\nimport { Spinner } from '@undp/design-system-react/Spinner';\r\nimport { P } from '@undp/design-system-react/Typography';\r\n\r\nimport {\r\n BeeSwarmChartDataType,\r\n ClassNameObject,\r\n CustomLayerDataType,\r\n ReferenceDataType,\r\n StyleObject,\r\n} from '@/Types';\r\nimport { numberFormattingFunction } from '@/Utils/numberFormattingFunction';\r\nimport { Tooltip } from '@/Components/Elements/Tooltip';\r\nimport { checkIfNullOrUndefined } from '@/Utils/checkIfNullOrUndefined';\r\nimport { getTextColorBasedOnBgColor } from '@/Utils/getTextColorBasedOnBgColor';\r\nimport { Colors } from '@/Components/ColorPalette';\r\nimport { Axis } from '@/Components/Elements/Axes/Axis';\r\nimport { RefLineX, RefLineY } from '@/Components/Elements/ReferenceLine';\r\nimport { YTicksAndGridLines } from '@/Components/Elements/Axes/YTicksAndGridLines';\r\nimport { XTicksAndGridLines } from '@/Components/Elements/Axes/XTicksAndGridLines';\r\nimport { DetailsModal } from '@/Components/Elements/DetailsModal';\r\n\r\ninterface BeeSwarmChartDataTypeForBubbleChart extends BeeSwarmChartDataType {\r\n x: number;\r\n y: number;\r\n vx: number;\r\n vy: number;\r\n}\r\n\r\ninterface Props {\r\n data: BeeSwarmChartDataType[];\r\n circleColors: string[];\r\n colorDomain: string[];\r\n showTicks: boolean;\r\n leftMargin?: number;\r\n rightMargin?: number;\r\n topMargin?: number;\r\n bottomMargin?: number;\r\n showLabels: boolean;\r\n width: number;\r\n height: number;\r\n suffix: string;\r\n prefix: string;\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 refValues?: ReferenceDataType[];\r\n selectedColor?: string;\r\n startFromZero: boolean;\r\n radius: number;\r\n maxRadiusValue?: number;\r\n maxValue?: number;\r\n minValue?: number;\r\n highlightedDataPoints?: (string | number)[];\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseClick?: (_d: any) => void;\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 noOfTicks: number;\r\n dimmedOpacity: number;\r\n precision: number;\r\n customLayers: CustomLayerDataType[];\r\n rtl?: boolean;\r\n hideAxisLine: boolean;\r\n locale: string;\r\n padZeros: boolean;\r\n}\r\n\r\nexport function VerticalGraph(props: Props) {\r\n const {\r\n data,\r\n circleColors,\r\n showTicks,\r\n width,\r\n height,\r\n colorDomain,\r\n topMargin = 25,\r\n bottomMargin = 10,\r\n leftMargin = 100,\r\n rightMargin = 40,\r\n suffix,\r\n prefix,\r\n showLabels,\r\n tooltip,\r\n onSeriesMouseOver,\r\n refValues,\r\n selectedColor,\r\n startFromZero,\r\n radius,\r\n maxRadiusValue,\r\n maxValue,\r\n minValue,\r\n highlightedDataPoints,\r\n onSeriesMouseClick,\r\n resetSelectionOnDoubleClick,\r\n detailsOnClick,\r\n styles,\r\n classNames,\r\n noOfTicks,\r\n dimmedOpacity,\r\n precision,\r\n customLayers,\r\n hideAxisLine,\r\n locale,\r\n padZeros,\r\n } = props;\r\n const svgRef = useRef(null);\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 [finalData, setFinalData] = useState<BeeSwarmChartDataTypeForBubbleChart[] | null>(null);\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 dataOrdered =\r\n data.filter(d => !checkIfNullOrUndefined(d.radius)).length === 0\r\n ? data\r\n : orderBy(\r\n data.filter(d => !checkIfNullOrUndefined(d.radius)),\r\n 'radius',\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 !startFromZero\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)) >=\r\n 0 && !startFromZero\r\n ? 0\r\n : Math.min(...data.filter(d => !checkIfNullOrUndefined(d.position)).map(d => d.position));\r\n\r\n const radiusScale =\r\n data.filter(d => d.radius === undefined || d.radius === null).length !== data.length\r\n ? scaleSqrt()\r\n .domain([\r\n 0,\r\n checkIfNullOrUndefined(maxRadiusValue)\r\n ? Math.max(...data.map(d => d.radius).filter(d => d !== undefined && d !== null))\r\n : (maxRadiusValue as number),\r\n ])\r\n .range([0.25, radius])\r\n .nice()\r\n : undefined;\r\n const y = scaleLinear().domain([yMinValue, yMaxValue]).range([graphHeight, 0]).nice();\r\n const yTicks = y.ticks(noOfTicks);\r\n\r\n useEffect(() => {\r\n const dataTemp = (\r\n dataOrdered.map(d => ({\r\n ...d,\r\n ...(d.data && { data: { ...d.data } }),\r\n })) as BeeSwarmChartDataType[]\r\n ).filter(d => d.position);\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n forceSimulation(dataTemp as any)\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n .force('y', forceY((d: any) => y(d.position as number)).strength(5))\r\n .force('x', forceX(_d => graphWidth / 2).strength(1))\r\n .force(\r\n 'collide',\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n forceCollide((d: any) => (radiusScale ? radiusScale(d.radius || 0) + 1 : radius + 1)),\r\n )\r\n .force('charge', forceManyBody().strength(-15))\r\n .alphaDecay(0.05)\r\n .tick(10000)\r\n .on('tick', () => {\r\n setFinalData(dataTemp as BeeSwarmChartDataTypeForBubbleChart[]);\r\n })\r\n .on('end', () => {\r\n setFinalData(dataTemp as BeeSwarmChartDataTypeForBubbleChart[]);\r\n });\r\n }, [data, radius, graphHeight, graphWidth, yMinValue, yMaxValue, dataOrdered, y, radiusScale]);\r\n\r\n return (\r\n <>\r\n {finalData ? (\r\n <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 {showTicks ? (\r\n <>\r\n <Axis\r\n hideAxisLine={hideAxisLine}\r\n y1={y(yMinValue < 0 ? 0 : yMinValue)}\r\n y2={y(yMinValue < 0 ? 0 : yMinValue)}\r\n x1={0 - margin.left}\r\n x2={graphWidth + margin.right}\r\n label={\r\n showTicks\r\n ? numberFormattingFunction(\r\n yMinValue < 0 ? 0 : yMinValue,\r\n undefined,\r\n precision,\r\n prefix,\r\n suffix,\r\n locale,\r\n padZeros,\r\n )\r\n : undefined\r\n }\r\n labelPos={{\r\n x: 0 - margin.left,\r\n y: y(yMinValue < 0 ? 0 : yMinValue),\r\n dx: 0,\r\n dy: yMaxValue < 0 ? '1em' : -5,\r\n }}\r\n classNames={{\r\n axis: classNames?.xAxis?.axis,\r\n label: classNames?.yAxis?.labels,\r\n }}\r\n styles={{\r\n axis: styles?.xAxis?.axis,\r\n label: styles?.yAxis?.labels,\r\n }}\r\n />\r\n <YTicksAndGridLines\r\n values={yTicks.filter(d => d !== 0)}\r\n y={yTicks.filter(d => d !== 0).map(d => y(d))}\r\n x1={0 - margin.left}\r\n x2={graphWidth + margin.right}\r\n styles={{\r\n gridLines: styles?.yAxis?.gridLines,\r\n labels: styles?.yAxis?.labels,\r\n }}\r\n classNames={{\r\n gridLines: classNames?.yAxis?.gridLines,\r\n labels: classNames?.yAxis?.labels,\r\n }}\r\n suffix={suffix}\r\n prefix={prefix}\r\n labelType='secondary'\r\n showGridLines\r\n labelPos='vertical'\r\n precision={precision}\r\n locale={locale}\r\n padZeros={padZeros}\r\n />\r\n </>\r\n ) : null}\r\n {customLayers.filter(d => d.position === 'before').map(d => d.layer)}\r\n {finalData.map(d => (\r\n <g\r\n className='undp-viz-g-with-hover'\r\n key={d.label}\r\n transform={`translate(${d.x},${d.y})`}\r\n opacity={\r\n selectedColor\r\n ? d.color\r\n ? circleColors[colorDomain.indexOf(d.color)] === selectedColor\r\n ? 1\r\n : dimmedOpacity\r\n : dimmedOpacity\r\n : highlightedDataPoints\r\n ? highlightedDataPoints.indexOf(d.label) !== -1\r\n ? 0.85\r\n : dimmedOpacity\r\n : 0.85\r\n }\r\n onMouseEnter={event => {\r\n setMouseOverData(d);\r\n setEventY(event.clientY);\r\n setEventX(event.clientX);\r\n onSeriesMouseOver?.(d);\r\n }}\r\n onMouseMove={event => {\r\n setMouseOverData(d);\r\n setEventY(event.clientY);\r\n setEventX(event.clientX);\r\n }}\r\n 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 onMouseLeave={() => {\r\n setMouseOverData(undefined);\r\n setEventX(undefined);\r\n setEventY(undefined);\r\n onSeriesMouseOver?.(undefined);\r\n }}\r\n >\r\n <circle\r\n cx={0}\r\n cy={0}\r\n r={radiusScale ? radiusScale(d.radius || 0) : radius}\r\n fill={\r\n data.filter(el => el.color).length === 0\r\n ? circleColors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : circleColors[colorDomain.indexOf(d.color)]\r\n }\r\n />\r\n {(radiusScale ? radiusScale(d.radius || 0) : radius) > 10 && showLabels ? (\r\n <g>\r\n <foreignObject\r\n y={0 - (radiusScale ? radiusScale(d.radius || 0) : radius)}\r\n x={0 - (radiusScale ? radiusScale(d.radius || 0) : radius)}\r\n width={2 * (radiusScale ? radiusScale(d.radius || 0) : radius)}\r\n height={2 * (radiusScale ? radiusScale(d.radius || 0) : radius)}\r\n >\r\n <div className='flex flex-col justify-center items-center h-inherit py-0 px-1.5'>\r\n {showLabels ? (\r\n <p\r\n className={cn(\r\n 'text-center leading-none m-0',\r\n classNames?.graphObjectValues,\r\n )}\r\n style={{\r\n fontSize: `${Math.min(\r\n Math.max(\r\n Math.round(\r\n (radiusScale ? radiusScale(d.radius || 0) : radius) / 4,\r\n ),\r\n 10,\r\n ),\r\n Math.max(\r\n Math.round(\r\n ((radiusScale ? radiusScale(d.radius || 0) : radius) * 12) /\r\n `${d.label}`.length,\r\n ),\r\n 10,\r\n ),\r\n 20,\r\n )}px`,\r\n hyphens: 'auto',\r\n color: getTextColorBasedOnBgColor(\r\n data.filter(el => el.color).length === 0\r\n ? circleColors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : circleColors[colorDomain.indexOf(d.color)],\r\n ),\r\n ...(styles?.graphObjectValues || {}),\r\n }}\r\n >\r\n {d.label}\r\n </p>\r\n ) : null}\r\n </div>\r\n </foreignObject>\r\n </g>\r\n ) : null}\r\n </g>\r\n ))}\r\n {refValues ? (\r\n <>\r\n {refValues.map((el, i) => (\r\n <RefLineY\r\n key={i}\r\n text={el.text}\r\n color={el.color}\r\n y={y(el.value as number)}\r\n x1={0 - margin.left}\r\n x2={graphWidth + margin.right}\r\n classNames={el.classNames}\r\n styles={el.styles}\r\n isInView={true}\r\n />\r\n ))}\r\n </>\r\n ) : null}\r\n {customLayers.filter(d => d.position === 'after').map(d => d.layer)}\r\n </g>\r\n </svg>\r\n ) : (\r\n <div style={{ width: `${width}px`, height: `${height}px` }}>\r\n <div className='flex m-auto items-center justify-center p-0 leading-none text-base h-40'>\r\n <Spinner />\r\n </div>\r\n </div>\r\n )}\r\n {mouseOverData && tooltip && eventX && eventY ? (\r\n <Tooltip\r\n data={mouseOverData}\r\n body={tooltip}\r\n xPos={eventX}\r\n yPos={eventY}\r\n backgroundStyle={styles?.tooltip}\r\n className={classNames?.tooltip}\r\n />\r\n ) : null}\r\n {detailsOnClick && mouseClickData !== undefined ? (\r\n <DetailsModal\r\n body={detailsOnClick}\r\n data={mouseClickData}\r\n setData={setMouseClickData}\r\n className={classNames?.modal}\r\n />\r\n ) : null}\r\n </>\r\n );\r\n}\r\n\r\nexport function HorizontalGraph(props: Props) {\r\n const {\r\n data,\r\n circleColors,\r\n showTicks,\r\n width,\r\n height,\r\n colorDomain,\r\n topMargin = 25,\r\n bottomMargin = 10,\r\n leftMargin = 10,\r\n rightMargin = 10,\r\n showLabels,\r\n tooltip,\r\n onSeriesMouseOver,\r\n refValues,\r\n selectedColor,\r\n startFromZero,\r\n radius,\r\n maxRadiusValue,\r\n maxValue,\r\n minValue,\r\n highlightedDataPoints,\r\n onSeriesMouseClick,\r\n rtl,\r\n resetSelectionOnDoubleClick,\r\n detailsOnClick,\r\n suffix,\r\n prefix,\r\n styles,\r\n classNames,\r\n noOfTicks,\r\n dimmedOpacity,\r\n precision,\r\n customLayers,\r\n hideAxisLine,\r\n locale,\r\n padZeros,\r\n } = props;\r\n const svgRef = useRef(null);\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 [finalData, setFinalData] = useState<BeeSwarmChartDataTypeForBubbleChart[] | null>(null);\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 dataOrdered =\r\n data.filter(d => !checkIfNullOrUndefined(d.radius)).length === 0\r\n ? data\r\n : orderBy(\r\n data.filter(d => !checkIfNullOrUndefined(d.radius)),\r\n 'radius',\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 !startFromZero\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)) >=\r\n 0 && !startFromZero\r\n ? 0\r\n : Math.min(...data.filter(d => !checkIfNullOrUndefined(d.position)).map(d => d.position));\r\n\r\n const radiusScale =\r\n data.filter(d => d.radius === undefined || d.radius === null).length !== data.length\r\n ? scaleSqrt()\r\n .domain([\r\n 0,\r\n checkIfNullOrUndefined(maxRadiusValue)\r\n ? Math.max(...data.map(d => d.radius).filter(d => d !== undefined && d !== null))\r\n : (maxRadiusValue as number),\r\n ])\r\n .range([0.25, radius])\r\n .nice()\r\n : undefined;\r\n const x = scaleLinear().domain([xMinValue, xMaxValue]).range([0, graphWidth]).nice();\r\n const xTicks = x.ticks(noOfTicks);\r\n\r\n useEffect(() => {\r\n const dataTemp = (\r\n dataOrdered.map(d => ({\r\n ...d,\r\n ...(d.data && { data: { ...d.data } }),\r\n })) as BeeSwarmChartDataType[]\r\n ).filter(d => d.position);\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n forceSimulation(dataTemp as any)\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n .force('x', forceX((d: any) => x(d.position as number)).strength(5))\r\n .force('y', forceY(_d => graphHeight / 2).strength(1))\r\n .force(\r\n 'collide',\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n forceCollide((d: any) => (radiusScale ? radiusScale(d.radius || 0) + 1 : radius + 1)),\r\n )\r\n .force('charge', forceManyBody().strength(-15))\r\n .alphaDecay(0.05)\r\n .tick(10000)\r\n .on('tick', () => {\r\n setFinalData(dataTemp as BeeSwarmChartDataTypeForBubbleChart[]);\r\n })\r\n .on('end', () => {\r\n setFinalData(dataTemp as BeeSwarmChartDataTypeForBubbleChart[]);\r\n });\r\n }, [data, radius, graphHeight, graphWidth, xMinValue, xMaxValue, dataOrdered, x, radiusScale]);\r\n\r\n return (\r\n <>\r\n {finalData ? (\r\n <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 {showTicks ? (\r\n <>\r\n <Axis\r\n hideAxisLine={hideAxisLine}\r\n x1={x(xMinValue < 0 ? 0 : xMinValue)}\r\n x2={x(xMinValue < 0 ? 0 : xMinValue)}\r\n y1={0 - margin.top}\r\n y2={graphHeight + margin.bottom}\r\n label={\r\n showTicks\r\n ? numberFormattingFunction(\r\n xMinValue < 0 ? 0 : xMinValue,\r\n undefined,\r\n precision,\r\n prefix,\r\n suffix,\r\n locale,\r\n padZeros,\r\n )\r\n : undefined\r\n }\r\n labelPos={{\r\n x: x(xMinValue < 0 ? 0 : xMinValue),\r\n y: 0 - topMargin,\r\n dy: '0.75em',\r\n dx: 3,\r\n }}\r\n classNames={{\r\n axis: classNames?.xAxis?.axis,\r\n label: classNames?.yAxis?.labels,\r\n }}\r\n styles={{\r\n axis: styles?.xAxis?.axis,\r\n label: styles?.yAxis?.labels,\r\n }}\r\n />\r\n <XTicksAndGridLines\r\n values={xTicks.filter(d => d !== 0)}\r\n x={xTicks.filter(d => d !== 0).map(d => x(d))}\r\n y1={0 - topMargin}\r\n y2={graphHeight + margin.bottom}\r\n styles={{\r\n gridLines: styles?.xAxis?.gridLines,\r\n labels: styles?.xAxis?.labels,\r\n }}\r\n classNames={{\r\n gridLines: classNames?.xAxis?.gridLines,\r\n labels: classNames?.xAxis?.labels,\r\n }}\r\n suffix={suffix}\r\n prefix={prefix}\r\n labelType='secondary'\r\n showGridLines\r\n precision={precision}\r\n locale={locale}\r\n padZeros={padZeros}\r\n />\r\n </>\r\n ) : null}\r\n {customLayers.filter(d => d.position === 'before').map(d => d.layer)}\r\n {finalData.map(d => (\r\n <g\r\n className='undp-viz-g-with-hover'\r\n key={d.label}\r\n transform={`translate(${d.x},${d.y})`}\r\n opacity={\r\n selectedColor\r\n ? d.color\r\n ? circleColors[colorDomain.indexOf(d.color)] === selectedColor\r\n ? 1\r\n : dimmedOpacity\r\n : dimmedOpacity\r\n : highlightedDataPoints\r\n ? highlightedDataPoints.indexOf(d.label) !== -1\r\n ? 0.85\r\n : dimmedOpacity\r\n : 0.85\r\n }\r\n onMouseEnter={event => {\r\n setMouseOverData(d);\r\n setEventY(event.clientY);\r\n setEventX(event.clientX);\r\n onSeriesMouseOver?.(d);\r\n }}\r\n onMouseMove={event => {\r\n setMouseOverData(d);\r\n setEventY(event.clientY);\r\n setEventX(event.clientX);\r\n }}\r\n 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 onMouseLeave={() => {\r\n setMouseOverData(undefined);\r\n setEventX(undefined);\r\n setEventY(undefined);\r\n onSeriesMouseOver?.(undefined);\r\n }}\r\n >\r\n <circle\r\n cx={0}\r\n cy={0}\r\n fill={\r\n data.filter(el => el.color).length === 0\r\n ? circleColors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : circleColors[colorDomain.indexOf(d.color)]\r\n }\r\n radius={radiusScale ? radiusScale(d.radius || 0) : radius}\r\n />\r\n {(radiusScale ? radiusScale(d.radius || 0) : radius) > 10 && showLabels ? (\r\n <g>\r\n <foreignObject\r\n y={0 - (radiusScale ? radiusScale(d.radius || 0) : radius)}\r\n x={0 - (radiusScale ? radiusScale(d.radius || 0) : radius)}\r\n width={2 * (radiusScale ? radiusScale(d.radius || 0) : radius)}\r\n height={2 * (radiusScale ? radiusScale(d.radius || 0) : radius)}\r\n >\r\n <div className='flex flex-col gap-0.5 justify-center items-center h-inherit py-0 px-1.5'>\r\n {showLabels ? (\r\n <P\r\n className={cn(\r\n 'text-center leading-none m-0',\r\n classNames?.graphObjectValues,\r\n )}\r\n marginBottom='none'\r\n style={{\r\n fontSize: `${Math.min(\r\n Math.max(\r\n Math.round(\r\n (radiusScale ? radiusScale(d.radius || 0) : radius) / 4,\r\n ),\r\n 10,\r\n ),\r\n Math.max(\r\n Math.round(\r\n ((radiusScale ? radiusScale(d.radius || 0) : radius) * 12) /\r\n `${d.label}`.length,\r\n ),\r\n 10,\r\n ),\r\n 20,\r\n )}px`,\r\n color: getTextColorBasedOnBgColor(\r\n data.filter(el => el.color).length === 0\r\n ? circleColors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : circleColors[colorDomain.indexOf(d.color)],\r\n ),\r\n hyphens: 'auto',\r\n ...(styles?.graphObjectValues || {}),\r\n }}\r\n >\r\n {d.label}\r\n </P>\r\n ) : null}\r\n </div>\r\n </foreignObject>\r\n </g>\r\n ) : null}\r\n </g>\r\n ))}\r\n {refValues ? (\r\n <>\r\n {refValues.map((el, i) => (\r\n <RefLineX\r\n key={i}\r\n text={el.text}\r\n color={el.color}\r\n x={x(el.value as number)}\r\n y1={0 - margin.top}\r\n y2={graphHeight + margin.bottom}\r\n textSide={x(el.value as number) > graphWidth * 0.75 || rtl ? 'left' : 'right'}\r\n classNames={el.classNames}\r\n styles={el.styles}\r\n isInView={true}\r\n />\r\n ))}\r\n </>\r\n ) : null}\r\n {customLayers.filter(d => d.position === 'after').map(d => d.layer)}\r\n </g>\r\n </svg>\r\n ) : (\r\n <div style={{ width: `${width}px`, height: `${height}px` }}>\r\n <div className='flex m-auto items-center justify-center p-0 leading-none text-base h-40'>\r\n <Spinner />\r\n </div>\r\n </div>\r\n )}\r\n {mouseOverData && tooltip && eventX && eventY ? (\r\n <Tooltip\r\n data={mouseOverData}\r\n body={tooltip}\r\n xPos={eventX}\r\n yPos={eventY}\r\n backgroundStyle={styles?.tooltip}\r\n className={classNames?.tooltip}\r\n />\r\n ) : null}\r\n {detailsOnClick && mouseClickData !== undefined ? (\r\n <DetailsModal\r\n body={detailsOnClick}\r\n data={mouseClickData}\r\n setData={setMouseClickData}\r\n className={classNames?.modal}\r\n />\r\n ) : null}\r\n </>\r\n );\r\n}\r\n","import { useEffect, useRef, useState } from 'react';\r\n\r\nimport { HorizontalGraph, VerticalGraph } from './Graph';\r\n\r\nimport { uniqBy } from '@/Utils/uniqBy';\r\nimport {\r\n ReferenceDataType,\r\n SourcesDataType,\r\n Languages,\r\n BeeSwarmChartDataType,\r\n StyleObject,\r\n ClassNameObject,\r\n CustomLayerDataType,\r\n NumberFormatOptions,\r\n} from '@/Types';\r\nimport { Colors } from '@/Components/ColorPalette';\r\nimport { GraphHeader } from '@/Components/Elements/GraphHeader';\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\n\r\ninterface Props {\r\n // Data\r\n /** Array of data objects */\r\n data: BeeSwarmChartDataType[];\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 circle */\r\n colors?: string | string[];\r\n /** Domain of colors for the graph */\r\n colorDomain?: string[];\r\n /** Title for the color legend */\r\n colorLegendTitle?: string;\r\n /** Background color of the graph */\r\n backgroundColor?: string | boolean;\r\n /** Custom styles for the graph. Each object should be a valid React CSS style object. */\r\n styles?: StyleObject;\r\n /** Custom class names */\r\n classNames?: ClassNameObject;\r\n\r\n // Size and Spacing\r\n /** Width of the graph */\r\n width?: number;\r\n /** Height of the graph */\r\n height?: number;\r\n /** Minimum height of the graph */\r\n minHeight?: number;\r\n /** Relative height scaling factor. This overwrites the height props */\r\n relativeHeight?: number;\r\n /** Padding around the graph. Defaults to 0 if no backgroundColor is mentioned else defaults to 1rem */\r\n padding?: string;\r\n /** Left margin of the graph */\r\n leftMargin?: number;\r\n /** Right margin of the graph */\r\n rightMargin?: number;\r\n /** Top margin of the graph */\r\n topMargin?: number;\r\n /** Bottom margin of the graph */\r\n bottomMargin?: number;\r\n\r\n // Values and Ticks\r\n /** Maximum value for the radius of the circle */\r\n maxRadiusValue?: number;\r\n /** Minimum value for position of the circle */\r\n minValue?: number;\r\n /** Maximum value for position of the circle */\r\n maxValue?: number;\r\n /** Reference values for comparison */\r\n refValues?: ReferenceDataType[];\r\n /** Number of ticks on the axis */\r\n noOfTicks?: number;\r\n\r\n // Graph Parameters\r\n /** Toggle visibility of labels */\r\n showLabels?: boolean;\r\n /** Toggle visibility of values */\r\n showTicks?: boolean;\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 /** Toggle visibility of axis line for the main axis */\r\n hideAxisLine?: 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 /** Maximum radius of the circles */\r\n radius?: number;\r\n /** Configuration options for controlling number formatting, localization, prefixes/suffixes, precision, and zero padding. */\r\n numberDisplayOptions?: NumberFormatOptions;\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 BeeSwarmChart(props: Props) {\r\n const {\r\n data,\r\n graphTitle,\r\n topMargin,\r\n bottomMargin,\r\n leftMargin,\r\n rightMargin,\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 padding,\r\n relativeHeight,\r\n tooltip,\r\n onSeriesMouseOver,\r\n refValues,\r\n showColorScale,\r\n graphID,\r\n radius = 5,\r\n showLabels = true,\r\n showTicks = true,\r\n maxRadiusValue,\r\n maxValue,\r\n minValue,\r\n highlightedDataPoints,\r\n onSeriesMouseClick,\r\n ariaLabel,\r\n backgroundColor = false,\r\n graphDownload = false,\r\n dataDownload = false,\r\n language = 'en',\r\n showNAColor = true,\r\n minHeight = 0,\r\n theme = 'light',\r\n resetSelectionOnDoubleClick = true,\r\n detailsOnClick,\r\n orientation = 'vertical',\r\n numberDisplayOptions,\r\n styles,\r\n classNames,\r\n noOfTicks = 5,\r\n dimmedOpacity = 0.3,\r\n customLayers = [],\r\n hideAxisLine = false,\r\n } = props;\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 const Comp = orientation === 'horizontal' ? HorizontalGraph : VerticalGraph;\r\n\r\n useEffect(() => {\r\n const resizeObserver = new ResizeObserver(entries => {\r\n setSvgWidth(entries[0].target.clientWidth || 620);\r\n setSvgHeight(entries[0].target.clientHeight || 480);\r\n });\r\n if (graphDiv.current) {\r\n resizeObserver.observe(graphDiv.current);\r\n }\r\n return () => resizeObserver.disconnect();\r\n }, []);\r\n return (\r\n <GraphContainer\r\n className={classNames?.graphContainer}\r\n style={styles?.graphContainer}\r\n id={graphID}\r\n ref={graphParentDiv}\r\n aria-label={ariaLabel}\r\n backgroundColor={backgroundColor}\r\n theme={theme}\r\n language={language}\r\n minHeight={minHeight}\r\n width={width}\r\n height={height}\r\n relativeHeight={relativeHeight}\r\n padding={padding}\r\n >\r\n {graphTitle || graphDescription || graphDownload || dataDownload ? (\r\n <GraphHeader\r\n styles={{\r\n title: styles?.title,\r\n description: styles?.description,\r\n }}\r\n classNames={{\r\n title: classNames?.title,\r\n description: classNames?.description,\r\n }}\r\n graphTitle={graphTitle}\r\n graphDescription={graphDescription}\r\n width={width}\r\n graphDownload={graphDownload ? graphParentDiv : undefined}\r\n dataDownload={\r\n dataDownload\r\n ? data.map(d => d.data).filter(d => d !== undefined).length > 0\r\n ? data.map(d => d.data).filter(d => d !== undefined)\r\n : data.filter(d => d !== undefined)\r\n : null\r\n }\r\n />\r\n ) : null}\r\n {showColorScale !== false && data.filter(el => el.color).length !== 0 && data.length > 0 ? (\r\n <ColorLegendWithMouseOver\r\n width={width}\r\n colorLegendTitle={colorLegendTitle}\r\n colors={(colors as string[] | undefined) || Colors[theme].categoricalColors.colors}\r\n colorDomain={colorDomain || (uniqBy(data, 'color', true) as string[])}\r\n setSelectedColor={setSelectedColor}\r\n showNAColor={showNAColor}\r\n className={classNames?.colorLegend}\r\n />\r\n ) : null}\r\n <GraphArea ref={graphDiv}>\r\n {data.length === 0 && <EmptyState />}\r\n {svgWidth && svgHeight && data.length > 0 ? (\r\n <Comp\r\n hideAxisLine={hideAxisLine}\r\n data={data}\r\n circleColors={\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 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 width={svgWidth}\r\n selectedColor={selectedColor}\r\n height={svgHeight}\r\n showTicks={showTicks}\r\n leftMargin={leftMargin}\r\n rightMargin={rightMargin}\r\n topMargin={topMargin}\r\n bottomMargin={bottomMargin}\r\n showLabels={showLabels}\r\n tooltip={tooltip}\r\n onSeriesMouseOver={onSeriesMouseOver}\r\n refValues={refValues}\r\n startFromZero={false}\r\n radius={radius}\r\n maxRadiusValue={maxRadiusValue}\r\n maxValue={maxValue}\r\n minValue={minValue}\r\n highlightedDataPoints={highlightedDataPoints}\r\n onSeriesMouseClick={onSeriesMouseClick}\r\n resetSelectionOnDoubleClick={resetSelectionOnDoubleClick}\r\n detailsOnClick={detailsOnClick}\r\n styles={styles}\r\n classNames={classNames}\r\n noOfTicks={noOfTicks || 5}\r\n dimmedOpacity={dimmedOpacity}\r\n customLayers={customLayers}\r\n locale={numberDisplayOptions?.locale || 'en'}\r\n padZeros={numberDisplayOptions?.padZeros || false}\r\n suffix={numberDisplayOptions?.suffix || ''}\r\n prefix={numberDisplayOptions?.prefix || ''}\r\n precision={numberDisplayOptions?.precision ?? 2}\r\n />\r\n ) : null}\r\n </GraphArea>\r\n {sources || footNote ? (\r\n <GraphFooter\r\n styles={{ footnote: styles?.footnote, source: styles?.source }}\r\n classNames={{\r\n footnote: classNames?.footnote,\r\n source: classNames?.source,\r\n }}\r\n sources={sources}\r\n footNote={footNote}\r\n width={width}\r\n />\r\n ) : null}\r\n </GraphContainer>\r\n );\r\n}\r\n"],"names":["VerticalGraph","props","$","_c","data","circleColors","showTicks","width","height","colorDomain","topMargin","t0","bottomMargin","t1","leftMargin","t2","rightMargin","t3","suffix","prefix","showLabels","tooltip","onSeriesMouseOver","refValues","selectedColor","startFromZero","radius","maxRadiusValue","maxValue","minValue","highlightedDataPoints","onSeriesMouseClick","resetSelectionOnDoubleClick","detailsOnClick","styles","classNames","noOfTicks","dimmedOpacity","precision","customLayers","hideAxisLine","locale","padZeros","undefined","svgRef","useRef","mouseOverData","setMouseOverData","useState","mouseClickData","setMouseClickData","finalData","setFinalData","eventX","setEventX","eventY","setEventY","t4","top","bottom","left","right","margin","graphWidth","graphHeight","dataOrdered","filter","_temp","length","orderBy","_temp2","t5","checkIfNullOrUndefined","Math","max","_temp3","map","_temp4","_temp5","_temp6","yMaxValue","t6","min","_temp7","_temp8","_temp9","_temp0","yMinValue","radiusScale","_temp1","scaleSqrt","domain","_temp10","_temp11","range","nice","y","scaleLinear","yTicks","ticks","useEffect","dataTemp","_temp12","_temp13","forceSimulation","force","forceY","d_14","d","position","strength","forceX","_d","forceCollide","d_15","forceManyBody","alphaDecay","tick","on","t7","jsx","jsxs","Fragment","Axis","numberFormattingFunction","x","dx","dy","axis","xAxis","label","yAxis","labels","YTicksAndGridLines","_temp14","_temp15","d_18","gridLines","_temp16","_temp17","d_21","color","indexOf","event","clientY","clientX","event_0","isEqual","_temp18","Colors","gray","cn","graphObjectValues","fontSize","round","hyphens","getTextColorBasedOnBgColor","_temp19","el_1","i","RefLineY","el","text","value","_temp20","_temp21","Spinner","t8","Tooltip","t9","modal","DetailsModal","t10","d_23","layer","d_22","el_0","d_20","d_19","d_17","d_16","d_13","d_12","d_10","d_9","d_11","d_6","d_5","d_8","d_7","d_2","d_1","d_4","d_3","d_0","HorizontalGraph","rtl","_temp22","_temp23","_temp24","_temp25","_temp26","_temp27","xMaxValue","_temp28","_temp29","_temp30","_temp31","xMinValue","_temp32","_temp33","_temp34","xTicks","_temp35","_temp36","XTicksAndGridLines","_temp37","_temp38","_temp39","_temp40","_temp41","P","_temp42","RefLineX","_temp43","_temp44","BeeSwarmChart","graphTitle","colors","sources","graphDescription","footNote","colorLegendTitle","padding","relativeHeight","showColorScale","graphID","ariaLabel","backgroundColor","graphDownload","dataDownload","language","showNAColor","minHeight","theme","orientation","t11","numberDisplayOptions","t12","t13","t14","t15","t16","svgWidth","setSvgWidth","svgHeight","setSvgHeight","setSelectedColor","graphDiv","graphParentDiv","Comp","t17","t18","Symbol","for","resizeObserver","ResizeObserver","entries","target","clientWidth","clientHeight","current","observe","disconnect","t19","graphContainer","t20","t21","description","title","GraphHeader","t22","colorLegend","ColorLegendWithMouseOver","categoricalColors","uniqBy","t23","EmptyState","t24","primaryColors","t25","GraphArea","t26","footnote","source","GraphFooter","t27","GraphContainer"],"mappings":"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"}
@@ -1,2 +1,2 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const o=require("./index-CHPV5EwG-D4pAp7u0.cjs"),a=require("react"),Rt=require("./getSliderMarks-BzrpHrHS.cjs"),Ft=require("./Spinner-WHzzloYQ.cjs"),wt=require("./parse-xYI9yrvL.cjs"),Lt=require("./index-DQA8q5sC.cjs"),S=require("./index-DLFt97gy.cjs"),$t=require("./index-C5K--w8d.cjs"),St=require("./Typography-BqmyF1gP.cjs"),Mt=require("./numberFormattingFunction-Cn9R7CM9.cjs"),Tt=require("./Tooltip-Hr46paWP.cjs"),Nt=require("./checkIfNullOrUndefined-BCW3Y1ML.cjs"),ct=require("./index-BhI7mBJx.cjs"),Gt=require("./DetailsModal-jmmKRMRM.cjs"),Ct=require("./select-Bnfk0lJx.cjs"),Ot=require("./threshold-DNsSUf8Q.cjs"),lt=require("./proxy-CqH8m8IQ.cjs"),Ht=require("./use-in-view-dnRv_qqF.cjs"),Vt=require("./index-FXfr51ZM.cjs"),Ut=require("./GraphHeader.cjs"),Xt=require("./GraphFooter.cjs"),kt=require("./Colors.cjs"),Bt=require("./fetchAndParseData-QTF6tjij.cjs"),qt=require("./getJenks-BzJvhy_H.cjs"),It=require("./GraphContainer-Cul9b74X.cjs");function Yt(i){const{data:e,xDomain:u,mapData:F,xColorLegendTitle:We,yDomain:Z,yColorLegendTitle:Q,width:y,height:x,colors:f,scale:Ae,centerPoint:E,mapBorderWidth:M,mapNoDataColor:ee,mapBorderColor:te,tooltip:oe,onSeriesMouseOver:ge,zoomScaleExtend:ye,zoomTranslateExtend:ve,highlightedIds:C,onSeriesMouseClick:re,mapProperty:N,resetSelectionOnDoubleClick:Fe,detailsOnClick:v,showColorScale:je,styles:Le,classNames:L,mapProjection:$,zoomInteraction:O,animate:B,dimmedOpacity:T,customLayers:ae,collapseColorScaleByDefault:be,zoomAndCenterByHighlightedIds:Ee,projectionRotate:G,rewindCoordinatesInMapData:V,overlayMapData:U,overlayMapBorderColor:$e,overlayMapBorderWidth:Te,locale:ne}=i,j=a.useMemo(()=>V?S.index_default(F,{reverse:!0}):F,[F,V]),Ce=a.useMemo(()=>!V||!U?U:S.index_default(U,{reverse:!0}),[U,V]),[p,c]=a.useState(be===void 0?!(y<680):!be),[X,ke]=a.useState(void 0),[ie,se]=a.useState(void 0),[q,H]=a.useState(void 0),[le,ce]=a.useState(void 0),[Y,de]=a.useState(void 0),d=a.useRef(null),De=Ht.useInView(d,{once:B.once,amount:B.amount}),k=a.useRef(null),D=a.useRef(null);a.useEffect(()=>{const t=Ct.select(k.current),r=Ct.select(d.current),m=g=>{if(O==="noZoom")return!1;if(O==="button")return!g.type.includes("wheel");const w=g.type==="wheel",b=g.type.startsWith("touch"),Ie=g.type==="mousedown"||g.type==="mousemove";return b?!0:w?O==="scroll"?!0:g.ctrlKey:Ie&&!g.button&&!g.ctrlKey},h=S.zoom().scaleExtent(ye).translateExtent(ve||[[-20,-20],[y+20,x+20]]).filter(m).on("zoom",({transform:g})=>{t.attr("transform",g)});r.call(h),D.current=h},[x,y,O]);const I=S.index_default$1({...j,features:Ee?j.features.filter(t=>(C||[]).length===0||C?.indexOf(t.properties[N])!==-1):j.features}),_=$t.index_default({...j,features:Ee?j.features.filter(t=>(C||[]).length===0||C?.indexOf(t.properties[N])!==-1):j.features}),Re=(I[2]-I[0])*1.15,we=(I[3]-I[1])*1.15,Se=y*190/960*360/Re,Me=x*190/678*180/we,z=Ae*Math.min(Se,Me),Ne=$==="mercator"?S.geoMercator().rotate(G).center(E||_.geometry.coordinates).translate([y/2,x/2]).scale(z):$==="equalEarth"?S.geoEqualEarth().rotate(G).center(E||_.geometry.coordinates).translate([y/2,x/2]).scale(z):$==="naturalEarth"?S.geoNaturalEarth1().rotate(G).center(E||_.geometry.coordinates).translate([y/2,x/2]).scale(z):$==="orthographic"?S.geoOrthographic().rotate(G).center(E||_.geometry.coordinates).translate([y/2,x/2]).scale(z):S.geoAlbersUsa().rotate(G).center(E||_.geometry.coordinates).translate([y/2,x/2]).scale(z),P=S.geoPath().projection(Ne),ue=Array.from({length:u.length},(t,r)=>r),Oe=Array.from({length:Z.length},(t,r)=>r),Be=Ot.threshold().domain(u).range(ue),qe=Ot.threshold().domain(Z).range(Oe),J=t=>{if(!d.current||!D.current)return;Ct.select(d.current).call(D.current.scaleBy,t==="in"?1.2:1/1.2)};return o.jsxRuntimeExports.jsxs(o.jsxRuntimeExports.Fragment,{children:[o.jsxRuntimeExports.jsxs("div",{className:"relative",children:[o.jsxRuntimeExports.jsx(lt.motion.svg,{viewBox:`0 0 ${y} ${x}`,width:`${y}px`,height:`${x}px`,ref:d,direction:"ltr",children:o.jsxRuntimeExports.jsxs("g",{ref:k,children:[ae.filter(t=>t.position==="before").map(t=>t.layer),j.features.map((t,r)=>{if(!t.properties?.[N])return null;const m=P(t);return m?o.jsxRuntimeExports.jsx(lt.motion.g,{opacity:X?T:C?C.indexOf(t.properties[N])!==-1?1:T:1,children:o.jsxRuntimeExports.jsx("path",{d:m,style:{stroke:te,strokeWidth:M,fill:ee,vectorEffect:"non-scaling-stroke"}})},r):null}),o.jsxRuntimeExports.jsx(Vt.AnimatePresence,{children:e.map(t=>{const r=j.features.findIndex(b=>t.id===b.properties[N]);if(r===-1)return null;const m=P(j.features[r]);if(!m)return null;const h=Nt.checkIfNullOrUndefined(t.x)?void 0:Be(t.x),g=Nt.checkIfNullOrUndefined(t.y)?void 0:qe(t.y),w=h!==void 0&&g!==void 0?f[g][h]:ee;return o.jsxRuntimeExports.jsx(lt.motion.g,{className:"undp-map-shapes",variants:{initial:{opacity:0},whileInView:{opacity:X?X===w?1:T:C?C.indexOf(t.id)!==-1?1:T:1,transition:{duration:B.duration}}},initial:"initial",animate:De?"whileInView":"initial",exit:{opacity:0,transition:{duration:B.duration}},onMouseEnter:b=>{H(t),de(b.clientY),ce(b.clientX),ge?.(t)},onClick:()=>{(re||v)&&(Lt.isEqual(ie,t)&&Fe?(se(void 0),re?.(void 0)):(se(t),re?.(t)))},onMouseMove:b=>{H(t),de(b.clientY),ce(b.clientX)},onMouseLeave:()=>{H(void 0),ce(void 0),de(void 0),ge?.(void 0)},children:o.jsxRuntimeExports.jsx(lt.motion.path,{d:m,variants:{initial:{fill:w,opacity:0},whileInView:{fill:w,opacity:1,transition:{duration:B.duration}}},initial:"initial",animate:De?"whileInView":"initial",exit:{opacity:0,transition:{duration:B.duration}},className:`${w===ee?"stroke-primary-gray-400 dark:stroke-primary-gray-500":"stroke-primary-white dark:stroke-primary-gray-650"}`,style:{stroke:te,strokeWidth:M,vectorEffect:"non-scaling-stroke"}},`${t.id}`)},t.id)})}),q?j.features.filter(t=>t.properties[N]===q.id).map((t,r)=>o.jsxRuntimeExports.jsx("path",{d:P(t)||"",className:"stroke-primary-gray-700 dark:stroke-primary-gray-300",style:{fill:"none",fillOpacity:0,strokeWidth:"0.5",vectorEffect:"non-scaling-stroke"}},r)):null,Ce?.features.map((t,r)=>{const m=P(t);return m?o.jsxRuntimeExports.jsx("g",{children:o.jsxRuntimeExports.jsx("path",{d:m,style:{stroke:$e||te,strokeWidth:Te||M+1,fill:"none",pointerEvents:"none",vectorEffect:"non-scaling-stroke"}})},r):null}),ae.filter(t=>t.position==="after").map(t=>t.layer)]})}),je===!1?null:o.jsxRuntimeExports.jsx("div",{className:o.mo("absolute left-4 bottom-4 map-color-legend",L?.colorLegend),children:p?o.jsxRuntimeExports.jsxs(o.jsxRuntimeExports.Fragment,{children:[o.jsxRuntimeExports.jsx("div",{className:"color-legend-close-button bg-[rgba(240,240,240,0.7)] dark:bg-[rgba(30,30,30,0.7)] border border-[var(--gray-400)] rounded-full w-6 h-6 p-[3px] cursor-pointer z-10 absolute right-[-0.75rem] top-[-0.75rem]",onClick:()=>{c(!1)},children:o.jsxRuntimeExports.jsx(ct.X,{})}),o.jsxRuntimeExports.jsxs("div",{className:"color-legend-box p-2 bg-[rgba(240,240,240,0.7)] dark:bg-[rgba(30,30,30,0.7)]",style:{width:"175px"},children:[o.jsxRuntimeExports.jsxs("div",{className:"flex gap-1 items-center",children:[o.jsxRuntimeExports.jsx("svg",{width:"136px",viewBox:"0 0 136 136",className:"shrink-0",children:o.jsxRuntimeExports.jsxs("g",{children:[f.map((t,r)=>o.jsxRuntimeExports.jsx("g",{transform:`translate(0,${100-r*25})`,children:t.map((m,h)=>o.jsxRuntimeExports.jsx("rect",{y:1,x:h*25+1,fill:m,width:23,height:23,strokeWidth:X===m?2:.25,style:{cursor:"pointer"},onMouseOver:()=>{ke(m)},onMouseLeave:()=>{ke(void 0)}},h))},r)),o.jsxRuntimeExports.jsx("g",{transform:"translate(0,125)",children:u.map((t,r)=>o.jsxRuntimeExports.jsx("text",{y:10,x:(r+1)*25,fontSize:10,textAnchor:"middle",children:typeof t=="string"||t<1?t:Mt.numberFormattingFunction(t,void 0,void 0,void 0,void 0,ne)},r))}),Z.map((t,r)=>o.jsxRuntimeExports.jsx("g",{transform:`translate(${Math.max(Math.min(u.length+1,5),4)*25+10},${100-r*25})`,children:o.jsxRuntimeExports.jsx("text",{x:0,transform:"rotate(-90)",y:0,fontSize:10,textAnchor:"middle",children:typeof t=="string"||t<1?t:Mt.numberFormattingFunction(t,void 0,void 0,void 0,void 0,ne)})},r))]})}),o.jsxRuntimeExports.jsx(St._,{marginBottom:"none",size:"xs",className:"leading-normal text-center shrink-0",style:{display:"-webkit-box",WebkitLineClamp:"1",WebkitBoxOrient:"vertical",overflow:"hidden",writingMode:"vertical-rl",height:"8.5rem",transform:"rotate(180deg)"},children:Q})]}),o.jsxRuntimeExports.jsx(St._,{marginBottom:"none",size:"xs",className:"mt-1 leading-normal text-center",style:{display:"-webkit-box",WebkitLineClamp:"1",width:"8.5rem",WebkitBoxOrient:"vertical",overflow:"hidden"},children:We})]})]}):o.jsxRuntimeExports.jsx("button",{type:"button",className:"p-1 border-0 rounded-[2px] text-primary-gray-700 bg-primary-gray-300 dark:bg-primary-gray-500 map-legend-button",onClick:()=>{c(!0)},children:o.jsxRuntimeExports.jsx(ct.ExpandIcon,{})})}),O==="button"&&o.jsxRuntimeExports.jsxs("div",{className:"absolute left-4 top-4 flex flex-col zoom-buttons",children:[o.jsxRuntimeExports.jsx("button",{onClick:()=>J("in"),className:"leading-0 px-2 py-3.5 border text-primary-gray-700 border-primary-gray-400 bg-primary-gray-200 dark:border-primary-gray-550 dark:bg-primary-gray-600 dark:text-primary-gray-100",children:"+"}),o.jsxRuntimeExports.jsx("button",{onClick:()=>J("out"),className:"leading-0 px-2 py-3.5 border text-primary-gray-700 border-t-0 border-primary-gray-400 bg-primary-gray-200 dark:border-primary-gray-550 dark:bg-primary-gray-600 dark:text-primary-gray-100",children:"–"})]})]}),q&&oe&&le&&Y?o.jsxRuntimeExports.jsx(Tt.Tooltip,{data:q,body:oe,xPos:le,yPos:Y,backgroundStyle:Le?.tooltip,className:L?.tooltip}):null,v&&ie!==void 0?o.jsxRuntimeExports.jsx(Gt.DetailsModal,{body:v,data:ie,setData:se,className:L?.modal}):null]})}function Jt(i){const e=o.compilerRuntimeExports.c(129),{data:u,graphTitle:F,mapData:We,colors:Z,sources:Q,graphDescription:y,height:x,width:f,footNote:Ae,xDomain:E,yDomain:M,xColorLegendTitle:ee,yColorLegendTitle:te,tooltip:oe,scale:ge,centerPoint:ye,padding:ve,mapBorderWidth:C,mapNoDataColor:re,backgroundColor:N,mapBorderColor:Fe,relativeHeight:v,onSeriesMouseOver:je,isWorldMap:Le,zoomScaleExtend:L,zoomTranslateExtend:$,graphID:O,showColorScale:B,highlightedIds:T,onSeriesMouseClick:ae,mapProperty:be,graphDownload:Ee,dataDownload:G,showAntarctica:V,language:U,minHeight:$e,theme:Te,ariaLabel:ne,resetSelectionOnDoubleClick:j,detailsOnClick:Ce,styles:p,classNames:c,mapProjection:X,zoomInteraction:ke,animate:ie,dimmedOpacity:se,customLayers:q,timeline:H,collapseColorScaleByDefault:le,zoomAndCenterByHighlightedIds:ce,projectionRotate:Y,rewindCoordinatesInMapData:de,mapOverlay:d,locale:De}=i,k=We===void 0?"https://raw.githubusercontent.com/UNDP-Data/dv-country-geojson/refs/heads/main/worldMap-v2.json":We,D=Z===void 0?kt.Colors.light.bivariateColors.colors05x05:Z,I=Ae===void 0?"The designations employed and the presentation of material on this map do not imply the expression of any opinion whatsoever on the part of the Secretariat of the United Nations or UNDP concerning the legal status of any country, territory, city or area or its authorities, or concerning the delimitation of its frontiers or boundaries.":Ae,_=ee===void 0?"X Color key":ee,Re=te===void 0?"Y Color key":te,we=ge===void 0?.95:ge,Se=C===void 0?.5:C,Me=re===void 0?kt.Colors.light.graphNoData:re,z=N===void 0?!1:N,Ne=Fe===void 0?kt.Colors.light.grays["gray-500"]:Fe,P=Le===void 0?!0:Le;let ue;e[0]!==L?(ue=L===void 0?[.8,6]:L,e[0]=L,e[1]=ue):ue=e[1];const Oe=ue,Be=B===void 0?!0:B,qe=be===void 0?"ISO3":be,J=Ee===void 0?!1:Ee,t=G===void 0?!1:G,r=V===void 0?!1:V,m=U===void 0?"en":U,h=$e===void 0?0:$e,g=Te===void 0?"light":Te,w=j===void 0?!0:j,b=X===void 0?"naturalEarth":X,Ie=ke===void 0?"button":ke,Ge=ie===void 0?!1:ie,dt=se===void 0?.3:se;let He;e[2]!==q?(He=q===void 0?[]:q,e[2]=q,e[3]=He):He=e[3];const ut=He;let Ve;e[4]!==H?(Ve=H===void 0?{enabled:!1,autoplay:!1,showOnlyActiveDate:!0}:H,e[4]=H,e[5]=Ve):Ve=e[5];const n=Ve,pt=ce===void 0?!1:ce;let Ue;e[6]!==Y?(Ue=Y===void 0?[0,0]:Y,e[6]=Y,e[7]=Ue):Ue=e[7];const mt=Ue,ht=de===void 0?!0:de,xt=De===void 0?"en":De,[K,_t]=a.useState(0),[_e,zt]=a.useState(0),[W,Pt]=a.useState(n.autoplay);let ze;if(e[8]!==u||e[9]!==n.dateFormat){let s;e[11]!==n.dateFormat?(s=R=>wt.parse(`${R.date}`,n.dateFormat||"yyyy",new Date).getTime(),e[11]=n.dateFormat,e[12]=s):s=e[12],ze=[...new Set(u.filter(io).map(s))],ze.sort(no),e[8]=u,e[9]=n.dateFormat,e[10]=ze}else ze=e[10];const l=ze,[A,ft]=a.useState(n.autoplay?0:l.length-1),[pe,Wt]=a.useState(void 0),[gt,At]=a.useState(void 0),yt=a.useRef(null),Dt=a.useRef(null);let Xe,Ye;e[13]===Symbol.for("react.memo_cache_sentinel")?(Xe=()=>{const s=new ResizeObserver(R=>{_t(R[0].target.clientWidth||620),zt(R[0].target.clientHeight||480)});return yt.current&&s.observe(yt.current),()=>s.disconnect()},Ye=[],e[13]=Xe,e[14]=Ye):(Xe=e[13],Ye=e[14]),a.useEffect(Xe,Ye);let Je;e[15]===Symbol.for("react.memo_cache_sentinel")?(Je=s=>{Wt(s)},e[15]=Je):Je=e[15];const Ke=a.useEffectEvent(Je);let Ze;e[16]===Symbol.for("react.memo_cache_sentinel")?(Ze=s=>{At(s)},e[16]=Ze):Ze=e[16];const Pe=a.useEffectEvent(Ze);let Qe;e[17]!==k||e[18]!==Ke?(Qe=()=>{typeof k=="string"?Bt.fetchAndParseJSON(k).then(R=>{Ke(R)}):Ke(k)},e[17]=k,e[18]=Ke,e[19]=Qe):Qe=e[19];let et;e[20]!==k?(et=[k],e[20]=k,e[21]=et):et=e[21],a.useEffect(Qe,et);let tt;e[22]!==d?.mapData||e[23]!==Pe?(tt=()=>{d?.mapData||Pe(void 0),typeof d?.mapData=="string"?Bt.fetchAndParseJSON(d?.mapData).then(R=>{Pe(R)}):Pe(d?.mapData)},e[22]=d?.mapData,e[23]=Pe,e[24]=tt):tt=e[24];const vt=d?.mapData;let ot;e[25]!==vt?(ot=[vt],e[25]=vt,e[26]=ot):ot=e[26],a.useEffect(tt,ot);let rt,at;e[27]!==W||e[28]!==n.speed||e[29]!==l?(rt=()=>{const s=setInterval(()=>{ft(R=>R<l.length-1?R+1:0)},(n.speed||2)*1e3);return W||clearInterval(s),()=>clearInterval(s)},at=[l,W,n.speed],e[27]=W,e[28]=n.speed,e[29]=l,e[30]=rt,e[31]=at):(rt=e[30],at=e[31]),a.useEffect(rt,at);const jt=n.dateFormat||"yyyy";let nt;e[32]!==A||e[33]!==jt||e[34]!==n.showOnlyActiveDate||e[35]!==l?(nt=Rt.getSliderMarks(l,A,n.showOnlyActiveDate,jt),e[32]=A,e[33]=jt,e[34]=n.showOnlyActiveDate,e[35]=l,e[36]=nt):nt=e[36];const it=nt;if(E&&M&&(E.length!==D[0].length-1||M.length!==D.length-1))return console.error("the xDomain and yDomain array length don't match to the color array length"),null;const bt=c?.graphContainer,Et=p?.graphContainer;let me;e[37]!==c?.description||e[38]!==c?.title||e[39]!==u||e[40]!==t||e[41]!==y||e[42]!==J||e[43]!==F||e[44]!==p?.description||e[45]!==p?.title||e[46]!==f?(me=F||y||J||t?o.jsxRuntimeExports.jsx(Ut.GraphHeader,{styles:{title:p?.title,description:p?.description},classNames:{title:c?.title,description:c?.description},graphTitle:F,graphDescription:y,width:f,graphDownload:J?Dt:void 0,dataDownload:t?u.map(ao).filter(ro).length>0?u.map(oo).filter(to):u.filter(eo):null}):null,e[37]=c?.description,e[38]=c?.title,e[39]=u,e[40]=t,e[41]=y,e[42]=J,e[43]=F,e[44]=p?.description,e[45]=p?.title,e[46]=f,e[47]=me):me=e[47];let he;e[48]!==A||e[49]!==it||e[50]!==W||e[51]!==n.enabled||e[52]!==l?(he=n.enabled&&l.length>0&&it?o.jsxRuntimeExports.jsxs("div",{className:"flex gap-6 items-center",dir:"ltr",children:[o.jsxRuntimeExports.jsx("button",{type:"button",onClick:()=>{Pt(!W)},className:"p-0 border-0 cursor-pointer bg-transparent","aria-label":W?"Click to pause animation":"Click to play animation",children:W?o.jsxRuntimeExports.jsx(ct.Pause,{}):o.jsxRuntimeExports.jsx(ct.Play,{})}),o.jsxRuntimeExports.jsx(Rt.Nr,{min:l[0],max:l[l.length-1],marks:it,step:null,defaultValue:l[l.length-1],value:l[A],onChangeComplete:s=>{ft(l.indexOf(s))},onChange:s=>{ft(l.indexOf(s))},"aria-label":"Time slider. Use arrow keys to adjust selected time period."})]}):null,e[48]=A,e[49]=it,e[50]=W,e[51]=n.enabled,e[52]=l,e[53]=he):he=e[53];let xe;e[54]!==Ge||e[55]!==ye||e[56]!==c||e[57]!==le||e[58]!==D||e[59]!==ut||e[60]!==u||e[61]!==Ce||e[62]!==dt||e[63]!==x||e[64]!==T||e[65]!==A||e[66]!==P||e[67]!==xt||e[68]!==Ne||e[69]!==Se||e[70]!==Me||e[71]!==d?.mapBorderColor||e[72]!==d?.mapBorderWidth||e[73]!==b||e[74]!==qe||e[75]!==pe||e[76]!==h||e[77]!==ae||e[78]!==je||e[79]!==gt||e[80]!==mt||e[81]!==v||e[82]!==w||e[83]!==ht||e[84]!==we||e[85]!==r||e[86]!==Be||e[87]!==p||e[88]!==_e||e[89]!==K||e[90]!==n.dateFormat||e[91]!==n.enabled||e[92]!==oe||e[93]!==l||e[94]!==f||e[95]!==_||e[96]!==E||e[97]!==Re||e[98]!==M||e[99]!==pt||e[100]!==Ie||e[101]!==Oe||e[102]!==$?(xe=o.jsxRuntimeExports.jsx(It.GraphArea,{ref:yt,children:K&&_e&&pe?o.jsxRuntimeExports.jsx(Yt,{data:u.filter(s=>n.enabled?`${s.date}`===wt.format(new Date(l[A]),n.dateFormat||"yyyy"):s),mapData:r?pe:{...pe,features:pe.features.filter(Qt)},xDomain:E||qt.getJenks(u.map(Zt),D[0].length),yDomain:M||qt.getJenks(u.map(Kt),D.length),width:K,height:_e,scale:we,centerPoint:ye,colors:D,xColorLegendTitle:_,yColorLegendTitle:Re,mapBorderWidth:Se,mapNoDataColor:Me,mapBorderColor:Ne,tooltip:oe,onSeriesMouseOver:je,isWorldMap:P,zoomScaleExtend:Oe,zoomTranslateExtend:$,onSeriesMouseClick:ae,mapProperty:qe,highlightedIds:T,resetSelectionOnDoubleClick:w,styles:p,showColorScale:Be,classNames:c,mapProjection:b||(P?"naturalEarth":"mercator"),detailsOnClick:Ce,zoomInteraction:Ie,overlayMapData:gt,overlayMapBorderColor:d?.mapBorderColor,overlayMapBorderWidth:d?.mapBorderWidth,animate:Ge===!0?{duration:.5,once:!0,amount:.5}:Ge||{duration:0,once:!0,amount:0},dimmedOpacity:dt,customLayers:ut,collapseColorScaleByDefault:le,zoomAndCenterByHighlightedIds:pt,projectionRotate:mt,rewindCoordinatesInMapData:ht,locale:xt}):o.jsxRuntimeExports.jsx("div",{style:{height:`${Math.max(h,x||(v?h?(f||K)*v>h?(f||K)*v:h:(f||K)*v:_e))}px`},className:"flex items-center justify-center",children:o.jsxRuntimeExports.jsx(Ft.w,{"aria-label":"Loading graph"})})}),e[54]=Ge,e[55]=ye,e[56]=c,e[57]=le,e[58]=D,e[59]=ut,e[60]=u,e[61]=Ce,e[62]=dt,e[63]=x,e[64]=T,e[65]=A,e[66]=P,e[67]=xt,e[68]=Ne,e[69]=Se,e[70]=Me,e[71]=d?.mapBorderColor,e[72]=d?.mapBorderWidth,e[73]=b,e[74]=qe,e[75]=pe,e[76]=h,e[77]=ae,e[78]=je,e[79]=gt,e[80]=mt,e[81]=v,e[82]=w,e[83]=ht,e[84]=we,e[85]=r,e[86]=Be,e[87]=p,e[88]=_e,e[89]=K,e[90]=n.dateFormat,e[91]=n.enabled,e[92]=oe,e[93]=l,e[94]=f,e[95]=_,e[96]=E,e[97]=Re,e[98]=M,e[99]=pt,e[100]=Ie,e[101]=Oe,e[102]=$,e[103]=xe):xe=e[103];let fe;e[104]!==c?.footnote||e[105]!==c?.source||e[106]!==I||e[107]!==Q||e[108]!==p?.footnote||e[109]!==p?.source||e[110]!==f?(fe=Q||I?o.jsxRuntimeExports.jsx(Xt.GraphFooter,{styles:{footnote:p?.footnote,source:p?.source},classNames:{footnote:c?.footnote,source:c?.source},sources:Q,footNote:I,width:f}):null,e[104]=c?.footnote,e[105]=c?.source,e[106]=I,e[107]=Q,e[108]=p?.footnote,e[109]=p?.source,e[110]=f,e[111]=fe):fe=e[111];let st;return e[112]!==ne||e[113]!==z||e[114]!==O||e[115]!==x||e[116]!==m||e[117]!==h||e[118]!==ve||e[119]!==v||e[120]!==bt||e[121]!==Et||e[122]!==me||e[123]!==he||e[124]!==xe||e[125]!==fe||e[126]!==g||e[127]!==f?(st=o.jsxRuntimeExports.jsxs(It.GraphContainer,{className:bt,style:Et,id:O,ref:Dt,"aria-label":ne,backgroundColor:z,theme:g,language:m,minHeight:h,width:f,height:x,relativeHeight:v,padding:ve,children:[me,he,xe,fe]}),e[112]=ne,e[113]=z,e[114]=O,e[115]=x,e[116]=m,e[117]=h,e[118]=ve,e[119]=v,e[120]=bt,e[121]=Et,e[122]=me,e[123]=he,e[124]=xe,e[125]=fe,e[126]=g,e[127]=f,e[128]=st):st=e[128],st}function Kt(i){return i.y}function Zt(i){return i.x}function Qt(i){return i.properties?.NAME!=="Antarctica"}function eo(i){return i!==void 0}function to(i){return i!==void 0}function oo(i){return i.data}function ro(i){return i!==void 0}function ao(i){return i.data}function no(i,e){return i-e}function io(i){return i.date}exports.BiVariateChoroplethMap=Jt;
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const o=require("./index-CHPV5EwG-D4pAp7u0.cjs"),n=require("react"),wt=require("./getSliderMarks-BzrpHrHS.cjs"),Ft=require("./Spinner-WHzzloYQ.cjs"),Rt=require("./parse-xYI9yrvL.cjs"),Lt=require("./index-DQA8q5sC.cjs"),R=require("./index-DLFt97gy.cjs"),$t=require("./index-C5K--w8d.cjs"),St=require("./Typography-BqmyF1gP.cjs"),Nt=require("./numberFormattingFunction-u2iNHL_c.cjs"),Tt=require("./Tooltip-C9F3uYG0.cjs"),Mt=require("./checkIfNullOrUndefined-BCW3Y1ML.cjs"),dt=require("./index-BhI7mBJx.cjs"),Gt=require("./DetailsModal-Du8Fr1QD.cjs"),Ht=require("./ImageDownloadButton.cjs"),Dt=require("./select-Bnfk0lJx.cjs"),Ot=require("./threshold-DNsSUf8Q.cjs"),ct=require("./proxy-CqH8m8IQ.cjs"),Vt=require("./use-in-view-dnRv_qqF.cjs"),Ut=require("./index-FXfr51ZM.cjs"),Xt=require("./GraphHeader.cjs"),Yt=require("./GraphFooter.cjs"),Ct=require("./Colors.cjs"),Bt=require("./fetchAndParseData-QTF6tjij.cjs"),It=require("./getJenks-BzJvhy_H.cjs"),qt=require("./GraphContainer-Cul9b74X.cjs");function Jt(l){const{data:e,xDomain:p,mapData:A,xColorLegendTitle:Ae,yDomain:oe,yColorLegendTitle:re,width:f,height:m,colors:h,scale:Fe,centerPoint:E,mapBorderWidth:S,mapNoDataColor:ae,mapBorderColor:ne,tooltip:ie,onSeriesMouseOver:je,zoomScaleExtend:be,zoomTranslateExtend:Ee,highlightedIds:y,onSeriesMouseClick:se,mapProperty:N,resetSelectionOnDoubleClick:Le,detailsOnClick:v,showColorScale:De,styles:$e,classNames:F,mapProjection:L,zoomInteraction:M,animate:O,dimmedOpacity:B,customLayers:le,collapseColorScaleByDefault:Ce,zoomAndCenterByHighlightedIds:ke,projectionRotate:$,rewindCoordinatesInMapData:X,overlayMapData:Y,overlayMapBorderColor:Te,overlayMapBorderWidth:Ge,xNumberDisplayOptions:J,yNumberDisplayOptions:ce,graphDownload:de}=l,a=n.useMemo(()=>X?R.index_default(A,{reverse:!0}):A,[A,X]),u=n.useMemo(()=>!X||!Y?Y:R.index_default(Y,{reverse:!0}),[Y,X]),[He,we]=n.useState(Ce===void 0?!(f<680):!Ce),[Z,Re]=n.useState(void 0),[T,G]=n.useState(void 0),[H,pe]=n.useState(void 0),[K,ue]=n.useState(void 0),[g,Q]=n.useState(void 0),I=n.useRef(null),D=Vt.useInView(I,{once:O.once,amount:O.amount}),k=n.useRef(null),V=n.useRef(null);n.useEffect(()=>{const t=Dt.select(k.current),r=Dt.select(I.current),i=x=>{if(M==="noZoom")return!1;if(M==="button")return!x.type.includes("wheel");const w=x.type==="wheel",j=x.type.startsWith("touch"),he=x.type==="mousedown"||x.type==="mousemove";return j?!0:w?M==="scroll"?!0:x.ctrlKey:he&&!x.button&&!x.ctrlKey},b=R.zoom().scaleExtent(be).translateExtent(Ee||[[-20,-20],[f+20,m+20]]).filter(i).on("zoom",({transform:x})=>{t.attr("transform",x)});r.call(b),V.current=b},[m,f,M]);const U=R.index_default$1({...a,features:ke?a.features.filter(t=>(y||[]).length===0||y?.indexOf(t.properties[N])!==-1):a.features}),q=$t.index_default({...a,features:ke?a.features.filter(t=>(y||[]).length===0||y?.indexOf(t.properties[N])!==-1):a.features}),Se=(U[2]-U[0])*1.15,Ne=(U[3]-U[1])*1.15,Me=f*190/960*360/Se,Oe=m*190/678*180/Ne,z=Fe*Math.min(Me,Oe),me=L==="mercator"?R.geoMercator().rotate($).center(E||q.geometry.coordinates).translate([f/2,m/2]).scale(z):L==="equalEarth"?R.geoEqualEarth().rotate($).center(E||q.geometry.coordinates).translate([f/2,m/2]).scale(z):L==="naturalEarth"?R.geoNaturalEarth1().rotate($).center(E||q.geometry.coordinates).translate([f/2,m/2]).scale(z):L==="orthographic"?R.geoOrthographic().rotate($).center(E||q.geometry.coordinates).translate([f/2,m/2]).scale(z):R.geoAlbersUsa().rotate($).center(E||q.geometry.coordinates).translate([f/2,m/2]).scale(z),_=R.geoPath().projection(me),Be=Array.from({length:p.length},(t,r)=>r),Ie=Array.from({length:oe.length},(t,r)=>r),qe=Ot.threshold().domain(p).range(Be),ze=Ot.threshold().domain(oe).range(Ie),ee=t=>{if(!I.current||!V.current)return;Dt.select(I.current).call(V.current.scaleBy,t==="in"?1.2:1/1.2)};return o.jsxRuntimeExports.jsxs(o.jsxRuntimeExports.Fragment,{children:[o.jsxRuntimeExports.jsxs("div",{className:"relative",children:[o.jsxRuntimeExports.jsx(ct.motion.svg,{viewBox:`0 0 ${f} ${m}`,width:`${f}px`,height:`${m}px`,ref:I,direction:"ltr",children:o.jsxRuntimeExports.jsxs("g",{ref:k,children:[le.filter(t=>t.position==="before").map(t=>t.layer),a.features.map((t,r)=>{if(!t.properties?.[N])return null;const i=_(t);return i?o.jsxRuntimeExports.jsx(ct.motion.g,{opacity:Z?B:y?y.indexOf(t.properties[N])!==-1?1:B:1,children:o.jsxRuntimeExports.jsx("path",{d:i,style:{stroke:ne,strokeWidth:S,fill:ae,vectorEffect:"non-scaling-stroke"}})},r):null}),o.jsxRuntimeExports.jsx(Ut.AnimatePresence,{children:e.map(t=>{const r=a.features.findIndex(j=>t.id===j.properties[N]);if(r===-1)return null;const i=_(a.features[r]);if(!i)return null;const b=Mt.checkIfNullOrUndefined(t.x)?void 0:qe(t.x),x=Mt.checkIfNullOrUndefined(t.y)?void 0:ze(t.y),w=b!==void 0&&x!==void 0?h[x][b]:ae;return o.jsxRuntimeExports.jsx(ct.motion.g,{className:"undp-map-shapes",variants:{initial:{opacity:0},whileInView:{opacity:Z?Z===w&&(!y||y.indexOf(t.id)!==-1)?1:B:y?y.indexOf(t.id)!==-1?1:B:1,transition:{duration:O.duration}}},initial:"initial",animate:D?"whileInView":"initial",exit:{opacity:0,transition:{duration:O.duration}},onMouseEnter:j=>{pe(t),Q(j.clientY),ue(j.clientX),je?.(t)},onClick:()=>{(se||v)&&(Lt.isEqual(T,t)&&Le?(G(void 0),se?.(void 0)):(G(t),se?.(t)))},onMouseMove:j=>{pe(t),Q(j.clientY),ue(j.clientX)},onMouseLeave:()=>{pe(void 0),ue(void 0),Q(void 0),je?.(void 0)},children:o.jsxRuntimeExports.jsx(ct.motion.path,{d:i,variants:{initial:{fill:w,opacity:0},whileInView:{fill:w,opacity:1,transition:{duration:O.duration}}},initial:"initial",animate:D?"whileInView":"initial",exit:{opacity:0,transition:{duration:O.duration}},className:`${w===ae?"stroke-primary-gray-400 dark:stroke-primary-gray-500":"stroke-primary-white dark:stroke-primary-gray-650"}`,style:{stroke:ne,strokeWidth:S,vectorEffect:"non-scaling-stroke"}},`${t.id}`)},t.id)})}),H?a.features.filter(t=>t.properties[N]===H.id).map((t,r)=>o.jsxRuntimeExports.jsx("path",{d:_(t)||"",className:"stroke-primary-gray-700 dark:stroke-primary-gray-300",style:{fill:"none",fillOpacity:0,strokeWidth:"0.5",vectorEffect:"non-scaling-stroke"}},r)):null,u?.features.map((t,r)=>{const i=_(t);return i?o.jsxRuntimeExports.jsx("g",{children:o.jsxRuntimeExports.jsx("path",{d:i,style:{stroke:Te||ne,strokeWidth:Ge||S+1,fill:"none",pointerEvents:"none",vectorEffect:"non-scaling-stroke"}})},r):null}),le.filter(t=>t.position==="after").map(t=>t.layer)]})}),De===!1?null:o.jsxRuntimeExports.jsx("div",{className:o.mo("absolute left-4 bottom-4 map-color-legend",F?.colorLegend),children:He?o.jsxRuntimeExports.jsxs(o.jsxRuntimeExports.Fragment,{children:[o.jsxRuntimeExports.jsx("div",{className:"color-legend-close-button bg-[rgba(240,240,240,0.7)] dark:bg-[rgba(30,30,30,0.7)] border border-[var(--gray-400)] rounded-full w-6 h-6 p-[3px] cursor-pointer z-10 absolute right-[-0.75rem] top-[-0.75rem]",onClick:()=>{we(!1)},children:o.jsxRuntimeExports.jsx(dt.X,{})}),o.jsxRuntimeExports.jsxs("div",{className:"color-legend-box p-2 bg-[rgba(240,240,240,0.7)] dark:bg-[rgba(30,30,30,0.7)]",style:{width:"175px"},children:[o.jsxRuntimeExports.jsxs("div",{className:"flex gap-1 items-center",children:[o.jsxRuntimeExports.jsx("svg",{width:"136px",viewBox:"0 0 136 136",className:"shrink-0",children:o.jsxRuntimeExports.jsxs("g",{children:[h.map((t,r)=>o.jsxRuntimeExports.jsx("g",{transform:`translate(0,${100-r*25})`,children:t.map((i,b)=>o.jsxRuntimeExports.jsx("rect",{y:1,x:b*25+1,fill:i,width:23,height:23,strokeWidth:Z===i?2:.25,style:{cursor:"pointer"},onMouseOver:()=>{Re(i)},onMouseLeave:()=>{Re(void 0)}},b))},r)),o.jsxRuntimeExports.jsx("g",{transform:"translate(0,125)",children:p.map((t,r)=>o.jsxRuntimeExports.jsx("text",{y:10,x:(r+1)*25,fontSize:10,textAnchor:"middle",children:typeof t=="string"||t<1?t:Nt.numberFormattingFunction(t,void 0,J?.precision??2,void 0,void 0,J?.locale||"en",J?.padZeros||!1)},r))}),oe.map((t,r)=>o.jsxRuntimeExports.jsx("g",{transform:`translate(${Math.max(Math.min(p.length+1,5),4)*25+10},${100-r*25})`,children:o.jsxRuntimeExports.jsx("text",{x:0,transform:"rotate(-90)",y:0,fontSize:10,textAnchor:"middle",children:typeof t=="string"||t<1?t:Nt.numberFormattingFunction(t,void 0,ce?.precision??2,void 0,void 0,ce?.locale||"en",ce?.padZeros||!1)})},r))]})}),o.jsxRuntimeExports.jsx(St._,{marginBottom:"none",size:"xs",className:"leading-normal text-center shrink-0",style:{display:"-webkit-box",WebkitLineClamp:"1",WebkitBoxOrient:"vertical",overflow:"hidden",writingMode:"vertical-rl",height:"8.5rem",transform:"rotate(180deg)"},children:re})]}),o.jsxRuntimeExports.jsx(St._,{marginBottom:"none",size:"xs",className:"mt-1 leading-normal text-center",style:{display:"-webkit-box",WebkitLineClamp:"1",width:"8.5rem",WebkitBoxOrient:"vertical",overflow:"hidden"},children:Ae})]})]}):o.jsxRuntimeExports.jsx("button",{type:"button",className:"p-1 border-0 rounded-[2px] text-primary-gray-700 bg-primary-gray-300 dark:bg-primary-gray-500 map-legend-button",onClick:()=>{we(!0)},children:o.jsxRuntimeExports.jsx(dt.ExpandIcon,{})})}),M==="button"&&o.jsxRuntimeExports.jsxs("div",{className:"absolute left-4 top-4 flex flex-col undp-viz-zoom-buttons",children:[o.jsxRuntimeExports.jsx("button",{onClick:()=>ee("in"),className:"leading-0 px-2 py-3.5 border text-primary-gray-700 border-primary-gray-400 bg-primary-gray-200 dark:border-primary-gray-550 dark:bg-primary-gray-600 dark:text-primary-gray-100",children:"+"}),o.jsxRuntimeExports.jsx("button",{onClick:()=>ee("out"),className:"leading-0 px-2 py-3.5 border text-primary-gray-700 border-t-0 border-primary-gray-400 bg-primary-gray-200 dark:border-primary-gray-550 dark:bg-primary-gray-600 dark:text-primary-gray-100",children:"–"})]}),de&&o.jsxRuntimeExports.jsx("div",{className:"absolute right-4 top-4 flex flex-col image-download-button",children:o.jsxRuntimeExports.jsx(Ht.ImageDownloadButton,{nodeID:de,buttonSmall:!0})})]}),H&&ie&&K&&g?o.jsxRuntimeExports.jsx(Tt.Tooltip,{data:H,body:ie,xPos:K,yPos:g,backgroundStyle:$e?.tooltip,className:F?.tooltip}):null,v&&T!==void 0?o.jsxRuntimeExports.jsx(Gt.DetailsModal,{body:v,data:T,setData:G,className:F?.modal}):null]})}function Zt(l){const e=o.compilerRuntimeExports.c(130),{data:p,graphTitle:A,mapData:Ae,colors:oe,sources:re,graphDescription:f,height:m,width:h,footNote:Fe,xDomain:E,yDomain:S,xColorLegendTitle:ae,yColorLegendTitle:ne,tooltip:ie,scale:je,centerPoint:be,padding:Ee,mapBorderWidth:y,mapNoDataColor:se,backgroundColor:N,mapBorderColor:Le,relativeHeight:v,onSeriesMouseOver:De,isWorldMap:$e,zoomScaleExtend:F,zoomTranslateExtend:L,graphID:M,showColorScale:O,highlightedIds:B,onSeriesMouseClick:le,mapProperty:Ce,graphDownload:ke,dataDownload:$,showAntarctica:X,language:Y,minHeight:Te,theme:Ge,ariaLabel:J,resetSelectionOnDoubleClick:ce,detailsOnClick:de,styles:a,classNames:u,mapProjection:He,zoomInteraction:we,animate:Z,dimmedOpacity:Re,customLayers:T,timeline:G,collapseColorScaleByDefault:H,zoomAndCenterByHighlightedIds:pe,projectionRotate:K,rewindCoordinatesInMapData:ue,mapOverlay:g,xNumberDisplayOptions:Q,yNumberDisplayOptions:I}=l,D=Ae===void 0?"https://raw.githubusercontent.com/UNDP-Data/dv-country-geojson/refs/heads/main/worldMap-v2.json":Ae,k=oe===void 0?Ct.Colors.light.bivariateColors.colors05x05:oe,V=Fe===void 0?"The designations employed and the presentation of material on this map do not imply the expression of any opinion whatsoever on the part of the Secretariat of the United Nations or UNDP concerning the legal status of any country, territory, city or area or its authorities, or concerning the delimitation of its frontiers or boundaries.":Fe,U=ae===void 0?"X Color key":ae,q=ne===void 0?"Y Color key":ne,Se=je===void 0?.95:je,Ne=y===void 0?.5:y,Me=se===void 0?Ct.Colors.light.graphNoData:se,Oe=N===void 0?!1:N,z=Le===void 0?Ct.Colors.light.grays["gray-500"]:Le,me=$e===void 0?!0:$e;let _;e[0]!==F?(_=F===void 0?[.8,6]:F,e[0]=F,e[1]=_):_=e[1];const Be=_,Ie=O===void 0?!0:O,qe=Ce===void 0?"ISO3":Ce,ze=ke===void 0?!1:ke,ee=$===void 0?!1:$,t=X===void 0?!1:X,r=Y===void 0?"en":Y,i=Te===void 0?0:Te,b=Ge===void 0?"light":Ge,x=ce===void 0?!0:ce,w=He===void 0?"naturalEarth":He,j=we===void 0?"button":we,he=Z===void 0?!1:Z,pt=Re===void 0?.3:Re;let Ve;e[2]!==T?(Ve=T===void 0?[]:T,e[2]=T,e[3]=Ve):Ve=e[3];const ut=Ve;let Ue;e[4]!==G?(Ue=G===void 0?{enabled:!1,autoplay:!1,showOnlyActiveDate:!0}:G,e[4]=G,e[5]=Ue):Ue=e[5];const s=Ue,mt=pe===void 0?!1:pe;let Xe;e[6]!==K?(Xe=K===void 0?[0,0]:K,e[6]=K,e[7]=Xe):Xe=e[7];const ht=Xe,xt=ue===void 0?!0:ue,[te,zt]=n.useState(0),[_e,_t]=n.useState(0),[P,Pt]=n.useState(s.autoplay);let Pe;if(e[8]!==p||e[9]!==s.dateFormat){let c;e[11]!==s.dateFormat?(c=C=>Rt.parse(`${C.date}`,s.dateFormat||"yyyy",new Date).getTime(),e[11]=s.dateFormat,e[12]=c):c=e[12],Pe=[...new Set(p.filter(so).map(c))],Pe.sort(io),e[8]=p,e[9]=s.dateFormat,e[10]=Pe}else Pe=e[10];const d=Pe,[W,ft]=n.useState(s.autoplay?0:d.length-1),[xe,Wt]=n.useState(void 0),[gt,At]=n.useState(void 0),yt=n.useRef(null),kt=n.useRef(null);let Ye,Je;e[13]===Symbol.for("react.memo_cache_sentinel")?(Ye=()=>{const c=new ResizeObserver(C=>{zt(C[0].target.clientWidth||620),_t(C[0].target.clientHeight||480)});return yt.current&&c.observe(yt.current),()=>c.disconnect()},Je=[],e[13]=Ye,e[14]=Je):(Ye=e[13],Je=e[14]),n.useEffect(Ye,Je);let Ze;e[15]===Symbol.for("react.memo_cache_sentinel")?(Ze=c=>{Wt(c)},e[15]=Ze):Ze=e[15];const Ke=n.useEffectEvent(Ze);let Qe;e[16]===Symbol.for("react.memo_cache_sentinel")?(Qe=c=>{At(c)},e[16]=Qe):Qe=e[16];const We=n.useEffectEvent(Qe);let et;e[17]!==D||e[18]!==Ke?(et=()=>{typeof D=="string"?Bt.fetchAndParseJSON(D).then(C=>{Ke(C)}):Ke(D)},e[17]=D,e[18]=Ke,e[19]=et):et=e[19];let tt;e[20]!==D?(tt=[D],e[20]=D,e[21]=tt):tt=e[21],n.useEffect(et,tt);let ot;e[22]!==g?.mapData||e[23]!==We?(ot=()=>{g?.mapData||We(void 0),typeof g?.mapData=="string"?Bt.fetchAndParseJSON(g?.mapData).then(C=>{We(C)}):We(g?.mapData)},e[22]=g?.mapData,e[23]=We,e[24]=ot):ot=e[24];const vt=g?.mapData;let rt;e[25]!==vt?(rt=[vt],e[25]=vt,e[26]=rt):rt=e[26],n.useEffect(ot,rt);let at,nt;e[27]!==P||e[28]!==s.speed||e[29]!==d?(at=()=>{const c=setInterval(()=>{ft(C=>C<d.length-1?C+1:0)},(s.speed||2)*1e3);return P||clearInterval(c),()=>clearInterval(c)},nt=[d,P,s.speed],e[27]=P,e[28]=s.speed,e[29]=d,e[30]=at,e[31]=nt):(at=e[30],nt=e[31]),n.useEffect(at,nt);const jt=s.dateFormat||"yyyy";let it;e[32]!==W||e[33]!==jt||e[34]!==s.showOnlyActiveDate||e[35]!==d?(it=wt.getSliderMarks(d,W,s.showOnlyActiveDate,jt),e[32]=W,e[33]=jt,e[34]=s.showOnlyActiveDate,e[35]=d,e[36]=it):it=e[36];const st=it;if(E&&S&&(E.length!==k[0].length-1||S.length!==k.length-1))return console.error("the xDomain and yDomain array length don't match to the color array length"),null;const bt=u?.graphContainer,Et=a?.graphContainer;let fe;e[37]!==u?.description||e[38]!==u?.title||e[39]!==p||e[40]!==ee||e[41]!==f||e[42]!==A||e[43]!==a?.description||e[44]!==a?.title||e[45]!==h?(fe=A||f||ee?o.jsxRuntimeExports.jsx(Xt.GraphHeader,{styles:{title:a?.title,description:a?.description},classNames:{title:u?.title,description:u?.description},graphTitle:A,graphDescription:f,width:h,dataDownload:ee?p.map(no).filter(ao).length>0?p.map(ro).filter(oo):p.filter(to):null}):null,e[37]=u?.description,e[38]=u?.title,e[39]=p,e[40]=ee,e[41]=f,e[42]=A,e[43]=a?.description,e[44]=a?.title,e[45]=h,e[46]=fe):fe=e[46];let ge;e[47]!==W||e[48]!==st||e[49]!==P||e[50]!==s.enabled||e[51]!==d?(ge=s.enabled&&d.length>0&&st?o.jsxRuntimeExports.jsxs("div",{className:"flex gap-6 items-center",dir:"ltr",children:[o.jsxRuntimeExports.jsx("button",{type:"button",onClick:()=>{Pt(!P)},className:"p-0 border-0 cursor-pointer bg-transparent","aria-label":P?"Click to pause animation":"Click to play animation",children:P?o.jsxRuntimeExports.jsx(dt.Pause,{}):o.jsxRuntimeExports.jsx(dt.Play,{})}),o.jsxRuntimeExports.jsx(wt.Nr,{min:d[0],max:d[d.length-1],marks:st,step:null,defaultValue:d[d.length-1],value:d[W],onChangeComplete:c=>{ft(d.indexOf(c))},onChange:c=>{ft(d.indexOf(c))},"aria-label":"Time slider. Use arrow keys to adjust selected time period."})]}):null,e[47]=W,e[48]=st,e[49]=P,e[50]=s.enabled,e[51]=d,e[52]=ge):ge=e[52];let ye;e[53]!==he||e[54]!==be||e[55]!==u||e[56]!==H||e[57]!==k||e[58]!==ut||e[59]!==p||e[60]!==de||e[61]!==pt||e[62]!==ze||e[63]!==m||e[64]!==B||e[65]!==W||e[66]!==me||e[67]!==z||e[68]!==Ne||e[69]!==Me||e[70]!==g?.mapBorderColor||e[71]!==g?.mapBorderWidth||e[72]!==w||e[73]!==qe||e[74]!==xe||e[75]!==i||e[76]!==le||e[77]!==De||e[78]!==gt||e[79]!==ht||e[80]!==v||e[81]!==x||e[82]!==xt||e[83]!==Se||e[84]!==t||e[85]!==Ie||e[86]!==a||e[87]!==_e||e[88]!==te||e[89]!==s.dateFormat||e[90]!==s.enabled||e[91]!==ie||e[92]!==d||e[93]!==h||e[94]!==U||e[95]!==E||e[96]!==Q||e[97]!==q||e[98]!==S||e[99]!==I||e[100]!==mt||e[101]!==j||e[102]!==Be||e[103]!==L?(ye=o.jsxRuntimeExports.jsx(qt.GraphArea,{ref:yt,children:te&&_e&&xe?o.jsxRuntimeExports.jsx(Jt,{data:p.filter(c=>s.enabled?`${c.date}`===Rt.format(new Date(d[W]),s.dateFormat||"yyyy"):c),mapData:t?xe:{...xe,features:xe.features.filter(eo)},xDomain:E||It.getJenks(p.map(Qt),k[0].length),yDomain:S||It.getJenks(p.map(Kt),k.length),width:te,height:_e,scale:Se,centerPoint:be,colors:k,xColorLegendTitle:U,yColorLegendTitle:q,mapBorderWidth:Ne,mapNoDataColor:Me,mapBorderColor:z,tooltip:ie,onSeriesMouseOver:De,isWorldMap:me,zoomScaleExtend:Be,zoomTranslateExtend:L,onSeriesMouseClick:le,mapProperty:qe,highlightedIds:B,resetSelectionOnDoubleClick:x,styles:a,showColorScale:Ie,classNames:u,mapProjection:w||(me?"naturalEarth":"mercator"),detailsOnClick:de,zoomInteraction:j,overlayMapData:gt,overlayMapBorderColor:g?.mapBorderColor,overlayMapBorderWidth:g?.mapBorderWidth,animate:he===!0?{duration:.5,once:!0,amount:.5}:he||{duration:0,once:!0,amount:0},dimmedOpacity:pt,customLayers:ut,collapseColorScaleByDefault:H,zoomAndCenterByHighlightedIds:mt,projectionRotate:ht,rewindCoordinatesInMapData:xt,xNumberDisplayOptions:Q,yNumberDisplayOptions:I,graphDownload:ze?kt:void 0}):o.jsxRuntimeExports.jsx("div",{style:{height:`${Math.max(i,m||(v?i?(h||te)*v>i?(h||te)*v:i:(h||te)*v:_e))}px`},className:"flex items-center justify-center",children:o.jsxRuntimeExports.jsx(Ft.w,{"aria-label":"Loading graph"})})}),e[53]=he,e[54]=be,e[55]=u,e[56]=H,e[57]=k,e[58]=ut,e[59]=p,e[60]=de,e[61]=pt,e[62]=ze,e[63]=m,e[64]=B,e[65]=W,e[66]=me,e[67]=z,e[68]=Ne,e[69]=Me,e[70]=g?.mapBorderColor,e[71]=g?.mapBorderWidth,e[72]=w,e[73]=qe,e[74]=xe,e[75]=i,e[76]=le,e[77]=De,e[78]=gt,e[79]=ht,e[80]=v,e[81]=x,e[82]=xt,e[83]=Se,e[84]=t,e[85]=Ie,e[86]=a,e[87]=_e,e[88]=te,e[89]=s.dateFormat,e[90]=s.enabled,e[91]=ie,e[92]=d,e[93]=h,e[94]=U,e[95]=E,e[96]=Q,e[97]=q,e[98]=S,e[99]=I,e[100]=mt,e[101]=j,e[102]=Be,e[103]=L,e[104]=ye):ye=e[104];let ve;e[105]!==u?.footnote||e[106]!==u?.source||e[107]!==V||e[108]!==re||e[109]!==a?.footnote||e[110]!==a?.source||e[111]!==h?(ve=re||V?o.jsxRuntimeExports.jsx(Yt.GraphFooter,{styles:{footnote:a?.footnote,source:a?.source},classNames:{footnote:u?.footnote,source:u?.source},sources:re,footNote:V,width:h}):null,e[105]=u?.footnote,e[106]=u?.source,e[107]=V,e[108]=re,e[109]=a?.footnote,e[110]=a?.source,e[111]=h,e[112]=ve):ve=e[112];let lt;return e[113]!==J||e[114]!==Oe||e[115]!==M||e[116]!==m||e[117]!==r||e[118]!==i||e[119]!==Ee||e[120]!==v||e[121]!==bt||e[122]!==Et||e[123]!==fe||e[124]!==ge||e[125]!==ye||e[126]!==ve||e[127]!==b||e[128]!==h?(lt=o.jsxRuntimeExports.jsxs(qt.GraphContainer,{className:bt,style:Et,id:M,ref:kt,"aria-label":J,backgroundColor:Oe,theme:b,language:r,minHeight:i,width:h,height:m,relativeHeight:v,padding:Ee,children:[fe,ge,ye,ve]}),e[113]=J,e[114]=Oe,e[115]=M,e[116]=m,e[117]=r,e[118]=i,e[119]=Ee,e[120]=v,e[121]=bt,e[122]=Et,e[123]=fe,e[124]=ge,e[125]=ye,e[126]=ve,e[127]=b,e[128]=h,e[129]=lt):lt=e[129],lt}function Kt(l){return l.y}function Qt(l){return l.x}function eo(l){return l.properties?.NAME!=="Antarctica"}function to(l){return l!==void 0}function oo(l){return l!==void 0}function ro(l){return l.data}function ao(l){return l!==void 0}function no(l){return l.data}function io(l,e){return l-e}function so(l){return l.date}exports.BiVariateChoroplethMap=Zt;
2
2
  //# sourceMappingURL=BiVariateChoroplethMap.cjs.map