1
0
mirror of https://github.com/zclzone/vue-naive-admin.git synced 2025-05-01 06:39:01 +08:00
2023-12-13 23:18:54 +08:00

84 lines
2.3 KiB
Vue

<!--------------------------------
- @Author: Ronnie Zhang
- @LastEditor: Ronnie Zhang
- @LastEditTime: 2023/12/05 21:23:46
- @Email: zclzone@outlook.com
- Copyright © 2023 Ronnie Zhang(大脸怪) | https://isme.top
--------------------------------->
<template>
<n-dropdown :options="options" @select="handleSelect">
<div class="flex cursor-pointer items-center">
<n-avatar round :size="36" :src="userStore.avatar" class="mr-12" />
<div v-if="userStore.userInfo" class="flex-col items-center">
<span class="text-14">{{ userStore.nickName ?? userStore.username }}</span>
<span class="text-12 opacity-50">[{{ userStore.currentRole?.name }}]</span>
</div>
</div>
</n-dropdown>
<RoleSelect ref="roleSelectRef" />
</template>
<script setup>
import { useUserStore, useAuthStore, usePermissionStore } from '@/store'
import { RoleSelect } from '@/layouts/components'
import { initUserAndPermissions } from '@/router'
import api from '@/api'
const router = useRouter()
const userStore = useUserStore()
const authStore = useAuthStore()
const permissionStore = usePermissionStore()
const options = reactive([
{
label: '个人资料',
key: 'profile',
icon: () => h('i', { class: 'i-material-symbols:person-outline text-14' }),
show: computed(() => permissionStore.accessRoutes?.some((item) => item.path === '/profile')),
},
{
label: '切换角色',
key: 'toggleRole',
icon: () => h('i', { class: 'i-basil:exchange-solid text-14' }),
show: computed(() => userStore.roles.length > 1),
},
{
label: '退出登录',
key: 'logout',
icon: () => h('i', { class: 'i-mdi:exit-to-app text-14' }),
},
])
const roleSelectRef = ref(null)
function handleSelect(key) {
switch (key) {
case 'profile':
router.push('/profile')
break
case 'toggleRole':
roleSelectRef.value?.open({
onOk() {
initUserAndPermissions().then(() => {
router.replace('/')
})
},
})
break
case 'logout':
$dialog.confirm({
title: '提示',
type: 'info',
content: '确认退出?',
async confirm() {
await api.logout()
authStore.logout()
$message.success('已退出登录')
},
})
break
}
}
</script>