yanjinhui
10 天以前 c5de0d98241f8c8349fa38851b77efcfc61e4d26
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
92
93
94
95
96
97
98
99
<script setup lang="ts">
import { ElDropdown, ElDropdownMenu, ElDropdownItem } from 'element-plus'
import { useI18n } from '@/hooks/web/useI18n'
import { useDesign } from '@/hooks/web/useDesign'
import LockDialog from './components/LockDialog.vue'
import { ref, computed } from 'vue'
import LockPage from './components/LockPage.vue'
import { useLockStore } from '@/store/modules/lock'
import { useUserStore } from '@/store/modules/user'
import { useRouter } from 'vue-router'
 
const { push } = useRouter()
 
const userStore = useUserStore()
 
const lockStore = useLockStore()
 
const getIsLock = computed(() => lockStore.getLockInfo?.isLock ?? false)
 
const { getPrefixCls } = useDesign()
 
const prefixCls = getPrefixCls('user-info')
 
const { t } = useI18n()
 
const loginOut = () => {
  userStore.reset()
  // 清除user
}
 
const dialogVisible = ref<boolean>(false)
 
// 锁定屏幕
const lockScreen = () => {
  dialogVisible.value = true
}
 
const toDocument = () => {
  window.open('https://element-plus-admin-doc.cn/')
}
 
const toPage = (path: string) => {
  push(path)
}
const userInfo = JSON.parse(localStorage.getItem('user')).userInfo || '{}'
</script>
 
<template>
  <ElDropdown class="custom-hover" :class="prefixCls" trigger="click">
    <div class="flex items-center">
      <img
        :src="'http://192.168.1.103:9090' + userInfo.img || '@/assets/imgs/avatar.jpg'"
        alt="src"
        class="w-[calc(var(--logo-height)-25px)] rounded-[50%]"
      />
      <span class="<lg:hidden text-14px pl-[5px] text-[var(--top-header-text-color)]">{{
        userStore.getUserInfo?.username
      }}</span>
    </div>
    <template #dropdown>
      <ElDropdownMenu>
        <ElDropdownItem>
          <div @click="toPage('/personal/personal-center')">
            {{ t('router.personalCenter') }}
          </div>
        </ElDropdownItem>
        <ElDropdownItem>
          <div @click="loginOut">{{ t('common.loginOut') }}</div>
        </ElDropdownItem>
      </ElDropdownMenu>
    </template>
  </ElDropdown>
 
  <LockDialog v-if="dialogVisible" v-model="dialogVisible" />
  <teleport to="body">
    <transition name="fade-bottom" mode="out-in">
      <LockPage v-if="getIsLock" />
    </transition>
  </teleport>
</template>
 
<style scoped lang="less">
.fade-bottom-enter-active,
.fade-bottom-leave-active {
  transition:
    opacity 0.25s,
    transform 0.3s;
}
 
.fade-bottom-enter-from {
  opacity: 0;
  transform: translateY(-10%);
}
 
.fade-bottom-leave-to {
  opacity: 0;
  transform: translateY(10%);
}
</style>