zhitong.yu
8 天以前 378d781e6f35f89652aa36e079a8b7fc44cea77e
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
<template>
  <el-dropdown trigger="click">
    <span class="username" v-html="username"></span>
  </el-dropdown>
  <el-dropdown trigger="click">
    <div class="avatar">
      <el-avatar :src="avatar" @error="errorHandler">
        <img :src="localImage" />
      </el-avatar>
    </div>
    <template #dropdown>
      <el-dropdown-menu>
        <el-dropdown-item divided @click="logout">
          <el-icon><SwitchButton /></el-icon>{{ $t("header.logout") }}
        </el-dropdown-item>
      </el-dropdown-menu>
    </template>
  </el-dropdown>
  <!-- infoDialog -->
  <InfoDialog ref="infoRef"></InfoDialog>
  <!-- passwordDialog -->
  <PasswordDialog ref="passwordRef"></PasswordDialog>
</template>
 
<script setup lang="ts">
import { ref } from "vue";
import { LOGIN_URL } from "@/config";
import { useRouter } from "vue-router";
import { logoutApi } from "@/api/modules/login";
import { useUserStore } from "@/stores/modules/user";
import { ElMessageBox, ElMessage } from "element-plus";
import InfoDialog from "./InfoDialog.vue";
import PasswordDialog from "./PasswordDialog.vue";
import { useI18n } from "vue-i18n";
import { SwitchButton } from "@element-plus/icons-vue";
import { getUserName } from "@/api/modules/hxzk/user/user";
import localImage from "../../../../assets/images/UserPhoto.png";
const { t } = useI18n();
const router = useRouter();
const userStore = useUserStore();
const avatar = ref("");
const username = ref("");
getUserName().then(TbUser => {
  avatar.value = TbUser.avatar;
  username.value = TbUser.username;
});
const errorHandler = () => true;
// 处理图片加载错误
 
// 退出登录
const logout = () => {
  ElMessageBox.confirm(t("HandleData.confirmMessage", { message: t("header.logout") }), t("HandleData.confirmTitle"), {
    confirmButtonText: t("HandleData.confirmButton"),
    cancelButtonText: t("HandleData.cancelButton"),
    type: "warning"
  }).then(async () => {
    // 1.执行退出登录接口
    await logoutApi();
 
    // 2.清除 Token
    userStore.setToken("");
 
    // 3.重定向到登陆页
    router.replace(LOGIN_URL);
    ElMessage.success(t("HandleData.successMessage", { action: t("header.logout") }));
  });
};
 
// 打开修改密码和个人信息弹窗
const infoRef = ref<InstanceType<typeof InfoDialog> | null>(null);
const passwordRef = ref<InstanceType<typeof PasswordDialog> | null>(null);
</script>
 
<style scoped lang="scss">
.avatar {
  width: 40px;
  height: 40px;
  overflow: hidden;
  cursor: pointer;
  border-radius: 50%;
  img {
    width: 100%;
    height: 100%;
  }
}
.username {
  margin: 0 20px;
  font-size: 15px;
  color: var(--el-header-text-color);
}
</style>