1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465 |
- 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
|