<template>
|
<div
|
:class="{ 'has-logo': showLogo }"
|
:style="{ backgroundColor: variables.menuLightBackground }"
|
>
|
<!-- <logo v-if="showLogo" :collapse="isCollapse" /> -->
|
<div class="hamburger-container">
|
<div class="border">
|
<div class="menu-tip" v-show="sidebar.opened">菜单管理</div>
|
<hamburger
|
id="hamburger-container"
|
:is-active="sidebar.opened"
|
class="hamburger-icon"
|
@toggleClick="toggleSideBar"
|
/>
|
</div>
|
</div>
|
<el-scrollbar
|
:class="settings.sideTheme"
|
wrap-class="scrollbar-wrapper"
|
>
|
<el-menu
|
:default-active="activeMenu"
|
:collapse="isCollapse"
|
:background-color="variables.menuLightBackground"
|
:text-color="variables.menuLightColor"
|
:unique-opened="true"
|
:active-text-color="settings.theme"
|
:collapse-transition="false"
|
mode="vertical"
|
>
|
<sidebar-item
|
v-for="(route, index) in sidebarRouters"
|
:key="route.path + index"
|
:item="route"
|
:base-path="route.path"
|
/>
|
</el-menu>
|
</el-scrollbar>
|
</div>
|
</template>
|
|
<script>
|
import { mapGetters, mapState } from "vuex";
|
import Logo from "./Logo";
|
import SidebarItem from "./SidebarItem";
|
import variables from "@/assets/styles/variables.scss";
|
import Hamburger from '@/components/Hamburger'
|
|
export default {
|
components: { SidebarItem, Logo, Hamburger },
|
computed: {
|
...mapState(["settings"]),
|
...mapGetters(["sidebarRouters", "sidebar"]),
|
activeMenu() {
|
const route = this.$route;
|
const { meta, path } = route;
|
// if set path, the sidebar will highlight the path you set
|
if (meta.activeMenu) {
|
return meta.activeMenu;
|
}
|
return path;
|
},
|
showLogo() {
|
return this.$store.state.settings.sidebarLogo;
|
},
|
variables() {
|
return variables;
|
},
|
isCollapse() {
|
return !this.sidebar.opened;
|
}
|
},
|
created() {
|
// console.log(this.settings.sideTheme);
|
},
|
methods: {
|
toggleSideBar() {
|
this.$store.dispatch('app/toggleSideBar')
|
},
|
}
|
};
|
</script>
|
<style scoped>
|
.hamburger-container {
|
display: flex;
|
color: #fff;
|
justify-content: space-between;
|
height: 59px;
|
line-height: 59px;
|
.border {
|
margin: 0 auto;
|
display: flex;
|
justify-content: space-between;
|
width: 180px;
|
border-bottom: 1px solid #e6eaf5;
|
}
|
.menu-tip {
|
height: 50px;
|
font-size: 14px;
|
font-weight: 400;
|
color: #000000;
|
padding-left: 20px;
|
}
|
.hamburger-icon {
|
width: 54px;
|
text-align: center;
|
cursor: pointer;
|
&:hover {
|
background: rgba(0, 0, 0, 0.025);
|
}
|
}
|
}
|
</style>
|