2026-01-04 15:36:11 +08:00
|
|
|
|
<template>
|
2026-01-07 09:22:00 +08:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2026-01-04 15:36:11 +08:00
|
|
|
|
<BasicDrawer v-bind="$attrs" @register="registerDrawer" width="650px" destroyOnClose showFooter>
|
|
|
|
|
|
<template #title>
|
2026-03-24 16:03:01 +08:00
|
|
|
|
区域功能配置
|
2026-01-04 15:36:11 +08:00
|
|
|
|
</template>
|
2026-01-07 09:22:00 +08:00
|
|
|
|
|
|
|
|
|
|
<div>
|
|
|
|
|
|
<a-card title="基础功能">
|
|
|
|
|
|
<a-row v-for="(item,index) in treeData" :key="index">
|
2026-03-12 10:40:47 +08:00
|
|
|
|
|
|
|
|
|
|
<a-checkbox-group v-model:value="formData.kzgn">
|
2026-01-07 09:22:00 +08:00
|
|
|
|
<template v-if="item.code === 'hldy' && areaFlag == 1">
|
|
|
|
|
|
<a-col :span="24" v-for="itemOne in item.children">
|
2026-03-12 10:40:47 +08:00
|
|
|
|
<a-checkbox :value="itemOne.key" style="margin-top:10px;">{{ itemOne.slotTitle }}</a-checkbox>
|
2026-01-07 09:22:00 +08:00
|
|
|
|
</a-col>
|
|
|
|
|
|
</template>
|
|
|
|
|
|
<template v-else-if="item.code === 'kf' && areaFlag == 3">
|
|
|
|
|
|
<a-col :span="24" v-for="itemOne in item.children">
|
2026-03-12 10:40:47 +08:00
|
|
|
|
<a-checkbox :value="itemOne.key" style="margin-top:10px;">{{ itemOne.slotTitle }}</a-checkbox>
|
2026-01-07 09:22:00 +08:00
|
|
|
|
</a-col>
|
|
|
|
|
|
</template>
|
2026-03-12 10:40:47 +08:00
|
|
|
|
</a-checkbox-group>
|
2026-01-07 09:22:00 +08:00
|
|
|
|
</a-row>
|
|
|
|
|
|
</a-card>
|
|
|
|
|
|
|
2026-03-12 10:40:47 +08:00
|
|
|
|
<!-- <a-card title="扩展功能" style="margin-top: 20px;">
|
2026-01-07 09:22:00 +08:00
|
|
|
|
<a-row v-for="(item,index) in treeData" :key="index">
|
|
|
|
|
|
<template v-if="item.code === 'kzgn'">
|
|
|
|
|
|
<a-checkbox-group v-model:value="formData.kzgn">
|
|
|
|
|
|
<a-col :span="24" v-for="itemOne in item.children">
|
|
|
|
|
|
<a-checkbox :value="itemOne.key" style="margin-top:10px;">{{ itemOne.slotTitle }}</a-checkbox>
|
|
|
|
|
|
</a-col>
|
|
|
|
|
|
</a-checkbox-group>
|
|
|
|
|
|
</template>
|
|
|
|
|
|
</a-row>
|
2026-03-12 10:40:47 +08:00
|
|
|
|
</a-card> -->
|
2026-01-07 09:22:00 +08:00
|
|
|
|
</div>
|
|
|
|
|
|
|
|
|
|
|
|
|
2026-01-04 15:36:11 +08:00
|
|
|
|
<template #footer>
|
|
|
|
|
|
<a-button @click="closeDrawer">取消</a-button>
|
2026-01-07 09:22:00 +08:00
|
|
|
|
<a-button @click="handleSubmit(true)" type="primary" :loading="loading">保存</a-button>
|
2026-01-04 15:36:11 +08:00
|
|
|
|
</template>
|
|
|
|
|
|
</BasicDrawer>
|
|
|
|
|
|
</template>
|
|
|
|
|
|
<script lang="ts" setup>
|
2026-01-07 09:22:00 +08:00
|
|
|
|
import { ref, reactive, computed, unref, onMounted } from 'vue';
|
2026-01-04 15:36:11 +08:00
|
|
|
|
import { BasicDrawer, useDrawer, useDrawerInner } from '/@/components/Drawer';
|
|
|
|
|
|
import { BasicTree, TreeItem } from '/@/components/Tree';
|
|
|
|
|
|
import { PopConfirmButton } from '/@/components/Button';
|
|
|
|
|
|
import { queryTreeListForRole, queryRolePermission, saveRolePermission } from '../NuBaseInfo.api';
|
|
|
|
|
|
import { useI18n } from "/@/hooks/web/useI18n";
|
|
|
|
|
|
import { ROLE_AUTH_CONFIG_KEY } from '/@/enums/cacheEnum';
|
|
|
|
|
|
const emit = defineEmits(['register']);
|
|
|
|
|
|
//树的信息
|
|
|
|
|
|
const treeData = ref<TreeItem[]>([]);
|
|
|
|
|
|
//树的全部节点信息
|
|
|
|
|
|
const allTreeKeys = ref([]);
|
|
|
|
|
|
//树的选择节点信息
|
|
|
|
|
|
const checkedKeys = ref<any>([]);
|
|
|
|
|
|
const defaultCheckedKeys = ref([]);
|
|
|
|
|
|
//树的选中的节点信息
|
|
|
|
|
|
const selectedKeys = ref([]);
|
|
|
|
|
|
const roleId = ref('');
|
2026-01-07 09:22:00 +08:00
|
|
|
|
const areaFlag = ref('');
|
2026-01-04 15:36:11 +08:00
|
|
|
|
//树的实例
|
|
|
|
|
|
const treeRef = ref(null);
|
|
|
|
|
|
const loading = ref(false);
|
|
|
|
|
|
|
2026-01-07 09:22:00 +08:00
|
|
|
|
const formData = reactive<Record<string, any>>({
|
|
|
|
|
|
id: '',
|
|
|
|
|
|
jcgn: '',
|
|
|
|
|
|
nuId: '',
|
|
|
|
|
|
kzgn: '',
|
|
|
|
|
|
});
|
2026-01-04 15:36:11 +08:00
|
|
|
|
//展开折叠的key
|
|
|
|
|
|
const expandedKeys = ref<any>([]);
|
|
|
|
|
|
//父子节点选中状态是否关联 true不关联,false关联
|
|
|
|
|
|
const checkStrictly = ref<boolean>(false);
|
|
|
|
|
|
const [registerDrawer, { setDrawerProps, closeDrawer }] = useDrawerInner(async (data) => {
|
|
|
|
|
|
await reset();
|
|
|
|
|
|
setDrawerProps({ confirmLoading: false, loading: true });
|
|
|
|
|
|
roleId.value = data.roleId;
|
2026-01-07 09:22:00 +08:00
|
|
|
|
areaFlag.value = data.areaFlag;
|
|
|
|
|
|
console.log("🚀 ~ areaFlag.value:", areaFlag.value)
|
2026-01-04 15:36:11 +08:00
|
|
|
|
//初始化数据
|
|
|
|
|
|
const roleResult = await queryTreeListForRole();
|
|
|
|
|
|
// update-begin--author:liaozhiyang---date:20240228---for:【QQYUN-8355】角色权限配置的菜单翻译
|
|
|
|
|
|
treeData.value = translateTitle(roleResult.treeList);
|
|
|
|
|
|
// update-end--author:liaozhiyang---date:20240228---for:【QQYUN-8355】角色权限配置的菜单翻译
|
|
|
|
|
|
allTreeKeys.value = roleResult.ids;
|
|
|
|
|
|
// update-begin--author:liaozhiyang---date:20240531---for:【TV360X-590】角色授权弹窗操作缓存
|
|
|
|
|
|
const localData = localStorage.getItem(ROLE_AUTH_CONFIG_KEY);
|
|
|
|
|
|
if (localData) {
|
|
|
|
|
|
} else {
|
|
|
|
|
|
expandedKeys.value = roleResult.ids;
|
|
|
|
|
|
}
|
|
|
|
|
|
// update-end--author:liaozhiyang---date:20240531---for:【TV360X-590】角色授权弹窗操作缓存
|
|
|
|
|
|
//初始化角色菜单数据
|
|
|
|
|
|
const permResult = await queryRolePermission({ nuId: unref(roleId) });
|
2026-01-07 09:22:00 +08:00
|
|
|
|
formData.kzgn = permResult;
|
|
|
|
|
|
// if(areaFlag.value == 1){
|
|
|
|
|
|
// var jcgn = "";
|
|
|
|
|
|
// treeData.value.forEach(function(item) {
|
|
|
|
|
|
// if(item.code == 'hldy'){
|
|
|
|
|
|
// var list = item.children;
|
|
|
|
|
|
// list.forEach(function(itemOne) {
|
|
|
|
|
|
// jcgn = jcgn+itemOne.key+",";
|
|
|
|
|
|
// });
|
|
|
|
|
|
// }
|
|
|
|
|
|
// });
|
|
|
|
|
|
// formData.jcgn = jcgn.substring(0,jcgn.length-1);
|
|
|
|
|
|
// }else if(areaFlag.value == 3){
|
|
|
|
|
|
// var jcgn = "";
|
|
|
|
|
|
// treeData.value.forEach(function(item) {
|
|
|
|
|
|
// if(item.code == 'kf'){
|
|
|
|
|
|
// var list = item.children;
|
|
|
|
|
|
// list.forEach(function(itemOne) {
|
|
|
|
|
|
// jcgn = jcgn+itemOne.key+",";
|
|
|
|
|
|
// });
|
|
|
|
|
|
// }
|
|
|
|
|
|
// });
|
|
|
|
|
|
// formData.jcgn = jcgn.substring(0,jcgn.length-1);
|
|
|
|
|
|
// }
|
2026-01-04 15:36:11 +08:00
|
|
|
|
checkedKeys.value = permResult;
|
|
|
|
|
|
defaultCheckedKeys.value = permResult;
|
|
|
|
|
|
setDrawerProps({ loading: false });
|
|
|
|
|
|
});
|
|
|
|
|
|
/**
|
|
|
|
|
|
* 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);
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
2026-01-07 09:22:00 +08:00
|
|
|
|
if(item.code.indexOf('kzgn') > -1){
|
|
|
|
|
|
item.checked = false;
|
|
|
|
|
|
}else{
|
|
|
|
|
|
item.checked = true;
|
|
|
|
|
|
}
|
2026-01-04 15:36:11 +08:00
|
|
|
|
if (item.children?.length) {
|
|
|
|
|
|
translateTitle(item.children);
|
|
|
|
|
|
}
|
|
|
|
|
|
});
|
|
|
|
|
|
}
|
|
|
|
|
|
return data;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
* 数据重置
|
|
|
|
|
|
*/
|
|
|
|
|
|
function reset() {
|
|
|
|
|
|
treeData.value = [];
|
|
|
|
|
|
allTreeKeys.value = [];
|
|
|
|
|
|
checkedKeys.value = [];
|
|
|
|
|
|
defaultCheckedKeys.value = [];
|
|
|
|
|
|
selectedKeys.value = [];
|
|
|
|
|
|
roleId.value = '';
|
|
|
|
|
|
}
|
|
|
|
|
|
/**
|
|
|
|
|
|
* 提交
|
|
|
|
|
|
*/
|
|
|
|
|
|
async function handleSubmit(exit) {
|
2026-01-07 09:22:00 +08:00
|
|
|
|
var kzgn = formData.kzgn;
|
|
|
|
|
|
|
2026-01-04 15:36:11 +08:00
|
|
|
|
let params = {
|
|
|
|
|
|
roleId: unref(roleId),
|
2026-01-07 09:22:00 +08:00
|
|
|
|
permissionIds: unref(kzgn).join(','),
|
2026-01-04 15:36:11 +08:00
|
|
|
|
lastpermissionIds: unref(defaultCheckedKeys).join(','),
|
|
|
|
|
|
};
|
|
|
|
|
|
//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({ nuId: unref(roleId) });
|
|
|
|
|
|
defaultCheckedKeys.value = permResult;
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// VUE角色授权重复保存 #352
|
|
|
|
|
|
async function doSave(params) {
|
2026-01-07 09:22:00 +08:00
|
|
|
|
console.log("🚀 ~ doSave ~ params:", params)
|
2026-01-04 15:36:11 +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角色授权重复保存
|
|
|
|
|
|
|
|
|
|
|
|
</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>
|