mirror of
https://github.com/zclzone/vue-naive-admin.git
synced 2025-05-01 06:39:01 +08:00
84 lines
2.3 KiB
Vue
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>
|