review: 重构代码.

This commit is contained in:
lijiahang
2023-11-09 16:10:58 +08:00
parent 0ee6ebe207
commit 6fc6c61d48
22 changed files with 366 additions and 50 deletions

View File

@@ -4,7 +4,7 @@
title-align="start"
title="分配菜单"
width="80%"
:top="80"
:top="40"
:body-style="{padding: '16px 16px 0 16px', 'margin-bottom': '16px'}"
:align-center="false"
:draggable="true"
@@ -15,11 +15,29 @@
:on-before-ok="handlerOk"
@close="handleClose">
<div class="role-menu-wrapper">
<a-alert class="mb8 usn">
<a-alert class="usn mb8">
<span>{{ roleRecord.name }} {{ roleRecord.code }}</span>
<span class="mx8">-</span>
<span>菜单分配后需要用户手动刷新页面才会生效</span>
</a-alert>
<div class="usn mb8">
<a-space>
<template v-for="opt of quickGrantMenuOperator" :key="opt.name">
<a-button size="mini" type="text" @click="() => { table.checked(opt.rule) }">
{{ '全选' + opt.name }}
</a-button>
</template>
</a-space>
</div>
<div class="usn mb8">
<a-space>
<template v-for="opt of quickGrantMenuOperator" :key="opt.name">
<a-button size="mini" type="text" @click="() => { table.unchecked(opt.rule) }">
{{ '反选' + opt.name }}
</a-button>
</template>
</a-space>
</div>
<!-- 菜单 -->
<menu-grant-table ref="table" />
</div>
@@ -42,6 +60,7 @@
import { useCacheStore } from '@/store';
import { getMenuList } from '@/api/system/menu';
import MenuGrantTable from '@/components/system/menu/grant/menu-grant-table.vue';
import { quickGrantMenuOperator } from '../types/const';
const { visible, setVisible } = useVisible();
const { loading, setLoading } = useLoading();
@@ -113,7 +132,7 @@
<style lang="less" scoped>
.role-menu-wrapper {
width: 100%;
max-height: calc(100vh - 285px);
max-height: calc(100vh - 230px);
}
</style>

View File

@@ -6,6 +6,44 @@ export const RoleStatus = {
ENABLED: 1,
};
// 快速分配菜单操作
export const quickGrantMenuOperator = [
{
name: '',
rule: undefined
}, {
name: '查询',
rule: (perm: string) => {
return perm.includes('query') || perm.includes('view');
}
}, {
name: '新增',
rule: (perm: string) => {
return perm.includes('add') || perm.includes('create');
}
}, {
name: '修改',
rule: (perm: string) => {
return perm.includes('update') || perm.includes('modify');
}
}, {
name: '删除',
rule: (perm: string) => {
return perm.includes('delete') || perm.includes('remove');
}
}, {
name: '导入',
rule: (perm: string) => {
return perm.includes('import');
}
}, {
name: '导出',
rule: (perm: string) => {
return perm.includes('export');
}
},
];
// 角色状态 字典项
export const roleStatusKey = 'systemRoleStatus';