| 
									
										
										
										
											2024-09-09 19:30:57 +08:00
										 |  |  |  | <template> | 
					
						
							|  |  |  |  |   <div class="app-container"> | 
					
						
							|  |  |  |  |     <!-- 对话框(添加 / 修改) --> | 
					
						
							| 
									
										
										
										
											2024-09-18 14:12:35 +08:00
										 |  |  |  |     <el-dialog :title="dialogTitle" :visible.sync="dialogVisible" width="50%" v-dialogDrag append-to-body> | 
					
						
							| 
									
										
										
										
											2024-09-09 19:30:57 +08:00
										 |  |  |  |       <el-form ref="formRef" :model="formData" :rules="formRules" v-loading="formLoading" label-width="100px"> | 
					
						
							| 
									
										
										
										
											2024-09-12 18:37:51 +08:00
										 |  |  |  |         <el-row :gutter="20"> | 
					
						
							|  |  |  |  |           <el-col :span="12"> | 
					
						
							|  |  |  |  |             <el-form-item label="名称" prop="name"> | 
					
						
							|  |  |  |  |               <el-input v-model="formData.name" placeholder="请输入名称"/> | 
					
						
							|  |  |  |  |             </el-form-item> | 
					
						
							|  |  |  |  |           </el-col> | 
					
						
							|  |  |  |  |           <el-col :span="12"> | 
					
						
							|  |  |  |  |             <el-form-item label="编码" prop="code"> | 
					
						
							|  |  |  |  |               <el-input v-model="formData.code" placeholder="请输入编码"/> | 
					
						
							|  |  |  |  |             </el-form-item> | 
					
						
							|  |  |  |  |           </el-col> | 
					
						
							|  |  |  |  |         </el-row> | 
					
						
							|  |  |  |  |         <el-row :gutter="20"> | 
					
						
							|  |  |  |  |           <el-col :span="12"> | 
					
						
							|  |  |  |  |             <el-form-item label="成本" prop="cost"> | 
					
						
							| 
									
										
										
										
											2024-09-13 17:17:13 +08:00
										 |  |  |  |               <el-input-number v-model="formData.cost" :precision="2" :step="0.1" :max="10"></el-input-number> | 
					
						
							| 
									
										
										
										
											2024-09-12 18:37:51 +08:00
										 |  |  |  |             </el-form-item> | 
					
						
							|  |  |  |  |           </el-col> | 
					
						
							|  |  |  |  |           <el-col :span="12"> | 
					
						
							|  |  |  |  |             <el-form-item label="售价" prop="price"> | 
					
						
							| 
									
										
										
										
											2024-09-13 17:17:13 +08:00
										 |  |  |  |               <el-input-number v-model="formData.price" :precision="2" :step="0.1" :max="10"></el-input-number> | 
					
						
							| 
									
										
										
										
											2024-09-12 18:37:51 +08:00
										 |  |  |  |             </el-form-item> | 
					
						
							|  |  |  |  |           </el-col> | 
					
						
							|  |  |  |  |         </el-row> | 
					
						
							|  |  |  |  |         <el-row :gutter="20"> | 
					
						
							|  |  |  |  |           <el-col :span="12"> | 
					
						
							|  |  |  |  |             <el-form-item label="规格" prop="spec"> | 
					
						
							|  |  |  |  |               <el-input v-model="formData.spec" placeholder="请输入规格"/> | 
					
						
							|  |  |  |  |             </el-form-item> | 
					
						
							|  |  |  |  |           </el-col> | 
					
						
							|  |  |  |  |           <el-col :span="12"> | 
					
						
							|  |  |  |  |             <el-form-item label="单位" prop="unit"> | 
					
						
							| 
									
										
										
										
											2024-09-13 17:17:13 +08:00
										 |  |  |  |               <el-select v-model="formData.unit" placeholder="请选择单位"> | 
					
						
							|  |  |  |  |                 <el-option v-for="dict in this.getDictDatas(DICT_TYPE.REPAIR_UNIT)" | 
					
						
							|  |  |  |  |                            :key="dict.value" :label="dict.label" :value="dict.value"/> | 
					
						
							|  |  |  |  |               </el-select> | 
					
						
							| 
									
										
										
										
											2024-09-12 18:37:51 +08:00
										 |  |  |  |             </el-form-item> | 
					
						
							|  |  |  |  |           </el-col> | 
					
						
							|  |  |  |  |         </el-row> | 
					
						
							|  |  |  |  |         <el-row :gutter="20"> | 
					
						
							|  |  |  |  |           <el-col :span="12"> | 
					
						
							|  |  |  |  |             <el-form-item label="分类" prop="type"> | 
					
						
							| 
									
										
										
										
											2024-09-13 17:17:13 +08:00
										 |  |  |  |               <TreeSelect | 
					
						
							|  |  |  |  |                 v-model="formData.type" | 
					
						
							|  |  |  |  |                 :options="baseTypeTree" | 
					
						
							|  |  |  |  |                 :normalizer="normalizer" | 
					
						
							|  |  |  |  |                 placeholder="请选择分类" | 
					
						
							|  |  |  |  |               /> | 
					
						
							| 
									
										
										
										
											2024-09-12 18:37:51 +08:00
										 |  |  |  |             </el-form-item> | 
					
						
							|  |  |  |  |           </el-col> | 
					
						
							|  |  |  |  |           <el-col :span="12"> | 
					
						
							|  |  |  |  |             <el-form-item label="工时" prop="manHour"> | 
					
						
							|  |  |  |  |               <el-input v-model="formData.manHour" placeholder="请输入工时"/> | 
					
						
							|  |  |  |  |             </el-form-item> | 
					
						
							|  |  |  |  |           </el-col> | 
					
						
							|  |  |  |  |         </el-row> | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         <el-row :gutter="20"> | 
					
						
							|  |  |  |  |           <el-col :span="12"> | 
					
						
							|  |  |  |  |             <el-form-item label="是否自助" prop="isSelf"> | 
					
						
							| 
									
										
										
										
											2024-09-13 17:17:13 +08:00
										 |  |  |  |               <el-switch | 
					
						
							|  |  |  |  |                 v-model="formData.isSelf" | 
					
						
							|  |  |  |  |                 active-color="#13ce66" | 
					
						
							|  |  |  |  |                 inactive-color="#ff4949" | 
					
						
							|  |  |  |  |                 active-value="1" | 
					
						
							|  |  |  |  |                 inactive-value="0"> | 
					
						
							|  |  |  |  |               </el-switch> | 
					
						
							| 
									
										
										
										
											2024-09-12 18:37:51 +08:00
										 |  |  |  |             </el-form-item> | 
					
						
							|  |  |  |  |           </el-col> | 
					
						
							|  |  |  |  |           <el-col :span="12"> | 
					
						
							|  |  |  |  |             <el-form-item label="分店公用" prop="isPublic"> | 
					
						
							| 
									
										
										
										
											2024-09-13 17:17:13 +08:00
										 |  |  |  |               <el-switch | 
					
						
							|  |  |  |  |                 v-model="formData.isPublic" | 
					
						
							|  |  |  |  |                 active-color="#13ce66" | 
					
						
							|  |  |  |  |                 inactive-color="#ff4949" | 
					
						
							|  |  |  |  |                 active-value="1" | 
					
						
							|  |  |  |  |                 inactive-value="0"> | 
					
						
							|  |  |  |  |               </el-switch> | 
					
						
							| 
									
										
										
										
											2024-09-12 18:37:51 +08:00
										 |  |  |  |             </el-form-item> | 
					
						
							|  |  |  |  |           </el-col> | 
					
						
							|  |  |  |  |           <el-col :span="24"> | 
					
						
							|  |  |  |  |             <el-form-item label="备注" prop="remark"> | 
					
						
							|  |  |  |  |               <el-input type="textarea" v-model="formData.remark" placeholder="请输入备注"/> | 
					
						
							|  |  |  |  |             </el-form-item> | 
					
						
							|  |  |  |  |           </el-col> | 
					
						
							|  |  |  |  |         </el-row> | 
					
						
							| 
									
										
										
										
											2024-09-09 19:30:57 +08:00
										 |  |  |  |       </el-form> | 
					
						
							| 
									
										
										
										
											2024-09-12 18:37:51 +08:00
										 |  |  |  |       <div slot="footer" class="dialog-footer"> | 
					
						
							| 
									
										
										
										
											2024-09-09 19:30:57 +08:00
										 |  |  |  |         <el-button type="primary" @click="submitForm" :disabled="formLoading">确 定</el-button> | 
					
						
							|  |  |  |  |         <el-button @click="dialogVisible = false">取 消</el-button> | 
					
						
							|  |  |  |  |       </div> | 
					
						
							|  |  |  |  |     </el-dialog> | 
					
						
							|  |  |  |  |   </div> | 
					
						
							|  |  |  |  | </template> | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | <script> | 
					
						
							| 
									
										
										
										
											2024-09-12 18:37:51 +08:00
										 |  |  |  | import * as RepairProjectApi from '@/api/repair/project'; | 
					
						
							| 
									
										
										
										
											2024-09-13 17:17:13 +08:00
										 |  |  |  | import * as BaseTypeApi from '@/api/base/type'; | 
					
						
							|  |  |  |  | import TreeSelect from "@riophae/vue-treeselect"; | 
					
						
							|  |  |  |  | import "@riophae/vue-treeselect/dist/vue-treeselect.css"; | 
					
						
							| 
									
										
										
										
											2024-09-12 18:37:51 +08:00
										 |  |  |  | export default { | 
					
						
							|  |  |  |  |   name: "RepairProjectForm", | 
					
						
							| 
									
										
										
										
											2024-09-13 17:17:13 +08:00
										 |  |  |  |   components: {TreeSelect}, | 
					
						
							| 
									
										
										
										
											2024-09-12 18:37:51 +08:00
										 |  |  |  |   data() { | 
					
						
							|  |  |  |  |     return { | 
					
						
							|  |  |  |  |       // 弹出层标题
 | 
					
						
							|  |  |  |  |       dialogTitle: "", | 
					
						
							|  |  |  |  |       // 是否显示弹出层
 | 
					
						
							|  |  |  |  |       dialogVisible: false, | 
					
						
							|  |  |  |  |       // 表单的加载中:1)修改时的数据加载;2)提交的按钮禁用
 | 
					
						
							|  |  |  |  |       formLoading: false, | 
					
						
							|  |  |  |  |       // 表单参数
 | 
					
						
							|  |  |  |  |       formData: { | 
					
						
							|  |  |  |  |         id: undefined, | 
					
						
							|  |  |  |  |         name: undefined, | 
					
						
							|  |  |  |  |         cost: undefined, | 
					
						
							|  |  |  |  |         spec: undefined, | 
					
						
							|  |  |  |  |         price: undefined, | 
					
						
							|  |  |  |  |         code: undefined, | 
					
						
							|  |  |  |  |         unit: undefined, | 
					
						
							|  |  |  |  |         type: undefined, | 
					
						
							|  |  |  |  |         manHour: undefined, | 
					
						
							|  |  |  |  |         isSelf: undefined, | 
					
						
							| 
									
										
										
										
											2024-09-13 17:17:13 +08:00
										 |  |  |  |         isPublic: '0', | 
					
						
							|  |  |  |  |         remark: '0', | 
					
						
							| 
									
										
										
										
											2024-09-12 18:37:51 +08:00
										 |  |  |  |         corpId:'', | 
					
						
							|  |  |  |  |         corpIds:[], | 
					
						
							|  |  |  |  |       }, | 
					
						
							|  |  |  |  |       // 表单校验
 | 
					
						
							| 
									
										
										
										
											2024-09-13 17:17:13 +08:00
										 |  |  |  |       formRules: { | 
					
						
							|  |  |  |  |         // name: [{required: true, message: '项目名称不能为空', trigger: 'blur'}],
 | 
					
						
							|  |  |  |  |         // code: [{required: true, message: '编码不能为空', trigger: 'blur'}],
 | 
					
						
							|  |  |  |  |         // type: [{required: true, message: '分类不能为空', trigger: 'blur'}],
 | 
					
						
							|  |  |  |  |         // unit: [{required: true, message: '单位不能为空', trigger: 'blur'}],
 | 
					
						
							|  |  |  |  |       }, | 
					
						
							|  |  |  |  |       baseTypeTree:[], | 
					
						
							| 
									
										
										
										
											2024-09-12 18:37:51 +08:00
										 |  |  |  |     }; | 
					
						
							|  |  |  |  |   }, | 
					
						
							|  |  |  |  |   methods: { | 
					
						
							|  |  |  |  |     /** 打开弹窗 */ | 
					
						
							|  |  |  |  |     async open(id) { | 
					
						
							|  |  |  |  |       this.dialogVisible = true; | 
					
						
							|  |  |  |  |       this.reset(); | 
					
						
							|  |  |  |  |       // 修改时,设置数据
 | 
					
						
							|  |  |  |  |       if (id) { | 
					
						
							|  |  |  |  |         this.formLoading = true; | 
					
						
							| 
									
										
										
										
											2024-09-09 19:30:57 +08:00
										 |  |  |  |         try { | 
					
						
							| 
									
										
										
										
											2024-09-12 18:37:51 +08:00
										 |  |  |  |           const res = await RepairProjectApi.getRepairProject(id); | 
					
						
							|  |  |  |  |           this.formData = res.data; | 
					
						
							|  |  |  |  |           this.title = "修改维修项目"; | 
					
						
							| 
									
										
										
										
											2024-09-09 19:30:57 +08:00
										 |  |  |  |         } finally { | 
					
						
							|  |  |  |  |           this.formLoading = false; | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |       } | 
					
						
							| 
									
										
										
										
											2024-09-12 18:37:51 +08:00
										 |  |  |  |       this.title = "新增维修项目"; | 
					
						
							| 
									
										
										
										
											2024-09-13 17:17:13 +08:00
										 |  |  |  |       //获取类型树
 | 
					
						
							|  |  |  |  |       await this.getBaseTypeTree(); | 
					
						
							|  |  |  |  |     }, | 
					
						
							|  |  |  |  |     /** 获得配置类型树 */ | 
					
						
							|  |  |  |  |     async getBaseTypeTree() { | 
					
						
							|  |  |  |  |       this.baseTypeTree = []; | 
					
						
							|  |  |  |  |       let param = { | 
					
						
							| 
									
										
										
										
											2024-09-25 15:17:09 +08:00
										 |  |  |  |         type:'03' | 
					
						
							| 
									
										
										
										
											2024-09-13 17:17:13 +08:00
										 |  |  |  |       } | 
					
						
							|  |  |  |  |       const res = await BaseTypeApi.getBaseTypeList(param); | 
					
						
							|  |  |  |  |       const root = {id: 0, name: '顶级配置类型', children: []}; | 
					
						
							|  |  |  |  |       root.children = this.handleTree(res.data, 'id', 'parentId',"children","0") | 
					
						
							|  |  |  |  |       this.baseTypeTree.push(root) | 
					
						
							| 
									
										
										
										
											2024-09-12 18:37:51 +08:00
										 |  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-09-13 17:17:13 +08:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |     /** 转换配置类型数据结构 */ | 
					
						
							|  |  |  |  |     normalizer(node) { | 
					
						
							|  |  |  |  |       if (node.children && !node.children.length) { | 
					
						
							|  |  |  |  |         delete node.children; | 
					
						
							|  |  |  |  |       } | 
					
						
							|  |  |  |  |       return { | 
					
						
							|  |  |  |  |         id: node.id, | 
					
						
							|  |  |  |  |         label: node.name, | 
					
						
							|  |  |  |  |         children: node.children | 
					
						
							|  |  |  |  |       }; | 
					
						
							|  |  |  |  |     }, | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-09-12 18:37:51 +08:00
										 |  |  |  |     /** 提交按钮 */ | 
					
						
							|  |  |  |  |     async submitForm() { | 
					
						
							|  |  |  |  |       // 校验主表
 | 
					
						
							|  |  |  |  |       await this.$refs["formRef"].validate(); | 
					
						
							|  |  |  |  |       this.formLoading = true; | 
					
						
							|  |  |  |  |       try { | 
					
						
							|  |  |  |  |         const data = this.formData; | 
					
						
							|  |  |  |  |         // 修改的提交
 | 
					
						
							|  |  |  |  |         if (data.id) { | 
					
						
							|  |  |  |  |           await RepairProjectApi.updateRepairProject(data); | 
					
						
							|  |  |  |  |           this.$modal.msgSuccess("修改成功"); | 
					
						
							|  |  |  |  |           this.dialogVisible = false; | 
					
						
							| 
									
										
										
										
											2024-09-25 18:15:28 +08:00
										 |  |  |  |           this.$emit('success', this.formData.name); | 
					
						
							| 
									
										
										
										
											2024-09-12 18:37:51 +08:00
										 |  |  |  |           return; | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |         // 添加的提交
 | 
					
						
							| 
									
										
										
										
											2024-09-25 17:44:00 +08:00
										 |  |  |  |         const res = await RepairProjectApi.createRepairProject(data); | 
					
						
							| 
									
										
										
										
											2024-09-12 18:37:51 +08:00
										 |  |  |  |         this.$modal.msgSuccess("新增成功"); | 
					
						
							|  |  |  |  |         this.dialogVisible = false; | 
					
						
							| 
									
										
										
										
											2024-09-25 17:44:00 +08:00
										 |  |  |  |         this.$emit('success',res.data); | 
					
						
							| 
									
										
										
										
											2024-09-12 18:37:51 +08:00
										 |  |  |  |       } finally { | 
					
						
							|  |  |  |  |         this.formLoading = false; | 
					
						
							|  |  |  |  |       } | 
					
						
							|  |  |  |  |     }, | 
					
						
							|  |  |  |  |     /** 表单重置 */ | 
					
						
							|  |  |  |  |     reset() { | 
					
						
							|  |  |  |  |       this.formData = { | 
					
						
							|  |  |  |  |         id: undefined, | 
					
						
							|  |  |  |  |         name: undefined, | 
					
						
							|  |  |  |  |         cost: undefined, | 
					
						
							|  |  |  |  |         spec: undefined, | 
					
						
							|  |  |  |  |         price: undefined, | 
					
						
							|  |  |  |  |         code: undefined, | 
					
						
							|  |  |  |  |         unit: undefined, | 
					
						
							|  |  |  |  |         type: undefined, | 
					
						
							|  |  |  |  |         manHour: undefined, | 
					
						
							|  |  |  |  |         isSelf: undefined, | 
					
						
							| 
									
										
										
										
											2024-09-13 17:17:13 +08:00
										 |  |  |  |         isPublic: '0', | 
					
						
							|  |  |  |  |         remark: '0', | 
					
						
							| 
									
										
										
										
											2024-09-12 18:37:51 +08:00
										 |  |  |  |         corpId:'', | 
					
						
							|  |  |  |  |         corpIds:[], | 
					
						
							|  |  |  |  |       }; | 
					
						
							|  |  |  |  |       this.resetForm("formRef"); | 
					
						
							| 
									
										
										
										
											2024-09-09 19:30:57 +08:00
										 |  |  |  |     } | 
					
						
							| 
									
										
										
										
											2024-09-12 18:37:51 +08:00
										 |  |  |  |   } | 
					
						
							|  |  |  |  | }; | 
					
						
							| 
									
										
										
										
											2024-09-09 19:30:57 +08:00
										 |  |  |  | </script> |