From 88e5392abfba200898c93e0d1d24f7454baaf921 Mon Sep 17 00:00:00 2001
From: liudong <liudong>
Date: 星期五, 16 八月 2024 13:54:17 +0800
Subject: [PATCH] 新版UI对话页面开发
---
src/store/modules/user/index.ts | 28 +++++++++++++++++++++++++---
1 files changed, 25 insertions(+), 3 deletions(-)
diff --git a/src/store/modules/user/index.ts b/src/store/modules/user/index.ts
index ca37a8b..7bb51c3 100644
--- a/src/store/modules/user/index.ts
+++ b/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 => ({
@@ -29,6 +31,7 @@
certification: undefined,
role: '',
resources:undefined,
+ hrefUrl:undefined
}),
getters: {
@@ -51,6 +54,7 @@
// Reset user's information
resetInfo() {
+ clearUserResources()
this.$reset();
},
@@ -62,17 +66,27 @@
},
// 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,
};
- this.resources=res.data.resources;
+ if(res.data.roles && res.data.roles.length>0)
+ this.resources=res.data.roles[0].resources;
+ else
+ this.resources=res.data.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;
@@ -90,9 +104,17 @@
try {
await userLogout();
} finally {
+ router.push({
+ name: "login",
+ });
this.logoutCallBack();
}
},
+
+
+ getHreFurl(url: string) {
+ this.hrefUrl=url
+ },
},
});
--
Gitblit v1.8.0