You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
362 lines
9.0 KiB
362 lines
9.0 KiB
<template>
|
|
<el-container class="layout-admin">
|
|
<el-aside
|
|
:class="isCollapse ? 'layout-aside-collapsed' : ''"
|
|
:width="'240px'"
|
|
>
|
|
<div class="logo" @click="gohome" title="文库管理后台">
|
|
<img v-if="isCollapse" src="/static/images/logo-icon.png" />
|
|
<img v-else src="/static/images/logo.png" />
|
|
</div>
|
|
<transition
|
|
:duration="{ enter: 800, leave: 800 }"
|
|
mode="out-in"
|
|
name="el-fade-in-linear"
|
|
>
|
|
<el-menu
|
|
:router="true"
|
|
:default-active="activeMenu"
|
|
:collapse="isCollapse"
|
|
class="layout-admin-menu"
|
|
>
|
|
<el-menu-item index="/admin/dashboard">
|
|
<i class="el-icon-monitor"></i>
|
|
<span slot="title">面板</span>
|
|
</el-menu-item>
|
|
<template v-for="menu in menus">
|
|
<el-submenu
|
|
v-if="menu.children"
|
|
v-show="allowPages.includes(menu.page)"
|
|
:key="'submenu-' + menu.page"
|
|
:index="menu.page"
|
|
>
|
|
<template slot="title">
|
|
<i :class="menu.icon"></i>
|
|
<span slot="title">{{ menu.title }}</span>
|
|
</template>
|
|
<el-menu-item
|
|
v-for="child in menu.children"
|
|
v-show="allowPages.includes(child.page)"
|
|
:key="child.page"
|
|
:index="child.page"
|
|
>
|
|
<i :class="child.icon"></i>
|
|
<span>{{ child.title }}</span>
|
|
</el-menu-item>
|
|
</el-submenu>
|
|
<el-menu-item
|
|
v-else
|
|
v-show="allowPages.includes(menu.page)"
|
|
:key="'menu-' + menu.page"
|
|
:index="menu.page"
|
|
>
|
|
<i :class="menu.icon"></i>
|
|
<span slot="title">{{ menu.title }}</span>
|
|
</el-menu-item>
|
|
</template>
|
|
</el-menu>
|
|
</transition>
|
|
</el-aside>
|
|
<el-container>
|
|
<el-header>
|
|
<el-button
|
|
v-if="isCollapse"
|
|
class="fold"
|
|
icon="el-icon-s-unfold"
|
|
type="text"
|
|
@click="isCollapse = false"
|
|
></el-button>
|
|
<el-button
|
|
v-else
|
|
class="fold"
|
|
icon="el-icon-s-fold"
|
|
type="text"
|
|
@click="isCollapse = true"
|
|
></el-button>
|
|
<el-dropdown style="float: right" trigger="click" @command="command">
|
|
<el-button>
|
|
<i class="el-icon-user"></i>
|
|
<span>{{ user.username }}</span>
|
|
</el-button>
|
|
<el-dropdown-menu slot="dropdown">
|
|
<el-dropdown-item command="profile"> 个人资料 </el-dropdown-item>
|
|
<el-dropdown-item command="password"> 修改密码 </el-dropdown-item>
|
|
<el-dropdown-item command="logout">退出登录</el-dropdown-item>
|
|
</el-dropdown-menu>
|
|
</el-dropdown>
|
|
</el-header>
|
|
<el-main>
|
|
<nuxt />
|
|
</el-main>
|
|
</el-container>
|
|
<el-dialog title="个人资料" :visible.sync="formProfileVisible" width="30%">
|
|
<FormProfile @success="profileSuccess" />
|
|
</el-dialog>
|
|
<el-dialog title="个人资料" :visible.sync="formPasswordVisible" width="30%">
|
|
<FormPassword @success="passwordSuccess" />
|
|
</el-dialog>
|
|
</el-container>
|
|
</template>
|
|
<script>
|
|
import { mapGetters, mapActions } from 'vuex'
|
|
import FormProfile from '~/components/FormProfile.vue'
|
|
import FormPassword from '~/components/FormPassword.vue'
|
|
export default {
|
|
components: {
|
|
FormProfile,
|
|
FormPassword,
|
|
},
|
|
middleware: ['auth'],
|
|
data() {
|
|
return {
|
|
formProfileVisible: false,
|
|
formPasswordVisible: false,
|
|
isCollapse: false,
|
|
activeMenu: this.$route.path,
|
|
menus: [
|
|
{
|
|
page: '/admin/document',
|
|
title: '文档管理',
|
|
icon: 'el-icon-document-copy',
|
|
children: [
|
|
{
|
|
page: '/admin/document/category',
|
|
title: '分类管理',
|
|
icon: 'el-icon-s-grid',
|
|
},
|
|
{
|
|
page: '/admin/document/list',
|
|
title: '文档列表',
|
|
icon: 'el-icon-tickets',
|
|
},
|
|
{
|
|
page: '/admin/document/recycle',
|
|
title: '回收站',
|
|
icon: 'el-icon-delete',
|
|
},
|
|
],
|
|
},
|
|
{
|
|
page: '/admin/user',
|
|
title: '用户管理',
|
|
icon: 'el-icon-user',
|
|
children: [
|
|
{
|
|
page: '/admin/user/list',
|
|
title: '用户管理',
|
|
icon: 'el-icon-user',
|
|
},
|
|
{
|
|
page: '/admin/user/group',
|
|
title: '角色管理',
|
|
icon: 'el-icon-magic-stick',
|
|
},
|
|
{
|
|
page: '/admin/user/permission',
|
|
title: '权限管理',
|
|
icon: 'el-icon-circle-check',
|
|
},
|
|
],
|
|
},
|
|
{
|
|
page: '/admin/banner',
|
|
title: '横幅管理',
|
|
icon: 'el-icon-picture-outline',
|
|
},
|
|
{
|
|
page: '/admin/article',
|
|
title: '文章管理',
|
|
icon: 'el-icon-discover',
|
|
},
|
|
{
|
|
page: '/admin/friendlink',
|
|
title: '友链管理',
|
|
icon: 'el-icon-link',
|
|
},
|
|
{
|
|
page: '/admin/comment',
|
|
title: '评论管理',
|
|
icon: 'el-icon-chat-dot-square',
|
|
},
|
|
{
|
|
page: '/admin/report',
|
|
title: '举报管理',
|
|
icon: 'el-icon-warning-outline',
|
|
},
|
|
{
|
|
page: '/admin/attachment',
|
|
title: '附件管理',
|
|
icon: 'el-icon-paperclip',
|
|
},
|
|
{
|
|
page: '/admin/config',
|
|
title: '系统设置',
|
|
icon: 'el-icon-setting',
|
|
},
|
|
],
|
|
}
|
|
},
|
|
head() {
|
|
return {
|
|
title:
|
|
this.settings.system.title || this.settings.system.sitename || '文库',
|
|
link: [
|
|
{
|
|
rel: 'icon',
|
|
type: 'image/x-icon',
|
|
href: this.settings.system.favicon,
|
|
},
|
|
],
|
|
}
|
|
},
|
|
computed: {
|
|
...mapGetters('user', ['user', 'token', 'permissions', 'allowPages']),
|
|
...mapGetters('setting', ['settings']),
|
|
},
|
|
created() {
|
|
if (this.activeMenu.endsWith('/')) {
|
|
this.activeMenu = this.activeMenu.slice(0, -1)
|
|
}
|
|
this.getUserPermissions()
|
|
},
|
|
mounted() {
|
|
const screenWidth = document.body.clientWidth
|
|
if (screenWidth < 1000) {
|
|
this.isCollapse = !this.isCollapse
|
|
}
|
|
},
|
|
methods: {
|
|
...mapActions('user', ['logout', 'getUserPermissions']),
|
|
profileSuccess() {
|
|
this.formProfileVisible = false
|
|
},
|
|
passwordSuccess() {
|
|
this.formPasswordVisible = false
|
|
},
|
|
command(cmd) {
|
|
switch (cmd) {
|
|
case 'profile':
|
|
this.formProfileVisible = true
|
|
break
|
|
case 'password':
|
|
this.formPasswordVisible = true
|
|
break
|
|
case 'logout':
|
|
this.logout()
|
|
this.$router.replace({ path: '/' })
|
|
this.$message.success('退出成功')
|
|
break
|
|
}
|
|
},
|
|
gohome() {
|
|
this.$router.push('/')
|
|
},
|
|
},
|
|
}
|
|
</script>
|
|
<style lang="scss">
|
|
.layout-admin {
|
|
.logo {
|
|
cursor: pointer;
|
|
height: 60px;
|
|
border-bottom: 1px solid #e5e5e5;
|
|
box-sizing: border-box;
|
|
overflow: hidden;
|
|
display: flex;
|
|
flex-direction: row;
|
|
justify-content: space-between;
|
|
img {
|
|
padding: 5px;
|
|
height: 50px;
|
|
margin: 0 2px;
|
|
max-width: 100%;
|
|
}
|
|
span {
|
|
font-size: 26px;
|
|
width: 240px;
|
|
font-weight: bold;
|
|
text-align: left;
|
|
height: 60px;
|
|
line-height: 60px;
|
|
}
|
|
}
|
|
height: 100vh;
|
|
.el-main {
|
|
background-color: #f0f2f5;
|
|
}
|
|
.el-aside {
|
|
transition: width 0.2s;
|
|
height: 100vh;
|
|
border-right: 1px solid #e6e6e6;
|
|
.el-menu {
|
|
border-right: 0;
|
|
}
|
|
}
|
|
.el-header {
|
|
border-bottom: 1px solid #e6e6e6;
|
|
line-height: 60px;
|
|
.fold {
|
|
padding: 0 15px 0 0;
|
|
font-size: 20px;
|
|
color: #999;
|
|
cursor: pointer;
|
|
&:hover {
|
|
color: #555;
|
|
}
|
|
}
|
|
}
|
|
.el-footer {
|
|
border-top: 1px solid #e6e6e6;
|
|
text-align: center;
|
|
line-height: 60px;
|
|
height: 60px;
|
|
overflow: hidden;
|
|
color: #999;
|
|
a {
|
|
color: #409eff;
|
|
}
|
|
}
|
|
.el-table th {
|
|
height: 45px;
|
|
line-height: 45px;
|
|
padding: 1px 0 5px;
|
|
&.el-table__cell {
|
|
background-color: #f7fbff;
|
|
color: #000;
|
|
font-weight: normal;
|
|
&.el-table-column--selection > .cell {
|
|
padding-left: 14px;
|
|
}
|
|
}
|
|
&.el-table__cell.is-leaf {
|
|
border-bottom: 0;
|
|
}
|
|
}
|
|
.search-card {
|
|
.el-card__body {
|
|
padding-bottom: 0;
|
|
}
|
|
}
|
|
.el-menu-item.is-active {
|
|
background-color: #ecf5ff;
|
|
}
|
|
}
|
|
|
|
.layout-aside-collapsed {
|
|
width: 64px !important;
|
|
overflow: hidden;
|
|
.quickstart-upload {
|
|
padding: 0;
|
|
.el-button {
|
|
height: 59px;
|
|
line-height: 30px;
|
|
padding: 0 5px;
|
|
border-radius: 0;
|
|
span {
|
|
display: block;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
</style>
|