219 lines
6.5 KiB
Vue
219 lines
6.5 KiB
Vue
<template>
|
|
<el-dropdown trigger="click" type="primary">
|
|
<div class="flex-center cursor">
|
|
<el-avatar :size="30">
|
|
<img src="@/assets/user-icon.svg" style="width: 54%" alt="" />
|
|
</el-avatar>
|
|
<span class="ml-8 color-text-primary">{{ user.userInfo?.username }}</span>
|
|
<el-icon class="el-icon--right">
|
|
<CaretBottom />
|
|
</el-icon>
|
|
</div>
|
|
|
|
<template #dropdown>
|
|
<el-dropdown-menu class="avatar-dropdown">
|
|
<div class="userInfo flex align-center">
|
|
<div class="mr-12 flex align-center">
|
|
<el-avatar :size="30">
|
|
<img src="@/assets/user-icon.svg" style="width: 54%" alt="" />
|
|
</el-avatar>
|
|
</div>
|
|
<div style="width: 90%">
|
|
<p class="bold mb-4" style="font-size: 14px">{{ user.userInfo?.username }}</p>
|
|
<template v-if="user.userInfo?.role_name && user.userInfo.role_name.length > 0">
|
|
<TagGroup
|
|
size="small"
|
|
:tags="user.userInfo?.role_name"
|
|
v-if="hasPermission([EditionConst.IS_EE, EditionConst.IS_PE], 'OR')"
|
|
/>
|
|
</template>
|
|
</div>
|
|
</div>
|
|
<el-dropdown-item class="border-t"
|
|
@click="router.push({ path: `/system/user` })"
|
|
v-if="
|
|
hasPermission(
|
|
[
|
|
RoleConst.EXTENDS_ADMIN,
|
|
RoleConst.EXTENDS_WORKSPACE_MANAGE,
|
|
RoleConst.ADMIN,
|
|
RoleConst.WORKSPACE_MANAGE,
|
|
],
|
|
'OR',
|
|
)
|
|
"
|
|
>
|
|
<div class="flex-between w-full">
|
|
{{ $t('views.system.title') }}
|
|
<AppIcon iconName="app-go"></AppIcon>
|
|
</div>
|
|
</el-dropdown-item>
|
|
<el-dropdown-item
|
|
|
|
@click="openResetPassword"
|
|
v-if="
|
|
hasPermission(
|
|
new ComplexPermission(
|
|
[RoleConst.ADMIN, RoleConst.WORKSPACE_MANAGE, RoleConst.USER],
|
|
[PermissionConst.CHANGE_PASSWORD],
|
|
[],
|
|
'OR',
|
|
),
|
|
'OR',
|
|
)
|
|
"
|
|
>
|
|
{{ $t('views.login.resetPassword') }}
|
|
</el-dropdown-item>
|
|
<div>
|
|
<el-dropdown-item
|
|
class="p-8"
|
|
@click="openAPIKeyDialog"
|
|
v-if="
|
|
hasPermission(
|
|
new ComplexPermission(
|
|
[RoleConst.ADMIN],
|
|
[PermissionConst.SYSTEM_API_KEY_EDIT],
|
|
[EditionConst.IS_EE, EditionConst.IS_PE],
|
|
'OR',
|
|
),
|
|
'OR',
|
|
)
|
|
"
|
|
>
|
|
{{ $t('layout.apiKey') }}
|
|
</el-dropdown-item>
|
|
</div>
|
|
<el-dropdown-item
|
|
style="padding: 0"
|
|
@click.stop
|
|
v-if="
|
|
hasPermission(
|
|
new ComplexPermission(
|
|
[RoleConst.ADMIN, RoleConst.WORKSPACE_MANAGE, RoleConst.USER],
|
|
[PermissionConst.SWITCH_LANGUAGE],
|
|
[],
|
|
'OR',
|
|
),
|
|
'OR',
|
|
)
|
|
"
|
|
>
|
|
<el-dropdown class="w-full" trigger="hover" placement="left-start">
|
|
<div class="flex-between w-full" style="line-height: 22px; padding: 12px 11px">
|
|
<span> {{ $t('layout.language') }}</span>
|
|
<el-icon>
|
|
<ArrowRight />
|
|
</el-icon>
|
|
</div>
|
|
|
|
<template #dropdown>
|
|
<el-dropdown-menu style="width: 180px">
|
|
<el-dropdown-item
|
|
v-for="(lang, index) in langList"
|
|
:key="index"
|
|
:value="lang.value"
|
|
@click="changeLang(lang.value)"
|
|
class="flex-between"
|
|
>
|
|
<span :class="lang.value === user.userInfo?.language ? 'primary' : ''">{{
|
|
lang.label
|
|
}}</span>
|
|
|
|
<el-icon
|
|
:class="lang.value === user.userInfo?.language ? 'primary' : ''"
|
|
v-if="lang.value === user.userInfo?.language"
|
|
>
|
|
<Check />
|
|
</el-icon>
|
|
</el-dropdown-item>
|
|
</el-dropdown-menu>
|
|
</template>
|
|
</el-dropdown>
|
|
</el-dropdown-item>
|
|
<el-dropdown-item
|
|
@click="openAbout"
|
|
v-if="hasPermission([RoleConst.ADMIN, PermissionConst.ABOUT_READ], 'OR')"
|
|
>
|
|
{{ $t('layout.about.title') }}
|
|
</el-dropdown-item>
|
|
|
|
<el-dropdown-item class="border-t" @click="logout">
|
|
{{ $t('layout.logout') }}
|
|
</el-dropdown-item>
|
|
</el-dropdown-menu>
|
|
</template>
|
|
</el-dropdown>
|
|
<APIKeyDialog :user-id="user.userInfo?.id" ref="APIKeyDialogRef" />
|
|
<ResetPassword ref="resetPasswordRef"></ResetPassword>
|
|
<AboutDialog ref="AboutDialogRef"></AboutDialog>
|
|
|
|
<!-- <UserPwdDialog ref="UserPwdDialogRef" /> -->
|
|
</template>
|
|
<script setup lang="ts">
|
|
import { ref, onMounted } from 'vue'
|
|
import useStore from '@/stores'
|
|
import { useRouter } from 'vue-router'
|
|
import ResetPassword from './ResetPassword.vue'
|
|
import AboutDialog from './AboutDialog.vue'
|
|
// import UserPwdDialog from '@/views/user-manage/component/UserPwdDialog.vue'
|
|
import APIKeyDialog from './APIKeyDialog.vue'
|
|
import { ComplexPermission } from '@/utils/permission/type'
|
|
import { langList } from '@/locales/index'
|
|
import { hasPermission } from '@/utils/permission'
|
|
import { PermissionConst, RoleConst, EditionConst } from '@/utils/permission/data'
|
|
|
|
const { user, login } = useStore()
|
|
const router = useRouter()
|
|
|
|
const AboutDialogRef = ref()
|
|
const APIKeyDialogRef = ref()
|
|
const resetPasswordRef = ref<InstanceType<typeof ResetPassword>>()
|
|
|
|
// const { changeLocale } = useLocale()
|
|
const changeLang = (lang: string) => {
|
|
user.postUserLanguage(lang)
|
|
// changeLocale(lang)
|
|
}
|
|
const openAbout = () => {
|
|
AboutDialogRef.value?.open()
|
|
}
|
|
|
|
function openAPIKeyDialog() {
|
|
APIKeyDialogRef.value.open()
|
|
}
|
|
|
|
const openResetPassword = () => {
|
|
resetPasswordRef.value?.open()
|
|
}
|
|
|
|
const logout = () => {
|
|
login.logout().then(() => {
|
|
router.push({ name: 'login' })
|
|
})
|
|
}
|
|
|
|
onMounted(() => {
|
|
if (user.userInfo?.is_edit_password) {
|
|
// UserPwdDialogRef.value.open(user.userInfo)
|
|
}
|
|
})
|
|
</script>
|
|
<style lang="scss" scoped>
|
|
.avatar-dropdown {
|
|
min-width: 210px;
|
|
|
|
.userInfo {
|
|
padding: 12px 11px;
|
|
}
|
|
|
|
:deep(.el-dropdown-menu__item) {
|
|
padding: 12px 11px;
|
|
|
|
&:hover {
|
|
background: var(--app-text-color-light-1);
|
|
}
|
|
}
|
|
}
|
|
</style>
|