Navbar.vue 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149
  1. <template>
  2. <div class="navbar">
  3. <hamburger
  4. :toggle-click="toggleSideBar"
  5. :is-active="sidebar.opened"
  6. class="hamburger-container"
  7. />
  8. <breadcrumb class="breadcrumb-container" />
  9. <div class="right-menu">
  10. <template v-if="device!=='mobile'">
  11. <el-tooltip :content="$t('navbar.screenfull')" effect="dark" placement="bottom">
  12. <screenfull class="screenfull right-menu-item" />
  13. </el-tooltip>
  14. <el-tooltip :content="$t('navbar.size')" effect="dark" placement="bottom">
  15. <size-select class="international right-menu-item" />
  16. </el-tooltip>
  17. <!-- <lang-select class="international right-menu-item" /> -->
  18. <el-tooltip :content="$t('navbar.theme')" effect="dark" placement="bottom">
  19. <theme-picker class="theme-switch right-menu-item" />
  20. </el-tooltip>
  21. </template>
  22. <el-dropdown class="avatar-container right-menu-item" trigger="click">
  23. <div class="avatar-wrapper">
  24. <img :src="avatar" class="user-avatar" > <!--avatar+'?imageView2/1/w/80/h/80'-->
  25. <i class="el-icon-caret-bottom" />
  26. </div>
  27. <el-dropdown-menu slot="dropdown">
  28. <router-link to="/">
  29. <el-dropdown-item>{{ $t('navbar.dashboard') }}</el-dropdown-item>
  30. </router-link>
  31. <el-dropdown-item divided>
  32. <router-link to="/profile/password">密码修改</router-link>
  33. </el-dropdown-item>
  34. <el-dropdown-item divided>
  35. <span style="display:block;" @click="logout">{{ $t('navbar.logOut') }}</span>
  36. </el-dropdown-item>
  37. </el-dropdown-menu>
  38. </el-dropdown>
  39. </div>
  40. </div>
  41. </template>
  42. <script>
  43. import { mapGetters } from 'vuex'
  44. import Breadcrumb from '@/components/Breadcrumb'
  45. import Hamburger from '@/components/Hamburger'
  46. import Screenfull from '@/components/Screenfull'
  47. import SizeSelect from '@/components/SizeSelect'
  48. import LangSelect from '@/components/LangSelect'
  49. import ThemePicker from '@/components/ThemePicker'
  50. import avatar from '@/assets/avatar.png'
  51. export default {
  52. components: {
  53. Breadcrumb,
  54. Hamburger,
  55. Screenfull,
  56. SizeSelect,
  57. LangSelect,
  58. ThemePicker
  59. },
  60. data() {
  61. return {
  62. avatar: avatar
  63. }
  64. },
  65. computed: {
  66. ...mapGetters(['sidebar', 'name', 'device']) //, 'avatar'
  67. },
  68. methods: {
  69. toggleSideBar() {
  70. this.$store.dispatch('toggleSideBar')
  71. },
  72. logout() {
  73. this.$store.dispatch('LogOut').then(() => {
  74. // window.location.href = 'http://106.14.75.12:9999/'
  75. location.reload() // In order to re-instantiate the vue-router object to avoid bugs
  76. })
  77. }
  78. }
  79. }
  80. </script>
  81. <style rel="stylesheet/scss" lang="scss" scoped>
  82. .navbar {
  83. height: 50px;
  84. line-height: 50px;
  85. border-radius: 0px !important;
  86. .hamburger-container {
  87. line-height: 58px;
  88. height: 50px;
  89. float: left;
  90. padding: 0 10px;
  91. }
  92. .breadcrumb-container {
  93. float: left;
  94. }
  95. .errLog-container {
  96. display: inline-block;
  97. vertical-align: top;
  98. }
  99. .right-menu {
  100. float: right;
  101. height: 100%;
  102. &:focus {
  103. outline: none;
  104. }
  105. .right-menu-item {
  106. display: inline-block;
  107. margin: 0 8px;
  108. }
  109. .screenfull {
  110. height: 20px;
  111. }
  112. .international {
  113. vertical-align: top;
  114. }
  115. .theme-switch {
  116. vertical-align: 15px;
  117. }
  118. .avatar-container {
  119. height: 50px;
  120. margin-right: 30px;
  121. .avatar-wrapper {
  122. cursor: pointer;
  123. margin-top: 5px;
  124. position: relative;
  125. .user-avatar {
  126. width: 40px;
  127. height: 40px;
  128. border-radius: 10px;
  129. }
  130. .el-icon-caret-bottom {
  131. position: absolute;
  132. right: -20px;
  133. top: 25px;
  134. font-size: 12px;
  135. }
  136. }
  137. }
  138. }
  139. }
  140. </style>