mirror of
https://github.com/iczer/vue-antd-admin.git
synced 2025-04-06 03:57:44 +08:00
116 lines
2.4 KiB
Vue
116 lines
2.4 KiB
Vue
<template>
|
|
<a-layout>
|
|
<a-layout-sider width="256px" collapsible v-model="collapsed" :trigger="null">
|
|
<div class="logo">
|
|
<a href="/">
|
|
<img src="static/img/vue-antd-logo.png">
|
|
<h1>Vue Ant Pro</h1>
|
|
</a>
|
|
</div>
|
|
<!--<gloabl-menu :collapsed="collapsed"/>-->
|
|
<i-menu :menuData="menuData" />
|
|
</a-layout-sider>
|
|
<a-layout>
|
|
<gloabl-header :collapsed="collapsed" @toggleCollapse="toggleCollapse"/>
|
|
<a-layout-content :style="{minHeight: minHeight, margin: '24px 24px 0'}">
|
|
<slot></slot>
|
|
</a-layout-content>
|
|
<a-layout-footer></a-layout-footer>
|
|
</a-layout>
|
|
</a-layout>
|
|
</template>
|
|
|
|
<script>
|
|
import ALayout from 'vue-antd-ui/es/layout'
|
|
import GloablHeader from './GloablHeader'
|
|
import AIcon from 'vue-antd-ui/es/icon/icon'
|
|
import GloablMenu from './GloablMenu'
|
|
import IMenu from '../menu/menu'
|
|
|
|
const ALayoutSider = ALayout.Sider
|
|
const ALayoutHeader = ALayout.Header
|
|
const ALayoutContent = ALayout.Content
|
|
const ALayoutFooter = ALayout.Footer
|
|
const minHeight = window.innerHeight - 64 - 48
|
|
|
|
const menuData = [
|
|
{
|
|
title: '统计分析',
|
|
path: '/dashboard'
|
|
},
|
|
{
|
|
title: '图表',
|
|
path: '/chart',
|
|
icon: 'line-chart'
|
|
},
|
|
{
|
|
title: '报表系统'
|
|
},
|
|
{
|
|
title: '日志',
|
|
children: [
|
|
{
|
|
title: '日志分析',
|
|
icon: 'none'
|
|
},
|
|
{
|
|
title: '数据分析',
|
|
icon: 'none'
|
|
}
|
|
]
|
|
}
|
|
]
|
|
|
|
export default {
|
|
name: 'GloablLayout',
|
|
components: {
|
|
GloablMenu,
|
|
AIcon,
|
|
GloablHeader,
|
|
ALayout,
|
|
ALayoutSider,
|
|
ALayoutHeader,
|
|
ALayoutContent,
|
|
ALayoutFooter,
|
|
IMenu},
|
|
data () {
|
|
return {
|
|
minHeight: minHeight + 'px',
|
|
collapsed: false,
|
|
menuData: menuData
|
|
}
|
|
},
|
|
methods: {
|
|
toggleCollapse () {
|
|
this.collapsed = !this.collapsed
|
|
}
|
|
}
|
|
}
|
|
</script>
|
|
|
|
<style scoped>
|
|
.logo{
|
|
height: 64px;
|
|
position: relative;
|
|
line-height: 64px;
|
|
padding-left: 24px;
|
|
-webkit-transition: all .3s;
|
|
transition: all .3s;
|
|
background: #002140;
|
|
overflow: hidden;
|
|
}
|
|
.logo h1{
|
|
color: #fff;
|
|
font-size: 20px;
|
|
margin: 0 0 0 12px;
|
|
font-family: "Myriad Pro","Helvetica Neue",Arial,Helvetica,sans-serif;
|
|
font-weight: 600;
|
|
display: inline-block;
|
|
}
|
|
.logo img{
|
|
width: 32px;
|
|
display: inline-block;
|
|
vertical-align: middle;
|
|
}
|
|
</style>
|