Files
vue3-element-admin/src/store/modules/user.ts
郝先瑞 8bd514fa29 refactor: ♻️ 获取用户信息和登出清除会话优化
Former-commit-id: 4486879b3beb4d26b7a41cffd4e0b4b022e1943d
2023-11-09 18:32:51 +08:00

101 lines
2.2 KiB
TypeScript

import { defineStore } from "pinia";
import { loginApi, logoutApi } from "@/api/auth";
import { getUserInfoApi } from "@/api/user";
import { resetRouter } from "@/router";
import { store } from "@/store";
import { LoginData } from "@/api/auth/types";
import { UserInfo } from "@/api/user/types";
import { useStorage } from "@vueuse/core";
export const useUserStore = defineStore("user", () => {
const user: UserInfo = {
roles: [],
perms: [],
};
const token = useStorage("accessToken", "");
/**
* 登录
*
* @param {LoginData}
* @returns
*/
function login(loginData: LoginData) {
return new Promise<void>((resolve, reject) => {
loginApi(loginData)
.then((response) => {
const { tokenType, accessToken } = response.data;
token.value = tokenType + " " + accessToken; // Bearer eyJhbGciOiJIUzI1NiJ9.xxx.xxx
resolve();
})
.catch((error) => {
reject(error);
});
});
}
// 获取信息(用户昵称、头像、角色集合、权限集合)
function getUserInfo() {
return new Promise<UserInfo>((resolve, reject) => {
getUserInfoApi()
.then(({ data }) => {
if (!data) {
reject("Verification failed, please Login again.");
return;
}
if (!data.roles || data.roles.length <= 0) {
reject("getUserInfo: roles must be a non-null array!");
return;
}
Object.assign(user, { ...data });
resolve(data);
})
.catch((error) => {
reject(error);
});
});
}
// user logout
function logout() {
return new Promise<void>((resolve, reject) => {
logoutApi()
.then(() => {
token.value = "";
location.reload(); // 清空路由
resolve();
})
.catch((error) => {
reject(error);
});
});
}
// remove token
function resetToken() {
return new Promise<void>((resolve) => {
token.value = "";
resetRouter();
resolve();
});
}
return {
token,
user,
login,
getUserInfo,
logout,
resetToken,
};
});
// 非setup
export function useUserStoreHook() {
return useUserStore(store);
}