mirror of
https://github.com/pure-admin/vue-pure-admin.git
synced 2025-06-08 01:17:23 +08:00
chore: update
This commit is contained in:
parent
12cbae29bb
commit
73b212edc4
@ -125,6 +125,8 @@ menus:
|
|||||||
purePermission: Permission Manage
|
purePermission: Permission Manage
|
||||||
purePermissionPage: Page Permission
|
purePermissionPage: Page Permission
|
||||||
purePermissionButton: Button Permission
|
purePermissionButton: Button Permission
|
||||||
|
purePermissionButtonRouter: Route return button permission
|
||||||
|
purePermissionButtonLogin: Login interface return button permission
|
||||||
pureTabs: Tabs Operate
|
pureTabs: Tabs Operate
|
||||||
pureGuide: Guide
|
pureGuide: Guide
|
||||||
pureAble: Able
|
pureAble: Able
|
||||||
|
@ -125,6 +125,8 @@ menus:
|
|||||||
purePermission: 权限管理
|
purePermission: 权限管理
|
||||||
purePermissionPage: 页面权限
|
purePermissionPage: 页面权限
|
||||||
purePermissionButton: 按钮权限
|
purePermissionButton: 按钮权限
|
||||||
|
purePermissionButtonRouter: 路由返回按钮权限
|
||||||
|
purePermissionButtonLogin: 登录接口返回按钮权限
|
||||||
pureTabs: 标签页操作
|
pureTabs: 标签页操作
|
||||||
pureGuide: 引导页
|
pureGuide: 引导页
|
||||||
pureAble: 功能
|
pureAble: 功能
|
||||||
|
@ -123,17 +123,34 @@ const permissionRouter = {
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
path: "/permission/button/index",
|
path: "/permission/button",
|
||||||
name: "PermissionButton",
|
|
||||||
meta: {
|
meta: {
|
||||||
title: "menus.purePermissionButton",
|
title: "menus.purePermissionButton",
|
||||||
roles: ["admin", "common"],
|
roles: ["admin", "common"]
|
||||||
|
},
|
||||||
|
children: [
|
||||||
|
{
|
||||||
|
path: "/permission/button/router",
|
||||||
|
component: "permission/button/index",
|
||||||
|
name: "PermissionButtonRouter",
|
||||||
|
meta: {
|
||||||
|
title: "menus.purePermissionButtonRouter",
|
||||||
auths: [
|
auths: [
|
||||||
"permission:btn:add",
|
"permission:btn:add",
|
||||||
"permission:btn:edit",
|
"permission:btn:edit",
|
||||||
"permission:btn:delete"
|
"permission:btn:delete"
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
path: "/permission/button/login",
|
||||||
|
component: "permission/button/perms",
|
||||||
|
name: "PermissionButtonLogin",
|
||||||
|
meta: {
|
||||||
|
title: "menus.purePermissionButtonLogin"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
]
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
};
|
};
|
||||||
|
@ -16,11 +16,7 @@ export default defineFakeRoute([
|
|||||||
// 一个用户可能有多个角色
|
// 一个用户可能有多个角色
|
||||||
roles: ["admin"],
|
roles: ["admin"],
|
||||||
// 按钮级别权限
|
// 按钮级别权限
|
||||||
permissions: [
|
permissions: ["*:*:*"],
|
||||||
"permission:btn:add",
|
|
||||||
"permission:btn:edit",
|
|
||||||
"permission:btn:delete"
|
|
||||||
],
|
|
||||||
accessToken: "eyJhbGciOiJIUzUxMiJ9.admin",
|
accessToken: "eyJhbGciOiJIUzUxMiJ9.admin",
|
||||||
refreshToken: "eyJhbGciOiJIUzUxMiJ9.adminRefresh",
|
refreshToken: "eyJhbGciOiJIUzUxMiJ9.adminRefresh",
|
||||||
expires: "2030/10/30 00:00:00"
|
expires: "2030/10/30 00:00:00"
|
||||||
@ -34,7 +30,7 @@ export default defineFakeRoute([
|
|||||||
username: "common",
|
username: "common",
|
||||||
nickname: "小林",
|
nickname: "小林",
|
||||||
roles: ["common"],
|
roles: ["common"],
|
||||||
permissions: [],
|
permissions: ["permission:btn:add", "permission:btn:edit"],
|
||||||
accessToken: "eyJhbGciOiJIUzUxMiJ9.common",
|
accessToken: "eyJhbGciOiJIUzUxMiJ9.common",
|
||||||
refreshToken: "eyJhbGciOiJIUzUxMiJ9.commonRefresh",
|
refreshToken: "eyJhbGciOiJIUzUxMiJ9.commonRefresh",
|
||||||
expires: "2030/10/30 00:00:00"
|
expires: "2030/10/30 00:00:00"
|
||||||
|
128
mock/system.ts
128
mock/system.ts
@ -696,7 +696,7 @@ export default defineFakeRoute([
|
|||||||
menuType: 0,
|
menuType: 0,
|
||||||
title: "menus.purePermissionButton",
|
title: "menus.purePermissionButton",
|
||||||
name: "PermissionButton",
|
name: "PermissionButton",
|
||||||
path: "/permission/button/index",
|
path: "/permission/button",
|
||||||
component: "",
|
component: "",
|
||||||
rank: null,
|
rank: null,
|
||||||
redirect: "",
|
redirect: "",
|
||||||
@ -717,6 +717,30 @@ export default defineFakeRoute([
|
|||||||
{
|
{
|
||||||
parentId: 202,
|
parentId: 202,
|
||||||
id: 203,
|
id: 203,
|
||||||
|
menuType: 0,
|
||||||
|
title: "menus.purePermissionButtonRouter",
|
||||||
|
name: "PermissionButtonRouter",
|
||||||
|
path: "/permission/button/router",
|
||||||
|
component: "permission/button/index",
|
||||||
|
rank: null,
|
||||||
|
redirect: "",
|
||||||
|
icon: "",
|
||||||
|
extraIcon: "",
|
||||||
|
enterTransition: "",
|
||||||
|
leaveTransition: "",
|
||||||
|
activePath: "",
|
||||||
|
auths: "",
|
||||||
|
frameSrc: "",
|
||||||
|
frameLoading: true,
|
||||||
|
keepAlive: false,
|
||||||
|
hiddenTag: false,
|
||||||
|
fixedTag: false,
|
||||||
|
showLink: true,
|
||||||
|
showParent: false
|
||||||
|
},
|
||||||
|
{
|
||||||
|
parentId: 203,
|
||||||
|
id: 210,
|
||||||
menuType: 3,
|
menuType: 3,
|
||||||
title: "添加",
|
title: "添加",
|
||||||
name: "",
|
name: "",
|
||||||
@ -739,8 +763,8 @@ export default defineFakeRoute([
|
|||||||
showParent: false
|
showParent: false
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
parentId: 202,
|
parentId: 203,
|
||||||
id: 204,
|
id: 211,
|
||||||
menuType: 3,
|
menuType: 3,
|
||||||
title: "修改",
|
title: "修改",
|
||||||
name: "",
|
name: "",
|
||||||
@ -762,9 +786,105 @@ export default defineFakeRoute([
|
|||||||
showLink: true,
|
showLink: true,
|
||||||
showParent: false
|
showParent: false
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
parentId: 203,
|
||||||
|
id: 212,
|
||||||
|
menuType: 3,
|
||||||
|
title: "删除",
|
||||||
|
name: "",
|
||||||
|
path: "",
|
||||||
|
component: "",
|
||||||
|
rank: null,
|
||||||
|
redirect: "",
|
||||||
|
icon: "",
|
||||||
|
extraIcon: "",
|
||||||
|
enterTransition: "",
|
||||||
|
leaveTransition: "",
|
||||||
|
activePath: "",
|
||||||
|
auths: "permission:btn:delete",
|
||||||
|
frameSrc: "",
|
||||||
|
frameLoading: true,
|
||||||
|
keepAlive: false,
|
||||||
|
hiddenTag: false,
|
||||||
|
fixedTag: false,
|
||||||
|
showLink: true,
|
||||||
|
showParent: false
|
||||||
|
},
|
||||||
{
|
{
|
||||||
parentId: 202,
|
parentId: 202,
|
||||||
id: 205,
|
id: 204,
|
||||||
|
menuType: 0,
|
||||||
|
title: "menus.purePermissionButtonLogin",
|
||||||
|
name: "PermissionButtonLogin",
|
||||||
|
path: "/permission/button/login",
|
||||||
|
component: "permission/button/perms",
|
||||||
|
rank: null,
|
||||||
|
redirect: "",
|
||||||
|
icon: "",
|
||||||
|
extraIcon: "",
|
||||||
|
enterTransition: "",
|
||||||
|
leaveTransition: "",
|
||||||
|
activePath: "",
|
||||||
|
auths: "",
|
||||||
|
frameSrc: "",
|
||||||
|
frameLoading: true,
|
||||||
|
keepAlive: false,
|
||||||
|
hiddenTag: false,
|
||||||
|
fixedTag: false,
|
||||||
|
showLink: true,
|
||||||
|
showParent: false
|
||||||
|
},
|
||||||
|
{
|
||||||
|
parentId: 204,
|
||||||
|
id: 220,
|
||||||
|
menuType: 3,
|
||||||
|
title: "添加",
|
||||||
|
name: "",
|
||||||
|
path: "",
|
||||||
|
component: "",
|
||||||
|
rank: null,
|
||||||
|
redirect: "",
|
||||||
|
icon: "",
|
||||||
|
extraIcon: "",
|
||||||
|
enterTransition: "",
|
||||||
|
leaveTransition: "",
|
||||||
|
activePath: "",
|
||||||
|
auths: "permission:btn:add",
|
||||||
|
frameSrc: "",
|
||||||
|
frameLoading: true,
|
||||||
|
keepAlive: false,
|
||||||
|
hiddenTag: false,
|
||||||
|
fixedTag: false,
|
||||||
|
showLink: true,
|
||||||
|
showParent: false
|
||||||
|
},
|
||||||
|
{
|
||||||
|
parentId: 204,
|
||||||
|
id: 221,
|
||||||
|
menuType: 3,
|
||||||
|
title: "修改",
|
||||||
|
name: "",
|
||||||
|
path: "",
|
||||||
|
component: "",
|
||||||
|
rank: null,
|
||||||
|
redirect: "",
|
||||||
|
icon: "",
|
||||||
|
extraIcon: "",
|
||||||
|
enterTransition: "",
|
||||||
|
leaveTransition: "",
|
||||||
|
activePath: "",
|
||||||
|
auths: "permission:btn:edit",
|
||||||
|
frameSrc: "",
|
||||||
|
frameLoading: true,
|
||||||
|
keepAlive: false,
|
||||||
|
hiddenTag: false,
|
||||||
|
fixedTag: false,
|
||||||
|
showLink: true,
|
||||||
|
showParent: false
|
||||||
|
},
|
||||||
|
{
|
||||||
|
parentId: 204,
|
||||||
|
id: 222,
|
||||||
menuType: 3,
|
menuType: 3,
|
||||||
title: "删除",
|
title: "删除",
|
||||||
name: "",
|
name: "",
|
||||||
|
@ -85,14 +85,14 @@ export function setToken(data: DataInfo<Date>) {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
if (data.username && data.roles && data.permissions) {
|
if (data.username && data.roles) {
|
||||||
const { username, roles, permissions } = data;
|
const { username, roles } = data;
|
||||||
setUserKey({
|
setUserKey({
|
||||||
avatar: data?.avatar ?? "",
|
avatar: data?.avatar ?? "",
|
||||||
username,
|
username,
|
||||||
nickname: data?.nickname ?? "",
|
nickname: data?.nickname ?? "",
|
||||||
roles,
|
roles,
|
||||||
permissions
|
permissions: data?.permissions ?? []
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
const avatar =
|
const avatar =
|
||||||
@ -130,8 +130,10 @@ export const formatToken = (token: string): string => {
|
|||||||
/** 是否有按钮级别的权限(根据登录接口返回的`permissions`字段进行判断)*/
|
/** 是否有按钮级别的权限(根据登录接口返回的`permissions`字段进行判断)*/
|
||||||
export const hasPerms = (value: string | Array<string>): boolean => {
|
export const hasPerms = (value: string | Array<string>): boolean => {
|
||||||
if (!value) return false;
|
if (!value) return false;
|
||||||
|
const allPerms = "*:*:*";
|
||||||
const { permissions } = useUserStoreHook();
|
const { permissions } = useUserStoreHook();
|
||||||
if (!permissions) return false;
|
if (!permissions) return false;
|
||||||
|
if (permissions.length === 1 && permissions[0] === allPerms) return true;
|
||||||
const isAuths = isString(value)
|
const isAuths = isString(value)
|
||||||
? permissions.includes(value)
|
? permissions.includes(value)
|
||||||
: isIncludeAllChildren(value, permissions);
|
: isIncludeAllChildren(value, permissions);
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
import { hasAuth, getAuths } from "@/router/utils";
|
import { hasAuth, getAuths } from "@/router/utils";
|
||||||
|
|
||||||
defineOptions({
|
defineOptions({
|
||||||
name: "PermissionButton"
|
name: "PermissionButtonRouter"
|
||||||
});
|
});
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
|
116
src/views/permission/button/perms.vue
Normal file
116
src/views/permission/button/perms.vue
Normal file
@ -0,0 +1,116 @@
|
|||||||
|
<script setup lang="ts">
|
||||||
|
import { hasPerms } from "@/utils/auth";
|
||||||
|
import { useUserStoreHook } from "@/store/modules/user";
|
||||||
|
|
||||||
|
const { permissions } = useUserStoreHook();
|
||||||
|
|
||||||
|
defineOptions({
|
||||||
|
name: "PermissionButtonLogin"
|
||||||
|
});
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<template>
|
||||||
|
<div>
|
||||||
|
<p class="mb-2">当前拥有的code列表:{{ permissions }}</p>
|
||||||
|
<p v-show="permissions?.[0] === '*:*:*'" class="mb-2">
|
||||||
|
*:*:* 代表拥有全部按钮级别权限
|
||||||
|
</p>
|
||||||
|
|
||||||
|
<el-card shadow="never" class="mb-2">
|
||||||
|
<template #header>
|
||||||
|
<div class="card-header">组件方式判断权限</div>
|
||||||
|
<el-link
|
||||||
|
class="mt-2"
|
||||||
|
href="https://github.com/pure-admin/vue-pure-admin/blob/main/src/views/permission/button/perms.vue"
|
||||||
|
target="_blank"
|
||||||
|
>
|
||||||
|
代码位置 src/views/permission/button/perms.vue
|
||||||
|
</el-link>
|
||||||
|
</template>
|
||||||
|
<el-space wrap>
|
||||||
|
<Perms value="permission:btn:add">
|
||||||
|
<el-button plain type="warning">
|
||||||
|
拥有code:'permission:btn:add' 权限可见
|
||||||
|
</el-button>
|
||||||
|
</Perms>
|
||||||
|
<Perms :value="['permission:btn:edit']">
|
||||||
|
<el-button plain type="primary">
|
||||||
|
拥有code:['permission:btn:edit'] 权限可见
|
||||||
|
</el-button>
|
||||||
|
</Perms>
|
||||||
|
<Perms
|
||||||
|
:value="[
|
||||||
|
'permission:btn:add',
|
||||||
|
'permission:btn:edit',
|
||||||
|
'permission:btn:delete'
|
||||||
|
]"
|
||||||
|
>
|
||||||
|
<el-button plain type="danger">
|
||||||
|
拥有code:['permission:btn:add', 'permission:btn:edit',
|
||||||
|
'permission:btn:delete'] 权限可见
|
||||||
|
</el-button>
|
||||||
|
</Perms>
|
||||||
|
</el-space>
|
||||||
|
</el-card>
|
||||||
|
|
||||||
|
<el-card shadow="never" class="mb-2">
|
||||||
|
<template #header>
|
||||||
|
<div class="card-header">函数方式判断权限</div>
|
||||||
|
</template>
|
||||||
|
<el-space wrap>
|
||||||
|
<el-button v-if="hasPerms('permission:btn:add')" plain type="warning">
|
||||||
|
拥有code:'permission:btn:add' 权限可见
|
||||||
|
</el-button>
|
||||||
|
<el-button
|
||||||
|
v-if="hasPerms(['permission:btn:edit'])"
|
||||||
|
plain
|
||||||
|
type="primary"
|
||||||
|
>
|
||||||
|
拥有code:['permission:btn:edit'] 权限可见
|
||||||
|
</el-button>
|
||||||
|
<el-button
|
||||||
|
v-if="
|
||||||
|
hasPerms([
|
||||||
|
'permission:btn:add',
|
||||||
|
'permission:btn:edit',
|
||||||
|
'permission:btn:delete'
|
||||||
|
])
|
||||||
|
"
|
||||||
|
plain
|
||||||
|
type="danger"
|
||||||
|
>
|
||||||
|
拥有code:['permission:btn:add', 'permission:btn:edit',
|
||||||
|
'permission:btn:delete'] 权限可见
|
||||||
|
</el-button>
|
||||||
|
</el-space>
|
||||||
|
</el-card>
|
||||||
|
|
||||||
|
<el-card shadow="never">
|
||||||
|
<template #header>
|
||||||
|
<div class="card-header">
|
||||||
|
指令方式判断权限(该方式不能动态修改权限)
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
<el-space wrap>
|
||||||
|
<el-button v-perms="'permission:btn:add'" plain type="warning">
|
||||||
|
拥有code:'permission:btn:add' 权限可见
|
||||||
|
</el-button>
|
||||||
|
<el-button v-perms="['permission:btn:edit']" plain type="primary">
|
||||||
|
拥有code:['permission:btn:edit'] 权限可见
|
||||||
|
</el-button>
|
||||||
|
<el-button
|
||||||
|
v-perms="[
|
||||||
|
'permission:btn:add',
|
||||||
|
'permission:btn:edit',
|
||||||
|
'permission:btn:delete'
|
||||||
|
]"
|
||||||
|
plain
|
||||||
|
type="danger"
|
||||||
|
>
|
||||||
|
拥有code:['permission:btn:add', 'permission:btn:edit',
|
||||||
|
'permission:btn:delete'] 权限可见
|
||||||
|
</el-button>
|
||||||
|
</el-space>
|
||||||
|
</el-card>
|
||||||
|
</div>
|
||||||
|
</template>
|
Loading…
x
Reference in New Issue
Block a user