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.

489 lines
14 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" tab="部门权限">
<a-tree
:tree-data="apartmentAdminTreeData"
v-model:checkedKeys="ApartcheckedKeys"
checkable
10 months ago
defaultExpandAll
11 months ago
@select="ApartmentSelect">
<template #title="{ title }">
{{ title }}
</template>
</a-tree>
11 months ago
</a-tab-pane>
</a-tabs>
11 months ago
<ns-button style="margin: 20px" type="primary" @click="CancelApartment">取消</ns-button>
10 months ago
<ns-button type="primary" @click="ApartmentSure">确定</ns-button>
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">
10 months ago
<ns-button :disabled="disabled2" style="margin: 10px" type="primary" @click="addUser"
>新增角色</ns-button
>
<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" tab="角色权限">
<a-tree
:tree-data="userAdminTreeData"
v-model:checkedKeys="UsercheckedKeys"
10 months ago
defaultExpandAll
11 months ago
checkable
@select="UserSelect">
<template #title="{ title }">
{{ title }}
</template>
</a-tree>
11 months ago
</a-tab-pane>
</a-tabs>
11 months ago
<ns-button style="margin: 20px" type="primary" @click="CancelUser">取消</ns-button>
<ns-button type="primary" @click="UserSure">{{ disabled2 ? '编辑' : '确定' }}</ns-button>
11 months ago
</a-col>
</a-row>
</div>
</div>
</template>
<script lang="ts">
11 months ago
import { createVNode, defineComponent, reactive, ref, watch } 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';
10 months ago
import { cloneDeep } from 'lodash-es';
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([]);
10 months ago
10 months ago
const userTreeData = ref([]);
10 months ago
const apartmentAdminTreeData = [
{
title: '首页',
key: '0-0',
children: [
{
title: '控制台',
key: '0-0-0',
children: [
{ title: 'leaf', key: '0-0-0-0' },
{ title: 'leaf', key: '0-0-0-1' },
],
},
{
title: '用户管理',
key: '0-0-1',
children: [{ key: '0-0-1-0', title: 'sss' }],
},
],
},
];
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;
});
const getTree = () => {
getDepartList({ orgId }).then((res) => {
apartmentTreeData.value = res.data;
NsMessage.success('操作成功');
});
};
const getUserTree = (params = { deptId: 2 }) => {
http.post(department.queryRoleTree, params).then((res) => {
userTreeData.value = res.data;
});
};
getUserTree({ deptId: 2 });
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';
formData.value = {};
opMap.fuc = (params) => {
delete params.roleId;
return http.post(department.addRole, {
...params,
orgId,
projectId,
enName: 'leader',
roleNote: 'wqe',
});
};
10 months ago
};
const addUserSon = () => {
disabled.value = false;
10 months ago
opMap.type = 'addUserSon';
formData.value = {};
opMap.fuc = (params) => {
delete params.roleId;
delete params.proleId;
return http.post(department.addRole, {
...params,
proleId: 4,
orgId,
projectId,
enName: 'leader',
roleNote: 'wqe',
});
};
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();
clearData();
});
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();
});
11 months ago
},
10 months ago
11 months ago
class: 'test',
});
};
10 months ago
const clearData = () => {
selectRef.value = {};
formData.value = {};
opMap.type = '';
opMap.fuc = '';
selectKey.value = '';
};
// 部门选择
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);
opMap.type = 'editDpet';
opMap.fuc = (params) => {
return http.post(department.deptEdit, params);
};
getUserTree({ deptId: selectRef.value.deptInfo.deptId });
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);
11 months ago
};
10 months ago
const CancelApartment = () => {
disabled.value = true;
};
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;
10 months ago
console.log(formData2.value, 'formData2');
10 months ago
console.log(opMap.type, 'opMap.type');
10 months ago
const typeArr = ['addUserSon', 'addUser'];
if (typeArr.includes(opMap.type)) {
opMap.fuc && opMap.fuc(formData2.value);
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');
}
formData2.value = {};
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,
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>