pinia替换vuex
parent
01a159d4a7
commit
fe3834916a
@ -1,80 +1,89 @@
|
|||||||
import { login, logout, getInfo } from '@/api/login'
|
import { login, logout, getInfo } from "@/api/login";
|
||||||
import { getToken, setToken, removeToken } from '@/utils/auth'
|
import { getToken, setToken, removeToken } from "@/utils/auth";
|
||||||
import defAva from '@/static/images/profile.jpg'
|
import defAva from "@/static/images/profile.jpg";
|
||||||
import { defineStore } from 'pinia'
|
import { defineStore } from "pinia";
|
||||||
|
|
||||||
export interface LoginForm {
|
export interface LoginForm {
|
||||||
username: string
|
username: string;
|
||||||
password: string
|
password: string;
|
||||||
code: string
|
code: string;
|
||||||
uuid: string
|
uuid: string;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const useUserStore = defineStore("user", {
|
||||||
const useUserStore = defineStore(
|
|
||||||
'user',
|
|
||||||
{
|
|
||||||
state: () => ({
|
state: () => ({
|
||||||
token: getToken(),
|
token: getToken(),
|
||||||
name: '',
|
name: "",
|
||||||
avatar: '',
|
avatar: "",
|
||||||
roles: Array(),
|
roles: Array(),
|
||||||
permissions: []
|
permissions: [],
|
||||||
}),
|
}),
|
||||||
actions: {
|
actions: {
|
||||||
// 登录
|
// 登录
|
||||||
login(userInfo: LoginForm) {
|
login(userInfo: LoginForm) {
|
||||||
const username = userInfo.username.trim()
|
const username = userInfo.username.trim();
|
||||||
const password = userInfo.password
|
const password = userInfo.password;
|
||||||
const code = userInfo.code
|
const code = userInfo.code;
|
||||||
const uuid = userInfo.uuid
|
const uuid = userInfo.uuid;
|
||||||
return new Promise((resolve, reject) => {
|
return new Promise((resolve, reject) => {
|
||||||
login(username, password, code, uuid).then((res:any) => {
|
login(username, password, code, uuid)
|
||||||
setToken(res.token)
|
.then((res: any) => {
|
||||||
this.token = res.token
|
setToken(res.token);
|
||||||
resolve(null)
|
this.token = res.token;
|
||||||
}).catch(error => {
|
resolve(null);
|
||||||
reject(error)
|
|
||||||
})
|
|
||||||
})
|
})
|
||||||
|
.catch((error) => {
|
||||||
|
reject(error);
|
||||||
|
});
|
||||||
|
});
|
||||||
},
|
},
|
||||||
// 获取用户信息
|
// 获取用户信息
|
||||||
getInfo() {
|
getInfo() {
|
||||||
return new Promise((resolve, reject) => {
|
return new Promise((resolve, reject) => {
|
||||||
getInfo().then((res:any) => {
|
getInfo()
|
||||||
const user = res.user
|
.then((res: any) => {
|
||||||
|
const user = res.user;
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
const avatar = (user.avatar == "" || user.avatar == null) ? defAva : import.meta.env.VITE_APP_BASE_API + user.avatar;
|
const avatar =
|
||||||
|
user.avatar == "" || user.avatar == null
|
||||||
|
? defAva
|
||||||
|
: import.meta.env.VITE_APP_BASE_API + user.avatar;
|
||||||
|
|
||||||
if (res.roles && res.roles.length > 0) { // 验证返回的roles是否是一个非空数组
|
if (res.roles && res.roles.length > 0) {
|
||||||
this.roles = res.roles
|
// 验证返回的roles是否是一个非空数组
|
||||||
this.permissions = res.permissions
|
this.roles = res.roles;
|
||||||
|
this.permissions = res.permissions;
|
||||||
} else {
|
} else {
|
||||||
this.roles = ['ROLE_DEFAULT']
|
this.roles = ["ROLE_DEFAULT"];
|
||||||
}
|
}
|
||||||
this.name = user.userName
|
this.name = user.userName;
|
||||||
this.avatar = avatar;
|
this.avatar = avatar;
|
||||||
resolve(res)
|
resolve(res);
|
||||||
}).catch(error => {
|
|
||||||
reject(error)
|
|
||||||
})
|
|
||||||
})
|
})
|
||||||
|
.catch((error) => {
|
||||||
|
reject(error);
|
||||||
|
});
|
||||||
|
});
|
||||||
},
|
},
|
||||||
// 退出系统
|
// 退出系统
|
||||||
logOut() {
|
logOut() {
|
||||||
return new Promise((resolve, reject) => {
|
return new Promise((resolve, reject) => {
|
||||||
logout().then(() => {
|
logout()
|
||||||
this.token = ''
|
.then(() => {
|
||||||
this.roles = []
|
this.token = "";
|
||||||
this.permissions = []
|
this.roles = [];
|
||||||
removeToken()
|
this.permissions = [];
|
||||||
resolve(null)
|
this.name = "";
|
||||||
}).catch(error => {
|
this.avatar = "";
|
||||||
reject(error)
|
removeToken();
|
||||||
})
|
resolve(null);
|
||||||
})
|
|
||||||
}
|
|
||||||
}
|
|
||||||
})
|
})
|
||||||
|
.catch((error) => {
|
||||||
|
reject(error);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
},
|
||||||
|
},
|
||||||
|
});
|
||||||
|
|
||||||
export default useUserStore
|
export default useUserStore;
|
||||||
|
|||||||
Loading…
Reference in New Issue