<template>
|
<el-container class="main-layout">
|
<el-aside :width="isCollapse ? '64px' : '220px'" class="aside">
|
<div class="logo">
|
<span v-if="!isCollapse">数据管理系统</span>
|
<span v-else>数据</span>
|
</div>
|
<el-menu
|
:default-active="activeMenu"
|
:collapse="isCollapse"
|
:router="true"
|
background-color="#304156"
|
text-color="#bfcbd9"
|
active-text-color="#409EFF"
|
class="menu"
|
>
|
<el-menu-item index="/dashboard">
|
<el-icon><HomeFilled /></el-icon>
|
<template #title>首页</template>
|
</el-menu-item>
|
|
<el-sub-menu index="system">
|
<template #title>
|
<el-icon><Setting /></el-icon>
|
<span>系统管理</span>
|
</template>
|
<el-menu-item index="/system/user">
|
<el-icon><User /></el-icon>
|
<template #title>用户管理</template>
|
</el-menu-item>
|
<el-menu-item index="/system/department">
|
<el-icon><OfficeBuilding /></el-icon>
|
<template #title>部门管理</template>
|
</el-menu-item>
|
</el-sub-menu>
|
|
<el-sub-menu index="data">
|
<template #title>
|
<el-icon><Upload /></el-icon>
|
<span>数据导入管理</span>
|
</template>
|
<el-menu-item index="/data/excel">
|
<el-icon><Document /></el-icon>
|
<template #title>Excel上传</template>
|
</el-menu-item>
|
</el-sub-menu>
|
</el-menu>
|
</el-aside>
|
|
<el-container>
|
<el-header class="header">
|
<div class="header-left">
|
<el-icon
|
class="collapse-btn"
|
:size="20"
|
@click="isCollapse = !isCollapse"
|
>
|
<Fold v-if="!isCollapse" />
|
<Expand v-else />
|
</el-icon>
|
</div>
|
<div class="header-right">
|
<el-dropdown @command="handleCommand">
|
<span class="user-info">
|
<el-icon><User /></el-icon>
|
{{ userStore.userInfo.realName || userStore.userInfo.username }}
|
<el-icon class="el-icon--right"><ArrowDown /></el-icon>
|
</span>
|
<template #dropdown>
|
<el-dropdown-menu>
|
<el-dropdown-item command="logout">退出登录</el-dropdown-item>
|
</el-dropdown-menu>
|
</template>
|
</el-dropdown>
|
</div>
|
</el-header>
|
|
<el-main class="main">
|
<router-view />
|
</el-main>
|
</el-container>
|
</el-container>
|
</template>
|
|
<script setup>
|
import { ref, computed } from 'vue'
|
import { useRoute, useRouter } from 'vue-router'
|
import { useUserStore } from '@/stores/user'
|
|
const route = useRoute()
|
const router = useRouter()
|
const userStore = useUserStore()
|
|
const isCollapse = ref(false)
|
|
const activeMenu = computed(() => {
|
return route.path
|
})
|
|
const handleCommand = (command) => {
|
if (command === 'logout') {
|
userStore.logout()
|
router.push('/login')
|
}
|
}
|
</script>
|
|
<style scoped>
|
.main-layout {
|
height: 100vh;
|
}
|
|
.aside {
|
background-color: #304156;
|
transition: width 0.3s;
|
}
|
|
.logo {
|
height: 60px;
|
display: flex;
|
align-items: center;
|
justify-content: center;
|
color: white;
|
font-size: 18px;
|
font-weight: bold;
|
background-color: #263445;
|
}
|
|
.menu {
|
border-right: none;
|
}
|
|
.header {
|
display: flex;
|
justify-content: space-between;
|
align-items: center;
|
background-color: white;
|
box-shadow: 0 1px 4px rgba(0, 21, 41, 0.08);
|
padding: 0 20px;
|
}
|
|
.header-left {
|
display: flex;
|
align-items: center;
|
}
|
|
.collapse-btn {
|
cursor: pointer;
|
padding: 10px;
|
}
|
|
.collapse-btn:hover {
|
background-color: #f5f5f5;
|
border-radius: 4px;
|
}
|
|
.header-right {
|
display: flex;
|
align-items: center;
|
}
|
|
.user-info {
|
display: flex;
|
align-items: center;
|
gap: 5px;
|
cursor: pointer;
|
color: #333;
|
}
|
|
.main {
|
background-color: #f0f2f5;
|
overflow-y: auto;
|
}
|
</style>
|