fix:部门管理新增部门级别下拉
This commit is contained in:
		
							parent
							
								
									13f3e113f5
								
							
						
					
					
						commit
						34a57ae920
					
				| @ -1,6 +1,12 @@ | |||||||
| <template> | <template> | ||||||
|   <div class="app-container"> |   <div class="app-container"> | ||||||
|     <el-form :model="queryParams" ref="queryForm" size="small" :inline="true" v-show="showSearch"> |     <el-form | ||||||
|  |       :model="queryParams" | ||||||
|  |       ref="queryForm" | ||||||
|  |       size="small" | ||||||
|  |       :inline="true" | ||||||
|  |       v-show="showSearch" | ||||||
|  |     > | ||||||
|       <el-form-item label="部门名称" prop="deptName"> |       <el-form-item label="部门名称" prop="deptName"> | ||||||
|         <el-input |         <el-input | ||||||
|           v-model="queryParams.deptName" |           v-model="queryParams.deptName" | ||||||
| @ -10,7 +16,11 @@ | |||||||
|         /> |         /> | ||||||
|       </el-form-item> |       </el-form-item> | ||||||
|       <el-form-item label="状态" prop="status"> |       <el-form-item label="状态" prop="status"> | ||||||
|         <el-select v-model="queryParams.status" placeholder="部门状态" clearable> |         <el-select | ||||||
|  |           v-model="queryParams.status" | ||||||
|  |           placeholder="部门状态" | ||||||
|  |           clearable | ||||||
|  |         > | ||||||
|           <el-option |           <el-option | ||||||
|             v-for="dict in dict.type.sys_normal_disable" |             v-for="dict in dict.type.sys_normal_disable" | ||||||
|             :key="dict.value" |             :key="dict.value" | ||||||
| @ -20,8 +30,16 @@ | |||||||
|         </el-select> |         </el-select> | ||||||
|       </el-form-item> |       </el-form-item> | ||||||
|       <el-form-item> |       <el-form-item> | ||||||
|         <el-button type="primary" icon="el-icon-search" size="mini" @click="handleQuery">搜索</el-button> |         <el-button | ||||||
|         <el-button icon="el-icon-refresh" size="mini" @click="resetQuery">重置</el-button> |           type="primary" | ||||||
|  |           icon="el-icon-search" | ||||||
|  |           size="mini" | ||||||
|  |           @click="handleQuery" | ||||||
|  |           >搜索</el-button | ||||||
|  |         > | ||||||
|  |         <el-button icon="el-icon-refresh" size="mini" @click="resetQuery" | ||||||
|  |           >重置</el-button | ||||||
|  |         > | ||||||
|       </el-form-item> |       </el-form-item> | ||||||
|     </el-form> |     </el-form> | ||||||
| 
 | 
 | ||||||
| @ -34,7 +52,8 @@ | |||||||
|           size="mini" |           size="mini" | ||||||
|           @click="handleAdd" |           @click="handleAdd" | ||||||
|           v-hasPermi="['system:dept:add']" |           v-hasPermi="['system:dept:add']" | ||||||
|         >新增</el-button> |           >新增</el-button | ||||||
|  |         > | ||||||
|       </el-col> |       </el-col> | ||||||
|       <el-col :span="1.5"> |       <el-col :span="1.5"> | ||||||
|         <el-button |         <el-button | ||||||
| @ -43,9 +62,13 @@ | |||||||
|           icon="el-icon-sort" |           icon="el-icon-sort" | ||||||
|           size="mini" |           size="mini" | ||||||
|           @click="toggleExpandAll" |           @click="toggleExpandAll" | ||||||
|         >展开/折叠</el-button> |           >展开/折叠</el-button | ||||||
|  |         > | ||||||
|       </el-col> |       </el-col> | ||||||
|       <right-toolbar :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar> |       <right-toolbar | ||||||
|  |         :showSearch.sync="showSearch" | ||||||
|  |         @queryTable="getList" | ||||||
|  |       ></right-toolbar> | ||||||
|     </el-row> |     </el-row> | ||||||
| 
 | 
 | ||||||
|     <el-table |     <el-table | ||||||
| @ -54,21 +77,41 @@ | |||||||
|       :data="deptList" |       :data="deptList" | ||||||
|       row-key="deptId" |       row-key="deptId" | ||||||
|       :default-expand-all="isExpandAll" |       :default-expand-all="isExpandAll" | ||||||
|       :tree-props="{children: 'children', hasChildren: 'hasChildren'}" |       :tree-props="{ children: 'children', hasChildren: 'hasChildren' }" | ||||||
|     > |     > | ||||||
|       <el-table-column prop="deptName" label="部门名称" width="260"></el-table-column> |       <el-table-column | ||||||
|       <el-table-column prop="orderNum" label="排序" width="200"></el-table-column> |         prop="deptName" | ||||||
|  |         label="部门名称" | ||||||
|  |         width="260" | ||||||
|  |       ></el-table-column> | ||||||
|  |       <el-table-column | ||||||
|  |         prop="orderNum" | ||||||
|  |         label="排序" | ||||||
|  |         width="200" | ||||||
|  |       ></el-table-column> | ||||||
|       <el-table-column prop="status" label="状态" width="100"> |       <el-table-column prop="status" label="状态" width="100"> | ||||||
|         <template slot-scope="scope"> |         <template slot-scope="scope"> | ||||||
|           <dict-tag :options="dict.type.sys_normal_disable" :value="scope.row.status"/> |           <dict-tag | ||||||
|  |             :options="dict.type.sys_normal_disable" | ||||||
|  |             :value="scope.row.status" | ||||||
|  |           /> | ||||||
|         </template> |         </template> | ||||||
|       </el-table-column> |       </el-table-column> | ||||||
|       <el-table-column label="创建时间" align="center" prop="createTime" width="200"> |       <el-table-column | ||||||
|  |         label="创建时间" | ||||||
|  |         align="center" | ||||||
|  |         prop="createTime" | ||||||
|  |         width="200" | ||||||
|  |       > | ||||||
|         <template slot-scope="scope"> |         <template slot-scope="scope"> | ||||||
|           <span>{{ parseTime(scope.row.createTime) }}</span> |           <span>{{ parseTime(scope.row.createTime) }}</span> | ||||||
|         </template> |         </template> | ||||||
|       </el-table-column> |       </el-table-column> | ||||||
|       <el-table-column label="操作" align="center" class-name="small-padding fixed-width"> |       <el-table-column | ||||||
|  |         label="操作" | ||||||
|  |         align="center" | ||||||
|  |         class-name="small-padding fixed-width" | ||||||
|  |       > | ||||||
|         <template slot-scope="scope"> |         <template slot-scope="scope"> | ||||||
|           <el-button |           <el-button | ||||||
|             size="mini" |             size="mini" | ||||||
| @ -76,14 +119,16 @@ | |||||||
|             icon="el-icon-edit" |             icon="el-icon-edit" | ||||||
|             @click="handleUpdate(scope.row)" |             @click="handleUpdate(scope.row)" | ||||||
|             v-hasPermi="['system:dept:edit']" |             v-hasPermi="['system:dept:edit']" | ||||||
|           >修改</el-button> |             >修改</el-button | ||||||
|  |           > | ||||||
|           <el-button |           <el-button | ||||||
|             size="mini" |             size="mini" | ||||||
|             type="text" |             type="text" | ||||||
|             icon="el-icon-plus" |             icon="el-icon-plus" | ||||||
|             @click="handleAdd(scope.row)" |             @click="handleAdd(scope.row)" | ||||||
|             v-hasPermi="['system:dept:add']" |             v-hasPermi="['system:dept:add']" | ||||||
|           >新增</el-button> |             >新增</el-button | ||||||
|  |           > | ||||||
|           <el-button |           <el-button | ||||||
|             v-if="scope.row.parentId != 0" |             v-if="scope.row.parentId != 0" | ||||||
|             size="mini" |             size="mini" | ||||||
| @ -91,7 +136,8 @@ | |||||||
|             icon="el-icon-delete" |             icon="el-icon-delete" | ||||||
|             @click="handleDelete(scope.row)" |             @click="handleDelete(scope.row)" | ||||||
|             v-hasPermi="['system:dept:remove']" |             v-hasPermi="['system:dept:remove']" | ||||||
|           >删除</el-button> |             >删除</el-button | ||||||
|  |           > | ||||||
|         </template> |         </template> | ||||||
|       </el-table-column> |       </el-table-column> | ||||||
|     </el-table> |     </el-table> | ||||||
| @ -102,7 +148,12 @@ | |||||||
|         <el-row> |         <el-row> | ||||||
|           <el-col :span="24" v-if="form.parentId !== 0"> |           <el-col :span="24" v-if="form.parentId !== 0"> | ||||||
|             <el-form-item label="上级部门" prop="parentId"> |             <el-form-item label="上级部门" prop="parentId"> | ||||||
|               <treeselect v-model="form.parentId" :options="deptOptions" :normalizer="normalizer" placeholder="选择上级部门" /> |               <treeselect | ||||||
|  |                 v-model="form.parentId" | ||||||
|  |                 :options="deptOptions" | ||||||
|  |                 :normalizer="normalizer" | ||||||
|  |                 placeholder="选择上级部门" | ||||||
|  |               /> | ||||||
|             </el-form-item> |             </el-form-item> | ||||||
|           </el-col> |           </el-col> | ||||||
|         </el-row> |         </el-row> | ||||||
| @ -114,26 +165,42 @@ | |||||||
|           </el-col> |           </el-col> | ||||||
|           <el-col :span="12"> |           <el-col :span="12"> | ||||||
|             <el-form-item label="显示排序" prop="orderNum"> |             <el-form-item label="显示排序" prop="orderNum"> | ||||||
|               <el-input-number v-model="form.orderNum" controls-position="right" :min="0" /> |               <el-input-number | ||||||
|  |                 v-model="form.orderNum" | ||||||
|  |                 controls-position="right" | ||||||
|  |                 :min="0" | ||||||
|  |               /> | ||||||
|             </el-form-item> |             </el-form-item> | ||||||
|           </el-col> |           </el-col> | ||||||
|         </el-row> |         </el-row> | ||||||
|         <el-row> |         <el-row> | ||||||
|           <el-col :span="12"> |           <el-col :span="12"> | ||||||
|             <el-form-item label="负责人" prop="leader"> |             <el-form-item label="负责人" prop="leader"> | ||||||
|               <el-input v-model="form.leader" placeholder="请输入负责人" maxlength="20" /> |               <el-input | ||||||
|  |                 v-model="form.leader" | ||||||
|  |                 placeholder="请输入负责人" | ||||||
|  |                 maxlength="20" | ||||||
|  |               /> | ||||||
|             </el-form-item> |             </el-form-item> | ||||||
|           </el-col> |           </el-col> | ||||||
|           <el-col :span="12"> |           <el-col :span="12"> | ||||||
|             <el-form-item label="联系电话" prop="phone"> |             <el-form-item label="联系电话" prop="phone"> | ||||||
|               <el-input v-model="form.phone" placeholder="请输入联系电话" maxlength="11" /> |               <el-input | ||||||
|  |                 v-model="form.phone" | ||||||
|  |                 placeholder="请输入联系电话" | ||||||
|  |                 maxlength="11" | ||||||
|  |               /> | ||||||
|             </el-form-item> |             </el-form-item> | ||||||
|           </el-col> |           </el-col> | ||||||
|         </el-row> |         </el-row> | ||||||
|         <el-row> |         <el-row> | ||||||
|           <el-col :span="12"> |           <el-col :span="12"> | ||||||
|             <el-form-item label="邮箱" prop="email"> |             <el-form-item label="邮箱" prop="email"> | ||||||
|               <el-input v-model="form.email" placeholder="请输入邮箱" maxlength="50" /> |               <el-input | ||||||
|  |                 v-model="form.email" | ||||||
|  |                 placeholder="请输入邮箱" | ||||||
|  |                 maxlength="50" | ||||||
|  |               /> | ||||||
|             </el-form-item> |             </el-form-item> | ||||||
|           </el-col> |           </el-col> | ||||||
|           <el-col :span="12"> |           <el-col :span="12"> | ||||||
| @ -143,11 +210,27 @@ | |||||||
|                   v-for="dict in dict.type.sys_normal_disable" |                   v-for="dict in dict.type.sys_normal_disable" | ||||||
|                   :key="dict.value" |                   :key="dict.value" | ||||||
|                   :label="dict.value" |                   :label="dict.value" | ||||||
|                 >{{dict.label}}</el-radio> |                   >{{ dict.label }}</el-radio | ||||||
|  |                 > | ||||||
|               </el-radio-group> |               </el-radio-group> | ||||||
|             </el-form-item> |             </el-form-item> | ||||||
|           </el-col> |           </el-col> | ||||||
|         </el-row> |         </el-row> | ||||||
|  |         <el-row> | ||||||
|  |           <el-col :span="12"> | ||||||
|  |             <el-form-item label="部门级别" prop="deptLevel"> | ||||||
|  |               <el-select v-model="form.deptLevel" placeholder="请选择部门级别"> | ||||||
|  |                 <el-option | ||||||
|  |                   v-for="item in deftOptions" | ||||||
|  |                   :key="item.value" | ||||||
|  |                   :label="item.label" | ||||||
|  |                   :value="item.value" | ||||||
|  |                 > | ||||||
|  |                 </el-option> | ||||||
|  |               </el-select> | ||||||
|  |             </el-form-item> | ||||||
|  |           </el-col> | ||||||
|  |         </el-row> | ||||||
|       </el-form> |       </el-form> | ||||||
|       <div slot="footer" class="dialog-footer"> |       <div slot="footer" class="dialog-footer"> | ||||||
|         <el-button type="primary" @click="submitForm">确 定</el-button> |         <el-button type="primary" @click="submitForm">确 定</el-button> | ||||||
| @ -158,13 +241,20 @@ | |||||||
| </template> | </template> | ||||||
| 
 | 
 | ||||||
| <script> | <script> | ||||||
| import { listDept, getDept, delDept, addDept, updateDept, listDeptExcludeChild } from "@/api/system/dept"; | import { | ||||||
|  |   listDept, | ||||||
|  |   getDept, | ||||||
|  |   delDept, | ||||||
|  |   addDept, | ||||||
|  |   updateDept, | ||||||
|  |   listDeptExcludeChild, | ||||||
|  | } from "@/api/system/dept"; | ||||||
| import Treeselect from "@riophae/vue-treeselect"; | import Treeselect from "@riophae/vue-treeselect"; | ||||||
| import "@riophae/vue-treeselect/dist/vue-treeselect.css"; | import "@riophae/vue-treeselect/dist/vue-treeselect.css"; | ||||||
| 
 | 
 | ||||||
| export default { | export default { | ||||||
|   name: "Dept", |   name: "Dept", | ||||||
|   dicts: ['sys_normal_disable'], |   dicts: ["sys_normal_disable"], | ||||||
|   components: { Treeselect }, |   components: { Treeselect }, | ||||||
|   data() { |   data() { | ||||||
|     return { |     return { | ||||||
| @ -176,6 +266,17 @@ export default { | |||||||
|       deptList: [], |       deptList: [], | ||||||
|       // 部门树选项 |       // 部门树选项 | ||||||
|       deptOptions: [], |       deptOptions: [], | ||||||
|  |       // 部门级别下拉数据 | ||||||
|  |       deftOptions: [ | ||||||
|  |         { | ||||||
|  |           value: "分公司", | ||||||
|  |           label: "分公司", | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |           value: "管理站", | ||||||
|  |           label: "管理站", | ||||||
|  |         }, | ||||||
|  |       ], | ||||||
|       // 弹出层标题 |       // 弹出层标题 | ||||||
|       title: "", |       title: "", | ||||||
|       // 是否显示弹出层 |       // 是否显示弹出层 | ||||||
| @ -187,36 +288,39 @@ export default { | |||||||
|       // 查询参数 |       // 查询参数 | ||||||
|       queryParams: { |       queryParams: { | ||||||
|         deptName: undefined, |         deptName: undefined, | ||||||
|         status: undefined |         status: undefined, | ||||||
|       }, |       }, | ||||||
|       // 表单参数 |       // 表单参数 | ||||||
|       form: {}, |       form: {}, | ||||||
|       // 表单校验 |       // 表单校验 | ||||||
|       rules: { |       rules: { | ||||||
|         parentId: [ |         parentId: [ | ||||||
|           { required: true, message: "上级部门不能为空", trigger: "blur" } |           { required: true, message: "上级部门不能为空", trigger: "blur" }, | ||||||
|         ], |         ], | ||||||
|         deptName: [ |         deptName: [ | ||||||
|           { required: true, message: "部门名称不能为空", trigger: "blur" } |           { required: true, message: "部门名称不能为空", trigger: "blur" }, | ||||||
|         ], |         ], | ||||||
|         orderNum: [ |         orderNum: [ | ||||||
|           { required: true, message: "显示排序不能为空", trigger: "blur" } |           { required: true, message: "显示排序不能为空", trigger: "blur" }, | ||||||
|         ], |         ], | ||||||
|         email: [ |         email: [ | ||||||
|           { |           { | ||||||
|             type: "email", |             type: "email", | ||||||
|             message: "请输入正确的邮箱地址", |             message: "请输入正确的邮箱地址", | ||||||
|             trigger: ["blur", "change"] |             trigger: ["blur", "change"], | ||||||
|           } |           }, | ||||||
|         ], |         ], | ||||||
|         phone: [ |         phone: [ | ||||||
|           { |           { | ||||||
|             pattern: /^1[3|4|5|6|7|8|9][0-9]\d{8}$/, |             pattern: /^1[3|4|5|6|7|8|9][0-9]\d{8}$/, | ||||||
|             message: "请输入正确的手机号码", |             message: "请输入正确的手机号码", | ||||||
|             trigger: "blur" |             trigger: "blur", | ||||||
|           } |           }, | ||||||
|         ] |         ], | ||||||
|       } |         deptLevel: [ | ||||||
|  |           { required: true, message: "部门级别不能为空", trigger: "change" }, | ||||||
|  |         ], | ||||||
|  |       }, | ||||||
|     }; |     }; | ||||||
|   }, |   }, | ||||||
|   created() { |   created() { | ||||||
| @ -226,7 +330,7 @@ export default { | |||||||
|     /** 查询部门列表 */ |     /** 查询部门列表 */ | ||||||
|     getList() { |     getList() { | ||||||
|       this.loading = true; |       this.loading = true; | ||||||
|       listDept(this.queryParams).then(response => { |       listDept(this.queryParams).then((response) => { | ||||||
|         this.deptList = this.handleTree(response.data, "deptId"); |         this.deptList = this.handleTree(response.data, "deptId"); | ||||||
|         this.loading = false; |         this.loading = false; | ||||||
|       }); |       }); | ||||||
| @ -239,7 +343,7 @@ export default { | |||||||
|       return { |       return { | ||||||
|         id: node.deptId, |         id: node.deptId, | ||||||
|         label: node.deptName, |         label: node.deptName, | ||||||
|         children: node.children |         children: node.children, | ||||||
|       }; |       }; | ||||||
|     }, |     }, | ||||||
|     // 取消按钮 |     // 取消按钮 | ||||||
| @ -257,7 +361,8 @@ export default { | |||||||
|         leader: undefined, |         leader: undefined, | ||||||
|         phone: undefined, |         phone: undefined, | ||||||
|         email: undefined, |         email: undefined, | ||||||
|         status: "0" |         deptLevel: undefined, | ||||||
|  |         status: "0", | ||||||
|       }; |       }; | ||||||
|       this.resetForm("form"); |       this.resetForm("form"); | ||||||
|     }, |     }, | ||||||
| @ -278,7 +383,7 @@ export default { | |||||||
|       } |       } | ||||||
|       this.open = true; |       this.open = true; | ||||||
|       this.title = "添加部门"; |       this.title = "添加部门"; | ||||||
|       listDept().then(response => { |       listDept().then((response) => { | ||||||
|         this.deptOptions = this.handleTree(response.data, "deptId"); |         this.deptOptions = this.handleTree(response.data, "deptId"); | ||||||
|       }); |       }); | ||||||
|     }, |     }, | ||||||
| @ -293,31 +398,35 @@ export default { | |||||||
|     /** 修改按钮操作 */ |     /** 修改按钮操作 */ | ||||||
|     handleUpdate(row) { |     handleUpdate(row) { | ||||||
|       this.reset(); |       this.reset(); | ||||||
|       getDept(row.deptId).then(response => { |       getDept(row.deptId).then((response) => { | ||||||
|         this.form = response.data; |         this.form = response.data; | ||||||
|         this.open = true; |         this.open = true; | ||||||
|         this.title = "修改部门"; |         this.title = "修改部门"; | ||||||
|         listDeptExcludeChild(row.deptId).then(response => { |         listDeptExcludeChild(row.deptId).then((response) => { | ||||||
|           this.deptOptions = this.handleTree(response.data, "deptId"); |           this.deptOptions = this.handleTree(response.data, "deptId"); | ||||||
|           if (this.deptOptions.length == 0) { |           if (this.deptOptions.length == 0) { | ||||||
|             const noResultsOptions = { deptId: this.form.parentId, deptName: this.form.parentName, children: [] }; |             const noResultsOptions = { | ||||||
|  |               deptId: this.form.parentId, | ||||||
|  |               deptName: this.form.parentName, | ||||||
|  |               children: [], | ||||||
|  |             }; | ||||||
|             this.deptOptions.push(noResultsOptions); |             this.deptOptions.push(noResultsOptions); | ||||||
|           } |           } | ||||||
|         }); |         }); | ||||||
|       }); |       }); | ||||||
|     }, |     }, | ||||||
|     /** 提交按钮 */ |     /** 提交按钮 */ | ||||||
|     submitForm: function() { |     submitForm: function () { | ||||||
|       this.$refs["form"].validate(valid => { |       this.$refs["form"].validate((valid) => { | ||||||
|         if (valid) { |         if (valid) { | ||||||
|           if (this.form.deptId != undefined) { |           if (this.form.deptId != undefined) { | ||||||
|             updateDept(this.form).then(response => { |             updateDept(this.form).then((response) => { | ||||||
|               this.$modal.msgSuccess("修改成功"); |               this.$modal.msgSuccess("修改成功"); | ||||||
|               this.open = false; |               this.open = false; | ||||||
|               this.getList(); |               this.getList(); | ||||||
|             }); |             }); | ||||||
|           } else { |           } else { | ||||||
|             addDept(this.form).then(response => { |             addDept(this.form).then((response) => { | ||||||
|               this.$modal.msgSuccess("新增成功"); |               this.$modal.msgSuccess("新增成功"); | ||||||
|               this.open = false; |               this.open = false; | ||||||
|               this.getList(); |               this.getList(); | ||||||
| @ -328,13 +437,17 @@ export default { | |||||||
|     }, |     }, | ||||||
|     /** 删除按钮操作 */ |     /** 删除按钮操作 */ | ||||||
|     handleDelete(row) { |     handleDelete(row) { | ||||||
|       this.$modal.confirm('是否确认删除名称为"' + row.deptName + '"的数据项?').then(function() { |       this.$modal | ||||||
|         return delDept(row.deptId); |         .confirm('是否确认删除名称为"' + row.deptName + '"的数据项?') | ||||||
|       }).then(() => { |         .then(function () { | ||||||
|         this.getList(); |           return delDept(row.deptId); | ||||||
|         this.$modal.msgSuccess("删除成功"); |         }) | ||||||
|       }).catch(() => {}); |         .then(() => { | ||||||
|     } |           this.getList(); | ||||||
|   } |           this.$modal.msgSuccess("删除成功"); | ||||||
|  |         }) | ||||||
|  |         .catch(() => {}); | ||||||
|  |     }, | ||||||
|  |   }, | ||||||
| }; | }; | ||||||
| </script> | </script> | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user