Files
nl-acs3.0/nl-vue/src/utils/permission/index.js

41 lines
1.8 KiB
JavaScript
Raw Normal View History

2026-01-06 09:58:29 +08:00
/**
* Copyright [2022] [https://www.xiaonuo.vip]
* Snowy采用APACHE LICENSE 2.0开源协议您在使用过程中需要注意以下几点
* 1.请不要删除和修改根目录下的LICENSE文件
* 2.请不要删除和修改Snowy源码头部的版权声明
* 3.本项目代码可免费商业使用商业使用请保留源码和相关描述文件的项目出处作者声明等
* 4.分发源码时候请注明软件出处 https://www.xiaonuo.vip
* 5.不可二次分发开源参与同类竞品如有想法可联系团队xiaonuobase@qq.com商议合作
* 6.若您的项目无法满足以上几点需要更多功能代码获取Snowy商业授权许可请在官网购买授权地址为 https://www.xiaonuo.vip
*/
import tool from '@/utils/tool'
/**
* 权限判断是否能看到这个按钮同时后端也做了校验前端只是显示与不显示
* @param {string, array} data 按钮的权限点可以是单个字符串也可以是数组
* @param {string} rule or代表或and代表与
* 使用方法
* 例如 buttonCodeList 的数据为 ['button1', 'button2', 'button3']
* 想要判断 button1 的权限可以写成hasPerm('button1')
* 想要判断 button1 button2 的权限可以写成hasPerm(['button1', 'button2' ])
* 想要判断 button1 button2 的权限可以写成hasPerm(['button1', 'button2' ], 'and')
*/
export function hasPerm(data, rule = 'or') {
if (!data) {
return false
}
const userInfo = tool.data.get('USER_INFO')
if (!userInfo) {
return false
}
const { buttonCodeList } = userInfo
if (!buttonCodeList) {
return false
}
if (Array.isArray(data)) {
const fn = rule === 'or' ? 'some' : 'every'
return data[fn]((item) => buttonCodeList.includes(item))
}
return buttonCodeList.includes(data)
}