vue-data-ui-hq
Version:
A user-empowering data visualization Vue 3 components library for eloquent data storytelling
629 lines (628 loc) • 25.2 kB
JavaScript
import { ref as i, computed as c, watch as De, onMounted as Ee, onBeforeUnmount as We, openBlock as u, createElementBlock as v, normalizeClass as E, unref as e, normalizeStyle as S, createBlock as _, createCommentVNode as b, createSlots as Ge, withCtx as g, renderSlot as d, normalizeProps as I, guardReactiveProps as M, createVNode as be, createElementVNode as C, Fragment as ke, renderList as Ce, createTextVNode as we, toDisplayString as W, nextTick as He } from "vue";
import { u as je, c as $e, t as Xe, a as Ye, p as x, o as qe, e as q, g as Je, b as Ke, J as Qe, d as Te, f as N, X as Ze, s as et, w as tt, v as J, i as _e, x as ot, y as lt, q as at, r as st } from "./index-WrV3SAID.js";
import { t as nt, u as rt } from "./useResponsive-CoxXLe23.js";
import { _ as it } from "./Title-BR-xoRp4.js";
import { u as ut, U as ct } from "./usePrinter-kVpf1iV8.js";
import { _ as dt } from "./Tooltip-ho4JxRm-.js";
import { D as pt } from "./DataTable-DNPvKWC0.js";
import { L as ht } from "./Legend-7H4oi6Sq.js";
import vt from "./vue-ui-skeleton-Qec_XSRf.js";
import gt from "./vue-ui-accordion-BQCDXXDs.js";
import { u as xe } from "./useNestedProp-Cj0kHD7k.js";
import { _ as ft } from "./PackageVersion-1NslmM8M.js";
import { P as yt } from "./PenAndPaper-BF1ZRVm3.js";
import { u as mt } from "./useUserOptionState-BIvW1Kz7.js";
import { _ as bt } from "./_plugin-vue_export-helper-CHgC5LLL.js";
const kt = ["id"], Ct = ["xmlns", "viewBox"], wt = ["width", "height"], $t = ["id"], Tt = ["stop-color"], _t = ["stop-color"], xt = ["stroke", "cx", "cy", "r", "fill"], Nt = ["stroke", "stroke-width", "cx", "cy", "r", "fill"], Ot = ["cx", "cy", "r", "onMouseenter"], Pt = {
key: 5,
class: "vue-data-ui-watermark"
}, St = ["onClick"], Lt = { key: 0 }, At = { key: 1 }, Ft = ["innerHTML"], It = {
__name: "vue-ui-rings",
props: {
config: {
type: Object,
default() {
return {};
}
},
dataset: {
type: Array,
default() {
return [];
}
}
},
emits: ["selectLegend"],
setup(Ne, { expose: Oe, emit: Pe }) {
const { vue_ui_rings: Se } = je(), y = Ne, L = i(!1), V = c(() => !!y.dataset && y.dataset.length), A = i($e()), Le = i(null), z = i(!1), G = i(""), T = i(null), K = i(0), O = i(null), Q = i(null), Z = i(null), ee = i(null), te = i(null), oe = i(0), le = i(0), ae = i(0), t = c({
get: () => re(),
set: (o) => o
}), { userOptionsVisible: H, setUserOptionsVisibility: se, keepUserOptionState: ne } = mt({ config: t.value });
function re() {
const o = xe({
userConfig: y.config,
defaultConfig: Se
});
return o.theme ? {
...xe({
userConfig: Xe.vue_ui_rings[o.theme] || y.config,
defaultConfig: o
}),
customPalette: Ye[o.theme] || x
} : o;
}
De(() => y.config, (o) => {
t.value = re(), H.value = !t.value.showOnChartHover, ie(), oe.value += 1, le.value += 1, ae.value += 1;
}, { deep: !0 });
const R = i(null);
Ee(() => {
ie();
});
function ie() {
if (qe(y.dataset) ? q({
componentName: "VueUiRings",
type: "dataset"
}) : y.dataset.forEach((o, a) => {
o.values.length || q({
componentName: "VueUiRings",
type: "dataset"
}), Je({
datasetObject: o,
requiredAttributes: ["name", "values"]
}).forEach((l) => {
q({
componentName: "VueUiRings",
type: "datasetSerieAttribute",
property: l,
index: a
});
});
}), t.value.responsive) {
const o = nt(() => {
const { width: a, height: l } = rt({
chart: O.value,
title: t.value.style.chart.title.text ? Q.value : null,
legend: t.value.style.chart.legend.show ? Z.value : null,
source: ee.value,
noTitle: te.value
});
r.value.width = a, r.value.height = l;
});
R.value = new ResizeObserver(o), R.value.observe(O.value.parentNode);
}
setTimeout(() => {
L.value = !0;
}, 600);
}
We(() => {
R.value && R.value.disconnect();
});
const { isPrinting: ue, isImaging: ce, generatePdf: de, generateImage: pe } = ut({
elementId: `rings_${A.value}`,
fileName: t.value.style.chart.title.text || "vue-ui-rings"
}), Ae = c(() => t.value.userOptions.show && !t.value.style.chart.title.text), he = c(() => Ke(t.value.customPalette)), w = i({
showTable: t.value.table.show,
showTooltip: t.value.style.chart.tooltip.show
}), r = i({
height: 360,
width: 360
}), Fe = c(() => Math.min(r.value.height, r.value.width)), Ie = Pe, p = i([]);
function j(o) {
p.value.includes(o) ? p.value = p.value.filter((a) => a !== o) : p.value.push(o), Ie("selectLegend", h.value.map((a) => ({
name: a.name,
color: a.color,
value: a.value
})));
}
const Me = c(() => Math.max(
...U.value.filter((o) => !p.value.includes(o.uid)).map(({ value: o }) => o)
));
function ve(o) {
return o / Me.value;
}
const U = c(() => y.dataset.map(({ values: o, name: a, color: l = null }, s) => {
const n = Qe(o).reduce((k, F) => k + F, 0);
return {
name: a,
color: l || Te(l) || he.value[s] || x[s] || x[s % x.length],
value: n,
proportion: n / y.dataset.map((k) => (k.values || []).reduce((F, Be) => F + Be, 0)).reduce((k, F) => k + F, 0),
uid: $e()
};
})), ge = c(() => U.value.map((o) => ({
...o,
shape: "circle",
opacity: p.value.includes(o.uid) ? 0.5 : 1,
segregate: () => j(o.uid),
isSegregated: p.value.includes(o.uid)
})).toSorted((o, a) => a.value - o.value)), Ve = c(() => ({
cy: "rings-div-legend",
backgroundColor: t.value.style.chart.legend.backgroundColor,
color: t.value.style.chart.legend.color,
fontSize: t.value.style.chart.legend.fontSize,
paddingBottom: 12,
fontWeight: t.value.style.chart.legend.bold ? "bold" : ""
})), m = c(() => U.value.filter((o) => !p.value.includes(o.uid)).map(({ value: o }) => o).reduce((o, a) => o + a, 0)), h = c(() => U.value.filter((o) => !p.value.includes(o.uid)).map(({ name: o, value: a, color: l = null, uid: s }, n) => ({
uid: s,
name: o,
color: l || Te(l) || he.value[n] || x[n] || x[n % x.length],
value: a,
proportion: ve(a),
percentage: a / m.value * 100,
strokeWidth: t.value.style.chart.layout.rings.strokeWidth * ve(a)
})).toSorted((o, a) => a.value - o.value));
function ze() {
return h.value.map(
({ name: o, color: a, value: l, absoluteValues: s, percentage: n }) => ({
name: o,
color: a,
value: l,
absoluteValues: s,
percentage: n
})
);
}
const f = c(() => Fe.value - t.value.style.chart.layout.rings.strokeWidth * 2), X = i(null);
function Re(o, a) {
if (p.value.length === y.dataset.length) return;
X.value = {
datapoint: a,
seriesIndex: o,
series: h.value,
config: t.value
}, T.value = o;
const l = h.value[o], s = t.value.style.chart.tooltip.customFormat;
if (ot(s) && lt(() => s({
seriesIndex: o,
datapoint: a,
series: h.value,
config: t.value
})))
G.value = s({
seriesIndex: o,
datapoint: a,
series: h.value,
config: t.value
});
else {
let n = "";
n += `<div style="width:100%;text-align:center;border-bottom:1px solid ${t.value.style.chart.tooltip.borderColor};padding-bottom:6px;margin-bottom:3px;">${l.name}</div>`, n += `<div style="display:flex;flex-direction:row;gap:6px;align-items:center;"><svg viewBox="0 0 12 12" height="14" width="14"><circle cx="6" cy="6" r="6" stroke="none" fill="${l.color}" /></svg>`, t.value.style.chart.tooltip.showValue && (n += `<b>${_e(
t.value.style.chart.layout.labels.dataLabels.formatter,
l.value,
N({
p: t.value.style.chart.layout.labels.dataLabels.prefix,
v: l.value,
s: t.value.style.chart.layout.labels.dataLabels.suffix,
r: t.value.style.chart.tooltip.roundingValue
}),
{ datapoint: a, seriesIndex: o }
)}
</b>`), t.value.style.chart.tooltip.showPercentage && (t.value.style.chart.tooltip.showValue ? n += `<span>(${N({
v: l.value / m.value * 100,
s: "%",
r: t.value.style.chart.tooltip.roundingPercentage
})})</span></div>` : n += `<b>${N({
v: l.value / m.value * 100,
s: "%",
r: t.value.style.chart.tooltip.roundingPercentage
})}</b></div>`), G.value = n;
}
z.value = !0;
}
const $ = c(() => {
const o = h.value.map((l) => ({
name: l.name,
color: l.color
})), a = h.value.map((l) => l.value);
return { head: o, body: a };
}), B = c(() => {
const o = [
' <svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" viewBox="0 0 24 24" stroke-width="1.5" stroke="currentColor" fill="none" stroke-linecap="round" stroke-linejoin="round"><path stroke="none" d="M0 0h24v24H0z" fill="none"/><path d="M18 16v2a1 1 0 0 1 -1 1h-11l6 -7l-6 -7h11a1 1 0 0 1 1 1v2" /></svg>',
N({ p: t.value.style.chart.layout.labels.dataLabels.prefix, v: m.value, s: t.value.style.chart.layout.labels.dataLabels.suffix, r: t.value.table.td.roundingValue }),
"100%"
], a = $.value.head.map((n, k) => [
{
color: n.color,
name: n.name
},
N({ p: t.value.style.chart.layout.labels.dataLabels.prefix, v: $.value.body[k], s: t.value.style.chart.layout.labels.dataLabels.suffix, r: t.value.table.td.roundingValue }),
isNaN($.value.body[k] / m.value) ? "-" : ($.value.body[k] / m.value * 100).toFixed(t.value.table.td.roundingPercentage) + "%"
]), l = {
th: {
backgroundColor: t.value.table.th.backgroundColor,
color: t.value.table.th.color,
outline: t.value.table.th.outline
},
td: {
backgroundColor: t.value.table.td.backgroundColor,
color: t.value.table.td.color,
outline: t.value.table.td.outline
},
breakpoint: t.value.table.responsiveBreakpoint
}, s = [
t.value.table.columnNames.series,
t.value.table.columnNames.value,
t.value.table.columnNames.percentage
];
return {
head: o,
body: a,
config: l,
colNames: s
};
});
function fe() {
He(() => {
const o = $.value.head.map((s, n) => [[
s.name
], [$.value.body[n]], [isNaN($.value.body[n] / m.value) ? "-" : $.value.body[n] / m.value * 100]]), a = [[t.value.style.chart.title.text], [t.value.style.chart.title.subtitle.text], [[""], ["val"], ["%"]]].concat(o), l = at(a);
st({ csvContent: l, title: t.value.style.chart.title.text || "vue-ui-rings" });
});
}
const P = i(!1);
function Ue(o) {
P.value = o, K.value += 1;
}
function ye() {
w.value.showTable = !w.value.showTable;
}
function me() {
w.value.showTooltip = !w.value.showTooltip;
}
const D = i(!1);
function Y() {
D.value = !D.value;
}
return Oe({
getData: ze,
generatePdf: de,
generateCsv: fe,
generateImage: pe,
toggleTable: ye,
toggleTooltip: me,
toggleAnnotator: Y
}), (o, a) => (u(), v("div", {
ref_key: "ringsChart",
ref: O,
class: E(`vue-ui-rings ${e(P) ? "vue-data-ui-wrapper-fullscreen" : ""} ${e(t).useCssAnimation ? "" : "vue-ui-dna"}`),
style: S(`font-family:${e(t).style.fontFamily};text-align:center;width:100%;background:${e(t).style.chart.backgroundColor};${e(t).responsive ? "height: 100%" : ""}`),
id: `rings_${e(A)}`,
onMouseleave: a[3] || (a[3] = (l) => {
T.value = null, z.value = !1, e(se)(!1);
}),
onMouseenter: a[4] || (a[4] = () => e(se)(!0))
}, [
e(t).userOptions.buttons.annotator ? (u(), _(yt, {
key: 0,
parent: e(O),
backgroundColor: e(t).style.chart.backgroundColor,
color: e(t).style.chart.color,
active: e(D),
onClose: Y
}, null, 8, ["parent", "backgroundColor", "color", "active"])) : b("", !0),
e(Ae) ? (u(), v("div", {
key: 1,
ref_key: "noTitle",
ref: te,
class: "vue-data-ui-no-title-space",
style: "height:36px; width: 100%;background:transparent"
}, null, 512)) : b("", !0),
e(t).style.chart.title.text ? (u(), v("div", {
key: 2,
ref_key: "chartTitle",
ref: Q,
style: "width:100%;background:transparent"
}, [
(u(), _(it, {
key: `title_${e(oe)}`,
config: {
title: {
cy: "rings-div-title",
...e(t).style.chart.title
},
subtitle: {
cy: "rings-div-subtitle",
...e(t).style.chart.title.subtitle
}
}
}, null, 8, ["config"]))
], 512)) : b("", !0),
e(t).userOptions.show && e(V) && (e(ne) || e(H)) ? (u(), _(ct, {
ref_key: "details",
ref: Le,
key: `user_options_${e(K)}`,
backgroundColor: e(t).style.chart.backgroundColor,
color: e(t).style.chart.color,
isPrinting: e(ue),
isImaging: e(ce),
uid: e(A),
hasTooltip: e(t).userOptions.buttons.tooltip && e(t).style.chart.tooltip.show,
hasPdf: e(t).userOptions.buttons.pdf,
hasXls: e(t).userOptions.buttons.csv,
hasImg: e(t).userOptions.buttons.img,
hasTable: e(t).userOptions.buttons.table,
hasFullscreen: e(t).userOptions.buttons.fullscreen,
isTooltip: e(w).showTooltip,
isFullscreen: e(P),
titles: { ...e(t).userOptions.buttonTitles },
chartElement: e(O),
position: e(t).userOptions.position,
hasAnnotator: e(t).userOptions.buttons.annotator,
isAnnotation: e(D),
onToggleFullscreen: Ue,
onGeneratePdf: e(de),
onGenerateCsv: fe,
onGenerateImage: e(pe),
onToggleTable: ye,
onToggleTooltip: me,
onToggleAnnotator: Y,
style: S({
visibility: e(ne) ? e(H) ? "visible" : "hidden" : "visible"
})
}, Ge({ _: 2 }, [
o.$slots.optionTooltip ? {
name: "optionTooltip",
fn: g(() => [
d(o.$slots, "optionTooltip", {}, void 0, !0)
]),
key: "0"
} : void 0,
o.$slots.optionPdf ? {
name: "optionPdf",
fn: g(() => [
d(o.$slots, "optionPdf", {}, void 0, !0)
]),
key: "1"
} : void 0,
o.$slots.optionCsv ? {
name: "optionCsv",
fn: g(() => [
d(o.$slots, "optionCsv", {}, void 0, !0)
]),
key: "2"
} : void 0,
o.$slots.optionImg ? {
name: "optionImg",
fn: g(() => [
d(o.$slots, "optionImg", {}, void 0, !0)
]),
key: "3"
} : void 0,
o.$slots.optionTable ? {
name: "optionTable",
fn: g(() => [
d(o.$slots, "optionTable", {}, void 0, !0)
]),
key: "4"
} : void 0,
o.$slots.optionFullscreen ? {
name: "optionFullscreen",
fn: g(({ toggleFullscreen: l, isFullscreen: s }) => [
d(o.$slots, "optionFullscreen", I(M({ toggleFullscreen: l, isFullscreen: s })), void 0, !0)
]),
key: "5"
} : void 0,
o.$slots.optionAnnotator ? {
name: "optionAnnotator",
fn: g(({ toggleAnnotator: l, isAnnotator: s }) => [
d(o.$slots, "optionAnnotator", I(M({ toggleAnnotator: l, isAnnotator: s })), void 0, !0)
]),
key: "6"
} : void 0
]), 1032, ["backgroundColor", "color", "isPrinting", "isImaging", "uid", "hasTooltip", "hasPdf", "hasXls", "hasImg", "hasTable", "hasFullscreen", "isTooltip", "isFullscreen", "titles", "chartElement", "position", "hasAnnotator", "isAnnotation", "onGeneratePdf", "onGenerateImage", "style"])) : b("", !0),
e(V) ? (u(), v("svg", {
key: 4,
xmlns: e(Ze),
class: E({ "vue-data-ui-fullscreen--on": e(P), "vue-data-ui-fulscreen--off": !e(P) }),
viewBox: `0 0 ${e(r).width <= 0 ? 10 : e(r).width} ${e(r).height <= 0 ? 10 : e(r).height}`,
style: S(`max-width:100%;overflow:visible;background:transparent;color:${e(t).style.chart.color}`)
}, [
be(ft),
o.$slots["chart-background"] ? (u(), v("foreignObject", {
key: 0,
x: 0,
y: 0,
width: e(r).width <= 0 ? 10 : e(r).width,
height: e(r).height <= 0 ? 10 : e(r).height,
style: {
pointerEvents: "none"
}
}, [
d(o.$slots, "chart-background", {}, void 0, !0)
], 8, wt)) : b("", !0),
C("defs", null, [
(u(!0), v(ke, null, Ce(e(h), (l, s) => (u(), v("radialGradient", {
cx: "50%",
cy: "30%",
r: "50%",
fx: "50%",
fy: "50%",
id: `gradient_${e(A)}_${s}`
}, [
C("stop", {
offset: "0%",
"stop-color": e(et)(e(tt)(l.color, 0.05), 100 - e(t).style.chart.layout.rings.gradient.intensity)
}, null, 8, Tt),
C("stop", {
offset: "100%",
"stop-color": l.color
}, null, 8, _t)
], 8, $t))), 256))
]),
(u(!0), v(ke, null, Ce(e(h), (l, s) => (u(), v("g", null, [
C("circle", {
class: E({
"vue-ui-rings-item": e(L) && e(t).useCssAnimation,
"vue-rings-item-onload": !e(L) && e(t).useCssAnimation,
"vue-ui-rings-opacity": e(T) !== null && e(T) !== s
}),
style: S(`animation-delay:${s * 100}ms`),
stroke: e(t).style.chart.layout.rings.stroke,
cx: e(r).width / 2,
cy: s === 0 ? e(r).height / 2 : e(r).height / 2 + e(f) * e(h)[0].proportion / 2 - e(f) * l.proportion / 2 - 2 * (s + 1),
r: e(J)(e(f) * l.proportion / 2 * 0.9 <= 0 ? 1e-4 : e(f) * l.proportion / 2 * 0.9),
fill: e(t).style.chart.layout.rings.gradient.underlayerColor
}, null, 14, xt),
C("circle", {
class: E({
"vue-ui-rings-item": e(L) && e(t).useCssAnimation,
"vue-rings-item-onload": !e(L) && e(t).useCssAnimation,
"vue-ui-rings-shadow": e(t).style.chart.layout.rings.useShadow,
"vue-ui-rings-blur": e(T) !== null && e(T) !== s
}),
style: S(`animation-delay:${s * 100}ms`),
stroke: e(t).style.chart.layout.rings.stroke,
"stroke-width": l.strokeWidth < 0.5 ? 0.5 : l.strokeWidth,
cx: e(r).width / 2,
cy: s === 0 ? e(r).height / 2 : e(r).height / 2 + e(f) * e(h)[0].proportion / 2 - e(f) * l.proportion / 2 - 2 * (s + 1),
r: e(J)(e(f) * l.proportion / 2 * 0.9 <= 0 ? 1e-4 : e(f) * l.proportion / 2 * 0.9),
fill: e(t).style.chart.layout.rings.gradient.show ? `url(#gradient_${e(A)}_${s})` : l.color
}, null, 14, Nt),
C("circle", {
"data-cy-trap": "",
stroke: "none",
cx: e(r).width / 2,
cy: s === 0 ? e(r).height / 2 : e(r).height / 2 + e(f) * e(h)[0].proportion / 2 - e(f) * l.proportion / 2 - 2 * (s + 1),
r: e(J)(e(f) * l.proportion / 2 * 0.9 <= 0 ? 1e-4 : e(f) * l.proportion / 2 * 0.9),
fill: "transparent",
onMouseenter: (n) => Re(s, l),
onMouseleave: a[0] || (a[0] = (n) => {
T.value = null, z.value = !1;
})
}, null, 40, Ot)
]))), 256)),
d(o.$slots, "svg", { svg: e(r) }, void 0, !0)
], 14, Ct)) : b("", !0),
o.$slots.watermark ? (u(), v("div", Pt, [
d(o.$slots, "watermark", I(M({ isPrinting: e(ue) || e(ce) })), void 0, !0)
])) : b("", !0),
e(V) ? b("", !0) : (u(), _(vt, {
key: 6,
config: {
type: "rings",
style: {
backgroundColor: e(t).style.chart.backgroundColor,
rings: {
color: "#CCCCCC"
}
}
}
}, null, 8, ["config"])),
C("div", {
ref_key: "chartLegend",
ref: Z
}, [
e(t).style.chart.legend.show ? (u(), _(ht, {
key: `legend_${e(ae)}`,
legendSet: e(ge),
config: e(Ve),
onClickMarker: a[1] || (a[1] = ({ legend: l }) => j(l.uid))
}, {
item: g(({ legend: l, index: s }) => [
C("div", {
"data-cy-legend-item": "",
onClick: (n) => j(l.uid),
style: S(`opacity:${e(p).includes(l.uid) ? 0.5 : 1}`)
}, [
we(W(l.name) + ": " + W(e(_e)(
e(t).style.chart.layout.labels.dataLabels.formatter,
l.value,
e(N)({
p: e(t).style.chart.layout.labels.dataLabels.prefix,
v: l.value,
s: e(t).style.chart.layout.labels.dataLabels.suffix,
r: e(t).style.chart.legend.roundingValue
}),
{ datapoint: l, seriesIndex: s }
)) + " ", 1),
e(p).includes(l.uid) ? (u(), v("span", At, " ( - % ) ")) : (u(), v("span", Lt, " (" + W(isNaN(l.value / e(m)) ? "-" : e(N)({
v: l.value / e(m) * 100,
s: "%",
r: e(t).style.chart.legend.roundingPercentage
})) + ") ", 1))
], 12, St)
]),
_: 1
}, 8, ["legendSet", "config"])) : d(o.$slots, "legend", {
key: 1,
legend: e(ge)
}, void 0, !0)
], 512),
o.$slots.source ? (u(), v("div", {
key: 7,
ref_key: "source",
ref: ee,
dir: "auto"
}, [
d(o.$slots, "source", {}, void 0, !0)
], 512)) : b("", !0),
be(dt, {
show: e(w).showTooltip && e(z) && e(p).length < y.dataset.length,
backgroundColor: e(t).style.chart.tooltip.backgroundColor,
color: e(t).style.chart.tooltip.color,
borderRadius: e(t).style.chart.tooltip.borderRadius,
borderColor: e(t).style.chart.tooltip.borderColor,
borderWidth: e(t).style.chart.tooltip.borderWidth,
fontSize: e(t).style.chart.tooltip.fontSize,
backgroundOpacity: e(t).style.chart.tooltip.backgroundOpacity,
position: e(t).style.chart.tooltip.position,
offsetY: e(t).style.chart.tooltip.offsetY,
parent: e(O),
content: e(G),
isFullscreen: e(P),
isCustom: e(t).style.chart.tooltip.customFormat && typeof e(t).style.chart.tooltip.customFormat == "function"
}, {
"tooltip-before": g(() => [
d(o.$slots, "tooltip-before", I(M({ ...e(X) })), void 0, !0)
]),
"tooltip-after": g(() => [
d(o.$slots, "tooltip-after", I(M({ ...e(X) })), void 0, !0)
]),
_: 3
}, 8, ["show", "backgroundColor", "color", "borderRadius", "borderColor", "borderWidth", "fontSize", "backgroundOpacity", "position", "offsetY", "parent", "content", "isFullscreen", "isCustom"]),
e(V) ? (u(), _(gt, {
key: 8,
hideDetails: "",
config: {
open: e(w).showTable,
maxHeight: 1e4,
body: {
backgroundColor: e(t).style.chart.backgroundColor,
color: e(t).style.chart.color
},
head: {
backgroundColor: e(t).style.chart.backgroundColor,
color: e(t).style.chart.color
}
}
}, {
content: g(() => [
(u(), _(pt, {
key: `table_${e(le)}`,
colNames: e(B).colNames,
head: e(B).head,
body: e(B).body,
config: e(B).config,
title: `${e(t).style.chart.title.text}${e(t).style.chart.title.subtitle.text ? ` : ${e(t).style.chart.title.subtitle.text}` : ""}`,
onClose: a[2] || (a[2] = (l) => e(w).showTable = !1)
}, {
th: g(({ th: l }) => [
C("div", {
innerHTML: l,
style: { display: "flex", "align-items": "center" }
}, null, 8, Ft)
]),
td: g(({ td: l }) => [
we(W(l.name || l), 1)
]),
_: 1
}, 8, ["colNames", "head", "body", "config", "title"]))
]),
_: 1
}, 8, ["config"])) : b("", !0)
], 46, kt));
}
}, Jt = /* @__PURE__ */ bt(It, [["__scopeId", "data-v-2434d661"]]);
export {
Jt as default
};