diff --git a/src/components/cards/SiteCard.vue b/src/components/cards/SiteCard.vue index 663b2d36..379ba3cf 100644 --- a/src/components/cards/SiteCard.vue +++ b/src/components/cards/SiteCard.vue @@ -6,15 +6,15 @@ import SiteUserDataDialog from '../dialog/SiteUserDataDialog.vue' import SiteResourceDialog from '../dialog/SiteResourceDialog.vue' import SiteCookieUpdateDialog from '../dialog/SiteCookieUpdateDialog.vue' import api from '@/api' -import type { Site, SiteStatistic } from '@/api/types' +import type { Site, SiteStatistic, SiteUserData } from '@/api/types' import { isNullOrEmptyObject } from '@/@core/utils' -import { VCardActions, VExpandTransition, VSpacer } from 'vuetify/lib/components/index.mjs' +import { VCardActions, VExpandTransition, VProgressLinear, VSpacer } from 'vuetify/lib/components/index.mjs' +import { formatFileSize } from '@/@core/utils/formatters' // 输入参数 const cardProps = defineProps({ site: Object as PropType, - width: String, - height: String, + data: Object as PropType, }) // 定义触发的自定义事件 @@ -121,6 +121,12 @@ const statColor = computed(() => { } }) +// 计算上传量和下载量的百分比 +const getPercentage = computed(() => { + if (cardProps.data?.upload === 0) return 100 + return ((cardProps.data?.download ?? 0) / ((cardProps.data?.download ?? 0) + (cardProps.data?.upload ?? 0))) * 100 +}) + // 保存站点 function saveSite() { siteEditDialog.value = false @@ -149,8 +155,6 @@ onMounted(() => {