Files
vue-antd-admin-skeleton/src/components/menu/SideMenu.vue

57 lines
1.2 KiB
Vue
Raw Normal View History

2018-08-14 22:11:56 +08:00
<template>
<a-layout-sider :theme="sideTheme" :class="['side-menu', isMobile ? null : 'shadow']" width="256px" :collapsible="collapsible" v-model="collapsed" :trigger="null">
2018-08-29 15:02:46 +08:00
<div :class="['logo', theme]">
2018-08-15 12:09:54 +08:00
<router-link to="/dashboard/workplace">
2020-06-21 18:03:10 +08:00
<img src="@/assets/img/logo.png">
2018-09-03 10:39:39 +08:00
<h1>{{systemName}}</h1>
2018-08-15 12:09:54 +08:00
</router-link>
2018-08-14 22:11:56 +08:00
</div>
<i-menu :theme="theme" :collapsed="collapsed" :options="menuData" @select="onSelect" class="menu"/>
2018-08-14 22:11:56 +08:00
</a-layout-sider>
</template>
<script>
import IMenu from './menu'
import {mapState} from 'vuex'
2018-08-14 22:11:56 +08:00
export default {
name: 'SideMenu',
components: {IMenu},
2018-08-14 22:11:56 +08:00
props: {
collapsible: {
type: Boolean,
required: false,
default: false
},
collapsed: {
type: Boolean,
required: false,
default: false
},
menuData: {
type: Array,
required: true
2018-08-29 15:02:46 +08:00
},
theme: {
type: String,
required: false,
default: 'dark'
2018-08-14 22:11:56 +08:00
}
},
2018-08-20 22:46:14 +08:00
computed: {
sideTheme() {
return this.theme == 'light' ? this.theme : 'dark'
},
...mapState('setting', ['isMobile', 'systemName'])
2018-08-20 22:46:14 +08:00
},
2018-08-14 22:11:56 +08:00
methods: {
onSelect (obj) {
this.$emit('menuSelect', obj)
}
2018-08-14 22:11:56 +08:00
}
}
</script>
<style lang="less" scoped>
@import "index";
2018-08-14 22:11:56 +08:00
</style>