1
0
mirror of https://github.com/hotomoe/hotomoe synced 2025-01-22 09:42:54 +09:00
hotomoe/packages/frontend/src/pages/admin/overview.pie.vue

76 lines
1.6 KiB
Vue
Raw Normal View History

<template>
<canvas ref="chartEl"></canvas>
</template>
<script lang="ts" setup>
import { onMounted, onUnmounted, ref } from 'vue';
2023-01-02 10:18:47 +09:00
import { Chart } from 'chart.js';
import number from '@/filters/number';
import { defaultStore } from '@/store';
import { useChartTooltip } from '@/scripts/use-chart-tooltip';
2023-01-02 10:18:47 +09:00
import { initChart } from '@/scripts/init-chart';
2023-01-02 10:18:47 +09:00
initChart();
const props = defineProps<{
2022-06-30 22:02:08 +09:00
data: { name: string; value: number; color: string; onClick?: () => void }[];
}>();
const chartEl = ref<HTMLCanvasElement>(null);
2022-12-26 13:26:21 +09:00
const { handler: externalTooltipHandler } = useChartTooltip({
position: 'middle',
});
let chartInstance: Chart;
onMounted(() => {
chartInstance = new Chart(chartEl.value, {
type: 'doughnut',
data: {
labels: props.data.map(x => x.name),
datasets: [{
backgroundColor: props.data.map(x => x.color),
2022-06-30 21:38:34 +09:00
borderColor: getComputedStyle(document.documentElement).getPropertyValue('--panel'),
borderWidth: 2,
hoverOffset: 0,
data: props.data.map(x => x.value),
}],
},
options: {
layout: {
padding: {
2022-06-30 20:15:14 +09:00
left: 16,
right: 16,
top: 16,
bottom: 16,
},
},
2022-06-30 22:02:08 +09:00
onClick: (ev) => {
const hit = chartInstance.getElementsAtEventForMode(ev, 'nearest', { intersect: true }, false)[0];
if (hit && props.data[hit.index].onClick) {
props.data[hit.index].onClick();
}
},
plugins: {
legend: {
display: false,
},
tooltip: {
enabled: false,
mode: 'index',
animation: {
duration: 0,
},
external: externalTooltipHandler,
},
},
},
});
});
</script>
<style lang="scss" scoped>
</style>