/store/index.js
import Vue from 'vue'
import Vuex from 'vuex'
import user from './modules/user'
import getters from './getters'
Vue.use(Vuex)
const store = new Vuex.Store({
modules: {
user
},
getters
})
export default store
/store/getters.js
const getters = {
userInfo: state => state.user.userInfo,
keyCollapse: (state, getters) => getters.screen > 1 ? getters.isCollapse : false,
access_token: state => state.user.access_token,
refresh_token: state => state.user.refresh_token,
expires_in: state => state.user.expires_in,
roles: state => state.user.roles,
permissions: state => state.user.permissions,
menu: state => state.user.menu,
schedule: state => state.user.schedule,
menuAll: state => state.user.menuAll
}
export default getters
/store/modules/user.js
import {getStore, setStore} from '@/util/store'
import {isURL, validatenull} from '@/util/validate'
import {getUserInfo, loginByUsername, logout, refreshToken} from '@/api/login'
import {deepClone, encryption} from '@/util/util'
import webiste from '@/const/website'
import {getMenu,getSchedule} from '@/api/admin/menu'
function addPath(ele, first) {
const menu = webiste.menu
const propsConfig = menu.props
const propsDefault = {
label: propsConfig.label || 'name',
path: propsConfig.path || 'path',
icon: propsConfig.icon || 'icon',
children: propsConfig.children || 'children'
}
const icon = ele[propsDefault.icon]
ele[propsDefault.icon] = validatenull(icon) ? menu.iconDefault : icon
const isChild = ele[propsDefault.children] && ele[propsDefault.children].length !== 0
if (!isChild) ele[propsDefault.children] = []
if (!isChild && first && !isURL(ele[propsDefault.path])) {
ele[propsDefault.path] = ele[propsDefault.path] + '/index'
} else {
ele[propsDefault.children].forEach(child => {
addPath(child)
})
}
}
const user = {
state: {
userInfo: {},
permissions: {},
roles: [],
schedule:getStore({
name: 'schedule'
}) || [],
menu: getStore({
name: 'menu'
}) || [],
menuAll: [],
expires_in: getStore({
name: 'expires_in'
}) || '',
access_token: getStore({
name: 'access_token'
}) || '',
refresh_token: getStore({
name: 'refresh_token'
}) || ''
},
actions: {
// 根据用户名登录
LoginByUsername({commit}, userInfo) {
const user = encryption({
data: userInfo,
key: 'thanks,pig4cloud',
param: ['password']
})
return new Promise((resolve, reject) => {
loginByUsername(user.username, user.password, user.code, user.randomStr).then(response => {
const data = response.data.data
commit('SET_ACCESS_TOKEN', data.access_token)
commit('SET_REFRESH_TOKEN', data.refresh_token)
commit('SET_EXPIRES_IN', data.expires_in)
commit('CLEAR_LOCK')
resolve()
}).catch(error => {
reject(error)
})
})
},
GetUserInfo({commit}) {
return new Promise((resolve, reject) => {
getUserInfo().then((res) => {
const data = res.data.data || {}
commit('SET_USER_INFO', {username: data.username, phone: data.phone})
commit('SET_ROLES', data.roles || [])
commit('SET_PERMISSIONS', data.permissions || [])
resolve(data)
}).catch((err) => {
reject()
})
})
},
// 刷新token
RefreshToken({commit, state}) {
return new Promise((resolve, reject) => {
refreshToken(state.refresh_token).then(response => {
const data = response.data
commit('SET_ACCESS_TOKEN', data.access_token)
commit('SET_REFRESH_TOKEN', data.refresh_token)
commit('SET_EXPIRES_IN', data.expires_in)
commit('CLEAR_LOCK')
resolve()
}).catch(error => {
reject(error)
})
})
},
// 登出
LogOut({commit}) {
return new Promise((resolve, reject) => {
logout().then(() => {
commit('SET_MENU', [])
commit('SET_PERMISSIONS', [])
commit('SET_USER_INFO', {})
commit('SET_ACCESS_TOKEN', '')
commit('SET_REFRESH_TOKEN', '')
commit('SET_EXPIRES_IN', '')
commit('SET_ROLES', [])
commit('DEL_ALL_TAG')
commit('CLEAR_LOCK')
resolve()
}).catch(error => {
reject(error)
})
})
},
// 注销session
FedLogOut({commit}) {
return new Promise(resolve => {
commit('SET_MENU', [])
commit('SET_PERMISSIONS', [])
commit('SET_USER_INFO', {})
commit('SET_ACCESS_TOKEN', '')
commit('SET_REFRESH_TOKEN', '')
commit('SET_ROLES', [])
commit('DEL_ALL_TAG')
commit('CLEAR_LOCK')
resolve()
})
},
// 获取系统菜单
GetMenu({commit}, obj) {
return new Promise(resolve => {
getMenu(obj.id).then((res) => {
const data = res.data.data
//
let menu = deepClone(data)
menu.forEach(ele => {
addPath(ele)
})
let type = obj.type
commit('SET_MENU', {type, menu})
resolve(menu)
})
})
},
// 获取待办事项
GetSchedule({commit}, obj) {
return new Promise(resolve => {
getSchedule(obj.id).then((res) => {
const data = res.data.data
console.log(data)
//
let schedule = deepClone(data)
// schedule.forEach(ele => {
// addPath(ele)
// })
let type = obj.type
commit('SET_SCHEDULE', {type, schedule})
resolve(schedule)
})
})
}
},
mutations: {
SET_ACCESS_TOKEN: (state, access_token) => {
state.access_token = access_token
setStore({
name: 'access_token',
content: state.access_token,
type: 'session'
})
},
SET_EXPIRES_IN: (state, expires_in) => {
state.expires_in = expires_in
setStore({
name: 'expires_in',
content: state.expires_in,
type: 'session'
})
},
SET_REFRESH_TOKEN: (state, rfToken) => {
state.refresh_token = rfToken
setStore({
name: 'refresh_token',
content: state.refresh_token,
type: 'session'
})
},
SET_USER_INFO: (state, userInfo) => {
state.userInfo = userInfo
},
SET_SCHEDULE: (state, params = {}) => {
let {schedule, type} = params;
if (type !== false) state.schedule = schedule
setStore({
name: 'schedule',
content: schedule,
type: 'session'
})
},
SET_MENU: (state, params = {}) => {
let {menu, type} = params;
if (type !== false) state.menu = menu
setStore({
name: 'menu',
content: menu,
type: 'session'
})
},
SET_MENU_ALL: (state, menuAll) => {
state.menuAll = menuAll
},
SET_ROLES: (state, roles) => {
state.roles = roles
},
SET_PERMISSIONS: (state, permissions) => {
const list = {}
for (let i = 0; i < permissions.length; i++) {
list[permissions[i]] = true
}
state.permissions = list
}
}
}
export default user
组件中使用
import { mapGetters } from "vuex";
created() {
this.xxxx= this.permissions["xxxx"];
},
computed: {
...mapGetters(["permissions"]),
},