import { login, logout, getInfo } from '@/api/login' import { getToken, setToken, removeToken } from '@/utils/auth' import defAva from '@/assets/images/profile.jpg' import Cookies from "js-cookie"; import {getUserById} from "@/api/sysUsers"; const useUserStore = defineStore( 'user', { state: () => ({ token: getToken(), id: '', name: '', avatar: '', roles: [], permissions: [] }), actions: { // 登录 login(userInfo) { const username = userInfo.username.trim() const password = userInfo.password const identity = userInfo.identity return new Promise( (resolve, reject) => { login(username, password).then( async res => { setToken(res.result.token) this.token = res.token const user = res.result const avatar = (user.avatar == "" || user.avatar == null) ? defAva : import.meta.env.VITE_APP_BASE_API + user.avatar; if (res.roles && res.roles.length > 0) { // 验证返回的roles是否是一个非空数组 this.roles = res.roles this.permissions = res.permissions } else { this.roles = ['ROLE_DEFAULT'] } this.id = user.userId this.name = user.userName this.avatar = avatar Cookies.set('userInfo',JSON.stringify(user)) Cookies.set('userRole',JSON.stringify(this.roles)) Cookies.set('roleType',user.roleType) Cookies.set('isSupervision',user.companyid) resolve() }).catch(error => { reject(error) }) }) }, // 获取用户信息 getInfo() { return new Promise((resolve, reject) => { getInfo(this.token).then(res => { const user = res.result const avatar = (user.avatar == "" || user.avatar == null) ? defAva : import.meta.env.VITE_APP_BASE_API + user.avatar; if (res.roles && res.roles.length > 0) { // 验证返回的roles是否是一个非空数组 this.roles = res.roles this.permissions = res.permissions } else { this.roles = ['ROLE_DEFAULT'] } this.id = user.userId this.name = user.userName this.avatar = avatar Cookies.set('userInfo',JSON.stringify(user)) Cookies.set('userRole',JSON.stringify(this.roles)) 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) }) }) } } }) export default useUserStore