@undp/data-viz 2.3.4 → 2.3.6
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/CirclePackingGraph.cjs +1 -1
- package/dist/CirclePackingGraph.d.ts +2 -0
- package/dist/CirclePackingGraph.js +1 -1
- package/dist/{GraphEl-C2xExzzY.js → GraphEl-Bw-9MUym.js} +7 -6
- package/dist/GraphEl-Bw-9MUym.js.map +1 -0
- package/dist/{GraphEl-B-XEJeRt.cjs → GraphEl-DjElfY07.cjs} +2 -2
- package/dist/GraphEl-DjElfY07.cjs.map +1 -0
- package/dist/GriddedGraphs.cjs +1 -1
- package/dist/GriddedGraphs.d.ts +1 -0
- package/dist/GriddedGraphs.js +1 -1
- package/dist/GriddedGraphsFromConfig.d.ts +1 -0
- package/dist/Histogram.cjs +1 -1
- package/dist/Histogram.js +1 -1
- package/dist/MultiGraphDashboard.d.ts +1 -0
- package/dist/MultiGraphDashboardFromConfig.d.ts +1 -0
- package/dist/PerformanceIntensiveMultiGraphDashboard.d.ts +1 -0
- package/dist/PerformanceIntensiveMultiGraphDashboardFromConfig.d.ts +1 -0
- package/dist/PerformanceIntensiveScrollStory.d.ts +1 -0
- package/dist/ScrollStory.d.ts +1 -0
- package/dist/SingleGraphDashboard.cjs +1 -1
- package/dist/SingleGraphDashboard.d.ts +1 -0
- package/dist/SingleGraphDashboard.js +1 -1
- package/dist/SingleGraphDashboardFromConfig.d.ts +1 -0
- package/dist/SingleGraphDashboardGeoHubMaps.d.ts +1 -0
- package/dist/SingleGraphDashboardGeoHubMapsFromConfig.d.ts +1 -0
- package/dist/SingleGraphDashboardThreeDGraphs.d.ts +1 -0
- package/dist/SingleGraphDashboardThreeDGraphsFromConfig.d.ts +1 -0
- package/dist/Types.d.ts +1 -0
- package/dist/index-BzNfurbO.js +378 -0
- package/dist/index-BzNfurbO.js.map +1 -0
- package/dist/index-CXobQn-E.cjs +2 -0
- package/dist/index-CXobQn-E.cjs.map +1 -0
- package/dist/index.cjs +1 -1
- package/dist/index.d.ts +3 -0
- package/dist/index.js +1 -1
- package/dist/style.css +1 -1
- package/package.json +3 -2
- package/dist/GraphEl-B-XEJeRt.cjs.map +0 -1
- package/dist/GraphEl-C2xExzzY.js.map +0 -1
- package/dist/index-CH8RndC2.js +0 -337
- package/dist/index-CH8RndC2.js.map +0 -1
- package/dist/index-DNmkwfX8.cjs +0 -2
- package/dist/index-DNmkwfX8.cjs.map +0 -1
|
@@ -0,0 +1,378 @@
|
|
|
1
|
+
import { c as Yt, j as x, m as Ft } from "./index-CHPV5EwG-DecW7_qr.js";
|
|
2
|
+
import { useRef as Bt, useState as rt, useEffect as Tt } from "react";
|
|
3
|
+
import { o as Xt } from "./index-BZQYSqar.js";
|
|
4
|
+
import { w as qt } from "./Spinner--r2RrJV8.js";
|
|
5
|
+
import { _ as Ht } from "./Typography-CdMGooqp.js";
|
|
6
|
+
import { T as It } from "./Tooltip-BRnAz2Gv.js";
|
|
7
|
+
import { n as Ut } from "./numberFormattingFunction-14YCbkN2.js";
|
|
8
|
+
import { g as Gt } from "./getTextColorBasedOnBgColor-CDY808zi.js";
|
|
9
|
+
import { Colors as At } from "./Colors.js";
|
|
10
|
+
import { c as Lt } from "./checkIfNullOrUndefined-DmfiKkNw.js";
|
|
11
|
+
import { D as Jt } from "./DetailsModal-BMCTgVsk.js";
|
|
12
|
+
import { s as Kt } from "./pow-CaIrlM4J.js";
|
|
13
|
+
import { f as Qt, b as Zt, a as _t, c as te, d as ee } from "./y-BqfogMAB.js";
|
|
14
|
+
import { GraphFooter as oe } from "./GraphFooter.js";
|
|
15
|
+
import { GraphHeader as ne } from "./GraphHeader.js";
|
|
16
|
+
import { ColorLegendWithMouseOver as ie } from "./ColorLegendWithMouseOver.js";
|
|
17
|
+
import { E as re } from "./EmptyState-dScPFkLy.js";
|
|
18
|
+
import { u as Wt } from "./uniqBy-BHy4I8PK.js";
|
|
19
|
+
import { a as le, G as se } from "./GraphContainer-CF6ws3pd.js";
|
|
20
|
+
function Et(i, t) {
|
|
21
|
+
let n, l;
|
|
22
|
+
if (t === void 0)
|
|
23
|
+
for (const s of i)
|
|
24
|
+
s != null && (n === void 0 ? s >= s && (n = l = s) : (n > s && (n = s), l < s && (l = s)));
|
|
25
|
+
else {
|
|
26
|
+
let s = -1;
|
|
27
|
+
for (let h of i)
|
|
28
|
+
(h = t(h, ++s, i)) != null && (n === void 0 ? h >= h && (n = l = h) : (n > h && (n = h), l < h && (l = h)));
|
|
29
|
+
}
|
|
30
|
+
return [n, l];
|
|
31
|
+
}
|
|
32
|
+
function H(i) {
|
|
33
|
+
return function() {
|
|
34
|
+
return i;
|
|
35
|
+
};
|
|
36
|
+
}
|
|
37
|
+
function ae(i, t, n, l) {
|
|
38
|
+
var s = H(0.1), h = !0, z = H(Math.min((n - i) / 2, (l - t) / 2)), a, V, P, u, N, f, O, g, E, A;
|
|
39
|
+
typeof i != "function" && (i = H(i == null ? -100 : +i)), typeof n != "function" && (n = H(n == null ? 100 : +n)), typeof t != "function" && (t = H(t == null ? -100 : +t)), typeof l != "function" && (l = H(l == null ? 100 : +l));
|
|
40
|
+
function G(e, o, W, r, B) {
|
|
41
|
+
return (e - o) * Math.min(2, Math.abs(e - o) / e) * W * B;
|
|
42
|
+
}
|
|
43
|
+
function d(e) {
|
|
44
|
+
for (var o = 0, W = a.length, r; o < W; ++o)
|
|
45
|
+
r = a[o], r.x < u[o] + g[o] || r.x > N[o] - g[o] || r.y < f[o] + g[o] || r.y > O[o] - g[o] ? (r.vx += G(E[o], r.x, V[o], g[o], e), r.vy += G(A[o], r.y, P[o], g[o], e)) : r.y < f[o] + g[o] || r.y > O[o] - g[o], h && (r.x >= N[o] && (r.vx += N[o] - r.x), r.x <= u[o] && (r.vx += u[o] - r.x), r.y >= O[o] && (r.vy += O[o] - r.y), r.y <= f[o] && (r.vy += f[o] - r.y));
|
|
46
|
+
}
|
|
47
|
+
function k() {
|
|
48
|
+
if (a) {
|
|
49
|
+
var e, o = a.length;
|
|
50
|
+
for (V = new Array(o), P = new Array(o), u = new Array(o), f = new Array(o), N = new Array(o), O = new Array(o), A = new Array(o), E = new Array(o), g = new Array(o), e = 0; e < o; ++e)
|
|
51
|
+
V[e] = isNaN(u[e] = +i(a[e], e, a)) || isNaN(N[e] = +n(a[e], e, a)) ? 0 : +s(a[e], e, a), P[e] = isNaN(f[e] = +t(a[e], e, a)) || isNaN(O[e] = +l(a[e], e, a)) ? 0 : +s(a[e], e, a), E[e] = u[e] + (N[e] - u[e]) / 2, A[e] = f[e] + (O[e] - f[e]) / 2, g[e] = +z(a[e], e, a);
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
return d.initialize = function(e) {
|
|
55
|
+
a = e, k();
|
|
56
|
+
}, d.x0 = function(e) {
|
|
57
|
+
return arguments.length ? (i = typeof e == "function" ? e : H(+e), k(), d) : i;
|
|
58
|
+
}, d.x1 = function(e) {
|
|
59
|
+
return arguments.length ? (n = typeof e == "function" ? e : H(+e), k(), d) : n;
|
|
60
|
+
}, d.y0 = function(e) {
|
|
61
|
+
return arguments.length ? (t = typeof e == "function" ? e : H(+e), k(), d) : t;
|
|
62
|
+
}, d.y1 = function(e) {
|
|
63
|
+
return arguments.length ? (l = typeof e == "function" ? e : H(+e), k(), d) : l;
|
|
64
|
+
}, d.strength = function(e) {
|
|
65
|
+
return arguments.length ? (s = typeof e == "function" ? e : H(+e), k(), d) : s;
|
|
66
|
+
}, d.border = function(e) {
|
|
67
|
+
return arguments.length ? (z = typeof e == "function" ? e : H(+e), k(), d) : z;
|
|
68
|
+
}, d.hardBoundary = function(e) {
|
|
69
|
+
return arguments.length ? (h = e, d) : h;
|
|
70
|
+
}, d;
|
|
71
|
+
}
|
|
72
|
+
const ce = (i) => {
|
|
73
|
+
const t = Yt.c(105), {
|
|
74
|
+
data: n,
|
|
75
|
+
colors: l,
|
|
76
|
+
leftMargin: s,
|
|
77
|
+
width: h,
|
|
78
|
+
height: z,
|
|
79
|
+
colorDomain: a,
|
|
80
|
+
selectedColor: V,
|
|
81
|
+
rightMargin: P,
|
|
82
|
+
topMargin: u,
|
|
83
|
+
bottomMargin: N,
|
|
84
|
+
showLabels: f,
|
|
85
|
+
tooltip: O,
|
|
86
|
+
onSeriesMouseOver: g,
|
|
87
|
+
showValues: E,
|
|
88
|
+
suffix: A,
|
|
89
|
+
prefix: G,
|
|
90
|
+
highlightedDataPoints: d,
|
|
91
|
+
onSeriesMouseClick: k,
|
|
92
|
+
maxRadiusValue: e,
|
|
93
|
+
radius: o,
|
|
94
|
+
resetSelectionOnDoubleClick: W,
|
|
95
|
+
detailsOnClick: r,
|
|
96
|
+
styles: B,
|
|
97
|
+
classNames: S,
|
|
98
|
+
dimmedOpacity: Q,
|
|
99
|
+
precision: T
|
|
100
|
+
} = i, kt = Bt(null), [bt, wt] = rt(void 0), [F, Z] = rt(void 0), [R, $t] = rt(void 0), [lt, st] = rt(void 0), [at, jt] = rt(void 0), [ct, C] = rt(null);
|
|
101
|
+
let p;
|
|
102
|
+
t[0] !== N || t[1] !== s || t[2] !== P || t[3] !== u ? (p = {
|
|
103
|
+
top: u,
|
|
104
|
+
bottom: N,
|
|
105
|
+
left: s,
|
|
106
|
+
right: P
|
|
107
|
+
}, t[0] = N, t[1] = s, t[2] = P, t[3] = u, t[4] = p) : p = t[4];
|
|
108
|
+
const _ = p, X = h - _.left - _.right, q = z - _.top - _.bottom;
|
|
109
|
+
let ft;
|
|
110
|
+
t[5] !== n ? (ft = n.filter(fe).length === 0 ? n : Xt(n.filter(ue), "radius", "asc"), t[5] = n, t[6] = ft) : ft = t[6];
|
|
111
|
+
const I = ft;
|
|
112
|
+
let ut;
|
|
113
|
+
t[7] !== n || t[8] !== e || t[9] !== o ? (ut = n.filter(he).length !== n.length ? Kt().domain([0, Lt(e) ? Math.max(...n.map(me).filter(ge)) : e]).range([0.25, o]).nice() : void 0, t[7] = n, t[8] = e, t[9] = o, t[10] = ut) : ut = t[10];
|
|
114
|
+
const m = ut;
|
|
115
|
+
let ht;
|
|
116
|
+
t[11] !== I || t[12] !== q || t[13] !== X || t[14] !== o || t[15] !== m ? (ht = () => {
|
|
117
|
+
(() => {
|
|
118
|
+
const v = I.map(de);
|
|
119
|
+
Qt(v).force("y", Zt((j) => q / 2).strength(1)).force("x", _t((j) => X / 2).strength(1)).force("collide", te((j) => m ? m(j.size || 0) + 1 : o + 1)).force("charge", ee().strength(-15)).force("boundary", ae(0, 0, X, q).strength(0.2).border(50)).alphaDecay(0.05).tick(1e4).on("tick", () => {
|
|
120
|
+
C(v);
|
|
121
|
+
}).on("end", () => {
|
|
122
|
+
C(v);
|
|
123
|
+
const j = Et(v, (b) => b.x - (m ? m(b.size || 0) + 1 : o + 1))[0] || 0, y = Et(v, (b) => b.y - (m ? m(b.size || 0) + 1 : o + 1))[0] || 0, Y = Et(v, (b) => b.x + (m ? m(b.size || 0) + 1 : o + 1))[1] || 0, L = Et(v, (b) => b.y + (m ? m(b.size || 0) + 1 : o + 1))[1] || 0;
|
|
124
|
+
$t([j, y, j < 0 ? Y - j : Y, y < 0 ? L - y : L]);
|
|
125
|
+
});
|
|
126
|
+
})();
|
|
127
|
+
}, t[11] = I, t[12] = q, t[13] = X, t[14] = o, t[15] = m, t[16] = ht) : ht = t[16];
|
|
128
|
+
let mt;
|
|
129
|
+
t[17] !== n || t[18] !== I || t[19] !== q || t[20] !== X || t[21] !== e || t[22] !== o || t[23] !== m ? (mt = [n, o, q, X, e, I, m], t[17] = n, t[18] = I, t[19] = q, t[20] = X, t[21] = e, t[22] = o, t[23] = m, t[24] = mt) : mt = t[24], Tt(ht, mt);
|
|
130
|
+
let gt;
|
|
131
|
+
t[25] !== g ? (gt = (c, v) => {
|
|
132
|
+
wt(v), jt(c.clientY), st(c.clientX), g?.(v);
|
|
133
|
+
}, t[25] = g, t[26] = gt) : gt = t[26];
|
|
134
|
+
const tt = gt;
|
|
135
|
+
let dt;
|
|
136
|
+
t[27] === /* @__PURE__ */ Symbol.for("react.memo_cache_sentinel") ? (dt = (c, v) => {
|
|
137
|
+
wt(v), jt(c.clientY), st(c.clientX);
|
|
138
|
+
}, t[27] = dt) : dt = t[27];
|
|
139
|
+
const Ot = dt;
|
|
140
|
+
let pt;
|
|
141
|
+
t[28] !== r || t[29] !== F || t[30] !== k || t[31] !== W ? (pt = (c) => {
|
|
142
|
+
(k || r) && (F === c.label && W ? (Z(void 0), k?.(void 0)) : (Z(c.label), k?.(c)));
|
|
143
|
+
}, t[28] = r, t[29] = F, t[30] = k, t[31] = W, t[32] = pt) : pt = t[32];
|
|
144
|
+
const U = pt;
|
|
145
|
+
let et;
|
|
146
|
+
t[33] !== g ? (et = () => {
|
|
147
|
+
wt(void 0), st(void 0), jt(void 0), g?.(void 0);
|
|
148
|
+
}, t[33] = g, t[34] = et) : et = t[34];
|
|
149
|
+
const ot = et;
|
|
150
|
+
let vt;
|
|
151
|
+
t[35] !== a || t[36] !== l || t[37] !== n ? (vt = (c) => n.filter(pe).length === 0 ? l[0] : c.color ? l[a.indexOf(c.color)] : At.gray, t[35] = a, t[36] = l, t[37] = n, t[38] = vt) : vt = t[38];
|
|
152
|
+
const $ = vt;
|
|
153
|
+
let xt;
|
|
154
|
+
t[39] !== a || t[40] !== l || t[41] !== Q || t[42] !== d || t[43] !== V ? (xt = (c) => V ? c.color && l[a.indexOf(c.color)] === V ? 1 : Q : d.length !== 0 ? d.indexOf(c.label) !== -1 ? 0.85 : Q : 0.85, t[39] = a, t[40] = l, t[41] = Q, t[42] = d, t[43] = V, t[44] = xt) : xt = t[44];
|
|
155
|
+
const nt = xt;
|
|
156
|
+
if (!ct) {
|
|
157
|
+
const c = `${h}px`, v = `${z}px`;
|
|
158
|
+
let D;
|
|
159
|
+
t[45] !== c || t[46] !== v ? (D = {
|
|
160
|
+
width: c,
|
|
161
|
+
height: v
|
|
162
|
+
}, t[45] = c, t[46] = v, t[47] = D) : D = t[47];
|
|
163
|
+
let j;
|
|
164
|
+
t[48] === /* @__PURE__ */ Symbol.for("react.memo_cache_sentinel") ? (j = /* @__PURE__ */ x.jsx("div", { className: "flex m-auto items-center justify-center p-0 leading-none text-base h-40", children: /* @__PURE__ */ x.jsx(qt, {}) }), t[48] = j) : j = t[48];
|
|
165
|
+
let y;
|
|
166
|
+
return t[49] !== D ? (y = /* @__PURE__ */ x.jsx("div", { style: D, children: j }), t[49] = D, t[50] = y) : y = t[50], y;
|
|
167
|
+
}
|
|
168
|
+
if (R) {
|
|
169
|
+
const c = `${h}px`, v = `${z}px`, D = `${R[0] > 0 ? 0 : R[0]} ${R[1] > 0 ? 0 : R[1]} ${h < R[2] ? R[2] : h} ${z < R[3] ? R[3] : z}`, j = `translate(${_.left},${_.top})`;
|
|
170
|
+
let y;
|
|
171
|
+
if (t[51] !== S?.graphObjectValues || t[52] !== ct || t[53] !== $ || t[54] !== nt || t[55] !== U || t[56] !== tt || t[57] !== ot || t[58] !== T || t[59] !== G || t[60] !== o || t[61] !== m || t[62] !== f || t[63] !== E || t[64] !== B?.graphObjectValues || t[65] !== A) {
|
|
172
|
+
let it;
|
|
173
|
+
t[67] !== S?.graphObjectValues || t[68] !== $ || t[69] !== nt || t[70] !== U || t[71] !== tt || t[72] !== ot || t[73] !== T || t[74] !== G || t[75] !== o || t[76] !== m || t[77] !== f || t[78] !== E || t[79] !== B?.graphObjectValues || t[80] !== A ? (it = (w) => {
|
|
174
|
+
const Ct = $(w), St = nt(w), M = m ? m(w.size || 0) : o, yt = M > 20 && (f || E);
|
|
175
|
+
return /* @__PURE__ */ x.jsxs("g", { className: "undp-viz-g-with-hover", opacity: St, transform: `translate(${w.x},${w.y})`, onMouseEnter: (K) => tt(K, w), onMouseMove: (K) => Ot(K, w), onClick: () => U(w), onMouseLeave: ot, children: [
|
|
176
|
+
/* @__PURE__ */ x.jsx("circle", { cx: 0, cy: 0, r: M, fill: Ct }),
|
|
177
|
+
(yt || E) && w.size !== void 0 && w.size !== null && M >= 15 && /* @__PURE__ */ x.jsx("g", { children: /* @__PURE__ */ x.jsx("foreignObject", { y: 0 - M, x: 0 - M, width: 2 * M, height: 2 * M, children: /* @__PURE__ */ x.jsxs("div", { className: "flex flex-col justify-center items-center h-full py-0 px-3", style: {
|
|
178
|
+
display: "flex",
|
|
179
|
+
flexDirection: "column",
|
|
180
|
+
justifyContent: "center",
|
|
181
|
+
alignItems: "center",
|
|
182
|
+
height: "100%",
|
|
183
|
+
padding: "0 0.75rem"
|
|
184
|
+
}, children: [
|
|
185
|
+
f && /* @__PURE__ */ x.jsx(Ht, { className: Ft("text-center leading-[1.25] overflow-hidden m-0 circle-packing-label", S?.graphObjectValues), marginBottom: "none", style: {
|
|
186
|
+
fontSize: `${Math.min(Math.max(Math.round(M / 4), 12), Math.max(Math.round(M * 12 / `${w.label}`.length), 12), 14)}px`,
|
|
187
|
+
WebkitLineClamp: M * 2 < 60 ? 1 : M * 2 < 75 ? 2 : M * 2 < 100 ? 3 : void 0,
|
|
188
|
+
display: "-webkit-box",
|
|
189
|
+
WebkitBoxOrient: "vertical",
|
|
190
|
+
color: Gt(Ct),
|
|
191
|
+
hyphens: "auto",
|
|
192
|
+
...B?.graphObjectValues || {}
|
|
193
|
+
}, children: w.label }),
|
|
194
|
+
E && /* @__PURE__ */ x.jsx(Ht, { className: "text-center font-bold leading-[1.25] w-full m-0 circle-packing-value", marginBottom: "none", style: {
|
|
195
|
+
fontSize: `${Math.min(Math.max(Math.round(M / 4), 14), 14)}px`,
|
|
196
|
+
color: Gt(Ct)
|
|
197
|
+
}, children: Ut(w.size, "NA", T, G, A) })
|
|
198
|
+
] }) }) })
|
|
199
|
+
] }, w.label);
|
|
200
|
+
}, t[67] = S?.graphObjectValues, t[68] = $, t[69] = nt, t[70] = U, t[71] = tt, t[72] = ot, t[73] = T, t[74] = G, t[75] = o, t[76] = m, t[77] = f, t[78] = E, t[79] = B?.graphObjectValues, t[80] = A, t[81] = it) : it = t[81], y = ct.map(it), t[51] = S?.graphObjectValues, t[52] = ct, t[53] = $, t[54] = nt, t[55] = U, t[56] = tt, t[57] = ot, t[58] = T, t[59] = G, t[60] = o, t[61] = m, t[62] = f, t[63] = E, t[64] = B?.graphObjectValues, t[65] = A, t[66] = y;
|
|
201
|
+
} else
|
|
202
|
+
y = t[66];
|
|
203
|
+
let Y;
|
|
204
|
+
t[82] !== j || t[83] !== y ? (Y = /* @__PURE__ */ x.jsx("g", { transform: j, children: y }), t[82] = j, t[83] = y, t[84] = Y) : Y = t[84];
|
|
205
|
+
let L;
|
|
206
|
+
t[85] !== c || t[86] !== v || t[87] !== D || t[88] !== Y ? (L = /* @__PURE__ */ x.jsx("svg", { width: c, height: v, viewBox: D, direction: "ltr", ref: kt, children: Y }), t[85] = c, t[86] = v, t[87] = D, t[88] = Y, t[89] = L) : L = t[89];
|
|
207
|
+
let b;
|
|
208
|
+
t[90] !== S?.tooltip || t[91] !== lt || t[92] !== at || t[93] !== bt || t[94] !== B?.tooltip || t[95] !== O ? (b = bt && O && lt && at && /* @__PURE__ */ x.jsx(It, { data: bt, body: O, xPos: lt, yPos: at, backgroundStyle: B?.tooltip, className: S?.tooltip }), t[90] = S?.tooltip, t[91] = lt, t[92] = at, t[93] = bt, t[94] = B?.tooltip, t[95] = O, t[96] = b) : b = t[96];
|
|
209
|
+
let J;
|
|
210
|
+
t[97] !== S?.modal || t[98] !== r || t[99] !== F ? (J = r && F !== void 0 ? /* @__PURE__ */ x.jsx(Jt, { body: r, data: F, setData: Z, className: S?.modal }) : null, t[97] = S?.modal, t[98] = r, t[99] = F, t[100] = J) : J = t[100];
|
|
211
|
+
let Mt;
|
|
212
|
+
return t[101] !== L || t[102] !== b || t[103] !== J ? (Mt = /* @__PURE__ */ x.jsxs(x.Fragment, { children: [
|
|
213
|
+
L,
|
|
214
|
+
b,
|
|
215
|
+
J
|
|
216
|
+
] }), t[101] = L, t[102] = b, t[103] = J, t[104] = Mt) : Mt = t[104], Mt;
|
|
217
|
+
}
|
|
218
|
+
return null;
|
|
219
|
+
};
|
|
220
|
+
function fe(i) {
|
|
221
|
+
return !Lt(i.size);
|
|
222
|
+
}
|
|
223
|
+
function ue(i) {
|
|
224
|
+
return !Lt(i.size);
|
|
225
|
+
}
|
|
226
|
+
function he(i) {
|
|
227
|
+
return i.size === void 0 || i.size === null;
|
|
228
|
+
}
|
|
229
|
+
function me(i) {
|
|
230
|
+
return i.size;
|
|
231
|
+
}
|
|
232
|
+
function ge(i) {
|
|
233
|
+
return i != null;
|
|
234
|
+
}
|
|
235
|
+
function de(i) {
|
|
236
|
+
return {
|
|
237
|
+
...i,
|
|
238
|
+
...i.data && {
|
|
239
|
+
data: {
|
|
240
|
+
...i.data
|
|
241
|
+
}
|
|
242
|
+
}
|
|
243
|
+
};
|
|
244
|
+
}
|
|
245
|
+
function pe(i) {
|
|
246
|
+
return i.color;
|
|
247
|
+
}
|
|
248
|
+
function ve(i, t, n, l) {
|
|
249
|
+
const s = i.filter((u) => u != null), h = l === !1 ? Math.sqrt(t * n / Math.PI) : Math.min(t, n) / 2, z = s.reduce((u, N) => u + N, 0), a = Math.max(...s), V = (u) => u <= 5 ? 0.9 : u <= 10 ? 0.85 : u <= 20 ? 0.8 : 0.7, P = (u) => u <= 200 ? 0.85 : u <= 250 ? 0.95 : 1;
|
|
250
|
+
return h * Math.sqrt(a / z) * (l ? P(h) : 1) * (l ? V(s.length) : 1);
|
|
251
|
+
}
|
|
252
|
+
function Ie(i) {
|
|
253
|
+
const t = Yt.c(84), {
|
|
254
|
+
data: n,
|
|
255
|
+
graphTitle: l,
|
|
256
|
+
colors: s,
|
|
257
|
+
suffix: h,
|
|
258
|
+
sources: z,
|
|
259
|
+
prefix: a,
|
|
260
|
+
graphDescription: V,
|
|
261
|
+
leftMargin: P,
|
|
262
|
+
rightMargin: u,
|
|
263
|
+
height: N,
|
|
264
|
+
width: f,
|
|
265
|
+
footNote: O,
|
|
266
|
+
colorDomain: g,
|
|
267
|
+
colorLegendTitle: E,
|
|
268
|
+
padding: A,
|
|
269
|
+
backgroundColor: G,
|
|
270
|
+
topMargin: d,
|
|
271
|
+
bottomMargin: k,
|
|
272
|
+
showLabels: e,
|
|
273
|
+
relativeHeight: o,
|
|
274
|
+
tooltip: W,
|
|
275
|
+
onSeriesMouseOver: r,
|
|
276
|
+
showColorScale: B,
|
|
277
|
+
showValues: S,
|
|
278
|
+
graphID: Q,
|
|
279
|
+
highlightedDataPoints: T,
|
|
280
|
+
onSeriesMouseClick: kt,
|
|
281
|
+
graphDownload: bt,
|
|
282
|
+
dataDownload: wt,
|
|
283
|
+
language: F,
|
|
284
|
+
showNAColor: Z,
|
|
285
|
+
minHeight: R,
|
|
286
|
+
theme: $t,
|
|
287
|
+
ariaLabel: lt,
|
|
288
|
+
radius: st,
|
|
289
|
+
maxRadiusValue: at,
|
|
290
|
+
resetSelectionOnDoubleClick: jt,
|
|
291
|
+
detailsOnClick: ct,
|
|
292
|
+
styles: C,
|
|
293
|
+
classNames: p,
|
|
294
|
+
dimmedOpacity: _,
|
|
295
|
+
precision: X,
|
|
296
|
+
circularBoundary: q
|
|
297
|
+
} = i, ft = h === void 0 ? "" : h, I = a === void 0 ? "" : a, ut = P === void 0 ? 0 : P, m = u === void 0 ? 0 : u, ht = G === void 0 ? !1 : G, mt = d === void 0 ? 0 : d, gt = k === void 0 ? 0 : k, tt = e === void 0 ? !0 : e, dt = B === void 0 ? !0 : B;
|
|
298
|
+
let Ot;
|
|
299
|
+
t[0] !== T ? (Ot = T === void 0 ? [] : T, t[0] = T, t[1] = Ot) : Ot = t[1];
|
|
300
|
+
const pt = Ot, U = bt === void 0 ? !1 : bt, et = wt === void 0 ? !1 : wt, ot = F === void 0 ? "en" : F, vt = R === void 0 ? 0 : R, $ = $t === void 0 ? "light" : $t, xt = jt === void 0 ? !0 : jt, nt = _ === void 0 ? 0.3 : _, c = X === void 0 ? 2 : X, v = q === void 0 ? !0 : q, [D, j] = rt(0), [y, Y] = rt(0), [L, b] = rt(void 0), J = Bt(null), Mt = Bt(null);
|
|
301
|
+
let it, w;
|
|
302
|
+
t[2] === /* @__PURE__ */ Symbol.for("react.memo_cache_sentinel") ? (it = () => {
|
|
303
|
+
const Pt = new ResizeObserver((Rt) => {
|
|
304
|
+
j(Rt[0].target.clientWidth || 620), Y(Rt[0].target.clientHeight || 480);
|
|
305
|
+
});
|
|
306
|
+
return J.current && Pt.observe(J.current), () => Pt.disconnect();
|
|
307
|
+
}, w = [], t[2] = it, t[3] = w) : (it = t[2], w = t[3]), Tt(it, w);
|
|
308
|
+
const Ct = p?.graphContainer, St = C?.graphContainer;
|
|
309
|
+
let M;
|
|
310
|
+
t[4] !== p?.description || t[5] !== p?.title || t[6] !== n || t[7] !== et || t[8] !== V || t[9] !== U || t[10] !== l || t[11] !== C?.description || t[12] !== C?.title || t[13] !== f ? (M = l || V || U || et ? /* @__PURE__ */ x.jsx(ne, { styles: {
|
|
311
|
+
title: C?.title,
|
|
312
|
+
description: C?.description
|
|
313
|
+
}, classNames: {
|
|
314
|
+
title: p?.title,
|
|
315
|
+
description: p?.description
|
|
316
|
+
}, graphTitle: l, graphDescription: V, width: f, graphDownload: U ? Mt : void 0, dataDownload: et ? n.map(ze).filter(De).length > 0 ? n.map(Oe).filter(je) : n.filter(we) : null }) : null, t[4] = p?.description, t[5] = p?.title, t[6] = n, t[7] = et, t[8] = V, t[9] = U, t[10] = l, t[11] = C?.description, t[12] = C?.title, t[13] = f, t[14] = M) : M = t[14];
|
|
317
|
+
let yt;
|
|
318
|
+
t[15] !== p?.colorLegend || t[16] !== g || t[17] !== E || t[18] !== s || t[19] !== n || t[20] !== dt || t[21] !== Z || t[22] !== $ || t[23] !== f ? (yt = dt && n.filter(Ce).length !== 0 && n.length > 0 ? /* @__PURE__ */ x.jsx(ie, { width: f, colorLegendTitle: E, colors: s || At[$].categoricalColors.colors, colorDomain: g || Wt(n, "color", !0), setSelectedColor: b, showNAColor: Z ?? !0, isCenter: !0, className: p?.colorLegend }) : null, t[15] = p?.colorLegend, t[16] = g, t[17] = E, t[18] = s, t[19] = n, t[20] = dt, t[21] = Z, t[22] = $, t[23] = f, t[24] = yt) : yt = t[24];
|
|
319
|
+
let K;
|
|
320
|
+
t[25] !== n.length ? (K = n.length === 0 && /* @__PURE__ */ x.jsx(re, {}), t[25] = n.length, t[26] = K) : K = t[26];
|
|
321
|
+
let Dt;
|
|
322
|
+
t[27] !== gt || t[28] !== v || t[29] !== p || t[30] !== g || t[31] !== s || t[32] !== n || t[33] !== ct || t[34] !== nt || t[35] !== pt || t[36] !== ut || t[37] !== at || t[38] !== kt || t[39] !== r || t[40] !== c || t[41] !== I || t[42] !== st || t[43] !== xt || t[44] !== m || t[45] !== L || t[46] !== tt || t[47] !== S || t[48] !== C || t[49] !== ft || t[50] !== y || t[51] !== D || t[52] !== $ || t[53] !== W || t[54] !== mt ? (Dt = D && y && n.length > 0 ? /* @__PURE__ */ x.jsx(ce, { data: n, colors: n.filter(Me).length === 0 ? s ? [s] : [At.primaryColors["blue-600"]] : s || At[$].categoricalColors.colors, colorDomain: n.filter(be).length === 0 ? [] : g || Wt(n, "color", !0), width: D, height: y, leftMargin: ut, rightMargin: m, topMargin: mt, bottomMargin: gt, showLabels: tt, showValues: S !== !1 ? n.filter(ye).length !== 0 : S, selectedColor: L, suffix: ft, prefix: I, tooltip: W, onSeriesMouseOver: r, highlightedDataPoints: pt, onSeriesMouseClick: kt, theme: $, radius: st || ve(n.map(xe), D, y, v), maxRadiusValue: at, resetSelectionOnDoubleClick: xt, detailsOnClick: ct, styles: C, classNames: p, dimmedOpacity: nt, precision: c }) : null, t[27] = gt, t[28] = v, t[29] = p, t[30] = g, t[31] = s, t[32] = n, t[33] = ct, t[34] = nt, t[35] = pt, t[36] = ut, t[37] = at, t[38] = kt, t[39] = r, t[40] = c, t[41] = I, t[42] = st, t[43] = xt, t[44] = m, t[45] = L, t[46] = tt, t[47] = S, t[48] = C, t[49] = ft, t[50] = y, t[51] = D, t[52] = $, t[53] = W, t[54] = mt, t[55] = Dt) : Dt = t[55];
|
|
323
|
+
let zt;
|
|
324
|
+
t[56] !== K || t[57] !== Dt ? (zt = /* @__PURE__ */ x.jsxs(le, { ref: J, children: [
|
|
325
|
+
K,
|
|
326
|
+
Dt
|
|
327
|
+
] }), t[56] = K, t[57] = Dt, t[58] = zt) : zt = t[58];
|
|
328
|
+
let Nt;
|
|
329
|
+
t[59] !== p?.footnote || t[60] !== p?.source || t[61] !== O || t[62] !== z || t[63] !== C?.footnote || t[64] !== C?.source || t[65] !== f ? (Nt = z || O ? /* @__PURE__ */ x.jsx(oe, { styles: {
|
|
330
|
+
footnote: C?.footnote,
|
|
331
|
+
source: C?.source
|
|
332
|
+
}, classNames: {
|
|
333
|
+
footnote: p?.footnote,
|
|
334
|
+
source: p?.source
|
|
335
|
+
}, sources: z, footNote: O, width: f }) : null, t[59] = p?.footnote, t[60] = p?.source, t[61] = O, t[62] = z, t[63] = C?.footnote, t[64] = C?.source, t[65] = f, t[66] = Nt) : Nt = t[66];
|
|
336
|
+
let Vt;
|
|
337
|
+
return t[67] !== lt || t[68] !== ht || t[69] !== Q || t[70] !== N || t[71] !== ot || t[72] !== vt || t[73] !== A || t[74] !== o || t[75] !== Ct || t[76] !== St || t[77] !== M || t[78] !== yt || t[79] !== zt || t[80] !== Nt || t[81] !== $ || t[82] !== f ? (Vt = /* @__PURE__ */ x.jsxs(se, { className: Ct, style: St, id: Q, ref: Mt, "aria-label": lt, backgroundColor: ht, theme: $, language: ot, minHeight: vt, width: f, height: N, relativeHeight: o, padding: A, children: [
|
|
338
|
+
M,
|
|
339
|
+
yt,
|
|
340
|
+
zt,
|
|
341
|
+
Nt
|
|
342
|
+
] }), t[67] = lt, t[68] = ht, t[69] = Q, t[70] = N, t[71] = ot, t[72] = vt, t[73] = A, t[74] = o, t[75] = Ct, t[76] = St, t[77] = M, t[78] = yt, t[79] = zt, t[80] = Nt, t[81] = $, t[82] = f, t[83] = Vt) : Vt = t[83], Vt;
|
|
343
|
+
}
|
|
344
|
+
function xe(i) {
|
|
345
|
+
return i.size;
|
|
346
|
+
}
|
|
347
|
+
function ye(i) {
|
|
348
|
+
return i.size;
|
|
349
|
+
}
|
|
350
|
+
function be(i) {
|
|
351
|
+
return i.color;
|
|
352
|
+
}
|
|
353
|
+
function Me(i) {
|
|
354
|
+
return i.color;
|
|
355
|
+
}
|
|
356
|
+
function Ce(i) {
|
|
357
|
+
return i.color;
|
|
358
|
+
}
|
|
359
|
+
function we(i) {
|
|
360
|
+
return i !== void 0;
|
|
361
|
+
}
|
|
362
|
+
function je(i) {
|
|
363
|
+
return i !== void 0;
|
|
364
|
+
}
|
|
365
|
+
function Oe(i) {
|
|
366
|
+
return i.data;
|
|
367
|
+
}
|
|
368
|
+
function De(i) {
|
|
369
|
+
return i !== void 0;
|
|
370
|
+
}
|
|
371
|
+
function ze(i) {
|
|
372
|
+
return i.data;
|
|
373
|
+
}
|
|
374
|
+
export {
|
|
375
|
+
Ie as C,
|
|
376
|
+
Et as e
|
|
377
|
+
};
|
|
378
|
+
//# sourceMappingURL=index-BzNfurbO.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index-BzNfurbO.js","sources":["../node_modules/d3-array/src/extent.js","../node_modules/d3-force-boundary/dist/d3-force-boundary.esm.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","// https://observablehq.com/@john-guerra/d3-force-boundary v0.0.2 Copyright 2022 John Alexis Guerra Gómez\nfunction constant(x) {\n return function() {\n return x;\n };\n}\n\nfunction forceBoundary(x0, y0, x1, y1) {\n var strength = constant(0.1),\n hardBoundary = true,\n border = constant( Math.min((x1 - x0)/2, (y1 - y0)/2) ),\n nodes,\n strengthsX,\n strengthsY,\n x0z, x1z,\n y0z, y1z,\n borderz,\n halfX, halfY;\n\n if (typeof x0 !== \"function\") x0 = constant(x0 == null ? -100 : +x0);\n if (typeof x1 !== \"function\") x1 = constant(x1 == null ? 100 : +x1);\n if (typeof y0 !== \"function\") y0 = constant(y0 == null ? -100 : +y0);\n if (typeof y1 !== \"function\") y1 = constant(y1 == null ? 100 : +y1);\n\n function getVx(halfX, x, strengthX, border, alpha) {\n return (halfX - x) * Math.min(2, Math.abs( halfX - x) / halfX) * strengthX * alpha;\n }\n\n function force(alpha) {\n for (var i = 0, n = nodes.length, node; i < n; ++i) {\n node = nodes[i];\n // debugger;\n if ((node.x < (x0z[i] + borderz[i]) || node.x > (x1z[i] - borderz[i])) ||\n (node.y < (y0z[i] + borderz[i]) || node.y > (y1z[i] - borderz[i]))) {\n node.vx += getVx(halfX[i], node.x, strengthsX[i], borderz[i], alpha);\n node.vy += getVx(halfY[i], node.y, strengthsY[i], borderz[i], alpha);\n } else if (node.y < (y0z[i] + borderz[i]) || node.y > (y1z[i] - borderz[i])) ;\n\n if (hardBoundary) {\n if (node.x >= x1z[i]) node.vx += x1z[i] - node.x;\n if (node.x <= x0z[i]) node.vx += x0z[i] - node.x;\n if (node.y >= y1z[i]) node.vy += y1z[i] - node.y;\n if (node.y <= y0z[i]) node.vy += y0z[i] - node.y;\n }\n }\n }\n\n function initialize() {\n if (!nodes) return;\n var i, n = nodes.length;\n strengthsX = new Array(n);\n strengthsY = new Array(n);\n x0z = new Array(n);\n y0z = new Array(n);\n x1z = new Array(n);\n y1z = new Array(n);\n halfY = new Array(n);\n halfX = new Array(n);\n borderz = new Array(n);\n\n for (i = 0; i < n; ++i) {\n strengthsX[i] = (isNaN(x0z[i] = +x0(nodes[i], i, nodes)) ||\n isNaN(x1z[i] = +x1(nodes[i], i, nodes))) ? 0 : +strength(nodes[i], i, nodes);\n strengthsY[i] = (isNaN(y0z[i] = +y0(nodes[i], i, nodes)) ||\n isNaN(y1z[i] = +y1(nodes[i], i, nodes))) ? 0 : +strength(nodes[i], i, nodes);\n halfX[i] = x0z[i] + (x1z[i] - x0z[i])/2,\n halfY[i] = y0z[i] + (y1z[i] - y0z[i])/2;\n borderz[i] = +border(nodes[i], i, nodes);\n }\n }\n\n force.initialize = function(_) {\n nodes = _;\n initialize();\n };\n\n force.x0 = function(_) {\n return arguments.length ? (x0 = typeof _ === \"function\" ? _ : constant(+_), initialize(), force) : x0;\n };\n\n force.x1 = function(_) {\n return arguments.length ? (x1 = typeof _ === \"function\" ? _ : constant(+_), initialize(), force) : x1;\n };\n\n force.y0 = function(_) {\n return arguments.length ? (y0 = typeof _ === \"function\" ? _ : constant(+_), initialize(), force) : y0;\n };\n\n force.y1 = function(_) {\n return arguments.length ? (y1 = typeof _ === \"function\" ? _ : constant(+_), initialize(), force) : y1;\n };\n\n force.strength = function(_) {\n return arguments.length ? (strength = typeof _ === \"function\" ? _ : constant(+_), initialize(), force) : strength;\n };\n\n force.border = function(_) {\n return arguments.length ? (border = typeof _ === \"function\" ? _ : constant(+_), initialize(), force) : border;\n };\n\n force.hardBoundary = function(_) {\n return arguments.length ? (hardBoundary = _, force) : hardBoundary;\n };\n\n return force;\n}\n\nexport default forceBoundary;\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 forceBoundary from 'd3-force-boundary';\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 .force('boundary', forceBoundary(0, 0, graphWidth, graphHeight).strength(0.2).border(50))\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 circularBoundary?: boolean,\r\n) {\r\n const filteredValues = values.filter(d => d !== undefined && d !== null);\r\n const containerRadius =\r\n circularBoundary === false\r\n ? Math.sqrt((width * height) / Math.PI)\r\n : 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 (circularBoundary ? getEfficiencyBecauseOfContainerRadius(containerRadius) : 1) *\r\n (circularBoundary ? getPackingEfficiency(filteredValues.length) : 1)\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 /** If true, the graph will be rendered in a circle layout */\r\n circularBoundary?: boolean;\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 circularBoundary = true,\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 circularBoundary,\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","constant","x","forceBoundary","x0","y0","x1","y1","strength","hardBoundary","border","nodes","strengthsX","strengthsY","x0z","x1z","y0z","y1z","borderz","halfX","halfY","getVx","strengthX","alpha","force","i","n","node","initialize","_","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","forceY","_d","forceX","_d_0","forceCollide","d_5","d","size","forceManyBody","alphaDecay","tick","on","xMinExtent","d_6","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","circularBoundary","filteredValues","containerRadius","sqrt","PI","totalValue","reduce","sum","v","maxValue","getPackingEfficiency","getEfficiencyBecauseOfContainerRadius","r","CirclePackingGraph","graphTitle","sources","graphDescription","footNote","colorLegendTitle","backgroundColor","relativeHeight","showColorScale","graphID","graphDownload","dataDownload","language","showNAColor","minHeight","theme","ariaLabel","svgWidth","setSvgWidth","svgHeight","setSvgHeight","setSelectedColor","graphDiv","graphParentDiv","t21","resizeObserver","ResizeObserver","entries","target","clientWidth","clientHeight","current","observe","disconnect","t22","graphContainer","t23","t24","description","title","GraphHeader","t25","colorLegend","ColorLegendWithMouseOver","categoricalColors","uniqBy","t26","EmptyState","t27","primaryColors","_temp8","_temp9","_temp0","t28","GraphArea","t29","footnote","source","GraphFooter","t30","GraphContainer","el_2","el_1","el_0"],"mappings":"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","x_google_ignoreList":[0,1]}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
"use strict";const h=require("./index-CHPV5EwG-6v2a2njQ.cjs"),$=require("react"),Fe=require("./index-Cno4Q0YE.cjs"),We=require("./Spinner-jTMOLuw_.cjs"),Pe=require("./Typography-Cc_iHQB-.cjs"),Ie=require("./Tooltip-BLa2EfMs.cjs"),Ye=require("./numberFormattingFunction-02t-wJta.cjs"),Ge=require("./getTextColorBasedOnBgColor-nqY-bsM_.cjs"),Ve=require("./Colors.cjs"),Be=require("./checkIfNullOrUndefined-BCW3Y1ML.cjs"),Xe=require("./DetailsModal-DHttOA80.cjs"),Ue=require("./pow-BnyPO-NX.cjs"),ke=require("./y-QcCbqrzx.cjs"),Je=require("./GraphFooter.cjs"),Ke=require("./GraphHeader.cjs"),Qe=require("./ColorLegendWithMouseOver.cjs"),Ze=require("./EmptyState-N1eHt3vq.cjs"),He=require("./uniqBy-O05lp2S5.cjs"),Te=require("./GraphContainer-B1EDxJ0S.cjs");function ze(r,e){let n,s;if(e===void 0)for(const l of r)l!=null&&(n===void 0?l>=l&&(n=s=l):(n>l&&(n=l),s<l&&(s=l)));else{let l=-1;for(let g of r)(g=e(g,++l,r))!=null&&(n===void 0?g>=g&&(n=s=g):(n>g&&(n=g),s<g&&(s=g)))}return[n,s]}function G(r){return function(){return r}}function _e(r,e,n,s){var l=G(.1),g=!0,R=G(Math.min((n-r)/2,(s-e)/2)),a,z,A,f,S,u,O,p,q,V;typeof r!="function"&&(r=G(r==null?-100:+r)),typeof n!="function"&&(n=G(n==null?100:+n)),typeof e!="function"&&(e=G(e==null?-100:+e)),typeof s!="function"&&(s=G(s==null?100:+s));function H(t,o,T,i,B){return(t-o)*Math.min(2,Math.abs(t-o)/t)*T*B}function m(t){for(var o=0,T=a.length,i;o<T;++o)i=a[o],i.x<f[o]+p[o]||i.x>S[o]-p[o]||i.y<u[o]+p[o]||i.y>O[o]-p[o]?(i.vx+=H(q[o],i.x,z[o],p[o],t),i.vy+=H(V[o],i.y,A[o],p[o],t)):i.y<u[o]+p[o]||i.y>O[o]-p[o],g&&(i.x>=S[o]&&(i.vx+=S[o]-i.x),i.x<=f[o]&&(i.vx+=f[o]-i.x),i.y>=O[o]&&(i.vy+=O[o]-i.y),i.y<=u[o]&&(i.vy+=u[o]-i.y))}function D(){if(a){var t,o=a.length;for(z=new Array(o),A=new Array(o),f=new Array(o),u=new Array(o),S=new Array(o),O=new Array(o),V=new Array(o),q=new Array(o),p=new Array(o),t=0;t<o;++t)z[t]=isNaN(f[t]=+r(a[t],t,a))||isNaN(S[t]=+n(a[t],t,a))?0:+l(a[t],t,a),A[t]=isNaN(u[t]=+e(a[t],t,a))||isNaN(O[t]=+s(a[t],t,a))?0:+l(a[t],t,a),q[t]=f[t]+(S[t]-f[t])/2,V[t]=u[t]+(O[t]-u[t])/2,p[t]=+R(a[t],t,a)}}return m.initialize=function(t){a=t,D()},m.x0=function(t){return arguments.length?(r=typeof t=="function"?t:G(+t),D(),m):r},m.x1=function(t){return arguments.length?(n=typeof t=="function"?t:G(+t),D(),m):n},m.y0=function(t){return arguments.length?(e=typeof t=="function"?t:G(+t),D(),m):e},m.y1=function(t){return arguments.length?(s=typeof t=="function"?t:G(+t),D(),m):s},m.strength=function(t){return arguments.length?(l=typeof t=="function"?t:G(+t),D(),m):l},m.border=function(t){return arguments.length?(R=typeof t=="function"?t:G(+t),D(),m):R},m.hardBoundary=function(t){return arguments.length?(g=t,m):g},m}const et=r=>{const e=h.compilerRuntimeExports.c(105),{data:n,colors:s,leftMargin:l,width:g,height:R,colorDomain:a,selectedColor:z,rightMargin:A,topMargin:f,bottomMargin:S,showLabels:u,tooltip:O,onSeriesMouseOver:p,showValues:q,suffix:V,prefix:H,highlightedDataPoints:m,onSeriesMouseClick:D,maxRadiusValue:t,radius:o,resetSelectionOnDoubleClick:T,detailsOnClick:i,styles:B,classNames:N,dimmedOpacity:Z,precision:W}=r,De=$.useRef(null),[be,Ce]=$.useState(void 0),[I,_]=$.useState(void 0),[P,qe]=$.useState(void 0),[se,le]=$.useState(void 0),[ae,we]=$.useState(void 0),[ce,M]=$.useState(null);let x;e[0]!==S||e[1]!==l||e[2]!==A||e[3]!==f?(x={top:f,bottom:S,left:l,right:A},e[0]=S,e[1]=l,e[2]=A,e[3]=f,e[4]=x):x=e[4];const ee=x,Y=g-ee.left-ee.right,X=R-ee.top-ee.bottom;let ue;e[5]!==n?(ue=n.filter(tt).length===0?n:Fe.orderBy(n.filter(ot),"radius","asc"),e[5]=n,e[6]=ue):ue=e[6];const U=ue;let fe;e[7]!==n||e[8]!==t||e[9]!==o?(fe=n.filter(nt).length!==n.length?Ue.sqrt().domain([0,Be.checkIfNullOrUndefined(t)?Math.max(...n.map(rt).filter(it)):t]).range([.25,o]).nice():void 0,e[7]=n,e[8]=t,e[9]=o,e[10]=fe):fe=e[10];const d=fe;let he;e[11]!==U||e[12]!==X||e[13]!==Y||e[14]!==o||e[15]!==d?(he=()=>{(()=>{const v=U.map(st);ke.forceSimulation(v).force("y",ke.forceY(w=>X/2).strength(1)).force("x",ke.forceX(w=>Y/2).strength(1)).force("collide",ke.forceCollide(w=>d?d(w.size||0)+1:o+1)).force("charge",ke.forceManyBody().strength(-15)).force("boundary",_e(0,0,Y,X).strength(.2).border(50)).alphaDecay(.05).tick(1e4).on("tick",()=>{M(v)}).on("end",()=>{M(v);const w=ze(v,b=>b.x-(d?d(b.size||0)+1:o+1))[0]||0,y=ze(v,b=>b.y-(d?d(b.size||0)+1:o+1))[0]||0,F=ze(v,b=>b.x+(d?d(b.size||0)+1:o+1))[1]||0,L=ze(v,b=>b.y+(d?d(b.size||0)+1:o+1))[1]||0;qe([w,y,w<0?F-w:F,y<0?L-y:L])})})()},e[11]=U,e[12]=X,e[13]=Y,e[14]=o,e[15]=d,e[16]=he):he=e[16];let ge;e[17]!==n||e[18]!==U||e[19]!==X||e[20]!==Y||e[21]!==t||e[22]!==o||e[23]!==d?(ge=[n,o,X,Y,t,U,d],e[17]=n,e[18]=U,e[19]=X,e[20]=Y,e[21]=t,e[22]=o,e[23]=d,e[24]=ge):ge=e[24],$.useEffect(he,ge);let de;e[25]!==p?(de=(c,v)=>{Ce(v),we(c.clientY),le(c.clientX),p?.(v)},e[25]=p,e[26]=de):de=e[26];const te=de;let pe;e[27]===Symbol.for("react.memo_cache_sentinel")?(pe=(c,v)=>{Ce(v),we(c.clientY),le(c.clientX)},e[27]=pe):pe=e[27];const Oe=pe;let me;e[28]!==i||e[29]!==I||e[30]!==D||e[31]!==T?(me=c=>{(D||i)&&(I===c.label&&T?(_(void 0),D?.(void 0)):(_(c.label),D?.(c)))},e[28]=i,e[29]=I,e[30]=D,e[31]=T,e[32]=me):me=e[32];const J=me;let oe;e[33]!==p?(oe=()=>{Ce(void 0),le(void 0),we(void 0),p?.(void 0)},e[33]=p,e[34]=oe):oe=e[34];const ne=oe;let xe;e[35]!==a||e[36]!==s||e[37]!==n?(xe=c=>n.filter(lt).length===0?s[0]:c.color?s[a.indexOf(c.color)]:Ve.Colors.gray,e[35]=a,e[36]=s,e[37]=n,e[38]=xe):xe=e[38];const k=xe;let ve;e[39]!==a||e[40]!==s||e[41]!==Z||e[42]!==m||e[43]!==z?(ve=c=>z?c.color&&s[a.indexOf(c.color)]===z?1:Z:m.length!==0?m.indexOf(c.label)!==-1?.85:Z:.85,e[39]=a,e[40]=s,e[41]=Z,e[42]=m,e[43]=z,e[44]=ve):ve=e[44];const re=ve;if(!ce){const c=`${g}px`,v=`${R}px`;let E;e[45]!==c||e[46]!==v?(E={width:c,height:v},e[45]=c,e[46]=v,e[47]=E):E=e[47];let w;e[48]===Symbol.for("react.memo_cache_sentinel")?(w=h.jsxRuntimeExports.jsx("div",{className:"flex m-auto items-center justify-center p-0 leading-none text-base h-40",children:h.jsxRuntimeExports.jsx(We.w,{})}),e[48]=w):w=e[48];let y;return e[49]!==E?(y=h.jsxRuntimeExports.jsx("div",{style:E,children:w}),e[49]=E,e[50]=y):y=e[50],y}if(P){const c=`${g}px`,v=`${R}px`,E=`${P[0]>0?0:P[0]} ${P[1]>0?0:P[1]} ${g<P[2]?P[2]:g} ${R<P[3]?P[3]:R}`,w=`translate(${ee.left},${ee.top})`;let y;if(e[51]!==N?.graphObjectValues||e[52]!==ce||e[53]!==k||e[54]!==re||e[55]!==J||e[56]!==te||e[57]!==ne||e[58]!==W||e[59]!==H||e[60]!==o||e[61]!==d||e[62]!==u||e[63]!==q||e[64]!==B?.graphObjectValues||e[65]!==V){let ie;e[67]!==N?.graphObjectValues||e[68]!==k||e[69]!==re||e[70]!==J||e[71]!==te||e[72]!==ne||e[73]!==W||e[74]!==H||e[75]!==o||e[76]!==d||e[77]!==u||e[78]!==q||e[79]!==B?.graphObjectValues||e[80]!==V?(ie=C=>{const Me=k(C),Ne=re(C),j=d?d(C.size||0):o,ye=j>20&&(u||q);return h.jsxRuntimeExports.jsxs("g",{className:"undp-viz-g-with-hover",opacity:Ne,transform:`translate(${C.x},${C.y})`,onMouseEnter:Q=>te(Q,C),onMouseMove:Q=>Oe(Q,C),onClick:()=>J(C),onMouseLeave:ne,children:[h.jsxRuntimeExports.jsx("circle",{cx:0,cy:0,r:j,fill:Me}),(ye||q)&&C.size!==void 0&&C.size!==null&&j>=15&&h.jsxRuntimeExports.jsx("g",{children:h.jsxRuntimeExports.jsx("foreignObject",{y:0-j,x:0-j,width:2*j,height:2*j,children:h.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:[u&&h.jsxRuntimeExports.jsx(Pe._,{className:h.mo("text-center leading-[1.25] overflow-hidden m-0 circle-packing-label",N?.graphObjectValues),marginBottom:"none",style:{fontSize:`${Math.min(Math.max(Math.round(j/4),12),Math.max(Math.round(j*12/`${C.label}`.length),12),14)}px`,WebkitLineClamp:j*2<60?1:j*2<75?2:j*2<100?3:void 0,display:"-webkit-box",WebkitBoxOrient:"vertical",color:Ge.getTextColorBasedOnBgColor(Me),hyphens:"auto",...B?.graphObjectValues||{}},children:C.label}),q&&h.jsxRuntimeExports.jsx(Pe._,{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(j/4),14),14)}px`,color:Ge.getTextColorBasedOnBgColor(Me)},children:Ye.numberFormattingFunction(C.size,"NA",W,H,V)})]})})})]},C.label)},e[67]=N?.graphObjectValues,e[68]=k,e[69]=re,e[70]=J,e[71]=te,e[72]=ne,e[73]=W,e[74]=H,e[75]=o,e[76]=d,e[77]=u,e[78]=q,e[79]=B?.graphObjectValues,e[80]=V,e[81]=ie):ie=e[81],y=ce.map(ie),e[51]=N?.graphObjectValues,e[52]=ce,e[53]=k,e[54]=re,e[55]=J,e[56]=te,e[57]=ne,e[58]=W,e[59]=H,e[60]=o,e[61]=d,e[62]=u,e[63]=q,e[64]=B?.graphObjectValues,e[65]=V,e[66]=y}else y=e[66];let F;e[82]!==w||e[83]!==y?(F=h.jsxRuntimeExports.jsx("g",{transform:w,children:y}),e[82]=w,e[83]=y,e[84]=F):F=e[84];let L;e[85]!==c||e[86]!==v||e[87]!==E||e[88]!==F?(L=h.jsxRuntimeExports.jsx("svg",{width:c,height:v,viewBox:E,direction:"ltr",ref:De,children:F}),e[85]=c,e[86]=v,e[87]=E,e[88]=F,e[89]=L):L=e[89];let b;e[90]!==N?.tooltip||e[91]!==se||e[92]!==ae||e[93]!==be||e[94]!==B?.tooltip||e[95]!==O?(b=be&&O&&se&&ae&&h.jsxRuntimeExports.jsx(Ie.Tooltip,{data:be,body:O,xPos:se,yPos:ae,backgroundStyle:B?.tooltip,className:N?.tooltip}),e[90]=N?.tooltip,e[91]=se,e[92]=ae,e[93]=be,e[94]=B?.tooltip,e[95]=O,e[96]=b):b=e[96];let K;e[97]!==N?.modal||e[98]!==i||e[99]!==I?(K=i&&I!==void 0?h.jsxRuntimeExports.jsx(Xe.DetailsModal,{body:i,data:I,setData:_,className:N?.modal}):null,e[97]=N?.modal,e[98]=i,e[99]=I,e[100]=K):K=e[100];let je;return e[101]!==L||e[102]!==b||e[103]!==K?(je=h.jsxRuntimeExports.jsxs(h.jsxRuntimeExports.Fragment,{children:[L,b,K]}),e[101]=L,e[102]=b,e[103]=K,e[104]=je):je=e[104],je}return null};function tt(r){return!Be.checkIfNullOrUndefined(r.size)}function ot(r){return!Be.checkIfNullOrUndefined(r.size)}function nt(r){return r.size===void 0||r.size===null}function rt(r){return r.size}function it(r){return r!=null}function st(r){return{...r,...r.data&&{data:{...r.data}}}}function lt(r){return r.color}function at(r,e,n,s){const l=r.filter(f=>f!=null),g=s===!1?Math.sqrt(e*n/Math.PI):Math.min(e,n)/2,R=l.reduce((f,S)=>f+S,0),a=Math.max(...l),z=f=>f<=5?.9:f<=10?.85:f<=20?.8:.7,A=f=>f<=200?.85:f<=250?.95:1;return g*Math.sqrt(a/R)*(s?A(g):1)*(s?z(l.length):1)}function ct(r){const e=h.compilerRuntimeExports.c(84),{data:n,graphTitle:s,colors:l,suffix:g,sources:R,prefix:a,graphDescription:z,leftMargin:A,rightMargin:f,height:S,width:u,footNote:O,colorDomain:p,colorLegendTitle:q,padding:V,backgroundColor:H,topMargin:m,bottomMargin:D,showLabels:t,relativeHeight:o,tooltip:T,onSeriesMouseOver:i,showColorScale:B,showValues:N,graphID:Z,highlightedDataPoints:W,onSeriesMouseClick:De,graphDownload:be,dataDownload:Ce,language:I,showNAColor:_,minHeight:P,theme:qe,ariaLabel:se,radius:le,maxRadiusValue:ae,resetSelectionOnDoubleClick:we,detailsOnClick:ce,styles:M,classNames:x,dimmedOpacity:ee,precision:Y,circularBoundary:X}=r,ue=g===void 0?"":g,U=a===void 0?"":a,fe=A===void 0?0:A,d=f===void 0?0:f,he=H===void 0?!1:H,ge=m===void 0?0:m,de=D===void 0?0:D,te=t===void 0?!0:t,pe=B===void 0?!0:B;let Oe;e[0]!==W?(Oe=W===void 0?[]:W,e[0]=W,e[1]=Oe):Oe=e[1];const me=Oe,J=be===void 0?!1:be,oe=Ce===void 0?!1:Ce,ne=I===void 0?"en":I,xe=P===void 0?0:P,k=qe===void 0?"light":qe,ve=we===void 0?!0:we,re=ee===void 0?.3:ee,c=Y===void 0?2:Y,v=X===void 0?!0:X,[E,w]=$.useState(0),[y,F]=$.useState(0),[L,b]=$.useState(void 0),K=$.useRef(null),je=$.useRef(null);let ie,C;e[2]===Symbol.for("react.memo_cache_sentinel")?(ie=()=>{const Le=new ResizeObserver(Ae=>{w(Ae[0].target.clientWidth||620),F(Ae[0].target.clientHeight||480)});return K.current&&Le.observe(K.current),()=>Le.disconnect()},C=[],e[2]=ie,e[3]=C):(ie=e[2],C=e[3]),$.useEffect(ie,C);const Me=x?.graphContainer,Ne=M?.graphContainer;let j;e[4]!==x?.description||e[5]!==x?.title||e[6]!==n||e[7]!==oe||e[8]!==z||e[9]!==J||e[10]!==s||e[11]!==M?.description||e[12]!==M?.title||e[13]!==u?(j=s||z||J||oe?h.jsxRuntimeExports.jsx(Ke.GraphHeader,{styles:{title:M?.title,description:M?.description},classNames:{title:x?.title,description:x?.description},graphTitle:s,graphDescription:z,width:u,graphDownload:J?je:void 0,dataDownload:oe?n.map(yt).filter(vt).length>0?n.map(xt).filter(mt):n.filter(pt):null}):null,e[4]=x?.description,e[5]=x?.title,e[6]=n,e[7]=oe,e[8]=z,e[9]=J,e[10]=s,e[11]=M?.description,e[12]=M?.title,e[13]=u,e[14]=j):j=e[14];let ye;e[15]!==x?.colorLegend||e[16]!==p||e[17]!==q||e[18]!==l||e[19]!==n||e[20]!==pe||e[21]!==_||e[22]!==k||e[23]!==u?(ye=pe&&n.filter(dt).length!==0&&n.length>0?h.jsxRuntimeExports.jsx(Qe.ColorLegendWithMouseOver,{width:u,colorLegendTitle:q,colors:l||Ve.Colors[k].categoricalColors.colors,colorDomain:p||He.uniqBy(n,"color",!0),setSelectedColor:b,showNAColor:_??!0,isCenter:!0,className:x?.colorLegend}):null,e[15]=x?.colorLegend,e[16]=p,e[17]=q,e[18]=l,e[19]=n,e[20]=pe,e[21]=_,e[22]=k,e[23]=u,e[24]=ye):ye=e[24];let Q;e[25]!==n.length?(Q=n.length===0&&h.jsxRuntimeExports.jsx(Ze.EmptyState,{}),e[25]=n.length,e[26]=Q):Q=e[26];let Ee;e[27]!==de||e[28]!==v||e[29]!==x||e[30]!==p||e[31]!==l||e[32]!==n||e[33]!==ce||e[34]!==re||e[35]!==me||e[36]!==fe||e[37]!==ae||e[38]!==De||e[39]!==i||e[40]!==c||e[41]!==U||e[42]!==le||e[43]!==ve||e[44]!==d||e[45]!==L||e[46]!==te||e[47]!==N||e[48]!==M||e[49]!==ue||e[50]!==y||e[51]!==E||e[52]!==k||e[53]!==T||e[54]!==ge?(Ee=E&&y&&n.length>0?h.jsxRuntimeExports.jsx(et,{data:n,colors:n.filter(gt).length===0?l?[l]:[Ve.Colors.primaryColors["blue-600"]]:l||Ve.Colors[k].categoricalColors.colors,colorDomain:n.filter(ht).length===0?[]:p||He.uniqBy(n,"color",!0),width:E,height:y,leftMargin:fe,rightMargin:d,topMargin:ge,bottomMargin:de,showLabels:te,showValues:N!==!1?n.filter(ft).length!==0:N,selectedColor:L,suffix:ue,prefix:U,tooltip:T,onSeriesMouseOver:i,highlightedDataPoints:me,onSeriesMouseClick:De,theme:k,radius:le||at(n.map(ut),E,y,v),maxRadiusValue:ae,resetSelectionOnDoubleClick:ve,detailsOnClick:ce,styles:M,classNames:x,dimmedOpacity:re,precision:c}):null,e[27]=de,e[28]=v,e[29]=x,e[30]=p,e[31]=l,e[32]=n,e[33]=ce,e[34]=re,e[35]=me,e[36]=fe,e[37]=ae,e[38]=De,e[39]=i,e[40]=c,e[41]=U,e[42]=le,e[43]=ve,e[44]=d,e[45]=L,e[46]=te,e[47]=N,e[48]=M,e[49]=ue,e[50]=y,e[51]=E,e[52]=k,e[53]=T,e[54]=ge,e[55]=Ee):Ee=e[55];let Re;e[56]!==Q||e[57]!==Ee?(Re=h.jsxRuntimeExports.jsxs(Te.GraphArea,{ref:K,children:[Q,Ee]}),e[56]=Q,e[57]=Ee,e[58]=Re):Re=e[58];let Se;e[59]!==x?.footnote||e[60]!==x?.source||e[61]!==O||e[62]!==R||e[63]!==M?.footnote||e[64]!==M?.source||e[65]!==u?(Se=R||O?h.jsxRuntimeExports.jsx(Je.GraphFooter,{styles:{footnote:M?.footnote,source:M?.source},classNames:{footnote:x?.footnote,source:x?.source},sources:R,footNote:O,width:u}):null,e[59]=x?.footnote,e[60]=x?.source,e[61]=O,e[62]=R,e[63]=M?.footnote,e[64]=M?.source,e[65]=u,e[66]=Se):Se=e[66];let $e;return e[67]!==se||e[68]!==he||e[69]!==Z||e[70]!==S||e[71]!==ne||e[72]!==xe||e[73]!==V||e[74]!==o||e[75]!==Me||e[76]!==Ne||e[77]!==j||e[78]!==ye||e[79]!==Re||e[80]!==Se||e[81]!==k||e[82]!==u?($e=h.jsxRuntimeExports.jsxs(Te.GraphContainer,{className:Me,style:Ne,id:Z,ref:je,"aria-label":se,backgroundColor:he,theme:k,language:ne,minHeight:xe,width:u,height:S,relativeHeight:o,padding:V,children:[j,ye,Re,Se]}),e[67]=se,e[68]=he,e[69]=Z,e[70]=S,e[71]=ne,e[72]=xe,e[73]=V,e[74]=o,e[75]=Me,e[76]=Ne,e[77]=j,e[78]=ye,e[79]=Re,e[80]=Se,e[81]=k,e[82]=u,e[83]=$e):$e=e[83],$e}function ut(r){return r.size}function ft(r){return r.size}function ht(r){return r.color}function gt(r){return r.color}function dt(r){return r.color}function pt(r){return r!==void 0}function mt(r){return r!==void 0}function xt(r){return r.data}function vt(r){return r!==void 0}function yt(r){return r.data}exports.CirclePackingGraph=ct;exports.extent=ze;
|
|
2
|
+
//# sourceMappingURL=index-CXobQn-E.cjs.map
|