user.js 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172
  1. import Vue from 'vue'
  2. import { login, getLoginUser, logout } from '@/api/modular/system/loginManage'
  3. import { sysDictTypeTree } from '@/api/modular/system/dictManage'
  4. import { sysMenuChange } from '@/api/modular/system/menuManage'
  5. import { ACCESS_TOKEN, ALL_APPS_MENU, DICT_TYPE_TREE_DATA } from '@/store/mutation-types'
  6. import { welcome } from '@/utils/util'
  7. import store from '../index'
  8. import router from '../../router'
  9. const user = {
  10. state: {
  11. token: '',
  12. name: '',
  13. welcome: '',
  14. avatar: '',
  15. buttons: [], // 按钮权限
  16. admintype: '', // 是否是超管
  17. roles: [],
  18. info: {}
  19. },
  20. mutations: {
  21. SET_TOKEN: (state, token) => {
  22. state.token = token
  23. },
  24. SET_NAME: (state, { name, welcome }) => {
  25. state.name = name
  26. state.welcome = welcome
  27. },
  28. SET_AVATAR: (state, avatar) => {
  29. state.avatar = avatar
  30. },
  31. SET_ROLES: (state, roles) => {
  32. state.roles = roles
  33. },
  34. SET_INFO: (state, info) => {
  35. state.info = info
  36. },
  37. SET_BUTTONS: (state, buttons) => {
  38. state.buttons = buttons
  39. },
  40. SET_ADMINTYPE: (state, admintype) => {
  41. state.admintype = admintype
  42. }
  43. },
  44. actions: {
  45. // 登录
  46. Login ({ commit }, userInfo) {
  47. return new Promise((resolve, reject) => {
  48. login(userInfo).then(response => {
  49. if (!response.success) {
  50. reject(response.message)
  51. return
  52. }
  53. const result = response.data
  54. Vue.ls.set(ACCESS_TOKEN, result, 7 * 24 * 60 * 60 * 1000)
  55. commit('SET_TOKEN', result)
  56. resolve()
  57. // eslint-disable-next-line handle-callback-err
  58. }).catch(error => {
  59. // eslint-disable-next-line prefer-promise-reject-errors
  60. reject('后端未启动或代理错误')
  61. })
  62. })
  63. },
  64. // 获取用户信息
  65. GetInfo ({ commit }) {
  66. return new Promise((resolve, reject) => {
  67. getLoginUser().then(response => {
  68. if (response.success) {
  69. const data = response.data
  70. commit('SET_ADMINTYPE', data.adminType)
  71. commit('SET_ROLES', 1)
  72. commit('SET_BUTTONS', data.permissions)
  73. commit('SET_INFO', data)
  74. commit('SET_NAME', { name: data.name, welcome: welcome() })
  75. if (data.avatar != null) {
  76. commit('SET_AVATAR', process.env.VUE_APP_API_BASE_URL + '/sysFileInfo/preview?id=' + data.avatar)
  77. }
  78. resolve(data)
  79. } else {
  80. // eslint-disable-next-line no-undef
  81. reject(new Error(data.message))
  82. }
  83. }).catch(error => {
  84. reject(error)
  85. })
  86. })
  87. },
  88. // 登出
  89. Logout ({ commit, state }) {
  90. return new Promise((resolve) => {
  91. logout(state.token).then(() => {
  92. resolve()
  93. }).catch(() => {
  94. resolve()
  95. }).finally(() => {
  96. commit('SET_TOKEN', '')
  97. commit('SET_ROLES', [])
  98. commit('SET_BUTTONS', [])
  99. commit('SET_ADMINTYPE', '')
  100. Vue.ls.remove(ACCESS_TOKEN)
  101. Vue.ls.remove(ALL_APPS_MENU)
  102. Vue.ls.remove(DICT_TYPE_TREE_DATA)
  103. })
  104. })
  105. },
  106. // 加载所有字典数据
  107. dictTypeData () {
  108. return new Promise((resolve, reject) => {
  109. sysDictTypeTree().then((data) => {
  110. if (data.success) {
  111. const result = data.data
  112. Vue.ls.set(DICT_TYPE_TREE_DATA, result)
  113. resolve()
  114. } else {
  115. // eslint-disable-next-line no-undef
  116. reject(new Error(data.message))
  117. }
  118. }).catch(error => {
  119. reject(error)
  120. })
  121. })
  122. },
  123. // 切换应用菜单
  124. MenuChange ({ commit }, application) {
  125. return new Promise((resolve) => {
  126. sysMenuChange({ application: application.code }).then((res) => {
  127. const apps = { 'code': '', 'name': '', 'active': '', 'menu': '' }
  128. apps.active = true
  129. apps.menu = res.data
  130. // eslint-disable-next-line camelcase
  131. const all_app_menu = Vue.ls.get(ALL_APPS_MENU)
  132. // eslint-disable-next-line camelcase
  133. const new_false_all_app_menu = []
  134. // 先去除所有默认的,以为此时切换的即将成为前端缓存默认的应用
  135. all_app_menu.forEach(item => {
  136. if (item.active) {
  137. item.active = false
  138. }
  139. new_false_all_app_menu.push(item)
  140. })
  141. // 此时缓存中全部都是不默认的应用
  142. Vue.ls.set(ALL_APPS_MENU, new_false_all_app_menu)
  143. apps.name = application.name
  144. apps.code = application.code
  145. const applocationR = []
  146. applocationR.push(apps)
  147. Vue.ls.set(ALL_APPS_MENU, applocationR)
  148. resolve(res)
  149. const antDesignmenus = res.data
  150. store.dispatch('GenerateRoutes', { antDesignmenus }).then(() => {
  151. router.addRoutes(store.getters.addRouters)
  152. })
  153. // 切换应用刷新整体界面,暂且取消
  154. // window.location.reload()
  155. }).catch(() => {
  156. resolve()
  157. })
  158. })
  159. }
  160. }
  161. }
  162. export default user