From 63a460afe88b96152573f7a84491deb9cc1962aa Mon Sep 17 00:00:00 2001
From: wupengfei <834520024@qq.com>
Date: 星期五, 17 十月 2025 19:38:40 +0800
Subject: [PATCH] feat: 1.2.0.1

---
 src/store/modules/user.ts |  126 ++++++++++++++++++++---------------------
 1 files changed, 61 insertions(+), 65 deletions(-)

diff --git a/src/store/modules/user.ts b/src/store/modules/user.ts
index 3aecc22..91a830c 100644
--- a/src/store/modules/user.ts
+++ b/src/store/modules/user.ts
@@ -1,31 +1,40 @@
 import { defineStore } from 'pinia';
 import { store } from '@/store';
-import { getToken, setToken, removeToken, removeUserInfo, setUserInfo, getUserInfo } from '@/utils';
+import {
+  getToken,
+  setToken,
+  removeToken,
+  removeUserInfo,
+  setUserInfo,
+  getUserInfo,
+  md5Encrypt,
+  getUserDetail,
+  setUserDetail,
+  removeUserDetail,
+} from '@/utils';
 import { resetRouter, router } from '@/router';
 import { useTagsViewStoreHook } from './tagsView';
-import * as accountServices from '@/services/api/Account';
 import { usePermissionStoreHook } from './permission';
 import { getAccountInfoFromAccessToken, AccountInfo } from '@bole-core/core';
 import { useClearSubModule } from '@/hooks';
 import { myClient } from '@/constants/query';
+import * as authServices from '@/services/api/auth';
 
 export interface UserState {
   token: string;
-  userInfo: API.IdentityModelTokenCacheItem;
-  accountInfo: Partial<AccountInfo>;
-  name: string;
+  userInfo: API.LoginCommandCallback;
+  userDetail?: Nullable<API.GetEnterpriseLoginInfoQueryResult>;
 }
 
 function getDefaultState() {
   const accessToken = getToken();
   const userInfo = getUserInfo();
-  const accountInfo = getAccountInfoFromAccessToken(accessToken);
+  const userDetail = getUserDetail();
 
   return {
     token: accessToken,
-    name: accountInfo.name,
-    accountInfo: accountInfo || {},
     userInfo: userInfo || {},
+    userDetail: userDetail,
   } as UserState;
 }
 
@@ -41,7 +50,7 @@
     },
 
     userId(state) {
-      return state.accountInfo.sub;
+      return state.userDetail?.id;
     },
   },
   actions: {
@@ -49,49 +58,48 @@
       this.token = token;
       setToken(token);
     },
-    setName(name: string) {
-      this.name = name;
-    },
-    setUserInfo(userInfo: API.IdentityModelTokenCacheItem) {
+    setUserInfo(userInfo: API.LoginCommandCallback) {
       this.userInfo = userInfo;
       setUserInfo(userInfo);
     },
-    setAccountInfo(accountInfo: Partial<AccountInfo>) {
-      this.accountInfo = accountInfo;
+
+    setUserDetail(detail: API.GetEnterpriseLoginInfoQueryResult) {
+      this.userDetail = detail;
+      setUserDetail(detail);
     },
 
     // 鐢ㄦ埛鐧诲叆
-    loginByUsername(data: API.AccessRequestDto) {
-      return new Promise<void>((resolve, reject) => {
-        accountServices
-          .getTokenForWeb(data, { showLoading: false })
-          // .passwordLogin(
-          //   {
-          //     loginName: data.userName,
-          //     password: data.userPassword,
-          //   },
-          //   { showLoading: false }
-          // )
-          .then((res) => {
-            if (res) {
-              console.log('res: ', res);
-              this.setToken(res.accessToken);
+    async loginByUsername(params: API.PasswordLoginCommand) {
+      let res = await authServices.passwordLogin(
+        {
+          ...params,
+          password: params.password,
+          // password: md5Encrypt(params.password),
+          type: AppLocalConfig.userType,
+          clientType: AppLocalConfig.clientType,
+        },
+        {
+          showLoading: false,
+        }
+      );
+      if (res) {
+        this.setToken(res.accessToken);
+        this.setUserInfo(res);
+        this.getCurrentUserInfo();
+      }
+    },
 
-              const accountInfo = getAccountInfoFromAccessToken(res.accessToken);
-
-              this.setName(accountInfo.name);
-              this.setAccountInfo(accountInfo);
-
-              // 鑾峰彇鐢ㄦ埛淇℃伅
-              this.setUserInfo(res);
-
-              resolve();
-            }
-          })
-          .catch((error) => {
-            reject(error);
-          });
-      });
+    async getCurrentUserInfo() {
+      try {
+        let res = await authServices.getEnterpriseLoginInfo({}, { showLoading: false });
+        if (res) {
+          // res.frontStatus = getUserCertificationFrontStatusAdapter(
+          //   res.userCertificationStatus,
+          //   res.userCertificationAuditStatus
+          // );
+          this.setUserDetail(res);
+        }
+      } catch (error) {}
     },
 
     // 鐧诲嚭 娓呯┖缂撳瓨
@@ -99,6 +107,7 @@
       return new Promise(async (resolve) => {
         removeToken();
         removeUserInfo();
+        removeUserDetail();
         this.resetState();
         resetRouter();
         myClient.removeQueries();
@@ -126,26 +135,13 @@
       Object.assign(this, getDefaultState());
     },
 
-    refreshToken(params: API.AccessRefreshToken) {
-      return new Promise<API.IdentityModelTokenCacheItem>(
-        // eslint-disable-next-line no-async-promise-executor
-        async (resolve, reject) => {
-          try {
-            const res = await accountServices.getTokenByRefreshToken(params, {
-              showLoading: false,
-            });
-            if (res) {
-              this.setToken(res.accessToken);
-              this.setUserInfo(res);
-              resolve(res);
-              return;
-            }
-            reject('鍑洪敊浜�');
-          } catch (error) {
-            reject(error);
-          }
-        }
-      );
+    async refreshToken(params: any) {
+      return Promise.resolve({
+        accessToken: '1222',
+        expiresIn: 1000 * 60 * 24 * 60,
+        creationTime: '2025-08-04 00:00:00',
+        refreshToken: '1222',
+      });
     },
   },
 });

--
Gitblit v1.9.1