| 
									
										
										
										
											2024-09-12 18:29:04 +08:00
										 |  |  | <template> | 
					
						
							|  |  |  |   <div> | 
					
						
							| 
									
										
										
										
											2024-09-25 15:42:23 +08:00
										 |  |  |     <el-row :gutter="24"> | 
					
						
							|  |  |  |       <el-col :span="17" style="padding-right: 0"> | 
					
						
							|  |  |  |         <el-card class="top-left"> | 
					
						
							|  |  |  |           <el-descriptions class="margin-top" :column="3" :size="'mini'" border> | 
					
						
							| 
									
										
										
										
											2024-09-29 18:13:07 +08:00
										 |  |  |             <template slot="extra"> | 
					
						
							| 
									
										
										
										
											2024-10-08 18:28:36 +08:00
										 |  |  |               <el-button v-if="createTicketType" type="success" size="small" @click="updateUserInfo(false)"> | 
					
						
							|  |  |  |                 新增客户信息 | 
					
						
							|  |  |  |               </el-button> | 
					
						
							|  |  |  |               <el-button v-if="createTicketType" type="primary" size="small" @click="updateUserInfo(true)" | 
					
						
							|  |  |  |                          :disabled="!selectUser.id"> | 
					
						
							| 
									
										
										
										
											2024-09-29 18:13:07 +08:00
										 |  |  |                 完善更多客户信息 | 
					
						
							|  |  |  |               </el-button> | 
					
						
							|  |  |  |             </template> | 
					
						
							| 
									
										
										
										
											2024-09-25 15:42:23 +08:00
										 |  |  |             <el-descriptions-item> | 
					
						
							|  |  |  |               <template slot="label"> | 
					
						
							|  |  |  |                 用户选择 | 
					
						
							|  |  |  |               </template> | 
					
						
							| 
									
										
										
										
											2024-10-08 18:28:36 +08:00
										 |  |  |               <UserChoose v-model="selectUser" :in-list="userInData"/> | 
					
						
							| 
									
										
										
										
											2024-09-25 15:42:23 +08:00
										 |  |  |             </el-descriptions-item> | 
					
						
							|  |  |  |             <el-descriptions-item> | 
					
						
							|  |  |  |               <template slot="label"> | 
					
						
							|  |  |  |                 车辆选择 | 
					
						
							|  |  |  |               </template> | 
					
						
							| 
									
										
										
										
											2024-10-08 18:28:36 +08:00
										 |  |  |               <CarChoose v-model="selectCar" :cus-name="selectUser.cusName" :in-list="carInData"/> | 
					
						
							| 
									
										
										
										
											2024-09-25 15:42:23 +08:00
										 |  |  |             </el-descriptions-item> | 
					
						
							|  |  |  |             <el-descriptions-item> | 
					
						
							|  |  |  |               <template slot="label"> | 
					
						
							|  |  |  |                 手机 | 
					
						
							|  |  |  |               </template> | 
					
						
							|  |  |  |               <el-input disabled v-model="selectUser.phoneNumber"/> | 
					
						
							|  |  |  |             </el-descriptions-item> | 
					
						
							|  |  |  |             <el-descriptions-item> | 
					
						
							|  |  |  |               <template slot="label"> | 
					
						
							|  |  |  |                 车架号 | 
					
						
							|  |  |  |               </template> | 
					
						
							|  |  |  |               <el-input disabled v-model="selectCar.vin"/> | 
					
						
							|  |  |  |             </el-descriptions-item> | 
					
						
							|  |  |  |             <el-descriptions-item> | 
					
						
							|  |  |  |               <template slot="label"> | 
					
						
							|  |  |  |                 品牌车系 | 
					
						
							|  |  |  |               </template> | 
					
						
							|  |  |  |               <el-input disabled v-model="selectCar.modelStr"/> | 
					
						
							|  |  |  |             </el-descriptions-item> | 
					
						
							|  |  |  |             <el-descriptions-item> | 
					
						
							|  |  |  |               <template slot="label"> | 
					
						
							|  |  |  |                 保险到期 | 
					
						
							|  |  |  |               </template> | 
					
						
							|  |  |  |               <el-date-picker disabled | 
					
						
							|  |  |  |                               v-model="selectCar.insuranceExpiryDate" | 
					
						
							|  |  |  |                               type="date"> | 
					
						
							|  |  |  |               </el-date-picker> | 
					
						
							|  |  |  |             </el-descriptions-item> | 
					
						
							|  |  |  |             <el-descriptions-item> | 
					
						
							|  |  |  |               <template slot="label"> | 
					
						
							|  |  |  |                 年检到期 | 
					
						
							|  |  |  |               </template> | 
					
						
							|  |  |  |               <el-date-picker disabled | 
					
						
							|  |  |  |                               v-model="selectCar.nextInspectionDate" | 
					
						
							|  |  |  |                               type="date"> | 
					
						
							|  |  |  |               </el-date-picker> | 
					
						
							|  |  |  |             </el-descriptions-item> | 
					
						
							|  |  |  |             <el-descriptions-item> | 
					
						
							|  |  |  |               <template slot="label"> | 
					
						
							|  |  |  |                 进厂时间 | 
					
						
							|  |  |  |               </template> | 
					
						
							|  |  |  |               <el-date-picker | 
					
						
							|  |  |  |                 v-model="formData.inTime" | 
					
						
							|  |  |  |                 type="date" | 
					
						
							|  |  |  |                 placeholder="选择日期"> | 
					
						
							|  |  |  |               </el-date-picker> | 
					
						
							|  |  |  |             </el-descriptions-item> | 
					
						
							|  |  |  |             <el-descriptions-item> | 
					
						
							|  |  |  |               <template slot="label"> | 
					
						
							|  |  |  |                 预计完工 | 
					
						
							|  |  |  |               </template> | 
					
						
							|  |  |  |               <el-date-picker | 
					
						
							|  |  |  |                 v-model="formData.outTime" | 
					
						
							|  |  |  |                 type="date" | 
					
						
							|  |  |  |                 placeholder="选择日期"> | 
					
						
							|  |  |  |               </el-date-picker> | 
					
						
							|  |  |  |             </el-descriptions-item> | 
					
						
							|  |  |  |             <el-descriptions-item> | 
					
						
							|  |  |  |               <template slot="label"> | 
					
						
							|  |  |  |                 上次里程 | 
					
						
							|  |  |  |               </template> | 
					
						
							|  |  |  |               <el-input v-model="selectCar.maintenanceMileage"/> | 
					
						
							|  |  |  |             </el-descriptions-item> | 
					
						
							|  |  |  |             <el-descriptions-item> | 
					
						
							|  |  |  |               <template slot="label"> | 
					
						
							|  |  |  |                 本次里程 | 
					
						
							|  |  |  |               </template> | 
					
						
							|  |  |  |               <el-input v-model="selectCar.newMaintenanceMileage"/> | 
					
						
							|  |  |  |             </el-descriptions-item> | 
					
						
							|  |  |  |             <el-descriptions-item> | 
					
						
							|  |  |  |               <template slot="label"> | 
					
						
							|  |  |  |                 预约订单选择 | 
					
						
							|  |  |  |               </template> | 
					
						
							|  |  |  |               <el-select v-model="formData.bookingId" size="small"> | 
					
						
							| 
									
										
										
										
											2024-09-25 17:34:42 +08:00
										 |  |  |                 <el-option v-for="item in bookingList" :key="item.id" :value="item.id" | 
					
						
							| 
									
										
										
										
											2024-09-26 10:42:40 +08:00
										 |  |  |                            :label="item.bookingTime"/> | 
					
						
							| 
									
										
										
										
											2024-09-25 15:42:23 +08:00
										 |  |  |               </el-select> | 
					
						
							|  |  |  |             </el-descriptions-item> | 
					
						
							|  |  |  |             <el-descriptions-item> | 
					
						
							|  |  |  |               <template slot="label"> | 
					
						
							|  |  |  |                 服务顾问 | 
					
						
							|  |  |  |               </template> | 
					
						
							| 
									
										
										
										
											2024-09-26 18:43:10 +08:00
										 |  |  |               <StaffChoose v-model="selectStaff" :is-get="'true'"/> | 
					
						
							| 
									
										
										
										
											2024-09-25 15:42:23 +08:00
										 |  |  |             </el-descriptions-item> | 
					
						
							|  |  |  |           </el-descriptions> | 
					
						
							|  |  |  |         </el-card> | 
					
						
							|  |  |  |       </el-col> | 
					
						
							|  |  |  |       <el-col :span="7" style="padding-left: 0"> | 
					
						
							| 
									
										
										
										
											2024-09-25 17:34:42 +08:00
										 |  |  |         <el-card style="margin-left: 0"> | 
					
						
							| 
									
										
										
										
											2024-09-25 15:42:23 +08:00
										 |  |  |           <div slot="header" class="clearfix"> | 
					
						
							|  |  |  |             <span style="font-weight: bold; font-size: 16px;"> 会员卡券</span> | 
					
						
							|  |  |  |           </div> | 
					
						
							|  |  |  |           <el-table | 
					
						
							|  |  |  |             :data="couponList" | 
					
						
							|  |  |  |             border | 
					
						
							|  |  |  |             size="mini" | 
					
						
							| 
									
										
										
										
											2024-09-29 18:13:07 +08:00
										 |  |  |             height="270" | 
					
						
							| 
									
										
										
										
											2024-09-25 15:42:23 +08:00
										 |  |  |             style="width: 100%"> | 
					
						
							| 
									
										
										
										
											2024-09-25 17:34:42 +08:00
										 |  |  |             <el-table-column prop="couponName" label="卡券名称"/> | 
					
						
							| 
									
										
										
										
											2024-09-25 15:42:23 +08:00
										 |  |  |             <el-table-column label="卡券类型" width="80" align="center" prop="couponType"> | 
					
						
							|  |  |  |               <template v-slot="scope"> | 
					
						
							|  |  |  |                 <dict-tag :type="DICT_TYPE.MEMBER_COUPON_TYPE" :value="scope.row.couponType"/> | 
					
						
							|  |  |  |               </template> | 
					
						
							|  |  |  |             </el-table-column> | 
					
						
							| 
									
										
										
										
											2024-09-25 17:34:42 +08:00
										 |  |  |             <el-table-column label="剩余金额/次数" width="120" align="right" prop="balance"> | 
					
						
							| 
									
										
										
										
											2024-09-25 15:42:23 +08:00
										 |  |  |               <template v-slot="scope"> | 
					
						
							| 
									
										
										
										
											2024-09-25 17:34:42 +08:00
										 |  |  |                 {{ scope.row.balance }}{{ scope.row.outRule == 'mehx' ? '元' : '次' }} | 
					
						
							| 
									
										
										
										
											2024-09-25 15:42:23 +08:00
										 |  |  |               </template> | 
					
						
							|  |  |  |             </el-table-column> | 
					
						
							|  |  |  |             <el-table-column label="适用车型" width="80" align="center" prop="carModel"> | 
					
						
							|  |  |  |               <template v-slot="scope"> | 
					
						
							|  |  |  |                 <span v-if="scope.row.carModel == null">不限</span> | 
					
						
							|  |  |  |                 <dict-tag :type="DICT_TYPE.MEMBER_CAR" :value="scope.row.carModel"/> | 
					
						
							|  |  |  |               </template> | 
					
						
							|  |  |  |             </el-table-column> | 
					
						
							|  |  |  |             <el-table-column label="核销规则" width="100" align="center" prop="outRule"> | 
					
						
							|  |  |  |               <template v-slot="scope"> | 
					
						
							|  |  |  |                 <dict-tag :type="DICT_TYPE.MEMBER_COUPON_OUT_RULE" :value="scope.row.outRule"/> | 
					
						
							|  |  |  |               </template> | 
					
						
							|  |  |  |             </el-table-column> | 
					
						
							|  |  |  |             <el-table-column label="开始有效期" align="center" prop="beginTime" width="150"> | 
					
						
							|  |  |  |               <template v-slot="scope"> | 
					
						
							|  |  |  |                 <span>{{ parseTime(scope.row.beginTime) }}</span> | 
					
						
							|  |  |  |               </template> | 
					
						
							|  |  |  |             </el-table-column> | 
					
						
							|  |  |  |             <el-table-column label="结束有效期" align="center" prop="endTime" width="150"> | 
					
						
							|  |  |  |               <template v-slot="scope"> | 
					
						
							|  |  |  |                 <span>{{ parseTime(scope.row.endTime) }}</span> | 
					
						
							|  |  |  |               </template> | 
					
						
							|  |  |  |             </el-table-column> | 
					
						
							|  |  |  |           </el-table> | 
					
						
							|  |  |  |         </el-card> | 
					
						
							|  |  |  |       </el-col> | 
					
						
							|  |  |  |     </el-row> | 
					
						
							| 
									
										
										
										
											2024-09-23 08:43:30 +08:00
										 |  |  |     <el-row :gutter="5" style="margin-bottom: 1rem"> | 
					
						
							|  |  |  |       <el-col v-if="createTicketType" :span="4.8"> | 
					
						
							| 
									
										
										
										
											2024-09-20 21:21:39 +08:00
										 |  |  |         <el-button size="small" @click="$refs['repairAdvice'].open()">维修建议</el-button> | 
					
						
							| 
									
										
										
										
											2024-09-12 18:29:04 +08:00
										 |  |  |       </el-col> | 
					
						
							| 
									
										
										
										
											2024-09-23 08:43:30 +08:00
										 |  |  |       <el-col v-if="createTicketType" :span="4.8"> | 
					
						
							| 
									
										
										
										
											2024-09-20 21:21:39 +08:00
										 |  |  |         <el-button size="small" @click="$refs['qualityExplain'].open()">质保说明</el-button> | 
					
						
							| 
									
										
										
										
											2024-09-12 18:29:04 +08:00
										 |  |  |       </el-col> | 
					
						
							| 
									
										
										
										
											2024-09-23 08:43:30 +08:00
										 |  |  |       <el-col v-if="createTicketType" :span="4.8"> | 
					
						
							| 
									
										
										
										
											2024-09-23 09:00:16 +08:00
										 |  |  |         <el-button size="small" v-if="formData.endCheck.toString() === '1'" @click="formData.endCheck = 0">终检 | 
					
						
							|  |  |  |         </el-button> | 
					
						
							|  |  |  |         <el-button size="small" v-if="formData.endCheck.toString() === '0'" @click="formData.endCheck = 1">不终检 | 
					
						
							|  |  |  |         </el-button> | 
					
						
							| 
									
										
										
										
											2024-09-12 18:29:04 +08:00
										 |  |  |       </el-col> | 
					
						
							| 
									
										
										
										
											2024-09-23 08:43:30 +08:00
										 |  |  |       <el-col v-if="createTicketType" :span="4.8"> | 
					
						
							| 
									
										
										
										
											2024-09-13 18:31:13 +08:00
										 |  |  |         <el-select v-model="formData.partDisposal" size="small"> | 
					
						
							| 
									
										
										
										
											2024-09-19 19:46:32 +08:00
										 |  |  |           <el-option v-for="item in this.getDictDatas(DICT_TYPE.REPAIR_PART_DISPOSAL)" :key="item.value" | 
					
						
							|  |  |  |                      :label="item.label" :value="item.value"/> | 
					
						
							| 
									
										
										
										
											2024-09-12 18:29:04 +08:00
										 |  |  |         </el-select> | 
					
						
							|  |  |  |       </el-col> | 
					
						
							| 
									
										
										
										
											2024-09-23 08:43:30 +08:00
										 |  |  |       <el-col v-if="createTicketType" :span="4.8"> | 
					
						
							| 
									
										
										
										
											2024-09-13 18:31:13 +08:00
										 |  |  |         <el-select v-model="formData.repairType" size="small"> | 
					
						
							| 
									
										
										
										
											2024-09-19 19:46:32 +08:00
										 |  |  |           <el-option v-for="item in this.getDictDatas(DICT_TYPE.REPAIR_TYPE)" :key="item.value" :label="item.label" | 
					
						
							|  |  |  |                      :value="item.value"/> | 
					
						
							| 
									
										
										
										
											2024-09-12 18:29:04 +08:00
										 |  |  |         </el-select> | 
					
						
							|  |  |  |       </el-col> | 
					
						
							| 
									
										
										
										
											2024-09-23 08:43:30 +08:00
										 |  |  |       <el-col :span="4"> | 
					
						
							|  |  |  |         <el-button size="small" v-if="formData.ticketType === '01'" @click="formData.ticketType = '02'">A单</el-button> | 
					
						
							|  |  |  |         <el-button size="small" v-if="formData.ticketType === '02'" @click="formData.ticketType = '01'">B单</el-button> | 
					
						
							|  |  |  |       </el-col> | 
					
						
							| 
									
										
										
										
											2024-09-12 18:29:04 +08:00
										 |  |  |     </el-row> | 
					
						
							| 
									
										
										
										
											2024-09-25 17:34:42 +08:00
										 |  |  |     <TicketItem item-type="project" :in-list-data="projectList" @tableData="projectData" ref="projectTable" | 
					
						
							|  |  |  |                 :coupon-list="couponList" @changeCoupon="changeCoupon"/> | 
					
						
							|  |  |  |     <TicketItem v-if="createTicketType" :in-list-data="partList" item-type="part" @tableData="partData" | 
					
						
							|  |  |  |                 :coupon-list="couponList" @changeCoupon="changeCoupon" | 
					
						
							| 
									
										
										
										
											2024-09-23 09:00:16 +08:00
										 |  |  |                 ref="partTable"/> | 
					
						
							| 
									
										
										
										
											2024-09-25 17:34:42 +08:00
										 |  |  |     <TicketItem v-if="createTicketType" :in-list-data="otherList" item-type="other" @tableData="otherData" | 
					
						
							|  |  |  |                 :coupon-list="couponList" @changeCoupon="changeCoupon" | 
					
						
							| 
									
										
										
										
											2024-09-23 09:00:16 +08:00
										 |  |  |                 ref="otherTable"/> | 
					
						
							| 
									
										
										
										
											2024-09-12 18:29:04 +08:00
										 |  |  |     <el-row :gutter="createTicketType ? 2 : 3" style="margin-top: 1rem"> | 
					
						
							|  |  |  |       <el-col :span="createTicketType ? 12 : 16"> | 
					
						
							| 
									
										
										
										
											2024-09-19 19:46:32 +08:00
										 |  |  |         <el-descriptions class="margin-top" :column="createTicketType ? 2 : 3" border :size="'medium'" | 
					
						
							|  |  |  |                          style="margin-bottom: 1rem"> | 
					
						
							| 
									
										
										
										
											2024-09-29 18:13:07 +08:00
										 |  |  |           <el-descriptions-item> | 
					
						
							|  |  |  |             <template slot="label"> | 
					
						
							|  |  |  |               工单号 | 
					
						
							|  |  |  |             </template> | 
					
						
							|  |  |  |             <TicketChoose @selected="getTickets"/> | 
					
						
							|  |  |  |           </el-descriptions-item> | 
					
						
							| 
									
										
										
										
											2024-09-12 18:29:04 +08:00
										 |  |  |           <el-descriptions-item> | 
					
						
							|  |  |  |             <template slot="label"> | 
					
						
							|  |  |  |               时间 | 
					
						
							|  |  |  |             </template> | 
					
						
							| 
									
										
										
										
											2024-09-19 19:46:32 +08:00
										 |  |  |             <el-date-picker | 
					
						
							|  |  |  |               v-model="formData.ticketTime" | 
					
						
							|  |  |  |               type="date" | 
					
						
							|  |  |  |               placeholder="选择日期"> | 
					
						
							|  |  |  |             </el-date-picker> | 
					
						
							| 
									
										
										
										
											2024-09-12 18:29:04 +08:00
										 |  |  |           </el-descriptions-item> | 
					
						
							|  |  |  |           <el-descriptions-item v-if="!createTicketType"> | 
					
						
							|  |  |  |             <template slot="label"> | 
					
						
							|  |  |  |               备注 | 
					
						
							|  |  |  |             </template> | 
					
						
							| 
									
										
										
										
											2024-09-22 21:38:20 +08:00
										 |  |  |             <el-input v-model="formData.remark"/> | 
					
						
							| 
									
										
										
										
											2024-09-12 18:29:04 +08:00
										 |  |  |           </el-descriptions-item> | 
					
						
							|  |  |  |         </el-descriptions> | 
					
						
							|  |  |  |       </el-col> | 
					
						
							|  |  |  |       <el-col v-if="createTicketType" :span="12"> | 
					
						
							|  |  |  |         <el-descriptions class="margin-top" :column="5" :size="'medium'" | 
					
						
							| 
									
										
										
										
											2024-09-19 19:46:32 +08:00
										 |  |  |                          style="margin-left: 1rem;margin-top: 1rem"> | 
					
						
							| 
									
										
										
										
											2024-09-20 16:21:46 +08:00
										 |  |  |           <el-descriptions-item label="数量">{{ formData.count }}</el-descriptions-item> | 
					
						
							|  |  |  |           <el-descriptions-item label="项目">{{ formData.projectPrice }}</el-descriptions-item> | 
					
						
							|  |  |  |           <el-descriptions-item label="配件">{{ formData.partPrice }}</el-descriptions-item> | 
					
						
							|  |  |  |           <el-descriptions-item label="附加">{{ formData.otherPrice }}</el-descriptions-item> | 
					
						
							|  |  |  |           <el-descriptions-item label="合计">{{ formData.totalPrice }}</el-descriptions-item> | 
					
						
							| 
									
										
										
										
											2024-09-12 18:29:04 +08:00
										 |  |  |         </el-descriptions> | 
					
						
							|  |  |  |       </el-col> | 
					
						
							|  |  |  |       <el-col v-else :span="8" style="margin-top:1rem;display: flex;justify-content: right"> | 
					
						
							|  |  |  |         <el-button type="danger">结算</el-button> | 
					
						
							| 
									
										
										
										
											2024-09-22 21:38:20 +08:00
										 |  |  |         <el-button type="warning" @click="handlePendingSave">挂单</el-button> | 
					
						
							| 
									
										
										
										
											2024-09-12 18:29:04 +08:00
										 |  |  |       </el-col> | 
					
						
							|  |  |  |     </el-row> | 
					
						
							|  |  |  |     <el-row v-if="createTicketType" :gutter="2"> | 
					
						
							|  |  |  |       <el-col :span="12"> | 
					
						
							|  |  |  |         <el-descriptions border class="margin-top" :column="1" :size="'medium'"> | 
					
						
							|  |  |  |           <el-descriptions-item> | 
					
						
							|  |  |  |             <template slot="label"> | 
					
						
							|  |  |  |               备注 | 
					
						
							|  |  |  |             </template> | 
					
						
							| 
									
										
										
										
											2024-09-20 16:21:46 +08:00
										 |  |  |             <el-input v-model="formData.remark"/> | 
					
						
							| 
									
										
										
										
											2024-09-12 18:29:04 +08:00
										 |  |  |           </el-descriptions-item> | 
					
						
							|  |  |  |         </el-descriptions> | 
					
						
							|  |  |  |       </el-col> | 
					
						
							|  |  |  |       <el-col :span="12" style="margin-top:1rem;display: flex;justify-content: right"> | 
					
						
							| 
									
										
										
										
											2024-09-25 17:34:42 +08:00
										 |  |  |         <el-button type="success" @click="handleSave" :disabled="isEnable">完成</el-button> | 
					
						
							|  |  |  |         <el-button type="danger" @click="handlePaid" :disabled="isEnable">结算</el-button> | 
					
						
							| 
									
										
										
										
											2024-09-23 09:00:16 +08:00
										 |  |  |         <!--        <el-button type="primary">通知施工</el-button>--> | 
					
						
							|  |  |  |         <!--        <el-button type="primary">领料</el-button>--> | 
					
						
							|  |  |  |         <!--        <el-button type="primary">退料</el-button>--> | 
					
						
							| 
									
										
										
										
											2024-09-12 18:29:04 +08:00
										 |  |  |       </el-col> | 
					
						
							|  |  |  |     </el-row> | 
					
						
							| 
									
										
										
										
											2024-09-20 21:21:39 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |     <RepairAdvice ref="repairAdvice" v-model="formData.repairAdvice"/> | 
					
						
							| 
									
										
										
										
											2024-09-23 09:00:16 +08:00
										 |  |  |     <QualityExplain ref="qualityExplain" v-model="formData.quality"/> | 
					
						
							| 
									
										
										
										
											2024-10-08 18:28:36 +08:00
										 |  |  |     <UserAndCarForm ref="userAndCarInfo" @success="successCusAndCar"/> | 
					
						
							| 
									
										
										
										
											2024-09-12 18:29:04 +08:00
										 |  |  |   </div> | 
					
						
							|  |  |  | </template> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | <script> | 
					
						
							|  |  |  | import UserChoose from "@/views/repair/Components/UserChoose.vue"; | 
					
						
							|  |  |  | import StaffChoose from "@/views/repair/Components/StaffChoose.vue"; | 
					
						
							|  |  |  | import TicketItem from "@/views/repair/tickets/Components/TicketItem.vue"; | 
					
						
							| 
									
										
										
										
											2024-09-19 19:46:32 +08:00
										 |  |  | import CarChoose from "@/views/repair/Components/CarChoose.vue"; | 
					
						
							| 
									
										
										
										
											2024-09-20 16:21:46 +08:00
										 |  |  | import {createUniqueCodeByHead} from "@/utils/createUniqueCode"; | 
					
						
							| 
									
										
										
										
											2024-09-21 20:42:56 +08:00
										 |  |  | import {createTickets, getTicketsById} from "@/api/repair/tickets/Tickets"; | 
					
						
							| 
									
										
										
										
											2024-09-20 21:21:39 +08:00
										 |  |  | import RepairAdvice from "@/views/repair/tickets/form/RepairAdvice.vue"; | 
					
						
							|  |  |  | import QualityExplain from "@/views/repair/tickets/form/QualityExplain.vue"; | 
					
						
							| 
									
										
										
										
											2024-09-21 20:42:56 +08:00
										 |  |  | import TicketChoose from "@/views/repair/tickets/Components/TicketChoose.vue"; | 
					
						
							| 
									
										
										
										
											2024-09-24 20:53:35 +08:00
										 |  |  | import request from "@/utils/request"; | 
					
						
							| 
									
										
										
										
											2024-09-25 15:42:23 +08:00
										 |  |  | import * as CustomerMainApi from "@/api/base/customer"; | 
					
						
							| 
									
										
										
										
											2024-09-29 18:13:07 +08:00
										 |  |  | import UserAndCarForm from "@/views/repair/tickets/form/UserAndCarForm.vue"; | 
					
						
							| 
									
										
										
										
											2024-10-08 18:28:36 +08:00
										 |  |  | import {getByNameAndMobile} from "@/api/base/customer"; | 
					
						
							|  |  |  | import {getByLicenseNumber} from "@/api/base/carmain"; | 
					
						
							| 
									
										
										
										
											2024-09-12 18:29:04 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | export default { | 
					
						
							|  |  |  |   name: "UserInfo", | 
					
						
							| 
									
										
										
										
											2024-09-29 18:13:07 +08:00
										 |  |  |   components: { | 
					
						
							|  |  |  |     UserAndCarForm, | 
					
						
							| 
									
										
										
										
											2024-10-08 18:28:36 +08:00
										 |  |  |     TicketChoose, QualityExplain, RepairAdvice, CarChoose, TicketItem, StaffChoose, UserChoose | 
					
						
							|  |  |  |   }, | 
					
						
							| 
									
										
										
										
											2024-09-19 19:46:32 +08:00
										 |  |  |   props: { | 
					
						
							|  |  |  |     createTicketType: { | 
					
						
							| 
									
										
										
										
											2024-09-12 18:29:04 +08:00
										 |  |  |       type: Boolean, | 
					
						
							|  |  |  |       required: true, | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   }, | 
					
						
							| 
									
										
										
										
											2024-09-19 19:46:32 +08:00
										 |  |  |   watch: { | 
					
						
							|  |  |  |     selectUser(val) { | 
					
						
							| 
									
										
										
										
											2024-09-25 17:34:42 +08:00
										 |  |  |       if (val) { | 
					
						
							| 
									
										
										
										
											2024-10-08 18:28:36 +08:00
										 |  |  |         if (!val.isRes) { | 
					
						
							|  |  |  |           this.selectCar = {} | 
					
						
							|  |  |  |           this.bookingList = [] | 
					
						
							|  |  |  |           this.couponList = [] | 
					
						
							|  |  |  |           if (val.userId) { | 
					
						
							|  |  |  |             this.getBooking(val.userId) | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |           if (val.id) { | 
					
						
							|  |  |  |             this.getCouponList(val.id) | 
					
						
							|  |  |  |           } | 
					
						
							| 
									
										
										
										
											2024-09-25 17:34:42 +08:00
										 |  |  |         } | 
					
						
							|  |  |  |       } else { | 
					
						
							|  |  |  |         this.selectCar = {} | 
					
						
							| 
									
										
										
										
											2024-09-25 15:42:23 +08:00
										 |  |  |         this.bookingList = [] | 
					
						
							|  |  |  |         this.couponList = [] | 
					
						
							| 
									
										
										
										
											2024-09-19 19:46:32 +08:00
										 |  |  |       } | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     selectCar(val) { | 
					
						
							|  |  |  |       if (!val) { | 
					
						
							|  |  |  |         this.selectCar = {} | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   }, | 
					
						
							| 
									
										
										
										
											2024-09-12 18:29:04 +08:00
										 |  |  |   data() { | 
					
						
							| 
									
										
										
										
											2024-09-13 18:31:13 +08:00
										 |  |  |     return { | 
					
						
							| 
									
										
										
										
											2024-09-25 17:34:42 +08:00
										 |  |  |       isEnable: false, | 
					
						
							| 
									
										
										
										
											2024-09-19 19:46:32 +08:00
										 |  |  |       formData: { | 
					
						
							| 
									
										
										
										
											2024-09-13 18:31:13 +08:00
										 |  |  |         endCheck: 1, | 
					
						
							| 
									
										
										
										
											2024-09-19 19:46:32 +08:00
										 |  |  |         partDisposal: '01', | 
					
						
							| 
									
										
										
										
											2024-09-13 18:31:13 +08:00
										 |  |  |         repairType: '01', | 
					
						
							| 
									
										
										
										
											2024-09-19 19:46:32 +08:00
										 |  |  |         ticketNo: null, | 
					
						
							|  |  |  |         remark: null, | 
					
						
							|  |  |  |         inTime: Date.now(), | 
					
						
							|  |  |  |         outTime: null, | 
					
						
							| 
									
										
										
										
											2024-09-20 16:21:46 +08:00
										 |  |  |         ticketTime: Date.now(), | 
					
						
							|  |  |  |         projectPrice: 0, | 
					
						
							|  |  |  |         partPrice: 0, | 
					
						
							|  |  |  |         otherPrice: 0, | 
					
						
							|  |  |  |         totalPrice: 0, | 
					
						
							|  |  |  |         count: 0, | 
					
						
							|  |  |  |         userId: null, | 
					
						
							|  |  |  |         userName: null, | 
					
						
							|  |  |  |         userMobile: null, | 
					
						
							|  |  |  |         carId: null, | 
					
						
							|  |  |  |         carNo: null, | 
					
						
							|  |  |  |         carVin: null, | 
					
						
							|  |  |  |         carBrandId: null, | 
					
						
							|  |  |  |         carBrandName: null, | 
					
						
							|  |  |  |         carBrandType: null, | 
					
						
							|  |  |  |         adviserId: null, | 
					
						
							|  |  |  |         adviserName: null, | 
					
						
							|  |  |  |         payType: null, | 
					
						
							|  |  |  |         repairAdvice: null, | 
					
						
							| 
									
										
										
										
											2024-09-20 21:21:39 +08:00
										 |  |  |         quality: { | 
					
						
							|  |  |  |           qualityMileage: 3000, | 
					
						
							|  |  |  |           qualityDay: 30 | 
					
						
							|  |  |  |         }, | 
					
						
							|  |  |  |         qualityMileage: null, | 
					
						
							|  |  |  |         qualityDay: null, | 
					
						
							| 
									
										
										
										
											2024-09-23 08:43:30 +08:00
										 |  |  |         ticketType: "01", | 
					
						
							| 
									
										
										
										
											2024-09-20 16:21:46 +08:00
										 |  |  |         itemList: [], | 
					
						
							| 
									
										
										
										
											2024-09-23 08:43:30 +08:00
										 |  |  |         ticketsStatus: "01", | 
					
						
							| 
									
										
										
										
											2024-09-24 20:53:35 +08:00
										 |  |  |         bookingId: null, | 
					
						
							| 
									
										
										
										
											2024-09-19 19:46:32 +08:00
										 |  |  |       }, | 
					
						
							|  |  |  |       selectUser: {}, | 
					
						
							|  |  |  |       selectCar: {}, | 
					
						
							|  |  |  |       selectStaff: {}, | 
					
						
							| 
									
										
										
										
											2024-09-20 16:21:46 +08:00
										 |  |  |       projectList: [], | 
					
						
							|  |  |  |       partList: [], | 
					
						
							| 
									
										
										
										
											2024-09-24 20:53:35 +08:00
										 |  |  |       otherList: [], | 
					
						
							|  |  |  |       bookingList: [], | 
					
						
							| 
									
										
										
										
											2024-09-25 15:42:23 +08:00
										 |  |  |       couponList: [], | 
					
						
							| 
									
										
										
										
											2024-10-08 18:28:36 +08:00
										 |  |  |       finaCouponList: [], | 
					
						
							|  |  |  |       userInData: null, | 
					
						
							|  |  |  |       carInData: null, | 
					
						
							| 
									
										
										
										
											2024-09-13 18:31:13 +08:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2024-09-12 18:29:04 +08:00
										 |  |  |   }, | 
					
						
							| 
									
										
										
										
											2024-09-13 18:31:13 +08:00
										 |  |  |   methods: { | 
					
						
							| 
									
										
										
										
											2024-09-25 17:34:42 +08:00
										 |  |  |     async getCouponList(id) { | 
					
						
							| 
									
										
										
										
											2024-09-25 15:42:23 +08:00
										 |  |  |       const res = await CustomerMainApi.getCustomerMain(id); | 
					
						
							|  |  |  |       this.couponList = res.data.couponList | 
					
						
							|  |  |  |       this.finaCouponList = [ | 
					
						
							|  |  |  |         ...this.couponList, | 
					
						
							|  |  |  |       ] | 
					
						
							|  |  |  |       this.finaCouponList.map(item => item["isChoose"] = false) | 
					
						
							|  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-09-20 16:21:46 +08:00
										 |  |  |     projectData(data) { | 
					
						
							|  |  |  |       // 去掉最后一行
 | 
					
						
							|  |  |  |       this.projectList = [...data] | 
					
						
							|  |  |  |       this.projectList.pop() | 
					
						
							|  |  |  |       // 通知计算
 | 
					
						
							|  |  |  |       this.computedData() | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     partData(data) { | 
					
						
							|  |  |  |       // 去掉最后一行
 | 
					
						
							|  |  |  |       this.partList = [...data] | 
					
						
							|  |  |  |       this.partList.pop() | 
					
						
							|  |  |  |       // 通知计算
 | 
					
						
							|  |  |  |       this.computedData() | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     otherData(data) { | 
					
						
							|  |  |  |       // 去掉最后一行
 | 
					
						
							|  |  |  |       this.otherList = [...data] | 
					
						
							|  |  |  |       this.otherList.pop() | 
					
						
							|  |  |  |       // 通知计算
 | 
					
						
							|  |  |  |       this.computedData() | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     computedData() { | 
					
						
							|  |  |  |       const data = this.formData | 
					
						
							|  |  |  |       this.formData = { | 
					
						
							|  |  |  |         ...data, | 
					
						
							|  |  |  |         projectPrice: 0, | 
					
						
							|  |  |  |         partPrice: 0, | 
					
						
							|  |  |  |         otherPrice: 0, | 
					
						
							|  |  |  |         totalPrice: 0, | 
					
						
							|  |  |  |         count: 0 | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       // 项目
 | 
					
						
							|  |  |  |       if (this.projectList) { | 
					
						
							|  |  |  |         this.formData.projectPrice = this.computeByItem(this.projectList) | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       // 配件
 | 
					
						
							|  |  |  |       if (this.partList) { | 
					
						
							|  |  |  |         this.formData.partPrice = this.computeByItem(this.partList) | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       // 其他
 | 
					
						
							|  |  |  |       if (this.otherList) { | 
					
						
							|  |  |  |         this.formData.otherPrice = this.computeByItem(this.otherList) | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     computeByItem(item) { | 
					
						
							|  |  |  |       const count = item.reduce((x, y) => { | 
					
						
							|  |  |  |         return x + y.count | 
					
						
							|  |  |  |       }, 0) | 
					
						
							|  |  |  |       const totalPrice = item.reduce((x, y) => { | 
					
						
							|  |  |  |         return x + y.totalPrice | 
					
						
							|  |  |  |       }, 0) | 
					
						
							|  |  |  |       this.formData.count += parseInt(count) | 
					
						
							|  |  |  |       this.formData.totalPrice += parseFloat(totalPrice) | 
					
						
							|  |  |  |       return parseFloat(totalPrice) | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     // 登记保存
 | 
					
						
							|  |  |  |     async handleSave() { | 
					
						
							| 
									
										
										
										
											2024-09-25 17:34:42 +08:00
										 |  |  |       this.isEnable = true | 
					
						
							| 
									
										
										
										
											2024-09-20 16:21:46 +08:00
										 |  |  |       this.createInit() | 
					
						
							|  |  |  |       this.createItemInit() | 
					
						
							|  |  |  |       try { | 
					
						
							| 
									
										
										
										
											2024-09-20 21:21:39 +08:00
										 |  |  |         await createTickets(this.formData) | 
					
						
							| 
									
										
										
										
											2024-09-20 16:21:46 +08:00
										 |  |  |         this.$modal.msgSuccess("新增成功") | 
					
						
							|  |  |  |         this.init() | 
					
						
							| 
									
										
										
										
											2024-09-23 09:00:16 +08:00
										 |  |  |       } catch { | 
					
						
							|  |  |  |       } finally { | 
					
						
							| 
									
										
										
										
											2024-09-20 21:21:39 +08:00
										 |  |  |         this.formData.ticketNo = null | 
					
						
							| 
									
										
										
										
											2024-09-25 17:34:42 +08:00
										 |  |  |         this.isEnable = false | 
					
						
							| 
									
										
										
										
											2024-09-20 21:21:39 +08:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2024-09-20 16:21:46 +08:00
										 |  |  |     }, | 
					
						
							|  |  |  |     // 初始化
 | 
					
						
							| 
									
										
										
										
											2024-09-23 09:00:16 +08:00
										 |  |  |     init() { | 
					
						
							| 
									
										
										
										
											2024-09-20 16:21:46 +08:00
										 |  |  |       this.formData = { | 
					
						
							|  |  |  |         endCheck: 1, | 
					
						
							|  |  |  |         partDisposal: '01', | 
					
						
							|  |  |  |         repairType: '01', | 
					
						
							|  |  |  |         ticketNo: null, | 
					
						
							|  |  |  |         remark: null, | 
					
						
							|  |  |  |         inTime: Date.now(), | 
					
						
							|  |  |  |         outTime: null, | 
					
						
							|  |  |  |         ticketTime: Date.now(), | 
					
						
							|  |  |  |         projectPrice: 0, | 
					
						
							|  |  |  |         partPrice: 0, | 
					
						
							|  |  |  |         otherPrice: 0, | 
					
						
							|  |  |  |         totalPrice: 0, | 
					
						
							|  |  |  |         count: 0, | 
					
						
							|  |  |  |         userId: null, | 
					
						
							|  |  |  |         userName: null, | 
					
						
							|  |  |  |         userMobile: null, | 
					
						
							|  |  |  |         carId: null, | 
					
						
							|  |  |  |         carNo: null, | 
					
						
							|  |  |  |         carVin: null, | 
					
						
							|  |  |  |         carBrandId: null, | 
					
						
							|  |  |  |         carBrandName: null, | 
					
						
							|  |  |  |         carBrandType: null, | 
					
						
							|  |  |  |         adviserId: null, | 
					
						
							|  |  |  |         adviserName: null, | 
					
						
							|  |  |  |         payType: null, | 
					
						
							|  |  |  |         repairAdvice: null, | 
					
						
							| 
									
										
										
										
											2024-09-20 21:21:39 +08:00
										 |  |  |         quality: { | 
					
						
							|  |  |  |           qualityMileage: 3000, | 
					
						
							|  |  |  |           qualityDay: 30 | 
					
						
							|  |  |  |         }, | 
					
						
							|  |  |  |         qualityMileage: null, | 
					
						
							|  |  |  |         qualityDay: null, | 
					
						
							| 
									
										
										
										
											2024-09-20 16:21:46 +08:00
										 |  |  |         ticketType: null, | 
					
						
							|  |  |  |         itemList: [], | 
					
						
							| 
									
										
										
										
											2024-09-21 20:42:56 +08:00
										 |  |  |         ticketStatus: "01" | 
					
						
							| 
									
										
										
										
											2024-09-20 16:21:46 +08:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2024-09-23 09:00:16 +08:00
										 |  |  |       this.selectUser = {} | 
					
						
							| 
									
										
										
										
											2024-09-20 16:21:46 +08:00
										 |  |  |       this.selectCar = {} | 
					
						
							|  |  |  |       this.selectStaff = {} | 
					
						
							|  |  |  |       this.projectList = [] | 
					
						
							|  |  |  |       this.partList = [] | 
					
						
							|  |  |  |       this.otherList = [] | 
					
						
							| 
									
										
										
										
											2024-09-20 21:21:39 +08:00
										 |  |  |       this.resetTable() | 
					
						
							|  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-09-23 09:00:16 +08:00
										 |  |  |     resetTable() { | 
					
						
							| 
									
										
										
										
											2024-09-20 21:21:39 +08:00
										 |  |  |       this.$refs['projectTable'].resetTable() | 
					
						
							|  |  |  |       this.$refs['partTable'].resetTable() | 
					
						
							|  |  |  |       this.$refs['otherTable'].resetTable() | 
					
						
							| 
									
										
										
										
											2024-09-20 16:21:46 +08:00
										 |  |  |     }, | 
					
						
							|  |  |  |     // 新增基础信息init
 | 
					
						
							|  |  |  |     createInit() { | 
					
						
							| 
									
										
										
										
											2024-10-10 17:04:17 +08:00
										 |  |  |       this.formData.bookingId = this.formData?.bookingId?.toString() || null | 
					
						
							| 
									
										
										
										
											2024-09-20 16:21:46 +08:00
										 |  |  |       // 生成工单号
 | 
					
						
							| 
									
										
										
										
											2024-09-21 20:42:56 +08:00
										 |  |  |       this.formData.ticketNo = this.formData.ticketNo || createUniqueCodeByHead("GD") | 
					
						
							| 
									
										
										
										
											2024-09-20 21:21:39 +08:00
										 |  |  |       // 质保说明
 | 
					
						
							|  |  |  |       this.formData.qualityMileage = this.formData.quality.qualityMileage | 
					
						
							|  |  |  |       this.formData.qualityDay = this.formData.quality.qualityDay | 
					
						
							| 
									
										
										
										
											2024-09-20 16:21:46 +08:00
										 |  |  |       // 选择的用户
 | 
					
						
							| 
									
										
										
										
											2024-09-21 20:42:56 +08:00
										 |  |  |       this.formData.userId = this.selectUser?.id | 
					
						
							| 
									
										
										
										
											2024-09-20 16:21:46 +08:00
										 |  |  |       this.formData.userName = this.selectUser?.cusName | 
					
						
							|  |  |  |       this.formData.userMobile = this.selectUser?.phoneNumber | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       // 选择的车辆
 | 
					
						
							|  |  |  |       this.formData.carId = this.selectCar?.id | 
					
						
							|  |  |  |       this.formData.carNo = this.selectCar?.licenseNumber | 
					
						
							|  |  |  |       this.formData.carVin = this.selectCar?.vin | 
					
						
							|  |  |  |       this.formData.carBrandId = this.selectCar?.carBrand | 
					
						
							|  |  |  |       this.formData.carBrandName = this.selectCar?.brandStr | 
					
						
							|  |  |  |       this.formData.carBrandType = this.selectCar?.brandType | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       // 服务顾问
 | 
					
						
							|  |  |  |       this.formData.adviserId = this.selectStaff?.id | 
					
						
							|  |  |  |       this.formData.adviserName = this.selectStaff?.name | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     // 新增子表信息init
 | 
					
						
							|  |  |  |     createItemInit() { | 
					
						
							|  |  |  |       // 项目
 | 
					
						
							|  |  |  |       this.formData.itemList = [...this.formData.itemList, ...this.formatItem("project", this.projectList)] | 
					
						
							|  |  |  |       // 配件
 | 
					
						
							|  |  |  |       this.formData.itemList = [...this.formData.itemList, ...this.formatItem("part", this.partList)] | 
					
						
							|  |  |  |       // 其他
 | 
					
						
							|  |  |  |       this.formData.itemList = [...this.formData.itemList, ...this.formatItem("other", this.otherList)] | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     // 子表信息预处理
 | 
					
						
							|  |  |  |     formatItem(type, list) { | 
					
						
							| 
									
										
										
										
											2024-09-23 09:00:16 +08:00
										 |  |  |       if (!(list && list.length > 0)) { | 
					
						
							| 
									
										
										
										
											2024-09-20 16:21:46 +08:00
										 |  |  |         return [] | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       return list.map(item => { | 
					
						
							|  |  |  |         const temp = { | 
					
						
							|  |  |  |           ...item, | 
					
						
							|  |  |  |           itemName: item.name, | 
					
						
							| 
									
										
										
										
											2024-09-21 20:42:56 +08:00
										 |  |  |           itemCount: item?.count, | 
					
						
							| 
									
										
										
										
											2024-09-20 16:21:46 +08:00
										 |  |  |           itemUnit: item.unit, | 
					
						
							|  |  |  |           itemPrice: item.price, | 
					
						
							|  |  |  |           itemDiscount: item.discount, | 
					
						
							|  |  |  |           itemMoney: item.totalPrice, | 
					
						
							| 
									
										
										
										
											2024-10-12 20:06:56 +08:00
										 |  |  |           repairIds: item?.repair.map(i => i.userId).join(','), | 
					
						
							| 
									
										
										
										
											2024-10-12 12:30:30 +08:00
										 |  |  |           repairNames: item?.repair.map(i => i.userName).join(','), | 
					
						
							| 
									
										
										
										
											2024-09-20 16:21:46 +08:00
										 |  |  |           saleId: item?.sale?.id, | 
					
						
							|  |  |  |           saleName: item?.sale?.name, | 
					
						
							|  |  |  |           itemTypeId: item?.type?.id, | 
					
						
							|  |  |  |           remark: item.remark, | 
					
						
							|  |  |  |           itemStatus: item.itemStatus, | 
					
						
							| 
									
										
										
										
											2024-09-20 21:21:39 +08:00
										 |  |  |           id: null | 
					
						
							| 
									
										
										
										
											2024-09-20 16:21:46 +08:00
										 |  |  |         } | 
					
						
							|  |  |  |         switch (type) { | 
					
						
							|  |  |  |           case 'project': | 
					
						
							|  |  |  |             temp['itemType'] = "01" | 
					
						
							|  |  |  |             break; | 
					
						
							|  |  |  |           case 'part': | 
					
						
							|  |  |  |             temp['itemType'] = "02" | 
					
						
							|  |  |  |             break; | 
					
						
							|  |  |  |           case 'other': | 
					
						
							|  |  |  |             temp['itemType'] = "03" | 
					
						
							|  |  |  |             break; | 
					
						
							|  |  |  |           default: | 
					
						
							|  |  |  |             return ""; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         temp[type + 'Id'] = item.id | 
					
						
							|  |  |  |         return temp; | 
					
						
							|  |  |  |       }) | 
					
						
							| 
									
										
										
										
											2024-09-20 21:21:39 +08:00
										 |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-09-21 20:42:56 +08:00
										 |  |  |     // 查看工单
 | 
					
						
							| 
									
										
										
										
											2024-09-23 09:00:16 +08:00
										 |  |  |     async getTickets(id) { | 
					
						
							| 
									
										
										
										
											2024-09-21 20:42:56 +08:00
										 |  |  |       try { | 
					
						
							|  |  |  |         const res = await getTicketsById(id) | 
					
						
							| 
									
										
										
										
											2024-09-23 09:00:16 +08:00
										 |  |  |         const data = res.data | 
					
						
							| 
									
										
										
										
											2024-09-21 20:42:56 +08:00
										 |  |  |         this.formData = { | 
					
						
							|  |  |  |           ...data, | 
					
						
							| 
									
										
										
										
											2024-09-26 18:23:54 +08:00
										 |  |  |           cusName: data.userName, | 
					
						
							|  |  |  |           id: data.userId, | 
					
						
							|  |  |  |           phoneNumber: data.userMobile, | 
					
						
							| 
									
										
										
										
											2024-09-21 20:42:56 +08:00
										 |  |  |           quality: {qualityMileage: data.qualityMileage, qualityDay: data.qualityDay} | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         const itemList = this.formData.itemList | 
					
						
							|  |  |  |         this.selectUser = {id: data.userId} | 
					
						
							|  |  |  |         this.selectCar = {id: data.carId} | 
					
						
							|  |  |  |         this.projectList = [itemList.find(item => item.itemType === '01')] | 
					
						
							|  |  |  |         this.partList = [itemList.find(item => item.itemType === '02')] | 
					
						
							|  |  |  |         this.otherList = [itemList.find(item => item.itemType === '03')] | 
					
						
							| 
									
										
										
										
											2024-09-23 09:00:16 +08:00
										 |  |  |       } catch { | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											2024-09-22 21:38:20 +08:00
										 |  |  |     }, | 
					
						
							|  |  |  |     // 挂单
 | 
					
						
							| 
									
										
										
										
											2024-09-23 09:00:16 +08:00
										 |  |  |     handlePendingSave() { | 
					
						
							| 
									
										
										
										
											2024-09-22 21:38:20 +08:00
										 |  |  |       this.formData.ticketsStatus = "06" | 
					
						
							|  |  |  |       this.handleSave() | 
					
						
							| 
									
										
										
										
											2024-09-23 09:00:16 +08:00
										 |  |  |     }, | 
					
						
							|  |  |  |     // 结算
 | 
					
						
							|  |  |  |     handlePaid() { | 
					
						
							| 
									
										
										
										
											2024-09-25 16:08:52 +08:00
										 |  |  |       // this.formData.ticketsStatus = '02'
 | 
					
						
							| 
									
										
										
										
											2024-09-23 09:00:16 +08:00
										 |  |  |       this.handleSave() | 
					
						
							| 
									
										
										
										
											2024-09-24 20:53:35 +08:00
										 |  |  |     }, | 
					
						
							|  |  |  |     // 查看用户的预约记录
 | 
					
						
							| 
									
										
										
										
											2024-09-25 17:34:42 +08:00
										 |  |  |     async getBooking(userId) { | 
					
						
							| 
									
										
										
										
											2024-09-24 20:53:35 +08:00
										 |  |  |       const res = await request({ | 
					
						
							|  |  |  |         url: "/repair/booking/list?userId=" + userId, | 
					
						
							|  |  |  |         method: "get" | 
					
						
							|  |  |  |       }) | 
					
						
							|  |  |  |       this.bookingList = res.data | 
					
						
							| 
									
										
										
										
											2024-09-26 10:42:40 +08:00
										 |  |  |       if (this.bookingList.length > 0) { | 
					
						
							|  |  |  |         this.bookingList.forEach(item => { | 
					
						
							|  |  |  |           item.bookingTime = this.parseTime(item.bookingTime, '{y}-{m}-{d} {h}:{m}') | 
					
						
							|  |  |  |         }) | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											2024-09-25 15:42:23 +08:00
										 |  |  |     }, | 
					
						
							|  |  |  |     // 权益更改
 | 
					
						
							| 
									
										
										
										
											2024-09-25 17:34:42 +08:00
										 |  |  |     changeCoupon(data) { | 
					
						
							| 
									
										
										
										
											2024-09-25 15:42:23 +08:00
										 |  |  |       this.finaCouponList.map(item => { | 
					
						
							|  |  |  |         item.isChoose = data.includes(item) | 
					
						
							|  |  |  |       }) | 
					
						
							|  |  |  |       this.finaCouponList.forEach(item => console.log(item.isChoose)) | 
					
						
							|  |  |  |       this.couponList = this.finaCouponList.filter(item => !item.isChoose) | 
					
						
							|  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-09-29 18:13:07 +08:00
										 |  |  |     // 新增客户信息
 | 
					
						
							| 
									
										
										
										
											2024-10-08 18:28:36 +08:00
										 |  |  |     updateUserInfo(flag) { | 
					
						
							| 
									
										
										
										
											2024-09-29 18:13:07 +08:00
										 |  |  |       const data = {} | 
					
						
							| 
									
										
										
										
											2024-10-08 18:28:36 +08:00
										 |  |  |       if (flag) { | 
					
						
							|  |  |  |         if (this.selectUser) { | 
					
						
							| 
									
										
										
										
											2024-09-29 18:13:07 +08:00
										 |  |  |           data.userInfo = this.selectUser | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2024-10-08 18:28:36 +08:00
										 |  |  |         if (this.selectCar) { | 
					
						
							| 
									
										
										
										
											2024-09-29 18:13:07 +08:00
										 |  |  |           data.carInfo = this.selectCar | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       this.$refs.userAndCarInfo.open(data) | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     // 新增客户信息回调
 | 
					
						
							| 
									
										
										
										
											2024-10-08 18:28:36 +08:00
										 |  |  |     async successCusAndCar(data) { | 
					
						
							|  |  |  |       const cus = { | 
					
						
							|  |  |  |         cusName: data.userInfo.cusName, | 
					
						
							|  |  |  |         phoneNumber: data.userInfo.phoneNumber | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       const car = { | 
					
						
							|  |  |  |         licenseNumber: data.carInfo.licenseNumber | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       // 查客户
 | 
					
						
							|  |  |  |       const cusRes = await getByNameAndMobile(cus) | 
					
						
							|  |  |  |       this.userInData = { | 
					
						
							|  |  |  |         ...cusRes.data, | 
					
						
							|  |  |  |         isRes: true | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       // 查车辆
 | 
					
						
							|  |  |  |       const carRes = await getByLicenseNumber(car) | 
					
						
							|  |  |  |       this.carInData = { | 
					
						
							|  |  |  |         ...carRes.data, | 
					
						
							|  |  |  |         brandAndModel: car.data.carInfo.brandAndModel | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											2024-09-29 18:13:07 +08:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2024-09-25 15:42:23 +08:00
										 |  |  |     // // 权益选择
 | 
					
						
							|  |  |  |     // handleSelectionChange(val){
 | 
					
						
							|  |  |  |     //
 | 
					
						
							|  |  |  |     // }
 | 
					
						
							| 
									
										
										
										
											2024-09-13 18:31:13 +08:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2024-09-12 18:29:04 +08:00
										 |  |  | } | 
					
						
							|  |  |  | </script> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | <style scoped lang="scss"> | 
					
						
							| 
									
										
										
										
											2024-09-25 17:34:42 +08:00
										 |  |  | .top-left { | 
					
						
							| 
									
										
										
										
											2024-09-25 15:42:23 +08:00
										 |  |  |   margin-bottom: 1rem; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2024-09-29 18:13:07 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | .el-card__body { | 
					
						
							|  |  |  |   min-height: 100rem; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2024-09-12 18:29:04 +08:00
										 |  |  | </style> |