import config from '@/config' import storage from '@/utils/storage' import constant from '@/utils/constant' import { login, logout, getInfo } from '@/api/login' import { getToken, setToken, removeToken } from '@/utils/auth' import Cookies from "js-cookie"; const baseUrl = config.baseUrl const user = { state: { token: getToken(), name: storage.get(constant.name), avatar: storage.get(constant.avatar), roles: storage.get(constant.roles) }, mutations: { SET_TOKEN: (state, token) => { state.token = token }, SET_NAME: (state, name) => { state.name = name storage.set(constant.name, name) }, 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_ACCOUNT_ID: (state, id) => { state.custId = id } }, actions: { // 登录 Login({ commit }, userInfo) { const formData = { username: userInfo.username.trim(), password: userInfo.encryptPassword, // loginType: 'USERNAME_PASSWORD', loginType: 'CUST_PHONE_PASSWORD',//CUST_PHONE_PASSWORD sourceType: 7, // code: userInfo.code, // uuid: userInfo.uuid } return new Promise((resolve, reject) => { console.log('🚀 ~ login ~ formData11:', formData) login(formData).then(res => { console.log('🚀 ~ login ~ res:', res) setToken(res.data.token) uni.setStorageSync('custId', res.data.custId) uni.setStorageSync('token', res.data.token) uni.setStorageSync('custName', res.data.sysUser.custName) uni.setStorageSync('mobile', res.data.sysUser.phonenumber) uni.setStorageSync('pwd', userInfo.encryptPassword) uni.setStorageSync('username', res.data.sysUser.phonenumber) // Cookies.set('custId', res.data.custId,{expires:90}) Cookies.set('token', res.data.token,{expires:90}) // Cookies.set('custName', res.data.sysUser.custName,{expires:90}) // Cookies.set('mobile', res.data.sysUser.phonenumber,{expires:90}) // Cookies.set('pwd', userInfo.encryptPassword,{expires:90}) // Cookies.set('username', res.data.sysUser.phonenumber,{expires:90}) 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 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_NAME', username) commit('SET_AVATAR', avatar) 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); }); // commit('SET_TOKEN', '') // commit('SET_ROLES', []) // commit('SET_PERMISSIONS', []) // removeToken() // storage.clean() // resolve() }) } } } export default user