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) { 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); } else { 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 }) { 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