|
|
import cookie from 'vue-cookies'
|
|
|
import router from '@/router'
|
|
|
|
|
|
/**
|
|
|
* 获取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
|
|
|
*/
|
|
|
export function isAuth (key) {
|
|
|
const authorities = JSON.parse(sessionStorage.getItem('Authorities') || '[]')
|
|
|
if (authorities.length) {
|
|
|
for (const i in authorities) {
|
|
|
const element = authorities[i]
|
|
|
if (element === key) {
|
|
|
return true
|
|
|
}
|
|
|
}
|
|
|
}
|
|
|
return false
|
|
|
}
|
|
|
|
|
|
/**
|
|
|
* 清除登录信息
|
|
|
*/
|
|
|
export function clearLoginInfo () {
|
|
|
cookie.remove('Authorization')
|
|
|
router.options.isAddDynamicMenuRoutes = false
|
|
|
}
|
|
|
|
|
|
/**
|
|
|
* 树形数据转换
|
|
|
* @param {*} data
|
|
|
* @param {*} id
|
|
|
* @param {*} pid
|
|
|
*/
|
|
|
export function treeDataTranslate (data, id = 'id', pid = 'parentId') {
|
|
|
const res = []
|
|
|
const temp = {}
|
|
|
for (let i = 0; i < data.length; i++) {
|
|
|
temp[data[i][id]] = data[i]
|
|
|
}
|
|
|
for (let k = 0; k < data.length; k++) {
|
|
|
if (temp[data[k][pid]] && data[k][id] !== data[k][pid]) {
|
|
|
if (!temp[data[k][pid]].children) {
|
|
|
temp[data[k][pid]].children = []
|
|
|
}
|
|
|
if (!temp[data[k][pid]]._level) {
|
|
|
temp[data[k][pid]]._level = 1
|
|
|
}
|
|
|
data[k]._level = temp[data[k][pid]]._level + 1
|
|
|
temp[data[k][pid]].children.push(data[k])
|
|
|
} else {
|
|
|
res.push(data[k])
|
|
|
}
|
|
|
}
|
|
|
return res
|
|
|
}
|
|
|
|
|
|
function idListFromTree (data, val, res = [], id = 'id', children = 'children') {
|
|
|
for (let i = 0; i < data.length; i++) {
|
|
|
const element = data[i]
|
|
|
if (element[children]) {
|
|
|
if (idListFromTree(element[children], val, res, id, children)) {
|
|
|
res.push(element[id])
|
|
|
return true
|
|
|
}
|
|
|
}
|
|
|
if (element[id] === val) {
|
|
|
res.push(element[id])
|
|
|
return true
|
|
|
}
|
|
|
}
|
|
|
}
|
|
|
/**
|
|
|
* 将数组中的parentId列表取出,倒序排列
|
|
|
*/
|
|
|
// eslint-disable-next-line no-unused-vars
|
|
|
export function idList (data, val, id = 'id', children = 'children') {
|
|
|
const res = []
|
|
|
idListFromTree(data, val, res, id)
|
|
|
return res
|
|
|
}
|