<template>
|
<div class="dashboard">
|
<el-row :gutter="20">
|
<el-col :span="6">
|
<el-card class="box-card">
|
<template #header>
|
<div class="card-header">
|
<span>用户总数</span>
|
</div>
|
</template>
|
<div class="card-content">
|
<el-icon :size="40" color="#409EFC"><User /></el-icon>
|
<span class="number">{{ stats.userCount }}</span>
|
</div>
|
</el-card>
|
</el-col>
|
<el-col :span="6">
|
<el-card class="box-card">
|
<template #header>
|
<div class="card-header">
|
<span>部门总数</span>
|
</div>
|
</template>
|
<div class="card-content">
|
<el-icon :size="40" color="#67C23A"><OfficeBuilding /></el-icon>
|
<span class="number">{{ stats.deptCount }}</span>
|
</div>
|
</el-card>
|
</el-col>
|
<el-col :span="6">
|
<el-card class="box-card">
|
<template #header>
|
<div class="card-header">
|
<span>模板总数</span>
|
</div>
|
</template>
|
<div class="card-content">
|
<el-icon :size="40" color="#E6A23C"><Document /></el-icon>
|
<span class="number">{{ stats.excelCount }}</span>
|
</div>
|
</el-card>
|
</el-col>
|
<el-col :span="6">
|
<el-card class="box-card">
|
<template #header>
|
<div class="card-header">
|
<span>当前用户</span>
|
</div>
|
</template>
|
<div class="card-content">
|
<el-icon :size="40" color="#F56C6C"><Avatar /></el-icon>
|
<span class="username">{{ userStore.userInfo.realName || userStore.userInfo.username }}</span>
|
</div>
|
</el-card>
|
</el-col>
|
</el-row>
|
|
<el-card class="welcome-card">
|
<h2>欢迎使用数据管理系统</h2>
|
<p>当前登录用户:{{ userStore.userInfo.realName || userStore.userInfo.username }}</p>
|
<p>所属部门:{{ userStore.userInfo.deptName || '未分配' }}</p>
|
</el-card>
|
</div>
|
</template>
|
|
<script setup>
|
import { ref, onMounted } from 'vue'
|
import { useUserStore } from '@/stores/user'
|
import { getCount } from '../api/auth'
|
|
const userStore = useUserStore()
|
|
const stats = ref({
|
userCount: 0,
|
deptCount: 0,
|
excelCount: 0
|
})
|
|
onMounted(() => {
|
fetchData()
|
})
|
|
const fetchData = async () => {
|
try {
|
const res = await getCount()
|
console.log('res=', res)
|
stats.value.userCount = res.data.userSize
|
stats.value.deptCount = res.data.deptSize
|
stats.value.excelCount = res.data.dataSize
|
} catch (error) {
|
console.error('获取数据列表失败:', error)
|
}
|
}
|
</script>
|
|
<style scoped>
|
.dashboard {
|
padding: 20px;
|
}
|
|
.box-card {
|
margin-bottom: 20px;
|
}
|
|
.card-header {
|
display: flex;
|
justify-content: space-between;
|
align-items: center;
|
}
|
|
.card-content {
|
display: flex;
|
align-items: center;
|
gap: 20px;
|
}
|
|
.number {
|
font-size: 32px;
|
font-weight: bold;
|
color: #333;
|
}
|
|
.username {
|
font-size: 18px;
|
font-weight: bold;
|
color: #333;
|
}
|
|
.welcome-card {
|
margin-top: 20px;
|
}
|
|
.welcome-card h2 {
|
margin-bottom: 20px;
|
color: #333;
|
}
|
|
.welcome-card p {
|
margin: 10px 0;
|
color: #666;
|
}
|
</style>
|