整合小程序库

This commit is contained in:
aixianling
2022-06-29 16:41:40 +08:00
parent 0b83cec78b
commit 2ef633a0c8
7 changed files with 133 additions and 138 deletions

View File

@@ -1,97 +1,25 @@
import Vue from 'vue'
import Vuex from 'vuex'
import perState from 'vuex-persistedstate'
import http from "../utils/axios";
import * as modules from "dvcp-wui/utils/modules"
Vue.use(Vuex)
const store = new Vuex.Store({
state: {
/**
* 是否需要强制登录
*/
forcedLogin: false,
token: "",
userName: "",
user: {
username: "",
avatarUrl: "",
nickName: "",
gender: "",
token: "",
phoneNumber: ''
},
global: {
areaId: ""
}
token: ""
},
mutations: {
getToken(state, params) {
if (params?.code) {
http.instance.post("/auth/wechat-con/token", params, {
headers: {"Authorization": "Basic d2VjaGF0OndlY2hhdA=="},
withoutToken: true
}).then(res => {
if (res?.access_token) {
store.commit("setToken", res.token_type + ' ' + res.access_token)
params?.then?.(true)
} else {
uni.showToast({title: res?.msg})
params?.then?.(false)
}
}).finally(err => console.error(err))
} else params?.then(false)
},
setToken(state, token) {
state.token = token
},
setUserInfo(state, user) {
state.user = user
},
getUserInfo(state, cb) {
http.instance.post("/app/appwechatuser/check").then(res => {
if (res?.data) {
store.commit("setUserInfo", res.data)
cb && cb(true)
} else {
cb && cb(false)
}
}).catch(err => {
console.error(err)
cb && cb(false)
})
},
login(state, ploy) {
state.userName = ploy.userName || '新用户';
state.token = ploy.token
},
logout(state) {
state.userName = "";
logout(state, showToast) {
state.token = ""
uni.setStorageSync('userInfo', {})
uni.setStorageSync('vuex', {})
state.user = {
username: "",
avatarUrl: "",
nickName: "",
gender: "",
token: "",
phoneNumber: ''
}
uni.showToast({title: `登录失效,请重新登录`, duration: 2000, icon: 'none'})
state.user = {}
showToast && uni.showToast({title: `登录失效,请重新登录`, duration: 2000, icon: 'none'})
},
setUser(state, info) {
state.user = info
},
getUser(state, ploy) {
state.user.nickName = ploy.nickName;
state.user.avatarUrl = ploy.avatarUrl;
state.user.gender = ploy.gender;
},
getUserPhoneNumber(state, ploy) {
state.user.phoneNumber = ploy.phoneNumber;
}
},
modules,
plugins: [perState({
storage: {
getItem: key => uni.getStorageSync(key),