access-control.vue 881 B

12345678910111213141516171819202122232425262728293031323334353637383940414243
  1. <!--
  2. Access control component for fine-grained access control.
  3. -->
  4. <script lang="ts" setup>
  5. import { computed } from 'vue';
  6. import { useAccess } from './use-access';
  7. interface Props {
  8. /**
  9. * 通过什么方式来控制组件,如果是 role,则传入角色,如果是 code,则传入权限码
  10. * @default 'role'
  11. */
  12. type?: 'code' | 'role';
  13. /**
  14. * Specified codes is visible
  15. * @default []
  16. */
  17. value?: string[];
  18. }
  19. defineOptions({
  20. name: 'AccessControl',
  21. });
  22. const props = withDefaults(defineProps<Props>(), {
  23. type: 'role',
  24. value: () => [],
  25. });
  26. const { hasAuthByCodes, hasAuthByRoles } = useAccess();
  27. const hasAuth = computed(() => {
  28. const { type, value } = props;
  29. return type === 'role' ? hasAuthByRoles(value) : hasAuthByCodes(value);
  30. });
  31. </script>
  32. <template>
  33. <slot v-if="!value"></slot>
  34. <slot v-else-if="hasAuth"></slot>
  35. </template>