@undp/data-viz 1.4.13 → 1.4.14
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/AreaChart.cjs +1 -1
- package/dist/AreaChart.cjs.map +1 -1
- package/dist/AreaChart.js +25 -24
- package/dist/AreaChart.js.map +1 -1
- package/dist/BarGraph.cjs +1 -1
- package/dist/BarGraph.cjs.map +1 -1
- package/dist/BarGraph.js +638 -632
- package/dist/BarGraph.js.map +1 -1
- package/dist/BeeSwarmChart.cjs +1 -1
- package/dist/BeeSwarmChart.cjs.map +1 -1
- package/dist/BeeSwarmChart.js +134 -132
- package/dist/BeeSwarmChart.js.map +1 -1
- package/dist/BiVariateChoroplethMap.cjs +1 -1
- package/dist/BiVariateChoroplethMap.cjs.map +1 -1
- package/dist/BiVariateChoroplethMap.js +35 -34
- package/dist/BiVariateChoroplethMap.js.map +1 -1
- package/dist/BulletChart.cjs +1 -1
- package/dist/BulletChart.cjs.map +1 -1
- package/dist/BulletChart.js +226 -224
- package/dist/BulletChart.js.map +1 -1
- package/dist/ButterflyChart.cjs +1 -1
- package/dist/ButterflyChart.cjs.map +1 -1
- package/dist/ButterflyChart.js +48 -47
- package/dist/ButterflyChart.js.map +1 -1
- package/dist/ChoroplethMap.cjs +1 -1
- package/dist/ChoroplethMap.cjs.map +1 -1
- package/dist/ChoroplethMap.js +56 -55
- package/dist/ChoroplethMap.js.map +1 -1
- package/dist/CirclePackingGraph.cjs +1 -1
- package/dist/CirclePackingGraph.js +1 -1
- package/dist/DataCards.cjs +3 -3
- package/dist/DataCards.cjs.map +1 -1
- package/dist/DataCards.js +2 -1
- package/dist/DataCards.js.map +1 -1
- package/dist/DataTable.cjs +1 -1
- package/dist/DataTable.cjs.map +1 -1
- package/dist/DataTable.js +9 -8
- package/dist/DataTable.js.map +1 -1
- package/dist/DifferenceLineChart.cjs +1 -1
- package/dist/DifferenceLineChart.cjs.map +1 -1
- package/dist/DifferenceLineChart.js +1 -0
- package/dist/DifferenceLineChart.js.map +1 -1
- package/dist/DonutChart.cjs +1 -1
- package/dist/DonutChart.cjs.map +1 -1
- package/dist/DonutChart.js +77 -76
- package/dist/DonutChart.js.map +1 -1
- package/dist/DotDensityMap.cjs +1 -1
- package/dist/DotDensityMap.cjs.map +1 -1
- package/dist/DotDensityMap.js +1 -0
- package/dist/DotDensityMap.js.map +1 -1
- package/dist/{DropdownSelect-CeHog_ih.js → DropdownSelect-CtOKZHD0.js} +22 -20
- package/dist/{DropdownSelect-CeHog_ih.js.map → DropdownSelect-CtOKZHD0.js.map} +1 -1
- package/dist/{DropdownSelect-BmE5JaeE.cjs → DropdownSelect-DBDM64B5.cjs} +2 -2
- package/dist/{DropdownSelect-BmE5JaeE.cjs.map → DropdownSelect-DBDM64B5.cjs.map} +1 -1
- package/dist/DualAxisLineChart.cjs +1 -1
- package/dist/DualAxisLineChart.cjs.map +1 -1
- package/dist/DualAxisLineChart.js +52 -51
- package/dist/DualAxisLineChart.js.map +1 -1
- package/dist/DumbbellChart.cjs +1 -1
- package/dist/DumbbellChart.cjs.map +1 -1
- package/dist/DumbbellChart.js +216 -214
- package/dist/DumbbellChart.js.map +1 -1
- package/dist/GeoHubCompareMaps.cjs +1 -1
- package/dist/GeoHubCompareMaps.cjs.map +1 -1
- package/dist/GeoHubCompareMaps.js +1 -0
- package/dist/GeoHubCompareMaps.js.map +1 -1
- package/dist/GeoHubMap.cjs +1 -1
- package/dist/GeoHubMap.cjs.map +1 -1
- package/dist/GeoHubMap.js +29 -28
- package/dist/GeoHubMap.js.map +1 -1
- package/dist/GeoHubMapWithLayerSelection.cjs +1 -1
- package/dist/GeoHubMapWithLayerSelection.cjs.map +1 -1
- package/dist/GeoHubMapWithLayerSelection.js +34 -33
- package/dist/GeoHubMapWithLayerSelection.js.map +1 -1
- package/dist/{GraphEl-B3xVlimz.js → GraphEl-N6vuMRw_.js} +2 -2
- package/dist/{GraphEl-B3xVlimz.js.map → GraphEl-N6vuMRw_.js.map} +1 -1
- package/dist/{GraphEl-DO-juRN8.cjs → GraphEl-Zl0W-LK9.cjs} +2 -2
- package/dist/{GraphEl-DO-juRN8.cjs.map → GraphEl-Zl0W-LK9.cjs.map} +1 -1
- package/dist/GriddedGraphs.cjs +1 -1
- package/dist/GriddedGraphs.js +2 -2
- package/dist/HeatMap.cjs +1 -1
- package/dist/HeatMap.cjs.map +1 -1
- package/dist/HeatMap.js +55 -54
- package/dist/HeatMap.js.map +1 -1
- package/dist/Histogram.cjs +1 -1
- package/dist/Histogram.js +1 -1
- package/dist/LineChartWithConfidenceInterval.cjs +1 -1
- package/dist/LineChartWithConfidenceInterval.cjs.map +1 -1
- package/dist/LineChartWithConfidenceInterval.js +22 -21
- package/dist/LineChartWithConfidenceInterval.js.map +1 -1
- package/dist/MultiGraphDashboard.cjs +1 -1
- package/dist/MultiGraphDashboard.js +1 -1
- package/dist/MultiGraphDashboardWideToLongFormat.cjs +1 -1
- package/dist/MultiGraphDashboardWideToLongFormat.js +1 -1
- package/dist/MultiLineAltChart.cjs +1 -1
- package/dist/MultiLineAltChart.cjs.map +1 -1
- package/dist/MultiLineAltChart.js +34 -33
- package/dist/MultiLineAltChart.js.map +1 -1
- package/dist/MultiLineChart.cjs +1 -1
- package/dist/MultiLineChart.cjs.map +1 -1
- package/dist/MultiLineChart.js +72 -71
- package/dist/MultiLineChart.js.map +1 -1
- package/dist/ParetoChart.cjs +1 -1
- package/dist/ParetoChart.cjs.map +1 -1
- package/dist/ParetoChart.js +22 -21
- package/dist/ParetoChart.js.map +1 -1
- package/dist/PerformanceIntensiveMultiGraphDashboard.cjs +1 -1
- package/dist/PerformanceIntensiveMultiGraphDashboard.js +1 -1
- package/dist/RadarChart.cjs +1 -1
- package/dist/RadarChart.cjs.map +1 -1
- package/dist/RadarChart.js +27 -26
- package/dist/RadarChart.js.map +1 -1
- package/dist/SankeyChart.cjs +1 -1
- package/dist/SankeyChart.cjs.map +1 -1
- package/dist/SankeyChart.js +30 -29
- package/dist/SankeyChart.js.map +1 -1
- package/dist/ScatterPlot.cjs +1 -1
- package/dist/ScatterPlot.cjs.map +1 -1
- package/dist/ScatterPlot.js +119 -118
- package/dist/ScatterPlot.js.map +1 -1
- package/dist/SimpleLineChart.cjs +1 -1
- package/dist/SimpleLineChart.cjs.map +1 -1
- package/dist/SimpleLineChart.js +16 -15
- package/dist/SimpleLineChart.js.map +1 -1
- package/dist/SingleGraphDashboard.cjs +1 -1
- package/dist/SingleGraphDashboard.js +2 -2
- package/dist/SingleGraphDashboardThreeDGraphs.cjs +1 -1
- package/dist/SingleGraphDashboardThreeDGraphs.js +1 -1
- package/dist/SlopeChart.cjs +1 -1
- package/dist/SlopeChart.cjs.map +1 -1
- package/dist/SlopeChart.js +46 -45
- package/dist/SlopeChart.js.map +1 -1
- package/dist/SparkLine.cjs +1 -1
- package/dist/SparkLine.cjs.map +1 -1
- package/dist/SparkLine.js +12 -11
- package/dist/SparkLine.js.map +1 -1
- package/dist/StripChart.cjs +1 -1
- package/dist/StripChart.cjs.map +1 -1
- package/dist/StripChart.js +81 -79
- package/dist/StripChart.js.map +1 -1
- package/dist/ThreeDGlobe.cjs +1 -1
- package/dist/ThreeDGlobe.cjs.map +1 -1
- package/dist/ThreeDGlobe.js +1 -0
- package/dist/ThreeDGlobe.js.map +1 -1
- package/dist/TreeMapGraph.cjs +1 -1
- package/dist/TreeMapGraph.cjs.map +1 -1
- package/dist/TreeMapGraph.js +114 -113
- package/dist/TreeMapGraph.js.map +1 -1
- package/dist/UnitChart.cjs +1 -1
- package/dist/UnitChart.cjs.map +1 -1
- package/dist/UnitChart.js +10 -9
- package/dist/UnitChart.js.map +1 -1
- package/dist/{index-CZLvTu6p.cjs → index-BbNoLJ_w.cjs} +2 -2
- package/dist/{index-CZLvTu6p.cjs.map → index-BbNoLJ_w.cjs.map} +1 -1
- package/dist/{index-DGAaLNu9.js → index-Bc5VF70V.js} +46 -45
- package/dist/{index-DGAaLNu9.js.map → index-Bc5VF70V.js.map} +1 -1
- package/dist/index.cjs +1 -1
- package/dist/index.js +1 -1
- package/package.json +2 -2
package/dist/SankeyChart.js
CHANGED
|
@@ -208,10 +208,10 @@ function kt() {
|
|
|
208
208
|
g = Math.min(y, (a - n) / (Ct(u, (s) => s.length) - 1)), T(u);
|
|
209
209
|
for (let s = 0; s < N; ++s) {
|
|
210
210
|
const c = Math.pow(0.99, s), r = Math.max(1 - c, (s + 1) / N);
|
|
211
|
-
|
|
211
|
+
et(u, c, r), tt(u, c, r);
|
|
212
212
|
}
|
|
213
213
|
}
|
|
214
|
-
function
|
|
214
|
+
function tt(t, u, s) {
|
|
215
215
|
for (let c = 1, r = t.length; c < r; ++c) {
|
|
216
216
|
const f = t[c];
|
|
217
217
|
for (const m of f) {
|
|
@@ -227,7 +227,7 @@ function kt() {
|
|
|
227
227
|
b === void 0 && f.sort(gt), B(f, s);
|
|
228
228
|
}
|
|
229
229
|
}
|
|
230
|
-
function
|
|
230
|
+
function et(t, u, s) {
|
|
231
231
|
for (let c = t.length, r = c - 2; r >= 0; --r) {
|
|
232
232
|
const f = t[r];
|
|
233
233
|
for (const m of f) {
|
|
@@ -245,7 +245,7 @@ function kt() {
|
|
|
245
245
|
}
|
|
246
246
|
function B(t, u) {
|
|
247
247
|
const s = t.length >> 1, c = t[s];
|
|
248
|
-
|
|
248
|
+
Q(t, c.y0 - g, s - 1, u), F(t, c.y1 + g, s + 1, u), Q(t, a, t.length - 1, u), F(t, n, 0, u);
|
|
249
249
|
}
|
|
250
250
|
function F(t, u, s, c) {
|
|
251
251
|
for (; s < t.length; ++s) {
|
|
@@ -253,7 +253,7 @@ function kt() {
|
|
|
253
253
|
f > 1e-6 && (r.y0 += f, r.y1 += f), u = r.y1 + g;
|
|
254
254
|
}
|
|
255
255
|
}
|
|
256
|
-
function
|
|
256
|
+
function Q(t, u, s, c) {
|
|
257
257
|
for (; s >= 0; --s) {
|
|
258
258
|
const r = t[s], f = (r.y1 - u) * c;
|
|
259
259
|
f > 1e-6 && (r.y0 -= f, r.y1 -= f), u = r.y0 - g;
|
|
@@ -298,7 +298,7 @@ function kt() {
|
|
|
298
298
|
}
|
|
299
299
|
return d;
|
|
300
300
|
}
|
|
301
|
-
var bt = Math.PI, $t = 2 * bt,
|
|
301
|
+
var bt = Math.PI, $t = 2 * bt, K = 1e-6, ne = $t - K;
|
|
302
302
|
function jt() {
|
|
303
303
|
this._x0 = this._y0 = // start of current subpath
|
|
304
304
|
this._x1 = this._y1 = null, this._ = "";
|
|
@@ -329,18 +329,18 @@ jt.prototype = It.prototype = {
|
|
|
329
329
|
if (l < 0) throw new Error("negative radius: " + l);
|
|
330
330
|
if (this._x1 === null)
|
|
331
331
|
this._ += "M" + (this._x1 = e) + "," + (this._y1 = n);
|
|
332
|
-
else if ($ >
|
|
332
|
+
else if ($ > K) if (!(Math.abs(k * p - v * b) > K) || !l)
|
|
333
333
|
this._ += "L" + (this._x1 = e) + "," + (this._y1 = n);
|
|
334
334
|
else {
|
|
335
335
|
var j = i - y, N = a - g, d = p * p + v * v, S = j * j + N * N, M = Math.sqrt(d), z = Math.sqrt($), X = l * Math.tan((bt - Math.acos((d + $ - S) / (2 * M * z))) / 2), P = X / z, T = X / M;
|
|
336
|
-
Math.abs(P - 1) >
|
|
336
|
+
Math.abs(P - 1) > K && (this._ += "L" + (e + P * b) + "," + (n + P * k)), this._ += "A" + l + "," + l + ",0,0," + +(k * j > b * N) + "," + (this._x1 = e + T * p) + "," + (this._y1 = n + T * v);
|
|
337
337
|
}
|
|
338
338
|
},
|
|
339
339
|
arc: function(e, n, i, a, l, y) {
|
|
340
340
|
e = +e, n = +n, i = +i, y = !!y;
|
|
341
341
|
var g = i * Math.cos(a), p = i * Math.sin(a), v = e + g, b = n + p, k = 1 ^ y, $ = y ? a - l : l - a;
|
|
342
342
|
if (i < 0) throw new Error("negative radius: " + i);
|
|
343
|
-
this._x1 === null ? this._ += "M" + v + "," + b : (Math.abs(this._x1 - v) >
|
|
343
|
+
this._x1 === null ? this._ += "M" + v + "," + b : (Math.abs(this._x1 - v) > K || Math.abs(this._y1 - b) > K) && (this._ += "L" + v + "," + b), i && ($ < 0 && ($ = $ % $t + $t), $ > ne ? this._ += "A" + i + "," + i + ",0,1," + k + "," + (e - g) + "," + (n - p) + "A" + i + "," + i + ",0,1," + k + "," + (this._x1 = v) + "," + (this._y1 = b) : $ > K && (this._ += "A" + i + "," + i + ",0," + +($ >= bt) + "," + k + "," + (this._x1 = e + i * Math.cos(l)) + "," + (this._y1 = n + i * Math.sin(l))));
|
|
344
344
|
},
|
|
345
345
|
rect: function(e, n, i, a) {
|
|
346
346
|
this._ += "M" + (this._x0 = this._x1 = +e) + "," + (this._y0 = this._y1 = +n) + "h" + +i + "v" + +a + "h" + -i + "Z";
|
|
@@ -423,11 +423,11 @@ function de(e) {
|
|
|
423
423
|
highlightedSourceDataPoints: P,
|
|
424
424
|
highlightedTargetDataPoints: T,
|
|
425
425
|
defaultLinkOpacity: W,
|
|
426
|
-
sourceTitle:
|
|
427
|
-
targetTitle:
|
|
426
|
+
sourceTitle: tt,
|
|
427
|
+
targetTitle: et,
|
|
428
428
|
animate: B,
|
|
429
429
|
sortNodes: F,
|
|
430
|
-
resetSelectionOnDoubleClick:
|
|
430
|
+
resetSelectionOnDoubleClick: Q,
|
|
431
431
|
detailsOnClick: D,
|
|
432
432
|
styles: I,
|
|
433
433
|
classNames: Y,
|
|
@@ -443,7 +443,7 @@ function de(e) {
|
|
|
443
443
|
right: l
|
|
444
444
|
}, G = g - A.left - A.right, q = p - A.top - A.bottom, st = F === "mostReadable" ? kt().nodeWidth(z).nodePadding(M).size([G, q]).nodeAlign(xt) : F === "none" ? kt().nodeWidth(z).nodePadding(M).size([G, q]).nodeAlign(xt).nodeSort(() => null).linkSort(() => null) : kt().nodeWidth(z).nodePadding(M).size([G, q]).nodeAlign(xt).nodeSort(
|
|
445
445
|
F === "desc" ? (o, _) => (_.value || 0) - (o.value || 0) : (o, _) => (o.value || 0) - (_.value || 0)
|
|
446
|
-
), { nodes: at, links: lt } = st(n),
|
|
446
|
+
), { nodes: at, links: lt } = st(n), J = ge();
|
|
447
447
|
return /* @__PURE__ */ h.jsxs(h.Fragment, { children: [
|
|
448
448
|
/* @__PURE__ */ h.jsxs(
|
|
449
449
|
mt.svg,
|
|
@@ -455,24 +455,24 @@ function de(e) {
|
|
|
455
455
|
direction: "ltr",
|
|
456
456
|
ref: u,
|
|
457
457
|
children: [
|
|
458
|
-
|
|
458
|
+
tt ? /* @__PURE__ */ h.jsx(
|
|
459
459
|
"text",
|
|
460
460
|
{
|
|
461
461
|
x: A.left,
|
|
462
462
|
y: A.top - 10,
|
|
463
463
|
className: "text-base font-bold fill-primary-gray-700 dark:fill-primary-gray-100",
|
|
464
464
|
style: { textAnchor: "start" },
|
|
465
|
-
children:
|
|
465
|
+
children: tt
|
|
466
466
|
}
|
|
467
467
|
) : null,
|
|
468
|
-
|
|
468
|
+
et ? /* @__PURE__ */ h.jsx(
|
|
469
469
|
"text",
|
|
470
470
|
{
|
|
471
471
|
x: g - A.right,
|
|
472
472
|
y: A.top - 10,
|
|
473
473
|
className: "text-base font-bold fill-primary-gray-700 dark:fill-primary-gray-100",
|
|
474
474
|
style: { textAnchor: "end" },
|
|
475
|
-
children:
|
|
475
|
+
children: et
|
|
476
476
|
}
|
|
477
477
|
) : null,
|
|
478
478
|
/* @__PURE__ */ h.jsxs("g", { transform: `translate(${A.left},${A.top})`, children: [
|
|
@@ -684,7 +684,7 @@ function de(e) {
|
|
|
684
684
|
},
|
|
685
685
|
onClick: () => {
|
|
686
686
|
(S || D) && (// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
687
|
-
Ht(f, o.data) &&
|
|
687
|
+
Ht(f, o.data) && Q ? (m(void 0), S?.(void 0)) : (m(o.data), S?.(o.data)));
|
|
688
688
|
},
|
|
689
689
|
onMouseLeave: () => {
|
|
690
690
|
r(void 0), E(void 0), H(void 0), $?.(void 0);
|
|
@@ -724,7 +724,7 @@ function de(e) {
|
|
|
724
724
|
children: /* @__PURE__ */ h.jsx(
|
|
725
725
|
mt.path,
|
|
726
726
|
{
|
|
727
|
-
d:
|
|
727
|
+
d: J(o) || "",
|
|
728
728
|
style: {
|
|
729
729
|
stroke: `url(#${X}-gradient-${_})`,
|
|
730
730
|
strokeWidth: o.width,
|
|
@@ -808,11 +808,11 @@ function Ve(e) {
|
|
|
808
808
|
prefix: P = "",
|
|
809
809
|
relativeHeight: T,
|
|
810
810
|
showValues: W = !0,
|
|
811
|
-
graphID:
|
|
812
|
-
onSeriesMouseClick:
|
|
811
|
+
graphID: tt,
|
|
812
|
+
onSeriesMouseClick: et,
|
|
813
813
|
graphDownload: B = !1,
|
|
814
814
|
dataDownload: F = !1,
|
|
815
|
-
fillContainer:
|
|
815
|
+
fillContainer: Q = !0,
|
|
816
816
|
language: D = "en",
|
|
817
817
|
minHeight: I = 0,
|
|
818
818
|
theme: Y = "light",
|
|
@@ -836,7 +836,7 @@ function Ve(e) {
|
|
|
836
836
|
animate: st = !1,
|
|
837
837
|
precision: at = 2,
|
|
838
838
|
customLayers: lt = []
|
|
839
|
-
} = e, [
|
|
839
|
+
} = e, [J, o] = Z(0), [_, U] = Z(0), [Lt, At] = Z(void 0), it = wt(null), Mt = wt(null);
|
|
840
840
|
return _t(() => {
|
|
841
841
|
const L = ot(n, "source").map((w) => ({
|
|
842
842
|
name: `source_${w.source}`,
|
|
@@ -876,20 +876,21 @@ function Ve(e) {
|
|
|
876
876
|
}, [j, $]), /* @__PURE__ */ h.jsx(
|
|
877
877
|
"div",
|
|
878
878
|
{
|
|
879
|
-
className: `${Y || "light"} flex ${j ? "grow-0" : "grow"} ${
|
|
879
|
+
className: `${Y || "light"} flex ${j ? "grow-0" : "grow"} ${Q ? "w-full" : "w-fit"} `,
|
|
880
880
|
dir: D === "he" || D === "ar" ? "rtl" : void 0,
|
|
881
881
|
children: /* @__PURE__ */ h.jsx(
|
|
882
882
|
"div",
|
|
883
883
|
{
|
|
884
884
|
className: rt(
|
|
885
885
|
`${S ? S === !0 ? "bg-primary-gray-200 dark:bg-primary-gray-650 " : "" : "bg-transparent "}ml-auto mr-auto flex flex-col grow h-inherit ${D || "en"}`,
|
|
886
|
+
Q ? "w-full" : "w-fit",
|
|
886
887
|
q?.graphContainer
|
|
887
888
|
),
|
|
888
889
|
style: {
|
|
889
890
|
...G?.graphContainer || {},
|
|
890
891
|
...S && S !== !0 ? { backgroundColor: S } : {}
|
|
891
892
|
},
|
|
892
|
-
id:
|
|
893
|
+
id: tt,
|
|
893
894
|
ref: Mt,
|
|
894
895
|
"aria-label": nt || `${i ? `The graph shows ${i}. ` : ""}This is a sankey chart showing flow. ${l ? ` ${l}` : ""}`,
|
|
895
896
|
children: /* @__PURE__ */ h.jsx(
|
|
@@ -922,16 +923,16 @@ function Ve(e) {
|
|
|
922
923
|
className: "flex flex-col grow justify-center gap-3 w-full leading-0",
|
|
923
924
|
ref: it,
|
|
924
925
|
"aria-label": "Graph area",
|
|
925
|
-
children: (j ||
|
|
926
|
+
children: (j || J) && ($ || _) && Lt ? /* @__PURE__ */ h.jsx(
|
|
926
927
|
de,
|
|
927
928
|
{
|
|
928
929
|
data: Lt,
|
|
929
|
-
width: j ||
|
|
930
|
+
width: j || J,
|
|
930
931
|
nodePadding: r,
|
|
931
932
|
nodeWidth: f,
|
|
932
933
|
height: Math.max(
|
|
933
934
|
I,
|
|
934
|
-
$ || (T ? I ? (j ||
|
|
935
|
+
$ || (T ? I ? (j || J) * T > I ? (j || J) * T : I : (j || J) * T : _)
|
|
935
936
|
),
|
|
936
937
|
showLabels: y,
|
|
937
938
|
leftMargin: g,
|
|
@@ -944,7 +945,7 @@ function Ve(e) {
|
|
|
944
945
|
showValues: W,
|
|
945
946
|
suffix: X,
|
|
946
947
|
prefix: P,
|
|
947
|
-
onSeriesMouseClick:
|
|
948
|
+
onSeriesMouseClick: et,
|
|
948
949
|
id: Ut(8),
|
|
949
950
|
highlightedSourceDataPoints: m.map((L) => `${L}`),
|
|
950
951
|
highlightedTargetDataPoints: C.map((L) => `${L}`),
|