v3-charts
Version:
> 基于 Vue 封装的 Echarts5 图表组件
1,055 lines (1,054 loc) • 37.3 kB
JavaScript
var __defProp = Object.defineProperty;
var __defProps = Object.defineProperties;
var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
var __getOwnPropSymbols = Object.getOwnPropertySymbols;
var __hasOwnProp = Object.prototype.hasOwnProperty;
var __propIsEnum = Object.prototype.propertyIsEnumerable;
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
var __spreadValues = (a, b) => {
for (var prop in b || (b = {}))
if (__hasOwnProp.call(b, prop))
__defNormalProp(a, prop, b[prop]);
if (__getOwnPropSymbols)
for (var prop of __getOwnPropSymbols(b)) {
if (__propIsEnum.call(b, prop))
__defNormalProp(a, prop, b[prop]);
}
return a;
};
var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
import { defineComponent, shallowRef, computed, ref, onMounted, watchEffect } from "vue-demi";
import { init } from "echarts";
import { merge } from "lodash";
import ExportJsonExcel from "js-export-excel";
import { useSize } from "ahooks-vue";
import { openBlock, createElementBlock, createElementVNode, resolveComponent, withDirectives, createVNode, vShow } from "vue";
var CHART_TYPE;
(function(CHART_TYPE2) {
CHART_TYPE2["line"] = "line";
CHART_TYPE2["bar"] = "bar";
CHART_TYPE2["pie"] = "pie";
CHART_TYPE2["histogram"] = "histogram";
})(CHART_TYPE || (CHART_TYPE = {}));
var ExportPng = "";
var ImagePng = "";
const labelColor = "#B3C0CC";
const axisColor = "rgba(0, 0, 0, 0.03)";
const color = [
"#407CFF",
"#21D39B",
"#F9697A",
"#9587F1",
"#83D587",
"#FFCD31"
];
const title = {
top: 12,
left: 12,
text: "\u8D1F\u5411\u8BA1\u6570\u8D8B\u52BF\u56FE",
textStyle: {
color: "#071238",
fontSize: 14,
fontWeight: "bold"
}
};
const toolbox = {
show: true,
right: 8,
top: 9,
itemSize: 16,
feature: {
saveAsImage: {
title: "\u5BFC\u51FA\u56FE\u7247",
icon: `image://${ImagePng}`,
iconStyle: {
color: `rgba(192, 196, 204, 1)`
},
emphasis: {
iconStyle: {
color: "#407cff"
}
}
},
mySaveAsExcel: {
show: true,
title: "\u5BFC\u51FA\u8868\u683C",
icon: `image://${ExportPng}`,
onclick: function({ option }) {
var _a;
const data = option.dataset[0].source;
const keys = Object.keys(data[0]);
const title2 = (_a = option.title[0]) == null ? void 0 : _a.text;
const options = {
fileName: title2 || "\u6570\u636E",
datas: [
{
sheetData: data,
sheetName: "sheet1",
sheetFilter: keys,
sheetHeader: keys,
columnWidths: keys.map(() => 12)
}
]
};
const toExcel = new ExportJsonExcel(options);
toExcel.saveExcel();
},
iconStyle: {
color: `rgba(192, 196, 204, 1)`
},
emphasis: {
iconStyle: {
color: "#407cff"
}
}
}
}
};
function getValue$1(series2) {
return series2.value[series2.seriesName];
}
const tooltip$2 = {
trigger: "axis",
axisPointer: {
type: "shadow",
shadowStyle: {
color: {
type: "linear",
x: 0,
y: 0,
x2: 0,
y2: 1,
colorStops: [
{
offset: 0,
color: "rgba(150,150,150,0.3)"
},
{
offset: 1,
color: "rgba(150,150,150,0.3)"
}
]
}
}
},
textStyle: {
align: "left"
},
appendToBody: true,
formatter: (params) => {
params = [params].flat();
if (params.length === 1) {
params = params[0];
return `${params.name}<br/>${params.marker}${params.seriesName}
<span style="font-weight: 600; margin-left: 10px;">${getValue$1(params)}</span>`;
}
const str = [params[0].name];
let maxValue = 0;
for (const i of params) {
i.value && getValue$1(i) && maxValue < getValue$1(i) && (maxValue = getValue$1(i));
}
const lines = params.filter((i) => getValue$1(i) !== void 0).sort((a, b) => getValue$1(b) - getValue$1(a)).map((i) => {
const width = getValue$1(i) / maxValue * 100;
const name = `<span style='display:inline-block; font-size: 12px; line-height: 12px; color: #666; width: 130px; overflow: hidden; white-space: nowrap; text-overflow: ellipsis;'>${i.seriesName}</span>`;
const line = `<span style='display:inline-block; font-size: 12px; margin-right:5px; line-height: 12px; border-radius:2px;width:${width}px;height:8px;background-color:${i.color};'></span>`;
const value = `<span style='font-size:12px;'>${getValue$1(i) || 0}</span>`;
return `${i.marker}${name}: ${line} ${value}`;
}).filter(Boolean);
str.push(...lines.length > 10 ? [...lines.slice(0, 10), "..."] : lines);
return str.join("<br/>");
}
};
const grid$1 = {
top: 88,
left: 28,
right: 36,
bottom: 12,
containLabel: true
};
const legend$1 = {
type: "scroll",
icon: "rect",
left: 16,
top: 42,
itemWidth: 9,
itemHeight: 9,
itemGap: 16,
pageIconSize: 12,
textStyle: {
color: "#777",
padding: [3, 0, 0, 0]
}
};
const xAxis$2 = {
type: "category",
boundaryGap: false,
z: 1,
axisLine: {
lineStyle: {
color: axisColor
}
},
axisTick: {
show: true,
inside: false,
lineStyle: {
color: "rgba(0, 0, 0, 0.5)"
}
},
axisLabel: {
show: true,
color: labelColor,
fontSize: "12",
margin: 16
},
splitLine: {
show: false,
interval: 2,
lineStyle: {
color: "rgba(0, 0, 0, 0.03)"
}
}
};
const yAxis$1 = {
type: "value",
offset: 8,
axisLine: {
show: false,
lineStyle: {
color: labelColor
}
},
axisLabel: {
show: true,
color: labelColor,
fontSize: "12"
},
axisTick: {
show: false,
alignWithLabel: true,
lineStyle: {
color: `rgba(0, 0, 0, 0.3)`
}
},
splitLine: {
show: true,
lineStyle: {
type: "solid",
color: "rgba(0, 0, 0, 0.04)"
}
},
scale: true,
splitNumber: 3
};
const series$2 = {
type: "line",
label: {
show: true
},
symbol: "circle"
};
const axisPointer = {
lineStyle: {},
shadowStyle: {
color: "rgba(0, 0, 0, 1)"
}
};
const COMMON_OPTIONS = {
color,
title,
tooltip: tooltip$2,
grid: grid$1,
toolbox,
legend: legend$1,
xAxis: xAxis$2,
yAxis: yAxis$1,
series: series$2,
axisPointer
};
const COMMON_SERIES = {
markLine: {
silent: true,
symbol: "none",
data: [],
lineStyle: {
color: "#E75E67",
width: 1,
type: "dotted"
},
label: {
show: true,
formatter: "{b}",
position: "insideStartTop",
distance: [0, 4]
},
animation: false
},
markPoint: {
symbol: "circle",
symbolSize: 8,
itemStyle: {
color: "rgba(0,0,0, 0)",
borderColor: "#F9697A",
borderWidth: 3
},
label: {
show: false,
formatter: (params) => {
var _a;
return `${(_a = params.data.coord[2]) != null ? _a : ""}${params.data.coord[1]}`;
},
position: "top",
color: "#E75E67",
distance: 4
}
}
};
function tramsformMarkLine(markLines) {
return markLines.map((i) => __spreadProps(__spreadValues({}, i), {
xAxis: i.yAxis,
yAxis: null
}));
}
const getSeriesIndex = (i) => {
const seriesIndex = (Array.isArray(i) ? i[0].seriesIndex : i.seriesIndex) || 0;
return seriesIndex;
};
function copySeriesByColumns(data, mergedOptions, type) {
var _a;
if (!data) {
return [{ type }];
}
const series2 = (_a = data.columns) == null ? void 0 : _a.slice(1).map((i, index) => {
var _a2, _b, _c, _d, _e, _f, _g, _h, _i, _j;
return __spreadProps(__spreadValues({}, mergedOptions.series), {
type,
markLine: __spreadProps(__spreadValues({}, (_b = (_a2 = mergedOptions.series) == null ? void 0 : _a2.markLine) != null ? _b : {}), {
data: (_e = (_d = (_c = mergedOptions.series) == null ? void 0 : _c.markLine) == null ? void 0 : _d.data) == null ? void 0 : _e.filter((i2) => getSeriesIndex(i2) === index)
}),
markPoint: __spreadProps(__spreadValues({}, (_g = (_f = mergedOptions.series) == null ? void 0 : _f.markPoint) != null ? _g : {}), {
data: (_j = (_i = (_h = mergedOptions.series) == null ? void 0 : _h.markPoint) == null ? void 0 : _i.data) == null ? void 0 : _j.filter((i2) => getSeriesIndex(i2) === index)
})
});
});
return series2;
}
function handleLineStyle(options) {
[options.series].flat().forEach((series2, index) => {
const color2 = options.color[index % options.color.length];
series2.lineStyle = __spreadValues({
shadowColor: transformColor(color2, 0.4)
}, series2.lineStyle);
});
}
function handleAreaStyle(options) {
[options.series].flat().forEach((series2, index) => {
if (index === 0) {
const color2 = options.color[index % options.color.length];
series2.areaStyle = __spreadValues({
color: linearColor(color2, color2, "column", 0.08, 0.01),
opacity: 1
}, series2.areaStyle);
}
});
}
function transformColor(color2, g = 0.15) {
const [, a, b, c] = color2.match(/#(\w{2})(\w{2})(\w{2})/) || [];
return `rgba(${+`0x${a}`},${+`0x${b}`},${+`0x${c}`},${g})`;
}
function linearColor(start, end, direction = "row", endOpacity = 1, startOpacity = 0.5) {
start = transformColor(start, startOpacity);
end = transformColor(end || start, endOpacity);
const xy = direction === "row" ? {
x: 1,
y: 1,
x2: 0,
y2: 0
} : {
x: 0,
y: 1,
x2: 0,
y2: 0
};
return __spreadProps(__spreadValues({
type: "linear"
}, xy), {
colorStops: [
{
offset: 0,
color: start
},
{
offset: 1,
color: end
}
]
});
}
const LINE_OPTIONS = {
axisPointer: {
type: "line"
},
series: __spreadProps(__spreadValues({}, COMMON_SERIES), {
type: "line",
label: {
show: true,
offset: [0, -2],
fontSize: 10
},
smooth: true,
lineStyle: {
width: 2,
shadowBlur: 8
},
symbol: "circle",
emphasis: {
lineStyle: {
width: 2,
shadowBlur: 10
},
symbolSize: 10
},
symbolSize: 5
})
};
function computeMarks(data, mark) {
var _a;
if (!((_a = data == null ? void 0 : data.rows) == null ? void 0 : _a.length)) {
return [];
}
const marks = mark.map((m) => {
var _a2, _b;
return [
{
seriesIndex: m.seriesIndex || 0,
symbol: "none",
lineStyle: {
color: "rgba(0,0,0, 0.2)"
},
label: {
position: (_a2 = m.position) != null ? _a2 : "end",
width: m.width,
overflow: "break",
align: (_b = m.align) != null ? _b : "right",
lineHeight: 20,
distance: [10, 0],
formatter: m.text
},
xAxis: m.xAxis,
yAxis: m.yAxis
},
{
symbol: "none",
xAxis: m.xAxis,
yAxis: m.y2Axis,
y: m.y2Axis ? void 0 : "40%"
}
];
});
return marks;
}
function getValue(series2) {
return series2.value[series2.seriesName];
}
function getLineOptions(data, {
unit,
propOptions,
limit,
sumSort,
limitLine,
markLine,
marks,
autoSmooth,
showMarkText
}) {
var _a, _b, _c, _d;
const markTips = showMarkText ? computeMarks(data, marks) : [];
const computedOptions = merge({}, LINE_OPTIONS, {
yAxis: {
axisLabel: {
formatter: (v) => `${v}${unit ? " " + unit : ""}`
}
},
series: {
smooth: autoSmooth ? Boolean((((_a = data == null ? void 0 : data.rows) == null ? void 0 : _a.length) || 0) > 15) : void 0,
label: {
fontSize: 12,
formatter: (params) => {
const v = params.data[params.seriesName] || "";
return `${v}${v && unit ? " " + unit : ""}`;
}
},
markLine: {
data: [...markLine, ...markTips]
},
markPoint: {
data: marks == null ? void 0 : marks.map((i) => ({
xAxis: i.xAxis,
yAxis: i.yAxis,
seriesIndex: i.seriesIndex
}))
}
}
}, propOptions);
let columns = (_b = data == null ? void 0 : data.columns) != null ? _b : [];
if (sumSort && (data == null ? void 0 : data.columns)) {
const dimensions = data.columns.slice(1);
const sumsMap = (_c = dimensions.map((key) => ({
key,
sum: data.rows.reduce((count, i) => {
var _a2;
return +(count || 0) + ((_a2 = i[key]) != null ? _a2 : 0);
})
})).reduce((map, i) => {
map[i.key] = i.sum;
return map;
}, {})) != null ? _c : {};
dimensions.sort((a, b) => sumsMap[a] > sumsMap[b] ? -1 : 1);
columns = [data.columns[0], ...dimensions];
}
let legend2 = {};
if (((_d = data == null ? void 0 : data.rows) == null ? void 0 : _d.length) && limit && columns.length - 1 > limit) {
legend2 = {
selected: columns.slice(1).reduce((map, i) => {
map[i] = true;
return map;
}, {})
};
for (const key of columns.slice(limit + 1)) {
legend2.selected[key] = false;
}
}
const finnalOptions = merge({}, COMMON_OPTIONS, computedOptions, {
legend: legend2,
dataset: {
dimensions: columns,
source: data == null ? void 0 : data.rows
},
tooltip: {
formatter(params) {
var _a2;
params = [params].flat();
const thisAxisMark = marks == null ? void 0 : marks.filter((i) => i.xAxis === params[0].axisValue);
const thisAxisMarkText = (_a2 = thisAxisMark == null ? void 0 : thisAxisMark.map((i) => `<span style="font-size: 12px; color: #999;">${i.text}</span>`).join("<br/>")) != null ? _a2 : "";
if (params.length === 1) {
params = params[0];
return `${params.name}<br/>${thisAxisMarkText ? thisAxisMarkText + "<br/>" : ""}${params.marker}${params.seriesName}
<span style="font-weight: 600; margin-left: 10px;">${getValue(params)}</span>`;
}
const str = [params[0].name];
thisAxisMarkText && str.push(thisAxisMarkText);
let maxValue = 0;
for (const i of params) {
i.value && getValue(i) && maxValue < getValue(i) && (maxValue = getValue(i));
}
const lines = params.filter((i) => getValue(i) !== void 0).sort((a, b) => getValue(b) - getValue(a)).map((i) => {
const width = getValue(i) / maxValue * 100;
const name = `${i.seriesName}`;
const line = `<span style='display:inline-block;margin-right:5px; line-height: 12px; border-radius:2px;width:${width}px;height:8px;background-color:${i.color};'></span>`;
const value = `<span style='font-size:12px;'>${getValue(i) || 0}</span>`;
return [`${i.marker}${name}`, `${line} ${value}`];
}).filter(Boolean);
const showEllipsis = lines.length > 10;
const htmlContent = `<div style="display: flex;font-size: 12px; color: #666;">
<div style="margin-right: 12px;">
${lines.slice(0, 10).map(([left]) => `<div style="height: 22px; max-width: 130px; overflow: hidden; white-space: nowrap; text-overflow: ellipsis;">${left}</div>`).join("")}
</div>
<div>
${lines.slice(0, 10).map(([, right]) => `<div style="height: 22px;">${right}</div>`).join("")}
</div>
</div>`;
str.push(htmlContent);
showEllipsis && str.push("...");
return str.join("<br/>");
}
},
series: copySeriesByColumns(data, computedOptions, CHART_TYPE.line)
});
if (limitLine) {
finnalOptions.series = finnalOptions.series.slice(0, limitLine);
}
handleLineStyle(finnalOptions);
handleAreaStyle(finnalOptions);
return finnalOptions;
}
const tooltip$1 = {
formatter: null,
confine: true
};
const barMaxWidth$1 = 20;
const activeColor = "#21D39B";
const xAxis$1 = {
type: "value",
axisTick: {
show: true,
alignWithLabel: true
},
axisLine: {
lineStyle: {
color: `rgba(0, 0, 0, 0.1)`
}
},
splitLine: {
show: true
}
};
const yAxis = {
type: "category",
boundaryGap: true,
axisTick: {
show: false
},
axisLine: {
show: false
},
splitLine: {
show: false
},
axisLabel: {
show: true,
formatter(text) {
let str = text;
if (str.length > 12) {
str = str.substr(0, 10) + "...";
}
return `${str}`;
}
},
z: 10
};
const label$1 = {
show: true,
position: "right"
};
const series$1 = __spreadProps(__spreadValues({}, COMMON_SERIES), {
type: "bar",
itemStyle: {
borderRadius: [0, 2, 2, 0],
label: {
show: true,
position: "right"
}
},
emphasis: {
itemStyle: {
borderWidth: 0
},
label: {
formatter(params) {
return `${params.value[params.seriesName]} \u221A`;
}
}
},
select: {
label: {
color: activeColor,
formatter(params) {
return `${params.value[params.seriesName]} \u221A`;
}
},
itemStyle: {
color: activeColor,
borderWidth: 0
}
}
});
const legend = {
show: false
};
const grid = {
top: 48,
right: 54
};
const BAR_OPTIONS = {
label: label$1,
tooltip: tooltip$1,
barMaxWidth: barMaxWidth$1,
xAxis: xAxis$1,
yAxis,
series: series$1,
legend,
grid
};
function getBarOptions(data, { unit, propOptions, limit, markLine, sort, selectedMode }) {
var _a, _b, _c, _d;
const mergedOptions = merge({}, BAR_OPTIONS, {
xAxis: {
axisLabel: {
formatter: (v) => `${v}${unit ? " " + unit : ""}`
}
},
series: {
markLine: {
data: tramsformMarkLine(markLine),
label: {
position: "end",
distance: [4, 0]
}
},
selectedMode
}
}, propOptions);
const dataset = {
dimensions: data == null ? void 0 : data.columns,
source: data == null ? void 0 : data.rows
};
if ((data == null ? void 0 : data.columns) && sort) {
(_a = dataset.source) == null ? void 0 : _a.sort((a, b) => {
return a[data.columns[1]] - b[data.columns[1]];
});
}
if (limit) {
if (!sort) {
dataset.source = [...(_c = (_b = dataset.source) == null ? void 0 : _b.slice(0, limit)) != null ? _c : []].reverse();
} else {
dataset.source = (_d = dataset.source) == null ? void 0 : _d.slice(-limit);
}
}
const finnalOptions = merge({}, COMMON_OPTIONS, __spreadProps(__spreadValues({}, mergedOptions), {
dataset,
series: copySeriesByColumns(data, mergedOptions, CHART_TYPE.bar)
}));
return finnalOptions;
}
const PIE_OPTIONS = {
legend: {
show: true,
orient: "vertical",
top: "middle",
left: "70%",
itemGap: 16,
itemWidth: 10,
itemHeight: 10,
textStyle: {
color: "#777",
fontSize: 12,
lineHeight: 10,
overflow: "truncate",
width: 100,
padding: [30, 0, 0, 0]
},
pageIconSize: 12,
padding: [
64,
5,
10,
5
]
},
xAxis: {
axisLine: {
show: false
}
},
series: {
type: "pie",
center: ["35%", "50%"],
radius: ["40%", "70%"],
label: {
formatter: `{d}%`
},
itemStyle: {
borderRadius: 10,
borderColor: "#fff",
borderWidth: 2
}
},
tooltip: {
show: true,
trigger: "item",
formatter: (params) => {
function getValue2(series2) {
return series2.value[series2.dimensionNames[1]];
}
return `${params.marker} <span style='font-size:14px; color: ${params.color}'>${params.name}</span> <br/>
<span style='font-size:10px; margin-right: 4px;'>\u503C:</span>
<span style='font-size:12px; color: #666;'>${getValue2(params)}</span> <br/>
<span style='font-size:10px; margin-right: 4px;'>\u767E\u5206\u6BD4:</span>
<span style='font-size:12px; color: #666;'>${params.percent}%</span>`;
}
}
};
function getPieOptions(data, { propOptions, limit, sort, selectedMode }) {
var _a;
const mergedOptions = merge({}, PIE_OPTIONS, {
series: {
selectedMode
}
}, propOptions);
if ((data == null ? void 0 : data.columns) && sort) {
(_a = data.rows) == null ? void 0 : _a.sort((a, b) => {
return b[data.columns[1]] - a[data.columns[1]];
});
}
if ((data == null ? void 0 : data.rows.length) && limit && data.rows.length > limit) {
const limitedRows = [
...data.rows.slice(0, limit),
{
[data.columns[0]]: "\u5176\u5B83",
[data.columns[1]]: data.rows.slice(limit).reduce((count, i) => {
var _a2;
return count + i[(_a2 = data == null ? void 0 : data.columns[1]) != null ? _a2 : ""];
}, 0)
}
];
data = {
columns: data.columns,
rows: limitedRows
};
}
const finnalOptions = merge({}, COMMON_OPTIONS, __spreadProps(__spreadValues({}, mergedOptions), {
dataset: {
dimensions: data == null ? void 0 : data.columns,
source: data == null ? void 0 : data.rows
},
series: copySeriesByColumns(data, mergedOptions, CHART_TYPE.pie)
}));
return finnalOptions;
}
const label = {
show: true,
position: "top"
};
const tooltip = {
formatter(params) {
params = [params].flat();
const str = [params[0].name];
let maxValue = 0;
function getValue2(series2) {
return series2.value[series2.seriesName];
}
for (const i of params) {
maxValue < getValue2(i) && (maxValue = getValue2(i));
}
const lines = params.sort((a, b) => getValue2(b) - getValue2(a)).map((i) => {
const width = getValue2(i) / maxValue * 100;
const name = `<span style='display:inline-block; font-size: 12px; line-height: 12px; color: #666; width: 130px; overflow: hidden; white-space: nowrap; text-overflow: ellipsis;'>${i.seriesName}</span>`;
const line = `<span style='display:inline-block; font-size: 12px; margin-right:5px; line-height: 12px; border-radius:2px;width:${width}px;height:8px;background-color:${i.color};'></span>`;
const value = `<span style='font-size:12px;'>${getValue2(i) || 0}</span>`;
return `${i.marker}${name}: ${line} ${value}`;
}).filter(Boolean);
str.push(...lines.length > 10 ? [...lines.slice(0, 10), "..."] : lines);
return str.join("<br/>");
}
};
const barMaxWidth = 32;
const xAxis = {
boundaryGap: true,
axisTick: {
alignWithLabel: true,
lineStyle: {
color: `rgba(0, 0, 0, 0.3)`
}
},
axisLine: {
lineStyle: {
color: `rgba(0, 0, 0, 0.1)`
}
}
};
const series = __spreadProps(__spreadValues({}, COMMON_SERIES), {
type: "bar"
});
const HISTOGRAM_OPTIONS = {
label,
tooltip,
barMaxWidth,
xAxis,
series
};
function getHistogramOptions(data, { unit, propOptions, markLine }) {
const mergedOptions = merge({}, HISTOGRAM_OPTIONS, {
yAxis: {
axisLabel: {
formatter: (v) => `${v}${unit ? " " + unit : ""}`
}
},
series: {
markLine: {
data: markLine
}
}
}, propOptions);
const finnalOptions = merge({}, COMMON_OPTIONS, __spreadProps(__spreadValues({}, mergedOptions), {
dataset: {
dimensions: data == null ? void 0 : data.columns,
source: data == null ? void 0 : data.rows
},
series: copySeriesByColumns(data, mergedOptions, CHART_TYPE.bar)
}));
return finnalOptions;
}
const SPECTAIL_OPTIONS = {
line: getLineOptions,
bar: getBarOptions,
pie: getPieOptions,
histogram: getHistogramOptions
};
function getOptionsByType(data, configs) {
var _a;
const fn = (_a = SPECTAIL_OPTIONS[configs.type]) != null ? _a : () => COMMON_OPTIONS;
const mergedOptions = fn(data, configs);
return Object.freeze(mergedOptions);
}
var DataEmpty_vue_vue_type_style_index_0_lang = "";
const _sfc_main$2 = {};
const _hoisted_1$2 = { class: "v-charts-data-empty" };
function _sfc_render$2(_ctx, _cache) {
return openBlock(), createElementBlock("div", _hoisted_1$2, "\u6682\u65E0\u6570\u636E");
}
_sfc_main$2.render = _sfc_render$2;
var Loading_vue_vue_type_style_index_0_lang = "";
const _sfc_main$1 = {};
const _hoisted_1$1 = { class: "v-charts-component-loading" };
const _hoisted_2$1 = /* @__PURE__ */ createElementVNode("div", { class: "loader" }, [
/* @__PURE__ */ createElementVNode("div", { class: "loading-spinner" }, [
/* @__PURE__ */ createElementVNode("svg", {
class: "circular",
viewBox: "25 25 50 50"
}, [
/* @__PURE__ */ createElementVNode("circle", {
class: "path",
cx: "50",
cy: "50",
r: "20",
fill: "none"
})
])
])
], -1);
const _hoisted_3 = [
_hoisted_2$1
];
function _sfc_render$1(_ctx, _cache) {
return openBlock(), createElementBlock("div", _hoisted_1$1, _hoisted_3);
}
_sfc_main$1.render = _sfc_render$1;
var _sfc_main = defineComponent({
name: "VChart",
props: {
data: Object,
options: Object,
type: { type: String, default: "line" },
loading: { type: Boolean, default: false },
unit: String,
limit: { type: Number, default: 0 },
sumSort: { type: Boolean, default: false },
limitLine: { type: Number, default: 0 },
markLine: { type: Array, default: () => [] },
markLines: { type: Array },
marks: { type: Array, default: () => [] },
showMarkText: { type: Boolean, default: false },
sort: { type: Boolean, default: true },
selectedMode: {
type: [Boolean, String],
default: false
},
defaultSelectNum: { type: Number, default: 3 },
autoSmooth: { type: Boolean, default: true }
},
components: {
DataEmpty: _sfc_main$2,
Loading: _sfc_main$1
},
emits: ["click", "select"],
setup(props, { emit }) {
const data = shallowRef(computed(() => props.data));
const isDataEmpty = computed(() => {
var _a, _b;
return Boolean(!((_b = (_a = data.value) == null ? void 0 : _a.rows) == null ? void 0 : _b.length));
});
const chartRef = ref(null);
const ContainerRef = ref(null);
const instance = { value: null };
function resize() {
var _a;
(_a = instance.value) == null ? void 0 : _a.resize();
}
onMounted(() => {
instance.value = init(chartRef.value);
let chartOptions = null;
watchEffect(() => {
var _a, _b, _c, _d;
chartOptions = getOptionsByType(data.value, {
type: (_a = props.type) != null ? _a : CHART_TYPE.line,
unit: props.unit,
limit: props.limit,
sumSort: props.sumSort,
limitLine: props.limitLine,
propOptions: props.options,
markLine: (_b = props.markLines) != null ? _b : props.markLine,
marks: props.marks,
showMarkText: props.showMarkText,
sort: props.sort,
selectedMode: props.selectedMode,
defaultSelectNum: props.defaultSelectNum,
autoSmooth: props.autoSmooth
});
if ((_c = data.value) == null ? void 0 : _c.rows) {
(_d = instance.value) == null ? void 0 : _d.setOption(chartOptions, {
notMerge: true
});
}
});
useSize(ContainerRef, {
onChange() {
resize();
}
});
instance.value.on("click", (params) => {
emit("click", params);
});
instance.value.on("selectchanged", ({ selected }) => {
const selectedValues = selected.length ? selected[0].dataIndex.map((index) => {
const dimension = chartOptions.dataset.dimensions[0];
return chartOptions.dataset.source[index][dimension];
}) : [];
console.log(selectedValues);
emit("select", selectedValues);
});
instance.value.on("mouseover", (params) => {
var _a;
console.log(params);
if (params.componentType === "markPoint") {
(_a = instance.value) == null ? void 0 : _a.dispatchAction({
type: "showTip",
seriesIndex: params.dataIndex
});
}
});
});
return {
chartRef,
ContainerRef,
isDataEmpty,
resize,
instance
};
}
});
var Chart_vue_vue_type_style_index_0_scoped_true_lang = "";
const _hoisted_1 = {
style: { "min-height": "100px", "position": "relative" },
ref: "ContainerRef"
};
const _hoisted_2 = {
ref: "chartRef",
style: { "height": "100%" }
};
function _sfc_render(_ctx, _cache, $props, $setup, $data, $options) {
const _component_DataEmpty = resolveComponent("DataEmpty");
const _component_Loading = resolveComponent("Loading");
return openBlock(), createElementBlock("div", _hoisted_1, [
createElementVNode("div", _hoisted_2, null, 512),
withDirectives(createVNode(_component_DataEmpty, null, null, 512), [
[vShow, _ctx.isDataEmpty && !_ctx.loading]
]),
withDirectives(createVNode(_component_Loading, null, null, 512), [
[vShow, _ctx.loading]
])
], 512);
}
_sfc_main.render = _sfc_render;
_sfc_main.__scopeId = "data-v-0ffcffc3";
export { _sfc_main as VChart };