fix:顶栏改为全宽单行(系统名+用户信息),材料分类归入配置项子菜单

Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
This commit is contained in:
caoqianming 2026-04-23 14:01:33 +08:00
parent e378bb9e1c
commit d3ceaded07
1 changed files with 99 additions and 78 deletions

View File

@ -1,38 +1,39 @@
<template> <template>
<div class="layout"> <div class="layout">
<aside class="sidebar"> <header class="topbar">
<div class="logo"> <div class="logo-title">房地产新材料选材管理数据系统</div>
<div class="logo-title">房地产新材料选材管理数据系统</div> <div class="user">
<div class="logo-sub">管理系统</div> <div class="user-info">
</div> <div class="name">{{ user?.username || '用户' }}</div>
<el-menu <div class="role">{{ isAdmin ? '管理员' : '普通账号' }}</div>
:default-active="active"
class="menu"
router
>
<el-menu-item v-if="isAdmin" index="/users">用户管理</el-menu-item>
<el-menu-item index="/factories">供应商库</el-menu-item>
<el-menu-item v-if="isAdmin" index="/dictionary">材料分类管理</el-menu-item>
<el-menu-item index="/materials">材料管理</el-menu-item>
<el-menu-item v-if="isAdmin" index="/screen/overview">数据大屏</el-menu-item>
</el-menu>
</aside>
<main class="main">
<header class="topbar">
<div class="breadcrumb">{{ title }}</div>
<div class="user">
<div class="user-info">
<div class="name">{{ user?.username || '用户' }}</div>
<div class="role">{{ isAdmin ? '管理员' : '普通账号' }}</div>
</div>
<el-button size="small" @click="openPassword">修改密码</el-button>
<el-button size="small" @click="onLogout">退出</el-button>
</div> </div>
</header> <el-button size="small" @click="openPassword">修改密码</el-button>
<section class="content"> <el-button size="small" @click="onLogout">退出</el-button>
<router-view /> </div>
</section> </header>
</main> <div class="body">
<aside class="sidebar">
<el-menu
:default-active="active"
class="menu"
router
>
<el-menu-item v-if="isAdmin" index="/users">用户管理</el-menu-item>
<el-menu-item index="/factories">供应商库</el-menu-item>
<el-menu-item index="/materials">材料管理</el-menu-item>
<el-menu-item v-if="isAdmin" index="/screen/overview">数据大屏</el-menu-item>
<el-sub-menu v-if="isAdmin" index="config">
<template #title>配置项</template>
<el-menu-item index="/dictionary">材料分类</el-menu-item>
</el-sub-menu>
</el-menu>
</aside>
<main class="main">
<section class="content">
<router-view />
</section>
</main>
</div>
</div> </div>
<el-dialog v-model="passwordVisible" title="修改密码" width="420px" class="dialog-scroll"> <el-dialog v-model="passwordVisible" title="修改密码" width="420px" class="dialog-scroll">
@ -66,13 +67,6 @@ const router = useRouter()
const { state, isAdmin, clearAuth } = useAuth() const { state, isAdmin, clearAuth } = useAuth()
const active = computed(() => route.path) const active = computed(() => route.path)
const titleMap = {
'/users': '用户管理',
'/factories': '供应商库',
'/dictionary': '材料分类管理',
'/materials': '材料管理'
}
const title = computed(() => titleMap[`/${route.path.split('/')[1]}`] || '系统首页')
const user = computed(() => state.user) const user = computed(() => state.user)
const passwordVisible = ref(false) const passwordVisible = ref(false)
@ -108,36 +102,69 @@ const onLogout = () => {
<style scoped> <style scoped>
.layout { .layout {
display: flex; display: flex;
flex-direction: column;
height: 100vh; height: 100vh;
} }
.topbar {
height: 64px;
padding: 0 24px;
display: flex;
align-items: center;
justify-content: space-between;
background: #fff;
box-shadow: 0 12px 24px rgba(15, 26, 42, 0.08);
flex-shrink: 0;
z-index: 10;
}
.logo-title {
font-size: 18px;
font-weight: 600;
color: var(--brand-900, #1b2a41);
white-space: nowrap;
}
.user {
display: flex;
align-items: center;
gap: 12px;
}
.user-info {
text-align: right;
line-height: 1.2;
}
.user-info .name {
font-weight: 600;
}
.user-info .role {
font-size: 12px;
color: #6b7785;
}
.body {
flex: 1;
display: flex;
min-height: 0;
}
.sidebar { .sidebar {
width: 220px; width: 220px;
flex-shrink: 0;
background: linear-gradient(180deg, var(--brand-900), var(--brand-950)); background: linear-gradient(180deg, var(--brand-900), var(--brand-950));
color: #fff; color: #fff;
display: flex; display: flex;
flex-direction: column; flex-direction: column;
} }
.logo {
padding: 20px 18px;
border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}
.logo-title {
font-size: 18px;
font-weight: 600;
}
.logo-sub {
font-size: 12px;
color: rgba(255, 255, 255, 0.6);
}
.menu { .menu {
border-right: none; border-right: none;
background: transparent; background: transparent;
color: #fff; color: #fff;
padding-top: 12px;
} }
:deep(.el-menu-item) { :deep(.el-menu-item) {
@ -156,6 +183,24 @@ const onLogout = () => {
background-color: rgba(255, 255, 255, 0.08); background-color: rgba(255, 255, 255, 0.08);
} }
:deep(.el-sub-menu__title) {
color: #fff;
transition: all 0.2s ease;
}
:deep(.el-sub-menu__title:hover) {
color: #fff;
background-color: rgba(255, 255, 255, 0.08);
}
:deep(.el-sub-menu.is-active > .el-sub-menu__title) {
color: #7cb4e3;
}
:deep(.el-sub-menu .el-menu) {
background: transparent;
}
.main { .main {
flex: 1; flex: 1;
display: flex; display: flex;
@ -163,34 +208,10 @@ const onLogout = () => {
min-height: 0; min-height: 0;
} }
.topbar {
height: 64px;
padding: 0 24px;
display: flex;
align-items: center;
justify-content: space-between;
background: #fff;
box-shadow: 0 12px 24px rgba(15, 26, 42, 0.08);
}
.user {
display: flex;
align-items: center;
gap: 12px;
}
.user-info {
text-align: right;
}
.content { .content {
flex: 1; flex: 1;
background: var(--bg); background: var(--bg);
min-height: 0; min-height: 0;
overflow: auto; overflow: auto;
} }
.breadcrumb {
font-weight: 600;
}
</style> </style>