2022-03-10 09:47:29 +08:00
|
|
|
|
<template>
|
|
|
|
|
<BasicDrawer v-bind="$attrs" @register="registerDrawer" title="角色权限配置" width="650px" destroyOnClose showFooter>
|
|
|
|
|
<BasicTree
|
|
|
|
|
ref="treeRef"
|
|
|
|
|
checkable
|
|
|
|
|
toolbar
|
|
|
|
|
:treeData="treeData"
|
|
|
|
|
:checkedKeys="checkedKeys"
|
|
|
|
|
:expandedKeys="allTreeKeys"
|
|
|
|
|
:selectedKeys="selectedKeys"
|
|
|
|
|
:checkStrictly="true"
|
|
|
|
|
:clickRowToExpand="false"
|
|
|
|
|
title="所拥有的的权限"
|
|
|
|
|
@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>
|
|
|
|
|
<PopConfirmButton title="确定放弃编辑?" @confirm="closeDrawer" okText="确定" cancelText="取消">取消</PopConfirmButton>
|
|
|
|
|
<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';
|
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);
|
|
|
|
|
|
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();
|
|
|
|
|
treeData.value = roleResult.treeList;
|
|
|
|
|
allTreeKeys.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
|
|
|
|
});
|
|
|
|
|
/**
|
|
|
|
|
* 点击选中
|
|
|
|
|
*/
|
|
|
|
|
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
|
|
|
|
};
|
|
|
|
|
loading.value = true;
|
|
|
|
|
await saveRolePermission(params);
|
|
|
|
|
loading.value = false;
|
2022-06-10 10:44:44 +08:00
|
|
|
|
exit && closeDrawer();
|
2022-03-10 09:47:29 +08:00
|
|
|
|
}
|
|
|
|
|
</script>
|