import Vue from 'vue'
|
|
import Vuex from 'vuex'
|
|
|
|
Vue.use(Vuex); //vue的插件机制
|
|
|
|
import api from '@/api/api.js'
|
|
|
|
//Vuex.Store 构造器选项
|
|
const store = new Vuex.Store({
|
|
state: {
|
|
configList: {}, //配置对象
|
|
userInfo: {},
|
|
},
|
|
getters: {
|
|
getConfig(state) {
|
|
return state.configList
|
|
}
|
|
},
|
|
mutations: {
|
|
// 初始化配置
|
|
initConfig(state) {
|
|
//初始化用户信息(防止用户每次点击重新进入小程序用户信息都没有了)
|
|
if (uni.getStorageSync('token') && uni.getStorageSync('userInfo')) {
|
|
state.userInfo = JSON.parse(uni.getStorageSync('userInfo'))
|
|
}
|
|
|
|
let apiConfig = [ 'getPrivacyPolicy' , 'getUserAgreement' ] //需要访问不同接口才能得到的配置数据
|
|
let key = ['privacyAgreement','userAgreement']
|
|
apiConfig.forEach((item,index) => {
|
|
api(item,res => {
|
|
state.configList[key[index]] = res.result
|
|
})
|
|
})
|
|
},
|
|
login(state , form) {
|
|
if (!form) { //微信登录
|
|
uni.login({
|
|
success(res) {
|
|
if (res.errMsg != "login:ok") {
|
|
return
|
|
}
|
|
api('studentLogin', {
|
|
code: res.code
|
|
}, res => {
|
|
if (res.code != 200) {
|
|
return
|
|
}
|
|
uni.setStorageSync('token', res.result.token);
|
|
uni.setStorageSync('userInfo', JSON.stringify(res.result.userInfo));
|
|
state.userInfo = res.result.userInfo
|
|
//用户未设置用户名和头像,跳转上传头像或设置昵称页面
|
|
if (!state.userInfo.nickName || !state.userInfo.headImage) {
|
|
uni.navigateTo({
|
|
url: '/pages/login/wxUserInfo'
|
|
})
|
|
} else { //跳转报修页面
|
|
uni.switchTab({
|
|
url: '/pages/repair/repair'
|
|
})
|
|
}
|
|
|
|
})
|
|
},
|
|
fail(err) {
|
|
console.error(err)
|
|
}
|
|
})
|
|
} else { //手机登录
|
|
api('repairLogin' , form , res => {
|
|
if (res.code == 200) {
|
|
uni.setStorageSync('token', res.result.token);
|
|
uni.setStorageSync('userInfo', JSON.stringify(res.result.userInfo));
|
|
state.userInfo = res.result.userInfo
|
|
uni.switchTab({
|
|
url: '/pages/repair/repair'
|
|
})
|
|
}
|
|
})
|
|
}
|
|
},
|
|
setUserInfo(state, userInfo) {
|
|
state.userInfo = userInfo
|
|
},
|
|
},
|
|
actions: {},
|
|
})
|
|
|
|
export default store
|