| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138 |
- import { defineStore } from "pinia";
- import {
- type userType,
- store,
- router,
- resetRouter,
- routerArrays,
- storageLocal
- } from "../utils";
- import {
- type UserResult,
- type RefreshTokenResult,
- getLogin,
- refreshTokenApi
- } from "@/api/user";
- import { useMultiTagsStoreHook } from "./multiTags";
- import { type DataInfo, setToken, removeToken, userKey } from "@/utils/auth";
- import { ROLES } from '@/global/constDefine.js';
- export const useUserStore = defineStore("pure-user", {
- state: (): userType => ({
- // 头像
- avatar: storageLocal().getItem<DataInfo<number>>(userKey)?.avatar ?? "",
- // 用户名
- username: storageLocal().getItem<DataInfo<number>>(userKey)?.username ?? "",
- // 昵称
- nickname: storageLocal().getItem<DataInfo<number>>(userKey)?.nickname ?? "",
- // 页面级别权限
- roles: storageLocal().getItem<DataInfo<number>>(userKey)?.roles ?? [],
- // 按钮级别权限
- permissions:
- storageLocal().getItem<DataInfo<number>>(userKey)?.permissions ?? [],
- // 前端生成的验证码(按实际需求替换)
- verifyCode: "",
- // 判断登录页面显示哪个组件(0:登录(默认)、1:手机登录、2:二维码登录、3:注册、4:忘记密码)
- currentPage: 0,
- // 是否勾选了登录页的免登录
- isRemembered: false,
- // 登录页的免登录存储几天,默认7天
- loginDay: 7
- }),
- actions: {
- /** 存储头像 */
- SET_AVATAR(avatar: string) {
- this.avatar = avatar;
- },
- /** 存储用户名 */
- SET_USERNAME(username: string) {
- this.username = username;
- },
- /** 存储昵称 */
- SET_NICKNAME(nickname: string) {
- this.nickname = nickname;
- },
- /** 存储角色 */
- SET_ROLES(roles: Array<string>) {
- this.roles = roles;
- },
- /** 存储按钮级别权限 */
- SET_PERMS(permissions: Array<string>) {
- this.permissions = permissions;
- },
- /** 存储前端生成的验证码 */
- SET_VERIFYCODE(verifyCode: string) {
- this.verifyCode = verifyCode;
- },
- /** 存储登录页面显示哪个组件 */
- SET_CURRENTPAGE(value: number) {
- this.currentPage = value;
- },
- /** 存储是否勾选了登录页的免登录 */
- SET_ISREMEMBERED(bool: boolean) {
- this.isRemembered = bool;
- },
- /** 设置登录页的免登录存储几天 */
- SET_LOGINDAY(value: number) {
- this.loginDay = Number(value);
- },
- /** 登入 */
- async loginByUsername(data) {
- return new Promise<UserResult>((resolve, reject) => {
- getLogin(data)
- .then(data => {
- console.log("rsp getLogin:", data);
- const userData = data.user;
- console.log("rsp userData:", userData);
- if (data?.success) setToken(userData);
- resolve(data);
- })
- .catch(error => {
- reject(error);
- });
- });
- },
- /** 前端登出(不调用接口) */
- logOut() {
- this.username = "";
- this.roles = [];
- this.permissions = [];
- const vGlobal = window.vueGlobal;
- console.log('vGlobal 重置')
- vGlobal.clearSchedule();
- vGlobal.resetInit();
- removeToken();
- useMultiTagsStoreHook().handleTags("equal", [...routerArrays]);
- resetRouter();
- router.push("/login");
- },
- /** 刷新`token` */
- async handRefreshToken(data) {
- return new Promise<RefreshTokenResult>((resolve, reject) => {
- refreshTokenApi(data)
- .then(data => {
- if (data) {
- console.log('refresh token data', data);
- setToken(data.data);
- resolve(data);
- }
- })
- .catch(error => {
- reject(error);
- });
- });
- },
- existsRole(rolenames) {
- for (const name of rolenames) {
- if (this.roles.indexOf(name) >= 0) {
- return true;
- }
- }
- return false;
- }
- }
- });
- export function useUserStoreHook() {
- return useUserStore(store);
- }
|