admin-vben5/packages/business/access/src/role-authority.vue

30 lines
497 B
Vue
Raw Normal View History

<!--
Access control component for fine-grained access control.
-->
<script lang="ts" setup>
import { useAccess } from './use-access';
interface Props {
/**
* Specified role is visible
* @default []
*/
roles?: string[];
}
defineOptions({
name: 'RoleAuthority',
});
withDefaults(defineProps<Props>(), {
roles: undefined,
});
const { hasAuthByRole } = useAccess();
</script>
<template>
<slot v-if="!roles"></slot>
<slot v-else-if="hasAuthByRole(roles)"></slot>
</template>