first commit

This commit is contained in:
zc
2026-02-26 17:31:18 +08:00
commit f1b87df6ca
803 changed files with 297148 additions and 0 deletions

10
src/directives/index.ts Normal file
View File

@@ -0,0 +1,10 @@
import type { App } from 'vue'
import hasPerm from './permission/hasPerm'
import hasRole from './permission/hasRole'
export default {
install(Vue: App) {
Vue.directive('permission', hasPerm)
Vue.directive('role', hasRole)
},
}

View File

@@ -0,0 +1,35 @@
import type { Directive, DirectiveBinding } from 'vue'
import { useUserStore } from '@/stores'
/**
* @desc v-permission 操作权限处理
* @desc 使用 v-permission="['system:user:add']"
*/
function checkPermission(el: HTMLElement, binding: DirectiveBinding) {
const userStore = useUserStore()
const { value } = binding
const all_permission = '*:*:*'
if (value && Array.isArray(value) && value.length) {
const permissionValues: string[] = value
const hasPermission = userStore.permissions.some((perm) => {
return all_permission === perm || permissionValues.includes(perm)
})
if (!hasPermission) {
el.parentNode && el.parentNode.removeChild(el)
}
} else {
throw new Error(`need permission! Like v-hasPerm="['home:btn:edit','home:btn:delete']"`)
}
}
const directive: Directive = {
mounted(el: HTMLElement, binding: DirectiveBinding) {
checkPermission(el, binding)
},
updated(el: HTMLElement, binding: DirectiveBinding) {
checkPermission(el, binding)
},
}
export default directive

View File

@@ -0,0 +1,34 @@
import type { Directive, DirectiveBinding } from 'vue'
import { useUserStore } from '@/stores'
/**
* @desc v-hasRole 角色权限处理
* @desc 使用 v-hasRole="['admin', 'user]"
*/
function checkRole(el: HTMLElement, binding: DirectiveBinding) {
const userStore = useUserStore()
const { value } = binding
const super_admin = 'role_admin'
if (value && Array.isArray(value) && value.length) {
const roleValues: string[] = value
const hasRole = userStore.roles.some((role) => {
return super_admin === role || roleValues.includes(role)
})
if (!hasRole) {
el.parentNode && el.parentNode.removeChild(el)
}
} else {
throw new Error(`need role! Like v-hasRole="['admin','user']"`)
}
}
const directive: Directive = {
mounted(el: HTMLElement, binding: DirectiveBinding) {
checkRole(el, binding)
},
updated(el: HTMLElement, binding: DirectiveBinding) {
checkRole(el, binding)
},
}
export default directive