<template>
|
<div class="user-wrapper">
|
<div class="content-box">
|
<span class="action" @click="toggleFullscreen">
|
<a-icon type="fullscreen-exit" v-if="isFullscreen"/>
|
<a-icon type="fullscreen" v-else/>
|
</span>
|
<notice-icon class="action"/>
|
<a-dropdown>
|
<span class="action ant-dropdown-link user-dropdown-menu">
|
<a-avatar class="avatar" size="small" :src="avatar"/>
|
<span>{{ nickname }}</span>
|
</span>
|
<a-menu slot="overlay" class="user-dropdown-menu-wrapper">
|
<a-menu-item key="4" v-if="mode === 'sidemenu'">
|
<a @click="appToggled()" >
|
<a-icon type="swap"/>
|
<span>切换应用</span>
|
</a>
|
</a-menu-item>
|
<a-menu-item key="0">
|
<router-link :to="{ name: 'center' }">
|
<a-icon type="user"/>
|
<span>个人中心</span>
|
</router-link>
|
</a-menu-item>
|
<a-menu-item key="1">
|
<router-link :to="{ name: 'settings' }">
|
<a-icon type="setting"/>
|
<span>账户设置</span>
|
</router-link>
|
</a-menu-item>
|
<a-menu-divider/>
|
<a-menu-item key="3">
|
<a href="javascript:;" @click="handleLogout">
|
<a-icon type="logout"/>
|
<span>退出登录</span>
|
</a>
|
</a-menu-item>
|
</a-menu>
|
</a-dropdown>
|
</div>
|
<a-modal
|
title="切换应用"
|
:visible="visible"
|
:footer="null"
|
:confirm-loading="confirmLoading"
|
@cancel="handleCancel"
|
>
|
<a-form :form="form1" >
|
<a-form-item
|
:labelCol="labelCol"
|
:wrapperCol="wrapperCol"
|
label="选择应用"
|
>
|
<a-menu
|
mode="inline"
|
:default-selected-keys="this.defApp"
|
style="border-bottom:0px;lineHeight:55px;"
|
>
|
<a-menu-item v-for="(item) in userInfo.apps" :key="item.code" style="top:0px;" @click="switchApp(item.code)">
|
{{ item.name }}
|
</a-menu-item>
|
</a-menu>
|
</a-form-item>
|
</a-form>
|
</a-modal>
|
</div>
|
</template>
|
|
<script>
|
import screenfull from 'screenfull'
|
import NoticeIcon from '@/components/NoticeIcon'
|
import { mapActions, mapGetters } from 'vuex'
|
import { ALL_APPS_MENU } from '@/store/mutation-types'
|
import Vue from 'vue'
|
import { message } from 'ant-design-vue/es'
|
|
export default {
|
name: 'UserMenu',
|
components: {
|
NoticeIcon,
|
screenfull
|
},
|
props: {
|
mode: {
|
type: String,
|
// sidemenu, topmenu
|
default: 'sidemenu'
|
}
|
},
|
data () {
|
return {
|
labelCol: {
|
xs: { span: 24 },
|
sm: { span: 5 }
|
},
|
wrapperCol: {
|
xs: { span: 24 },
|
sm: { span: 16 }
|
},
|
visible: false,
|
confirmLoading: false,
|
form1: this.$form.createForm(this),
|
defApp: [],
|
isFullscreen: false
|
}
|
},
|
|
computed: {
|
...mapGetters(['nickname', 'avatar', 'userInfo'])
|
},
|
methods: {
|
...mapActions(['Logout', 'MenuChange']),
|
|
handleLogout () {
|
this.$confirm({
|
title: '提示',
|
content: '真的要注销登录吗 ?',
|
okText: '确定',
|
cancelText: '取消',
|
onOk: () => {
|
return this.Logout({}).then(() => {
|
setTimeout(() => {
|
window.location.reload()
|
}, 16)
|
}).catch(err => {
|
this.$message.error({
|
title: '错误',
|
description: err.message
|
})
|
})
|
},
|
onCancel () {
|
}
|
})
|
},
|
|
/**
|
* 打开切换应用框
|
*/
|
appToggled () {
|
this.visible = true
|
this.defApp.push(Vue.ls.get(ALL_APPS_MENU)[0].code)
|
},
|
|
switchApp (appCode) {
|
this.visible = false
|
this.defApp = []
|
const applicationData = this.userInfo.apps.filter(item => item.code === appCode)
|
const hideMessage = message.loading('正在切换应用!', 0)
|
this.MenuChange(applicationData[0]).then((res) => {
|
hideMessage()
|
// eslint-disable-next-line handle-callback-err
|
}).catch((err) => {
|
message.error('应用切换异常')
|
})
|
},
|
handleCancel () {
|
this.form1.resetFields()
|
this.visible = false
|
},
|
/* 全屏切换 */
|
toggleFullscreen () {
|
if (!screenfull.isEnabled) {
|
message.error('您的浏览器不支持全屏模式')
|
return
|
}
|
screenfull.toggle()
|
if (screenfull.isFullscreen) {
|
this.isFullscreen = false
|
} else {
|
this.isFullscreen = true
|
}
|
}
|
}
|
}
|
</script>
|
|
<style lang="less" scoped>
|
.appRedio {
|
border:1px solid #91d5ff;
|
padding:10px 20px;
|
background: #e6f7ff;
|
border-radius:2px;
|
margin-bottom:10px;
|
color: #91d5ff;
|
/*display: inline;
|
margin-bottom:10px;*/
|
}
|
</style>
|