index.js 1.9 KB

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