12345678910111213141516171819202122232425262728293031323334353637383940 |
- /**
- * 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)
- }
|