UserInfoBar.vue 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118
  1. <template>
  2. <el-dropdown size="large">
  3. <div class="hc-user-info-bar">
  4. <img :alt="userInfo.account" :src="userInfo.avatar || avatarPng" class="user-avatar">
  5. <div class="user-name">{{ userInfo.real_name || '还未登录' }}</div>
  6. <hc-icon name="more-2" fill ui="arrow-icon" />
  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. <hc-icon :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 '~src/store/user'
  27. import { calcDate, isNullES } from 'js-fast-way'
  28. import { getStore } from 'hc-vue3-ui'
  29. //事件
  30. const emit = defineEmits(['load'])
  31. //变量
  32. const router = useRouter()
  33. const store = useAppStore()
  34. const userInfo = ref(store.userInfo)
  35. const refreshLock = ref(false)
  36. //监听
  37. watch(() => store.userInfo, (info) => {
  38. userInfo.value = info
  39. emit('load', info)
  40. })
  41. onMounted(() => {
  42. getRefreshToken()
  43. emit('load', userInfo.value)
  44. })
  45. //刷新token
  46. const getRefreshToken = () => {
  47. /*setInterval(() => {
  48. const token = getStore('token', true) || {}
  49. const date = calcDate(token.datetime, new Date().getTime())
  50. if (isNullES(date)) return
  51. if (date.seconds >= website.tokenTime && !refreshLock.value) {
  52. refreshLock.value = true
  53. console.log('刷新token')
  54. RefreshToken().then(() => {
  55. refreshLock.value = false
  56. }).catch(() => {
  57. refreshLock.value = false
  58. router.push({ name: 'login' })
  59. })
  60. }
  61. }, 10000)*/
  62. }
  63. const options = [{ key: 'logout', label: '退出登录', icon: 'login-box' }]
  64. const handleSelect = (key) => {
  65. if (key === 'logout') {
  66. //LogOut().then()
  67. window.$message?.info('退出成功')
  68. router.push({ name: 'login' })
  69. }
  70. }
  71. </script>
  72. <style lang="scss" scoped>
  73. .hc-user-info-bar {
  74. position: relative;
  75. display: flex;
  76. align-items: center;
  77. height: 50px;
  78. cursor: pointer;
  79. outline: none;
  80. width: 100%;
  81. padding: 0 10px;
  82. .user-avatar {
  83. width: 26px;
  84. height: 26px;
  85. border-radius: 5px;
  86. background: white;
  87. object-fit: cover;
  88. }
  89. .user-name {
  90. flex: 1;
  91. font-size: 16px;
  92. margin-left: 10px;
  93. color: white;
  94. }
  95. .arrow-icon {
  96. margin-left: 5px;
  97. font-size: 20px;
  98. color: white;
  99. }
  100. }
  101. .hc-dropdown-item {
  102. display: flex;
  103. align-items: center;
  104. .icon {
  105. font-size: 14px;
  106. margin-right: 8px;
  107. }
  108. }
  109. </style>