后台隐藏头部

dev_xd
haha 2025-04-13 23:09:31 +08:00
parent c50517a26c
commit 1b80070208
1 changed files with 142 additions and 139 deletions

View File

@ -1,46 +1,47 @@
<template> <template>
<div class="navbar"> <div class="navbar">
<hamburger id="hamburger-container" :is-active="appStore.sidebar.opened" class="hamburger-container" <hamburger id="hamburger-container" :is-active="appStore.sidebar.opened" class="hamburger-container" @toggleClick="toggleSideBar" />
@toggleClick="toggleSideBar" /> <breadcrumb id="breadcrumb-container" class="breadcrumb-container" v-if="!settingsStore.topNav" />
<breadcrumb id="breadcrumb-container" class="breadcrumb-container" v-if="!settingsStore.topNav" /> <top-nav id="topmenu-container" class="topmenu-container" v-if="settingsStore.topNav" />
<top-nav id="topmenu-container" class="topmenu-container" v-if="settingsStore.topNav" />
<div class="right-menu"> <div class="right-menu">
<template v-if="appStore.device !== 'mobile'"> <template v-if="appStore.device !== 'mobile'">
<el-tag class="cur-comp" v-if="data.comName">:{{ data.comName }}</el-tag> <el-tag class="cur-comp" v-if="data.comName && false ">:{{ data.comName }}</el-tag>
<current-project id="current-project" class="right-menu-item" /> <current-project id="current-project" class="right-menu-item" />
<header-search id="header-search" class="right-menu-item" /> <header-search id="header-search" class="right-menu-item" />
<screenfull id="screenfull" class="right-menu-item hover-effect" /> <screenfull id="screenfull" class="right-menu-item hover-effect" />
<el-tooltip content="布局大小" effect="dark" placement="bottom"> <el-tooltip content="布局大小" effect="dark" placement="bottom">
<size-select id="size-select" class="right-menu-item hover-effect" /> <size-select id="size-select" class="right-menu-item hover-effect" />
</el-tooltip> </el-tooltip>
</template> </template>
<div class="avatar-container"> <div class="avatar-container">
<el-dropdown @command="handleCommand" class="right-menu-item hover-effect" trigger="click"> <el-dropdown @command="handleCommand" class="right-menu-item hover-effect" trigger="click">
<div class="avatar-wrapper"> <div class="avatar-wrapper">
<img :src="userStore.avatar" class="user-avatar" /> <img :src="userStore.avatar" class="user-avatar" />
<el-icon><caret-bottom /></el-icon> <el-icon>
</div> <caret-bottom />
<template #dropdown> </el-icon>
<el-dropdown-menu> </div>
<router-link to="/user/profile"> <template #dropdown>
<el-dropdown-item>个人中心</el-dropdown-item> <el-dropdown-menu>
</router-link> <router-link to="/user/profile">
<el-dropdown-item command="setLayout"> <el-dropdown-item>个人中心</el-dropdown-item>
<span>布局设置</span> </router-link>
</el-dropdown-item> <el-dropdown-item command="setLayout">
<el-dropdown-item divided command="logout"> <span>布局设置</span>
<span>退出登录</span> </el-dropdown-item>
</el-dropdown-item> <el-dropdown-item divided command="logout">
</el-dropdown-menu> <span>退出登录</span>
</template> </el-dropdown-item>
</el-dropdown> </el-dropdown-menu>
</div> </template>
</el-dropdown>
</div>
</div>
</div> </div>
</div>
</template> </template>
<script setup> <script setup>
@ -60,138 +61,140 @@ const appStore = useAppStore()
const userStore = useUserStore() const userStore = useUserStore()
const settingsStore = useSettingsStore() const settingsStore = useSettingsStore()
const data = reactive({ const data = reactive({
comName: '', comName: '',
}) })
function toggleSideBar() { function toggleSideBar() {
appStore.toggleSideBar(); appStore.toggleSideBar()
userStore.getTasks(); // userStore.getTasks() //
} }
function handleCommand(command) { function handleCommand(command) {
switch (command) { switch (command) {
case "setLayout": case 'setLayout':
setLayout(); setLayout()
break; break
case "logout": case 'logout':
logout(); logout()
break; break
default: default:
break; break
} }
} }
function logout() { function logout() {
ElMessageBox.confirm('确定注销并退出系统吗?', '提示', { ElMessageBox.confirm('确定注销并退出系统吗?', '提示', {
confirmButtonText: '确定', confirmButtonText: '确定',
cancelButtonText: '取消', cancelButtonText: '取消',
type: 'warning' type: 'warning',
}).then(() => {
userStore.logOut().then(() => {
location.href = '#/index';
}) })
}).catch(() => { }); .then(() => {
userStore.logOut().then(() => {
location.href = '#/index'
})
})
.catch(() => {})
} }
const emits = defineEmits(['setLayout']) const emits = defineEmits(['setLayout'])
function setLayout() { function setLayout() {
emits('setLayout'); emits('setLayout')
} }
data.comName = userStore.currentComName data.comName = userStore.currentComName
</script> </script>
<style lang='scss' scoped> <style lang='scss' scoped>
.navbar { .navbar {
height: 50px; height: 50px;
overflow: hidden; overflow: hidden;
position: relative;
background: #fff;
box-shadow: 0 1px 4px rgba(0, 21, 41, 0.08);
.cur-comp {
position: relative; position: relative;
top: 11px; background: #fff;
height: 32px; box-shadow: 0 1px 4px rgba(0, 21, 41, 0.08);
line-height: 32px;
}
.hamburger-container { .cur-comp {
line-height: 46px; position: relative;
height: 100%; top: 11px;
float: left; height: 32px;
cursor: pointer; line-height: 32px;
transition: background 0.3s;
-webkit-tap-highlight-color: transparent;
&:hover {
background: rgba(0, 0, 0, 0.025);
}
}
.breadcrumb-container {
float: left;
}
.topmenu-container {
position: absolute;
left: 50px;
}
.errLog-container {
display: inline-block;
vertical-align: top;
}
.right-menu {
float: right;
height: 100%;
line-height: 50px;
display: flex;
&:focus {
outline: none;
} }
.right-menu-item { .hamburger-container {
display: inline-block; line-height: 46px;
padding: 0 8px; height: 100%;
height: 100%; float: left;
font-size: 18px;
color: #5a5e66;
vertical-align: text-bottom;
&.hover-effect {
cursor: pointer; cursor: pointer;
transition: background 0.3s; transition: background 0.3s;
-webkit-tap-highlight-color: transparent;
&:hover { &:hover {
background: rgba(0, 0, 0, 0.025); background: rgba(0, 0, 0, 0.025);
} }
}
} }
.avatar-container { .breadcrumb-container {
margin-right: 40px; float: left;
}
.avatar-wrapper {
margin-top: 5px; .topmenu-container {
position: relative; position: absolute;
left: 50px;
.user-avatar { }
cursor: pointer;
width: 40px; .errLog-container {
height: 40px; display: inline-block;
border-radius: 10px; vertical-align: top;
} }
i { .right-menu {
cursor: pointer; float: right;
position: absolute; height: 100%;
right: -20px; line-height: 50px;
top: 25px; display: flex;
font-size: 12px;
} &:focus {
} outline: none;
}
.right-menu-item {
display: inline-block;
padding: 0 8px;
height: 100%;
font-size: 18px;
color: #5a5e66;
vertical-align: text-bottom;
&.hover-effect {
cursor: pointer;
transition: background 0.3s;
&:hover {
background: rgba(0, 0, 0, 0.025);
}
}
}
.avatar-container {
margin-right: 40px;
.avatar-wrapper {
margin-top: 5px;
position: relative;
.user-avatar {
cursor: pointer;
width: 40px;
height: 40px;
border-radius: 10px;
}
i {
cursor: pointer;
position: absolute;
right: -20px;
top: 25px;
font-size: 12px;
}
}
}
} }
}
} }
</style> </style>