2022-10-18 15:07:42 +08:00
|
|
|
import { type Directive } from "vue"
|
2022-04-22 12:47:04 +08:00
|
|
|
import { useUserStoreHook } from "@/store/modules/user"
|
2022-04-21 18:20:39 +08:00
|
|
|
|
|
|
|
/** 权限指令 */
|
|
|
|
export const permission: Directive = {
|
|
|
|
mounted(el, binding) {
|
|
|
|
const { value } = binding
|
2023-05-19 20:02:02 +08:00
|
|
|
const { roles } = useUserStoreHook()
|
|
|
|
if (Array.isArray(value) && value.length > 0) {
|
2022-04-21 18:20:39 +08:00
|
|
|
const permissionRoles = value
|
2023-05-19 20:02:02 +08:00
|
|
|
const hasPermission = roles.some((role) => permissionRoles.includes(role))
|
2022-04-21 18:20:39 +08:00
|
|
|
if (!hasPermission) {
|
2023-05-19 20:02:02 +08:00
|
|
|
// 隐藏
|
|
|
|
// el.style.display = "none"
|
|
|
|
// 销毁
|
|
|
|
el.parentNode?.removeChild(el)
|
2022-04-21 18:20:39 +08:00
|
|
|
}
|
|
|
|
} else {
|
2022-07-01 16:25:51 +08:00
|
|
|
throw new Error(`need roles! Like v-permission="['admin','editor']"`)
|
2022-04-21 18:20:39 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|