index.js 1.8 KB

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