UNPKG

vue-data-ui-hq

Version:

A user-empowering data visualization Vue 3 components library for eloquent data storytelling

767 lines (766 loc) 31.7 kB
import { computed as b, ref as h, watch as Ge, onMounted as Xe, onBeforeUnmount as Ye, openBlock as r, createElementBlock as u, normalizeClass as U, unref as e, normalizeStyle as T, createBlock as z, createCommentVNode as v, createSlots as qe, withCtx as k, renderSlot as x, normalizeProps as W, guardReactiveProps as E, createVNode as _e, Fragment as C, renderList as I, createElementVNode as F, toDisplayString as D, createTextVNode as Qe } from "vue"; import { u as Je, c as ee, t as Ke, a as Ze, p as H, o as et, e as Me, g as tt, b as ot, d as at, D as st, Q as lt, R as nt, S as it, X as rt, x as ze, i as Ie, f as Fe, y as ut, q as ct, r as dt, F as G } from "./index-WrV3SAID.js"; import { t as ht, u as pt } from "./useResponsive-CoxXLe23.js"; import { _ as mt } from "./Title-BR-xoRp4.js"; import { L as vt } from "./Legend-7H4oi6Sq.js"; import { _ as yt } from "./Tooltip-ho4JxRm-.js"; import { _ as ft } from "./Shape-DNIrFW-J.js"; import { u as gt, U as bt } from "./usePrinter-kVpf1iV8.js"; import { D as xt } from "./DataTable-DNPvKWC0.js"; import kt from "./vue-ui-accordion-BQCDXXDs.js"; import wt from "./vue-ui-skeleton-Qec_XSRf.js"; import { u as Pe } from "./useNestedProp-Cj0kHD7k.js"; import { _ as Ct } from "./PackageVersion-1NslmM8M.js"; import { P as $t } from "./PenAndPaper-BF1ZRVm3.js"; import { u as At } from "./useUserOptionState-BIvW1Kz7.js"; import { _ as Tt } from "./_plugin-vue_export-helper-CHgC5LLL.js"; const _t = ["id"], Mt = ["xmlns", "viewBox"], zt = ["x", "y", "width", "height"], It = { style: { "pointer-events": "none" } }, Ft = ["x1", "x2", "y1", "y2", "stroke", "stroke-width"], Pt = ["x", "y", "fill", "font-size", "font-weight"], Nt = ["x1", "x2", "y1", "y2", "stroke", "stroke-width"], St = ["x", "y", "fill", "font-size", "font-weight"], Lt = { key: 0 }, Ot = ["x", "y", "font-size", "fill"], Dt = ["width", "x", "y"], Ut = { style: { width: "100%" } }, Wt = ["x", "y", "fill", "font-weight", "font-size", "onMouseenter"], Et = ["d", "stroke", "stroke-width", "onMouseenter"], Vt = ["d", "onMouseenter"], jt = { key: 5, class: "vue-data-ui-watermark" }, Bt = ["onClick"], Rt = ["innerHTML"], Ht = { __name: "vue-ui-parallel-coordinate-plot", props: { config: { type: Object, default() { return {}; } }, dataset: { type: Array, default() { return []; } } }, emits: ["selectLegend", "selectDatapoint"], setup(Ne, { expose: Se, emit: Le }) { const { vue_ui_parallel_coordinate_plot: Oe } = Je(), _ = Ne, P = b({ get() { return !!_.dataset && _.dataset.length; }, set(o) { return o; } }), te = h(0), N = h(null), oe = h(null), ae = h(null), se = h(null), le = h(null), ne = h(0), ie = h(0), re = h(0), X = h(ee()), S = h(!1); function De(o) { S.value = o, te.value += 1; } const t = b({ get: () => de(), set: (o) => o }), { userOptionsVisible: Y, setUserOptionsVisibility: ue, keepUserOptionState: ce } = At({ config: t.value }); function de() { const o = Pe({ userConfig: _.config, defaultConfig: Oe }); return o.theme ? { ...Pe({ userConfig: Ke.vue_ui_parallel_coordinate_plot[o.theme] || _.config, defaultConfig: o }), customPalette: Ze[o.theme] || H } : o; } Ge(() => _.config, (o) => { t.value = de(), Y.value = !t.value.showOnChartHover, he(), ne.value += 1, re.value += 1, ie.value += 1; }, { deep: !0 }); const V = h(null); Xe(() => { he(); }); function he() { if (et(_.dataset) ? Me({ componentName: "VueUiParallelCoordinatePlot", type: "dataset" }) : _.dataset.forEach((o, s) => { tt({ datasetObject: o, requiredAttributes: ["name", "series"] }).forEach((a) => { P.value = !1, Me({ componentName: "VueUiParallelCoordinatePlot", type: "datasetSerieAttribute", property: a, index: s }); }); }), t.value.responsive) { const o = ht(() => { const { width: s, height: a } = pt({ chart: N.value, title: t.value.style.chart.title.text ? oe.value : null, legend: t.value.style.chart.legend.show ? ae.value : null, source: se.value, noTitle: le.value }); p.value.width = s, p.value.height = a, p.value.plotSize = G({ relator: Math.min(s, a), adjuster: 600, source: t.value.style.chart.plots.radius, threshold: 2, fallback: 2 }), p.value.ticksFontSize = G({ relator: Math.min(s, a), adjuster: 600, source: t.value.style.chart.yAxis.labels.ticks.fontSize, threshold: 10, fallback: 10 }), p.value.datapointFontSize = G({ relator: Math.min(s, a), adjuster: 600, source: t.value.style.chart.yAxis.labels.datapoints.fontSize, threshold: 10, fallback: 10 }), p.value.axisNameFontSize = G({ relator: Math.min(s, a), adjuster: 600, source: t.value.style.chart.yAxis.labels.axisNamesFontSize, threshold: 12, fallback: 12 }); }); V.value = new ResizeObserver(o), V.value.observe(N.value.parentNode); } } Ye(() => { V.value && V.value.disconnect(); }); const { isPrinting: pe, isImaging: me, generatePdf: ve, generateImage: ye } = gt({ elementId: `pcp_${X.value}`, fileName: t.value.style.chart.title.text || "vue-ui-parallel-coordinate-plot" }), Ue = b(() => t.value.userOptions.show && !t.value.style.chart.title.text), p = h({ height: t.value.style.chart.height, width: t.value.style.chart.width, plotSize: t.value.style.chart.plots.radius, // ratio 100 ticksFontSize: t.value.style.chart.yAxis.labels.ticks.fontSize, // ratio 42.85 datapointFontSize: t.value.style.chart.yAxis.labels.datapoints.fontSize, axisNameFontSize: t.value.style.chart.yAxis.labels.axisNamesFontSize }), d = b(() => { const { top: o, right: s, bottom: a, left: l } = t.value.style.chart.padding, i = p.value.height, n = p.value.width; return { chartHeight: i, chartWidth: n, height: i - o - a, width: n - l - s, top: o, left: l, right: n - s, bottom: i - a }; }), We = b(() => ot(t.value.customPalette)), f = h({ dataLabels: { show: t.value.style.chart.yAxis.labels.datapoints.show }, showTable: t.value.table.show, showTooltip: t.value.style.chart.tooltip.show }), $ = h([]); function fe(o) { $.value.includes(o) ? $.value = $.value.filter((s) => s !== o) : $.value.push(o); } const M = b(() => _.dataset.map((o, s) => { const a = at(o.color) || We.value[s] || H[s] || H[s % H.length]; return { ...o, series: o.series.map((l) => ({ ...l, id: ee(), color: a })), seriesIndex: s, color: a, id: ee(), shape: o.shape || "circle" }; })), Ee = b(() => M.value.map((o) => ({ ...o, opacity: $.value.includes(o.id) ? 0.5 : 1, segregate: () => fe(o.id), isSegregated: $.value.includes(o.id) }))), Ve = b(() => ({ cy: "pcp-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" : "" })), ge = b(() => Math.max( ...M.value.filter((o) => !$.value.includes(o.id)).map((o) => Math.max(...o.series.flatMap((s) => s.values.length))) )), w = b(() => d.value.width / ge.value), q = b(() => M.value.filter((o) => !$.value.includes(o.id))), g = b(() => { let o = []; for (let s = 0; s < ge.value; s += 1) { const a = Math.min(...q.value.flatMap((m) => m.series.map((R) => R.values[s] || 0) || 0)), l = Math.max(...q.value.flatMap((m) => m.series.map((R) => R.values[s] || 0) || 0)), i = l === a ? a / 4 : a, n = l === a ? l * 2 : l, c = st(i, n, t.value.style.chart.yAxis.scaleTicks), A = c.ticks.map((m, R) => { const Re = c.min < 0 ? m + Math.abs(c.min) : m - Math.abs(c.min), He = c.min < 0 ? c.max + Math.abs(c.min) : c.max - Math.abs(c.min); return { y: d.value.bottom - d.value.height * (Re / He), x: d.value.left + w.value * s + w.value / 2, value: m }; }); o.push({ scale: c, ticks: A, name: t.value.style.chart.yAxis.labels.axisNames[s] || `Y-${s + 1}` }); } return o; }), Q = b(() => q.value.map((o, s) => ({ ...o, series: o.series.map((a, l) => ({ ...a, datapoints: a.values.map((i, n) => { const c = g.value[n].scale.min < 0 ? (i || 0) + Math.abs(g.value[n].scale.min) : (i || 0) - Math.abs(g.value[n].scale.min), A = g.value[n].scale.min < 0 ? g.value[n].scale.max + Math.abs(g.value[n].scale.min) : g.value[n].scale.max - Math.abs(g.value[n].scale.min); return { name: a.name, seriesName: o.name, axisIndex: n, datapointIndex: l, seriesIndex: s, value: i || 0, x: d.value.left + w.value * n + w.value / 2, y: d.value.bottom - d.value.height * (c / A), comment: a.comments && a.comments[n] || "" }; }) })) })).map((o) => ({ ...o, series: o.series.map((s) => { const a = lt(s.datapoints), l = nt(s.datapoints), i = it(t.value.style.chart.lines.smooth ? `M ${l}` : `M ${a}`); return { ...s, smoothPath: l, straightPath: a, pathLength: i }; }) }))); function be({ value: o, index: s, datapoint: a }) { return Ie( t.value.style.chart.yAxis.labels.formatters[s] || null, o, Fe({ p: t.value.style.chart.yAxis.labels.prefixes[s] || "", v: o, s: t.value.style.chart.yAxis.labels.suffixes[s] || "", r: t.value.style.chart.yAxis.labels.roundings[s] || 0 }), { datapoint: a, seriesIndex: s } ); } const y = h(null), J = h(null), L = h(!1), K = h(""); function j({ shape: o, serieName: s, serie: a, relativeIndex: l, seriesIndex: i }) { J.value = { serie: a, relativeIndex: l, seriesIndex: i, series: M.value, scales: g.value }, L.value = !0, y.value = a.id; let n = ""; const c = t.value.style.chart.tooltip.customFormat; ze(c) && ut(() => c({ serie: a, seriesIndex: a.seriesIndex, series: M.value, config: t.value, scales: g.value })) ? K.value = c({ serie: a, seriesIndex: a.seriesIndex, series: M.value, config: t.value, scales: g.value }) : (n += `<div style="width:100%;text-align:center;border-bottom:1px solid ${t.value.style.chart.tooltip.borderColor};padding-bottom:6px;margin-bottom:3px;">${s ? s + " - " : ""}${a.name}</div>`, g.value.map((A) => A.name).forEach((A, m) => { n += ` <div class="vue-ui-tooltip-item" style="text-align:left"> <span>${A}: </span> <span> ${Ie( t.value.style.chart.yAxis.labels.formatters[m] || null, a.datapoints[m].value, Fe({ p: t.value.style.chart.yAxis.labels.prefixes[m] || "", v: a.datapoints[m].value, s: t.value.style.chart.yAxis.labels.suffixes[m] || "", r: t.value.style.chart.yAxis.labels.roundings[m] || "" }), { datapoint: a.datapoints[m], seriesIndex: m } )} </span> </div> `, t.value.style.chart.comments.showInTooltip && a.datapoints[m].comment && (n += `<div class="vue-data-ui-tooltip-comment" style="background:${a.color}20; padding: 6px; margin-bottom: 6px; border-left: 1px solid ${a.color}">${a.datapoints[m].comment}</div>`); }), K.value = `<div>${n}</div>`); } function je() { return M.value; } const O = b(() => { const o = [t.value.table.columnNames.series].concat([t.value.table.columnNames.item]).concat(g.value.map((i) => i.name)), s = Q.value.flatMap((i, n) => i.series.map((c) => [i.name].concat([c.name]).concat(c.values))), a = { 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 }, l = [t.value.table.columnNames.series].concat([t.value.table.columnNames.item]).concat(g.value.map((i) => i.name)); return { body: s, head: o, config: a, colNames: l }; }), xe = b(() => Q.value.length === 0 ? { head: [], body: [], config: {}, columnNames: [] } : { head: O.value.head, body: O.value.body }); function ke() { const o = [[t.value.style.chart.title.text], [t.value.style.chart.title.subtitle.text], [""]], s = xe.value.head, a = xe.value.body, l = o.concat([s]).concat(a), i = ct(l); dt({ csvContent: i, title: t.value.style.chart.title.text || "vue-ui-parallel-coordinate-plot" }); } const we = Le; function Be(o) { we("selectDatapoint", o); } function Ce(o) { we("selectLegend", { ...o, isSegregated: !o.isSegregated, opacity: o.isSegregated ? 1 : 0.5 }); } function $e() { f.value.showTable = !f.value.showTable; } function Ae() { f.value.dataLabels.show = !f.value.dataLabels.show; } function Te() { f.value.showTooltip = !f.value.showTooltip; } const B = h(!1); function Z() { B.value = !B.value; } return Se({ getData: je, generateCsv: ke, generatePdf: ve, generateImage: ye, toggleTable: $e, toggleLabels: Ae, toggleTooltip: Te, toggleAnnotator: Z }), (o, s) => (r(), u("div", { ref_key: "pcpChart", ref: N, class: U(`vue-ui-pcp ${e(S) ? "vue-data-ui-wrapper-fullscreen" : ""} ${e(t).useCssAnimation ? "" : "vue-ui-dna"}`), style: T(`font-family:${e(t).style.fontFamily};width:100%; text-align:center;background:${e(t).style.chart.backgroundColor};${e(t).responsive ? "height:100%" : ""}`), id: `pcp_${e(X)}`, onMouseenter: s[6] || (s[6] = () => e(ue)(!0)), onMouseleave: s[7] || (s[7] = () => e(ue)(!1)) }, [ e(t).userOptions.buttons.annotator ? (r(), z($t, { key: 0, parent: e(N), backgroundColor: e(t).style.chart.backgroundColor, color: e(t).style.chart.color, active: e(B), onClose: Z }, null, 8, ["parent", "backgroundColor", "color", "active"])) : v("", !0), e(Ue) ? (r(), u("div", { key: 1, ref_key: "noTitle", ref: le, class: "vue-data-ui-no-title-space", style: "height:36px; width: 100%;background:transparent" }, null, 512)) : v("", !0), e(t).style.chart.title.text ? (r(), u("div", { key: 2, ref_key: "chartTitle", ref: oe, style: "width:100%;background:transparent;padding-bottom:24px" }, [ (r(), z(mt, { key: `title_${e(ne)}`, config: { title: { cy: "pcp-div-title", ...e(t).style.chart.title }, subtitle: { cy: "pcp-div-subtitle", ...e(t).style.chart.title.subtitle } } }, null, 8, ["config"])) ], 512)) : v("", !0), e(t).userOptions.show && e(P) && (e(ce) || e(Y)) ? (r(), z(bt, { ref: "details", key: `user_options_${e(te)}`, backgroundColor: e(t).style.chart.backgroundColor, color: e(t).style.chart.color, isPrinting: e(pe), isImaging: e(me), uid: e(X), 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, hasLabel: e(t).userOptions.buttons.labels, hasFullscreen: e(t).userOptions.buttons.fullscreen, isFullscreen: e(S), isTooltip: e(f).showTooltip, titles: { ...e(t).userOptions.buttonTitles }, chartElement: e(N), position: e(t).userOptions.position, hasAnnotator: e(t).userOptions.buttons.annotator, isAnnotation: e(B), onToggleFullscreen: De, onGeneratePdf: e(ve), onGenerateCsv: ke, onGenerateImage: e(ye), onToggleTable: $e, onToggleLabels: Ae, onToggleTooltip: Te, onToggleAnnotator: Z, style: T({ visibility: e(ce) ? e(Y) ? "visible" : "hidden" : "visible" }) }, qe({ _: 2 }, [ o.$slots.optionPdf ? { name: "optionPdf", fn: k(() => [ x(o.$slots, "optionPdf", {}, void 0, !0) ]), key: "0" } : void 0, o.$slots.optionCsv ? { name: "optionCsv", fn: k(() => [ x(o.$slots, "optionCsv", {}, void 0, !0) ]), key: "1" } : void 0, o.$slots.optionImg ? { name: "optionImg", fn: k(() => [ x(o.$slots, "optionImg", {}, void 0, !0) ]), key: "2" } : void 0, o.$slots.optionTable ? { name: "optionTable", fn: k(() => [ x(o.$slots, "optionTable", {}, void 0, !0) ]), key: "3" } : void 0, o.$slots.optionLabels ? { name: "optionLabels", fn: k(() => [ x(o.$slots, "optionLabels", {}, void 0, !0) ]), key: "4" } : void 0, o.$slots.optionFullscreen ? { name: "optionFullscreen", fn: k(({ toggleFullscreen: a, isFullscreen: l }) => [ x(o.$slots, "optionFullscreen", W(E({ toggleFullscreen: a, isFullscreen: l })), void 0, !0) ]), key: "5" } : void 0, o.$slots.optionAnnotator ? { name: "optionAnnotator", fn: k(({ toggleAnnotator: a, isAnnotator: l }) => [ x(o.$slots, "optionAnnotator", W(E({ toggleAnnotator: a, isAnnotator: l })), void 0, !0) ]), key: "6" } : void 0 ]), 1032, ["backgroundColor", "color", "isPrinting", "isImaging", "uid", "hasTooltip", "hasPdf", "hasXls", "hasImg", "hasTable", "hasLabel", "hasFullscreen", "isFullscreen", "isTooltip", "titles", "chartElement", "position", "hasAnnotator", "isAnnotation", "onGeneratePdf", "onGenerateImage", "style"])) : v("", !0), e(P) ? (r(), u("svg", { key: 4, xmlns: e(rt), class: U({ "vue-data-ui-fullscreen--on": e(S), "vue-data-ui-fulscreen--off": !e(S) }), viewBox: `0 0 ${e(d).chartWidth <= 0 ? 10 : e(d).chartWidth} ${e(d).chartHeight <= 0 ? 10 : e(d).chartHeight}`, style: T(`max-width:100%; overflow: visible; background:transparent;color:${e(t).style.chart.color}`) }, [ _e(Ct), o.$slots["chart-background"] ? (r(), u("foreignObject", { key: 0, x: e(d).left, y: e(d).top, width: e(d).width, height: e(d).height, style: { pointerEvents: "none" } }, [ x(o.$slots, "chart-background", {}, void 0, !0) ], 8, zt)) : v("", !0), (r(!0), u(C, null, I(e(g), (a, l) => (r(), u("g", It, [ F("line", { x1: e(d).left + e(w) * l + e(w) / 2, x2: e(d).left + e(w) * l + e(w) / 2, y1: e(d).top, y2: e(d).bottom, stroke: e(t).style.chart.yAxis.stroke, "stroke-width": e(t).style.chart.yAxis.strokeWidth }, null, 8, Ft), F("text", { x: e(d).left + e(w) * l + e(w) / 2, y: e(d).top - 24, fill: e(t).style.chart.yAxis.labels.axisNamesColor, "font-size": e(p).axisNameFontSize, "font-weight": e(t).style.chart.yAxis.labels.axisNamesBold ? "bold" : "", "text-anchor": "middle" }, D(a.name), 9, Pt), e(t).style.chart.yAxis.labels.ticks.show ? (r(), u(C, { key: 0 }, [ (r(!0), u(C, null, I(a.ticks, (i) => (r(), u("line", { x1: i.x, x2: i.x - 10, y1: i.y, y2: i.y, stroke: e(t).style.chart.yAxis.stroke, "stroke-width": e(t).style.chart.yAxis.strokeWidth, style: T(`opacity:${e(y) && !e(f).showTooltip ? 0.2 : 1}`) }, null, 12, Nt))), 256)), (r(!0), u(C, null, I(a.ticks, (i) => (r(), u("text", { x: i.x - 12 + e(t).style.chart.yAxis.labels.ticks.offsetX, y: i.y + e(t).style.chart.yAxis.labels.ticks.offsetY + e(p).ticksFontSize / 3, fill: e(t).style.chart.yAxis.labels.ticks.color, "text-anchor": "end", "font-size": e(p).ticksFontSize, "font-weight": e(t).style.chart.yAxis.labels.ticks.bold ? "bold" : "normal", style: T(`opacity:${e(y) && !e(f).showTooltip ? 0.2 : 1}`) }, D(be({ value: i.value, index: l, datapoint: i })), 13, St))), 256)) ], 64)) : v("", !0) ]))), 256)), (r(!0), u(C, null, I(e(Q), (a) => (r(), u("g", null, [ (r(!0), u(C, null, I(a.series, (l, i) => (r(), u("g", null, [ e(t).style.chart.plots.show ? (r(), u("g", Lt, [ (r(!0), u(C, null, I(l.datapoints, (n) => (r(), z(ft, { plot: { x: n.x, y: n.y }, color: a.color, shape: a.shape, radius: a.shape === "triangle" ? e(p).plotSize * 1.2 : e(p).plotSize, stroke: e(t).style.chart.backgroundColor, strokeWidth: 0.5, onMouseenter: (c) => j({ shape: a.shape, serieName: a.name, serie: l, relativeIndex: i, seriesIndex: l.seriesIndex }), onMouseleave: s[0] || (s[0] = (c) => { y.value = null, L.value = !1; }), style: T(`opacity:${e(y) ? e(y) === l.id ? e(t).style.chart.plots.opacity : 0.2 : e(t).style.chart.plots.opacity}`), onClick: () => Be(n) }, null, 8, ["plot", "color", "shape", "radius", "stroke", "onMouseenter", "style", "onClick"]))), 256)), e(f).showTooltip ? v("", !0) : (r(), u(C, { key: 0 }, [ e(y) && e(y) === l.id && l.datapoints.length ? (r(), u("text", { key: 0, x: l.datapoints[0].x - e(p).ticksFontSize, y: l.datapoints[0].y + e(p).ticksFontSize / 3, "text-anchor": "end", "font-size": e(p).ticksFontSize, fill: a.color, "font-weight": "bold" }, D(l.name), 9, Ot)) : v("", !0) ], 64)), e(t).style.chart.comments.show ? (r(!0), u(C, { key: 1 }, I(l.datapoints, (n) => (r(), u("g", null, [ n.comment ? (r(), u("foreignObject", { key: 0, style: { overflow: "visible" }, height: "12", width: e(t).style.chart.comments.width, x: n.x - e(t).style.chart.comments.width / 2 + e(t).style.chart.comments.offsetX, y: n.y + e(t).style.chart.comments.offsetY + 6 }, [ F("div", Ut, [ x(o.$slots, "plot-comment", { plot: { ...n, color: a.color } }, void 0, !0) ]) ], 8, Dt)) : v("", !0) ]))), 256)) : v("", !0) ])) : v("", !0), e(f).dataLabels.show || e(y) && e(y) === l.id ? (r(!0), u(C, { key: 1 }, I(l.datapoints, (n, c) => (r(), u("text", { x: n.x + 12 + e(t).style.chart.yAxis.labels.datapoints.offsetX, y: n.y + e(t).style.chart.yAxis.labels.datapoints.offsetY + e(p).datapointFontSize / 3, fill: e(t).style.chart.yAxis.labels.datapoints.useSerieColor ? a.color : e(t).style.chart.yAxis.labels.datapoints.color, "text-anchor": "start", "font-weight": e(t).style.chart.yAxis.labels.datapoints.bold ? "bold" : "normal", class: U({ "vue-ui-pcp-animated": !1, "vue-ui-pcp-transition": !0 }), "font-size": e(p).datapointFontSize, onMouseenter: (A) => j({ shape: a.shape, serieName: a.name, serie: l, relativeIndex: i, seriesIndex: l.seriesIndex }), onMouseleave: s[1] || (s[1] = (A) => { y.value = null, L.value = !1; }), style: T(`opacity:${e(y) ? e(y) === l.id ? 1 : 0.2 : 1}`) }, D(be({ value: n.value, index: c, datapoint: n })), 45, Wt))), 256)) : v("", !0), F("path", { d: `M${e(t).style.chart.lines.smooth ? l.smoothPath : l.straightPath}`, stroke: a.color, "stroke-width": e(t).style.chart.lines.strokeWidth, fill: "none", class: U({ "vue-ui-pcp-animated vue-data-ui-line-animated": e(t).useCssAnimation, "vue-ui-pcp-transition": !0 }), onMouseenter: (n) => j({ shape: a.shape, serieName: a.name, serie: l, relativeIndex: i, seriesIndex: l.seriesIndex }), onMouseleave: s[2] || (s[2] = (n) => { y.value = null, L.value = !1; }), style: T(`opacity:${e(y) ? e(y) === l.id ? e(t).style.chart.lines.opacity : 0.2 : e(t).style.chart.lines.opacity}; stroke-dasharray:${l.pathLength}; stroke-dashoffset: ${e(t).useCssAnimation ? l.pathLength : 0}`) }, null, 46, Et), e(f).showTooltip ? (r(), u("path", { key: 2, d: `M${e(t).style.chart.lines.smooth ? l.smoothPath : l.straightPath}`, stroke: "transparent", "stroke-width": 12, fill: "none", class: U({ "vue-ui-pcp-animated vue-data-ui-line-animated": e(t).useCssAnimation, "vue-ui-pcp-transition": !0 }), onMouseenter: (n) => j({ shape: a.shape, serieName: a.name, serie: l, relativeIndex: i, seriesIndex: l.seriesIndex }), onMouseleave: s[3] || (s[3] = (n) => { y.value = null, L.value = !1; }), style: { opacity: "0" } }, null, 42, Vt)) : v("", !0) ]))), 256)) ]))), 256)), x(o.$slots, "svg", { svg: e(d) }, void 0, !0) ], 14, Mt)) : v("", !0), o.$slots.watermark ? (r(), u("div", jt, [ x(o.$slots, "watermark", W(E({ isPrinting: e(pe) || e(me) })), void 0, !0) ])) : v("", !0), e(P) ? v("", !0) : (r(), z(wt, { key: 6, config: { type: "parallelCoordinatePlot", style: { backgroundColor: e(t).style.chart.backgroundColor } } }, null, 8, ["config"])), F("div", { ref_key: "chartLegend", ref: ae }, [ e(t).style.chart.legend.show && e(P) ? (r(), z(vt, { key: `legend_${e(ie)}`, legendSet: e(Ee), config: e(Ve), onClickMarker: s[4] || (s[4] = ({ legend: a }) => { fe(a.id), Ce(a); }) }, { item: k(({ legend: a, index: l }) => [ F("div", { onClick: (i) => { a.segregate(), Ce(a); }, style: T(`opacity:${e($).includes(a.id) ? 0.5 : 1}`) }, D(a.name), 13, Bt) ]), _: 1 }, 8, ["legendSet", "config"])) : x(o.$slots, "legend", { key: 1, legend: e(M) }, void 0, !0) ], 512), o.$slots.source ? (r(), u("div", { key: 7, ref_key: "source", ref: se, dir: "auto" }, [ x(o.$slots, "source", {}, void 0, !0) ], 512)) : v("", !0), _e(yt, { show: e(f).showTooltip && e(L), backgroundColor: e(t).style.chart.tooltip.backgroundColor, color: e(t).style.chart.tooltip.color, fontSize: e(t).style.chart.tooltip.fontSize, borderRadius: e(t).style.chart.tooltip.borderRadius, borderColor: e(t).style.chart.tooltip.borderColor, borderWidth: e(t).style.chart.tooltip.borderWidth, backgroundOpacity: e(t).style.chart.tooltip.backgroundOpacity, position: e(t).style.chart.tooltip.position, offsetY: e(t).style.chart.tooltip.offsetY, parent: e(N), content: e(K), isFullscreen: e(S), isCustom: e(ze)(e(t).style.chart.tooltip.customFormat) }, { "tooltip-before": k(() => [ x(o.$slots, "tooltip-before", W(E({ ...e(J) })), void 0, !0) ]), "tooltip-after": k(() => [ x(o.$slots, "tooltip-after", W(E({ ...e(J) })), void 0, !0) ]), _: 3 }, 8, ["show", "backgroundColor", "color", "fontSize", "borderRadius", "borderColor", "borderWidth", "backgroundOpacity", "position", "offsetY", "parent", "content", "isFullscreen", "isCustom"]), e(P) ? (r(), z(kt, { key: 8, hideDetails: "", config: { open: e(f).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: k(() => [ (r(), z(xt, { key: `table_${e(re)}`, colNames: e(O).colNames, head: e(O).head, body: e(O).body, config: e(O).config, title: `${e(t).style.chart.title.text}${e(t).style.chart.title.subtitle.text ? ` : ${e(t).style.chart.title.subtitle.text}` : ""}`, onClose: s[5] || (s[5] = (a) => e(f).showTable = !1) }, { th: k(({ th: a }) => [ F("div", { innerHTML: a }, null, 8, Rt) ]), td: k(({ td: a }) => [ Qe(D(a), 1) ]), _: 1 }, 8, ["colNames", "head", "body", "config", "title"])) ]), _: 1 }, 8, ["config"])) : v("", !0) ], 46, _t)); } }, ro = /* @__PURE__ */ Tt(Ht, [["__scopeId", "data-v-4eba3ce7"]]); export { ro as default };