加油站付款小程序,打印小票
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 

86 lines
1.7 KiB

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
})
})
},
login(state) {
uni.login({
success(res) {
console.log(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/payment/payment'
})
}
})
},
fail(err) {
console.error(err)
}
})
},
getUserInfo(state) {
api('infoGetInfo', res => {
if(res.code == 200){
state.userInfo = res.result
}
})
},
},
actions: {},
})
export default store