<template>
<Card title="任务状态统计" :loading="loading">
<div ref="chartRef" :style="{ height, width }"></div>
</Card>
</template>
<script lang="ts" setup>
import { Ref, ref } from 'vue';
import { Card } from 'ant-design-vue';
import { useECharts } from '/@/hooks/web/useECharts';
import { getTaskStatusInfo } from '/@/views/dashboard/Analysis/api';
const loading = ref(false);
const props = defineProps({
width: {
type: String as PropType<string>,
default: '100%',
},
height: {
type: String as PropType<string>,
default: '300px',
},
});
const chartRef = ref<HTMLDivElement | null>(null);
const { setOptions } = useECharts(chartRef as Ref<HTMLDivElement>);
const status_data = ref([]);
function initData() {
loading.value = true;
getTaskStatusInfo({}).then((res) => {
status_data.value = res.data;
console.log(status_data.value);
setOptions({
tooltip: {
trigger: 'item',
},
legend: {
bottom: '1%',
left: 'center',
},
series: [
{
// color: ['#5ab1ef', '#b6a2de', '#67e0e3', '#2ec7c9'],
name: '任务状态统计',
type: 'pie',
radius: ['40%', '70%'],
avoidLabelOverlap: false,
itemStyle: {
borderRadius: 10,
borderColor: '#fff',
borderWidth: 2,
},
label: {
show: false,
position: 'center',
},
emphasis: {
label: {
show: true,
fontSize: '12',
fontWeight: 'bold',
},
},
labelLine: {
show: false,
},
data: status_data.value,
animationType: 'scale',
animationEasing: 'exponentialInOut',
animationDelay: function () {
return Math.random() * 100;
},
},
],
});
loading.value = false;
});
}
initData();
</script>