56 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			Plaintext
		
	
	
			
		
		
	
	
			56 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			Plaintext
		
	
	
| <template>
 | |
|   <div :class="{'has-logo':showLogo}">
 | |
|     <logo v-if="showLogo" :collapse="isCollapse" />
 | |
|     <el-scrollbar wrap-class="scrollbar-wrapper">
 | |
|       <el-menu
 | |
|         :default-active="activeMenu"
 | |
|         :collapse="isCollapse"
 | |
|         :background-color="variables.menuBg"
 | |
|         :text-color="variables.menuText"
 | |
|         :unique-opened="false"
 | |
|         :active-text-color="variables.menuActiveText"
 | |
|         :collapse-transition="false"
 | |
|         mode="vertical"
 | |
|       >
 | |
|         <sidebar-item v-for="route in routes" :key="route.path" :item="route" :base-path="route.path" />
 | |
|       </el-menu>
 | |
|     </el-scrollbar>
 | |
|   </div>
 | |
| </template>
 | |
| 
 | |
| <script>
 | |
| import { mapGetters } from 'vuex'
 | |
| import Logo from './Logo'
 | |
| import SidebarItem from './SidebarItem'
 | |
| import variables from '@/styles/variables.scss'
 | |
| 
 | |
| export default {
 | |
|   components: { SidebarItem, Logo },
 | |
|   computed: {
 | |
|     ...mapGetters([
 | |
|       'sidebar'
 | |
|     ]),
 | |
|     routes() {
 | |
|       return this.$store.getters.routes
 | |
|     },
 | |
|     activeMenu() {
 | |
|       const route = this.$route
 | |
|       const { meta, path } = route
 | |
|       if (meta.activeMenu) {
 | |
|         return meta.activeMenu
 | |
|       }
 | |
|       return path
 | |
|     },
 | |
|     showLogo() {
 | |
|       return this.$store.state.settings.sidebarLogo
 | |
|     },
 | |
|     variables() {
 | |
|       return variables
 | |
|     },
 | |
|     isCollapse() {
 | |
|       return !this.sidebar.opened
 | |
|     }
 | |
|   }
 | |
| }
 | |
| </script>
 |