Navbar.vue 4.9 KB
<template>
  <div class="navbar">
    <hamburger
      id="hamburger-container" :is-active="appStore.sidebar.opened" class="hamburger-container"
      @toggleClick="toggleSideBar"
    />
    <breadcrumb v-if="!settingsStore.topNav" id="breadcrumb-container" class="breadcrumb-container" />
    <top-nav v-if="settingsStore.topNav" id="topmenu-container" class="topmenu-container" />
    
    <div class="right-menu">
      <div class="welcome">{{ userStore?.memberInfo?.name ?? '您好' }},欢迎登录中跆协会员管理系统 !</div>
      <!-- <template v-if="appStore.device !== 'mobile'"> -->
      <!-- <header-search id="header-search" class="right-menu-item" /> -->
      <!-- </template> -->
      <div class="avatar-container">
        <el-dropdown class="right-menu-item hover-effect" trigger="click" @command="handleCommand">
          <!-- <div>{{ userStore.name }}</div> -->
          <div class="avatar-wrapper">
            <img :src="fillImgUrl(userStore.avatar)" class="user-avatar">
            <span class="userName">{{ userStore?.memberInfo?.name }}</span>
            <el-icon>
              <caret-bottom />
            </el-icon>
          </div>
          <template #dropdown>
            <el-dropdown-menu>
              <router-link to="" @click="goUser">
                <el-dropdown-item>个人中心</el-dropdown-item>
              </router-link>
              <el-dropdown-item divided command="logout">
                <span>退出登录</span>
              </el-dropdown-item>
            </el-dropdown-menu>
          </template>
        </el-dropdown>
      </div>
    </div>
  </div>
</template>

<script setup>
import { getCurrentInstance } from 'vue'
import { ElMessageBox } from 'element-plus'
import Breadcrumb from '@/components/Breadcrumb'
import TopNav from '@/components/TopNav'
import Hamburger from '@/components/Hamburger'
// import HeaderSearch from '@/components/HeaderSearch'
const { proxy } = getCurrentInstance()
import { useRouter } from 'vue-router'
import useAppStore from '@/store/modules/app'
import useUserStore from '@/store/modules/user'
import useSettingsStore from '@/store/modules/settings'

const router = useRouter()
// const handleCommand = (command) => {'
const appStore = useAppStore()
const userStore = useUserStore()
const settingsStore = useSettingsStore()

// console.log(userStore)

function toggleSideBar() {
  appStore.toggleSideBar()
}

function handleCommand(command) {
  switch (command) {
    case 'setLayout':
      setLayout()
      break
    case 'logout':
      logout()
      break
    default:
      break
  }
}

function logout() {
  ElMessageBox.confirm('确定注销并退出系统吗?', '提示', {
    confirmButtonText: '确定',
    cancelButtonText: '取消',
    type: 'warning'
  }).then(() => {
    userStore.logOut().then(() => {
      location.href = import.meta.env.VITE_APP_CONTEXT_PATH
    })
  }).catch(() => {
  })
}

const emits = defineEmits(['setLayout'])

function setLayout() {
  emits('setLayout')
}

function goUser() {
  if (userStore.isBlack == 1) {
    return proxy.$modal.msgError('您的账号无法操作,请联系上级协会!')
  } else {
    router.push('/user/profile')
  }
}
</script>

<style lang='scss' scoped>
.navbar {
  height: 50px;
  overflow: hidden;
  position: relative;
  background: #fff;
  box-shadow: 0 1px 4px rgba(0, 21, 41, 0.08);
  
  .hamburger-container {
    line-height: 46px;
    height: 100%;
    float: left;
    cursor: pointer;
    transition: background 0.3s;
    -webkit-tap-highlight-color: transparent;
    
    &:hover {
      background: rgba(0, 0, 0, 0.025);
    }
  }
  
  .breadcrumb-container {
    float: left;
  }
  
  .topmenu-container {
    position: absolute;
    left: 50px;
  }
  
  .errLog-container {
    display: inline-block;
    vertical-align: top;
  }
  
  .right-menu {
    float: right;
    height: 100%;
    line-height: 50px;
    display: flex;
    
    &:focus {
      outline: none;
    }
    
    .right-menu-item {
      display: inline-block;
      padding: 0 8px;
      height: 100%;
      font-size: 18px;
      color: #5a5e66;
      vertical-align: text-bottom;
      
      &.hover-effect {
        cursor: pointer;
        transition: background 0.3s;
        
        &:hover {
          background: rgba(0, 0, 0, 0.025);
        }
      }
    }
    
    .avatar-container {
      margin-right: 40px;
      
      .avatar-wrapper {
        margin-top: 10px;
        position: relative;
        display: flex;
        
        .user-avatar {
          cursor: pointer;
          width: 30px;
          height: 30px;
          border-radius: 10px;
        }
        
        i {
          cursor: pointer;
          position: absolute;
          right: -20px;
          top: 10px;
          font-size: 12px;
        }
      }
    }
  }
}

.userName {
  padding-left: 10px;
  padding-right: 10px;
  line-height: 30px;
}

.welcome {
  font-size: 16px;
  color: #000;
  font-weight: 400;
  margin-right: 40px;
}
</style>