|
|
import Vue from 'vue'
|
|
|
import router from '@/router'
|
|
|
import store from '@/store'
|
|
|
|
|
|
/**
|
|
|
* 获取UUID
|
|
|
* 生成一个标准的UUID(例如:xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx)
|
|
|
* 使用随机数和指定格式的规则生成UUID
|
|
|
*/
|
|
|
export function getUUID() {
|
|
|
return 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, c => {
|
|
|
return (c === 'x' ? (Math.random() * 16 | 0) : ('r&0x3' | '0x8')).toString(16)
|
|
|
})
|
|
|
}
|
|
|
|
|
|
/**
|
|
|
* 检查是否有某个权限
|
|
|
* @param {*} key 权限的标识符
|
|
|
* @returns {boolean} 如果权限列表中包含该权限返回true,否则返回false
|
|
|
*/
|
|
|
export function isAuth(key) {
|
|
|
// 从 sessionStorage 中获取权限列表,并转换为数组,如果没有权限列表,默认返回空数组
|
|
|
return JSON.parse(sessionStorage.getItem('permissions') || '[]').indexOf(key) !== -1 || false
|
|
|
}
|
|
|
|
|
|
/**
|
|
|
* 将平面数据转换为树形数据
|
|
|
* @param {*} data 原始平面数据
|
|
|
* @param {*} id 唯一标识符字段,默认为'id'
|
|
|
* @param {*} pid 父级标识符字段,默认为'parentId'
|
|
|
* @returns {Array} 转换后的树形数据
|
|
|
*/
|
|
|
export function treeDataTranslate(data, id = 'id', pid = 'parentId') {
|
|
|
var res = [] // 存储最终的树形结构
|
|
|
var temp = {} // 临时存储每个节点,以便快速查找父节点
|
|
|
|
|
|
// 将数据转换为临时对象,key为节点的id,值为节点本身
|
|
|
for (var i = 0; i < data.length; i++) {
|
|
|
temp[data[i][id]] = data[i]
|
|
|
}
|
|
|
|
|
|
// 遍历数据,根据pid将节点组织成树形结构
|
|
|
for (var k = 0; k < data.length; k++) {
|
|
|
// 如果节点的父节点存在,并且当前节点的id不等于父节点的id
|
|
|
if (temp[data[k][pid]] && data[k][id] !== data[k][pid]) {
|
|
|
// 如果父节点没有'children'属性,则初始化为数组
|
|
|
if (!temp[data[k][pid]]['children']) {
|
|
|
temp[data[k][pid]]['children'] = []
|
|
|
}
|
|
|
// 如果父节点没有'_level'属性,则设置为1
|
|
|
if (!temp[data[k][pid]]['_level']) {
|
|
|
temp[data[k][pid]]['_level'] = 1
|
|
|
}
|
|
|
// 当前节点的级别为父节点的级别+1
|
|
|
data[k]['_level'] = temp[data[k][pid]]._level + 1
|
|
|
// 将当前节点推送到父节点的children数组中
|
|
|
temp[data[k][pid]]['children'].push(data[k])
|
|
|
} else {
|
|
|
// 如果当前节点是根节点,直接推送到结果数组中
|
|
|
res.push(data[k])
|
|
|
}
|
|
|
}
|
|
|
|
|
|
return res // 返回转换后的树形数据
|
|
|
}
|
|
|
|
|
|
/**
|
|
|
* 清除登录信息
|
|
|
* 用于用户退出时,清理本地存储的登录信息
|
|
|
*/
|
|
|
export function clearLoginInfo() {
|
|
|
// 删除cookie中的'token'
|
|
|
Vue.cookie.delete('token')
|
|
|
// 目前注释掉了重置store的操作,若需要可以解除注释
|
|
|
// store.commit('resetStore')
|
|
|
// 重置动态菜单路由标志
|
|
|
router.options.isAddDynamicMenuRoutes = false
|
|
|
}
|