index.js 1.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  1. import Vue from 'vue'
  2. import Vuex from 'vuex'
  3. import { logout } from '@/api/auth'
  4. import { getUserInfo } from '@/api/user'
  5. Vue.use(Vuex) // vue的插件机制
  6. // Vuex.Store 构造器选项
  7. const store = new Vuex.Store({
  8. state: {
  9. openExamine: false, // 是否开启审核状态。用于小程序、App 等审核时,关闭部分功能。TODO 芋艿:暂时没找到刷新的地方
  10. token: uni.getStorageSync('token'), // 用户身份 Token
  11. userInfo: uni.getStorageSync('userInfo'), // 用户基本信息
  12. timerIdent: false // 全局 1s 定时器,只在全局开启一个,所有需要定时执行的任务监听该值即可,无需额外开启 TODO 芋艿:需要看看
  13. },
  14. getters: {
  15. hasLogin(state) {
  16. return !!state.token
  17. }
  18. },
  19. mutations: {
  20. // 更新 state 的通用方法
  21. setStateAttr(state, param) {
  22. if (param instanceof Array) {
  23. for (let item of param) {
  24. state[item.key] = item.val
  25. }
  26. } else {
  27. state[param.key] = param.val
  28. }
  29. },
  30. // 更新token
  31. setToken(state, data) {
  32. // 设置 Token
  33. const { token } = data
  34. state.token = token
  35. uni.setStorageSync('token', token)
  36. // 加载用户信息
  37. this.dispatch('obtainUserInfo')
  38. },
  39. // 更新用户信息
  40. setUserInfo(state, data) {
  41. state.userInfo = data
  42. uni.setStorageSync('userInfo', data)
  43. },
  44. // 清空 Token 和 用户信息
  45. clearLoginInfo(state) {
  46. uni.removeStorageSync('token')
  47. state.token = ''
  48. uni.removeStorageSync('userInfo')
  49. state.userInfo = {}
  50. }
  51. },
  52. actions: {
  53. // 获得用户基本信息
  54. async obtainUserInfo({ state, commit }) {
  55. const res = await getUserInfo()
  56. commit('setUserInfo', res.data)
  57. },
  58. // 退出登录
  59. async logout({ state, commit }) {
  60. commit('clearLoginInfo')
  61. await logout()
  62. }
  63. }
  64. })
  65. export default store