|
@@ -1,37 +1,44 @@
|
|
|
<template>
|
|
|
<div class="app-container">
|
|
|
- <transition :enter-active-class="proxy?.animate.searchAnimate.enter"
|
|
|
- :leave-active-class="proxy?.animate.searchAnimate.leave">
|
|
|
- <div v-show="showSearch" class="mb-[10px]">
|
|
|
- <el-form ref="queryFormRef" :model="queryParams" :inline="true">
|
|
|
- <el-form-item label="部门名称" prop="deptName">
|
|
|
- <el-input v-model="queryParams.deptName" placeholder="请输入部门名称" clearable @keyup.enter="handleQuery"/>
|
|
|
- </el-form-item>
|
|
|
- <el-form-item label="类别编码" prop="deptCategory">
|
|
|
- <el-input v-model="queryParams.deptCategory" placeholder="请输入类别编码" clearable style="width: 240px"
|
|
|
- @keyup.enter="handleQuery"/>
|
|
|
- </el-form-item>
|
|
|
- <el-form-item label="状态" prop="status">
|
|
|
- <el-select v-model="queryParams.status" placeholder="部门状态" clearable>
|
|
|
- <el-option v-for="dict in sys_normal_disable" :key="dict.value" :label="dict.label" :value="dict.value"/>
|
|
|
- </el-select>
|
|
|
- </el-form-item>
|
|
|
- <el-form-item>
|
|
|
- <el-button type="primary" icon="Search" @click="handleQuery">搜索</el-button>
|
|
|
- <el-button icon="Refresh" @click="resetQuery">重置</el-button>
|
|
|
- </el-form-item>
|
|
|
+ <transition :enter-active-class="proxy?.animate.searchAnimate.enter" :leave-active-class="proxy?.animate.searchAnimate.leave">
|
|
|
+ <div v-show="showSearch">
|
|
|
+ <el-form ref="queryFormRef" :model="queryParams">
|
|
|
+ <el-row :gutter="20">
|
|
|
+ <!-- 第一行 -->
|
|
|
+ <el-col :span="6">
|
|
|
+ <el-form-item label="部门名称:" prop="deptName">
|
|
|
+ <el-input v-model="queryParams.deptName" placeholder="请输入部门名称" clearable @keyup.enter="handleQuery" />
|
|
|
+ </el-form-item>
|
|
|
+ </el-col>
|
|
|
+ <el-col :span="6">
|
|
|
+ <el-form-item label="类别编码:" prop="deptCategory">
|
|
|
+ <el-input v-model="queryParams.deptCategory" placeholder="请输入类别编码" clearable style="width: 240px" @keyup.enter="handleQuery" />
|
|
|
+ </el-form-item>
|
|
|
+ </el-col>
|
|
|
+ <el-col :span="6">
|
|
|
+ <el-form-item label="状态:" prop="status">
|
|
|
+ <el-select v-model="queryParams.status" placeholder="部门状态" clearable>
|
|
|
+ <el-option v-for="dict in sys_normal_disable" :key="dict.value" :label="dict.label" :value="dict.value" />
|
|
|
+ </el-select>
|
|
|
+ </el-form-item>
|
|
|
+ </el-col>
|
|
|
+ <el-col :span="6">
|
|
|
+ <el-form-item>
|
|
|
+ <el-button type="primary" icon="Search" @click="handleQuery">搜索</el-button>
|
|
|
+ <el-button icon="Refresh" @click="resetQuery">重置</el-button>
|
|
|
+ </el-form-item>
|
|
|
+ </el-col>
|
|
|
+ </el-row>
|
|
|
</el-form>
|
|
|
</div>
|
|
|
</transition>
|
|
|
|
|
|
-
|
|
|
<el-row :gutter="10" class="mb8">
|
|
|
<el-col :span="1.5">
|
|
|
- <el-button v-hasPermi="['system:dept:add']" type="primary" plain icon="Plus" @click="handleAdd()">新增
|
|
|
- </el-button>
|
|
|
+ <el-button v-hasPermi="['system:dept:add']" type="primary" icon="Plus" @click="handleAdd()">新增 </el-button>
|
|
|
</el-col>
|
|
|
<el-col :span="1.5">
|
|
|
- <el-button type="info" plain icon="Sort" @click="handleToggleExpandAll">展开/折叠</el-button>
|
|
|
+ <el-button type="danger" plain icon="Sort" @click="handleToggleExpandAll">展开/折叠</el-button>
|
|
|
</el-col>
|
|
|
<right-toolbar v-model:showSearch="showSearch" @query-table="getList"></right-toolbar>
|
|
|
</el-row>
|
|
@@ -44,110 +51,103 @@
|
|
|
:tree-props="{ children: 'children', hasChildren: 'hasChildren' }"
|
|
|
:default-expand-all="isExpandAll"
|
|
|
>
|
|
|
- <el-table-column prop="deptName" label="部门名称" width="260"></el-table-column>
|
|
|
- <el-table-column prop="deptCategory" align="center" label="类别编码" width="200"></el-table-column>
|
|
|
+ <el-table-column prop="deptName" align="center" label="部门名称" width="360"></el-table-column>
|
|
|
+ <el-table-column prop="deptCategory" align="center" label="类别编码" width="300"></el-table-column>
|
|
|
<el-table-column prop="orderNum" align="center" label="排序" width="200"></el-table-column>
|
|
|
- <el-table-column prop="status" align="center" label="状态" width="100">
|
|
|
+ <el-table-column prop="status" align="center" label="状态" width="160">
|
|
|
<template #default="scope">
|
|
|
- <dict-tag :options="sys_normal_disable" :value="scope.row.status"/>
|
|
|
+ <dict-tag :options="sys_normal_disable" :value="scope.row.status" />
|
|
|
</template>
|
|
|
</el-table-column>
|
|
|
- <el-table-column label="创建时间" align="center" prop="createTime" width="200">
|
|
|
+ <el-table-column label="创建时间" align="center" prop="createTime" width="260">
|
|
|
<template #default="scope">
|
|
|
<span>{{ parseTime(scope.row.createTime) }}</span>
|
|
|
</template>
|
|
|
</el-table-column>
|
|
|
- <el-table-column fixed="right" align="center" label="操作">
|
|
|
+ <el-table-column label="操作" align="center" class-name="small-padding fixed-width">
|
|
|
<template #default="scope">
|
|
|
- <el-tooltip content="修改" placement="top">
|
|
|
- <el-button v-hasPermi="['system:dept:edit']" link type="primary" icon="Edit"
|
|
|
- @click="handleUpdate(scope.row)"/>
|
|
|
- </el-tooltip>
|
|
|
- <el-tooltip content="新增" placement="top">
|
|
|
- <el-button v-hasPermi="['system:dept:add']" link type="primary" icon="Plus" @click="handleAdd(scope.row)"/>
|
|
|
- </el-tooltip>
|
|
|
- <el-tooltip content="删除" placement="top">
|
|
|
- <el-button v-hasPermi="['system:dept:remove']" link type="primary" icon="Delete"
|
|
|
- @click="handleDelete(scope.row)"/>
|
|
|
- </el-tooltip>
|
|
|
+ <el-text v-hasPermi="['system:menu:edit']" class="common-btn-text-primary" @click="handleUpdate(scope.row)">修改</el-text>
|
|
|
+ <el-text v-hasPermi="['system:menu:add']" class="common-btn-text-primary" @click="handleAdd(scope.row)">新增</el-text>
|
|
|
+ <el-text v-hasPermi="['system:menu:remove']" class="common-btn-text-danger" @click="handleDelete(scope.row)">删除</el-text>
|
|
|
</template>
|
|
|
</el-table-column>
|
|
|
</el-table>
|
|
|
|
|
|
- <el-dialog v-model="dialog.visible" :title="dialog.title" destroy-on-close append-to-body width="600px">
|
|
|
- <el-form ref="deptFormRef" :model="form" :rules="rules" label-width="80px">
|
|
|
- <el-row>
|
|
|
- <el-col v-if="form.parentId !== 0" :span="24">
|
|
|
- <el-form-item label="上级部门" prop="parentId">
|
|
|
- <el-tree-select
|
|
|
- v-model="form.parentId"
|
|
|
- :data="deptOptions"
|
|
|
- :props="{ value: 'deptId', label: 'deptName', children: 'children' }"
|
|
|
- value-key="deptId"
|
|
|
- placeholder="选择上级部门"
|
|
|
- check-strictly
|
|
|
- />
|
|
|
- </el-form-item>
|
|
|
- </el-col>
|
|
|
- <el-col :span="12">
|
|
|
- <el-form-item label="部门名称" prop="deptName">
|
|
|
- <el-input v-model="form.deptName" placeholder="请输入部门名称"/>
|
|
|
- </el-form-item>
|
|
|
- </el-col>
|
|
|
- <el-col :span="12">
|
|
|
- <el-form-item label="类别编码" prop="deptCategory">
|
|
|
- <el-input v-model="form.deptCategory" placeholder="请输入类别编码"/>
|
|
|
- </el-form-item>
|
|
|
- </el-col>
|
|
|
- <el-col :span="12">
|
|
|
- <el-form-item label="显示排序" prop="orderNum">
|
|
|
- <el-input-number v-model="form.orderNum" controls-position="right" :min="0"/>
|
|
|
- </el-form-item>
|
|
|
- </el-col>
|
|
|
- <el-col :span="12">
|
|
|
- <el-form-item label="负责人" prop="leader">
|
|
|
- <el-select v-model="form.leader" placeholder="请选择负责人">
|
|
|
- <el-option v-for="item in deptUserList" :key="item.userId" :label="item.userName" :value="item.userId"/>
|
|
|
- </el-select>
|
|
|
- </el-form-item>
|
|
|
- </el-col>
|
|
|
- <el-col :span="12">
|
|
|
- <el-form-item label="联系电话" prop="phone">
|
|
|
- <el-input v-model="form.phone" placeholder="请输入联系电话" maxlength="11"/>
|
|
|
- </el-form-item>
|
|
|
- </el-col>
|
|
|
- <el-col :span="12">
|
|
|
- <el-form-item label="邮箱" prop="email">
|
|
|
- <el-input v-model="form.email" placeholder="请输入邮箱" maxlength="50"/>
|
|
|
- </el-form-item>
|
|
|
- </el-col>
|
|
|
- <el-col :span="12">
|
|
|
- <el-form-item label="部门状态">
|
|
|
- <el-radio-group v-model="form.status">
|
|
|
- <el-radio v-for="dict in sys_normal_disable" :key="dict.value" :value="dict.value">{{
|
|
|
- dict.label
|
|
|
- }}
|
|
|
- </el-radio>
|
|
|
- </el-radio-group>
|
|
|
- </el-form-item>
|
|
|
- </el-col>
|
|
|
- </el-row>
|
|
|
- </el-form>
|
|
|
- <template #footer>
|
|
|
- <div class="dialog-footer">
|
|
|
+ <div v-show="dialog.visible" class="common-dialog">
|
|
|
+ <div class="common-dialog-content">
|
|
|
+ <div class="common-dialog-title-box">
|
|
|
+ <i class="common-dialog-title-icon" />
|
|
|
+ <div>{{ dialog.title }}</div>
|
|
|
+ </div>
|
|
|
+ <el-form ref="deptFormRef" :model="form" :rules="rules" label-width="80px">
|
|
|
+ <el-row>
|
|
|
+ <el-col v-if="form.parentId !== 0" :span="24">
|
|
|
+ <el-form-item label="上级部门:" prop="parentId">
|
|
|
+ <el-tree-select
|
|
|
+ v-model="form.parentId"
|
|
|
+ :data="deptOptions"
|
|
|
+ :props="{ value: 'deptId', label: 'deptName', children: 'children' }"
|
|
|
+ value-key="deptId"
|
|
|
+ placeholder="选择上级部门"
|
|
|
+ check-strictly
|
|
|
+ />
|
|
|
+ </el-form-item>
|
|
|
+ </el-col>
|
|
|
+ <el-col :span="12">
|
|
|
+ <el-form-item label="部门名称:" prop="deptName">
|
|
|
+ <el-input v-model="form.deptName" placeholder="请输入部门名称" />
|
|
|
+ </el-form-item>
|
|
|
+ </el-col>
|
|
|
+ <el-col :span="12">
|
|
|
+ <el-form-item label="类别编码:" prop="deptCategory">
|
|
|
+ <el-input v-model="form.deptCategory" placeholder="请输入类别编码" />
|
|
|
+ </el-form-item>
|
|
|
+ </el-col>
|
|
|
+ <el-col :span="12">
|
|
|
+ <el-form-item label="显示排序:" prop="orderNum">
|
|
|
+ <el-input-number v-model="form.orderNum" controls-position="right" :min="0" />
|
|
|
+ </el-form-item>
|
|
|
+ </el-col>
|
|
|
+ <el-col :span="12">
|
|
|
+ <el-form-item label="负责人:" prop="leader">
|
|
|
+ <el-select v-model="form.leader" placeholder="请选择负责人">
|
|
|
+ <el-option v-for="item in deptUserList" :key="item.userId" :label="item.userName" :value="item.userId" />
|
|
|
+ </el-select>
|
|
|
+ </el-form-item>
|
|
|
+ </el-col>
|
|
|
+ <el-col :span="12">
|
|
|
+ <el-form-item label="联系电话:" prop="phone">
|
|
|
+ <el-input v-model="form.phone" placeholder="请输入联系电话" maxlength="11" />
|
|
|
+ </el-form-item>
|
|
|
+ </el-col>
|
|
|
+ <el-col :span="12">
|
|
|
+ <el-form-item label="邮箱:" prop="email">
|
|
|
+ <el-input v-model="form.email" placeholder="请输入邮箱" maxlength="50" />
|
|
|
+ </el-form-item>
|
|
|
+ </el-col>
|
|
|
+ <el-col :span="12">
|
|
|
+ <el-form-item label="部门状态:">
|
|
|
+ <el-radio-group v-model="form.status">
|
|
|
+ <el-radio v-for="dict in sys_normal_disable" :key="dict.value" :value="dict.value">{{ dict.label }} </el-radio>
|
|
|
+ </el-radio-group>
|
|
|
+ </el-form-item>
|
|
|
+ </el-col>
|
|
|
+ </el-row>
|
|
|
+ </el-form>
|
|
|
+ <div class="common-dialog-footer" style="display: flex; justify-content: right">
|
|
|
<el-button type="primary" @click="submitForm">确 定</el-button>
|
|
|
<el-button @click="cancel">取 消</el-button>
|
|
|
</div>
|
|
|
- </template>
|
|
|
- </el-dialog>
|
|
|
+ </div>
|
|
|
+ </div>
|
|
|
</div>
|
|
|
</template>
|
|
|
|
|
|
<script setup name="Dept" lang="ts">
|
|
|
-import {listDept, getDept, delDept, addDept, updateDept, listDeptExcludeChild} from '@/api/system/dept';
|
|
|
-import {DeptForm, DeptQuery, DeptVO} from '@/api/system/dept/types';
|
|
|
-import {UserVO} from '@/api/system/user/types';
|
|
|
-import {listUserByDeptId} from '@/api/system/user';
|
|
|
+import { listDept, getDept, delDept, addDept, updateDept, listDeptExcludeChild } from '@/api/system/dept';
|
|
|
+import { DeptForm, DeptQuery, DeptVO } from '@/api/system/dept/types';
|
|
|
+import { UserVO } from '@/api/system/user/types';
|
|
|
+import { listUserByDeptId } from '@/api/system/user';
|
|
|
|
|
|
interface DeptOptionsType {
|
|
|
deptId: number | string;
|
|
@@ -155,8 +155,8 @@ interface DeptOptionsType {
|
|
|
children: DeptOptionsType[];
|
|
|
}
|
|
|
|
|
|
-const {proxy} = getCurrentInstance() as ComponentInternalInstance;
|
|
|
-const {sys_normal_disable} = toRefs<any>(proxy?.useDict('sys_normal_disable'));
|
|
|
+const { proxy } = getCurrentInstance() as ComponentInternalInstance;
|
|
|
+const { sys_normal_disable } = toRefs<any>(proxy?.useDict('sys_normal_disable'));
|
|
|
|
|
|
const deptList = ref<DeptVO[]>([]);
|
|
|
const loading = ref(true);
|
|
@@ -186,7 +186,7 @@ const initFormData: DeptForm = {
|
|
|
status: '0'
|
|
|
};
|
|
|
const initData: PageData<DeptForm, DeptQuery> = {
|
|
|
- form: {...initFormData},
|
|
|
+ form: { ...initFormData },
|
|
|
queryParams: {
|
|
|
pageNum: 1,
|
|
|
pageSize: 10,
|
|
@@ -195,16 +195,16 @@ const initData: PageData<DeptForm, DeptQuery> = {
|
|
|
status: undefined
|
|
|
},
|
|
|
rules: {
|
|
|
- parentId: [{required: true, message: '上级部门不能为空', trigger: 'blur'}],
|
|
|
- deptName: [{required: true, message: '部门名称不能为空', trigger: 'blur'}],
|
|
|
- orderNum: [{required: true, message: '显示排序不能为空', trigger: 'blur'}],
|
|
|
- email: [{type: 'email', message: '请输入正确的邮箱地址', trigger: ['blur', 'change']}],
|
|
|
- phone: [{pattern: /^1[3|4|5|6|7|8|9][0-9]\d{8}$/, message: '请输入正确的手机号码', trigger: 'blur'}]
|
|
|
+ parentId: [{ required: true, message: '上级部门不能为空', trigger: 'blur' }],
|
|
|
+ deptName: [{ required: true, message: '部门名称不能为空', trigger: 'blur' }],
|
|
|
+ orderNum: [{ required: true, message: '显示排序不能为空', trigger: 'blur' }],
|
|
|
+ email: [{ type: 'email', message: '请输入正确的邮箱地址', trigger: ['blur', 'change'] }],
|
|
|
+ phone: [{ pattern: /^1[3|4|5|6|7|8|9][0-9]\d{8}$/, message: '请输入正确的手机号码', trigger: 'blur' }]
|
|
|
}
|
|
|
};
|
|
|
const data = reactive<PageData<DeptForm, DeptQuery>>(initData);
|
|
|
|
|
|
-const {queryParams, form, rules} = toRefs<PageData<DeptForm, DeptQuery>>(data);
|
|
|
+const { queryParams, form, rules } = toRefs<PageData<DeptForm, DeptQuery>>(data);
|
|
|
|
|
|
/** 查询菜单列表 */
|
|
|
const getList = async () => {
|
|
@@ -232,7 +232,7 @@ const cancel = () => {
|
|
|
};
|
|
|
/** 表单重置 */
|
|
|
const reset = () => {
|
|
|
- form.value = {...initFormData};
|
|
|
+ form.value = { ...initFormData };
|
|
|
deptFormRef.value?.resetFields();
|
|
|
};
|
|
|
|