From b4ec95ea65bafad5cadb27ecae17ce5f596f2bf9 Mon Sep 17 00:00:00 2001 From: moeakwak Date: Sun, 10 Dec 2023 14:01:39 +0800 Subject: [PATCH] fix: echarts can't get dom size --- .../views/admin/components/charts/AskChart.vue | 17 +++++++---------- .../admin/components/charts/RequestsChart.vue | 10 ++++++++-- 2 files changed, 15 insertions(+), 12 deletions(-) diff --git a/frontend/src/views/admin/components/charts/AskChart.vue b/frontend/src/views/admin/components/charts/AskChart.vue index e31bfe6f..a5ad9304 100644 --- a/frontend/src/views/admin/components/charts/AskChart.vue +++ b/frontend/src/views/admin/components/charts/AskChart.vue @@ -1,6 +1,6 @@ @@ -19,7 +19,7 @@ import { } from 'echarts/components'; import { use } from 'echarts/core'; import { CanvasRenderer } from 'echarts/renderers'; -import { computed, ref } from 'vue'; +import { computed, onMounted, ref } from 'vue'; import VChart from 'vue-echarts'; import { useI18n } from 'vue-i18n'; @@ -43,6 +43,8 @@ use([ BrushComponent, ]); +const chartRef = ref>(); + const props = defineProps<{ loading: boolean; askStats: AskLogAggregation[]; @@ -343,12 +345,7 @@ const option = computed(() => { } as EChartsOption; }); -// watchEffect(() => { -console.log('props', props.askStats); -// console.log('xAxis', xAxis.value); -// console.log('totalRequestsCountData', totalRequestsCountData.value); -// console.log('datasetSource', datasetSource.value); -// console.log('users', props.users) -// console.log('option', option.value); -// }); +onMounted(() => { + chartRef.value?.resize(); +}); diff --git a/frontend/src/views/admin/components/charts/RequestsChart.vue b/frontend/src/views/admin/components/charts/RequestsChart.vue index d2fdbffd..f7c8323c 100644 --- a/frontend/src/views/admin/components/charts/RequestsChart.vue +++ b/frontend/src/views/admin/components/charts/RequestsChart.vue @@ -1,6 +1,6 @@ @@ -20,7 +20,7 @@ import { } from 'echarts/components'; import { use } from 'echarts/core'; import { CanvasRenderer } from 'echarts/renderers'; -import { computed, ref, watchEffect } from 'vue'; +import { computed, onMounted, ref, watchEffect } from 'vue'; import VChart from 'vue-echarts'; import { useI18n } from 'vue-i18n'; @@ -55,6 +55,8 @@ const props = defineProps<{ users?: UserRead[]; }>(); +const chartRef = ref>(); + const findUsername = (user_id: number) => { const user = props.users?.find((u) => u.id === user_id); return user?.username || user_id; @@ -278,4 +280,8 @@ watchEffect(() => { // console.log('users', props.users) console.log('option', option.value); }); + +onMounted(() => { + chartRef.value?.resize(); +});