user.js 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165
  1. // import { login, logout, getInfo } from '@/api/user'
  2. import { login, getInfo } from '@/api/user'
  3. import { getOrganizeInfo } from '@/api/other'
  4. import { getToken, setToken, removeToken } from '@/utils/auth'
  5. import router, { resetRouter } from '@/router'
  6. // import store from '@/store'
  7. const state = {
  8. token: getToken(),
  9. isSimplePwd: false,
  10. name: '',
  11. avatar: '',
  12. systemName: '',
  13. systemImage: '',
  14. roles: []
  15. }
  16. const mutations = {
  17. SET_TOKEN: (state, token) => {
  18. state.token = token
  19. },
  20. SET_IS_SIMPLE_PWD: (state, isSimplePwd) => {
  21. state.isSimplePwd = isSimplePwd
  22. },
  23. SET_SYSTEM_NAME: (state, systemName) => {
  24. state.systemName = systemName
  25. },
  26. SET_SYSTEM_IMAGE: (state, systemImage) => {
  27. state.systemImage = systemImage
  28. },
  29. SET_NAME: (state, name) => {
  30. state.name = name
  31. },
  32. SET_AVATAR: (state, avatar) => {
  33. state.avatar = avatar
  34. },
  35. SET_ROLES: (state, roles) => {
  36. state.roles = roles
  37. }
  38. }
  39. const actions = {
  40. getSysInfo: function({ commit, state }, organizeID) {
  41. return new Promise((resolve, reject) => {
  42. getOrganizeInfo({ id: organizeID }).then(response => {
  43. const { data } = response
  44. if (data) {
  45. const { systemName, systemImage } = data
  46. commit('SET_SYSTEM_NAME', systemName)
  47. commit('SET_SYSTEM_IMAGE', systemImage)
  48. }
  49. resolve(data)
  50. }).catch(error => {
  51. reject(error)
  52. })
  53. })
  54. },
  55. // user login
  56. login: function({ commit }, userInfo) {
  57. const { account, password, organizeID, simplePwd } = userInfo
  58. return new Promise((resolve, reject) => {
  59. if (password.trim() === simplePwd) {
  60. commit('SET_IS_SIMPLE_PWD', true)
  61. }
  62. login({ account: account.trim(), password: password, organizeID: organizeID }).then(response => {
  63. const { data } = response
  64. commit('SET_TOKEN', data)
  65. setToken(data)
  66. resolve()
  67. }).catch(error => {
  68. reject(error)
  69. })
  70. })
  71. },
  72. // get user info
  73. getInfo({ commit, state }) {
  74. return new Promise((resolve, reject) => {
  75. getInfo(state.token).then(response => {
  76. // const { data } = response
  77. const data = response.data
  78. if (!data) {
  79. reject('Verification failed, please Login again.')
  80. }
  81. /* const { roles, account, avatar, introduction } = data
  82. if (!roles || roles.length <= 0) {
  83. reject('getInfo: roles must be a non-null array!')
  84. } */
  85. data.roles = ['admin']
  86. const { roles, accountName, avatar } = data
  87. commit('SET_ROLES', roles)
  88. commit('SET_NAME', accountName)
  89. commit('SET_AVATAR', avatar)
  90. // commit('SET_SYSTEM_NAME', introduction)
  91. resolve(data)
  92. }).catch(error => {
  93. reject(error)
  94. })
  95. })
  96. },
  97. // user logout
  98. logout({ commit, state, dispatch }) {
  99. return new Promise((resolve, reject) => {
  100. // logout(state.token).then(() => {
  101. commit('SET_TOKEN', '')
  102. commit('SET_ROLES', [])
  103. removeToken()
  104. resetRouter()
  105. // reset visited views and cached views
  106. // to fixed https://github.com/PanJiaChen/vue-element-admin/issues/2485
  107. dispatch('tagsView/delAllViews', null, { root: true })
  108. resolve()
  109. // }).catch(error => {
  110. // reject(error)
  111. // })
  112. })
  113. },
  114. // remove token
  115. resetToken({ commit }) {
  116. return new Promise(resolve => {
  117. commit('SET_TOKEN', '')
  118. commit('SET_ROLES', [])
  119. removeToken()
  120. resolve()
  121. })
  122. },
  123. // dynamically modify permissions
  124. changeRoles({ commit, dispatch }, role) {
  125. return new Promise(async resolve => {
  126. const token = role + '-token'
  127. commit('SET_TOKEN', token)
  128. setToken(token)
  129. const { roles } = await dispatch('getInfo')
  130. resetRouter()
  131. // generate accessible routes map based on roles
  132. const accessRoutes = await dispatch('permission/generateRoutes', roles, { root: true })
  133. // dynamically add accessible routes
  134. router.addRoutes(accessRoutes)
  135. // reset visited views and cached views
  136. dispatch('tagsView/delAllViews', null, { root: true })
  137. resolve()
  138. })
  139. }
  140. }
  141. export default {
  142. namespaced: true,
  143. state,
  144. mutations,
  145. actions
  146. }