Compare commits

..

No commits in common. "5e838368cb6084c078f17ee40fc2c36a3201f3c3" and "6d1663f282c1e331eb1fb5cb85bb6c14f0919dae" have entirely different histories.

1 changed files with 135 additions and 138 deletions

View File

@ -1,47 +1,46 @@
<template> <template>
<div class="navbar"> <div class="navbar">
<hamburger id="hamburger-container" :is-active="appStore.sidebar.opened" class="hamburger-container" @toggleClick="toggleSideBar" /> <hamburger id="hamburger-container" :is-active="appStore.sidebar.opened" class="hamburger-container"
<breadcrumb id="breadcrumb-container" class="breadcrumb-container" v-if="!settingsStore.topNav" /> @toggleClick="toggleSideBar" />
<top-nav id="topmenu-container" class="topmenu-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" />
<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 && false ">:{{ data.comName }}</el-tag> <el-tag class="cur-comp" v-if="data.comName">:{{ 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> <el-icon><caret-bottom /></el-icon>
<caret-bottom /> </div>
</el-icon> <template #dropdown>
</div> <el-dropdown-menu>
<template #dropdown> <router-link to="/user/profile">
<el-dropdown-menu> <el-dropdown-item>个人中心</el-dropdown-item>
<router-link to="/user/profile"> </router-link>
<el-dropdown-item>个人中心</el-dropdown-item> <el-dropdown-item command="setLayout">
</router-link> <span>布局设置</span>
<el-dropdown-item command="setLayout"> </el-dropdown-item>
<span>布局设置</span> <el-dropdown-item divided command="logout">
</el-dropdown-item> <span>退出登录</span>
<el-dropdown-item divided command="logout"> </el-dropdown-item>
<span>退出登录</span> </el-dropdown-menu>
</el-dropdown-item> </template>
</el-dropdown-menu> </el-dropdown>
</template> </div>
</el-dropdown>
</div>
</div>
</div> </div>
</div>
</template> </template>
<script setup> <script setup>
@ -61,140 +60,138 @@ 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';
}) })
.then(() => { }).catch(() => { });
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; position: relative;
background: #fff; background: #fff;
box-shadow: 0 1px 4px rgba(0, 21, 41, 0.08); box-shadow: 0 1px 4px rgba(0, 21, 41, 0.08);
.cur-comp { .cur-comp {
position: relative; position: relative;
top: 11px; top: 11px;
height: 32px; height: 32px;
line-height: 32px; line-height: 32px;
}
.hamburger-container {
line-height: 46px;
height: 100%;
float: left;
cursor: pointer;
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;
} }
.hamburger-container { .right-menu-item {
line-height: 46px; display: inline-block;
height: 100%; padding: 0 8px;
float: left; height: 100%;
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);
} }
}
} }
.breadcrumb-container { .avatar-container {
float: left; margin-right: 40px;
}
.topmenu-container { .avatar-wrapper {
position: absolute; margin-top: 5px;
left: 50px; position: relative;
}
.errLog-container { .user-avatar {
display: inline-block; cursor: pointer;
vertical-align: top; width: 40px;
} height: 40px;
border-radius: 10px;
.right-menu {
float: right;
height: 100%;
line-height: 50px;
display: flex;
&:focus {
outline: none;
} }
.right-menu-item { i {
display: inline-block; cursor: pointer;
padding: 0 8px; position: absolute;
height: 100%; right: -20px;
font-size: 18px; top: 25px;
color: #5a5e66; font-size: 12px;
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>