header-tools.vue 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191
  1. <!-- 顶栏右侧区域 -->
  2. <template>
  3. <div class="ele-admin-header-tool">
  4. <!-- 全屏切换 -->
  5. <div
  6. class="ele-admin-header-tool-item hidden-xs-only"
  7. @click="toggleFullscreen"
  8. >
  9. <i v-if="fullscreen" class="el-icon-_screen-restore"></i>
  10. <i v-else class="el-icon-_screen-full"></i>
  11. </div>
  12. <!-- 语言切换 -->
  13. <div class="ele-admin-header-tool-item">
  14. <i18n-icon />
  15. </div>
  16. <!-- 消息通知 -->
  17. <div class="ele-admin-header-tool-item">
  18. <header-notice />
  19. </div>
  20. <div class="ele-admin-header-tool-item">
  21. <el-select v-model="groupId" @change="groupIdChange">
  22. <el-option
  23. v-for="item in loginChangeGroupVOList"
  24. :key="item.groupId"
  25. :label="item.groupName"
  26. :value="item.groupId"
  27. >
  28. </el-option>
  29. </el-select>
  30. </div>
  31. <div class="ele-admin-header-tool-item">
  32. <el-select v-model="roleId" @change="roleChange">
  33. <el-option
  34. v-for="item in loginChangeRoleVOList"
  35. :key="item.roleId"
  36. :label="item.roleName"
  37. :value="item.roleId"
  38. >
  39. </el-option>
  40. </el-select>
  41. </div>
  42. <!-- 用户信息 -->
  43. <div class="ele-admin-header-tool-item">
  44. <el-dropdown @command="onUserDropClick">
  45. <div class="ele-admin-header-avatar">
  46. <el-avatar
  47. :src="
  48. loginUser && loginUser.avatarAddress
  49. ? loginUser.avatarAddress
  50. : xyy
  51. "
  52. />
  53. <span class="hidden-xs-only">{{
  54. loginUser && loginUser.nickname ? loginUser.nickname : ''
  55. }}</span>
  56. <i class="el-icon-arrow-down"></i>
  57. </div>
  58. <template v-slot:dropdown>
  59. <el-dropdown-menu>
  60. <!-- <router-link to="/user/profile">-->
  61. <!-- <el-dropdown-item icon="el-icon-user">个人中心</el-dropdown-item>-->
  62. <!-- </router-link>-->
  63. <el-dropdown-item command="profile" icon="el-icon-user">
  64. {{ $t('layout.header.profile') }}
  65. </el-dropdown-item>
  66. <el-dropdown-item command="password" icon="el-icon-key">
  67. {{ $t('layout.header.password') }}
  68. </el-dropdown-item>
  69. <el-dropdown-item
  70. command="logout"
  71. icon="el-icon-switch-button"
  72. divided
  73. >
  74. {{ $t('layout.header.logout') }}
  75. </el-dropdown-item>
  76. </el-dropdown-menu>
  77. </template>
  78. </el-dropdown>
  79. </div>
  80. <!-- 主题设置 -->
  81. <div class="ele-admin-header-tool-item" @click="openSetting">
  82. <i class="el-icon-_more"></i>
  83. </div>
  84. <!-- 修改密码弹窗 -->
  85. <password-modal :visible.sync="passwordVisible" />
  86. <!-- 主题设置抽屉 -->
  87. <setting-drawer :visible.sync="settingVisible" />
  88. </div>
  89. </template>
  90. <script>
  91. import HeaderNotice from './header-notice.vue';
  92. import PasswordModal from './password-modal.vue';
  93. import SettingDrawer from './setting-drawer.vue';
  94. import I18nIcon from './i18n-icon.vue';
  95. import { logout } from '@/utils/page-tab-util';
  96. import { userLogout } from '@/api/system/user';
  97. import xyy from '@/assets/xyy.jpg';
  98. import router from '@/router/index';
  99. export default {
  100. components: { HeaderNotice, PasswordModal, SettingDrawer, I18nIcon },
  101. props: {
  102. // 是否是全屏
  103. fullscreen: Boolean
  104. },
  105. data() {
  106. return {
  107. xyy,
  108. // 是否显示修改密码弹窗
  109. passwordVisible: false,
  110. // 是否显示主题设置抽屉
  111. settingVisible: false,
  112. groupId: '',
  113. roleId: '',
  114. currentUser:{
  115. currentGroupId:'',
  116. currentRoleId:''
  117. }
  118. };
  119. },
  120. created() {
  121. this.currentUser = JSON.parse(sessionStorage['currentUser']);
  122. this.groupId = this.currentUser.currentGroupId;
  123. this.roleId = this.currentUser.currentRoleId;
  124. },
  125. computed: {
  126. // 当前用户信息
  127. loginUser() {
  128. return this.$store.state.user.info;
  129. },
  130. // 部门下拉
  131. loginChangeGroupVOList() {
  132. return this.$store.state.user?.info?.loginChangeGroupVOList;
  133. },
  134. // 角色下拉
  135. loginChangeRoleVOList() {
  136. return this.$store.state.user?.info?.loginChangeGroupVOList.find(
  137. (item) => item.groupId == this.groupId
  138. )?.loginChangeRoleVOList;
  139. }
  140. },
  141. methods: {
  142. groupIdChange(val) {
  143. this.roleChange(this.loginChangeRoleVOList[0].roleId);
  144. },
  145. roleChange(val) {
  146. this.roleId = val;
  147. this.currentUser.currentGroupId = this.groupId;
  148. this.currentUser.currentRoleId = val;
  149. sessionStorage['currentUser']=JSON.stringify(this.currentUser)
  150. this.$store
  151. .dispatch('user/fetchUserInfo')
  152. .then(({ menus, homePath, authoritiesRouter }) => {
  153. router.roleChange({ menus, homePath, authoritiesRouter });
  154. });
  155. },
  156. /* 用户信息下拉点击事件 */
  157. onUserDropClick(command) {
  158. if (command === 'password') {
  159. this.passwordVisible = true;
  160. } else if (command === 'profile') {
  161. if (this.$route.fullPath !== '/user/profile') {
  162. this.$router.push('/user/profile');
  163. }
  164. } else if (command === 'logout') {
  165. // 退出登录
  166. this.$confirm(
  167. this.$t('layout.logout.message'),
  168. this.$t('layout.logout.title'),
  169. { type: 'warning' }
  170. )
  171. .then(() => {
  172. userLogout().then((res) => {
  173. localStorage.removeItem('userId');
  174. logout();
  175. });
  176. })
  177. .catch(() => {});
  178. }
  179. },
  180. /* 全屏切换 */
  181. toggleFullscreen() {
  182. this.$emit('fullscreen');
  183. },
  184. /* 打开设置抽屉 */
  185. openSetting() {
  186. this.settingVisible = true;
  187. }
  188. }
  189. };
  190. </script>