You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

573 lines
17 KiB

11 months ago
<!-- @format -->
<template>
<div class="main">
<div class="left">
<div class="ns-table-title">部门管理</div>
<a-row>
<a-col :span="12" class="tree">
10 months ago
<ns-button :disabled="disabled" style="margin: 10px" type="primary" @click="addApartment"
>新增部门</ns-button
>
<ns-button :disabled="disabled" type="primary" @click="addApartmentSon"
>新增子部门</ns-button
>
<ns-button
:disabled="disabled"
style="margin: 10px"
type="primary"
@click="deleteApartment"
>删除</ns-button
>
10 months ago
<a-tree
v-if="apartmentTreeData?.length"
:tree-data="apartmentTreeData"
defaultExpandAll
@select="SelectApartmentTree">
<template #title="data">
10 months ago
{{ data.deptInfo?.deptName }}
11 months ago
</template>
</a-tree>
</a-col>
<a-col :span="12" class="list">
<a-tabs v-model:activeKey="activeKey">
<a-tab-pane key="1" tab="部门信息">
10 months ago
<ns-form
ref="formRef"
:schemas="formSchema"
:model="formData"
formLayout="vertical"
class="form" />
11 months ago
</a-tab-pane>
<a-tab-pane key="2" :disabled="disabled" tab="部门权限">
11 months ago
<a-tree
:tree-data="apartmentAdminTreeData"
:fieldNames="{ children: 'menus', title: 'label', key: 'permissionId' }"
11 months ago
v-model:checkedKeys="ApartcheckedKeys"
checkable
:selectable="false"
10 months ago
defaultExpandAll
11 months ago
@select="ApartmentSelect">
<template #title="data"> {{ data.label }}</template>
11 months ago
</a-tree>
11 months ago
</a-tab-pane>
</a-tabs>
<div v-show="activeKey === '1'">
<ns-button style="margin: 16px" type="primary" @click="CancelApartment">取消</ns-button>
<ns-button type="primary" :disabled="disabled" @click="ApartmentSure">确定</ns-button>
</div>
<div v-show="activeKey === '2'">
<ns-button style="margin-left: 16px" type="primary" @click="apartmentPermission"
>确定</ns-button
>
</div>
11 months ago
</a-col>
</a-row>
</div>
<div class="right">
<div class="ns-table-title">角色管理</div>
<a-row>
<a-col :span="12" class="tree">
<ns-button style="margin: 10px" type="primary" @click="addUser">新增角色</ns-button>
10 months ago
<ns-button :disabled="disabled2" type="primary" @click="addUserSon">新增子角色</ns-button>
<ns-button :disabled="disabled2" style="margin: 10px" type="primary" @click="deleteUser"
>删除</ns-button
>
<a-tree
v-if="userTreeData.length"
:tree-data="userTreeData"
defaultExpandAll
@select="SelectUserTree">
10 months ago
<template #title="data">
10 months ago
{{ data.zhName }}
11 months ago
</template>
</a-tree>
</a-col>
<a-col :span="12" class="list">
<a-tabs v-model:activeKey="activeKey2">
<a-tab-pane key="1" tab="角色信息">
11 months ago
<ns-form
:schemas="formSchema2"
:model="formData2"
formLayout="vertical"
class="form" />
</a-tab-pane>
<a-tab-pane key="2" :disabled="disabled2" tab="角色权限">
11 months ago
<a-tree
v-if="userAdminTreeData?.length"
11 months ago
:tree-data="userAdminTreeData"
v-model:checkedKeys="UsercheckedKeys"
10 months ago
defaultExpandAll
:fieldNames="{ children: 'menus', title: 'label', key: 'permissionId' }"
:selectable="false"
11 months ago
checkable
@select="UserSelect" />
11 months ago
</a-tab-pane>
</a-tabs>
<div v-show="activeKey2 === '1'">
<ns-button style="margin: 16px" type="primary" @click="CancelUser">取消</ns-button>
<ns-button type="primary" :disabled="disabled2" @click="UserSure"> 确定</ns-button>
</div>
<div v-show="activeKey2 === '2'">
<ns-button style="margin: 16px" type="primary" @click="rolePermission"> 确定</ns-button>
</div>
11 months ago
</a-col>
</a-row>
</div>
</div>
</template>
<script lang="ts">
import { createVNode, defineComponent, reactive, ref, watch, watchEffect } from 'vue';
11 months ago
import { Modal } from 'ant-design-vue';
import { ExclamationCircleOutlined } from '@ant-design/icons-vue';
11 months ago
import { http } from '/nerv-lib/util/http';
import { cloneDeep, get } from 'lodash-es';
10 months ago
import { formConfig, formConfig2 } from './config';
10 months ago
import { department } from '/@/api/origanizemanage';
10 months ago
import { permission } from '/@/api/origanizemanage';
import { NsMessage } from '/nerv-lib/component';
10 months ago
11 months ago
export default defineComponent({
10 months ago
name: 'AuthorityManageIndex',
11 months ago
setup() {
10 months ago
const formRef = ref();
10 months ago
let formData = ref({});
let formData2 = ref({});
const activeKey = ref('1');
const activeKey2 = ref('1');
const disabled = ref(true);
const disabled2 = ref(true);
11 months ago
const ApartcheckedKeys = ref<string[]>([]);
const UsercheckedKeys = ref<string[]>([]);
10 months ago
const selectKey = ref();
const selectRef = ref();
const selectKey2 = ref();
const selectRef2 = ref();
const formSchema = formConfig(disabled as any);
const formSchema2 = formConfig2(disabled2 as any);
10 months ago
const orgId = JSON.parse(sessionStorage.getItem('userInfo')).orgId;
const projectId = JSON.parse(sessionStorage.getItem('userInfo')).projectId;
10 months ago
const userAdminTreeData = ref([]);
10 months ago
const apartmentTreeData = ref([]);
const apartmentAdminTreeData = ref([]);
10 months ago
10 months ago
const userTreeData = ref([]);
const getPermissionTree = (params) => {
return http.post(permission.permissionTree, params).then((res) => {
apartmentAdminTreeData.value = get(res, 'data.data');
userAdminTreeData.value = get(res, 'data.data');
});
};
getPermissionTree({ projectId });
10 months ago
10 months ago
watch(ApartcheckedKeys, () => {
console.log('checkedKeys', ApartcheckedKeys.value);
});
watch(UsercheckedKeys, () => {
console.log('checkedKeys', UsercheckedKeys.value);
});
10 months ago
10 months ago
// 部门树
const getDepartList = (params) => {
return http.post(department.dartList, params);
};
getDepartList({ orgId }).then((res) => {
apartmentTreeData.value = res.data;
});
// 获取部门树
10 months ago
const getTree = () => {
getDepartList({ orgId }).then((res) => {
apartmentTreeData.value = res.data;
NsMessage.success('操作成功');
});
};
// 获取角色树
const getUserTree = (params = { deptId: selectRef.value?.deptInfo?.deptId }) => {
10 months ago
http.post(department.queryRoleTree, params).then((res) => {
userTreeData.value = res.data;
});
};
// 根据依赖刷新角色树
watchEffect(() => {
if (selectRef.value) {
getUserTree();
}
});
10 months ago
const opMap: any = {
type: 'add',
fuc: () => {},
record: {},
callback: null,
};
11 months ago
10 months ago
function fetch(api, params) {
return http.post(api, params);
}
11 months ago
const addApartment = () => {
disabled.value = false;
10 months ago
opMap.type = 'addDept';
formData.value = {};
10 months ago
opMap.fuc = (params) => {
10 months ago
return http.post(department.deptSave, {
...params,
orgId,
projectId,
});
10 months ago
};
return;
11 months ago
};
const addApartmentSon = () => {
disabled.value = false;
10 months ago
opMap.type = 'addson';
10 months ago
formData.value = {};
opMap.fuc = (params) => {
10 months ago
return http.post(department.deptSave, {
10 months ago
...params,
orgId,
projectId,
pdeptId: selectRef.value.deptInfo.deptId,
});
};
11 months ago
};
10 months ago
const addUser = () => {
disabled2.value = false;
10 months ago
opMap.type = 'addUser';
formData2.value = {};
10 months ago
opMap.fuc = (params) => {
delete params.roleId;
return http.post(department.addRole, {
...params,
orgId,
projectId,
deptId: selectRef.value.deptInfo.deptId,
10 months ago
});
};
10 months ago
};
const addUserSon = () => {
disabled.value = false;
10 months ago
opMap.type = 'addUserSon';
formData2.value = {};
10 months ago
opMap.fuc = (params) => {
delete params.roleId;
return http.post(department.addRole, {
...params,
orgId,
projectId,
proleId: selectRef2.value.roleId,
deptId: selectRef.value.deptInfo.deptId,
10 months ago
});
};
10 months ago
};
11 months ago
const deleteApartment = () => {
10 months ago
// 删除逻辑
// opMap.type = 'deptDelete';
// opMap.fuc = (params) => {
// return http.post(department.deptDel, params).then(() => {
// NsMessage.success('删除成功');
// });
// };
11 months ago
Modal.confirm({
title: '是否确认删除',
icon: createVNode(ExclamationCircleOutlined),
content: createVNode('div', { style: 'color:red;' }, ''),
10 months ago
onOk() {
10 months ago
http.post(department.deptDel, { deptId: selectRef.value.deptInfo.deptId }).then(() => {
getTree();
clearApartData();
10 months ago
});
10 months ago
},
11 months ago
onCancel() {
console.log('Cancel');
},
});
};
const deleteUser = () => {
Modal.confirm({
title: '是否确认删除',
icon: createVNode(ExclamationCircleOutlined),
content: createVNode('div', { style: 'color:red;' }, ''),
10 months ago
onOk() {
10 months ago
http.post(department.delRole, { roleId: selectRef2.value.roleId }).then(() => {
getUserTree({ deptId: selectRef.value.deptInfo.deptId });
10 months ago
});
11 months ago
},
10 months ago
11 months ago
class: 'test',
});
};
const clearApartData = () => {
10 months ago
selectRef.value = {};
formData.value = {};
opMap.type = '';
opMap.fuc = '';
selectKey.value = '';
};
// 保存部门权限
const apartmentPermission = () => {
http
.post(department.addPermission, {
deptId: selectRef.value?.deptInfo.deptId,
projectId,
permissionVoList: ApartcheckedKeys.value.map((item) => {
return { permissionId: item };
}),
})
.then(() => {
NsMessage.success('保存成功');
});
};
// 保存角色权限
const rolePermission = () => {
http
.post(department.addRolePermission, {
// deptId: selectRef.value?.deptInfo.deptId,
roleId: selectRef2.value?.roleId,
projectId,
permissionVoList: UsercheckedKeys.value.map((item) => {
return { permissionId: item };
}),
})
.then(() => {
NsMessage.success('保存成功');
});
};
// 获取部门拥有的权限
const getDeptPermission = () => {
http
.post(department.queryDeptPermission, { deptId: selectRef.value?.deptInfo.deptId })
.then((res) => {
ApartcheckedKeys.value = res.data.map((item) => {
return item.permissionId;
});
});
};
// 获取角色拥有的权限
const getRolePermission = () => {
http
.post(department.queryRolePermission, { roleId: selectRef2.value?.roleId })
.then((res) => {
UsercheckedKeys.value = res.data.map((item) => {
return item.permissionId;
});
});
};
/**
* 默认选中视为编辑部门
* type editDpet
*/
const apartmentChoose = () => {
opMap.type = 'editDpet';
opMap.fuc = (params) => {
return http.post(department.deptEdit, params);
};
};
10 months ago
// 部门选择
11 months ago
const SelectApartmentTree = (selectedKeys: any, info: any) => {
10 months ago
const { selected } = info;
disabled.value = !selected;
console.log(info, 'info');
10 months ago
selectKey.value = selectedKeys[0];
selectRef.value = info.node.dataRef;
10 months ago
formData.value = cloneDeep(info.node.dataRef.deptInfo);
apartmentChoose();
ApartcheckedKeys.value.splice(0);
getDeptPermission();
// getUserTree({ deptId: selectRef.value.deptInfo.deptId });
};
/**
* 默认选中视为编辑角色
* type editDpet
*/
const roleChoose = () => {
10 months ago
opMap.type = 'editDpet';
opMap.fuc = (params) => {
return http.post(department.deptEdit, params);
};
11 months ago
};
10 months ago
// 角色选择
11 months ago
const SelectUserTree = (selectedKeys: any, info: any) => {
10 months ago
const { selected } = info;
disabled2.value = !selected;
11 months ago
console.log(selectedKeys, 'selectedKeys');
10 months ago
console.log(info, 'info');
10 months ago
selectKey2.value = selectedKeys[0];
selectRef2.value = info.node.dataRef;
10 months ago
formData2.value = cloneDeep(info.node.dataRef);
roleChoose();
UsercheckedKeys.value.splice(0);
getRolePermission();
11 months ago
};
10 months ago
const CancelApartment = () => {
disabled.value = true;
// 取消视为转入编辑状态
// clearApartData();
10 months ago
};
const CancelUser = () => {
disabled2.value = true;
};
11 months ago
const ApartmentSelect = (selectedKeys: any, info: any) => {
console.log(selectedKeys, 'selectedKeys');
console.log(info, 'info');
};
const UserSelect = (selectedKeys: any, info: any) => {
console.log(selectedKeys, 'selectedKeys');
console.log(info, 'info');
};
11 months ago
const ApartmentSure = () => {
10 months ago
// formRef.value?.triggerSubmit().then(() => {});
10 months ago
// disabled.value = !disabled.value;
10 months ago
// console.log(formData.value.name, 'formData');
10 months ago
console.log(opMap.type, 'ApartmentSure');
const opArr = ['addDept', 'editDpet'];
if (opArr.includes(opMap.type)) {
10 months ago
console.log(formRef.value, formData);
10 months ago
opMap.fuc &&
opMap.fuc(formData.value).then(() => {
getTree();
});
10 months ago
} else if (selectRef.value && opMap.type === 'addson')
10 months ago
opMap.fuc && opMap.fuc(formData.value);
10 months ago
else if (opMap.type === 'deptDelete') {
opMap.fuc && opMap.fuc({ ...formData.value, selectRef: selectRef.value });
10 months ago
}
11 months ago
};
11 months ago
const UserSure = () => {
disabled2.value = !disabled2.value;
const typeArr = ['addUserSon', 'addUser', 'editRole'];
10 months ago
if (typeArr.includes(opMap.type)) {
opMap.fuc &&
opMap.fuc(formData2.value).then(() => {
getUserTree();
});
10 months ago
} else if (selectRef2.value && opMap.type === 'addson')
selectRef2.value['children'] = [
{
key: '123',
title: formData2.value.departname,
info: { ...cloneDeep(formData2.value) },
},
];
else {
console.log('ss');
}
11 months ago
};
11 months ago
return {
11 months ago
disabled,
11 months ago
disabled2,
11 months ago
formSchema,
11 months ago
formSchema2,
11 months ago
formData,
11 months ago
formData2,
apartmentTreeData,
userTreeData,
SelectApartmentTree,
SelectUserTree,
11 months ago
activeKey,
11 months ago
activeKey2,
ApartmentSure,
11 months ago
UserSure,
11 months ago
addApartment,
addApartmentSon,
deleteApartment,
deleteUser,
addUser,
addUserSon,
11 months ago
CancelApartment,
CancelUser,
apartmentAdminTreeData,
ApartmentSelect,
ApartcheckedKeys,
userAdminTreeData,
UsercheckedKeys,
UserSelect,
10 months ago
formRef,
apartmentPermission,
rolePermission,
11 months ago
};
},
});
</script>
<style scoped>
.main {
display: flex;
flex: 1;
}
10 months ago
11 months ago
.left {
width: 50%;
height: calc(100vh-50px);
border-right: 5px solid rgb(229, 235, 240);
}
10 months ago
11 months ago
.tree {
11 months ago
width: 400px;
height: 89vh;
border-right: 2px solid rgb(229, 235, 240);
}
10 months ago
11 months ago
.right {
width: 50%;
}
.top {
height: 50vh;
border-bottom: 5px solid rgb(229, 235, 240);
}
10 months ago
11 months ago
.ns-table-title {
text-align: left;
height: 46px;
line-height: 46px;
font-size: 18px;
font-weight: bold;
user-select: text;
padding-left: 16px;
width: 100%;
border-bottom: 2px solid rgb(229, 235, 240);
}
10 months ago
11 months ago
.table {
width: 2000px;
}
10 months ago
11 months ago
.admin {
text-align: left;
height: 42px;
line-height: 42px;
font-size: 16px;
font-weight: bold;
user-select: text;
padding-left: 16px;
width: calc(100% + 32px);
}
10 months ago
11 months ago
.form {
11 months ago
margin: 20px;
11 months ago
}
</style>