zhangxiao
2024-08-16 b4e4fccbe90d22e2a064b686705a9ccf7ea29027
src/store/modules/user/index.ts
@@ -5,10 +5,12 @@
  getUserInfo,
  LoginData,
} from '@/api/user';
import { setToken, clearToken,setUserInfo } from '@/utils/auth';
import { setToken, clearToken, setUserInfo, setUserResources, clearUserResources } from "@/utils/auth";
import { removeRouteListener } from '@/utils/route-listener';
import { UserState } from './types';
import useAppStore from '../app';
import router from "@/router";
const useUserStore = defineStore('user', {
  state: (): UserState => ({
@@ -28,6 +30,8 @@
    accountId: undefined,
    certification: undefined,
    role: '',
    resources:undefined,
    hrefUrl:undefined
  }),
  getters: {
@@ -50,6 +54,7 @@
    // Reset user's information
    resetInfo() {
      clearUserResources()
      this.$reset();
    },
@@ -61,16 +66,26 @@
    },
    // Login
    async login(loginForm: LoginData) {
    async login(loginForm: LoginData):string {
      try {
        const res = await userLogin(loginForm);
        setToken(res.data.access_token);
        const userInfo = {
          avatar: res.data.avatar,
          name: res.data.nickname,
          email: res.data.email,
        };
        setUserInfo(JSON.stringify(userInfo));
        if(res.data?.roles.length>0)
            this.resources=res.data.roles[0].resources;
            setUserInfo(JSON.stringify(userInfo));
            setUserResources(JSON.stringify(this.resources))
        for (const r of this.resources) {
          if (r.menuType == 0) {
            return r.component
          }
        }
      } catch (err) {
        clearToken();
        throw err;
@@ -88,9 +103,17 @@
      try {
        await userLogout();
      } finally {
        router.push({
          name: "login",
        });
        this.logoutCallBack();
      }
    },
    getHreFurl(url: string) {
      this.hrefUrl=url
    },
  },
});