维修工单及项目生命周期记录完善
This commit is contained in:
		
							parent
							
								
									742f1bde16
								
							
						
					
					
						commit
						dc3153b1af
					
				| @ -288,7 +288,6 @@ export default { | ||||
|             remark: item.remark | ||||
|           } | ||||
|         })] | ||||
|         console.log(this.formData) | ||||
|         await auditTicketWares(this.formData) | ||||
|         this.dialogVisible = false | ||||
|         this.$modal.msgSuccess("审核成功") | ||||
|  | ||||
| @ -1,12 +1,30 @@ | ||||
| <template> | ||||
|   <div class="app-container"> | ||||
|     <el-dialog title="流程记录" :visible.sync="dialogVisible" width="60%" v-dialogDrag append-to-body> | ||||
|       <el-form :model="formData" ref="formRef" :rules="formRules" :loading="formLoading" :inline="true" label-width="15rem"> | ||||
|       <el-row :gutter="1"> | ||||
|         <el-col :span="24"> | ||||
|           <span class="notice">{{ | ||||
|               projectList.length === 0 | ||||
|                 ? (this.formData.recordType === 'kssg' | ||||
|                     ? "没有项目可以施工" | ||||
|                     : (this.formData.recordType === 'sgz') | ||||
|                       ? "没有项目在施工中" | ||||
|                       : (this.formData.recordType === 'sgwczj' | ||||
|                           ? "没有项目可以完成" | ||||
|                           : '' | ||||
|                       ) | ||||
|                 ) | ||||
|                 : '' | ||||
|             }}</span> | ||||
|         </el-col> | ||||
|       </el-row> | ||||
|       <el-form :model="formData" ref="formRef" :rules="formRules" :loading="formLoading" :inline="true" | ||||
|                label-width="15rem"> | ||||
|         <el-row :gutter="1"> | ||||
|           <el-col :span="24"> | ||||
|             <el-form-item v-if="formData.recordType !== 'zj'" label="维修项目" prop="item.id"> | ||||
|               <el-select style="width: 20rem" v-model="formData.item.id" > | ||||
|                 <el-option v-for="item in projectList" :key="item.id" :label="item.itemName" :value="item.id" /> | ||||
|               <el-select style="width: 20rem" v-model="formData.item.id"> | ||||
|                 <el-option v-for="item in projectList" :key="item.id" :label="item.itemName" :value="item.id"/> | ||||
|               </el-select> | ||||
|             </el-form-item> | ||||
|           </el-col> | ||||
| @ -14,30 +32,41 @@ | ||||
|         <el-row :gutter="1"> | ||||
|           <el-col :span="24"> | ||||
|             <el-form-item label="描述" prop="remark"> | ||||
|               <el-input style="width: 30rem" type="textarea" v-model="formData.remark" :autosize="{ minRows: 4, maxRows: 8}"/> | ||||
|               <el-input style="width: 30rem" type="textarea" v-model="formData.remark" | ||||
|                         :autosize="{ minRows: 4, maxRows: 8}"/> | ||||
|             </el-form-item> | ||||
|           </el-col> | ||||
|         </el-row> | ||||
|         <el-row :gutter="1"> | ||||
|           <el-col :span="24"> | ||||
|             <el-form-item label="附件" prop="image"> | ||||
| <!--              <FileUpload v-model="formData.image" />--> | ||||
|               <ImageUpload v-model="formData.image" /> | ||||
|               <!--              <FileUpload v-model="formData.image" />--> | ||||
|               <ImageUpload v-model="formData.image"/> | ||||
|             </el-form-item> | ||||
|           </el-col> | ||||
|         </el-row> | ||||
|       </el-form> | ||||
|       <div slot="footer" class="dialog-footer"> | ||||
|         <el-button v-if="formData.recordType !== 'sgwczj'" type="primary" @click="doUpdate">确 定</el-button> | ||||
|         <el-button v-if="formData.recordType === 'sgwczj'" type="primary" @click="doUpdate">部分完成</el-button> | ||||
|         <el-button v-if="formData.recordType === 'sgwczj'" type="success" @click="doFinish"> | ||||
|           {{isNext ? "整体完成并指派下一项目" : (isEndCheck ? "整体完成并移交总检" : "整体完成")}} | ||||
|         <el-button v-if="formData.recordType !== 'sgwczj' && projectList.length > 0" type="primary" @click="doUpdate(null)">确 | ||||
|           定 | ||||
|         </el-button> | ||||
|         <el-button @click="dialogVisible = false">取 消</el-button> | ||||
|         <el-button v-if="formData.recordType === 'sgwczj' && projectList.length !== 0" type="primary" @click="doUpdate(null)"> | ||||
|           部分完成 | ||||
|         </el-button> | ||||
|         <el-button v-if="formData.recordType === 'sgwczj' && projectList.length !== 0" type="primary" @click="doFinish"> | ||||
|           完成并移交下一班组 | ||||
|         </el-button> | ||||
|         <el-button v-if="formData.recordType === 'sgwczj' && !isNext && projectList.length !== 0" type="primary" | ||||
|                    @click="doFinish"> | ||||
|           {{ isEndCheck ? "完成并移交总检" : "完成工单" }} | ||||
|         </el-button> | ||||
|         <!--        <el-button v-if="formData.recordType === 'sgwczj'" type="success" @click="doFinish">--> | ||||
|         <!--          {{isNext ? "整体完成并指派下一项目" : (isEndCheck ? "整体完成并移交总检" : "整体完成")}}--> | ||||
|         <!--        </el-button>--> | ||||
|       </div> | ||||
|     </el-dialog> | ||||
| 
 | ||||
|     <UpdateRepair ref="updateRepair" @success="doUpdate" /> | ||||
|     <UpdateRepair ref="updateRepair" @success="doUpdate"/> | ||||
|   </div> | ||||
| </template> | ||||
| 
 | ||||
| @ -49,16 +78,16 @@ import UpdateRepair from "@/views/repair/tickets/form/UpdateRepair.vue"; | ||||
| export default { | ||||
|   name: "UpdateRecord", | ||||
|   components: {UpdateRepair}, | ||||
|   data(){ | ||||
|   data() { | ||||
|     return { | ||||
|       dialogVisible: false, | ||||
|       formData:{ | ||||
|       formData: { | ||||
|         // 主表信息 | ||||
|         id: null, | ||||
|         ticketsWorkStatus: null, | ||||
|         remark: null, | ||||
|         // 子表信息 | ||||
|         item:{ | ||||
|         item: { | ||||
|           id: null, | ||||
|           itemStatus: null, | ||||
|         }, | ||||
| @ -66,8 +95,8 @@ export default { | ||||
|         image: null, | ||||
|         recordType: null, | ||||
|       }, | ||||
|       formRules:{ | ||||
|         'item.id':[{required: true, message: "维修项目不能为空", trigger: 'blur'}] | ||||
|       formRules: { | ||||
|         'item.id': [{required: true, message: "维修项目不能为空", trigger: 'blur'}] | ||||
|       }, | ||||
|       formLoading: false, | ||||
|       projectList: [], | ||||
| @ -78,104 +107,127 @@ export default { | ||||
|       clickRow: null | ||||
|     } | ||||
|   }, | ||||
|   methods:{ | ||||
|     init(){ | ||||
|   methods: { | ||||
|     init() { | ||||
|       this.formData = { | ||||
|         // 主表信息 | ||||
|         id: null, | ||||
|           ticketsWorkStatus: null, | ||||
|           remark: null, | ||||
|           // 子表信息 | ||||
|           item:{ | ||||
|         ticketsWorkStatus: null, | ||||
|         remark: null, | ||||
|         // 子表信息 | ||||
|         item: { | ||||
|           id: null, | ||||
|             itemStatus: null, | ||||
|           itemStatus: null, | ||||
|         }, | ||||
|         // 记录信息 | ||||
|         image: null, | ||||
|           recordType: null, | ||||
|         recordType: null, | ||||
|       } | ||||
|       this.projectList = [] | ||||
|       this.clickRow = null | ||||
|     }, | ||||
|     async open(row){ | ||||
|     async open(row) { | ||||
|       this.init() | ||||
|       this.clickRow = row | ||||
|       // 是否需要总检 | ||||
|       this.isEndCheck = row.endCheck === '1' | ||||
|       this.formData.id = row.id | ||||
|       this.formData.recordType = row.clickType | ||||
|       await this.listProject(row.id) | ||||
|       this.dialogVisible = true | ||||
|     }, | ||||
|     async listProject(ticketId){ | ||||
|     async listProject(ticketId) { | ||||
|       try { | ||||
|         this.formLoading = true | ||||
|         const res = await getProjectList(ticketId) | ||||
|         this.projectList = res.data | ||||
|         this.formData.ticketsWorkStatus = "02" | ||||
|         this.formData.item.itemStatus = "02" | ||||
|         if (this.formData.recordType === 'kssg') { | ||||
|           this.projectList = this.projectList.filter(item => item.itemStatus === '01') | ||||
|         }else if (this.formData.recordType === 'sgz'){ | ||||
|           this.projectList = this.projectList.filter(item => item.itemStatus === '02') | ||||
|         }else { | ||||
|           // 因为自己手里有一个项目,所以是>1 | ||||
|           this.isNext = this.projectList.filter(item => item.itemStatus !== '03').length > 1 | ||||
|         // 下面 01:未派工、02:施工中、03:已完成 | ||||
|         // 开始施工展示所有的项目,方便返工 | ||||
|         // 施工中的项目只展示施工中的项目,一是没施工就有施工记录不合理,二是防止项目太多员工选错,三已完成的项目需要重新就重新开始施工 | ||||
|         // 施工完成同施工中 | ||||
|         if (this.formData.recordType !== 'kssg') { | ||||
|           this.projectList = this.projectList.filter(item => item.itemStatus === '02') | ||||
|           // 施工完成需要特殊计算一些东西 | ||||
|           // 项目全完成需要总检、项目全完成不需要总检、项目没有全完成 | ||||
|           if (this.formData.recordType !== 'sgz') { | ||||
|             // 因为自己手里有一个项目,所以是>1 | ||||
|             this.isNext = this.projectList.filter(item => item.itemStatus !== '03').length > 1 | ||||
|           } | ||||
|         } | ||||
|       }finally { | ||||
|       } finally { | ||||
|         this.formLoading = false | ||||
|       } | ||||
|     }, | ||||
|     async doUpdate(){ | ||||
|     async doUpdate(nextName = null) { | ||||
|       try { | ||||
|         if (this.formData.recordType === 'zj'){ | ||||
|         if (nextName){ | ||||
|           this.formData['nextName'] = nextName | ||||
|         } | ||||
|         if (this.formData.recordType === 'zj') { | ||||
|           this.formData.ticketsWorkStatus = '03' | ||||
|           this.formData['isFinish'] = '1' | ||||
|         } | ||||
|         if (this.formData.recordType !== 'zj'){ | ||||
|         if (this.formData.recordType !== 'zj') { | ||||
|           await this.$refs.formRef.validate() | ||||
|           this.formLoading = true | ||||
|           await updateStatus(this.formData) | ||||
|           this.$modal.msgSuccess("操作成功") | ||||
|           if (!nextName) { | ||||
|             this.$modal.msgSuccess("操作成功") | ||||
|           } | ||||
|           this.dialogVisible = false | ||||
|           this.$emit("success") | ||||
|         }else { | ||||
|         } else { | ||||
|           this.formLoading = true | ||||
|           await updateStatus(this.formData) | ||||
|           this.$modal.msgSuccess("操作成功") | ||||
|           if (nextName) { | ||||
|             this.$modal.msgSuccess("操作成功") | ||||
|           } | ||||
|           this.dialogVisible = false | ||||
|           this.$emit("success") | ||||
|         } | ||||
|       }catch  { | ||||
|       } catch { | ||||
|       } | ||||
|     }, | ||||
|     async doFinish(){ | ||||
|       try{ | ||||
|     async doFinish() { | ||||
|       try { | ||||
|         await this.$refs.formRef.validate() | ||||
|         this.formLoading = true | ||||
|         // 不论是什么按钮,这个工单子项是完了的 | ||||
|         this.formData.item.itemStatus = "03" | ||||
|         // 整体完成并指派下一个人 | ||||
|         if (this.isNext){ | ||||
|         if (this.isNext) { | ||||
|           this.formData['finishType'] = "01" | ||||
|           await this.$refs.updateRepair.open(this.clickRow) | ||||
|           return | ||||
|         } | ||||
|         // 整体完成并移交总检 | ||||
|         if (this.isEndCheck){ | ||||
|         if (this.isEndCheck) { | ||||
|           this.formData['finishType'] = "02" | ||||
|           this.formData.ticketsWorkStatus = "05" | ||||
|           await this.doUpdate(); | ||||
|           return | ||||
|         } | ||||
|         // 整体完成,只有没有项目,不需要总检,这个工单才是完了 | ||||
|         this.formData.ticketsWorkStatus = "03" | ||||
|         this.formData['finishType'] = "03" | ||||
|         this.formData['isFinish'] = '1' | ||||
|         await this.doUpdate() | ||||
|       }catch{} | ||||
|       } catch { | ||||
|       } | ||||
|     } | ||||
|   } | ||||
| } | ||||
| </script> | ||||
| 
 | ||||
| <style scoped lang="scss"> | ||||
| 
 | ||||
| .notice { | ||||
|   display: inline-block; | ||||
|   width: 100%; | ||||
|   text-align: center; | ||||
|   margin: 1rem 0; | ||||
|   font-size: 18px; | ||||
|   color: red; | ||||
| } | ||||
| </style> | ||||
|  | ||||
| @ -208,7 +208,7 @@ export default { | ||||
|         await updateRepair(this.formData) | ||||
|         this.$modal.msgSuccess("指派成功") | ||||
|         this.dialogVisible = false | ||||
|         this.$emit("success") | ||||
|         this.$emit("success", this.formData.nowRepairName) | ||||
|       } catch { | ||||
| 
 | ||||
|       } | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 xiaofajia
						xiaofajia