import Vue from 'vue' import Vuex from 'vuex' Vue.use(Vuex) const debug = process.env.NODE_ENV !== 'production' import cookie from '@/utils/store/cookie' import { getUserInfo, getUser } from '@/api/user' import dialog from '@/utils/dialog' const loginKey = 'login_status' const vuexStore = new Vuex.Store({ state: { // 是否已经在授权页面 isAuthorizationPage: false, // 是否授权 isAuthorization: false, // 不建议从这里取 token,但是删除掉会影响其他的页面 token: cookie.get(loginKey) || null, userInfo: cookie.get('userInfo'), $deviceType: null, location: { latitude: '', longitude: '', }, storeItems: cookie.get('storeItems') || null, goName: cookie.get('goName') || '', }, mutations: { login(state, token, expires_time) { console.log('设置token') state.token = token cookie.set(loginKey, token, expires_time) }, logout(state) { console.log('清除数据') state.token = null state.userInfo = null cookie.clearAll() }, backgroundColor(state, color) { state.color = color // document.body.style.backgroundColor = color; }, updateUserInfo(state, userInfo) { state.userInfo = userInfo if (userInfo) { cookie.set('userInfo', userInfo) } else { cookie.set('userInfo', null) } }, updateAuthorizationPage(state, isAuthorizationPage) { state.isAuthorizationPage = isAuthorizationPage }, updateAuthorization(state, isAuthorization) { state.isAuthorization = isAuthorization }, updateDevicetype(state, $deviceType) { state.$deviceType = $deviceType }, setLocation(state, location) { state.location = location }, get_store(state, storeItems) { state.storeItems = storeItems cookie.set('storeItems', storeItems) }, get_to(state, goName) { state.goName = goName cookie.set('goName', goName) }, }, actions: { getLocation({ state, commit }, force) { uni.getLocation({ type: 'gcj02', success: function(res) { console.log(res) commit('setLocation', { longitude: res.longitude, latitude: res.latitude, }) }, }) }, userInfo({ state, commit }, force) { if (state.userInfo !== null && !force) { return Promise.resolve(state.userInfo) } return new Promise(reslove => { getUserInfo().then(res => { commit('updateUserInfo', res.data) reslove(res.data) }) }).catch(() => { uni.showToast({ title: '获取信息失败!', icon: 'none', duration: 2000, }) }) }, getUser({ state, commit }) { if (!state.token) { return Promise.reject('未获取到token') } return new Promise(reslove => { getUserInfo().then(res => { console.log(res) commit('updateUserInfo', res.data) reslove(res.data) }) }).catch(error => { console.log(error) uni.showToast({ title: '获取信息失败!', icon: 'none', duration: 2000, }) }) }, changeLogin({ state, commit }, data, date) { commit('login', data, date) }, setUserInfo({ state, commit }, user) { commit('updateUserInfo', user) }, changeAuthorizationPage({ state, commit }, index) { commit('updateAuthorizationPage', index) }, changeAuthorization({ state, commit }, index) { commit('updateAuthorization', index) }, }, getters: { isAuthorizationPage: state => state.isAuthorizationPage, isAuthorization: state => state.isAuthorization, token: state => state.token, isLogin: state => !!state.token, userInfo: state => state.userInfo || {}, location: state => state.location, storeItems: state => state.storeItems, goName: state => state.goName, $deviceType: state => state.$deviceType, }, strict: debug, }) export default vuexStore