user.ts 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112
  1. import config from '@/config'
  2. import storage from '@/utils/storage'
  3. import constant from '@/utils/constant'
  4. import { login, logout, getInfo } from '@/api/login'
  5. import { getToken, setToken, removeToken } from '@/utils/auth'
  6. import { UserState, UserForm } from '@/types/store'
  7. import { Module } from 'vuex'
  8. const baseUrl = config.baseUrl
  9. const user: Module<UserState, UserState> = {
  10. state: {
  11. token: getToken(),
  12. name: storage.get(constant.name),
  13. avatar: storage.get(constant.avatar),
  14. roles: storage.get(constant.roles),
  15. permissions: storage.get(constant.permissions),
  16. userOrWorker: storage.get(constant.userOrWorker)
  17. },
  18. mutations: {
  19. SET_TOKEN: (state, token: string) => {
  20. state.token = token
  21. },
  22. SET_NAME: (state, name: string) => {
  23. state.name = name
  24. storage.set(constant.name, name)
  25. },
  26. SET_AVATAR: (state, avatar: string) => {
  27. state.avatar = avatar
  28. storage.set(constant.avatar, avatar)
  29. },
  30. SET_ROLES: (state, roles: Array<string>) => {
  31. state.roles = roles
  32. storage.set(constant.roles, roles)
  33. },
  34. SET_PERMISSIONS: (state, permissions: Array<string>) => {
  35. state.permissions = permissions
  36. storage.set(constant.permissions, permissions)
  37. },
  38. SET_USERORWORKER: (state, userOrWorker: Array<string>) => {
  39. state.userOrWorker = userOrWorker
  40. storage.set(constant.userOrWorker, userOrWorker)
  41. }
  42. },
  43. actions: {
  44. // 登录
  45. Login({ commit }, userInfo: UserForm) {
  46. const username = userInfo.username
  47. const password = userInfo.password
  48. const code = userInfo.code
  49. const uuid = userInfo.uuid
  50. return new Promise((resolve, reject) => {
  51. login(username, password, code, uuid).then((res: any) => {
  52. setToken(res.token)
  53. commit('SET_TOKEN', res.token)
  54. resolve(res)
  55. }).catch(error => {
  56. reject(error)
  57. })
  58. })
  59. },
  60. // 获取用户信息
  61. GetInfo({ commit, state }) {
  62. return new Promise((resolve, reject) => {
  63. getInfo().then((res: any) => {
  64. const user = res.user
  65. const avatar = (user == null || user.avatar == "" || user.avatar == null) ? "@/static/images/profile.jpg" : baseUrl + user.avatar
  66. const username = (user == null || user.userName == "" || user.userName == null) ? "" : user.userName
  67. if (res.roles && res.roles.length > 0) {
  68. commit('SET_ROLES', res.roles)
  69. commit('SET_PERMISSIONS', res.permissions)
  70. } else {
  71. commit('SET_ROLES', ['ROLE_DEFAULT'])
  72. }
  73. console.log(res.user.userOrWorker, '>>>>>>res.user.userOrWorker');
  74. if (res.user) commit('SET_USERORWORKER', res.user.userOrWorker)
  75. console.log(state.userOrWorker, '>>>>>>');
  76. commit('SET_NAME', username)
  77. commit('SET_AVATAR', avatar)
  78. resolve(res)
  79. }).catch(error => {
  80. reject(error)
  81. })
  82. })
  83. },
  84. // 退出系统
  85. LogOut({ commit, state }) {
  86. return new Promise((resolve, reject) => {
  87. logout().then((res) => {
  88. commit('SET_TOKEN', '')
  89. commit('SET_ROLES', [])
  90. commit('SET_PERMISSIONS', [])
  91. removeToken()
  92. storage.clean()
  93. resolve(res)
  94. }).catch(error => {
  95. reject(error)
  96. })
  97. })
  98. }
  99. }
  100. }
  101. export default user