From 9c7465c9e2cb36b9de943cfb6065b80d214ab023 Mon Sep 17 00:00:00 2001
From: zhangwencui <1064582902@qq.com>
Date: 星期四, 21 五月 2026 09:39:18 +0800
Subject: [PATCH] Merge branch 'dev_NEW_pro' of http://114.132.189.42:9002/r/product-inventory-management into dev_NEW_pro

---
 src/store/modules/user.js |  149 +++++++++++++++++++++++++++----------------------
 1 files changed, 83 insertions(+), 66 deletions(-)

diff --git a/src/store/modules/user.js b/src/store/modules/user.js
index 057af50..dd31b26 100644
--- a/src/store/modules/user.js
+++ b/src/store/modules/user.js
@@ -7,30 +7,36 @@
 const useUserStore = defineStore(
   'user',
   {
-    state: () => ({
-      token: getToken(),
-      id: '',
-      name: '',
-      avatar: '',
-      roles: [],
-      permissions: []
+    state: () => ({
+      token: getToken(),
+      id: '',
+      name: '',
+      avatar: '',
+      roles: [],
+      permissions: [],
+      aiEnabled: 0
     }),
     actions: {
       // 鐧诲綍
-      login(userInfo) {
-        const username = userInfo.username.trim()
-        const password = userInfo.password
-        const code = userInfo.code
-        const uuid = userInfo.uuid
-        return new Promise((resolve, reject) => {
-          login(username, password, code, uuid).then(res => {
-            setToken(res.token)
-            this.token = res.token
-            resolve()
-          }).catch(error => {
-            reject(error)
-          })
-        })
+      login(userInfo) {
+        const username = userInfo.username.trim()
+        const password = userInfo.password
+        const code = userInfo.code
+        const uuid = userInfo.uuid
+        return new Promise((resolve, reject) => {
+          login(username, password, code, uuid).then(res => {
+            const token = res?.token || res?.data?.token
+            if (!token) {
+              reject(new Error('鏈幏鍙栧埌鐧诲綍浠ょ墝'))
+              return
+            }
+            setToken(token)
+            this.token = token
+            resolve()
+          }).catch(error => {
+            reject(error)
+          })
+        })
       },
       getCurrentTime() {
         const now = new Date();
@@ -46,7 +52,7 @@
       getInfo() {
         return new Promise((resolve, reject) => {
           getInfo().then(res => {
-            const user = res.user
+            const user = res.user || {}
             let avatar = user.avatar || ""
             avatar = import.meta.env.VITE_APP_BASE_API + '/profile/' + avatar
             if (res.roles && res.roles.length > 0) { // 楠岃瘉杩斿洖鐨剅oles鏄惁鏄竴涓潪绌烘暟缁�
@@ -55,32 +61,34 @@
             } else {
               this.roles = ['ROLE_DEFAULT']
             }
-            this.id = user.userId
-            this.name = user.userName
+            this.id = user.userId || ''
+            this.name = user.userName || ''
             this.avatar = avatar
-            this.currentFactoryName = user.currentFactoryName
-            this.nickName = user.nickName
-            this.roleName = user.roles[0].roleName
-            this.currentDeptId = user.tenantId
-            this.currentLoginTime = this.getCurrentTime()
-            resolve(res)
-          }).catch(error => {
-            reject(error)
-          })
-        })
+            this.currentFactoryName = user.currentFactoryName || ''
+            this.nickName = user.nickName || ''
+            this.roleName = Array.isArray(user.roles) && user.roles.length > 0 ? (user.roles[0].roleName || '') : ''
+            this.currentDeptId = user.tenantId || ''
+            this.currentLoginTime = this.getCurrentTime()
+            this.aiEnabled = Number(res.aiEnabled) === 1 ? 1 : 0
+            resolve(res)
+          }).catch(error => {
+            reject(error)
+          })
+        })
       },
       // 閫�鍑虹郴缁�
       logOut() {
         return new Promise((resolve, reject) => {
           logout(this.token).then(() => {
-            this.token = ''
-            this.roles = []
-            this.permissions = []
-            removeToken()
-            resolve()
-          }).catch(error => {
-            reject(error)
-          })
+            this.token = ''
+            this.roles = []
+            this.permissions = []
+            this.aiEnabled = 0
+            removeToken()
+            resolve()
+          }).catch(error => {
+            reject(error)
+          })
         })
       },
       // 鐧诲綍鏍¢獙
@@ -96,31 +104,40 @@
         })
       },
       // 閮ㄩ棬鐧诲綍
-      loginCheckFactory(userInfo) {
-        const username = userInfo.username.trim()
-        const password = userInfo.password
-        const factoryId = userInfo.currentFatoryId
-        return new Promise((resolve, reject) => {
-          loginCheckFactory(username, password, factoryId).then(res => {
-            setToken(res.token)
-            this.token = res.token
-            resolve()
-          }).catch(error => {
-            reject(error)
-          })
-        })
+      loginCheckFactory(userInfo) {
+        const username = userInfo.username.trim()
+        const password = userInfo.password
+        return new Promise((resolve, reject) => {
+          loginCheckFactory(username, password).then(res => {
+            const token = res?.token || res?.data?.token
+            if (!token) {
+              reject(new Error('鏈幏鍙栧埌鐧诲綍浠ょ墝'))
+              return
+            }
+            setToken(token)
+            this.token = token
+            resolve()
+          }).catch(error => {
+            reject(error)
+          })
+        })
       },
-      TideLogin(code) {
-        return new Promise((resolve, reject) => {
-          tideLogin(code)
-              .then((res) => {
-                setToken(res.token);
-                this.token = res.token
-                Vue.prototype.uploadHeader = {
-                  Authorization: "Bearer " + res.token,
-                };
-                resolve();
-              })
+      TideLogin(code) {
+        return new Promise((resolve, reject) => {
+          tideLogin(code)
+              .then((res) => {
+                const token = res?.token || res?.data?.token
+                if (!token) {
+                  reject(new Error('鏈幏鍙栧埌鐧诲綍浠ょ墝'))
+                  return
+                }
+                setToken(token);
+                this.token = token
+                Vue.prototype.uploadHeader = {
+                  Authorization: "Bearer " + token,
+                };
+                resolve();
+              })
               .catch((error) => {
                 reject(error);
               });

--
Gitblit v1.9.3