UserInfoBar.vue 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159
  1. <template>
  2. <el-dropdown size="large">
  3. <div class="header-bar user-info-bar">
  4. <img :alt="userInfo.account" :src="userInfo.avatar || avatarPng" class="user-avatar">
  5. <span class="user-name" :style="{ color: isYunNanProject ? 'black' : 'white' }">{{ userInfo.real_name }}</span>
  6. <HcIcon name="arrow-down-s" ui="arrow-icon" :style="{ color: isYunNanProject ? 'black' : 'white' }" />
  7. </div>
  8. <template #dropdown>
  9. <el-dropdown-menu>
  10. <el-dropdown-item v-for="item in options" :key="item.key">
  11. <div class="hc-dropdown-item" @click="handleSelect(item.key)">
  12. <HcIcon :name="item.icon" class="icon" />
  13. <span class="label">{{ item.label }}</span>
  14. </div>
  15. </el-dropdown-item>
  16. </el-dropdown-menu>
  17. </template>
  18. </el-dropdown>
  19. </template>
  20. <script setup>
  21. import { onMounted, ref, watch } from 'vue'
  22. import { useRouter } from 'vue-router'
  23. import { useAppStore } from '~src/store'
  24. import website from '~src/config/index'
  25. import avatarPng from '~src/assets/images/avatar.png'
  26. import { LogOut, RefreshToken } from '~sto/user'
  27. import { getStoreValue } from '~src/utils/storage'
  28. import { calcDate, isNullES } from 'js-fast-way'
  29. //事件
  30. const emit = defineEmits(['load'])
  31. //变量
  32. const router = useRouter()
  33. const store = useAppStore()
  34. const userInfo = ref(store.getUserInfo)
  35. const refreshLock = ref(false)
  36. const projectId = ref(store.getProjectId)
  37. // 判断是否为云南项目
  38. const isYunNanProject = ref(projectId.value === '1904814720589430785')
  39. // 添加watch来更新isYunNanProject
  40. watch(() => projectId.value, (newProjectId) => {
  41. isYunNanProject.value = newProjectId === '1904814720589430785'
  42. })
  43. //监听
  44. watch(() => store.getUserInfo, (info) => {
  45. userInfo.value = info
  46. emit('load', info)
  47. })
  48. onMounted(() => {
  49. getRefreshToken()
  50. emit('load', userInfo.value)
  51. })
  52. //刷新token
  53. const getRefreshToken = () => {
  54. setInterval(() => {
  55. const token = getStoreValue('token', true) || {}
  56. const date = calcDate(token.datetime, new Date().getTime())
  57. if (isNullES(date)) return
  58. if (date.seconds >= website.tokenTime && !refreshLock.value) {
  59. refreshLock.value = true
  60. console.log('刷新token')
  61. RefreshToken().then(() => {
  62. refreshLock.value = false
  63. }).catch(() => {
  64. refreshLock.value = false
  65. router.push({ name: 'login-main' })
  66. })
  67. }
  68. }, 10000)
  69. }
  70. const options = [
  71. {
  72. key: 'my',
  73. label: '个人中心',
  74. icon: 'user-3',
  75. },
  76. {
  77. key: 'logout',
  78. label: '退出登录',
  79. icon: 'login-box',
  80. },
  81. ]
  82. const handleSelect = (key) => {
  83. if (key === 'my') {
  84. router.push({ name: 'user-index' })
  85. } else if (key === 'logout') {
  86. LogOut().then()
  87. window.$message?.info('退出成功')
  88. router.push({ name: 'login-main' })
  89. }
  90. }
  91. </script>
  92. <style lang="scss" scoped>
  93. .user-info-bar {
  94. position: relative;
  95. display: flex;
  96. align-items: center;
  97. height: 100%;
  98. cursor: pointer;
  99. padding-left: 16px;
  100. margin-left: 4px;
  101. outline: none;
  102. .user-avatar {
  103. width: 26px;
  104. height: 26px;
  105. border-radius: 50%;
  106. background: white;
  107. object-fit: cover;
  108. }
  109. .user-name {
  110. font-size: 16px;
  111. margin-left: 10px;
  112. color: white;
  113. }
  114. .arrow-icon {
  115. margin-left: 5px;
  116. font-size: 20px;
  117. color: white;
  118. }
  119. &::before {
  120. position: absolute;
  121. content: '';
  122. left: 0;
  123. width: 0;
  124. height: 20px;
  125. border-left: 1px solid #7291ff;
  126. }
  127. }
  128. .hc-layout-box .hc-container-view.home .hc-header-view .hc-header-content .user-info-bar {
  129. color: inherit;
  130. .user-name {
  131. color: white;
  132. }
  133. .arrow-icon {
  134. color: white;
  135. }
  136. &::before {
  137. border-left: 1px solid white;
  138. }
  139. }
  140. .hc-dropdown-item {
  141. display: flex;
  142. align-items: center;
  143. .icon {
  144. font-size: 14px;
  145. margin-right: 8px;
  146. }
  147. }
  148. </style>