From 2c86a8bd60deed0dd0e044bad6fb83f75d19a332 Mon Sep 17 00:00:00 2001
From: wlzboy <66905212@qq.com>
Date: 星期日, 26 十月 2025 15:05:50 +0800
Subject: [PATCH] Merge branch 'feature-task'

---
 app/store/modules/user.js |  152 ++++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 152 insertions(+), 0 deletions(-)

diff --git a/app/store/modules/user.js b/app/store/modules/user.js
new file mode 100644
index 0000000..ec289bf
--- /dev/null
+++ b/app/store/modules/user.js
@@ -0,0 +1,152 @@
+import config from '@/config'
+import storage from '@/utils/storage'
+import constant from '@/utils/constant'
+import { login, logout, getInfo } from '@/api/login'
+import { wechatLogin } from '@/api/wechat'
+import { getToken, setToken, removeToken } from '@/utils/auth'
+
+const baseUrl = config.baseUrl
+
+const user = {
+  state: {
+    token: getToken(),
+    userId: storage.get(constant.userId),
+    name: storage.get(constant.name),
+    nickName: storage.get(constant.nickName),
+    avatar: storage.get(constant.avatar),
+    roles: storage.get(constant.roles),
+    permissions: storage.get(constant.permissions),
+    deptId: storage.get(constant.deptId),
+    branchCompanyId: storage.get(constant.branchCompanyId),
+    branchCompanyName: storage.get(constant.branchCompanyName),
+    oaUserId: storage.get(constant.oaUserId)
+  },
+
+  mutations: {
+    SET_TOKEN: (state, token) => {
+      state.token = token
+    },
+    SET_USER_ID: (state, userId) => {
+      state.userId = userId
+      storage.set(constant.userId, userId)
+    },
+    SET_NAME: (state, name) => {
+      state.name = name
+      storage.set(constant.name, name)
+    },
+    SET_NICK_NAME: (state, nickName) => {
+      state.nickName = nickName
+      storage.set(constant.nickName, nickName)
+    },
+    SET_AVATAR: (state, avatar) => {
+      state.avatar = avatar
+      storage.set(constant.avatar, avatar)
+    },
+    SET_ROLES: (state, roles) => {
+      state.roles = roles
+      storage.set(constant.roles, roles)
+    },
+    SET_PERMISSIONS: (state, permissions) => {
+      state.permissions = permissions
+      storage.set(constant.permissions, permissions)
+    },
+    SET_DEPT_ID: (state, deptId) => {
+      state.deptId = deptId
+      storage.set(constant.deptId, deptId)
+    },
+    SET_BRANCH_COMPANY_ID: (state, branchCompanyId) => {
+      state.branchCompanyId = branchCompanyId
+      storage.set(constant.branchCompanyId, branchCompanyId)
+    },
+    SET_BRANCH_COMPANY_NAME: (state, branchCompanyName) => {
+      state.branchCompanyName = branchCompanyName
+      storage.set(constant.branchCompanyName, branchCompanyName)
+    },
+    SET_OA_USER_ID: (state, oaUserId) => {
+      state.oaUserId = oaUserId
+      storage.set(constant.oaUserId, oaUserId)
+    }
+  },
+
+  actions: {
+    // 鐧诲綍
+    Login({ commit }, 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)
+          commit('SET_TOKEN', res.token)
+          resolve()
+        }).catch(error => {
+          reject(error)
+        })
+      })
+    },
+
+    // 寰俊鐧诲綍
+    WechatLogin({ commit }, wechatData) {
+      return new Promise((resolve, reject) => {
+        wechatLogin(wechatData).then(res => {
+          setToken(res.token)
+          commit('SET_TOKEN', res.token)
+          resolve()
+        }).catch(error => {
+          reject(error)
+        })
+      })
+    },
+
+    // 鑾峰彇鐢ㄦ埛淇℃伅
+    GetInfo({ commit, state }) {
+      return new Promise((resolve, reject) => {
+        getInfo().then(res => {
+          const user = res.user
+          const avatar = (user == null || user.avatar == "" || user.avatar == null) ? require("@/static/images/profile.jpg") : baseUrl + user.avatar
+          const username = (user == null || user.userName == "" || user.userName == null) ? "" : user.userName
+          const nickname = (user == null || user.nickName == "" || user.nickName == null) ? username : user.nickName
+          const userId = (user == null || user.userId == null) ? null : user.userId
+          const deptId = (user == null || user.deptId == null) ? null : user.deptId
+          
+          if (res.roles && res.roles.length > 0) {
+            commit('SET_ROLES', res.roles)
+            commit('SET_PERMISSIONS', res.permissions)
+          } else {
+            commit('SET_ROLES', ['ROLE_DEFAULT'])
+          }
+          commit('SET_USER_ID', userId)
+          commit('SET_NAME', username)
+          commit('SET_NICK_NAME', nickname)
+          commit('SET_AVATAR', avatar)
+          commit('SET_DEPT_ID', deptId)
+          commit('SET_BRANCH_COMPANY_ID', res.branchCompanyId)
+          commit('SET_BRANCH_COMPANY_NAME', res.branchCompanyName)
+          commit('SET_OA_USER_ID', res.oaUserId)
+          resolve(res)
+        }).catch(error => {
+          reject(error)
+        })
+      })
+    },
+
+    // 閫�鍑虹郴缁�
+    LogOut({ commit, state }) {
+      return new Promise((resolve, reject) => {
+        logout(state.token).then(() => {
+          commit('SET_TOKEN', '')
+          commit('SET_ROLES', [])
+          commit('SET_PERMISSIONS', [])
+          removeToken()
+          storage.clean()
+          resolve()
+        }).catch(error => {
+          reject(error)
+        })
+      })
+    }
+  }
+}
+
+export default user
\ No newline at end of file

--
Gitblit v1.9.1