Some checks failed
CI / Test (ubuntu-latest) (push) Has been cancelled
CI / Test (windows-latest) (push) Has been cancelled
CI / Lint (ubuntu-latest) (push) Has been cancelled
CI / Lint (windows-latest) (push) Has been cancelled
CI / Check (ubuntu-latest) (push) Has been cancelled
CI / Check (windows-latest) (push) Has been cancelled
CodeQL / Analyze (javascript-typescript) (push) Has been cancelled
Deploy Website on push / Deploy Push Playground Ftp (push) Has been cancelled
Deploy Website on push / Deploy Push Docs Ftp (push) Has been cancelled
Deploy Website on push / Deploy Push Antd Ftp (push) Has been cancelled
Deploy Website on push / Deploy Push Element Ftp (push) Has been cancelled
Deploy Website on push / Deploy Push Naive Ftp (push) Has been cancelled
Release Drafter / update_release_draft (push) Has been cancelled
CI / CI OK (push) Has been cancelled
Deploy Website on push / Rerun on failure (push) Has been cancelled
Lock Threads / action (push) Has been cancelled
Issue Close Require / close-issues (push) Has been cancelled
Close stale issues / stale (push) Has been cancelled
43 lines
1.0 KiB
TypeScript
43 lines
1.0 KiB
TypeScript
/**
|
|
* Global authority directive
|
|
* Used for fine-grained control of component permissions
|
|
* @Example v-access:role="[ROLE_NAME]" or v-access:role="ROLE_NAME"
|
|
* @Example v-access:code="[ROLE_CODE]" or v-access:code="ROLE_CODE"
|
|
*/
|
|
import type { App, Directive, DirectiveBinding } from 'vue';
|
|
|
|
import { useAccess } from './use-access';
|
|
|
|
function isAccessible(
|
|
el: Element,
|
|
binding: DirectiveBinding<string | string[]>,
|
|
) {
|
|
const { accessMode, hasAccessByCodes, hasAccessByRoles } = useAccess();
|
|
|
|
const value = binding.value;
|
|
|
|
if (!value) return;
|
|
const authMethod =
|
|
accessMode.value === 'frontend' && binding.arg === 'role'
|
|
? hasAccessByRoles
|
|
: hasAccessByCodes;
|
|
|
|
const values = Array.isArray(value) ? value : [value];
|
|
|
|
if (!authMethod(values)) {
|
|
el?.remove();
|
|
}
|
|
}
|
|
|
|
const mounted = (el: Element, binding: DirectiveBinding<string | string[]>) => {
|
|
isAccessible(el, binding);
|
|
};
|
|
|
|
const authDirective: Directive = {
|
|
mounted,
|
|
};
|
|
|
|
export function registerAccessDirective(app: App) {
|
|
app.directive('access', authDirective);
|
|
}
|