user.js 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177
  1. import Vue from 'vue'
  2. import { login, getInfo, logout, smsLogin } from '@/api/upms/login'
  3. import { dictData } from '@/api/upms/dict'
  4. import { configData } from '@/api/upms/config'
  5. import { ACCESS_TOKEN } from '@/store/mutation-types'
  6. import DictCache from '@/utils/dict'
  7. import { welcome } from '@/utils/util'
  8. import { checkBxr } from '@/api/upms/user'
  9. const user = {
  10. state: {
  11. token: '',
  12. name: '',
  13. welcome: '',
  14. avatar: '',
  15. rmbRate: 1,
  16. permissions: [],
  17. roles: [],
  18. info: {
  19. username: null,
  20. realName: null,
  21. isAuthentication: false
  22. }
  23. },
  24. mutations: {
  25. SET_TOKEN: (state, token) => {
  26. state.token = token
  27. },
  28. SET_NAME: (state, { name, welcome }) => {
  29. state.name = name
  30. state.welcome = welcome
  31. },
  32. SET_AVATAR: (state, avatar) => {
  33. state.avatar = avatar
  34. },
  35. SET_USER_ROLES: (state, roles) => {
  36. state.roles = roles
  37. },
  38. SET_USER_PERMISSIONS: (state, permissions) => {
  39. state.permissions = permissions
  40. },
  41. SET_INFO: (state, info) => {
  42. state.info = info
  43. },
  44. SET_RMB_RATE: (state, rmbRate) => {
  45. state.rmbRate = rmbRate
  46. }
  47. },
  48. actions: {
  49. // 登录
  50. Login ({ commit }, userInfo) {
  51. return new Promise((resolve, reject) => {
  52. const loginType = userInfo.loginType
  53. if (loginType === 1) {
  54. login(userInfo).then(response => {
  55. const result = response.data
  56. if (result) {
  57. const accessToken = result.access_token
  58. Vue.ls.set(ACCESS_TOKEN, accessToken, 7 * 24 * 60 * 60 * 1000)
  59. commit('SET_TOKEN', accessToken)
  60. }
  61. dictData().then(response => {
  62. const data = response.data
  63. Vue.ls.set(DictCache.BASE_DATA_CACHE, data)
  64. })
  65. checkBxr().then(res => {
  66. Vue.ls.set('bxrFlag', res.data)
  67. })
  68. resolve()
  69. }).catch(error => {
  70. reject(error)
  71. })
  72. } else if (loginType === 2) {
  73. smsLogin(userInfo).then(response => {
  74. const result = response.data
  75. if (result) {
  76. const accessToken = result.access_token
  77. Vue.ls.set(ACCESS_TOKEN, accessToken, 7 * 24 * 60 * 60 * 1000)
  78. commit('SET_TOKEN', accessToken)
  79. }
  80. dictData().then(response => {
  81. const data = response.data
  82. Vue.ls.set(DictCache.BASE_DATA_CACHE, data)
  83. })
  84. resolve()
  85. }).catch(error => {
  86. reject(error)
  87. })
  88. }
  89. })
  90. },
  91. setAvatar ({ commit }, avatar) {
  92. commit('SET_AVATAR', avatar)
  93. },
  94. setUserInfo ({ commit }, userInfo) {
  95. console.log(userInfo)
  96. commit('SET_INFO', userInfo)
  97. },
  98. // 获取用户信息
  99. GetInfo ({ commit }) {
  100. return new Promise((resolve, reject) => {
  101. getInfo().then(response => {
  102. const result = response.data
  103. console.log(response)
  104. // if (result && result.permissions && result.permissions.length > 0) {
  105. // result.permissions.map(per => {
  106. // if (per.actionEntitySet != null && per.actionEntitySet.length > 0) {
  107. // const action = per.actionEntitySet.map(action => { return action.action })
  108. // per.actionList = action
  109. // }
  110. // })
  111. if (result && result.permissions && result.permissions.length > 0) {
  112. const permissionList = []
  113. result.permissions.forEach(function (v) {
  114. permissionList.push(...v.split(','))
  115. })
  116. commit('SET_USER_PERMISSIONS', permissionList)
  117. } else {
  118. commit('SET_USER_PERMISSIONS', ['test:permissions'])
  119. }
  120. if (result && result.roles && result.roles.length > 0) {
  121. const roleList = []
  122. result.roles.forEach(function (v) {
  123. roleList.push(...v.split(','))
  124. })
  125. commit('SET_USER_ROLES', roleList)
  126. console.log(roleList)
  127. } else {
  128. commit('SET_USER_ROLES', ['test:role'])
  129. }
  130. commit('SET_INFO', result.userInfo)
  131. // } else {
  132. // reject(new Error('getInfo: roles must be a non-null array !'))
  133. // }
  134. commit('SET_NAME', { name: result.userInfo.realName, welcome: welcome() })
  135. commit('SET_AVATAR', result.userInfo.avatar)
  136. configData().then(res => {
  137. const configMap = res.data['config:open:value']
  138. const rmbRate = parseFloat(configMap[DictCache.TYPE.MONEY_TYPE + DictCache.VALUE.MONEY_TYPE.RMB + '_' + DictCache.VALUE.MONEY_TYPE.MY])
  139. commit('SET_RMB_RATE', rmbRate)
  140. })
  141. resolve(response)
  142. }).catch(error => {
  143. reject(error)
  144. })
  145. })
  146. },
  147. // 登出
  148. Logout ({ commit, state }) {
  149. return new Promise((resolve) => {
  150. commit('SET_TOKEN', '')
  151. commit('SET_USER_ROLES', [])
  152. Vue.ls.remove(ACCESS_TOKEN)
  153. resolve()
  154. // logout(state.token).then(() => {
  155. // resolve()
  156. // }).catch(() => {
  157. // resolve()
  158. // }).finally(() => {
  159. // commit('SET_TOKEN', '')
  160. // commit('SET_USER_ROLES', [])
  161. // Vue.ls.remove(ACCESS_TOKEN)
  162. // })
  163. })
  164. }
  165. }
  166. }
  167. export default user