66 lines
1.6 KiB
JavaScript
66 lines
1.6 KiB
JavaScript
|
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
|