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) {
|
|
// let config = ['preferential', 'wx']
|
|
// config.forEach(k => {
|
|
// api('getConfig', {
|
|
// keyValue : k
|
|
// }, res => {
|
|
// if (res.code == 200) {
|
|
// state.configList[k] = res.result
|
|
// }
|
|
// })
|
|
// })
|
|
|
|
// let apiConfig = [ 'getPrivacyPolicy' , 'getUserAgreement' ] //需要访问不同接口才能得到的配置数据
|
|
// let key = ['privacyAgreement','userAgreement']
|
|
// apiConfig.forEach((item,index) => {
|
|
// api(item,res => {
|
|
// state.configList[key[index]] = res.result
|
|
// })
|
|
// })
|
|
//初始化用户信息(防止用户每次点击重新进入小程序用户信息都没有了)
|
|
if(uni.getStorageSync('token') && uni.getStorageSync('userInfo')){
|
|
state.userInfo = JSON.parse(uni.getStorageSync('userInfo'))
|
|
}
|
|
|
|
},
|
|
login(state) {
|
|
uni.login({
|
|
success(res) {
|
|
if (res.errMsg != "login:ok") {
|
|
return
|
|
}
|
|
api('loginLogin', {
|
|
code: res.code
|
|
}, res => {
|
|
if (res.code != 200) {
|
|
return
|
|
}
|
|
|
|
state.userInfo = res.result.userInfo
|
|
uni.setStorageSync('token', res.result.token)
|
|
|
|
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)
|
|
}
|
|
})
|
|
},
|
|
setUserInfo(state,userInfo) {
|
|
state.userInfo = userInfo
|
|
console.log(state.userInfo);
|
|
},
|
|
},
|
|
actions: {},
|
|
})
|
|
|
|
export default store
|