import Vue from 'vue' import Vuex from 'vuex' // import {request} from '@/common/js/request' import { getUserInfo } from '@/api/member/userProfile.js' Vue.use(Vuex) const store = new Vuex.Store({ state: { openExamine: false, // 是否开启审核状态。用于小程序、App 等审核时,关闭部分功能。TODO 芋艿:暂时没找到刷新的地方 token: '', // 用户身份 Token userInfo: {}, // 用户基本信息 timerIdent: false, // 全局 1s 定时器,只在全局开启一个,所有需要定时执行的任务监听该值即可,无需额外开启 TODO 芋艿:需要看看 }, getters: { hasLogin(state){ return !!state.token; } }, mutations: { // 更新 state 的通用方法 setStateAttr(state, param) { if (param instanceof Array) { for(let item of param){ state[item.key] = item.val; } } else { state[param.key] = param.val; } }, // 更新token setToken(state, data) { // 设置 Token const { token } = data; state.token = token; uni.setStorageSync('token', token); // 加载用户信息 this.dispatch('obtainUserInfo'); }, // 退出登录 logout(state) { // 清空 Token state.token = ''; uni.removeStorageSync('token'); // 清空用户信息 TODO 芋艿:这里 setTimeout 的原因是,上面可能还有一些 request 请求。后续得优化下 setTimeout(()=>{ state.userInfo = {}; }, 1100) }, }, actions: { // 获得用户基本信息 async obtainUserInfo({state, commit}) { const data = await getUserInfo(); commit('setStateAttr', { key: 'userInfo', val: data }); } } }) export default store