CEES-manage/src/views/system/role/components/RolePermissionDrawer.vue

232 lines
7.3 KiB
Vue
Raw Normal View History

2022-03-10 09:47:29 +08:00
<template>
<BasicDrawer v-bind="$attrs" @register="registerDrawer" width="650px" destroyOnClose showFooter>
<template #title>
角色权限配置
<a-dropdown>
<Icon icon="ant-design:more-outlined" class="more-icon" />
<template #overlay>
<a-menu @click="treeMenuClick">
<a-menu-item key="checkAll">选择全部</a-menu-item>
<a-menu-item key="cancelCheck">取消选择</a-menu-item>
<div class="line"></div>
<a-menu-item key="openAll">展开全部</a-menu-item>
<a-menu-item key="closeAll">折叠全部</a-menu-item>
<div class="line"></div>
<a-menu-item key="relation">层级关联</a-menu-item>
<a-menu-item key="standAlone">层级独立</a-menu-item>
</a-menu>
</template>
</a-dropdown>
</template>
2022-03-10 09:47:29 +08:00
<BasicTree
ref="treeRef"
checkable
:treeData="treeData"
:checkedKeys="checkedKeys"
:expandedKeys="expandedKeys"
2022-03-10 09:47:29 +08:00
:selectedKeys="selectedKeys"
:checkStrictly="checkStrictly"
2022-03-10 09:47:29 +08:00
:clickRowToExpand="false"
2024-01-07 17:11:30 +08:00
title="所拥有的的权限"
2022-03-10 09:47:29 +08:00
@check="onCheck"
2022-06-10 10:44:44 +08:00
@select="onTreeNodeSelect"
>
<template #title="{ slotTitle, ruleFlag }">
2022-03-10 09:47:29 +08:00
{{ slotTitle }}
2022-06-10 10:44:44 +08:00
<Icon v-if="ruleFlag" icon="ant-design:align-left-outlined" style="margin-left: 5px; color: red"></Icon>
2022-03-10 09:47:29 +08:00
</template>
</BasicTree>
<!--右下角按钮-->
<template #footer>
2024-03-06 16:33:03 +08:00
<!-- <PopConfirmButton title="确定放弃编辑?" @confirm="closeDrawer" okText="确定" cancelText="取消"></PopConfirmButton> -->
<a-button @click="closeDrawer">取消</a-button>
2022-03-10 09:47:29 +08:00
<a-button @click="handleSubmit(false)" type="primary" :loading="loading" ghost style="margin-right: 0.8rem">仅保存</a-button>
<a-button @click="handleSubmit(true)" type="primary" :loading="loading">保存并关闭</a-button>
</template>
2022-06-10 10:44:44 +08:00
<RoleDataRuleDrawer @register="registerDrawer1" />
2022-03-10 09:47:29 +08:00
</BasicDrawer>
</template>
<script lang="ts" setup>
2022-06-10 10:44:44 +08:00
import { ref, computed, unref, onMounted } from 'vue';
import { BasicDrawer, useDrawer, useDrawerInner } from '/src/components/Drawer';
import { BasicTree, TreeItem } from '/src/components/Tree';
import { PopConfirmButton } from '/@/components/Button';
2022-03-10 09:47:29 +08:00
import RoleDataRuleDrawer from './RoleDataRuleDrawer.vue';
2022-06-10 10:44:44 +08:00
import { queryTreeListForRole, queryRolePermission, saveRolePermission } from '../role.api';
2024-03-06 16:33:03 +08:00
import { useI18n } from "/@/hooks/web/useI18n";
2022-03-10 09:47:29 +08:00
const emit = defineEmits(['register']);
//树的信息
const treeData = ref<TreeItem[]>([]);
//树的全部节点信息
const allTreeKeys = ref([]);
//树的选择节点信息
const checkedKeys = ref([]);
const defaultCheckedKeys = ref([]);
//树的选中的节点信息
const selectedKeys = ref([]);
const roleId = ref('');
//树的实例
const treeRef = ref(null);
const loading = ref(false);
//展开折叠的key
const expandedKeys = ref<any>([]);
//父子节点选中状态是否关联
const checkStrictly = ref<boolean>(true);
2022-06-10 10:44:44 +08:00
const [registerDrawer1, { openDrawer: openDataRuleDrawer }] = useDrawer();
const [registerDrawer, { setDrawerProps, closeDrawer }] = useDrawerInner(async (data) => {
2022-03-10 09:47:29 +08:00
await reset();
2022-06-10 10:44:44 +08:00
setDrawerProps({ confirmLoading: false, loading: true });
2022-03-10 09:47:29 +08:00
roleId.value = data.roleId;
//初始化数据
const roleResult = await queryTreeListForRole();
2024-03-06 16:33:03 +08:00
// update-begin--author:liaozhiyang---date:20240228---for【QQYUN-8355】角色权限配置的菜单翻译
treeData.value = translateTitle(roleResult.treeList);
// update-end--author:liaozhiyang---date:20240228---for【QQYUN-8355】角色权限配置的菜单翻译
2022-03-10 09:47:29 +08:00
allTreeKeys.value = roleResult.ids;
expandedKeys.value = roleResult.ids;
2022-06-10 10:44:44 +08:00
//初始化角色菜单数据
const permResult = await queryRolePermission({ roleId: unref(roleId) });
2022-03-10 09:47:29 +08:00
checkedKeys.value = permResult;
defaultCheckedKeys.value = permResult;
2022-06-10 10:44:44 +08:00
setDrawerProps({ loading: false });
2022-03-10 09:47:29 +08:00
});
2024-03-06 16:33:03 +08:00
/**
* 2024-02-28
* liaozhiyang
* 翻译菜单名称
*/
function translateTitle(data) {
if (data?.length) {
data.forEach((item) => {
if (item.slotTitle) {
const { t } = useI18n();
if (item.slotTitle.includes("t('") && t) {
item.slotTitle = new Function('t', `return ${item.slotTitle}`)(t);
}
}
if (item.children?.length) {
translateTitle(item.children);
}
});
}
return data;
}
2022-03-10 09:47:29 +08:00
/**
* 点击选中
*/
function onCheck(o) {
2022-06-10 10:44:44 +08:00
checkedKeys.value = o.checked ? o.checked : o;
2022-03-10 09:47:29 +08:00
}
/**
* 选中节点打开数据权限抽屉
*/
function onTreeNodeSelect(key) {
2022-06-10 10:44:44 +08:00
if (key && key.length > 0) {
selectedKeys.value = key;
2022-03-10 09:47:29 +08:00
}
2022-06-10 10:44:44 +08:00
openDataRuleDrawer(true, { functionId: unref(selectedKeys)[0], roleId: unref(roleId) });
2022-03-10 09:47:29 +08:00
}
/**
* 数据重置
*/
function reset() {
2022-06-10 10:44:44 +08:00
treeData.value = [];
allTreeKeys.value = [];
checkedKeys.value = [];
defaultCheckedKeys.value = [];
selectedKeys.value = [];
roleId.value = '';
2022-03-10 09:47:29 +08:00
}
/**
* 获取tree实例
*/
function getTree() {
const tree = unref(treeRef);
if (!tree) {
throw new Error('tree is null!');
}
return tree;
}
/**
* 提交
*/
async function handleSubmit(exit) {
let params = {
roleId: unref(roleId),
2022-06-10 10:44:44 +08:00
permissionIds: unref(getTree().getCheckedKeys()).join(','),
lastpermissionIds: unref(defaultCheckedKeys).join(','),
2022-03-10 09:47:29 +08:00
};
//update-begin-author:taoyan date:2023-2-11 for: issues/352 VUE角色授权重复保存
if(loading.value===false){
await doSave(params)
}else{
console.log('请等待上次执行完毕!');
}
if(exit){
// 如果关闭
closeDrawer();
}else{
// 没有关闭需要重新获取选中数据
const permResult = await queryRolePermission({ roleId: unref(roleId) });
defaultCheckedKeys.value = permResult;
}
}
// VUE角色授权重复保存 #352
async function doSave(params) {
2022-03-10 09:47:29 +08:00
loading.value = true;
await saveRolePermission(params);
setTimeout(()=>{
loading.value = false;
}, 500)
}
//update-end-author:taoyan date:2023-2-11 for: issues/352 VUE角色授权重复保存
/**
* 树菜单选择
* @param key
*/
function treeMenuClick({ key }) {
if (key === 'checkAll') {
checkedKeys.value = allTreeKeys.value;
} else if (key === 'cancelCheck') {
checkedKeys.value = [];
} else if (key === 'openAll') {
expandedKeys.value = allTreeKeys.value;
} else if (key === 'closeAll') {
expandedKeys.value = [];
} else if (key === 'relation') {
checkStrictly.value = false;
} else {
checkStrictly.value = true;
}
2022-03-10 09:47:29 +08:00
}
</script>
<style lang="less" scoped>
/** 固定操作按钮 */
.jeecg-basic-tree {
position: absolute;
width: 618px;
}
//update-begin---author:wangshuai ---date:20230202 for抽屉弹窗标题图标下拉样式------------
.line {
height: 1px;
width: 100%;
border-bottom: 1px solid #f0f0f0;
}
.more-icon {
font-size: 20px !important;
color: black;
display: inline-flex;
float: right;
margin-right: 2px;
cursor: pointer;
}
:deep(.jeecg-tree-header){
border-bottom: none;
}
//update-end---author:wangshuai ---date:20230202 for抽屉弹窗标题图标下拉样式------------
</style>