| 
									
										
										
										
											2024-10-12 20:06:56 +08:00
										 |  |  | <template> | 
					
						
							|  |  |  |   <div> | 
					
						
							|  |  |  |     <!-- 搜索 --> | 
					
						
							|  |  |  |     <el-form :model="queryParams" ref="queryForm" size="small" :inline="true" v-show="showSearch" label-width="90px"> | 
					
						
							|  |  |  |       <el-form-item label="关键字" prop="ticketNo"> | 
					
						
							|  |  |  |         <el-input style="width: 20rem" type="text" placeholder="工单号、车牌号、联系电话" v-model="queryParams.ticketNo"/> | 
					
						
							|  |  |  |       </el-form-item> | 
					
						
							|  |  |  |       <el-form-item label="时间" prop="searchTimeArray"> | 
					
						
							|  |  |  |         <el-date-picker | 
					
						
							|  |  |  |           value-format="yyyy-MM-dd HH:mm:ss" | 
					
						
							|  |  |  |           v-model="queryParams.searchTimeArray" | 
					
						
							|  |  |  |           type="daterange" | 
					
						
							|  |  |  |           range-separator="至" | 
					
						
							|  |  |  |           start-placeholder="开始日期" | 
					
						
							| 
									
										
										
										
											2024-10-12 20:20:34 +08:00
										 |  |  |           end-placeholder="结束日期"/> | 
					
						
							| 
									
										
										
										
											2024-10-12 20:06:56 +08:00
										 |  |  |       </el-form-item> | 
					
						
							|  |  |  |       <el-form-item> | 
					
						
							|  |  |  |         <el-button type="primary" icon="el-icon-search" @click="handleQuery">搜索</el-button> | 
					
						
							|  |  |  |         <el-button icon="el-icon-refresh" @click="resetQuery">重置</el-button> | 
					
						
							|  |  |  |       </el-form-item> | 
					
						
							|  |  |  |     </el-form> | 
					
						
							|  |  |  |     <!-- 操作 --> | 
					
						
							|  |  |  |     <el-row :gutter="10" class="mb8"> | 
					
						
							|  |  |  |       <right-toolbar :showSearch.sync="showSearch"></right-toolbar> | 
					
						
							|  |  |  |     </el-row> | 
					
						
							|  |  |  |     <el-table v-loading="loading" :data="list" :stripe="true" :show-overflow-tooltip="true"> | 
					
						
							|  |  |  |       <el-table-column label="序号" align="center"> | 
					
						
							|  |  |  |         <template scope="scope"> | 
					
						
							|  |  |  |           <span>{{ scope.$index + 1 }}</span> | 
					
						
							|  |  |  |         </template> | 
					
						
							|  |  |  |       </el-table-column> | 
					
						
							|  |  |  |       <el-table-column label="订单编号" align="center" prop="ticketNo" width="200"/> | 
					
						
							|  |  |  |       <el-table-column label="维修类别" align="center" prop="repairType" width="180"> | 
					
						
							|  |  |  |         <template slot-scope="scope"> | 
					
						
							|  |  |  |           <dict-tag :type="DICT_TYPE.REPAIR_TYPE" v-model="scope.row.repairType"/> | 
					
						
							|  |  |  |         </template> | 
					
						
							|  |  |  |       </el-table-column> | 
					
						
							|  |  |  |       <el-table-column label="客户名称" align="center" prop="userName" width="180"/> | 
					
						
							|  |  |  |       <el-table-column label="车牌号" align="center" prop="carNo" width="180"/> | 
					
						
							|  |  |  |       <el-table-column label="车系" align="center" prop="carBrandName" width="180"/> | 
					
						
							|  |  |  |       <el-table-column label="手机号" align="center" prop="userMobile" width="180"/> | 
					
						
							| 
									
										
										
										
											2024-10-14 17:25:49 +08:00
										 |  |  |       <el-table-column label="操作" fixed="right" align="center" width="200"> | 
					
						
							| 
									
										
										
										
											2024-10-12 20:06:56 +08:00
										 |  |  |         <template slot-scope="scope"> | 
					
						
							|  |  |  |           <el-button size="mini" type="text" icon="el-icon-view" @click="handleShow(scope.row)" | 
					
						
							|  |  |  |           >查看 | 
					
						
							|  |  |  |           </el-button> | 
					
						
							| 
									
										
										
										
											2024-10-17 23:39:54 +08:00
										 |  |  |           <el-button v-if="scope.row.ticketsWorkStatus === '01' && userRole === 'repair_staff'" size="mini" type="text" icon="el-icon-check" @click="handleTake(scope.row)"> | 
					
						
							| 
									
										
										
										
											2024-10-14 17:25:49 +08:00
										 |  |  |             接单 | 
					
						
							| 
									
										
										
										
											2024-10-12 20:20:34 +08:00
										 |  |  |           </el-button> | 
					
						
							| 
									
										
										
										
											2024-10-17 23:39:54 +08:00
										 |  |  |           <el-button v-if="userRole === 'service_advisor' && scope.row.ticketsWorkStatus === '01'" size="mini" type="text" icon="el-icon-check" @click="handleNotify(scope.row)"> | 
					
						
							| 
									
										
										
										
											2024-10-14 17:25:49 +08:00
										 |  |  |             通知施工 | 
					
						
							|  |  |  |           </el-button> | 
					
						
							| 
									
										
										
										
											2024-10-19 17:00:20 +08:00
										 |  |  |           <el-button size="mini" v-if="scope.row.ticketsWorkStatus !== '01' &&userRole === 'repair_staff'  && !isFinish" type="text" icon="el-icon-monitor" @click="handleRecord(scope.row, 'kssg')"> | 
					
						
							| 
									
										
										
										
											2024-10-18 18:07:43 +08:00
										 |  |  |             开始施工 | 
					
						
							|  |  |  |           </el-button> | 
					
						
							| 
									
										
										
										
											2024-10-19 22:55:25 +08:00
										 |  |  |           <el-button size="mini" v-if=" scope.row.ticketsWorkStatus !== '01' && userRole === 'repair_staff' && !isFinish" type="text" icon="el-icon-monitor" @click="handleRecord(scope.row, 'sgz')"> | 
					
						
							|  |  |  |             过程记录 | 
					
						
							|  |  |  |           </el-button> | 
					
						
							| 
									
										
										
										
											2024-10-19 17:00:20 +08:00
										 |  |  |           <el-button size="mini" v-if="scope.row.ticketsWorkStatus !== '01' && userRole === 'repair_staff' && !isFinish" type="text" icon="el-icon-monitor" @click="handleRecord(scope.row, 'sgwczj')"> | 
					
						
							| 
									
										
										
										
											2024-10-18 18:07:43 +08:00
										 |  |  |             施工完成 | 
					
						
							|  |  |  |           </el-button> | 
					
						
							| 
									
										
										
										
											2024-10-19 11:06:09 +08:00
										 |  |  |           <el-button @click="handleRecord(scope.row, 'zj')" size="mini" type="text" icon="el-icon-monitor" v-if="userRole === 'general_inspection' && scope.row.ticketsWorkStatus === '05'"> | 
					
						
							|  |  |  |             终检 | 
					
						
							|  |  |  |           </el-button> | 
					
						
							| 
									
										
										
										
											2024-10-19 17:00:20 +08:00
										 |  |  |           <el-button @click="handleReTake(scope.row)" size="mini" type="text" icon="el-icon-refresh" v-if="(userRole === 'repair_staff' ? leader : false) && !(scope.row.ticketsWorkStatus !== '01' && userRole === 'repair_staff' && !isFinish)"> | 
					
						
							|  |  |  |             重新指派 | 
					
						
							|  |  |  |           </el-button> | 
					
						
							| 
									
										
										
										
											2024-10-19 11:06:09 +08:00
										 |  |  |           <el-dropdown | 
					
						
							| 
									
										
										
										
											2024-10-19 17:00:20 +08:00
										 |  |  |             v-if="scope.row.ticketsWorkStatus !== '01'" | 
					
						
							| 
									
										
										
										
											2024-10-19 11:06:09 +08:00
										 |  |  |             @command="(command) => handleCommand(command, scope.$index, scope.row)"> | 
					
						
							| 
									
										
										
										
											2024-10-14 17:25:49 +08:00
										 |  |  |             <el-button size="mini" type="text" icon="el-icon-d-arrow-right">更多</el-button> | 
					
						
							|  |  |  |             <el-dropdown-menu slot="dropdown"> | 
					
						
							| 
									
										
										
										
											2024-10-18 22:02:51 +08:00
										 |  |  |               <el-dropdown-item v-if="!isFinish && scope.row.ticketsWorkStatus !== '01' && userRole === 'repair_staff'" command="handleGet" size="mini" type="text" icon="el-icon-document-add" | 
					
						
							| 
									
										
										
										
											2024-10-19 22:55:25 +08:00
										 |  |  |               >申请配件 | 
					
						
							| 
									
										
										
										
											2024-10-14 17:25:49 +08:00
										 |  |  |               </el-dropdown-item> | 
					
						
							| 
									
										
										
										
											2024-10-19 22:55:25 +08:00
										 |  |  | <!--              <el-dropdown-item v-if="scope.row.ticketsWorkStatus !== '01' && userRole === 'repair_staff'" command="handleBack" size="mini" type="text" icon="el-icon-document-delete"--> | 
					
						
							|  |  |  | <!--              >申请退料--> | 
					
						
							|  |  |  | <!--              </el-dropdown-item>--> | 
					
						
							| 
									
										
										
										
											2024-10-17 23:39:54 +08:00
										 |  |  |               <!-- 还要判断是不是员工 --> | 
					
						
							|  |  |  |               <el-dropdown-item | 
					
						
							| 
									
										
										
										
											2024-10-19 17:00:20 +08:00
										 |  |  |                 v-if="userRole !== 'repair_staff'  && !isFinish && scope.row.ticketsWorkStatus !== '01'" | 
					
						
							| 
									
										
										
										
											2024-10-17 23:39:54 +08:00
										 |  |  |                 command="handleReTake" size="mini" type="text" icon="el-icon-refresh" | 
					
						
							| 
									
										
										
										
											2024-10-14 17:25:49 +08:00
										 |  |  |               >重新指派 | 
					
						
							|  |  |  |               </el-dropdown-item> | 
					
						
							|  |  |  |             </el-dropdown-menu> | 
					
						
							|  |  |  |           </el-dropdown> | 
					
						
							| 
									
										
										
										
											2024-10-12 20:06:56 +08:00
										 |  |  |         </template> | 
					
						
							|  |  |  |       </el-table-column> | 
					
						
							|  |  |  |     </el-table> | 
					
						
							|  |  |  |     <!-- 分页组件 --> | 
					
						
							|  |  |  |     <pagination v-show="total > 0" :total="total" :page.sync="queryParams.pageNo" :limit.sync="queryParams.pageSize" | 
					
						
							|  |  |  |                 @pagination="listTickets" | 
					
						
							|  |  |  |     /> | 
					
						
							| 
									
										
										
										
											2024-10-18 22:02:51 +08:00
										 |  |  |     <TicketsShow ref="ticketsShow" :user-role="userRole"/> | 
					
						
							| 
									
										
										
										
											2024-10-14 17:25:49 +08:00
										 |  |  |     <UpdateRepair ref="updateRepair" @success="listTickets"/> | 
					
						
							| 
									
										
										
										
											2024-10-15 18:00:35 +08:00
										 |  |  |     <TWOperate ref="twOperate" @success="listTickets"/> | 
					
						
							| 
									
										
										
										
											2024-10-18 18:07:43 +08:00
										 |  |  |     <UpdateRecord ref="updateRecord" @success="listTickets" /> | 
					
						
							| 
									
										
										
										
											2024-10-17 17:29:58 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |     <el-dialog title="退料申请" :visible.sync="backVisible" width="60%" v-dialogDrag append-to-body> | 
					
						
							|  |  |  |       <el-table v-loading="backLoading" :data="partList" :stripe="true" :show-overflow-tooltip="true" | 
					
						
							|  |  |  |                 @cell-mouse-enter="handleCellEnter" | 
					
						
							|  |  |  |                 @cell-mouse-leave="handleCellLeave" | 
					
						
							|  |  |  |                 @cell-click="handleCellClick" | 
					
						
							|  |  |  |                 @selection-change="rowSelect" | 
					
						
							|  |  |  |       > | 
					
						
							|  |  |  |         <el-table-column type="selection" align="center" /> | 
					
						
							| 
									
										
										
										
											2024-10-19 17:00:20 +08:00
										 |  |  |         <el-table-column label="商品名称" prop="itemName" align="center"/> | 
					
						
							|  |  |  |         <el-table-column label="规格" prop="ware.model" align="center"/> | 
					
						
							|  |  |  |         <el-table-column label="数量" prop="itemCount" align="center"> | 
					
						
							| 
									
										
										
										
											2024-10-17 17:29:58 +08:00
										 |  |  |           <div v-if="scope.row.id" class="item" slot-scope="scope"> | 
					
						
							| 
									
										
										
										
											2024-10-19 17:00:20 +08:00
										 |  |  |             <el-input @blur="save(scope.row)" class="item__input" v-model="scope.row.itemCount"/> | 
					
						
							|  |  |  |             <span class="item__txt">{{ scope.row.itemCount }}</span> | 
					
						
							| 
									
										
										
										
											2024-10-17 17:29:58 +08:00
										 |  |  |           </div> | 
					
						
							|  |  |  |         </el-table-column> | 
					
						
							|  |  |  |         <el-table-column label="备注" prop="remark" align="center"> | 
					
						
							|  |  |  |           <div v-if="scope.row.id" class="item" slot-scope="scope"> | 
					
						
							|  |  |  |             <el-input @blur="save(scope.row)" class="item__input" v-model="scope.row.remark"/> | 
					
						
							|  |  |  |             <span class="item__txt">{{ scope.row.remark }}</span> | 
					
						
							|  |  |  |           </div> | 
					
						
							|  |  |  |         </el-table-column> | 
					
						
							|  |  |  |       </el-table> | 
					
						
							|  |  |  |       <el-row :gutter="1" style="margin-top: 1rem"> | 
					
						
							|  |  |  |         <el-col :span="24"> | 
					
						
							|  |  |  |           <el-input v-model="remark" placeholder="备注" /> | 
					
						
							|  |  |  |         </el-col> | 
					
						
							|  |  |  |       </el-row> | 
					
						
							|  |  |  |       <div slot="footer" class="dialog-footer"> | 
					
						
							|  |  |  |         <el-button @click="doBack(false)" type="primary" :disabled="selections.length === 0">退料选择</el-button> | 
					
						
							| 
									
										
										
										
											2024-10-17 23:39:54 +08:00
										 |  |  |         <el-button @click="doBack(true)" type="success" :disabled="partList.length === 0">退料全部</el-button> | 
					
						
							| 
									
										
										
										
											2024-10-17 17:29:58 +08:00
										 |  |  |       </div> | 
					
						
							|  |  |  |     </el-dialog> | 
					
						
							| 
									
										
										
										
											2024-10-12 20:06:56 +08:00
										 |  |  |   </div> | 
					
						
							|  |  |  | </template> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | <script> | 
					
						
							| 
									
										
										
										
											2024-10-19 17:00:20 +08:00
										 |  |  | import {getPageType, updateTake, getTicketsById} from "@/api/repair/tickets/Tickets"; | 
					
						
							| 
									
										
										
										
											2024-10-12 20:20:34 +08:00
										 |  |  | import TicketsShow from "@/views/repair/tickets/Components/TicketsShow.vue"; | 
					
						
							| 
									
										
										
										
											2024-10-14 17:25:49 +08:00
										 |  |  | import UpdateRepair from "@/views/repair/tickets/form/UpdateRepair.vue"; | 
					
						
							| 
									
										
										
										
											2024-10-15 18:00:35 +08:00
										 |  |  | import TWOperate from "@/views/repair/tickets/form/TWOperate.vue"; | 
					
						
							| 
									
										
										
										
											2024-10-17 17:29:58 +08:00
										 |  |  | import {listTwItem} from "@/api/repair/tickets/TWItem"; | 
					
						
							|  |  |  | import {createUniqueCodeByHead} from "@/utils/createUniqueCode"; | 
					
						
							|  |  |  | import {updateTicketWares} from "@/api/repair/tickets/TicketWares"; | 
					
						
							| 
									
										
										
										
											2024-10-17 23:39:54 +08:00
										 |  |  | import {getIfLeader} from "@/api/repair/repairworker"; | 
					
						
							| 
									
										
										
										
											2024-10-18 18:07:43 +08:00
										 |  |  | import UpdateRecord from "@/views/repair/tickets/form/UpdateRecord.vue"; | 
					
						
							| 
									
										
										
										
											2024-10-12 20:06:56 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | export default { | 
					
						
							|  |  |  |   name: "TicketManagerItem", | 
					
						
							| 
									
										
										
										
											2024-10-18 18:07:43 +08:00
										 |  |  |   components: {UpdateRecord, TWOperate, UpdateRepair, TicketsShow}, | 
					
						
							| 
									
										
										
										
											2024-10-12 20:20:34 +08:00
										 |  |  |   props: { | 
					
						
							|  |  |  |     isFinish: { | 
					
						
							| 
									
										
										
										
											2024-10-12 20:06:56 +08:00
										 |  |  |       type: Boolean, | 
					
						
							| 
									
										
										
										
											2024-10-14 17:25:49 +08:00
										 |  |  |     }, | 
					
						
							|  |  |  |     userRole: { | 
					
						
							| 
									
										
										
										
											2024-10-17 23:39:54 +08:00
										 |  |  |       type: String, | 
					
						
							|  |  |  |       default: '', | 
					
						
							| 
									
										
										
										
											2024-10-14 17:25:49 +08:00
										 |  |  |       required: true | 
					
						
							| 
									
										
										
										
											2024-10-12 20:06:56 +08:00
										 |  |  |     } | 
					
						
							|  |  |  |   }, | 
					
						
							|  |  |  |   data() { | 
					
						
							|  |  |  |     return { | 
					
						
							|  |  |  |       queryParams: { | 
					
						
							| 
									
										
										
										
											2024-10-12 20:20:34 +08:00
										 |  |  |         pageNo: 1, | 
					
						
							|  |  |  |         pageSize: 10, | 
					
						
							| 
									
										
										
										
											2024-10-12 20:06:56 +08:00
										 |  |  |         ticketNo: null, | 
					
						
							|  |  |  |         searchTimeArray: [], | 
					
						
							| 
									
										
										
										
											2024-10-19 17:00:20 +08:00
										 |  |  |         isFinish: this.isFinish ? "1" : "0", | 
					
						
							| 
									
										
										
										
											2024-10-12 20:06:56 +08:00
										 |  |  |       }, | 
					
						
							|  |  |  |       showSearch: true, | 
					
						
							|  |  |  |       loading: false, | 
					
						
							|  |  |  |       list: [], | 
					
						
							| 
									
										
										
										
											2024-10-17 17:29:58 +08:00
										 |  |  |       total: 0, | 
					
						
							|  |  |  |       backVisible: false, | 
					
						
							|  |  |  |       partList: [], | 
					
						
							|  |  |  |       backLoading: false, | 
					
						
							|  |  |  |       // 保存进入编辑的cell
 | 
					
						
							|  |  |  |       clickCellMap: {}, | 
					
						
							|  |  |  |       // 需要编辑的属性
 | 
					
						
							| 
									
										
										
										
											2024-10-19 17:00:20 +08:00
										 |  |  |       editProp: ['remark', 'itemCount'], | 
					
						
							| 
									
										
										
										
											2024-10-17 17:29:58 +08:00
										 |  |  |       selections: [], | 
					
						
							|  |  |  |       formData: {}, | 
					
						
							| 
									
										
										
										
											2024-10-17 23:39:54 +08:00
										 |  |  |       remark: null, | 
					
						
							|  |  |  |       leader: false, | 
					
						
							| 
									
										
										
										
											2024-10-12 20:06:56 +08:00
										 |  |  |     } | 
					
						
							|  |  |  |   }, | 
					
						
							|  |  |  |   mounted() { | 
					
						
							| 
									
										
										
										
											2024-10-12 20:20:34 +08:00
										 |  |  |     this.listTickets() | 
					
						
							| 
									
										
										
										
											2024-10-17 23:39:54 +08:00
										 |  |  |     this.isLeader() | 
					
						
							| 
									
										
										
										
											2024-10-12 20:06:56 +08:00
										 |  |  |   }, | 
					
						
							| 
									
										
										
										
											2024-10-12 20:20:34 +08:00
										 |  |  |   methods: { | 
					
						
							| 
									
										
										
										
											2024-10-17 23:39:54 +08:00
										 |  |  |     async isLeader(){ | 
					
						
							|  |  |  |         const res = await getIfLeader() | 
					
						
							|  |  |  |         this.leader = res.data | 
					
						
							|  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-10-12 20:20:34 +08:00
										 |  |  |     async listTickets() { | 
					
						
							|  |  |  |       try { | 
					
						
							|  |  |  |         this.loading = true | 
					
						
							|  |  |  |         const res = await getPageType(this.queryParams) | 
					
						
							|  |  |  |         if (res.data) { | 
					
						
							|  |  |  |           this.list = res.data.records | 
					
						
							|  |  |  |           this.total = res.data.total | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2024-10-14 17:25:49 +08:00
										 |  |  |       } finally { | 
					
						
							| 
									
										
										
										
											2024-10-12 20:20:34 +08:00
										 |  |  |         this.loading = false | 
					
						
							| 
									
										
										
										
											2024-10-12 20:06:56 +08:00
										 |  |  |       } | 
					
						
							|  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-10-14 17:25:49 +08:00
										 |  |  |     // 搜索
 | 
					
						
							| 
									
										
										
										
											2024-10-12 20:20:34 +08:00
										 |  |  |     handleQuery() { | 
					
						
							|  |  |  |       this.queryParams.pageNo = 1 | 
					
						
							|  |  |  |       this.listTickets() | 
					
						
							| 
									
										
										
										
											2024-10-12 20:06:56 +08:00
										 |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-10-14 17:25:49 +08:00
										 |  |  |     // 重置
 | 
					
						
							| 
									
										
										
										
											2024-10-12 20:20:34 +08:00
										 |  |  |     resetQuery() { | 
					
						
							|  |  |  |       this.resetForm('queryForm') | 
					
						
							|  |  |  |       this.handleQuery() | 
					
						
							|  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-10-14 17:25:49 +08:00
										 |  |  |     // 查看
 | 
					
						
							| 
									
										
										
										
											2024-10-12 20:20:34 +08:00
										 |  |  |     handleShow(row) { | 
					
						
							|  |  |  |       this.$refs.ticketsShow.open(row) | 
					
						
							| 
									
										
										
										
											2024-10-12 20:06:56 +08:00
										 |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-10-14 17:25:49 +08:00
										 |  |  |     // 配件申请
 | 
					
						
							|  |  |  |     handleGet(row) { | 
					
						
							| 
									
										
										
										
											2024-10-15 18:00:35 +08:00
										 |  |  |       row = { | 
					
						
							|  |  |  |         ...row, | 
					
						
							|  |  |  |         type: true | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       this.$refs.twOperate.open(row) | 
					
						
							| 
									
										
										
										
											2024-10-14 17:25:49 +08:00
										 |  |  |     }, | 
					
						
							|  |  |  |     // 接单
 | 
					
						
							|  |  |  |     async handleTake(row) { | 
					
						
							|  |  |  |       try { | 
					
						
							|  |  |  |         this.loading = true | 
					
						
							|  |  |  |         await this.$modal.confirm("确认接单吗?") | 
					
						
							|  |  |  |         await updateTake(row.id) | 
					
						
							|  |  |  |         this.$modal.msgSuccess("接单成功") | 
					
						
							|  |  |  |         await this.listTickets() | 
					
						
							|  |  |  |       }finally { | 
					
						
							|  |  |  |         this.loading = false | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     // 退料
 | 
					
						
							| 
									
										
										
										
											2024-10-17 17:29:58 +08:00
										 |  |  |     async handleBack(row){ | 
					
						
							|  |  |  |       this.formData = {} | 
					
						
							|  |  |  |       this.formData = row | 
					
						
							|  |  |  |       this.remark = null | 
					
						
							|  |  |  |       this.backVisible = true | 
					
						
							|  |  |  |       try { | 
					
						
							|  |  |  |         this.backLoading = true | 
					
						
							| 
									
										
										
										
											2024-10-19 17:00:20 +08:00
										 |  |  |         const res = await getTicketsById(row.id) | 
					
						
							|  |  |  |         this.partList = res.data.wares | 
					
						
							| 
									
										
										
										
											2024-10-17 17:29:58 +08:00
										 |  |  |       }finally { | 
					
						
							|  |  |  |         this.backLoading = false | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											2024-10-14 17:25:49 +08:00
										 |  |  |     }, | 
					
						
							|  |  |  |     // 重新指派
 | 
					
						
							|  |  |  |     handleReTake(row){ | 
					
						
							|  |  |  |       row = { | 
					
						
							|  |  |  |         ...row, | 
					
						
							| 
									
										
										
										
											2024-10-17 23:39:54 +08:00
										 |  |  |         // 还要判断是不是班组长
 | 
					
						
							|  |  |  |         isLeads: this.userRole === 'repair_staff' | 
					
						
							| 
									
										
										
										
											2024-10-14 17:25:49 +08:00
										 |  |  |       } | 
					
						
							|  |  |  |       this.$refs.updateRepair.open(row) | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     // 指派员工,通知施工
 | 
					
						
							|  |  |  |     handleNotify(row){ | 
					
						
							|  |  |  |       this.$refs.updateRepair.open(row) | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     // 更多操作
 | 
					
						
							|  |  |  |     handleCommand(command, index, row){ | 
					
						
							|  |  |  |       switch (command){ | 
					
						
							|  |  |  |         case 'handleReTake': | 
					
						
							|  |  |  |           this.handleReTake(row) | 
					
						
							|  |  |  |           break | 
					
						
							| 
									
										
										
										
											2024-10-15 18:00:35 +08:00
										 |  |  |         case 'handleGet': | 
					
						
							|  |  |  |           this.handleGet(row) | 
					
						
							|  |  |  |           break | 
					
						
							| 
									
										
										
										
											2024-10-17 17:29:58 +08:00
										 |  |  |         case 'handleBack': | 
					
						
							|  |  |  |           this.handleBack(row) | 
					
						
							|  |  |  |           break | 
					
						
							| 
									
										
										
										
											2024-10-14 17:25:49 +08:00
										 |  |  |         default: | 
					
						
							|  |  |  |           break | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											2024-10-17 17:29:58 +08:00
										 |  |  |     }, | 
					
						
							|  |  |  |     /** 鼠标移入cell */ | 
					
						
							|  |  |  |     handleCellEnter(row, column, cell, event) { | 
					
						
							|  |  |  |       const property = column.property | 
					
						
							|  |  |  |       if (this.editProp.includes(property)) { | 
					
						
							|  |  |  |         cell.querySelector('.item__txt').classList.add('item__txt--hover') | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     /** 鼠标移出cell */ | 
					
						
							|  |  |  |     handleCellLeave(row, column, cell, event) { | 
					
						
							|  |  |  |       const property = column.property | 
					
						
							|  |  |  |       if (this.editProp.includes(property)) { | 
					
						
							|  |  |  |         cell.querySelector('.item__txt').classList.remove('item__txt--hover') | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     /** 点击cell */ | 
					
						
							|  |  |  |     handleCellClick(row, column, cell, event) { | 
					
						
							|  |  |  |       const property = column.property | 
					
						
							|  |  |  |       if (this.editProp.includes(property)) { | 
					
						
							|  |  |  |         // 保存cell
 | 
					
						
							|  |  |  |         this.saveCellClick(row, cell) | 
					
						
							|  |  |  |         cell.querySelector('.item__txt').style.display = 'none' | 
					
						
							|  |  |  |         cell.querySelector('.item__input').style.display = 'inline' | 
					
						
							|  |  |  |         cell.querySelector('input').focus() | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     /** 取消编辑状态 */ | 
					
						
							|  |  |  |     cancelEditable(cell) { | 
					
						
							|  |  |  |       cell.querySelector('.item__txt').style.display = 'inline' | 
					
						
							|  |  |  |       cell.querySelector('.item__input').style.display = 'none' | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     /** 保存进入编辑的cell */ | 
					
						
							|  |  |  |     saveCellClick(row, cell) { | 
					
						
							|  |  |  |       const id = row.id | 
					
						
							|  |  |  |       if (this.clickCellMap[id] !== undefined) { | 
					
						
							|  |  |  |         if (!this.clickCellMap[id].includes(cell)) { | 
					
						
							|  |  |  |           this.clickCellMap[id].push(cell) | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } else { | 
					
						
							|  |  |  |         this.clickCellMap[id] = [cell] | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     /** 保存数据 */ | 
					
						
							|  |  |  |     save(row) { | 
					
						
							|  |  |  |       // 更新表格的数据
 | 
					
						
							| 
									
										
										
										
											2024-10-19 17:00:20 +08:00
										 |  |  |       console.log(row, this.clickCellMap) | 
					
						
							| 
									
										
										
										
											2024-10-17 17:29:58 +08:00
										 |  |  |       const id = row.id | 
					
						
							|  |  |  |       // 取消本行所有cell的编辑状态
 | 
					
						
							|  |  |  |       this.clickCellMap[id].forEach(cell => { | 
					
						
							|  |  |  |         this.cancelEditable(cell) | 
					
						
							|  |  |  |       }) | 
					
						
							|  |  |  |       this.clickCellMap[id] = [] | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     rowSelect(val){ | 
					
						
							|  |  |  |       this.selections = val | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     async doBack(flag){ | 
					
						
							|  |  |  |       const data = { | 
					
						
							|  |  |  |         no: createUniqueCodeByHead("TLSQ"), | 
					
						
							|  |  |  |         ticketId: this.formData.id, | 
					
						
							|  |  |  |         type: "02", | 
					
						
							|  |  |  |         status: "01", | 
					
						
							|  |  |  |         remark: this.remark, | 
					
						
							|  |  |  |         adviserId: this.formData.adviserId, | 
					
						
							|  |  |  |         adviserName: this.formData.adviserName | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       if (flag){ | 
					
						
							|  |  |  |         data.items = this.partList | 
					
						
							|  |  |  |       }else { | 
					
						
							|  |  |  |         data.items = this.selections | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       await updateTicketWares(data) | 
					
						
							|  |  |  |       this.backVisible = false | 
					
						
							|  |  |  |       this.$modal.msgSuccess("申请成功"); | 
					
						
							|  |  |  |       await this.listTickets() | 
					
						
							| 
									
										
										
										
											2024-10-18 18:07:43 +08:00
										 |  |  |     }, | 
					
						
							|  |  |  |     handleRecord(row, type){ | 
					
						
							|  |  |  |       row = { | 
					
						
							|  |  |  |         ...row, | 
					
						
							|  |  |  |         clickType: type | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       this.$refs.updateRecord.open(row) | 
					
						
							| 
									
										
										
										
											2024-10-12 20:06:56 +08:00
										 |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | </script> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | <style scoped lang="scss"> | 
					
						
							| 
									
										
										
										
											2024-10-17 17:29:58 +08:00
										 |  |  | .item { | 
					
						
							|  |  |  |   .item__input { | 
					
						
							|  |  |  |     display: none; | 
					
						
							|  |  |  |     width: 100px; | 
					
						
							|  |  |  |     /* 调整elementUI中样式 如果不需要调整请忽略 */ | 
					
						
							|  |  |  |     .el-input__inner { | 
					
						
							|  |  |  |       height: 24px !important; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2024-10-12 20:06:56 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-17 17:29:58 +08:00
										 |  |  |     /* 调整elementUI中样式 如果不需要调整请忽略 */ | 
					
						
							|  |  |  |     .el-input__suffix { | 
					
						
							|  |  |  |       i { | 
					
						
							|  |  |  |         font-size: 12px !important; | 
					
						
							|  |  |  |         line-height: 26px !important; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   .item__txt { | 
					
						
							|  |  |  |     box-sizing: border-box; | 
					
						
							|  |  |  |     border: 1px solid transparent; | 
					
						
							|  |  |  |     width: 100px; | 
					
						
							|  |  |  |     line-height: 24px; | 
					
						
							|  |  |  |     padding: 0 8px; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   .item__txt--hover { | 
					
						
							|  |  |  |     border: 1px solid #dddddd; | 
					
						
							|  |  |  |     border-radius: 4px; | 
					
						
							|  |  |  |     cursor: text; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2024-10-12 20:06:56 +08:00
										 |  |  | </style> |