| 
									
										
										
										
											2024-10-23 22:15:34 +08:00
										 |  |  |  | <template> | 
					
						
							|  |  |  |  |   <view class="container"> | 
					
						
							|  |  |  |  |     <VNavigationBar background-color="#fff" :title="title" title-color="#333"></VNavigationBar> | 
					
						
							|  |  |  |  |     <view class="body"> | 
					
						
							| 
									
										
										
										
											2024-11-14 18:33:55 +08:00
										 |  |  |  |       <view class="repairInfo"> | 
					
						
							|  |  |  |  |         <view class="header"> | 
					
						
							|  |  |  |  |           申请人 | 
					
						
							|  |  |  |  |         </view> | 
					
						
							|  |  |  |  |         <view class="repairItem"> | 
					
						
							|  |  |  |  |           <view class="grid"> | 
					
						
							|  |  |  |  |             <view style="grid-area: a" class="girdItem"> | 
					
						
							|  |  |  |  |               <text class="label">岗位</text> | 
					
						
							|  |  |  |  |               <text class="value">{{ info.repairWork }}</text> | 
					
						
							|  |  |  |  |             </view> | 
					
						
							|  |  |  |  |             <view style="grid-area: b" class="girdItem"> | 
					
						
							|  |  |  |  |               <text class="label">姓名</text> | 
					
						
							|  |  |  |  |               <text class="value">{{ info.repairName }}</text> | 
					
						
							|  |  |  |  |             </view> | 
					
						
							|  |  |  |  |             <view style="grid-area: c" class="girdItem"> | 
					
						
							|  |  |  |  |               <text class="label">服务顾问</text> | 
					
						
							|  |  |  |  |               <text class="value">{{ info.adviserName }}</text> | 
					
						
							|  |  |  |  |             </view> | 
					
						
							|  |  |  |  |             <view style="grid-area: d" class="girdItem"> | 
					
						
							|  |  |  |  |               <text class="label">时间</text> | 
					
						
							|  |  |  |  |               <text class="value">{{ getDateFormat(info.createTime) }}</text> | 
					
						
							|  |  |  |  |             </view> | 
					
						
							|  |  |  |  |           </view> | 
					
						
							|  |  |  |  |         </view> | 
					
						
							|  |  |  |  |       </view> | 
					
						
							|  |  |  |  |       <view class="repairInfo"> | 
					
						
							|  |  |  |  |         <view class="header"> | 
					
						
							|  |  |  |  |           客户信息 | 
					
						
							|  |  |  |  |         </view> | 
					
						
							|  |  |  |  |         <view class="repairItem"> | 
					
						
							|  |  |  |  |           <view class="grid"> | 
					
						
							|  |  |  |  |             <view style="grid-area: a" class="girdItem"> | 
					
						
							|  |  |  |  |               <text class="label">车牌号</text> | 
					
						
							|  |  |  |  |               <text class="value">{{ info.licenseNumber }}</text> | 
					
						
							|  |  |  |  |             </view> | 
					
						
							|  |  |  |  |             <view style="grid-area: b" class="girdItem"> | 
					
						
							|  |  |  |  |               <text class="label">车系</text> | 
					
						
							|  |  |  |  |               <text class="value">{{ info.carBrandName }}</text> | 
					
						
							|  |  |  |  |             </view> | 
					
						
							|  |  |  |  |             <view style="grid-area: c" class="girdItem"> | 
					
						
							|  |  |  |  |               <text class="label">姓名</text> | 
					
						
							|  |  |  |  |               <text class="value">{{ info.userName }}</text> | 
					
						
							|  |  |  |  |             </view> | 
					
						
							|  |  |  |  |             <view style="grid-area: d" class="girdItem"> | 
					
						
							|  |  |  |  |               <text class="label">电话</text> | 
					
						
							|  |  |  |  |               <text class="value">{{ info.userMobile }}</text> | 
					
						
							|  |  |  |  |             </view> | 
					
						
							|  |  |  |  |           </view> | 
					
						
							|  |  |  |  |         </view> | 
					
						
							|  |  |  |  |       </view> | 
					
						
							|  |  |  |  |       <view class="repairInfo" v-if="imageUrls && imageUrls.length > 0"> | 
					
						
							|  |  |  |  |         <view class="header"> | 
					
						
							|  |  |  |  |           配件申请表 | 
					
						
							|  |  |  |  |         </view> | 
					
						
							|  |  |  |  |         <view class="repairItem"> | 
					
						
							|  |  |  |  |           <image | 
					
						
							|  |  |  |  |               v-for="(url, index) in imageUrls" | 
					
						
							|  |  |  |  |               :key="index" | 
					
						
							|  |  |  |  |               :src="url" | 
					
						
							|  |  |  |  |               class="image-item" | 
					
						
							|  |  |  |  |               @click="showFullScreen(index)" | 
					
						
							|  |  |  |  |           /> | 
					
						
							|  |  |  |  |         </view> | 
					
						
							|  |  |  |  |       </view> | 
					
						
							| 
									
										
										
										
											2024-10-23 22:15:34 +08:00
										 |  |  |  |       <view class="repairInfo"> | 
					
						
							|  |  |  |  |         <view class="header"> | 
					
						
							|  |  |  |  |           配件信息 | 
					
						
							| 
									
										
										
										
											2024-11-14 18:33:55 +08:00
										 |  |  |  |           <view v-if="canOperate" style="float: right; color: #0174F6" @click="addWares">添加配件</view> | 
					
						
							| 
									
										
										
										
											2024-10-23 22:15:34 +08:00
										 |  |  |  |         </view> | 
					
						
							| 
									
										
										
										
											2024-11-14 18:33:55 +08:00
										 |  |  |  |         <view @click="changeChoose(item)" class="repairItem" v-for="(item, index) in repairList" :key="index"> | 
					
						
							|  |  |  |  |           <view class="repairName"> | 
					
						
							|  |  |  |  |             <radio v-if="canOperate" :value="item.id" :checked="item.selected"/> | 
					
						
							|  |  |  |  |             {{ item.waresName }} | 
					
						
							|  |  |  |  |             <text class="repairNum">×{{ item.waresCount }}</text> | 
					
						
							|  |  |  |  |           </view> | 
					
						
							| 
									
										
										
										
											2024-10-23 22:15:34 +08:00
										 |  |  |  |           <view class="grid"> | 
					
						
							|  |  |  |  |             <view style="grid-area: a" class="girdItem"> | 
					
						
							|  |  |  |  |               <text class="label">配件分类</text> | 
					
						
							|  |  |  |  |               <text class="value">{{ item.typeName }}</text> | 
					
						
							|  |  |  |  |             </view> | 
					
						
							|  |  |  |  |             <view style="grid-area: b" class="girdItem"> | 
					
						
							|  |  |  |  |               <text class="label">当前库存</text> | 
					
						
							|  |  |  |  |               <text class="value">{{ item.wares.stock }}</text> | 
					
						
							|  |  |  |  |             </view> | 
					
						
							|  |  |  |  |             <view style="grid-area: c" class="girdItem"> | 
					
						
							|  |  |  |  |               <text class="label">单位</text> | 
					
						
							|  |  |  |  |               <text class="value">{{ item.wares.unit }}</text> | 
					
						
							|  |  |  |  |             </view> | 
					
						
							| 
									
										
										
										
											2024-11-14 18:33:55 +08:00
										 |  |  |  |             <!--            <view style="grid-area: d" class="girdItem">--> | 
					
						
							|  |  |  |  |             <!--              <text class="label">编码</text>--> | 
					
						
							|  |  |  |  |             <!--              <text class="value">{{ item.wares.code || ""}}</text>--> | 
					
						
							|  |  |  |  |             <!--            </view>--> | 
					
						
							| 
									
										
										
										
											2024-10-23 22:15:34 +08:00
										 |  |  |  |             <view style="grid-area: d" class="girdItem"> | 
					
						
							| 
									
										
										
										
											2024-10-30 20:04:35 +08:00
										 |  |  |  |               <text class="label">售价</text> | 
					
						
							| 
									
										
										
										
											2024-11-14 18:33:55 +08:00
										 |  |  |  |               <text class="value"><input type="number" placeholder="请输入售价" v-model="item.wares.price"/></text> | 
					
						
							|  |  |  |  |             </view> | 
					
						
							|  |  |  |  |             <view style="grid-area: e" class="girdItem"> | 
					
						
							|  |  |  |  |               <text class="label">状态</text> | 
					
						
							|  |  |  |  |               <text :class="getWaresStatusClass(item.waresStatus)">{{ getWaresStatus(item.waresStatus) }}</text> | 
					
						
							|  |  |  |  |             </view> | 
					
						
							|  |  |  |  |             <view style="grid-area: f" class="girdItem"> | 
					
						
							|  |  |  |  |               <text class="label">审核人</text> | 
					
						
							|  |  |  |  |               <text class="value">{{ item.handleName }}</text> | 
					
						
							| 
									
										
										
										
											2024-10-23 22:15:34 +08:00
										 |  |  |  |             </view> | 
					
						
							|  |  |  |  |           </view> | 
					
						
							|  |  |  |  |         </view> | 
					
						
							|  |  |  |  |       </view> | 
					
						
							|  |  |  |  |     </view> | 
					
						
							|  |  |  |  |     <view v-if="canOperate" class="footer"> | 
					
						
							|  |  |  |  |       <view class="no" @click="confirmOpe('no')"> | 
					
						
							|  |  |  |  |         {{ backText }} | 
					
						
							|  |  |  |  |       </view> | 
					
						
							|  |  |  |  |       <view class="yes" @click="confirmOpe('yes')"> | 
					
						
							|  |  |  |  |         {{ yesText }} | 
					
						
							|  |  |  |  |       </view> | 
					
						
							|  |  |  |  |     </view> | 
					
						
							| 
									
										
										
										
											2024-11-14 18:33:55 +08:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |     <!-- 全屏查看弹窗 --> | 
					
						
							|  |  |  |  |     <view v-if="showFullscreen" class="fullscreen-container" @click="closeFullscreen"> | 
					
						
							|  |  |  |  |       <image :src="currentImage" class="fullscreen-image" @click.stop /> | 
					
						
							|  |  |  |  |     </view> | 
					
						
							| 
									
										
										
										
											2024-10-23 22:15:34 +08:00
										 |  |  |  |   </view> | 
					
						
							|  |  |  |  | </template> | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | <script> | 
					
						
							|  |  |  |  | import VNavigationBar from "@/components/VNavigationBar.vue"; | 
					
						
							|  |  |  |  | import request from '@/utils/request'; | 
					
						
							| 
									
										
										
										
											2024-11-14 18:33:55 +08:00
										 |  |  |  | import {getDictTextByCodeAndValue, formatTimestampCustom} from "@/utils/utils"; | 
					
						
							|  |  |  |  | import config from "@/config"; | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-23 22:15:34 +08:00
										 |  |  |  | export default { | 
					
						
							|  |  |  |  |   components: { | 
					
						
							|  |  |  |  |     VNavigationBar | 
					
						
							|  |  |  |  |   }, | 
					
						
							|  |  |  |  |   data() { | 
					
						
							|  |  |  |  |     return { | 
					
						
							| 
									
										
										
										
											2024-11-14 18:33:55 +08:00
										 |  |  |  |       viewType: "", | 
					
						
							|  |  |  |  |       id: "", | 
					
						
							|  |  |  |  |       title: "", | 
					
						
							|  |  |  |  |       canOperate: false, | 
					
						
							|  |  |  |  |       backText: "", | 
					
						
							|  |  |  |  |       yesText: "", | 
					
						
							| 
									
										
										
										
											2024-10-23 22:15:34 +08:00
										 |  |  |  |       repairList: [ | 
					
						
							|  |  |  |  |         // {
 | 
					
						
							|  |  |  |  |         //   name: '7字小钩',
 | 
					
						
							|  |  |  |  |         //   num: 3,
 | 
					
						
							|  |  |  |  |         //   type: '机电',
 | 
					
						
							|  |  |  |  |         //   unit: '桶',
 | 
					
						
							|  |  |  |  |         //   total: 35,
 | 
					
						
							|  |  |  |  |         //   code: 'XCQHCJYS7 SPI SP 5W30 4L'
 | 
					
						
							|  |  |  |  |         // },
 | 
					
						
							|  |  |  |  |         // {
 | 
					
						
							|  |  |  |  |         //   name: '7字小钩',
 | 
					
						
							|  |  |  |  |         //   num: 3,
 | 
					
						
							|  |  |  |  |         //   type: '机电',
 | 
					
						
							|  |  |  |  |         //   unit: '桶',
 | 
					
						
							|  |  |  |  |         //   total: 35,
 | 
					
						
							|  |  |  |  |         //   code: 'XCQHCJYS7 SPI SP 5W30 4L'
 | 
					
						
							|  |  |  |  |         // }
 | 
					
						
							| 
									
										
										
										
											2024-11-14 18:33:55 +08:00
										 |  |  |  |       ], | 
					
						
							|  |  |  |  |       selectWares: [], | 
					
						
							|  |  |  |  |       info: {}, | 
					
						
							|  |  |  |  |       imageUrls: [], | 
					
						
							|  |  |  |  |       showFullscreen: false, | 
					
						
							|  |  |  |  |       currentImage: '' | 
					
						
							| 
									
										
										
										
											2024-10-23 22:15:34 +08:00
										 |  |  |  |     }; | 
					
						
							|  |  |  |  |   }, | 
					
						
							| 
									
										
										
										
											2024-11-14 18:33:55 +08:00
										 |  |  |  |   onShow(){ | 
					
						
							|  |  |  |  |     this.getTicketWares() | 
					
						
							|  |  |  |  |     this.getDetail() | 
					
						
							|  |  |  |  |   }, | 
					
						
							|  |  |  |  |   onLoad(data) { | 
					
						
							| 
									
										
										
										
											2024-10-23 22:15:34 +08:00
										 |  |  |  |     this.canOperate = data.canOperate | 
					
						
							|  |  |  |  |     this.id = data.id | 
					
						
							| 
									
										
										
										
											2024-11-14 18:33:55 +08:00
										 |  |  |  |     this.getTicketWares() | 
					
						
							| 
									
										
										
										
											2024-10-23 22:15:34 +08:00
										 |  |  |  |     this.getDetail() | 
					
						
							|  |  |  |  |   }, | 
					
						
							| 
									
										
										
										
											2024-11-14 18:33:55 +08:00
										 |  |  |  |   methods: { | 
					
						
							|  |  |  |  |     addWares(){ | 
					
						
							|  |  |  |  |       //配件申请
 | 
					
						
							|  |  |  |  |       uni.navigateTo({ | 
					
						
							|  |  |  |  |         url: '/pages-repair/apply/applyForm?twId=' + this.id | 
					
						
							|  |  |  |  |       }) | 
					
						
							|  |  |  |  |     }, | 
					
						
							|  |  |  |  |     showFullScreen(index) { | 
					
						
							|  |  |  |  |       this.currentImage = this.imageUrls[index]; | 
					
						
							|  |  |  |  |       this.showFullscreen = true; | 
					
						
							|  |  |  |  |     }, | 
					
						
							|  |  |  |  |     closeFullscreen() { | 
					
						
							|  |  |  |  |       this.showFullscreen = false; | 
					
						
							|  |  |  |  |     }, | 
					
						
							|  |  |  |  |     getDateFormat(val) { | 
					
						
							|  |  |  |  |       return formatTimestampCustom(val); | 
					
						
							|  |  |  |  |     }, | 
					
						
							|  |  |  |  |     async getTicketWares() { | 
					
						
							|  |  |  |  |       try { | 
					
						
							|  |  |  |  |         const url = "/admin-api/repair/tw/getById?id=" + this.id | 
					
						
							|  |  |  |  |         const res = await  request({ | 
					
						
							|  |  |  |  |           url: url, | 
					
						
							|  |  |  |  |           method: 'get' | 
					
						
							|  |  |  |  |         }) | 
					
						
							|  |  |  |  |         this.info = res.data | 
					
						
							| 
									
										
										
										
											2024-11-15 16:59:26 +08:00
										 |  |  |  |         if (this.info.repairWork){ | 
					
						
							|  |  |  |  |           this.getWorkToText() | 
					
						
							|  |  |  |  |         } | 
					
						
							| 
									
										
										
										
											2024-11-14 18:33:55 +08:00
										 |  |  |  |         await this.getTicketById(this.info.ticketId) | 
					
						
							|  |  |  |  |         if (this.info.images && this.info.images.length > 0) { | 
					
						
							|  |  |  |  |           this.getImageUrls(this.info.images) | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |       }catch{} | 
					
						
							|  |  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-11-15 16:59:26 +08:00
										 |  |  |  |     getWorkToText(){ | 
					
						
							|  |  |  |  |       getDictTextByCodeAndValue('repair_work_type', this.info.repairWork).then(value => { | 
					
						
							|  |  |  |  |         this.info.repairWork = value | 
					
						
							|  |  |  |  |       }).catch(() => { | 
					
						
							|  |  |  |  |         this.info.repairWork = "未知" | 
					
						
							|  |  |  |  |       }) | 
					
						
							|  |  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-11-14 18:33:55 +08:00
										 |  |  |  |     getImageUrls(val) { | 
					
						
							|  |  |  |  |       this.imageUrls = [...val.split(",").map(item => { | 
					
						
							|  |  |  |  |         return config.baseImageUrl + item | 
					
						
							|  |  |  |  |       })] | 
					
						
							|  |  |  |  |     }, | 
					
						
							|  |  |  |  |     async getTicketById(id) { | 
					
						
							|  |  |  |  |       const res = await request({ | 
					
						
							|  |  |  |  |         url: '/admin-api/repair/tickets/get?id=' + id, | 
					
						
							|  |  |  |  |         method: 'get', | 
					
						
							|  |  |  |  |       }) | 
					
						
							|  |  |  |  |       this.info.carBrandName = res.data.carBrandName | 
					
						
							|  |  |  |  |     }, | 
					
						
							|  |  |  |  |     changeChoose(val) { | 
					
						
							|  |  |  |  |       const flag = this.selectWares.findIndex(item => item.id === val.id) | 
					
						
							|  |  |  |  |       if (flag === -1) { | 
					
						
							|  |  |  |  |         val.selected = true | 
					
						
							|  |  |  |  |         this.selectWares.push(val) | 
					
						
							|  |  |  |  |       } else { | 
					
						
							|  |  |  |  |         val.selected = false | 
					
						
							|  |  |  |  |         this.selectWares.splice(flag, 1) | 
					
						
							|  |  |  |  |       } | 
					
						
							|  |  |  |  |       if (this.selectWares && this.selectWares.length > 0) { | 
					
						
							|  |  |  |  |         this.yesText = "通过" | 
					
						
							|  |  |  |  |         this.backText = "驳回" | 
					
						
							|  |  |  |  |       } else { | 
					
						
							|  |  |  |  |         this.yesText = "通过全部" | 
					
						
							|  |  |  |  |         this.backText = "驳回全部" | 
					
						
							|  |  |  |  |       } | 
					
						
							|  |  |  |  |     }, | 
					
						
							|  |  |  |  |     getWaresStatus(val) { | 
					
						
							|  |  |  |  |       switch (val) { | 
					
						
							|  |  |  |  |         case "1": | 
					
						
							|  |  |  |  |           return "通过"; | 
					
						
							|  |  |  |  |         case "0": | 
					
						
							|  |  |  |  |           return "不通过"; | 
					
						
							|  |  |  |  |         default: | 
					
						
							|  |  |  |  |           return "待定" | 
					
						
							|  |  |  |  |       } | 
					
						
							|  |  |  |  |     }, | 
					
						
							|  |  |  |  |     getWaresStatusClass(val) { | 
					
						
							|  |  |  |  |       switch (val) { | 
					
						
							|  |  |  |  |         case "1": | 
					
						
							|  |  |  |  |           return "pass"; | 
					
						
							|  |  |  |  |         case "0": | 
					
						
							|  |  |  |  |           return "no_pass"; | 
					
						
							|  |  |  |  |         default: | 
					
						
							|  |  |  |  |           return "" | 
					
						
							|  |  |  |  |       } | 
					
						
							|  |  |  |  |     }, | 
					
						
							|  |  |  |  |     getDetail() { | 
					
						
							| 
									
										
										
										
											2024-10-23 22:15:34 +08:00
										 |  |  |  |       let url; | 
					
						
							| 
									
										
										
										
											2024-11-14 18:33:55 +08:00
										 |  |  |  |       let params = {}; | 
					
						
							| 
									
										
										
										
											2024-10-23 22:15:34 +08:00
										 |  |  |  |       this.title = "配件申请单详情" | 
					
						
							|  |  |  |  |       //配件申请单
 | 
					
						
							|  |  |  |  |       url = "/admin-api/repair/twi/list" | 
					
						
							|  |  |  |  |       params.twId = this.id | 
					
						
							| 
									
										
										
										
											2024-11-14 18:33:55 +08:00
										 |  |  |  |       this.yesText = "通过全部" | 
					
						
							|  |  |  |  |       this.backText = "驳回全部" | 
					
						
							| 
									
										
										
										
											2024-10-23 22:15:34 +08:00
										 |  |  |  |       request({ | 
					
						
							|  |  |  |  |         url: url, | 
					
						
							|  |  |  |  |         method: 'get', | 
					
						
							| 
									
										
										
										
											2024-11-14 18:33:55 +08:00
										 |  |  |  |         params: params | 
					
						
							| 
									
										
										
										
											2024-10-23 22:15:34 +08:00
										 |  |  |  |       }).then((res) => { | 
					
						
							|  |  |  |  |         if (res.code == 200) { | 
					
						
							|  |  |  |  |           this.repairList = res.data | 
					
						
							| 
									
										
										
										
											2024-11-14 18:33:55 +08:00
										 |  |  |  |           if (this.canOperate && this.repairList && this.repairList.length > 0) { | 
					
						
							|  |  |  |  |             this.repairList = this.repairList.filter(item => item.waresStatus === '').map(item => { | 
					
						
							|  |  |  |  |               return { | 
					
						
							|  |  |  |  |                 ...item, | 
					
						
							|  |  |  |  |                 selected: false | 
					
						
							|  |  |  |  |               } | 
					
						
							|  |  |  |  |             }) | 
					
						
							|  |  |  |  |           } | 
					
						
							| 
									
										
										
										
											2024-10-23 22:15:34 +08:00
										 |  |  |  |         } | 
					
						
							|  |  |  |  |       }) | 
					
						
							|  |  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-11-14 18:33:55 +08:00
										 |  |  |  |     confirmOpe(type) { | 
					
						
							|  |  |  |  |       // let forSign = true
 | 
					
						
							|  |  |  |  |       // if (type == 'yes') {
 | 
					
						
							|  |  |  |  |       //   this.repairList.map(item=>{
 | 
					
						
							|  |  |  |  |       //     if (item.wares.price == null || item.wares.price == ''){
 | 
					
						
							|  |  |  |  |       //       uni.showToast({
 | 
					
						
							|  |  |  |  |       //         title: '售价不能为空!',
 | 
					
						
							|  |  |  |  |       //         icon: 'none'
 | 
					
						
							|  |  |  |  |       //       })
 | 
					
						
							|  |  |  |  |       //       forSign = false
 | 
					
						
							|  |  |  |  |       //       return;
 | 
					
						
							|  |  |  |  |       //     }
 | 
					
						
							|  |  |  |  |       //   })
 | 
					
						
							|  |  |  |  |       // }
 | 
					
						
							|  |  |  |  |       // if (!forSign) {
 | 
					
						
							|  |  |  |  |       //   return;
 | 
					
						
							|  |  |  |  |       // }
 | 
					
						
							| 
									
										
										
										
											2024-10-23 22:15:34 +08:00
										 |  |  |  |       let url = '/admin-api/repair/tw/audit' | 
					
						
							| 
									
										
										
										
											2024-11-14 18:33:55 +08:00
										 |  |  |  |       let dataObj = { | 
					
						
							|  |  |  |  |         id: this.id, | 
					
						
							|  |  |  |  |         type: "01", | 
					
						
							|  |  |  |  |         status: "yes" == type ? "01" : "02" | 
					
						
							|  |  |  |  |       } | 
					
						
							|  |  |  |  |       if (this.selectWares && this.selectWares.length > 0) { | 
					
						
							|  |  |  |  |         dataObj.items = [...this.selectWares.map(item => { | 
					
						
							|  |  |  |  |           return { | 
					
						
							|  |  |  |  |             id: item.id | 
					
						
							|  |  |  |  |           } | 
					
						
							|  |  |  |  |         })] | 
					
						
							|  |  |  |  |       } else { | 
					
						
							|  |  |  |  |         dataObj.items = [...this.repairList.map(item => { | 
					
						
							|  |  |  |  |           return { | 
					
						
							|  |  |  |  |             id: item.id | 
					
						
							|  |  |  |  |           } | 
					
						
							|  |  |  |  |         })] | 
					
						
							| 
									
										
										
										
											2024-10-23 22:15:34 +08:00
										 |  |  |  |       } | 
					
						
							|  |  |  |  |       request({ | 
					
						
							|  |  |  |  |         url: url, | 
					
						
							|  |  |  |  |         method: 'POST', | 
					
						
							| 
									
										
										
										
											2024-11-14 18:33:55 +08:00
										 |  |  |  |         data: dataObj | 
					
						
							| 
									
										
										
										
											2024-10-23 22:15:34 +08:00
										 |  |  |  |       }).then((res) => { | 
					
						
							|  |  |  |  |         if (res.code == 200) { | 
					
						
							|  |  |  |  |           uni.showToast({ | 
					
						
							|  |  |  |  |             title: '审批成功!', | 
					
						
							|  |  |  |  |             icon: 'none' | 
					
						
							|  |  |  |  |           }) | 
					
						
							|  |  |  |  |           setTimeout(() => { | 
					
						
							|  |  |  |  |             uni.navigateBack() | 
					
						
							|  |  |  |  |           }, 700) | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |       }) | 
					
						
							|  |  |  |  |     }, | 
					
						
							|  |  |  |  |   } | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | </script> | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | <style lang="less" scoped> | 
					
						
							|  |  |  |  | .container { | 
					
						
							|  |  |  |  |   height: 100%; | 
					
						
							|  |  |  |  |   background: #F3F5F7; | 
					
						
							|  |  |  |  |   display: flex; | 
					
						
							|  |  |  |  |   flex-direction: column; | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | .body { | 
					
						
							|  |  |  |  |   flex: 1; | 
					
						
							|  |  |  |  |   height: 0; | 
					
						
							|  |  |  |  |   overflow: auto; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   .todoInfo { | 
					
						
							|  |  |  |  |     margin: 20rpx 32rpx; | 
					
						
							|  |  |  |  |     background-color: #fff; | 
					
						
							|  |  |  |  |     border-radius: 8rpx 8rpx 8rpx 8rpx; | 
					
						
							|  |  |  |  |     padding: 30rpx; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     .todoName { | 
					
						
							|  |  |  |  |       font-weight: bold; | 
					
						
							|  |  |  |  |       font-size: 32rpx; | 
					
						
							|  |  |  |  |       color: #333333; | 
					
						
							|  |  |  |  |       margin-bottom: 16rpx; | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     .todoDate { | 
					
						
							|  |  |  |  |       font-size: 24rpx; | 
					
						
							|  |  |  |  |       color: #858BA0; | 
					
						
							|  |  |  |  |       margin-bottom: 30rpx; | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     .line { | 
					
						
							|  |  |  |  |       height: 1rpx; | 
					
						
							|  |  |  |  |       background-color: #DDDDDD; | 
					
						
							|  |  |  |  |       margin: 30rpx 0; | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     .grid { | 
					
						
							|  |  |  |  |       display: grid; | 
					
						
							|  |  |  |  |       grid-template-areas: | 
					
						
							|  |  |  |  |       'a b' | 
					
						
							|  |  |  |  |       'c c'; | 
					
						
							|  |  |  |  |       gap: 20rpx; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |       .gridItem { | 
					
						
							|  |  |  |  |         display: flex; | 
					
						
							|  |  |  |  |         flex-direction: column; | 
					
						
							|  |  |  |  |         row-gap: 10rpx; | 
					
						
							|  |  |  |  |         font-size: 28rpx; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         .gridItemLabel { | 
					
						
							|  |  |  |  |           color: #858BA0; | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         .gridItemValue { | 
					
						
							|  |  |  |  |           color: #333333; | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |       } | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  |   } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   .repairInfo { | 
					
						
							|  |  |  |  |     margin: 20rpx 32rpx; | 
					
						
							|  |  |  |  |     background-color: #fff; | 
					
						
							|  |  |  |  |     border-radius: 8rpx 8rpx 8rpx 8rpx; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     .header { | 
					
						
							|  |  |  |  |       padding: 30rpx; | 
					
						
							|  |  |  |  |       border-bottom: 1rpx solid #DDDDDD; | 
					
						
							|  |  |  |  |     } | 
					
						
							| 
									
										
										
										
											2024-11-14 18:33:55 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-23 22:15:34 +08:00
										 |  |  |  |     .repairItem { | 
					
						
							|  |  |  |  |       padding: 30rpx; | 
					
						
							|  |  |  |  |       border-bottom: 1rpx solid #DDDDDD; | 
					
						
							| 
									
										
										
										
											2024-11-14 18:33:55 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-23 22:15:34 +08:00
										 |  |  |  |       &:last-child { | 
					
						
							|  |  |  |  |         border-bottom: none; | 
					
						
							|  |  |  |  |       } | 
					
						
							|  |  |  |  |     } | 
					
						
							| 
									
										
										
										
											2024-11-14 18:33:55 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-23 22:15:34 +08:00
										 |  |  |  |     .repairName { | 
					
						
							|  |  |  |  |       display: flex; | 
					
						
							|  |  |  |  |       align-items: center; | 
					
						
							|  |  |  |  |       column-gap: 20rpx; | 
					
						
							|  |  |  |  |       font-size: 32rpx; | 
					
						
							|  |  |  |  |       color: #333333; | 
					
						
							|  |  |  |  |       margin-bottom: 30rpx; | 
					
						
							| 
									
										
										
										
											2024-11-14 18:33:55 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-23 22:15:34 +08:00
										 |  |  |  |       .repairNum { | 
					
						
							|  |  |  |  |         font-size: 28rpx; | 
					
						
							|  |  |  |  |         color: #0174F6; | 
					
						
							|  |  |  |  |       } | 
					
						
							|  |  |  |  |     } | 
					
						
							| 
									
										
										
										
											2024-11-14 18:33:55 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-23 22:15:34 +08:00
										 |  |  |  |     .grid { | 
					
						
							|  |  |  |  |       display: grid; | 
					
						
							|  |  |  |  |       grid-template-areas: | 
					
						
							|  |  |  |  |         'a b' | 
					
						
							| 
									
										
										
										
											2024-11-14 18:33:55 +08:00
										 |  |  |  |         'c d' | 
					
						
							|  |  |  |  | 		'e f'; | 
					
						
							| 
									
										
										
										
											2024-10-23 22:15:34 +08:00
										 |  |  |  |       grid-template-columns: 1fr 1fr; | 
					
						
							|  |  |  |  |       gap: 30rpx; | 
					
						
							| 
									
										
										
										
											2024-11-14 18:33:55 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-23 22:15:34 +08:00
										 |  |  |  |       .girdItem { | 
					
						
							|  |  |  |  |         display: flex; | 
					
						
							|  |  |  |  |         flex-direction: column; | 
					
						
							|  |  |  |  |         row-gap: 12rpx; | 
					
						
							|  |  |  |  |         font-size: 28rpx; | 
					
						
							| 
									
										
										
										
											2024-11-14 18:33:55 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-23 22:15:34 +08:00
										 |  |  |  |         .label { | 
					
						
							|  |  |  |  |           color: #858BA0; | 
					
						
							|  |  |  |  |         } | 
					
						
							| 
									
										
										
										
											2024-11-14 18:33:55 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-23 22:15:34 +08:00
										 |  |  |  |         .value { | 
					
						
							|  |  |  |  |           color: #333333; | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |       } | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  |   } | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | .footer { | 
					
						
							|  |  |  |  |   background-color: #fff; | 
					
						
							|  |  |  |  |   display: flex; | 
					
						
							|  |  |  |  |   justify-content: space-between; | 
					
						
							|  |  |  |  |   align-items: center; | 
					
						
							|  |  |  |  |   padding: 30rpx 32rpx; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   .yes, .no { | 
					
						
							|  |  |  |  |     width: 310rpx; | 
					
						
							|  |  |  |  |     height: 76rpx; | 
					
						
							|  |  |  |  |     border-radius: 38rpx 38rpx 38rpx 38rpx; | 
					
						
							|  |  |  |  |     display: flex; | 
					
						
							|  |  |  |  |     align-items: center; | 
					
						
							|  |  |  |  |     justify-content: center; | 
					
						
							|  |  |  |  |     column-gap: 10rpx; | 
					
						
							|  |  |  |  |   } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   .yes { | 
					
						
							|  |  |  |  |     background: #0174F6; | 
					
						
							|  |  |  |  |     color: #FFFFFF; | 
					
						
							|  |  |  |  |   } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   .no { | 
					
						
							|  |  |  |  |     border: 2rpx solid #858BA0; | 
					
						
							|  |  |  |  |     color: #858BA0; | 
					
						
							|  |  |  |  |   } | 
					
						
							|  |  |  |  | } | 
					
						
							| 
									
										
										
										
											2024-11-14 18:33:55 +08:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | .pass { | 
					
						
							|  |  |  |  |   color: #2979FF; | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | .no_pass { | 
					
						
							|  |  |  |  |   color: #E8A321; | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | .image-item { | 
					
						
							|  |  |  |  |   width: 100rpx; | 
					
						
							|  |  |  |  |   height: 100rpx; | 
					
						
							|  |  |  |  |   border-radius: 8rpx; | 
					
						
							|  |  |  |  |   object-fit: cover; | 
					
						
							|  |  |  |  |   margin-right: 10rpx; /* 增加右边距,使图片之间有间隔 */ | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | .fullscreen-container { | 
					
						
							|  |  |  |  |   position: fixed; | 
					
						
							|  |  |  |  |   top: 0; | 
					
						
							|  |  |  |  |   left: 0; | 
					
						
							|  |  |  |  |   right: 0; | 
					
						
							|  |  |  |  |   bottom: 0; | 
					
						
							|  |  |  |  |   background-color: rgba(0, 0, 0, 0.8); | 
					
						
							|  |  |  |  |   display: flex; | 
					
						
							|  |  |  |  |   justify-content: center; | 
					
						
							|  |  |  |  |   align-items: center; | 
					
						
							|  |  |  |  |   z-index: 9999; | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | .fullscreen-image { | 
					
						
							|  |  |  |  |   max-width: 90vw; /* 最大宽度为视口宽度的90% */ | 
					
						
							|  |  |  |  |   max-height: 90vh; /* 最大高度为视口高度的90% */ | 
					
						
							|  |  |  |  |   object-fit: contain; /* 保持宽高比 */ | 
					
						
							|  |  |  |  |   cursor: pointer; | 
					
						
							|  |  |  |  |   margin: 0 20rpx; /* 增加左右边距,使图片距离屏幕边缘有一定距离 */ | 
					
						
							|  |  |  |  | } | 
					
						
							| 
									
										
										
										
											2024-10-23 22:15:34 +08:00
										 |  |  |  | </style> |