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.

547 lines
15 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">
11 months ago
<ns-button style="margin: 10px" type="primary" @click="addApartment">新增部门</ns-button>
<ns-button type="primary" @click="addApartmentSon">新增子部门</ns-button>
<ns-button style="margin: 10px" type="primary" @click="deleteApartment">删除</ns-button>
11 months ago
<a-tree :tree-data="apartmentTreeData" @select="SelectApartmentTree">
11 months ago
<template #title="{ title }">
{{ title }}
</template>
</a-tree>
</a-col>
<a-col :span="12" class="list">
<a-tabs v-model:activeKey="activeKey">
<a-tab-pane key="1" tab="部门信息">
11 months ago
<ns-form :schemas="formSchema" :model="formData" formLayout="vertical" class="form" />
</a-tab-pane>
<a-tab-pane key="2" tab="部门权限">
<a-tree
:tree-data="apartmentAdminTreeData"
v-model:checkedKeys="ApartcheckedKeys"
checkable
@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>
11 months ago
<ns-button type="primary" @click="ApartmentSure">{{
disabled ? '编辑' : '确定'
}}</ns-button>
</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>
<ns-button type="primary" @click="addUserSon">新增子角色</ns-button>
<ns-button style="margin: 10px" type="primary" @click="deleteUser">删除</ns-button>
11 months ago
<a-tree :tree-data="userTreeData" @select="SelectUserTree">
11 months ago
<template #title="{ title }">
{{ title }}
</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"
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';
export default defineComponent({
11 months ago
name: 'authorityManageIndex',
11 months ago
setup() {
11 months ago
const ApartcheckedKeys = ref<string[]>([]);
const UsercheckedKeys = ref<string[]>([]);
watch(ApartcheckedKeys, () => {
console.log('checkedKeys', ApartcheckedKeys.value);
});
watch(UsercheckedKeys, () => {
console.log('checkedKeys', UsercheckedKeys.value);
});
11 months ago
const activeKey = ref('1');
11 months ago
const activeKey2 = ref('1');
const disabled = ref(false);
11 months ago
const disabled2 = ref(false);
11 months ago
const addApartment = () => {
disabled.value = false;
};
const addApartmentSon = () => {
disabled.value = false;
};
const deleteApartment = () => {
Modal.confirm({
title: '是否确认删除',
icon: createVNode(ExclamationCircleOutlined),
content: createVNode('div', { style: 'color:red;' }, ''),
onOk() {},
onCancel() {
console.log('Cancel');
},
class: 'test',
});
};
const addUser = () => {
11 months ago
disabled2.value = false;
11 months ago
};
const addUserSon = () => {
disabled.value = false;
};
const deleteUser = () => {
Modal.confirm({
title: '是否确认删除',
icon: createVNode(ExclamationCircleOutlined),
content: createVNode('div', { style: 'color:red;' }, ''),
onOk() {},
onCancel() {
console.log('Cancel');
},
class: 'test',
});
};
11 months ago
const SelectApartmentTree = (selectedKeys: any, info: any) => {
11 months ago
console.log(selectedKeys, 'selectedKeys');
console.log(info, 'info');
};
11 months ago
const SelectUserTree = (selectedKeys: any, info: any) => {
console.log(selectedKeys, 'selectedKeys');
console.log(info, 'info');
};
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 = () => {
disabled.value = !disabled.value;
};
11 months ago
const UserSure = () => {
disabled2.value = !disabled2.value;
};
const CancelApartment = () => {
disabled.value = true;
};
const CancelUser = () => {
disabled2.value = true;
};
11 months ago
11 months ago
const apartmentTreeData = [
11 months ago
{
title: '铁路总局',
key: '0-0',
children: [
{ title: '济阳站', key: '0-0-0' },
{ title: '临沂站', key: '0-0-1' },
],
},
];
11 months ago
const userTreeData = [
{
title: '产品总监',
key: '0-0',
children: [
{ title: '产品经理', key: '0-0-0' },
{ title: '产品助理', key: '0-0-1' },
],
},
];
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' }],
},
],
},
];
const userAdminTreeData = [
{
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' }],
},
],
},
];
11 months ago
let formData = reactive({
11 months ago
department: '',
remark: '',
11 months ago
});
11 months ago
let formData2 = reactive({
department: '',
remark: '',
});
11 months ago
const formSchema = reactive([
{
field: 'field111',
component: 'NsChildForm',
componentProps: {
schemas: [
{
11 months ago
label: '部门名称',
field: 'department',
component: 'NsSelect',
11 months ago
componentProps: {
11 months ago
disabled: disabled,
11 months ago
placeholder: '请选择部门',
11 months ago
options: [
11 months ago
{
11 months ago
label: '产品部',
11 months ago
value: 1,
},
{
11 months ago
label: '项目部',
11 months ago
value: 2,
},
11 months ago
],
},
rules: [
{
required: false,
11 months ago
message: '请选择部门',
11 months ago
},
],
},
{
11 months ago
label: '上级部门',
field: 'department',
component: 'NsSelect',
11 months ago
componentProps: {
11 months ago
disabled: disabled,
11 months ago
placeholder: '请选择上级部门',
options: [
{
label: '正常',
value: 1,
},
{
label: '冻结',
value: 2,
},
],
11 months ago
},
},
{
11 months ago
label: '部门编码',
field: 'department',
11 months ago
component: 'NsSelect',
componentProps: {
11 months ago
disabled: disabled,
11 months ago
placeholder: '请选择部门编码',
11 months ago
options: [
{
label: '正常',
value: 1,
},
{
label: '冻结',
value: 2,
},
],
},
11 months ago
rules: [
{
required: false,
message: '请选择部门编码',
},
],
11 months ago
},
{
11 months ago
label: '排序',
field: 'order',
component: 'NsInput',
componentProps: {
11 months ago
disabled: disabled,
11 months ago
placeholder: '请输入排序',
},
rules: [
11 months ago
{
11 months ago
required: false,
message: '请输入排序',
11 months ago
},
],
},
11 months ago
{
field: 'remark',
label: '备注',
component: 'NsTextarea',
componentProps: {
11 months ago
disabled: disabled,
11 months ago
placeholder: '请输入',
},
},
11 months ago
],
},
},
]);
11 months ago
const formSchema2 = reactive([
{
field: 'field111',
component: 'NsChildForm',
componentProps: {
schemas: [
{
label: '角色名称',
field: 'department',
component: 'NsSelect',
componentProps: {
disabled: disabled2,
placeholder: '请选择角色名称',
options: [
{
label: '正常',
value: 1,
},
{
label: '冻结',
value: 2,
},
],
},
rules: [
{
required: false,
message: '请选择角色名称',
},
],
},
{
label: '上级领导',
field: 'department',
component: 'NsSelect',
componentProps: {
disabled: disabled2,
placeholder: '请选择上级领导',
options: [
{
label: '正常',
value: 1,
},
{
label: '冻结',
value: 2,
},
],
},
},
{
label: '节点编码',
field: 'department',
component: 'NsSelect',
componentProps: {
disabled: disabled2,
placeholder: '请选择节点编码',
options: [
{
label: '正常',
value: 1,
},
{
label: '冻结',
value: 2,
},
],
},
rules: [
{
required: false,
message: '请选择节点编码',
},
],
},
{
label: '是否部门领导',
field: 'sex',
component: 'NsRadioGroup',
componentProps: {
disabled: disabled2,
radioType: 'radio',
options: [
{ label: '是', value: 1 },
{ label: '否', value: 2 },
],
rules: [
{
required: false,
message: '请选择是否部门领导',
},
],
},
},
{
field: 'remark',
label: '备注',
component: 'NsTextarea',
componentProps: {
disabled: disabled2,
placeholder: '请输入',
},
},
],
},
},
]);
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,
11 months ago
};
},
});
</script>
<style scoped>
.main {
display: flex;
flex: 1;
}
.left {
width: 50%;
height: calc(100vh-50px);
border-right: 5px solid rgb(229, 235, 240);
}
11 months ago
.tree {
11 months ago
width: 400px;
height: 89vh;
border-right: 2px solid rgb(229, 235, 240);
}
.right {
width: 50%;
}
.top {
height: 50vh;
border-bottom: 5px solid rgb(229, 235, 240);
}
.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);
}
.table {
width: 2000px;
}
.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);
}
.form {
11 months ago
margin: 20px;
11 months ago
}
</style>