admin-vben/packages/effects/access/src/directive.ts

39 lines
874 B
TypeScript
Raw Normal View History

2024-07-18 13:31:34 +00:00
/**
* Global authority directive
* Used for fine-grained control of component permissions
* @Example v-auth="RoleEnum.TEST"
*/
import type { App, Directive, DirectiveBinding } from 'vue';
import { useAccess } from './use-access';
function isAccessible(el: Element, binding: any) {
const { accessMode, hasAccessByCodes, hasAccessByRoles } = useAccess();
const value = binding.value;
if (!value) {
return;
}
const authMethod =
accessMode.value === 'frontend' && binding.arg === 'role'
? hasAccessByRoles
: hasAccessByCodes;
2024-07-18 13:31:34 +00:00
if (!authMethod(value)) {
el?.remove();
}
}
const mounted = (el: Element, binding: DirectiveBinding<string | string[]>) => {
isAccessible(el, binding);
};
const authDirective: Directive = {
mounted,
};
2024-07-30 13:10:28 +00:00
export function registerAccessDirective(app: App) {
2024-07-18 13:31:34 +00:00
app.directive('access', authDirective);
}