@undp/data-viz 2.3.1 → 2.3.3

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 (154) hide show
  1. package/dist/AreaChart.cjs +1 -1
  2. package/dist/AreaChart.js +1 -1
  3. package/dist/BarGraph.cjs +1 -1
  4. package/dist/BarGraph.js +2 -2
  5. package/dist/BasicStatCard.cjs +1 -1
  6. package/dist/BasicStatCard.js +15 -15
  7. package/dist/BeeSwarmChart.cjs +1 -1
  8. package/dist/BeeSwarmChart.js +2 -2
  9. package/dist/BiVariateChoroplethMap.cjs +1 -1
  10. package/dist/BiVariateChoroplethMap.cjs.map +1 -1
  11. package/dist/BiVariateChoroplethMap.js +202 -202
  12. package/dist/BiVariateChoroplethMap.js.map +1 -1
  13. package/dist/BulletChart.cjs +1 -1
  14. package/dist/BulletChart.js +2 -2
  15. package/dist/ButterflyChart.cjs +1 -1
  16. package/dist/ButterflyChart.js +2 -2
  17. package/dist/ChoroplethMap.cjs +1 -1
  18. package/dist/ChoroplethMap.cjs.map +1 -1
  19. package/dist/ChoroplethMap.js +33 -33
  20. package/dist/ChoroplethMap.js.map +1 -1
  21. package/dist/CirclePackingGraph.cjs +1 -1
  22. package/dist/CirclePackingGraph.js +2 -2
  23. package/dist/ColorLegend.cjs +1 -1
  24. package/dist/ColorLegend.js +7 -7
  25. package/dist/ColorLegendWithMouseOver.cjs +1 -1
  26. package/dist/ColorLegendWithMouseOver.js +1 -1
  27. package/dist/CopyTextButton.cjs +1 -1
  28. package/dist/CopyTextButton.js +1 -1
  29. package/dist/CsvDownloadButton.cjs +2 -2
  30. package/dist/CsvDownloadButton.js +1 -1
  31. package/dist/DataCards.cjs +1 -1
  32. package/dist/DataCards.js +3 -3
  33. package/dist/DataCards.js.map +1 -1
  34. package/dist/DataTable.cjs +1 -1
  35. package/dist/DataTable.js +2 -2
  36. package/dist/DifferenceLineChart.cjs +1 -1
  37. package/dist/DifferenceLineChart.js +1 -1
  38. package/dist/DonutChart.cjs +1 -1
  39. package/dist/DonutChart.js +20 -20
  40. package/dist/DotDensityMap.cjs +1 -1
  41. package/dist/DotDensityMap.cjs.map +1 -1
  42. package/dist/DotDensityMap.js +46 -46
  43. package/dist/DotDensityMap.js.map +1 -1
  44. package/dist/DualAxisLineChart.cjs +1 -1
  45. package/dist/DualAxisLineChart.js +1 -1
  46. package/dist/DumbbellChart.cjs +1 -1
  47. package/dist/DumbbellChart.js +2 -2
  48. package/dist/{EmptyState-CGeBqbmR.cjs → EmptyState-DX0t62iF.cjs} +2 -2
  49. package/dist/{EmptyState-CGeBqbmR.cjs.map → EmptyState-DX0t62iF.cjs.map} +1 -1
  50. package/dist/{EmptyState-tZBErBKF.js → EmptyState-Pj-emXt5.js} +3 -3
  51. package/dist/{EmptyState-tZBErBKF.js.map → EmptyState-Pj-emXt5.js.map} +1 -1
  52. package/dist/ExcelDownloadButton.cjs +1 -1
  53. package/dist/ExcelDownloadButton.js +7 -7
  54. package/dist/FootNote.cjs +1 -1
  55. package/dist/FootNote.js +1 -1
  56. package/dist/GeoHubCompareMaps.cjs +1 -1
  57. package/dist/GeoHubCompareMaps.js +1 -1
  58. package/dist/GeoHubMap.cjs +1 -1
  59. package/dist/GeoHubMap.js +1 -1
  60. package/dist/GeoHubMapWithLayerSelection.cjs +1 -1
  61. package/dist/GeoHubMapWithLayerSelection.js +2 -2
  62. package/dist/GraphDescription.cjs +1 -1
  63. package/dist/GraphDescription.js +1 -1
  64. package/dist/{GraphEl-ic8C5Ksc.cjs → GraphEl-CWjTuiYd.cjs} +2 -2
  65. package/dist/{GraphEl-ic8C5Ksc.cjs.map → GraphEl-CWjTuiYd.cjs.map} +1 -1
  66. package/dist/{GraphEl-L5hNe7wJ.js → GraphEl-DDXkYObU.js} +7 -7
  67. package/dist/{GraphEl-L5hNe7wJ.js.map → GraphEl-DDXkYObU.js.map} +1 -1
  68. package/dist/GraphFooter.cjs +1 -1
  69. package/dist/GraphFooter.js +1 -1
  70. package/dist/GraphTitle.cjs +1 -1
  71. package/dist/GraphTitle.js +1 -1
  72. package/dist/GriddedGraphs.cjs +1 -1
  73. package/dist/GriddedGraphs.js +1 -1
  74. package/dist/HeatMap.cjs +1 -1
  75. package/dist/HeatMap.js +1 -1
  76. package/dist/Histogram.cjs +1 -1
  77. package/dist/Histogram.js +1 -1
  78. package/dist/HybridMap.cjs +1 -1
  79. package/dist/HybridMap.cjs.map +1 -1
  80. package/dist/HybridMap.js +42 -42
  81. package/dist/HybridMap.js.map +1 -1
  82. package/dist/ImageDownloadButton.cjs +1 -1
  83. package/dist/ImageDownloadButton.js +1 -1
  84. package/dist/LineChartWithConfidenceInterval.cjs +1 -1
  85. package/dist/LineChartWithConfidenceInterval.js +1 -1
  86. package/dist/LinearColorLegend.cjs +1 -1
  87. package/dist/LinearColorLegend.js +1 -1
  88. package/dist/MultiLineAltChart.cjs +1 -1
  89. package/dist/MultiLineAltChart.js +1 -1
  90. package/dist/MultiLineChart.cjs +1 -1
  91. package/dist/MultiLineChart.js +1 -1
  92. package/dist/ParetoChart.cjs +1 -1
  93. package/dist/ParetoChart.js +1 -1
  94. package/dist/RadarChart.cjs +1 -1
  95. package/dist/RadarChart.js +1 -1
  96. package/dist/SVGDownloadButton.cjs +1 -1
  97. package/dist/SVGDownloadButton.js +8 -8
  98. package/dist/SankeyChart.cjs +1 -1
  99. package/dist/SankeyChart.js +80 -80
  100. package/dist/ScatterPlot.cjs +1 -1
  101. package/dist/ScatterPlot.js +2 -2
  102. package/dist/SimpleLineChart.cjs +1 -1
  103. package/dist/SimpleLineChart.js +1 -1
  104. package/dist/SingleGraphDashboard.cjs +1 -1
  105. package/dist/SingleGraphDashboard.js +1 -1
  106. package/dist/SingleGraphDashboardGeoHubMaps.cjs +1 -1
  107. package/dist/SingleGraphDashboardGeoHubMaps.js +10 -10
  108. package/dist/SingleGraphDashboardThreeDGraphs.cjs +1 -1
  109. package/dist/SingleGraphDashboardThreeDGraphs.js +1 -1
  110. package/dist/SlopeChart.cjs +1 -1
  111. package/dist/SlopeChart.js +1 -1
  112. package/dist/{Source-B5AoSlsi.cjs → Source-B3i0Bx2R.cjs} +2 -2
  113. package/dist/{Source-B5AoSlsi.cjs.map → Source-B3i0Bx2R.cjs.map} +1 -1
  114. package/dist/{Source-F8EYCYkV.js → Source-_STIejqs.js} +14 -14
  115. package/dist/{Source-F8EYCYkV.js.map → Source-_STIejqs.js.map} +1 -1
  116. package/dist/Source.cjs +1 -1
  117. package/dist/Source.js +2 -2
  118. package/dist/StatCardFromData.cjs +1 -1
  119. package/dist/StatCardFromData.js +12 -12
  120. package/dist/StripChart.cjs +1 -1
  121. package/dist/StripChart.js +1 -1
  122. package/dist/ThreeDGlobe.cjs +1 -1
  123. package/dist/ThreeDGlobe.js +2 -2
  124. package/dist/ThresholdColorLegendWithMouseOver.cjs +1 -1
  125. package/dist/ThresholdColorLegendWithMouseOver.js +10 -10
  126. package/dist/TreeMapGraph.cjs +1 -1
  127. package/dist/TreeMapGraph.js +29 -29
  128. package/dist/Typography-DrJ7IOdw.cjs +2 -0
  129. package/dist/Typography-DrJ7IOdw.cjs.map +1 -0
  130. package/dist/Typography-iR8PEgdt.js +263 -0
  131. package/dist/Typography-iR8PEgdt.js.map +1 -0
  132. package/dist/UnitChart.cjs +1 -1
  133. package/dist/UnitChart.js +25 -25
  134. package/dist/WaterfallChart.cjs +1 -1
  135. package/dist/WaterfallChart.js +1 -1
  136. package/dist/{index-BQYOuXdl.js → index-B-4y_iGB.js} +19 -17
  137. package/dist/index-B-4y_iGB.js.map +1 -0
  138. package/dist/{index-D5ihtaJJ.js → index-BE-lvE4c.js} +3 -3
  139. package/dist/{index-D5ihtaJJ.js.map → index-BE-lvE4c.js.map} +1 -1
  140. package/dist/{index-Dgjq6aZ2.cjs → index-DlrGwLQA.cjs} +2 -2
  141. package/dist/{index-Dgjq6aZ2.cjs.map → index-DlrGwLQA.cjs.map} +1 -1
  142. package/dist/index-sbKVyHS2.cjs +2 -0
  143. package/dist/index-sbKVyHS2.cjs.map +1 -0
  144. package/dist/index.cjs +1 -1
  145. package/dist/index.js +2 -2
  146. package/dist/style.css +1 -1
  147. package/package.json +3 -3
  148. package/dist/Typography-hWfh3H0J.js +0 -142
  149. package/dist/Typography-hWfh3H0J.js.map +0 -1
  150. package/dist/Typography-sa1UE0oF.cjs +0 -2
  151. package/dist/Typography-sa1UE0oF.cjs.map +0 -1
  152. package/dist/index-BQYOuXdl.js.map +0 -1
  153. package/dist/index-C6er0ety.cjs +0 -2
  154. package/dist/index-C6er0ety.cjs.map +0 -1
@@ -1,12 +1,14 @@
1
1
  import { _ as m, m as p, a as x, b as g, c as i, j as t } from "./index-CHPV5EwG-DecW7_qr.js";
2
- import y from "react";
3
- const w = x("undp-button m-0! tracking-[0.48px] inline-flex items-center justify-center gap-2 uppercase whitespace-nowrap rounded-none text-lg font-bold transition-colors focus-visible:outline-hidden focus-visible:ring-1 disabled:pointer-events-none disabled:opacity-50 [&_svg]:pointer-events-none [&_svg]:size-4 [&_svg]:shrink-0", {
2
+ import w from "react";
3
+ const y = x("undp-button cursor-pointer m-0! tracking-[0.48px] inline-flex items-center justify-center gap-2 uppercase whitespace-nowrap rounded-none text-lg font-bold transition-colors focus-visible:outline-hidden focus-visible:ring-1 disabled:pointer-events-none disabled:opacity-50 [&_svg]:pointer-events-none [&_svg]:size-4 [&_svg]:shrink-0", {
4
4
  variants: {
5
5
  variant: {
6
6
  primary: "bg-accent-dark-red text-primary-white button-arrow black-arrow hover:bg-accent-red",
7
7
  "primary-without-icon": "bg-accent-dark-red text-primary-white hover:bg-accent-red",
8
8
  secondary: "bg-primary-blue-600 text-primary-white button-arrow white-arrow hover:bg-primary-blue-400",
9
9
  "secondary-without-icon": "bg-primary-blue-600 text-primary-white hover:bg-primary-blue-400",
10
+ custom: "bg-custom-color-600 text-custom-foreground button-arrow white-arrow hover:bg-custom-color-400",
11
+ "custom-without-icon": "bg-custom-color-600 text-custom-foreground hover:bg-custom-color-400",
10
12
  tertiary: "bg-primary-gray-300 text-primary-gray-700 dark:bg-primary-gray-600 dark:text-primary-white red-arrow hover:bg-primary-gray-400 dark:hover:bg-primary-gray-550",
11
13
  link: "text-primary-gray-700 dark:text-primary-white red-arrow button-arrow",
12
14
  "link-without-icon": "text-primary-gray-700 dark:text-primary-white dark:hover:text-primary-gray-500 hover:text-primary-gray-500",
@@ -30,24 +32,24 @@ const w = x("undp-button m-0! tracking-[0.48px] inline-flex items-center justify
30
32
  size: "base",
31
33
  padding: "base"
32
34
  }
33
- }), k = y.forwardRef((e, r) => {
35
+ }), k = w.forwardRef((e, r) => {
34
36
  const a = m.c(15);
35
- let s, n, o, c, l;
37
+ let s, o, n, c, l;
36
38
  a[0] !== e ? ({
37
39
  className: s,
38
40
  variant: l,
39
41
  size: c,
40
- padding: n,
41
- ...o
42
- } = e, a[0] = e, a[1] = s, a[2] = n, a[3] = o, a[4] = c, a[5] = l) : (s = a[1], n = a[2], o = a[3], c = a[4], l = a[5]);
42
+ padding: o,
43
+ ...n
44
+ } = e, a[0] = e, a[1] = s, a[2] = o, a[3] = n, a[4] = c, a[5] = l) : (s = a[1], o = a[2], n = a[3], c = a[4], l = a[5]);
43
45
  let h;
44
- a[6] !== s || a[7] !== n || a[8] !== c || a[9] !== l ? (h = p(w({
46
+ a[6] !== s || a[7] !== o || a[8] !== c || a[9] !== l ? (h = p(y({
45
47
  variant: l,
46
48
  size: c,
47
- padding: n
48
- }), s), a[6] = s, a[7] = n, a[8] = c, a[9] = l, a[10] = h) : h = a[10];
49
+ padding: o
50
+ }), s), a[6] = s, a[7] = o, a[8] = c, a[9] = l, a[10] = h) : h = a[10];
49
51
  let d;
50
- return a[11] !== o || a[12] !== r || a[13] !== h ? (d = /* @__PURE__ */ g.jsx("button", { ...o, className: h, ref: r }), a[11] = o, a[12] = r, a[13] = h, a[14] = d) : d = a[14], d;
52
+ return a[11] !== n || a[12] !== r || a[13] !== h ? (d = /* @__PURE__ */ g.jsx("button", { ...n, className: h, ref: r }), a[11] = n, a[12] = r, a[13] = h, a[14] = d) : d = a[14], d;
51
53
  });
52
54
  k.displayName = "Button";
53
55
  function v() {
@@ -60,7 +62,7 @@ function v() {
60
62
  /* @__PURE__ */ t.jsx("path", { d: "m9 15 3 3 3-3" })
61
63
  ] }), e[0] = r) : r = e[0], r;
62
64
  }
63
- function j() {
65
+ function b() {
64
66
  const e = i.c(1);
65
67
  let r;
66
68
  return e[0] === /* @__PURE__ */ Symbol.for("react.memo_cache_sentinel") ? (r = /* @__PURE__ */ t.jsxs("svg", { xmlns: "http://www.w3.org/2000/svg", width: "20", height: "20", viewBox: "0 0 24 24", className: "stroke-primary-black dark:stroke-primary-white", fill: "none", strokeWidth: "1.2", strokeLinecap: "round", strokeLinejoin: "round", children: [
@@ -70,7 +72,7 @@ function j() {
70
72
  /* @__PURE__ */ t.jsx("circle", { cx: "9", cy: "9", r: "2" })
71
73
  ] }), e[0] = r) : r = e[0], r;
72
74
  }
73
- function b() {
75
+ function j() {
74
76
  const e = i.c(1);
75
77
  let r;
76
78
  return e[0] === /* @__PURE__ */ Symbol.for("react.memo_cache_sentinel") ? (r = /* @__PURE__ */ t.jsxs("svg", { xmlns: "http://www.w3.org/2000/svg", width: "20", height: "20", viewBox: "0 0 24 24", className: "stroke-primary-black dark:stroke-primary-white", fill: "none", strokeWidth: "1.2", strokeLinecap: "round", strokeLinejoin: "round", children: [
@@ -169,7 +171,7 @@ export {
169
171
  I as A,
170
172
  $ as C,
171
173
  S as F,
172
- j as I,
174
+ b as I,
173
175
  V as P,
174
176
  M as S,
175
177
  _ as X,
@@ -178,7 +180,7 @@ export {
178
180
  B as c,
179
181
  v as d,
180
182
  W as e,
181
- b as f,
182
- k as x
183
+ j as f,
184
+ k as u
183
185
  };
184
- //# sourceMappingURL=index-BQYOuXdl.js.map
186
+ //# sourceMappingURL=index-B-4y_iGB.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index-B-4y_iGB.js","sources":["../node_modules/@undp/design-system-react/dist/Button.js","../src/Components/Icons/index.tsx"],"sourcesContent":["import { j as y } from \"./jsx-runtime-BzflLqGi.js\";\nimport { c as g } from \"./compiler-runtime-Cu50tn6L.js\";\nimport c from \"react\";\nimport { c as d } from \"./index-CHPV5EwG.js\";\nimport { c as b } from \"./utils-D_Pof5Gy.js\";\nconst l = d(\"undp-button cursor-pointer m-0! tracking-[0.48px] inline-flex items-center justify-center gap-2 uppercase whitespace-nowrap rounded-none text-lg font-bold transition-colors focus-visible:outline-hidden focus-visible:ring-1 disabled:pointer-events-none disabled:opacity-50 [&_svg]:pointer-events-none [&_svg]:size-4 [&_svg]:shrink-0\", {\n variants: {\n variant: {\n primary: \"bg-accent-dark-red text-primary-white button-arrow black-arrow hover:bg-accent-red\",\n \"primary-without-icon\": \"bg-accent-dark-red text-primary-white hover:bg-accent-red\",\n secondary: \"bg-primary-blue-600 text-primary-white button-arrow white-arrow hover:bg-primary-blue-400\",\n \"secondary-without-icon\": \"bg-primary-blue-600 text-primary-white hover:bg-primary-blue-400\",\n custom: \"bg-custom-color-600 text-custom-foreground button-arrow white-arrow hover:bg-custom-color-400\",\n \"custom-without-icon\": \"bg-custom-color-600 text-custom-foreground hover:bg-custom-color-400\",\n tertiary: \"bg-primary-gray-300 text-primary-gray-700 dark:bg-primary-gray-600 dark:text-primary-white red-arrow hover:bg-primary-gray-400 dark:hover:bg-primary-gray-550\",\n link: \"text-primary-gray-700 dark:text-primary-white red-arrow button-arrow\",\n \"link-without-icon\": \"text-primary-gray-700 dark:text-primary-white dark:hover:text-primary-gray-500 hover:text-primary-gray-500\",\n outline: \"bg-transparent text-primary-black dark:text-primary-white border-2 border-primary-gray-700 dark:border-primary-gray-100 dark:hover:bg-primary-gray-550 hover:bg-primary-gray-300\",\n icon: \"bg-transparent dark:text-primary-gray-100 text-primary-gray-700 dark:hover:text-primary-gray-500 hover:text-primary-gray-500\"\n },\n size: {\n base: \"leading-none text-base!\",\n xs: \"leading-none text-xs!\",\n sm: \"leading-none text-sm!\",\n xl: \"leading-none text-xl!\"\n },\n padding: {\n base: \"py-4 px-6\",\n sm: \"px-4 py-2\",\n none: \"py-0 px-0\"\n }\n },\n defaultVariants: {\n variant: \"primary\",\n size: \"base\",\n padding: \"base\"\n }\n}), u = c.forwardRef((p, m) => {\n const r = g.c(15);\n let t, e, a, o, i;\n r[0] !== p ? ({\n className: t,\n variant: i,\n size: o,\n padding: e,\n ...a\n } = p, r[0] = p, r[1] = t, r[2] = e, r[3] = a, r[4] = o, r[5] = i) : (t = r[1], e = r[2], a = r[3], o = r[4], i = r[5]);\n let n;\n r[6] !== t || r[7] !== e || r[8] !== o || r[9] !== i ? (n = b(l({\n variant: i,\n size: o,\n padding: e\n }), t), r[6] = t, r[7] = e, r[8] = o, r[9] = i, r[10] = n) : n = r[10];\n let s;\n return r[11] !== a || r[12] !== m || r[13] !== n ? (s = /* @__PURE__ */ y.jsx(\"button\", { ...a, className: n, ref: m }), r[11] = a, r[12] = m, r[13] = n, r[14] = s) : s = r[14], s;\n});\nu.displayName = \"Button\";\nexport {\n u as Button\n};\n//# sourceMappingURL=Button.js.map\n","export function FileDown() {\r\n return (\r\n <svg\r\n xmlns='http://www.w3.org/2000/svg'\r\n width='20'\r\n height='20'\r\n viewBox='0 0 24 24'\r\n className='stroke-primary-black dark:stroke-primary-white'\r\n fill='none'\r\n strokeLinecap='round'\r\n strokeLinejoin='round'\r\n >\r\n <path d='M15 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V7Z' />\r\n <path d='M14 2v4a2 2 0 0 0 2 2h4' />\r\n <path d='M12 18v-6' />\r\n <path d='m9 15 3 3 3-3' />\r\n </svg>\r\n );\r\n}\r\n\r\nexport function ImageDown() {\r\n return (\r\n <svg\r\n xmlns='http://www.w3.org/2000/svg'\r\n width='20'\r\n height='20'\r\n viewBox='0 0 24 24'\r\n className='stroke-primary-black dark:stroke-primary-white'\r\n fill='none'\r\n strokeWidth='1.2'\r\n strokeLinecap='round'\r\n strokeLinejoin='round'\r\n >\r\n <path d='M10.3 21H5a2 2 0 0 1-2-2V5a2 2 0 0 1 2-2h14a2 2 0 0 1 2 2v10l-3.1-3.1a2 2 0 0 0-2.814.014L6 21' />\r\n <path d='m14 19 3 3v-5.5' />\r\n <path d='m17 22 3-3' />\r\n <circle cx='9' cy='9' r='2' />\r\n </svg>\r\n );\r\n}\r\n\r\nexport function Copy() {\r\n return (\r\n <svg\r\n xmlns='http://www.w3.org/2000/svg'\r\n width='20'\r\n height='20'\r\n viewBox='0 0 24 24'\r\n className='stroke-primary-black dark:stroke-primary-white'\r\n fill='none'\r\n strokeWidth='1.2'\r\n strokeLinecap='round'\r\n strokeLinejoin='round'\r\n >\r\n <rect width='14' height='14' x='8' y='8' rx='2' ry='2' />\r\n <path d='M4 16c-1.1 0-2-.9-2-2V4c0-1.1.9-2 2-2h10c1.1 0 2 .9 2 2' />\r\n </svg>\r\n );\r\n}\r\n\r\nexport function X() {\r\n return (\r\n <svg\r\n xmlns='http://www.w3.org/2000/svg'\r\n width='16'\r\n height='16'\r\n viewBox='0 0 24 24'\r\n className='stroke-primary-gray-600 dark:stroke-primary-white'\r\n fill='none'\r\n strokeWidth='2'\r\n strokeLinecap='round'\r\n strokeLinejoin='round'\r\n >\r\n <path d='M18 6 6 18' />\r\n <path d='m6 6 12 12' />\r\n </svg>\r\n );\r\n}\r\n\r\nexport function CircleCheckBig() {\r\n return (\r\n <svg\r\n xmlns='http://www.w3.org/2000/svg'\r\n width='20'\r\n height='20'\r\n viewBox='0 0 24 24'\r\n className='stroke-primary-black dark:stroke-primary-white'\r\n fill='none'\r\n strokeWidth='2'\r\n strokeLinecap='round'\r\n strokeLinejoin='round'\r\n >\r\n <path d='M22 11.08V12a10 10 0 1 1-5.93-9.14' />\r\n <path d='m9 11 3 3L22 4' />\r\n </svg>\r\n );\r\n}\r\n\r\nexport function SortingIcon() {\r\n return (\r\n <svg\r\n xmlns='http://www.w3.org/2000/svg'\r\n width='14'\r\n height='14'\r\n viewBox='0 0 24 24'\r\n className='stroke-primary-black dark:stroke-primary-white'\r\n fill='none'\r\n strokeWidth='1.25'\r\n strokeLinecap='round'\r\n strokeLinejoin='round'\r\n >\r\n <path d='m3 16 4 4 4-4' />\r\n <path d='M7 20V4' />\r\n <path d='m21 8-4-4-4 4' />\r\n <path d='M17 4v16' />\r\n </svg>\r\n );\r\n}\r\nexport function SortingIconDescending() {\r\n return (\r\n <svg\r\n xmlns='http://www.w3.org/2000/svg'\r\n width='14'\r\n height='14'\r\n viewBox='0 0 24 24'\r\n className='stroke-primary-black dark:stroke-primary-white'\r\n fill='none'\r\n strokeWidth='1.25'\r\n strokeLinecap='round'\r\n strokeLinejoin='round'\r\n >\r\n <path d='m3 16 4 4 4-4' />\r\n <path d='M7 20V4' />\r\n <path d='M11 4h10' />\r\n <path d='M11 8h7' />\r\n <path d='M11 12h4' />\r\n </svg>\r\n );\r\n}\r\n\r\nexport function SortingIconAscending() {\r\n return (\r\n <svg\r\n xmlns='http://www.w3.org/2000/svg'\r\n width='14'\r\n height='14'\r\n viewBox='0 0 24 24'\r\n className='stroke-primary-black dark:stroke-primary-white'\r\n fill='none'\r\n strokeWidth='1.25'\r\n strokeLinecap='round'\r\n strokeLinejoin='round'\r\n >\r\n <path d='m3 16 4 4 4-4' />\r\n <path d='M7 20V4' />\r\n <path d='M11 4h4' />\r\n <path d='M11 8h7' />\r\n <path d='M11 12h10' />\r\n </svg>\r\n );\r\n}\r\n\r\nexport function FilterIcon() {\r\n return (\r\n <svg\r\n xmlns='http://www.w3.org/2000/svg'\r\n width='14'\r\n height='14'\r\n viewBox='0 0 24 24'\r\n className='stroke-primary-black dark:stroke-primary-white'\r\n fill='none'\r\n strokeWidth='1.25'\r\n strokeLinecap='round'\r\n strokeLinejoin='round'\r\n >\r\n <polygon points='22 3 2 3 10 12.46 10 19 14 21 14 12.46 22 3' />\r\n </svg>\r\n );\r\n}\r\n\r\nexport function FilterIconApplied() {\r\n return (\r\n <svg width='14' height='14' viewBox='0 0 24 24' fill='none' xmlns='http://www.w3.org/2000/svg'>\r\n <path\r\n d='M16.926 9L14 12.46V21L10 19V12.46L2 3H14.5'\r\n className='stroke-primary-black dark:stroke-primary-white'\r\n fill='none'\r\n strokeWidth='1.25'\r\n strokeLinecap='round'\r\n strokeLinejoin='round'\r\n />\r\n <circle\r\n cx='20'\r\n cy='4'\r\n r='3'\r\n className='stroke-primary-black dark:stroke-primary-white fill-primary-black dark:fill-primary-white'\r\n strokeWidth='1.25'\r\n strokeLinecap='round'\r\n strokeLinejoin='round'\r\n />\r\n </svg>\r\n );\r\n}\r\n\r\nexport function ChevronLeftRight() {\r\n return (\r\n <svg\r\n xmlns='http://www.w3.org/2000/svg'\r\n width='24'\r\n height='24'\r\n viewBox='0 0 24 24'\r\n className='stroke-primary-white dark:stroke-primary-white'\r\n fill='none'\r\n strokeWidth='2'\r\n strokeLinecap='round'\r\n strokeLinejoin='round'\r\n >\r\n <path d='m9 7-5 5 5 5' />\r\n <path d='m15 7 5 5-5 5' />\r\n </svg>\r\n );\r\n}\r\n\r\nexport function ChevronLeft() {\r\n return (\r\n <svg\r\n xmlns='http://www.w3.org/2000/svg'\r\n width='24'\r\n height='24'\r\n viewBox='0 0 24 24'\r\n className='stroke-primary-white dark:stroke-primary-white'\r\n fill='none'\r\n strokeWidth='2'\r\n strokeLinecap='round'\r\n strokeLinejoin='round'\r\n >\r\n <path d='m15 18-6-6 6-6' />\r\n </svg>\r\n );\r\n}\r\n\r\nexport function ChevronRight() {\r\n return (\r\n <svg\r\n xmlns='http://www.w3.org/2000/svg'\r\n width='24'\r\n height='24'\r\n viewBox='0 0 24 24'\r\n className='stroke-primary-black dark:stroke-primary-white'\r\n fill='none'\r\n strokeWidth='2'\r\n strokeLinecap='round'\r\n strokeLinejoin='round'\r\n >\r\n <path d='m9 18 6-6-6-6' />\r\n </svg>\r\n );\r\n}\r\n\r\nexport function MoreHorizontal() {\r\n return (\r\n <svg\r\n xmlns='http://www.w3.org/2000/svg'\r\n width='24'\r\n height='24'\r\n viewBox='0 0 24 24'\r\n className='stroke-primary-black dark:stroke-primary-white'\r\n fill='none'\r\n strokeWidth='2'\r\n strokeLinecap='round'\r\n strokeLinejoin='round'\r\n >\r\n <circle cx='12' cy='12' r='1' />\r\n <circle cx='19' cy='12' r='1' />\r\n <circle cx='5' cy='12' r='1' />\r\n </svg>\r\n );\r\n}\r\n\r\nexport function Play() {\r\n return (\r\n <svg xmlns='http://www.w3.org/2000/svg' width='48' height='48' viewBox='0 0 48 48'>\r\n <circle cx={24} cy={24} r={24} className='fill-primary-gray-300 dark:fill-primary-gray-600' />\r\n <polygon\r\n points='6 3 20 12 6 21 6 3'\r\n className='fill-accent-dark-red dark:fill-accent-red'\r\n transform='translate(10,10) scale(1.25)'\r\n />\r\n </svg>\r\n );\r\n}\r\n\r\nexport function Pause() {\r\n return (\r\n <svg xmlns='http://www.w3.org/2000/svg' width='48' height='48' viewBox='0 0 48 48'>\r\n <circle cx={24} cy={24} r={24} className='fill-primary-gray-300 dark:fill-primary-gray-600' />\r\n <rect\r\n x='14'\r\n y='4'\r\n width='4'\r\n height='16'\r\n rx='1'\r\n className='fill-accent-dark-red dark:fill-accent-red'\r\n transform='translate(10,10) scale(1.25)'\r\n />\r\n <rect\r\n x='6'\r\n y='4'\r\n width='4'\r\n height='16'\r\n rx='1'\r\n className='fill-accent-dark-red dark:fill-accent-red'\r\n transform='translate(10,10) scale(1.25)'\r\n />\r\n </svg>\r\n );\r\n}\r\n\r\nexport function Alert() {\r\n return (\r\n <svg\r\n xmlns='http://www.w3.org/2000/svg'\r\n width='48'\r\n height='48'\r\n viewBox='0 0 24 24'\r\n fill='none'\r\n stroke='currentColor'\r\n strokeWidth='1.5'\r\n strokeLinecap='round'\r\n strokeLinejoin='round'\r\n className='stroke-primary-gray-500 dark:stroke-primary-gray-550'\r\n >\r\n <path d='m21.73 18-8-14a2 2 0 0 0-3.48 0l-8 14A2 2 0 0 0 4 21h16a2 2 0 0 0 1.73-3' />\r\n <path d='M12 9v4' />\r\n <path d='M12 17h.01' />\r\n </svg>\r\n );\r\n}\r\n"],"names":["l","d","u","c","p","m","r","g","t","e","a","o","i","n","b","s","y","FileDown","$","_c","t0","Symbol","for","jsx","ImageDown","Copy","X","SortingIcon","SortingIconDescending","SortingIconAscending","FilterIcon","FilterIconApplied","ChevronLeftRight","Play","jsxs","Pause","Alert"],"mappings":"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","x_google_ignoreList":[0]}
@@ -2,7 +2,7 @@ import { c as Ge, j as a, m as Te } from "./index-CHPV5EwG-DecW7_qr.js";
2
2
  import { useRef as Ne, useState as te, useEffect as We } from "react";
3
3
  import { o as Fe } from "./index-BZQYSqar.js";
4
4
  import { w as Xe } from "./Spinner--r2RrJV8.js";
5
- import { j as Be } from "./Typography-hWfh3H0J.js";
5
+ import { _ as Be } from "./Typography-iR8PEgdt.js";
6
6
  import { T as Ye } from "./Tooltip-BRnAz2Gv.js";
7
7
  import { n as Ae } from "./numberFormattingFunction-14YCbkN2.js";
8
8
  import { g as Pe } from "./getTextColorBasedOnBgColor-CDY808zi.js";
@@ -14,7 +14,7 @@ import { f as Ue, b as Je, a as Ke, c as Qe, d as Ze } from "./y-BqfogMAB.js";
14
14
  import { GraphFooter as _e } from "./GraphFooter.js";
15
15
  import { GraphHeader as et } from "./GraphHeader.js";
16
16
  import { ColorLegendWithMouseOver as tt } from "./ColorLegendWithMouseOver.js";
17
- import { E as ot } from "./EmptyState-tZBErBKF.js";
17
+ import { E as ot } from "./EmptyState-Pj-emXt5.js";
18
18
  import { u as He } from "./uniqBy-BHy4I8PK.js";
19
19
  import { a as it, G as nt } from "./GraphContainer-CF6ws3pd.js";
20
20
  function ze(o, e) {
@@ -334,4 +334,4 @@ export {
334
334
  Xt as C,
335
335
  ze as e
336
336
  };
337
- //# sourceMappingURL=index-D5ihtaJJ.js.map
337
+ //# sourceMappingURL=index-BE-lvE4c.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index-D5ihtaJJ.js","sources":["../node_modules/d3-array/src/extent.js","../src/Components/Graphs/CirclePackingGraph/Graph.tsx","../src/Components/Graphs/CirclePackingGraph/getMaxCircleRadius.ts","../src/Components/Graphs/CirclePackingGraph/index.tsx"],"sourcesContent":["export default function extent(values, valueof) {\n let min;\n let max;\n if (valueof === undefined) {\n for (const value of values) {\n if (value != null) {\n if (min === undefined) {\n if (value >= value) min = max = value;\n } else {\n if (min > value) min = value;\n if (max < value) max = value;\n }\n }\n }\n } else {\n let index = -1;\n for (let value of values) {\n if ((value = valueof(value, ++index, values)) != null) {\n if (min === undefined) {\n if (value >= value) min = max = value;\n } else {\n if (min > value) min = value;\n if (max < value) max = value;\n }\n }\n }\n }\n return [min, max];\n}\n","import { useEffect, useState, useRef } from 'react';\r\nimport { forceCollide, forceManyBody, forceSimulation, forceX, forceY } from 'd3-force';\r\nimport orderBy from 'lodash.orderby';\r\nimport { scaleSqrt } from 'd3-scale';\r\nimport { extent } from 'd3-array';\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 { ClassNameObject, StyleObject, TreeMapDataType } from '@/Types';\r\nimport { Tooltip } from '@/Components/Elements/Tooltip';\r\nimport { numberFormattingFunction } from '@/Utils/numberFormattingFunction';\r\nimport { getTextColorBasedOnBgColor } from '@/Utils/getTextColorBasedOnBgColor';\r\nimport { Colors } from '@/Components/ColorPalette';\r\nimport { checkIfNullOrUndefined } from '@/Utils/checkIfNullOrUndefined';\r\nimport { DetailsModal } from '@/Components/Elements/DetailsModal';\r\n\r\ninterface Props {\r\n data: TreeMapDataType[];\r\n colors: string[];\r\n colorDomain: string[];\r\n leftMargin: number;\r\n rightMargin: number;\r\n topMargin: number;\r\n bottomMargin: number;\r\n showLabels: boolean;\r\n showValues: boolean;\r\n width: number;\r\n height: number;\r\n suffix: string;\r\n prefix: string;\r\n selectedColor?: 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 highlightedDataPoints: (string | number)[];\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseClick?: (_d: any) => void;\r\n theme: 'light' | 'dark';\r\n maxRadiusValue?: number;\r\n radius: number;\r\n resetSelectionOnDoubleClick: boolean;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n detailsOnClick?: string | ((_d: any) => React.ReactNode);\r\n styles?: StyleObject;\r\n classNames?: ClassNameObject;\r\n dimmedOpacity: number;\r\n precision: number;\r\n}\r\n\r\ninterface TreeMapDataTypeForBubbleChart extends TreeMapDataType {\r\n x: number;\r\n y: number;\r\n vx: number;\r\n vy: number;\r\n}\r\n\r\nexport const Graph = (props: Props) => {\r\n const {\r\n data,\r\n colors,\r\n leftMargin,\r\n width,\r\n height,\r\n colorDomain,\r\n selectedColor,\r\n rightMargin,\r\n topMargin,\r\n bottomMargin,\r\n showLabels,\r\n tooltip,\r\n onSeriesMouseOver,\r\n showValues,\r\n suffix,\r\n prefix,\r\n highlightedDataPoints,\r\n onSeriesMouseClick,\r\n maxRadiusValue,\r\n radius,\r\n resetSelectionOnDoubleClick,\r\n detailsOnClick,\r\n styles,\r\n classNames,\r\n dimmedOpacity,\r\n precision,\r\n } = props;\r\n const svgRef = useRef(null);\r\n\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const [mouseOverData, setMouseOverData] = useState<any>(undefined);\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const [mouseClickData, setMouseClickData] = useState<any>(undefined);\r\n const [viewPortDimensions, setViewPortDimensions] = useState<\r\n [number, number, number, number] | undefined\r\n >(undefined);\r\n const [eventX, setEventX] = useState<number | undefined>(undefined);\r\n const [eventY, setEventY] = useState<number | undefined>(undefined);\r\n const [finalData, setFinalData] = useState<TreeMapDataTypeForBubbleChart[] | null>(null);\r\n\r\n const margin = {\r\n top: topMargin,\r\n bottom: bottomMargin,\r\n left: leftMargin,\r\n right: rightMargin,\r\n };\r\n\r\n const graphWidth = width - margin.left - margin.right;\r\n const graphHeight = height - margin.top - margin.bottom;\r\n\r\n // Memoize data ordering and radius scale\r\n const dataOrdered =\r\n data.filter(d => !checkIfNullOrUndefined(d.size)).length === 0\r\n ? data\r\n : orderBy(\r\n data.filter(d => !checkIfNullOrUndefined(d.size)),\r\n 'radius',\r\n 'asc',\r\n );\r\n\r\n const radiusScale =\r\n data.filter(d => d.size === undefined || d.size === 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.size).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\r\n // Memoize simulation setup\r\n useEffect(() => {\r\n const setupSimulation = () => {\r\n const dataTemp = dataOrdered.map(d => ({ ...d, ...(d.data && { data: { ...d.data } }) }));\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const simulation = forceSimulation(dataTemp as any)\r\n .force('y', forceY(_d => graphHeight / 2).strength(1))\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.size || 0) + 1 : radius + 1)),\r\n )\r\n .force('charge', forceManyBody().strength(-15))\r\n .alphaDecay(0.05)\r\n .tick(10000);\r\n\r\n simulation\r\n .on('tick', () => {\r\n setFinalData(dataTemp as TreeMapDataTypeForBubbleChart[]);\r\n })\r\n .on('end', () => {\r\n setFinalData(dataTemp as TreeMapDataTypeForBubbleChart[]);\r\n const xMinExtent =\r\n extent(\r\n dataTemp as TreeMapDataTypeForBubbleChart[],\r\n d => d.x - (radiusScale ? radiusScale(d.size || 0) + 1 : radius + 1),\r\n )[0] || 0;\r\n const yMinExtent =\r\n extent(\r\n dataTemp as TreeMapDataTypeForBubbleChart[],\r\n d => d.y - (radiusScale ? radiusScale(d.size || 0) + 1 : radius + 1),\r\n )[0] || 0;\r\n const xMaxExtent =\r\n extent(\r\n dataTemp as TreeMapDataTypeForBubbleChart[],\r\n d => d.x + (radiusScale ? radiusScale(d.size || 0) + 1 : radius + 1),\r\n )[1] || 0;\r\n const yMaxExtent =\r\n extent(\r\n dataTemp as TreeMapDataTypeForBubbleChart[],\r\n d => d.y + (radiusScale ? radiusScale(d.size || 0) + 1 : radius + 1),\r\n )[1] || 0;\r\n setViewPortDimensions([\r\n xMinExtent,\r\n yMinExtent,\r\n xMinExtent < 0 ? xMaxExtent - xMinExtent : xMaxExtent,\r\n yMinExtent < 0 ? yMaxExtent - yMinExtent : yMaxExtent,\r\n ]);\r\n });\r\n };\r\n\r\n setupSimulation();\r\n }, [data, radius, graphHeight, graphWidth, maxRadiusValue, dataOrdered, radiusScale]);\r\n\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const handleMouseEnter = (event: any, d: any) => {\r\n setMouseOverData(d);\r\n setEventY(event.clientY);\r\n setEventX(event.clientX);\r\n onSeriesMouseOver?.(d);\r\n };\r\n\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const handleMouseMove = (event: any, d: any) => {\r\n setMouseOverData(d);\r\n setEventY(event.clientY);\r\n setEventX(event.clientX);\r\n };\r\n\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const handleClick = (d: any) => {\r\n if (onSeriesMouseClick || detailsOnClick) {\r\n if (mouseClickData === d.label && resetSelectionOnDoubleClick) {\r\n setMouseClickData(undefined);\r\n onSeriesMouseClick?.(undefined);\r\n } else {\r\n setMouseClickData(d.label);\r\n onSeriesMouseClick?.(d);\r\n }\r\n }\r\n };\r\n\r\n const handleMouseLeave = () => {\r\n setMouseOverData(undefined);\r\n setEventX(undefined);\r\n setEventY(undefined);\r\n onSeriesMouseOver?.(undefined);\r\n };\r\n\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const getCircleColor = (d: any) =>\r\n data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)];\r\n\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const getOpacity = (d: any) =>\r\n selectedColor\r\n ? d.color\r\n ? colors[colorDomain.indexOf(d.color)] === selectedColor\r\n ? 1\r\n : dimmedOpacity\r\n : dimmedOpacity\r\n : highlightedDataPoints.length !== 0\r\n ? highlightedDataPoints.indexOf(d.label) !== -1\r\n ? 0.85\r\n : dimmedOpacity\r\n : 0.85;\r\n\r\n // Render loading state\r\n if (!finalData) {\r\n return (\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 }\r\n if (viewPortDimensions) {\r\n return (\r\n <>\r\n <svg\r\n width={`${width}px`}\r\n height={`${height}px`}\r\n viewBox={`${viewPortDimensions[0] > 0 ? 0 : viewPortDimensions[0]} ${\r\n viewPortDimensions[1] > 0 ? 0 : viewPortDimensions[1]\r\n } ${width < viewPortDimensions[2] ? viewPortDimensions[2] : width} ${\r\n height < viewPortDimensions[3] ? viewPortDimensions[3] : height\r\n }`}\r\n direction='ltr'\r\n ref={svgRef}\r\n >\r\n <g transform={`translate(${margin.left},${margin.top})`}>\r\n {finalData.map(d => {\r\n const circleColor = getCircleColor(d);\r\n const opacity = getOpacity(d);\r\n const bubbleRadius = radiusScale ? radiusScale(d.size || 0) : radius;\r\n const showLabel = bubbleRadius > 20 && (showLabels || showValues);\r\n return (\r\n <g\r\n className='undp-viz-g-with-hover'\r\n key={d.label}\r\n opacity={opacity}\r\n transform={`translate(${d.x},${d.y})`}\r\n onMouseEnter={event => handleMouseEnter(event, d)}\r\n onMouseMove={event => handleMouseMove(event, d)}\r\n onClick={() => handleClick(d)}\r\n onMouseLeave={handleMouseLeave}\r\n >\r\n <circle cx={0} cy={0} r={bubbleRadius} fill={circleColor} />\r\n {(showLabel || showValues) &&\r\n d.size !== undefined &&\r\n d.size !== null &&\r\n bubbleRadius >= 15 && (\r\n <g>\r\n <foreignObject\r\n y={0 - bubbleRadius}\r\n x={0 - bubbleRadius}\r\n width={2 * bubbleRadius}\r\n height={2 * bubbleRadius}\r\n >\r\n <div\r\n className='flex flex-col justify-center items-center h-full py-0 px-3'\r\n style={{\r\n display: 'flex',\r\n flexDirection: 'column',\r\n justifyContent: 'center',\r\n alignItems: 'center',\r\n height: '100%',\r\n padding: '0 0.75rem',\r\n }}\r\n >\r\n {showLabels && (\r\n <P\r\n className={cn(\r\n 'text-center leading-[1.25] overflow-hidden m-0 circle-packing-label',\r\n classNames?.graphObjectValues,\r\n )}\r\n marginBottom='none'\r\n style={{\r\n fontSize: `${Math.min(\r\n Math.max(Math.round(bubbleRadius / 4), 12),\r\n Math.max(\r\n Math.round((bubbleRadius * 12) / `${d.label}`.length),\r\n 12,\r\n ),\r\n 14,\r\n )}px`,\r\n WebkitLineClamp:\r\n bubbleRadius * 2 < 60\r\n ? 1\r\n : bubbleRadius * 2 < 75\r\n ? 2\r\n : bubbleRadius * 2 < 100\r\n ? 3\r\n : undefined,\r\n display: '-webkit-box',\r\n WebkitBoxOrient: 'vertical',\r\n color: getTextColorBasedOnBgColor(circleColor),\r\n hyphens: 'auto',\r\n ...(styles?.graphObjectValues || {}),\r\n }}\r\n >\r\n {d.label}\r\n </P>\r\n )}\r\n {showValues && (\r\n <P\r\n className='text-center font-bold leading-[1.25] w-full m-0 circle-packing-value'\r\n marginBottom='none'\r\n style={{\r\n fontSize: `${Math.min(\r\n Math.max(Math.round(bubbleRadius / 4), 14),\r\n 14,\r\n )}px`,\r\n color: getTextColorBasedOnBgColor(circleColor),\r\n }}\r\n >\r\n {numberFormattingFunction(d.size, 'NA', precision, prefix, suffix)}\r\n </P>\r\n )}\r\n </div>\r\n </foreignObject>\r\n </g>\r\n )}\r\n </g>\r\n );\r\n })}\r\n </g>\r\n </svg>\r\n {mouseOverData && tooltip && eventX && eventY && (\r\n <Tooltip\r\n data={mouseOverData}\r\n body={tooltip}\r\n xPos={eventX}\r\n yPos={eventY}\r\n backgroundStyle={styles?.tooltip}\r\n className={classNames?.tooltip}\r\n />\r\n )}\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 return null;\r\n};\r\n","export function getMaxCircleRadius(\r\n values: (number | undefined | null)[],\r\n width: number,\r\n height: number,\r\n) {\r\n const filteredValues = values.filter(d => d !== undefined && d !== null);\r\n const containerRadius = Math.min(width, height) / 2;\r\n const totalValue = filteredValues.reduce((sum, v) => sum + v, 0);\r\n const maxValue = Math.max(...filteredValues);\r\n const getPackingEfficiency = (n: number) => {\r\n if (n <= 5) return 0.9;\r\n if (n <= 10) return 0.85;\r\n if (n <= 20) return 0.8;\r\n return 0.7;\r\n };\r\n const getEfficiencyBecauseOfContainerRadius = (r: number) => {\r\n if (r <= 200) return 0.85;\r\n if (r <= 250) return 0.95;\r\n return 1;\r\n };\r\n return (\r\n containerRadius *\r\n Math.sqrt(maxValue / totalValue) *\r\n getEfficiencyBecauseOfContainerRadius(containerRadius) *\r\n getPackingEfficiency(filteredValues.length)\r\n );\r\n}\r\n","import { useState, useRef, useEffect } from 'react';\r\n\r\nimport { Graph } from './Graph';\r\nimport { getMaxCircleRadius } from './getMaxCircleRadius';\r\n\r\nimport { Languages, SourcesDataType, StyleObject, ClassNameObject, TreeMapDataType } from '@/Types';\r\nimport { GraphFooter } from '@/Components/Elements/GraphFooter';\r\nimport { GraphHeader } from '@/Components/Elements/GraphHeader';\r\nimport { ColorLegendWithMouseOver } from '@/Components/Elements/ColorLegendWithMouseOver';\r\nimport { Colors } from '@/Components/ColorPalette';\r\nimport { EmptyState } from '@/Components/Elements/EmptyState';\r\nimport { uniqBy } from '@/Utils/uniqBy';\r\nimport { GraphArea, GraphContainer } from '@/Components/Elements/GraphContainer';\r\n\r\ninterface Props {\r\n // Data\r\n /** Array of data objects */\r\n data: TreeMapDataType[];\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 mapped to the radius chart */\r\n maxRadiusValue?: number;\r\n\r\n // Graph Parameters\r\n /** Maximum radius of the circle */\r\n radius?: number;\r\n /** Toggle visibility of labels */\r\n showLabels?: boolean;\r\n /** Toggle visibility of values */\r\n showValues?: 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 /** 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 /** Specifies the number of decimal places to display in the value. */\r\n precision?: number;\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 CirclePackingGraph(props: Props) {\r\n const {\r\n data,\r\n graphTitle,\r\n colors,\r\n suffix = '',\r\n sources,\r\n prefix = '',\r\n graphDescription,\r\n leftMargin = 0,\r\n rightMargin = 0,\r\n height,\r\n width,\r\n footNote,\r\n colorDomain,\r\n colorLegendTitle,\r\n padding,\r\n backgroundColor = false,\r\n topMargin = 0,\r\n bottomMargin = 0,\r\n showLabels = true,\r\n relativeHeight,\r\n tooltip,\r\n onSeriesMouseOver,\r\n showColorScale = true,\r\n showValues,\r\n graphID,\r\n highlightedDataPoints = [],\r\n onSeriesMouseClick,\r\n graphDownload = false,\r\n dataDownload = false,\r\n language = 'en',\r\n showNAColor,\r\n minHeight = 0,\r\n theme = 'light',\r\n ariaLabel,\r\n radius,\r\n maxRadiusValue,\r\n resetSelectionOnDoubleClick = true,\r\n detailsOnClick,\r\n styles,\r\n classNames,\r\n dimmedOpacity = 0.3,\r\n precision = 2,\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 const graphDiv = useRef<HTMLDivElement>(null);\r\n const graphParentDiv = useRef<HTMLDivElement>(null);\r\n useEffect(() => {\r\n const resizeObserver = new ResizeObserver(entries => {\r\n setSvgWidth(entries[0].target.clientWidth || 620);\r\n setSvgHeight(entries[0].target.clientHeight || 480);\r\n });\r\n if (graphDiv.current) {\r\n resizeObserver.observe(graphDiv.current);\r\n }\r\n return () => resizeObserver.disconnect();\r\n }, []);\r\n return (\r\n <GraphContainer\r\n className={classNames?.graphContainer}\r\n style={styles?.graphContainer}\r\n id={graphID}\r\n ref={graphParentDiv}\r\n aria-label={ariaLabel}\r\n backgroundColor={backgroundColor}\r\n theme={theme}\r\n language={language}\r\n minHeight={minHeight}\r\n width={width}\r\n height={height}\r\n relativeHeight={relativeHeight}\r\n padding={padding}\r\n >\r\n {graphTitle || graphDescription || graphDownload || dataDownload ? (\r\n <GraphHeader\r\n styles={{\r\n title: styles?.title,\r\n description: styles?.description,\r\n }}\r\n classNames={{\r\n title: classNames?.title,\r\n description: classNames?.description,\r\n }}\r\n graphTitle={graphTitle}\r\n graphDescription={graphDescription}\r\n width={width}\r\n graphDownload={graphDownload ? graphParentDiv : undefined}\r\n dataDownload={\r\n dataDownload\r\n ? data.map(d => d.data).filter(d => d !== undefined).length > 0\r\n ? data.map(d => d.data).filter(d => d !== undefined)\r\n : data.filter(d => d !== undefined)\r\n : null\r\n }\r\n />\r\n ) : null}\r\n {showColorScale && data.filter(el => el.color).length !== 0 && data.length > 0 ? (\r\n <ColorLegendWithMouseOver\r\n width={width}\r\n colorLegendTitle={colorLegendTitle}\r\n colors={(colors as string[] | undefined) || Colors[theme].categoricalColors.colors}\r\n colorDomain={colorDomain || (uniqBy(data, 'color', true) as string[])}\r\n setSelectedColor={setSelectedColor}\r\n showNAColor={showNAColor === undefined || showNAColor === null ? true : showNAColor}\r\n isCenter\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 <Graph\r\n data={data}\r\n colors={\r\n data.filter(el => el.color).length === 0\r\n ? colors\r\n ? [colors as string]\r\n : [Colors.primaryColors['blue-600']]\r\n : (colors as string[] | undefined) || Colors[theme].categoricalColors.colors\r\n }\r\n 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 height={svgHeight}\r\n leftMargin={leftMargin}\r\n rightMargin={rightMargin}\r\n topMargin={topMargin}\r\n bottomMargin={bottomMargin}\r\n showLabels={showLabels}\r\n showValues={\r\n showValues !== false\r\n ? data.filter(el => el.size).length !== 0\r\n : (showValues as boolean)\r\n }\r\n selectedColor={selectedColor}\r\n suffix={suffix}\r\n prefix={prefix}\r\n tooltip={tooltip}\r\n onSeriesMouseOver={onSeriesMouseOver}\r\n highlightedDataPoints={highlightedDataPoints}\r\n onSeriesMouseClick={onSeriesMouseClick}\r\n theme={theme}\r\n radius={\r\n !radius\r\n ? getMaxCircleRadius(\r\n data.map(d => d.size),\r\n svgWidth,\r\n svgHeight,\r\n )\r\n : radius\r\n }\r\n maxRadiusValue={maxRadiusValue}\r\n resetSelectionOnDoubleClick={resetSelectionOnDoubleClick}\r\n detailsOnClick={detailsOnClick}\r\n styles={styles}\r\n classNames={classNames}\r\n dimmedOpacity={dimmedOpacity}\r\n precision={precision}\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":["extent","values","valueof","min","max","value","index","Graph","props","$","_c","data","colors","leftMargin","width","height","colorDomain","selectedColor","rightMargin","topMargin","bottomMargin","showLabels","tooltip","onSeriesMouseOver","showValues","suffix","prefix","highlightedDataPoints","onSeriesMouseClick","maxRadiusValue","radius","resetSelectionOnDoubleClick","detailsOnClick","styles","classNames","dimmedOpacity","precision","svgRef","useRef","mouseOverData","setMouseOverData","useState","undefined","mouseClickData","setMouseClickData","viewPortDimensions","setViewPortDimensions","eventX","setEventX","eventY","setEventY","finalData","setFinalData","t0","top","bottom","left","right","margin","graphWidth","graphHeight","t1","filter","_temp","length","orderBy","_temp2","dataOrdered","t2","_temp3","scaleSqrt","domain","checkIfNullOrUndefined","Math","map","_temp4","_temp5","range","nice","radiusScale","t3","setupSimulation","dataTemp","_temp6","simulation","forceSimulation","force","forceY","_d","strength","forceX","_d_0","forceCollide","d_5","d","size","forceManyBody","alphaDecay","tick","on","xMinExtent","d_6","x","yMinExtent","d_7","y","xMaxExtent","d_8","yMaxExtent","d_9","t4","useEffect","t5","event","d_10","clientY","clientX","handleMouseEnter","t6","Symbol","for","event_0","d_11","handleMouseMove","t7","d_12","label","handleClick","t8","handleMouseLeave","t9","d_13","_temp7","color","indexOf","Colors","gray","getCircleColor","t10","d_14","getOpacity","t11","t12","t13","t14","jsx","Spinner","t15","graphObjectValues","t16","d_15","circleColor","opacity","bubbleRadius","showLabel","jsxs","event_1","event_2","display","flexDirection","justifyContent","alignItems","padding","P","cn","fontSize","round","WebkitLineClamp","WebkitBoxOrient","getTextColorBasedOnBgColor","hyphens","numberFormattingFunction","t17","t18","Tooltip","t19","modal","DetailsModal","t20","Fragment","d_0","d_3","d_1","d_2","d_4","el","getMaxCircleRadius","filteredValues","containerRadius","totalValue","reduce","sum","v","maxValue","getPackingEfficiency","n","getEfficiencyBecauseOfContainerRadius","r","sqrt","CirclePackingGraph","graphTitle","sources","graphDescription","footNote","colorLegendTitle","backgroundColor","relativeHeight","showColorScale","graphID","graphDownload","dataDownload","language","showNAColor","minHeight","theme","ariaLabel","svgWidth","setSvgWidth","svgHeight","setSvgHeight","setSelectedColor","graphDiv","graphParentDiv","resizeObserver","ResizeObserver","entries","target","clientWidth","clientHeight","current","observe","disconnect","t21","graphContainer","t22","t23","description","title","GraphHeader","t24","colorLegend","ColorLegendWithMouseOver","categoricalColors","uniqBy","t25","EmptyState","t26","primaryColors","_temp8","_temp9","_temp0","t27","GraphArea","t28","footnote","source","GraphFooter","t29","GraphContainer","el_2","el_1","el_0"],"mappings":"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","x_google_ignoreList":[0]}
1
+ {"version":3,"file":"index-BE-lvE4c.js","sources":["../node_modules/d3-array/src/extent.js","../src/Components/Graphs/CirclePackingGraph/Graph.tsx","../src/Components/Graphs/CirclePackingGraph/getMaxCircleRadius.ts","../src/Components/Graphs/CirclePackingGraph/index.tsx"],"sourcesContent":["export default function extent(values, valueof) {\n let min;\n let max;\n if (valueof === undefined) {\n for (const value of values) {\n if (value != null) {\n if (min === undefined) {\n if (value >= value) min = max = value;\n } else {\n if (min > value) min = value;\n if (max < value) max = value;\n }\n }\n }\n } else {\n let index = -1;\n for (let value of values) {\n if ((value = valueof(value, ++index, values)) != null) {\n if (min === undefined) {\n if (value >= value) min = max = value;\n } else {\n if (min > value) min = value;\n if (max < value) max = value;\n }\n }\n }\n }\n return [min, max];\n}\n","import { useEffect, useState, useRef } from 'react';\r\nimport { forceCollide, forceManyBody, forceSimulation, forceX, forceY } from 'd3-force';\r\nimport orderBy from 'lodash.orderby';\r\nimport { scaleSqrt } from 'd3-scale';\r\nimport { extent } from 'd3-array';\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 { ClassNameObject, StyleObject, TreeMapDataType } from '@/Types';\r\nimport { Tooltip } from '@/Components/Elements/Tooltip';\r\nimport { numberFormattingFunction } from '@/Utils/numberFormattingFunction';\r\nimport { getTextColorBasedOnBgColor } from '@/Utils/getTextColorBasedOnBgColor';\r\nimport { Colors } from '@/Components/ColorPalette';\r\nimport { checkIfNullOrUndefined } from '@/Utils/checkIfNullOrUndefined';\r\nimport { DetailsModal } from '@/Components/Elements/DetailsModal';\r\n\r\ninterface Props {\r\n data: TreeMapDataType[];\r\n colors: string[];\r\n colorDomain: string[];\r\n leftMargin: number;\r\n rightMargin: number;\r\n topMargin: number;\r\n bottomMargin: number;\r\n showLabels: boolean;\r\n showValues: boolean;\r\n width: number;\r\n height: number;\r\n suffix: string;\r\n prefix: string;\r\n selectedColor?: 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 highlightedDataPoints: (string | number)[];\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseClick?: (_d: any) => void;\r\n theme: 'light' | 'dark';\r\n maxRadiusValue?: number;\r\n radius: number;\r\n resetSelectionOnDoubleClick: boolean;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n detailsOnClick?: string | ((_d: any) => React.ReactNode);\r\n styles?: StyleObject;\r\n classNames?: ClassNameObject;\r\n dimmedOpacity: number;\r\n precision: number;\r\n}\r\n\r\ninterface TreeMapDataTypeForBubbleChart extends TreeMapDataType {\r\n x: number;\r\n y: number;\r\n vx: number;\r\n vy: number;\r\n}\r\n\r\nexport const Graph = (props: Props) => {\r\n const {\r\n data,\r\n colors,\r\n leftMargin,\r\n width,\r\n height,\r\n colorDomain,\r\n selectedColor,\r\n rightMargin,\r\n topMargin,\r\n bottomMargin,\r\n showLabels,\r\n tooltip,\r\n onSeriesMouseOver,\r\n showValues,\r\n suffix,\r\n prefix,\r\n highlightedDataPoints,\r\n onSeriesMouseClick,\r\n maxRadiusValue,\r\n radius,\r\n resetSelectionOnDoubleClick,\r\n detailsOnClick,\r\n styles,\r\n classNames,\r\n dimmedOpacity,\r\n precision,\r\n } = props;\r\n const svgRef = useRef(null);\r\n\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const [mouseOverData, setMouseOverData] = useState<any>(undefined);\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const [mouseClickData, setMouseClickData] = useState<any>(undefined);\r\n const [viewPortDimensions, setViewPortDimensions] = useState<\r\n [number, number, number, number] | undefined\r\n >(undefined);\r\n const [eventX, setEventX] = useState<number | undefined>(undefined);\r\n const [eventY, setEventY] = useState<number | undefined>(undefined);\r\n const [finalData, setFinalData] = useState<TreeMapDataTypeForBubbleChart[] | null>(null);\r\n\r\n const margin = {\r\n top: topMargin,\r\n bottom: bottomMargin,\r\n left: leftMargin,\r\n right: rightMargin,\r\n };\r\n\r\n const graphWidth = width - margin.left - margin.right;\r\n const graphHeight = height - margin.top - margin.bottom;\r\n\r\n // Memoize data ordering and radius scale\r\n const dataOrdered =\r\n data.filter(d => !checkIfNullOrUndefined(d.size)).length === 0\r\n ? data\r\n : orderBy(\r\n data.filter(d => !checkIfNullOrUndefined(d.size)),\r\n 'radius',\r\n 'asc',\r\n );\r\n\r\n const radiusScale =\r\n data.filter(d => d.size === undefined || d.size === 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.size).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\r\n // Memoize simulation setup\r\n useEffect(() => {\r\n const setupSimulation = () => {\r\n const dataTemp = dataOrdered.map(d => ({ ...d, ...(d.data && { data: { ...d.data } }) }));\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const simulation = forceSimulation(dataTemp as any)\r\n .force('y', forceY(_d => graphHeight / 2).strength(1))\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.size || 0) + 1 : radius + 1)),\r\n )\r\n .force('charge', forceManyBody().strength(-15))\r\n .alphaDecay(0.05)\r\n .tick(10000);\r\n\r\n simulation\r\n .on('tick', () => {\r\n setFinalData(dataTemp as TreeMapDataTypeForBubbleChart[]);\r\n })\r\n .on('end', () => {\r\n setFinalData(dataTemp as TreeMapDataTypeForBubbleChart[]);\r\n const xMinExtent =\r\n extent(\r\n dataTemp as TreeMapDataTypeForBubbleChart[],\r\n d => d.x - (radiusScale ? radiusScale(d.size || 0) + 1 : radius + 1),\r\n )[0] || 0;\r\n const yMinExtent =\r\n extent(\r\n dataTemp as TreeMapDataTypeForBubbleChart[],\r\n d => d.y - (radiusScale ? radiusScale(d.size || 0) + 1 : radius + 1),\r\n )[0] || 0;\r\n const xMaxExtent =\r\n extent(\r\n dataTemp as TreeMapDataTypeForBubbleChart[],\r\n d => d.x + (radiusScale ? radiusScale(d.size || 0) + 1 : radius + 1),\r\n )[1] || 0;\r\n const yMaxExtent =\r\n extent(\r\n dataTemp as TreeMapDataTypeForBubbleChart[],\r\n d => d.y + (radiusScale ? radiusScale(d.size || 0) + 1 : radius + 1),\r\n )[1] || 0;\r\n setViewPortDimensions([\r\n xMinExtent,\r\n yMinExtent,\r\n xMinExtent < 0 ? xMaxExtent - xMinExtent : xMaxExtent,\r\n yMinExtent < 0 ? yMaxExtent - yMinExtent : yMaxExtent,\r\n ]);\r\n });\r\n };\r\n\r\n setupSimulation();\r\n }, [data, radius, graphHeight, graphWidth, maxRadiusValue, dataOrdered, radiusScale]);\r\n\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const handleMouseEnter = (event: any, d: any) => {\r\n setMouseOverData(d);\r\n setEventY(event.clientY);\r\n setEventX(event.clientX);\r\n onSeriesMouseOver?.(d);\r\n };\r\n\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const handleMouseMove = (event: any, d: any) => {\r\n setMouseOverData(d);\r\n setEventY(event.clientY);\r\n setEventX(event.clientX);\r\n };\r\n\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const handleClick = (d: any) => {\r\n if (onSeriesMouseClick || detailsOnClick) {\r\n if (mouseClickData === d.label && resetSelectionOnDoubleClick) {\r\n setMouseClickData(undefined);\r\n onSeriesMouseClick?.(undefined);\r\n } else {\r\n setMouseClickData(d.label);\r\n onSeriesMouseClick?.(d);\r\n }\r\n }\r\n };\r\n\r\n const handleMouseLeave = () => {\r\n setMouseOverData(undefined);\r\n setEventX(undefined);\r\n setEventY(undefined);\r\n onSeriesMouseOver?.(undefined);\r\n };\r\n\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const getCircleColor = (d: any) =>\r\n data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)];\r\n\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const getOpacity = (d: any) =>\r\n selectedColor\r\n ? d.color\r\n ? colors[colorDomain.indexOf(d.color)] === selectedColor\r\n ? 1\r\n : dimmedOpacity\r\n : dimmedOpacity\r\n : highlightedDataPoints.length !== 0\r\n ? highlightedDataPoints.indexOf(d.label) !== -1\r\n ? 0.85\r\n : dimmedOpacity\r\n : 0.85;\r\n\r\n // Render loading state\r\n if (!finalData) {\r\n return (\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 }\r\n if (viewPortDimensions) {\r\n return (\r\n <>\r\n <svg\r\n width={`${width}px`}\r\n height={`${height}px`}\r\n viewBox={`${viewPortDimensions[0] > 0 ? 0 : viewPortDimensions[0]} ${\r\n viewPortDimensions[1] > 0 ? 0 : viewPortDimensions[1]\r\n } ${width < viewPortDimensions[2] ? viewPortDimensions[2] : width} ${\r\n height < viewPortDimensions[3] ? viewPortDimensions[3] : height\r\n }`}\r\n direction='ltr'\r\n ref={svgRef}\r\n >\r\n <g transform={`translate(${margin.left},${margin.top})`}>\r\n {finalData.map(d => {\r\n const circleColor = getCircleColor(d);\r\n const opacity = getOpacity(d);\r\n const bubbleRadius = radiusScale ? radiusScale(d.size || 0) : radius;\r\n const showLabel = bubbleRadius > 20 && (showLabels || showValues);\r\n return (\r\n <g\r\n className='undp-viz-g-with-hover'\r\n key={d.label}\r\n opacity={opacity}\r\n transform={`translate(${d.x},${d.y})`}\r\n onMouseEnter={event => handleMouseEnter(event, d)}\r\n onMouseMove={event => handleMouseMove(event, d)}\r\n onClick={() => handleClick(d)}\r\n onMouseLeave={handleMouseLeave}\r\n >\r\n <circle cx={0} cy={0} r={bubbleRadius} fill={circleColor} />\r\n {(showLabel || showValues) &&\r\n d.size !== undefined &&\r\n d.size !== null &&\r\n bubbleRadius >= 15 && (\r\n <g>\r\n <foreignObject\r\n y={0 - bubbleRadius}\r\n x={0 - bubbleRadius}\r\n width={2 * bubbleRadius}\r\n height={2 * bubbleRadius}\r\n >\r\n <div\r\n className='flex flex-col justify-center items-center h-full py-0 px-3'\r\n style={{\r\n display: 'flex',\r\n flexDirection: 'column',\r\n justifyContent: 'center',\r\n alignItems: 'center',\r\n height: '100%',\r\n padding: '0 0.75rem',\r\n }}\r\n >\r\n {showLabels && (\r\n <P\r\n className={cn(\r\n 'text-center leading-[1.25] overflow-hidden m-0 circle-packing-label',\r\n classNames?.graphObjectValues,\r\n )}\r\n marginBottom='none'\r\n style={{\r\n fontSize: `${Math.min(\r\n Math.max(Math.round(bubbleRadius / 4), 12),\r\n Math.max(\r\n Math.round((bubbleRadius * 12) / `${d.label}`.length),\r\n 12,\r\n ),\r\n 14,\r\n )}px`,\r\n WebkitLineClamp:\r\n bubbleRadius * 2 < 60\r\n ? 1\r\n : bubbleRadius * 2 < 75\r\n ? 2\r\n : bubbleRadius * 2 < 100\r\n ? 3\r\n : undefined,\r\n display: '-webkit-box',\r\n WebkitBoxOrient: 'vertical',\r\n color: getTextColorBasedOnBgColor(circleColor),\r\n hyphens: 'auto',\r\n ...(styles?.graphObjectValues || {}),\r\n }}\r\n >\r\n {d.label}\r\n </P>\r\n )}\r\n {showValues && (\r\n <P\r\n className='text-center font-bold leading-[1.25] w-full m-0 circle-packing-value'\r\n marginBottom='none'\r\n style={{\r\n fontSize: `${Math.min(\r\n Math.max(Math.round(bubbleRadius / 4), 14),\r\n 14,\r\n )}px`,\r\n color: getTextColorBasedOnBgColor(circleColor),\r\n }}\r\n >\r\n {numberFormattingFunction(d.size, 'NA', precision, prefix, suffix)}\r\n </P>\r\n )}\r\n </div>\r\n </foreignObject>\r\n </g>\r\n )}\r\n </g>\r\n );\r\n })}\r\n </g>\r\n </svg>\r\n {mouseOverData && tooltip && eventX && eventY && (\r\n <Tooltip\r\n data={mouseOverData}\r\n body={tooltip}\r\n xPos={eventX}\r\n yPos={eventY}\r\n backgroundStyle={styles?.tooltip}\r\n className={classNames?.tooltip}\r\n />\r\n )}\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 return null;\r\n};\r\n","export function getMaxCircleRadius(\r\n values: (number | undefined | null)[],\r\n width: number,\r\n height: number,\r\n) {\r\n const filteredValues = values.filter(d => d !== undefined && d !== null);\r\n const containerRadius = Math.min(width, height) / 2;\r\n const totalValue = filteredValues.reduce((sum, v) => sum + v, 0);\r\n const maxValue = Math.max(...filteredValues);\r\n const getPackingEfficiency = (n: number) => {\r\n if (n <= 5) return 0.9;\r\n if (n <= 10) return 0.85;\r\n if (n <= 20) return 0.8;\r\n return 0.7;\r\n };\r\n const getEfficiencyBecauseOfContainerRadius = (r: number) => {\r\n if (r <= 200) return 0.85;\r\n if (r <= 250) return 0.95;\r\n return 1;\r\n };\r\n return (\r\n containerRadius *\r\n Math.sqrt(maxValue / totalValue) *\r\n getEfficiencyBecauseOfContainerRadius(containerRadius) *\r\n getPackingEfficiency(filteredValues.length)\r\n );\r\n}\r\n","import { useState, useRef, useEffect } from 'react';\r\n\r\nimport { Graph } from './Graph';\r\nimport { getMaxCircleRadius } from './getMaxCircleRadius';\r\n\r\nimport { Languages, SourcesDataType, StyleObject, ClassNameObject, TreeMapDataType } from '@/Types';\r\nimport { GraphFooter } from '@/Components/Elements/GraphFooter';\r\nimport { GraphHeader } from '@/Components/Elements/GraphHeader';\r\nimport { ColorLegendWithMouseOver } from '@/Components/Elements/ColorLegendWithMouseOver';\r\nimport { Colors } from '@/Components/ColorPalette';\r\nimport { EmptyState } from '@/Components/Elements/EmptyState';\r\nimport { uniqBy } from '@/Utils/uniqBy';\r\nimport { GraphArea, GraphContainer } from '@/Components/Elements/GraphContainer';\r\n\r\ninterface Props {\r\n // Data\r\n /** Array of data objects */\r\n data: TreeMapDataType[];\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 mapped to the radius chart */\r\n maxRadiusValue?: number;\r\n\r\n // Graph Parameters\r\n /** Maximum radius of the circle */\r\n radius?: number;\r\n /** Toggle visibility of labels */\r\n showLabels?: boolean;\r\n /** Toggle visibility of values */\r\n showValues?: 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 /** 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 /** Specifies the number of decimal places to display in the value. */\r\n precision?: number;\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 CirclePackingGraph(props: Props) {\r\n const {\r\n data,\r\n graphTitle,\r\n colors,\r\n suffix = '',\r\n sources,\r\n prefix = '',\r\n graphDescription,\r\n leftMargin = 0,\r\n rightMargin = 0,\r\n height,\r\n width,\r\n footNote,\r\n colorDomain,\r\n colorLegendTitle,\r\n padding,\r\n backgroundColor = false,\r\n topMargin = 0,\r\n bottomMargin = 0,\r\n showLabels = true,\r\n relativeHeight,\r\n tooltip,\r\n onSeriesMouseOver,\r\n showColorScale = true,\r\n showValues,\r\n graphID,\r\n highlightedDataPoints = [],\r\n onSeriesMouseClick,\r\n graphDownload = false,\r\n dataDownload = false,\r\n language = 'en',\r\n showNAColor,\r\n minHeight = 0,\r\n theme = 'light',\r\n ariaLabel,\r\n radius,\r\n maxRadiusValue,\r\n resetSelectionOnDoubleClick = true,\r\n detailsOnClick,\r\n styles,\r\n classNames,\r\n dimmedOpacity = 0.3,\r\n precision = 2,\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 const graphDiv = useRef<HTMLDivElement>(null);\r\n const graphParentDiv = useRef<HTMLDivElement>(null);\r\n useEffect(() => {\r\n const resizeObserver = new ResizeObserver(entries => {\r\n setSvgWidth(entries[0].target.clientWidth || 620);\r\n setSvgHeight(entries[0].target.clientHeight || 480);\r\n });\r\n if (graphDiv.current) {\r\n resizeObserver.observe(graphDiv.current);\r\n }\r\n return () => resizeObserver.disconnect();\r\n }, []);\r\n return (\r\n <GraphContainer\r\n className={classNames?.graphContainer}\r\n style={styles?.graphContainer}\r\n id={graphID}\r\n ref={graphParentDiv}\r\n aria-label={ariaLabel}\r\n backgroundColor={backgroundColor}\r\n theme={theme}\r\n language={language}\r\n minHeight={minHeight}\r\n width={width}\r\n height={height}\r\n relativeHeight={relativeHeight}\r\n padding={padding}\r\n >\r\n {graphTitle || graphDescription || graphDownload || dataDownload ? (\r\n <GraphHeader\r\n styles={{\r\n title: styles?.title,\r\n description: styles?.description,\r\n }}\r\n classNames={{\r\n title: classNames?.title,\r\n description: classNames?.description,\r\n }}\r\n graphTitle={graphTitle}\r\n graphDescription={graphDescription}\r\n width={width}\r\n graphDownload={graphDownload ? graphParentDiv : undefined}\r\n dataDownload={\r\n dataDownload\r\n ? data.map(d => d.data).filter(d => d !== undefined).length > 0\r\n ? data.map(d => d.data).filter(d => d !== undefined)\r\n : data.filter(d => d !== undefined)\r\n : null\r\n }\r\n />\r\n ) : null}\r\n {showColorScale && data.filter(el => el.color).length !== 0 && data.length > 0 ? (\r\n <ColorLegendWithMouseOver\r\n width={width}\r\n colorLegendTitle={colorLegendTitle}\r\n colors={(colors as string[] | undefined) || Colors[theme].categoricalColors.colors}\r\n colorDomain={colorDomain || (uniqBy(data, 'color', true) as string[])}\r\n setSelectedColor={setSelectedColor}\r\n showNAColor={showNAColor === undefined || showNAColor === null ? true : showNAColor}\r\n isCenter\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 <Graph\r\n data={data}\r\n colors={\r\n data.filter(el => el.color).length === 0\r\n ? colors\r\n ? [colors as string]\r\n : [Colors.primaryColors['blue-600']]\r\n : (colors as string[] | undefined) || Colors[theme].categoricalColors.colors\r\n }\r\n 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 height={svgHeight}\r\n leftMargin={leftMargin}\r\n rightMargin={rightMargin}\r\n topMargin={topMargin}\r\n bottomMargin={bottomMargin}\r\n showLabels={showLabels}\r\n showValues={\r\n showValues !== false\r\n ? data.filter(el => el.size).length !== 0\r\n : (showValues as boolean)\r\n }\r\n selectedColor={selectedColor}\r\n suffix={suffix}\r\n prefix={prefix}\r\n tooltip={tooltip}\r\n onSeriesMouseOver={onSeriesMouseOver}\r\n highlightedDataPoints={highlightedDataPoints}\r\n onSeriesMouseClick={onSeriesMouseClick}\r\n theme={theme}\r\n radius={\r\n !radius\r\n ? getMaxCircleRadius(\r\n data.map(d => d.size),\r\n svgWidth,\r\n svgHeight,\r\n )\r\n : radius\r\n }\r\n maxRadiusValue={maxRadiusValue}\r\n resetSelectionOnDoubleClick={resetSelectionOnDoubleClick}\r\n detailsOnClick={detailsOnClick}\r\n styles={styles}\r\n classNames={classNames}\r\n dimmedOpacity={dimmedOpacity}\r\n precision={precision}\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":["extent","values","valueof","min","max","value","index","Graph","props","$","_c","data","colors","leftMargin","width","height","colorDomain","selectedColor","rightMargin","topMargin","bottomMargin","showLabels","tooltip","onSeriesMouseOver","showValues","suffix","prefix","highlightedDataPoints","onSeriesMouseClick","maxRadiusValue","radius","resetSelectionOnDoubleClick","detailsOnClick","styles","classNames","dimmedOpacity","precision","svgRef","useRef","mouseOverData","setMouseOverData","useState","undefined","mouseClickData","setMouseClickData","viewPortDimensions","setViewPortDimensions","eventX","setEventX","eventY","setEventY","finalData","setFinalData","t0","top","bottom","left","right","margin","graphWidth","graphHeight","t1","filter","_temp","length","orderBy","_temp2","dataOrdered","t2","_temp3","scaleSqrt","domain","checkIfNullOrUndefined","Math","map","_temp4","_temp5","range","nice","radiusScale","t3","setupSimulation","dataTemp","_temp6","simulation","forceSimulation","force","forceY","_d","strength","forceX","_d_0","forceCollide","d_5","d","size","forceManyBody","alphaDecay","tick","on","xMinExtent","d_6","x","yMinExtent","d_7","y","xMaxExtent","d_8","yMaxExtent","d_9","t4","useEffect","t5","event","d_10","clientY","clientX","handleMouseEnter","t6","Symbol","for","event_0","d_11","handleMouseMove","t7","d_12","label","handleClick","t8","handleMouseLeave","t9","d_13","_temp7","color","indexOf","Colors","gray","getCircleColor","t10","d_14","getOpacity","t11","t12","t13","t14","jsx","Spinner","t15","graphObjectValues","t16","d_15","circleColor","opacity","bubbleRadius","showLabel","jsxs","event_1","event_2","display","flexDirection","justifyContent","alignItems","padding","P","cn","fontSize","round","WebkitLineClamp","WebkitBoxOrient","getTextColorBasedOnBgColor","hyphens","numberFormattingFunction","t17","t18","Tooltip","t19","modal","DetailsModal","t20","Fragment","d_0","d_3","d_1","d_2","d_4","el","getMaxCircleRadius","filteredValues","containerRadius","totalValue","reduce","sum","v","maxValue","getPackingEfficiency","n","getEfficiencyBecauseOfContainerRadius","r","sqrt","CirclePackingGraph","graphTitle","sources","graphDescription","footNote","colorLegendTitle","backgroundColor","relativeHeight","showColorScale","graphID","graphDownload","dataDownload","language","showNAColor","minHeight","theme","ariaLabel","svgWidth","setSvgWidth","svgHeight","setSvgHeight","setSelectedColor","graphDiv","graphParentDiv","resizeObserver","ResizeObserver","entries","target","clientWidth","clientHeight","current","observe","disconnect","t21","graphContainer","t22","t23","description","title","GraphHeader","t24","colorLegend","ColorLegendWithMouseOver","categoricalColors","uniqBy","t25","EmptyState","t26","primaryColors","_temp8","_temp9","_temp0","t27","GraphArea","t28","footnote","source","GraphFooter","t29","GraphContainer","el_2","el_1","el_0"],"mappings":"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","x_google_ignoreList":[0]}
@@ -1,2 +1,2 @@
1
- "use strict";const s=require("./index-CHPV5EwG-6v2a2njQ.cjs"),M=require("react"),He=require("./index-Cno4Q0YE.cjs"),Te=require("./Spinner-jTMOLuw_.cjs"),Be=require("./Typography-sa1UE0oF.cjs"),Fe=require("./Tooltip-BLa2EfMs.cjs"),We=require("./numberFormattingFunction-02t-wJta.cjs"),Le=require("./getTextColorBasedOnBgColor-nqY-bsM_.cjs"),$e=require("./Colors.cjs"),ze=require("./checkIfNullOrUndefined-BCW3Y1ML.cjs"),Ie=require("./DetailsModal-DHttOA80.cjs"),Xe=require("./pow-BnyPO-NX.cjs"),Se=require("./y-QcCbqrzx.cjs"),Ye=require("./GraphFooter.cjs"),Ae=require("./GraphHeader.cjs"),Ue=require("./ColorLegendWithMouseOver.cjs"),Je=require("./EmptyState-CGeBqbmR.cjs"),Pe=require("./uniqBy-O05lp2S5.cjs"),Ge=require("./GraphContainer-B1EDxJ0S.cjs");function De(o,e){let t,l;if(e===void 0)for(const n of o)n!=null&&(t===void 0?n>=n&&(t=l=n):(t>n&&(t=n),l<n&&(l=n)));else{let n=-1;for(let d of o)(d=e(d,++n,o))!=null&&(t===void 0?d>=d&&(t=l=d):(t>d&&(t=d),l<d&&(l=d)))}return[t,l]}const Ke=o=>{const e=s.compilerRuntimeExports.c(105),{data:t,colors:l,leftMargin:n,width:d,height:R,colorDomain:S,selectedColor:D,rightMargin:x,topMargin:oe,bottomMargin:je,showLabels:p,tooltip:W,onSeriesMouseOver:O,showValues:k,suffix:I,prefix:ie,highlightedDataPoints:be,onSeriesMouseClick:ne,maxRadiusValue:V,radius:c,resetSelectionOnDoubleClick:ye,detailsOnClick:q,styles:$,classNames:y,dimmedOpacity:X,precision:B}=o,Re=M.useRef(null),[Ce,Me]=M.useState(void 0),[L,Y]=M.useState(void 0),[w,ke]=M.useState(void 0),[se,re]=M.useState(void 0),[le,Oe]=M.useState(void 0),[ae,m]=M.useState(null);let a;e[0]!==je||e[1]!==n||e[2]!==x||e[3]!==oe?(a={top:oe,bottom:je,left:n,right:x},e[0]=je,e[1]=n,e[2]=x,e[3]=oe,e[4]=a):a=e[4];const A=a,U=d-A.left-A.right,P=R-A.top-A.bottom;let ce;e[5]!==t?(ce=t.filter(Qe).length===0?t:He.orderBy(t.filter(Ze),"radius","asc"),e[5]=t,e[6]=ce):ce=e[6];const G=ce;let ue;e[7]!==t||e[8]!==V||e[9]!==c?(ue=t.filter(_e).length!==t.length?Xe.sqrt().domain([0,ze.checkIfNullOrUndefined(V)?Math.max(...t.map(et).filter(tt)):V]).range([.25,c]).nice():void 0,e[7]=t,e[8]=V,e[9]=c,e[10]=ue):ue=e[10];const r=ue;let fe;e[11]!==G||e[12]!==P||e[13]!==U||e[14]!==c||e[15]!==r?(fe=()=>{(()=>{const u=G.map(ot);Se.forceSimulation(u).force("y",Se.forceY(v=>P/2).strength(1)).force("x",Se.forceX(v=>U/2).strength(1)).force("collide",Se.forceCollide(v=>r?r(v.size||0)+1:c+1)).force("charge",Se.forceManyBody().strength(-15)).alphaDecay(.05).tick(1e4).on("tick",()=>{m(u)}).on("end",()=>{m(u);const v=De(u,f=>f.x-(r?r(f.size||0)+1:c+1))[0]||0,g=De(u,f=>f.y-(r?r(f.size||0)+1:c+1))[0]||0,z=De(u,f=>f.x+(r?r(f.size||0)+1:c+1))[1]||0,E=De(u,f=>f.y+(r?r(f.size||0)+1:c+1))[1]||0;ke([v,g,v<0?z-v:z,g<0?E-g:E])})})()},e[11]=G,e[12]=P,e[13]=U,e[14]=c,e[15]=r,e[16]=fe):fe=e[16];let de;e[17]!==t||e[18]!==G||e[19]!==P||e[20]!==U||e[21]!==V||e[22]!==c||e[23]!==r?(de=[t,c,P,U,V,G,r],e[17]=t,e[18]=G,e[19]=P,e[20]=U,e[21]=V,e[22]=c,e[23]=r,e[24]=de):de=e[24],M.useEffect(fe,de);let he;e[25]!==O?(he=(i,u)=>{Me(u),Oe(i.clientY),re(i.clientX),O?.(u)},e[25]=O,e[26]=he):he=e[26];const J=he;let K;e[27]===Symbol.for("react.memo_cache_sentinel")?(K=(i,u)=>{Me(u),Oe(i.clientY),re(i.clientX)},e[27]=K):K=e[27];const we=K;let Q;e[28]!==q||e[29]!==L||e[30]!==ne||e[31]!==ye?(Q=i=>{(ne||q)&&(L===i.label&&ye?(Y(void 0),ne?.(void 0)):(Y(i.label),ne?.(i)))},e[28]=q,e[29]=L,e[30]=ne,e[31]=ye,e[32]=Q):Q=e[32];const H=Q;let pe;e[33]!==O?(pe=()=>{Me(void 0),re(void 0),Oe(void 0),O?.(void 0)},e[33]=O,e[34]=pe):pe=e[34];const Z=pe;let C;e[35]!==S||e[36]!==l||e[37]!==t?(C=i=>t.filter(it).length===0?l[0]:i.color?l[S.indexOf(i.color)]:$e.Colors.gray,e[35]=S,e[36]=l,e[37]=t,e[38]=C):C=e[38];const _=C;let me;e[39]!==S||e[40]!==l||e[41]!==X||e[42]!==be||e[43]!==D?(me=i=>D?i.color&&l[S.indexOf(i.color)]===D?1:X:be.length!==0?be.indexOf(i.label)!==-1?.85:X:.85,e[39]=S,e[40]=l,e[41]=X,e[42]=be,e[43]=D,e[44]=me):me=e[44];const ee=me;if(!ae){const i=`${d}px`,u=`${R}px`;let b;e[45]!==i||e[46]!==u?(b={width:i,height:u},e[45]=i,e[46]=u,e[47]=b):b=e[47];let v;e[48]===Symbol.for("react.memo_cache_sentinel")?(v=s.jsxRuntimeExports.jsx("div",{className:"flex m-auto items-center justify-center p-0 leading-none text-base h-40",children:s.jsxRuntimeExports.jsx(Te.w,{})}),e[48]=v):v=e[48];let g;return e[49]!==b?(g=s.jsxRuntimeExports.jsx("div",{style:b,children:v}),e[49]=b,e[50]=g):g=e[50],g}if(w){const i=`${d}px`,u=`${R}px`,b=`${w[0]>0?0:w[0]} ${w[1]>0?0:w[1]} ${d<w[2]?w[2]:d} ${R<w[3]?w[3]:R}`,v=`translate(${A.left},${A.top})`;let g;if(e[51]!==y?.graphObjectValues||e[52]!==ae||e[53]!==_||e[54]!==ee||e[55]!==H||e[56]!==J||e[57]!==Z||e[58]!==B||e[59]!==ie||e[60]!==c||e[61]!==r||e[62]!==p||e[63]!==k||e[64]!==$?.graphObjectValues||e[65]!==I){let ge;e[67]!==y?.graphObjectValues||e[68]!==_||e[69]!==ee||e[70]!==H||e[71]!==J||e[72]!==Z||e[73]!==B||e[74]!==ie||e[75]!==c||e[76]!==r||e[77]!==p||e[78]!==k||e[79]!==$?.graphObjectValues||e[80]!==I?(ge=j=>{const T=_(j),xe=ee(j),h=r?r(j.size||0):c,ve=h>20&&(p||k);return s.jsxRuntimeExports.jsxs("g",{className:"undp-viz-g-with-hover",opacity:xe,transform:`translate(${j.x},${j.y})`,onMouseEnter:F=>J(F,j),onMouseMove:F=>we(F,j),onClick:()=>H(j),onMouseLeave:Z,children:[s.jsxRuntimeExports.jsx("circle",{cx:0,cy:0,r:h,fill:T}),(ve||k)&&j.size!==void 0&&j.size!==null&&h>=15&&s.jsxRuntimeExports.jsx("g",{children:s.jsxRuntimeExports.jsx("foreignObject",{y:0-h,x:0-h,width:2*h,height:2*h,children:s.jsxRuntimeExports.jsxs("div",{className:"flex flex-col justify-center items-center h-full py-0 px-3",style:{display:"flex",flexDirection:"column",justifyContent:"center",alignItems:"center",height:"100%",padding:"0 0.75rem"},children:[p&&s.jsxRuntimeExports.jsx(Be.j,{className:s.mo("text-center leading-[1.25] overflow-hidden m-0 circle-packing-label",y?.graphObjectValues),marginBottom:"none",style:{fontSize:`${Math.min(Math.max(Math.round(h/4),12),Math.max(Math.round(h*12/`${j.label}`.length),12),14)}px`,WebkitLineClamp:h*2<60?1:h*2<75?2:h*2<100?3:void 0,display:"-webkit-box",WebkitBoxOrient:"vertical",color:Le.getTextColorBasedOnBgColor(T),hyphens:"auto",...$?.graphObjectValues||{}},children:j.label}),k&&s.jsxRuntimeExports.jsx(Be.j,{className:"text-center font-bold leading-[1.25] w-full m-0 circle-packing-value",marginBottom:"none",style:{fontSize:`${Math.min(Math.max(Math.round(h/4),14),14)}px`,color:Le.getTextColorBasedOnBgColor(T)},children:We.numberFormattingFunction(j.size,"NA",B,ie,I)})]})})})]},j.label)},e[67]=y?.graphObjectValues,e[68]=_,e[69]=ee,e[70]=H,e[71]=J,e[72]=Z,e[73]=B,e[74]=ie,e[75]=c,e[76]=r,e[77]=p,e[78]=k,e[79]=$?.graphObjectValues,e[80]=I,e[81]=ge):ge=e[81],g=ae.map(ge),e[51]=y?.graphObjectValues,e[52]=ae,e[53]=_,e[54]=ee,e[55]=H,e[56]=J,e[57]=Z,e[58]=B,e[59]=ie,e[60]=c,e[61]=r,e[62]=p,e[63]=k,e[64]=$?.graphObjectValues,e[65]=I,e[66]=g}else g=e[66];let z;e[82]!==v||e[83]!==g?(z=s.jsxRuntimeExports.jsx("g",{transform:v,children:g}),e[82]=v,e[83]=g,e[84]=z):z=e[84];let E;e[85]!==i||e[86]!==u||e[87]!==b||e[88]!==z?(E=s.jsxRuntimeExports.jsx("svg",{width:i,height:u,viewBox:b,direction:"ltr",ref:Re,children:z}),e[85]=i,e[86]=u,e[87]=b,e[88]=z,e[89]=E):E=e[89];let f;e[90]!==y?.tooltip||e[91]!==se||e[92]!==le||e[93]!==Ce||e[94]!==$?.tooltip||e[95]!==W?(f=Ce&&W&&se&&le&&s.jsxRuntimeExports.jsx(Fe.Tooltip,{data:Ce,body:W,xPos:se,yPos:le,backgroundStyle:$?.tooltip,className:y?.tooltip}),e[90]=y?.tooltip,e[91]=se,e[92]=le,e[93]=Ce,e[94]=$?.tooltip,e[95]=W,e[96]=f):f=e[96];let N;e[97]!==y?.modal||e[98]!==q||e[99]!==L?(N=q&&L!==void 0?s.jsxRuntimeExports.jsx(Ie.DetailsModal,{body:q,data:L,setData:Y,className:y?.modal}):null,e[97]=y?.modal,e[98]=q,e[99]=L,e[100]=N):N=e[100];let te;return e[101]!==E||e[102]!==f||e[103]!==N?(te=s.jsxRuntimeExports.jsxs(s.jsxRuntimeExports.Fragment,{children:[E,f,N]}),e[101]=E,e[102]=f,e[103]=N,e[104]=te):te=e[104],te}return null};function Qe(o){return!ze.checkIfNullOrUndefined(o.size)}function Ze(o){return!ze.checkIfNullOrUndefined(o.size)}function _e(o){return o.size===void 0||o.size===null}function et(o){return o.size}function tt(o){return o!=null}function ot(o){return{...o,...o.data&&{data:{...o.data}}}}function it(o){return o.color}function nt(o,e,t){const l=o.filter(x=>x!=null),n=Math.min(e,t)/2,d=l.reduce((x,oe)=>x+oe,0),R=Math.max(...l),S=x=>x<=5?.9:x<=10?.85:x<=20?.8:.7,D=x=>x<=200?.85:x<=250?.95:1;return n*Math.sqrt(R/d)*D(n)*S(l.length)}function st(o){const e=s.compilerRuntimeExports.c(83),{data:t,graphTitle:l,colors:n,suffix:d,sources:R,prefix:S,graphDescription:D,leftMargin:x,rightMargin:oe,height:je,width:p,footNote:W,colorDomain:O,colorLegendTitle:k,padding:I,backgroundColor:ie,topMargin:be,bottomMargin:ne,showLabels:V,relativeHeight:c,tooltip:ye,onSeriesMouseOver:q,showColorScale:$,showValues:y,graphID:X,highlightedDataPoints:B,onSeriesMouseClick:Re,graphDownload:Ce,dataDownload:Me,language:L,showNAColor:Y,minHeight:w,theme:ke,ariaLabel:se,radius:re,maxRadiusValue:le,resetSelectionOnDoubleClick:Oe,detailsOnClick:ae,styles:m,classNames:a,dimmedOpacity:A,precision:U}=o,P=d===void 0?"":d,ce=S===void 0?"":S,G=x===void 0?0:x,ue=oe===void 0?0:oe,r=ie===void 0?!1:ie,fe=be===void 0?0:be,de=ne===void 0?0:ne,he=V===void 0?!0:V,J=$===void 0?!0:$;let K;e[0]!==B?(K=B===void 0?[]:B,e[0]=B,e[1]=K):K=e[1];const we=K,Q=Ce===void 0?!1:Ce,H=Me===void 0?!1:Me,pe=L===void 0?"en":L,Z=w===void 0?0:w,C=ke===void 0?"light":ke,_=Oe===void 0?!0:Oe,me=A===void 0?.3:A,ee=U===void 0?2:U,[i,u]=M.useState(0),[b,v]=M.useState(0),[g,z]=M.useState(void 0),E=M.useRef(null),f=M.useRef(null);let N,te;e[2]===Symbol.for("react.memo_cache_sentinel")?(N=()=>{const Ne=new ResizeObserver(Ve=>{u(Ve[0].target.clientWidth||620),v(Ve[0].target.clientHeight||480)});return E.current&&Ne.observe(E.current),()=>Ne.disconnect()},te=[],e[2]=N,e[3]=te):(N=e[2],te=e[3]),M.useEffect(N,te);const ge=a?.graphContainer,j=m?.graphContainer;let T;e[4]!==a?.description||e[5]!==a?.title||e[6]!==t||e[7]!==H||e[8]!==D||e[9]!==Q||e[10]!==l||e[11]!==m?.description||e[12]!==m?.title||e[13]!==p?(T=l||D||Q||H?s.jsxRuntimeExports.jsx(Ae.GraphHeader,{styles:{title:m?.title,description:m?.description},classNames:{title:a?.title,description:a?.description},graphTitle:l,graphDescription:D,width:p,graphDownload:Q?f:void 0,dataDownload:H?t.map(mt).filter(pt).length>0?t.map(ht).filter(dt):t.filter(ft):null}):null,e[4]=a?.description,e[5]=a?.title,e[6]=t,e[7]=H,e[8]=D,e[9]=Q,e[10]=l,e[11]=m?.description,e[12]=m?.title,e[13]=p,e[14]=T):T=e[14];let xe;e[15]!==a?.colorLegend||e[16]!==O||e[17]!==k||e[18]!==n||e[19]!==t||e[20]!==J||e[21]!==Y||e[22]!==C||e[23]!==p?(xe=J&&t.filter(ut).length!==0&&t.length>0?s.jsxRuntimeExports.jsx(Ue.ColorLegendWithMouseOver,{width:p,colorLegendTitle:k,colors:n||$e.Colors[C].categoricalColors.colors,colorDomain:O||Pe.uniqBy(t,"color",!0),setSelectedColor:z,showNAColor:Y??!0,isCenter:!0,className:a?.colorLegend}):null,e[15]=a?.colorLegend,e[16]=O,e[17]=k,e[18]=n,e[19]=t,e[20]=J,e[21]=Y,e[22]=C,e[23]=p,e[24]=xe):xe=e[24];let h;e[25]!==t.length?(h=t.length===0&&s.jsxRuntimeExports.jsx(Je.EmptyState,{}),e[25]=t.length,e[26]=h):h=e[26];let ve;e[27]!==de||e[28]!==a||e[29]!==O||e[30]!==n||e[31]!==t||e[32]!==ae||e[33]!==me||e[34]!==we||e[35]!==G||e[36]!==le||e[37]!==Re||e[38]!==q||e[39]!==ee||e[40]!==ce||e[41]!==re||e[42]!==_||e[43]!==ue||e[44]!==g||e[45]!==he||e[46]!==y||e[47]!==m||e[48]!==P||e[49]!==b||e[50]!==i||e[51]!==C||e[52]!==ye||e[53]!==fe?(ve=i&&b&&t.length>0?s.jsxRuntimeExports.jsx(Ke,{data:t,colors:t.filter(ct).length===0?n?[n]:[$e.Colors.primaryColors["blue-600"]]:n||$e.Colors[C].categoricalColors.colors,colorDomain:t.filter(at).length===0?[]:O||Pe.uniqBy(t,"color",!0),width:i,height:b,leftMargin:G,rightMargin:ue,topMargin:fe,bottomMargin:de,showLabels:he,showValues:y!==!1?t.filter(lt).length!==0:y,selectedColor:g,suffix:P,prefix:ce,tooltip:ye,onSeriesMouseOver:q,highlightedDataPoints:we,onSeriesMouseClick:Re,theme:C,radius:re||nt(t.map(rt),i,b),maxRadiusValue:le,resetSelectionOnDoubleClick:_,detailsOnClick:ae,styles:m,classNames:a,dimmedOpacity:me,precision:ee}):null,e[27]=de,e[28]=a,e[29]=O,e[30]=n,e[31]=t,e[32]=ae,e[33]=me,e[34]=we,e[35]=G,e[36]=le,e[37]=Re,e[38]=q,e[39]=ee,e[40]=ce,e[41]=re,e[42]=_,e[43]=ue,e[44]=g,e[45]=he,e[46]=y,e[47]=m,e[48]=P,e[49]=b,e[50]=i,e[51]=C,e[52]=ye,e[53]=fe,e[54]=ve):ve=e[54];let F;e[55]!==h||e[56]!==ve?(F=s.jsxRuntimeExports.jsxs(Ge.GraphArea,{ref:E,children:[h,ve]}),e[55]=h,e[56]=ve,e[57]=F):F=e[57];let Ee;e[58]!==a?.footnote||e[59]!==a?.source||e[60]!==W||e[61]!==R||e[62]!==m?.footnote||e[63]!==m?.source||e[64]!==p?(Ee=R||W?s.jsxRuntimeExports.jsx(Ye.GraphFooter,{styles:{footnote:m?.footnote,source:m?.source},classNames:{footnote:a?.footnote,source:a?.source},sources:R,footNote:W,width:p}):null,e[58]=a?.footnote,e[59]=a?.source,e[60]=W,e[61]=R,e[62]=m?.footnote,e[63]=m?.source,e[64]=p,e[65]=Ee):Ee=e[65];let qe;return e[66]!==se||e[67]!==r||e[68]!==X||e[69]!==je||e[70]!==pe||e[71]!==Z||e[72]!==I||e[73]!==c||e[74]!==ge||e[75]!==j||e[76]!==T||e[77]!==xe||e[78]!==F||e[79]!==Ee||e[80]!==C||e[81]!==p?(qe=s.jsxRuntimeExports.jsxs(Ge.GraphContainer,{className:ge,style:j,id:X,ref:f,"aria-label":se,backgroundColor:r,theme:C,language:pe,minHeight:Z,width:p,height:je,relativeHeight:c,padding:I,children:[T,xe,F,Ee]}),e[66]=se,e[67]=r,e[68]=X,e[69]=je,e[70]=pe,e[71]=Z,e[72]=I,e[73]=c,e[74]=ge,e[75]=j,e[76]=T,e[77]=xe,e[78]=F,e[79]=Ee,e[80]=C,e[81]=p,e[82]=qe):qe=e[82],qe}function rt(o){return o.size}function lt(o){return o.size}function at(o){return o.color}function ct(o){return o.color}function ut(o){return o.color}function ft(o){return o!==void 0}function dt(o){return o!==void 0}function ht(o){return o.data}function pt(o){return o!==void 0}function mt(o){return o.data}exports.CirclePackingGraph=st;exports.extent=De;
2
- //# sourceMappingURL=index-Dgjq6aZ2.cjs.map
1
+ "use strict";const s=require("./index-CHPV5EwG-6v2a2njQ.cjs"),M=require("react"),He=require("./index-Cno4Q0YE.cjs"),Te=require("./Spinner-jTMOLuw_.cjs"),Be=require("./Typography-DrJ7IOdw.cjs"),Fe=require("./Tooltip-BLa2EfMs.cjs"),We=require("./numberFormattingFunction-02t-wJta.cjs"),Le=require("./getTextColorBasedOnBgColor-nqY-bsM_.cjs"),$e=require("./Colors.cjs"),ze=require("./checkIfNullOrUndefined-BCW3Y1ML.cjs"),Ie=require("./DetailsModal-DHttOA80.cjs"),Xe=require("./pow-BnyPO-NX.cjs"),Se=require("./y-QcCbqrzx.cjs"),Ye=require("./GraphFooter.cjs"),Ae=require("./GraphHeader.cjs"),Ue=require("./ColorLegendWithMouseOver.cjs"),Je=require("./EmptyState-DX0t62iF.cjs"),Pe=require("./uniqBy-O05lp2S5.cjs"),Ge=require("./GraphContainer-B1EDxJ0S.cjs");function De(o,e){let t,l;if(e===void 0)for(const n of o)n!=null&&(t===void 0?n>=n&&(t=l=n):(t>n&&(t=n),l<n&&(l=n)));else{let n=-1;for(let d of o)(d=e(d,++n,o))!=null&&(t===void 0?d>=d&&(t=l=d):(t>d&&(t=d),l<d&&(l=d)))}return[t,l]}const Ke=o=>{const e=s.compilerRuntimeExports.c(105),{data:t,colors:l,leftMargin:n,width:d,height:R,colorDomain:S,selectedColor:D,rightMargin:x,topMargin:oe,bottomMargin:je,showLabels:p,tooltip:W,onSeriesMouseOver:O,showValues:k,suffix:I,prefix:ie,highlightedDataPoints:be,onSeriesMouseClick:ne,maxRadiusValue:V,radius:c,resetSelectionOnDoubleClick:ye,detailsOnClick:q,styles:$,classNames:y,dimmedOpacity:X,precision:B}=o,Re=M.useRef(null),[Ce,Me]=M.useState(void 0),[L,Y]=M.useState(void 0),[w,ke]=M.useState(void 0),[se,re]=M.useState(void 0),[le,Oe]=M.useState(void 0),[ae,m]=M.useState(null);let a;e[0]!==je||e[1]!==n||e[2]!==x||e[3]!==oe?(a={top:oe,bottom:je,left:n,right:x},e[0]=je,e[1]=n,e[2]=x,e[3]=oe,e[4]=a):a=e[4];const A=a,U=d-A.left-A.right,P=R-A.top-A.bottom;let ce;e[5]!==t?(ce=t.filter(Qe).length===0?t:He.orderBy(t.filter(Ze),"radius","asc"),e[5]=t,e[6]=ce):ce=e[6];const G=ce;let ue;e[7]!==t||e[8]!==V||e[9]!==c?(ue=t.filter(_e).length!==t.length?Xe.sqrt().domain([0,ze.checkIfNullOrUndefined(V)?Math.max(...t.map(et).filter(tt)):V]).range([.25,c]).nice():void 0,e[7]=t,e[8]=V,e[9]=c,e[10]=ue):ue=e[10];const r=ue;let fe;e[11]!==G||e[12]!==P||e[13]!==U||e[14]!==c||e[15]!==r?(fe=()=>{(()=>{const u=G.map(ot);Se.forceSimulation(u).force("y",Se.forceY(v=>P/2).strength(1)).force("x",Se.forceX(v=>U/2).strength(1)).force("collide",Se.forceCollide(v=>r?r(v.size||0)+1:c+1)).force("charge",Se.forceManyBody().strength(-15)).alphaDecay(.05).tick(1e4).on("tick",()=>{m(u)}).on("end",()=>{m(u);const v=De(u,f=>f.x-(r?r(f.size||0)+1:c+1))[0]||0,g=De(u,f=>f.y-(r?r(f.size||0)+1:c+1))[0]||0,z=De(u,f=>f.x+(r?r(f.size||0)+1:c+1))[1]||0,E=De(u,f=>f.y+(r?r(f.size||0)+1:c+1))[1]||0;ke([v,g,v<0?z-v:z,g<0?E-g:E])})})()},e[11]=G,e[12]=P,e[13]=U,e[14]=c,e[15]=r,e[16]=fe):fe=e[16];let de;e[17]!==t||e[18]!==G||e[19]!==P||e[20]!==U||e[21]!==V||e[22]!==c||e[23]!==r?(de=[t,c,P,U,V,G,r],e[17]=t,e[18]=G,e[19]=P,e[20]=U,e[21]=V,e[22]=c,e[23]=r,e[24]=de):de=e[24],M.useEffect(fe,de);let he;e[25]!==O?(he=(i,u)=>{Me(u),Oe(i.clientY),re(i.clientX),O?.(u)},e[25]=O,e[26]=he):he=e[26];const J=he;let K;e[27]===Symbol.for("react.memo_cache_sentinel")?(K=(i,u)=>{Me(u),Oe(i.clientY),re(i.clientX)},e[27]=K):K=e[27];const we=K;let Q;e[28]!==q||e[29]!==L||e[30]!==ne||e[31]!==ye?(Q=i=>{(ne||q)&&(L===i.label&&ye?(Y(void 0),ne?.(void 0)):(Y(i.label),ne?.(i)))},e[28]=q,e[29]=L,e[30]=ne,e[31]=ye,e[32]=Q):Q=e[32];const H=Q;let pe;e[33]!==O?(pe=()=>{Me(void 0),re(void 0),Oe(void 0),O?.(void 0)},e[33]=O,e[34]=pe):pe=e[34];const Z=pe;let C;e[35]!==S||e[36]!==l||e[37]!==t?(C=i=>t.filter(it).length===0?l[0]:i.color?l[S.indexOf(i.color)]:$e.Colors.gray,e[35]=S,e[36]=l,e[37]=t,e[38]=C):C=e[38];const _=C;let me;e[39]!==S||e[40]!==l||e[41]!==X||e[42]!==be||e[43]!==D?(me=i=>D?i.color&&l[S.indexOf(i.color)]===D?1:X:be.length!==0?be.indexOf(i.label)!==-1?.85:X:.85,e[39]=S,e[40]=l,e[41]=X,e[42]=be,e[43]=D,e[44]=me):me=e[44];const ee=me;if(!ae){const i=`${d}px`,u=`${R}px`;let b;e[45]!==i||e[46]!==u?(b={width:i,height:u},e[45]=i,e[46]=u,e[47]=b):b=e[47];let v;e[48]===Symbol.for("react.memo_cache_sentinel")?(v=s.jsxRuntimeExports.jsx("div",{className:"flex m-auto items-center justify-center p-0 leading-none text-base h-40",children:s.jsxRuntimeExports.jsx(Te.w,{})}),e[48]=v):v=e[48];let g;return e[49]!==b?(g=s.jsxRuntimeExports.jsx("div",{style:b,children:v}),e[49]=b,e[50]=g):g=e[50],g}if(w){const i=`${d}px`,u=`${R}px`,b=`${w[0]>0?0:w[0]} ${w[1]>0?0:w[1]} ${d<w[2]?w[2]:d} ${R<w[3]?w[3]:R}`,v=`translate(${A.left},${A.top})`;let g;if(e[51]!==y?.graphObjectValues||e[52]!==ae||e[53]!==_||e[54]!==ee||e[55]!==H||e[56]!==J||e[57]!==Z||e[58]!==B||e[59]!==ie||e[60]!==c||e[61]!==r||e[62]!==p||e[63]!==k||e[64]!==$?.graphObjectValues||e[65]!==I){let ge;e[67]!==y?.graphObjectValues||e[68]!==_||e[69]!==ee||e[70]!==H||e[71]!==J||e[72]!==Z||e[73]!==B||e[74]!==ie||e[75]!==c||e[76]!==r||e[77]!==p||e[78]!==k||e[79]!==$?.graphObjectValues||e[80]!==I?(ge=j=>{const T=_(j),xe=ee(j),h=r?r(j.size||0):c,ve=h>20&&(p||k);return s.jsxRuntimeExports.jsxs("g",{className:"undp-viz-g-with-hover",opacity:xe,transform:`translate(${j.x},${j.y})`,onMouseEnter:F=>J(F,j),onMouseMove:F=>we(F,j),onClick:()=>H(j),onMouseLeave:Z,children:[s.jsxRuntimeExports.jsx("circle",{cx:0,cy:0,r:h,fill:T}),(ve||k)&&j.size!==void 0&&j.size!==null&&h>=15&&s.jsxRuntimeExports.jsx("g",{children:s.jsxRuntimeExports.jsx("foreignObject",{y:0-h,x:0-h,width:2*h,height:2*h,children:s.jsxRuntimeExports.jsxs("div",{className:"flex flex-col justify-center items-center h-full py-0 px-3",style:{display:"flex",flexDirection:"column",justifyContent:"center",alignItems:"center",height:"100%",padding:"0 0.75rem"},children:[p&&s.jsxRuntimeExports.jsx(Be._,{className:s.mo("text-center leading-[1.25] overflow-hidden m-0 circle-packing-label",y?.graphObjectValues),marginBottom:"none",style:{fontSize:`${Math.min(Math.max(Math.round(h/4),12),Math.max(Math.round(h*12/`${j.label}`.length),12),14)}px`,WebkitLineClamp:h*2<60?1:h*2<75?2:h*2<100?3:void 0,display:"-webkit-box",WebkitBoxOrient:"vertical",color:Le.getTextColorBasedOnBgColor(T),hyphens:"auto",...$?.graphObjectValues||{}},children:j.label}),k&&s.jsxRuntimeExports.jsx(Be._,{className:"text-center font-bold leading-[1.25] w-full m-0 circle-packing-value",marginBottom:"none",style:{fontSize:`${Math.min(Math.max(Math.round(h/4),14),14)}px`,color:Le.getTextColorBasedOnBgColor(T)},children:We.numberFormattingFunction(j.size,"NA",B,ie,I)})]})})})]},j.label)},e[67]=y?.graphObjectValues,e[68]=_,e[69]=ee,e[70]=H,e[71]=J,e[72]=Z,e[73]=B,e[74]=ie,e[75]=c,e[76]=r,e[77]=p,e[78]=k,e[79]=$?.graphObjectValues,e[80]=I,e[81]=ge):ge=e[81],g=ae.map(ge),e[51]=y?.graphObjectValues,e[52]=ae,e[53]=_,e[54]=ee,e[55]=H,e[56]=J,e[57]=Z,e[58]=B,e[59]=ie,e[60]=c,e[61]=r,e[62]=p,e[63]=k,e[64]=$?.graphObjectValues,e[65]=I,e[66]=g}else g=e[66];let z;e[82]!==v||e[83]!==g?(z=s.jsxRuntimeExports.jsx("g",{transform:v,children:g}),e[82]=v,e[83]=g,e[84]=z):z=e[84];let E;e[85]!==i||e[86]!==u||e[87]!==b||e[88]!==z?(E=s.jsxRuntimeExports.jsx("svg",{width:i,height:u,viewBox:b,direction:"ltr",ref:Re,children:z}),e[85]=i,e[86]=u,e[87]=b,e[88]=z,e[89]=E):E=e[89];let f;e[90]!==y?.tooltip||e[91]!==se||e[92]!==le||e[93]!==Ce||e[94]!==$?.tooltip||e[95]!==W?(f=Ce&&W&&se&&le&&s.jsxRuntimeExports.jsx(Fe.Tooltip,{data:Ce,body:W,xPos:se,yPos:le,backgroundStyle:$?.tooltip,className:y?.tooltip}),e[90]=y?.tooltip,e[91]=se,e[92]=le,e[93]=Ce,e[94]=$?.tooltip,e[95]=W,e[96]=f):f=e[96];let N;e[97]!==y?.modal||e[98]!==q||e[99]!==L?(N=q&&L!==void 0?s.jsxRuntimeExports.jsx(Ie.DetailsModal,{body:q,data:L,setData:Y,className:y?.modal}):null,e[97]=y?.modal,e[98]=q,e[99]=L,e[100]=N):N=e[100];let te;return e[101]!==E||e[102]!==f||e[103]!==N?(te=s.jsxRuntimeExports.jsxs(s.jsxRuntimeExports.Fragment,{children:[E,f,N]}),e[101]=E,e[102]=f,e[103]=N,e[104]=te):te=e[104],te}return null};function Qe(o){return!ze.checkIfNullOrUndefined(o.size)}function Ze(o){return!ze.checkIfNullOrUndefined(o.size)}function _e(o){return o.size===void 0||o.size===null}function et(o){return o.size}function tt(o){return o!=null}function ot(o){return{...o,...o.data&&{data:{...o.data}}}}function it(o){return o.color}function nt(o,e,t){const l=o.filter(x=>x!=null),n=Math.min(e,t)/2,d=l.reduce((x,oe)=>x+oe,0),R=Math.max(...l),S=x=>x<=5?.9:x<=10?.85:x<=20?.8:.7,D=x=>x<=200?.85:x<=250?.95:1;return n*Math.sqrt(R/d)*D(n)*S(l.length)}function st(o){const e=s.compilerRuntimeExports.c(83),{data:t,graphTitle:l,colors:n,suffix:d,sources:R,prefix:S,graphDescription:D,leftMargin:x,rightMargin:oe,height:je,width:p,footNote:W,colorDomain:O,colorLegendTitle:k,padding:I,backgroundColor:ie,topMargin:be,bottomMargin:ne,showLabels:V,relativeHeight:c,tooltip:ye,onSeriesMouseOver:q,showColorScale:$,showValues:y,graphID:X,highlightedDataPoints:B,onSeriesMouseClick:Re,graphDownload:Ce,dataDownload:Me,language:L,showNAColor:Y,minHeight:w,theme:ke,ariaLabel:se,radius:re,maxRadiusValue:le,resetSelectionOnDoubleClick:Oe,detailsOnClick:ae,styles:m,classNames:a,dimmedOpacity:A,precision:U}=o,P=d===void 0?"":d,ce=S===void 0?"":S,G=x===void 0?0:x,ue=oe===void 0?0:oe,r=ie===void 0?!1:ie,fe=be===void 0?0:be,de=ne===void 0?0:ne,he=V===void 0?!0:V,J=$===void 0?!0:$;let K;e[0]!==B?(K=B===void 0?[]:B,e[0]=B,e[1]=K):K=e[1];const we=K,Q=Ce===void 0?!1:Ce,H=Me===void 0?!1:Me,pe=L===void 0?"en":L,Z=w===void 0?0:w,C=ke===void 0?"light":ke,_=Oe===void 0?!0:Oe,me=A===void 0?.3:A,ee=U===void 0?2:U,[i,u]=M.useState(0),[b,v]=M.useState(0),[g,z]=M.useState(void 0),E=M.useRef(null),f=M.useRef(null);let N,te;e[2]===Symbol.for("react.memo_cache_sentinel")?(N=()=>{const Ne=new ResizeObserver(Ve=>{u(Ve[0].target.clientWidth||620),v(Ve[0].target.clientHeight||480)});return E.current&&Ne.observe(E.current),()=>Ne.disconnect()},te=[],e[2]=N,e[3]=te):(N=e[2],te=e[3]),M.useEffect(N,te);const ge=a?.graphContainer,j=m?.graphContainer;let T;e[4]!==a?.description||e[5]!==a?.title||e[6]!==t||e[7]!==H||e[8]!==D||e[9]!==Q||e[10]!==l||e[11]!==m?.description||e[12]!==m?.title||e[13]!==p?(T=l||D||Q||H?s.jsxRuntimeExports.jsx(Ae.GraphHeader,{styles:{title:m?.title,description:m?.description},classNames:{title:a?.title,description:a?.description},graphTitle:l,graphDescription:D,width:p,graphDownload:Q?f:void 0,dataDownload:H?t.map(mt).filter(pt).length>0?t.map(ht).filter(dt):t.filter(ft):null}):null,e[4]=a?.description,e[5]=a?.title,e[6]=t,e[7]=H,e[8]=D,e[9]=Q,e[10]=l,e[11]=m?.description,e[12]=m?.title,e[13]=p,e[14]=T):T=e[14];let xe;e[15]!==a?.colorLegend||e[16]!==O||e[17]!==k||e[18]!==n||e[19]!==t||e[20]!==J||e[21]!==Y||e[22]!==C||e[23]!==p?(xe=J&&t.filter(ut).length!==0&&t.length>0?s.jsxRuntimeExports.jsx(Ue.ColorLegendWithMouseOver,{width:p,colorLegendTitle:k,colors:n||$e.Colors[C].categoricalColors.colors,colorDomain:O||Pe.uniqBy(t,"color",!0),setSelectedColor:z,showNAColor:Y??!0,isCenter:!0,className:a?.colorLegend}):null,e[15]=a?.colorLegend,e[16]=O,e[17]=k,e[18]=n,e[19]=t,e[20]=J,e[21]=Y,e[22]=C,e[23]=p,e[24]=xe):xe=e[24];let h;e[25]!==t.length?(h=t.length===0&&s.jsxRuntimeExports.jsx(Je.EmptyState,{}),e[25]=t.length,e[26]=h):h=e[26];let ve;e[27]!==de||e[28]!==a||e[29]!==O||e[30]!==n||e[31]!==t||e[32]!==ae||e[33]!==me||e[34]!==we||e[35]!==G||e[36]!==le||e[37]!==Re||e[38]!==q||e[39]!==ee||e[40]!==ce||e[41]!==re||e[42]!==_||e[43]!==ue||e[44]!==g||e[45]!==he||e[46]!==y||e[47]!==m||e[48]!==P||e[49]!==b||e[50]!==i||e[51]!==C||e[52]!==ye||e[53]!==fe?(ve=i&&b&&t.length>0?s.jsxRuntimeExports.jsx(Ke,{data:t,colors:t.filter(ct).length===0?n?[n]:[$e.Colors.primaryColors["blue-600"]]:n||$e.Colors[C].categoricalColors.colors,colorDomain:t.filter(at).length===0?[]:O||Pe.uniqBy(t,"color",!0),width:i,height:b,leftMargin:G,rightMargin:ue,topMargin:fe,bottomMargin:de,showLabels:he,showValues:y!==!1?t.filter(lt).length!==0:y,selectedColor:g,suffix:P,prefix:ce,tooltip:ye,onSeriesMouseOver:q,highlightedDataPoints:we,onSeriesMouseClick:Re,theme:C,radius:re||nt(t.map(rt),i,b),maxRadiusValue:le,resetSelectionOnDoubleClick:_,detailsOnClick:ae,styles:m,classNames:a,dimmedOpacity:me,precision:ee}):null,e[27]=de,e[28]=a,e[29]=O,e[30]=n,e[31]=t,e[32]=ae,e[33]=me,e[34]=we,e[35]=G,e[36]=le,e[37]=Re,e[38]=q,e[39]=ee,e[40]=ce,e[41]=re,e[42]=_,e[43]=ue,e[44]=g,e[45]=he,e[46]=y,e[47]=m,e[48]=P,e[49]=b,e[50]=i,e[51]=C,e[52]=ye,e[53]=fe,e[54]=ve):ve=e[54];let F;e[55]!==h||e[56]!==ve?(F=s.jsxRuntimeExports.jsxs(Ge.GraphArea,{ref:E,children:[h,ve]}),e[55]=h,e[56]=ve,e[57]=F):F=e[57];let Ee;e[58]!==a?.footnote||e[59]!==a?.source||e[60]!==W||e[61]!==R||e[62]!==m?.footnote||e[63]!==m?.source||e[64]!==p?(Ee=R||W?s.jsxRuntimeExports.jsx(Ye.GraphFooter,{styles:{footnote:m?.footnote,source:m?.source},classNames:{footnote:a?.footnote,source:a?.source},sources:R,footNote:W,width:p}):null,e[58]=a?.footnote,e[59]=a?.source,e[60]=W,e[61]=R,e[62]=m?.footnote,e[63]=m?.source,e[64]=p,e[65]=Ee):Ee=e[65];let qe;return e[66]!==se||e[67]!==r||e[68]!==X||e[69]!==je||e[70]!==pe||e[71]!==Z||e[72]!==I||e[73]!==c||e[74]!==ge||e[75]!==j||e[76]!==T||e[77]!==xe||e[78]!==F||e[79]!==Ee||e[80]!==C||e[81]!==p?(qe=s.jsxRuntimeExports.jsxs(Ge.GraphContainer,{className:ge,style:j,id:X,ref:f,"aria-label":se,backgroundColor:r,theme:C,language:pe,minHeight:Z,width:p,height:je,relativeHeight:c,padding:I,children:[T,xe,F,Ee]}),e[66]=se,e[67]=r,e[68]=X,e[69]=je,e[70]=pe,e[71]=Z,e[72]=I,e[73]=c,e[74]=ge,e[75]=j,e[76]=T,e[77]=xe,e[78]=F,e[79]=Ee,e[80]=C,e[81]=p,e[82]=qe):qe=e[82],qe}function rt(o){return o.size}function lt(o){return o.size}function at(o){return o.color}function ct(o){return o.color}function ut(o){return o.color}function ft(o){return o!==void 0}function dt(o){return o!==void 0}function ht(o){return o.data}function pt(o){return o!==void 0}function mt(o){return o.data}exports.CirclePackingGraph=st;exports.extent=De;
2
+ //# sourceMappingURL=index-DlrGwLQA.cjs.map