| 
									
										
										
										
											2025-03-15 17:32:23 +08:00
										 |  |  | <template> | 
					
						
							|  |  |  |   <view class="page flex-col"> | 
					
						
							| 
									
										
										
										
											2025-04-03 16:47:39 +08:00
										 |  |  |     <view style="width: 100%;background: #f4f5f6;box-sizing: border-box;padding-top: 88px;"> | 
					
						
							|  |  |  |       <headers titles="预约"> | 
					
						
							|  |  |  |         <uni-icons type="left" color="#000000" size="22px"></uni-icons> | 
					
						
							|  |  |  |       </headers> | 
					
						
							| 
									
										
										
										
											2025-03-15 17:32:23 +08:00
										 |  |  |     </view> | 
					
						
							|  |  |  |     <view class="section_3 flex-col"> | 
					
						
							| 
									
										
										
										
											2025-04-03 16:47:39 +08:00
										 |  |  |       <view :class="appointmentInfo.status === false ? 'jj' : 'section_4'" class="flex-row"> | 
					
						
							|  |  |  |         <view class="text-group_1 flex-col justify-between" v-if="isTrain"> | 
					
						
							|  |  |  |           <text class="text_2">已训练</text> | 
					
						
							|  |  |  |           <text class="text_3">{{ appointmentInfo.trainDay }}</text> | 
					
						
							|  |  |  |         </view> | 
					
						
							|  |  |  |         <view class="text-group_1 flex-col justify-between" v-else> | 
					
						
							|  |  |  |           <text class="text_2">{{ appointmentInfo.statusStr }}</text> | 
					
						
							|  |  |  |           <text class="text_3">{{ appointmentInfo.reservDay }}</text> | 
					
						
							| 
									
										
										
										
											2025-03-15 17:32:23 +08:00
										 |  |  |         </view> | 
					
						
							|  |  |  |       </view> | 
					
						
							| 
									
										
										
										
											2025-04-03 16:47:39 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-03-15 17:32:23 +08:00
										 |  |  |       <view class="text-wrapper_1 flex-row justify-between"> | 
					
						
							|  |  |  |         <text class="text_4">课程名称</text> | 
					
						
							| 
									
										
										
										
											2025-04-03 16:47:39 +08:00
										 |  |  |         <text class="text_5">{{ appointmentInfo.courseName }}</text> | 
					
						
							| 
									
										
										
										
											2025-03-15 17:32:23 +08:00
										 |  |  |       </view> | 
					
						
							|  |  |  |       <view class="text-wrapper_2 flex-row justify-between"> | 
					
						
							|  |  |  |         <text class="text_6">训练类型</text> | 
					
						
							| 
									
										
										
										
											2025-04-03 16:47:39 +08:00
										 |  |  |         <text class="text_7">{{ appointmentInfo.courseType }}</text> | 
					
						
							| 
									
										
										
										
											2025-03-15 17:32:23 +08:00
										 |  |  |       </view> | 
					
						
							|  |  |  |       <view class="text-wrapper_3 flex-row justify-between"> | 
					
						
							|  |  |  |         <text class="text_8">训练科目</text> | 
					
						
							| 
									
										
										
										
											2025-04-03 16:47:39 +08:00
										 |  |  |         <text class="text_9">{{ subjectArr[appointmentInfo.subject - 1] }}</text> | 
					
						
							| 
									
										
										
										
											2025-03-15 17:32:23 +08:00
										 |  |  |       </view> | 
					
						
							|  |  |  |       <view class="text-wrapper_4 flex-row justify-between"> | 
					
						
							|  |  |  |         <text class="text_10">教练名称</text> | 
					
						
							| 
									
										
										
										
											2025-04-03 16:47:39 +08:00
										 |  |  |         <text class="text_11">{{ appointmentInfo.coachName }}</text> | 
					
						
							| 
									
										
										
										
											2025-03-15 17:32:23 +08:00
										 |  |  |       </view> | 
					
						
							| 
									
										
										
										
											2025-04-03 16:47:39 +08:00
										 |  |  |       <!-- 添加一条宽度占 80% 的线 --> | 
					
						
							|  |  |  |       <view style="width: 90%; height: 1px; background-color: #e0e0e0; margin: 20px 10rpx auto;"></view> | 
					
						
							|  |  |  |       <view class="text-wrapper_5 flex-row justify-between" v-if="!isTrain"> | 
					
						
							| 
									
										
										
										
											2025-03-15 17:32:23 +08:00
										 |  |  |         <text class="text_12">累计训练时长</text> | 
					
						
							| 
									
										
										
										
											2025-04-08 17:00:07 +08:00
										 |  |  |         <text class="text_13">{{ appointmentInfo.trainTime }}分钟</text> | 
					
						
							| 
									
										
										
										
											2025-03-15 17:32:23 +08:00
										 |  |  |       </view> | 
					
						
							| 
									
										
										
										
											2025-04-03 16:47:39 +08:00
										 |  |  |       <view class="text-wrapper_6 flex-row justify-between" v-if="isTrain"> | 
					
						
							| 
									
										
										
										
											2025-03-15 17:32:23 +08:00
										 |  |  |         <text class="text_14">训练地址</text> | 
					
						
							| 
									
										
										
										
											2025-04-03 16:47:39 +08:00
										 |  |  |         <text class="text_15">{{ appointmentInfo.addr }}</text> | 
					
						
							| 
									
										
										
										
											2025-03-15 17:32:23 +08:00
										 |  |  |       </view> | 
					
						
							| 
									
										
										
										
											2025-04-03 16:47:39 +08:00
										 |  |  |       <view class="text-wrapper_7 flex-row justify-between" :class="isTrain ? 'text-wrapper_8' : 'text-wrapper_7'" | 
					
						
							|  |  |  |             v-if="isTrain"> | 
					
						
							| 
									
										
										
										
											2025-03-15 17:32:23 +08:00
										 |  |  |         <text class="text_16">交通方式</text> | 
					
						
							| 
									
										
										
										
											2025-04-03 16:47:39 +08:00
										 |  |  |         <text class="text_17">{{ appointmentInfo.reservationWay }}</text> | 
					
						
							| 
									
										
										
										
											2025-03-15 17:32:23 +08:00
										 |  |  |       </view> | 
					
						
							| 
									
										
										
										
											2025-04-03 16:47:39 +08:00
										 |  |  |       <view class="text-wrapper_8 flex-row justify-between" v-else> | 
					
						
							| 
									
										
										
										
											2025-03-15 17:32:23 +08:00
										 |  |  |         <text class="text_18">时间范围</text> | 
					
						
							| 
									
										
										
										
											2025-04-03 16:47:39 +08:00
										 |  |  |         <text class="text_19">{{ appointmentInfo.reservTime }}</text> | 
					
						
							| 
									
										
										
										
											2025-03-15 17:32:23 +08:00
										 |  |  |       </view> | 
					
						
							|  |  |  |     </view> | 
					
						
							| 
									
										
										
										
											2025-04-03 16:47:39 +08:00
										 |  |  |     <view class="text-wrapper_9 flex-col" v-if="!isTrain"> | 
					
						
							| 
									
										
										
										
											2025-03-15 17:32:23 +08:00
										 |  |  |       <text class="text_20">审核意见</text> | 
					
						
							|  |  |  |       <text class="text_21"> | 
					
						
							| 
									
										
										
										
											2025-04-08 17:00:07 +08:00
										 |  |  |         {{ appointmentInfo.refuseReason == null ? '暂无' : appointmentInfo.refuseReason }} | 
					
						
							| 
									
										
										
										
											2025-03-15 17:32:23 +08:00
										 |  |  |       </text> | 
					
						
							|  |  |  |     </view> | 
					
						
							|  |  |  |   </view> | 
					
						
							|  |  |  | </template> | 
					
						
							|  |  |  | <script> | 
					
						
							| 
									
										
										
										
											2025-04-03 16:47:39 +08:00
										 |  |  | import headers from "@/components/header/headers.vue"; | 
					
						
							|  |  |  | import request from "@/utils/request"; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-03-15 17:32:23 +08:00
										 |  |  | export default { | 
					
						
							| 
									
										
										
										
											2025-04-03 16:47:39 +08:00
										 |  |  |   components: {headers}, | 
					
						
							| 
									
										
										
										
											2025-03-15 17:32:23 +08:00
										 |  |  |   data() { | 
					
						
							|  |  |  |     return { | 
					
						
							| 
									
										
										
										
											2025-04-03 16:47:39 +08:00
										 |  |  |       constants: {}, | 
					
						
							|  |  |  |       appointmentInfo: {}, | 
					
						
							|  |  |  |       isTrain: false, | 
					
						
							|  |  |  |       subjectArr: ['科目一', '科目二', '科目三', '科目四'], | 
					
						
							| 
									
										
										
										
											2025-03-15 17:32:23 +08:00
										 |  |  |     }; | 
					
						
							|  |  |  |   }, | 
					
						
							| 
									
										
										
										
											2025-04-03 16:47:39 +08:00
										 |  |  |   onLoad(options) { | 
					
						
							|  |  |  |     this.appointmentInfo = JSON.parse(options.data) | 
					
						
							|  |  |  |     this.getAllTrainTime() | 
					
						
							|  |  |  |     console.log(this.appointmentInfo) | 
					
						
							|  |  |  |     if (options.type === 'train') { | 
					
						
							|  |  |  |       this.isTrain = true | 
					
						
							| 
									
										
										
										
											2025-04-03 17:33:17 +08:00
										 |  |  |     } else { | 
					
						
							| 
									
										
										
										
											2025-04-03 16:47:39 +08:00
										 |  |  |       this.isTrain = false | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     console.log(this.isTrain) | 
					
						
							|  |  |  |   }, | 
					
						
							|  |  |  |   methods: { | 
					
						
							| 
									
										
										
										
											2025-04-03 17:33:17 +08:00
										 |  |  |     async getAllTrainTime() { | 
					
						
							|  |  |  |       try { | 
					
						
							|  |  |  |         const res = await request({ | 
					
						
							|  |  |  |           url: "/app-api/process/getAllByCourseId", | 
					
						
							|  |  |  |           method: "GET", | 
					
						
							|  |  |  |           params: { | 
					
						
							|  |  |  |             courseId: this.appointmentInfo.courseId, | 
					
						
							|  |  |  |           }, | 
					
						
							|  |  |  |           tenantIdFlag: false, | 
					
						
							|  |  |  |         }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         console.log("获取所有训练时间", res); | 
					
						
							|  |  |  |         console.log("当前科目:", this.appointmentInfo.subject); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // 确保 appointmentInfo.subject 已有值
 | 
					
						
							|  |  |  |         if (!this.appointmentInfo.subject) { | 
					
						
							|  |  |  |           console.warn("appointmentInfo.subject 为空,等待赋值..."); | 
					
						
							|  |  |  |           await new Promise((resolve) => setTimeout(resolve, 100)); | 
					
						
							| 
									
										
										
										
											2025-04-03 16:47:39 +08:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2025-04-03 17:33:17 +08:00
										 |  |  |         const data = res.data.find( | 
					
						
							|  |  |  |             (item) => item.subject == this.appointmentInfo.subject | 
					
						
							|  |  |  |         ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         console.log("匹配的训练时间数据:", data); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-04-08 17:00:07 +08:00
										 |  |  |         this.appointmentInfo.trainTime = data ? data.trainTime || "0" : "0"; | 
					
						
							| 
									
										
										
										
											2025-04-03 17:33:17 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |         console.log( | 
					
						
							| 
									
										
										
										
											2025-04-08 17:00:07 +08:00
										 |  |  |             "this.appointmentInfo.trainTime", | 
					
						
							|  |  |  |             this.appointmentInfo.trainTime | 
					
						
							| 
									
										
										
										
											2025-04-03 17:33:17 +08:00
										 |  |  |         ); | 
					
						
							|  |  |  |       } catch (error) { | 
					
						
							|  |  |  |         console.error("获取训练时间失败:", error); | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											2025-04-03 16:47:39 +08:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2025-04-03 17:33:17 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-04-03 16:47:39 +08:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2025-03-15 17:32:23 +08:00
										 |  |  | }; | 
					
						
							|  |  |  | </script> | 
					
						
							|  |  |  | <style lang='scss'> | 
					
						
							|  |  |  | @import '../common/common.scss'; | 
					
						
							|  |  |  | @import './assets/style/index.rpx.scss'; | 
					
						
							| 
									
										
										
										
											2025-04-03 16:47:39 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | .jj { | 
					
						
							|  |  |  |   background-image: linear-gradient(180deg, rgba(245, 44, 44, 0.2) 0%, rgba(245, 44, 44, 0) 100%); | 
					
						
							|  |  |  |   border-radius: 8px; | 
					
						
							|  |  |  |   width: 686rpx; | 
					
						
							|  |  |  |   height: 140rpx; | 
					
						
							|  |  |  |   border: 1px solid rgba(255, 255, 255, 1); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   .text-group_1 { | 
					
						
							|  |  |  |     width: 248rpx; | 
					
						
							|  |  |  |     height: 80rpx; | 
					
						
							|  |  |  |     margin: 30rpx 0 0 20rpx; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     .text_2 { | 
					
						
							|  |  |  |       width: 96rpx; | 
					
						
							|  |  |  |       height: 32rpx; | 
					
						
							|  |  |  |       overflow-wrap: break-word; | 
					
						
							|  |  |  |       color: rgba(242, 39, 39, 1); | 
					
						
							|  |  |  |       font-size: 32rpx; | 
					
						
							|  |  |  |       font-family: PingFang SC-Regular; | 
					
						
							|  |  |  |       font-weight: NaN; | 
					
						
							|  |  |  |       text-align: left; | 
					
						
							|  |  |  |       white-space: nowrap; | 
					
						
							|  |  |  |       line-height: 32rpx; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     .text_3 { | 
					
						
							|  |  |  |       width: 248rpx; | 
					
						
							|  |  |  |       height: 28rpx; | 
					
						
							|  |  |  |       overflow-wrap: break-word; | 
					
						
							|  |  |  |       color: rgba(115, 124, 144, 1); | 
					
						
							|  |  |  |       font-size: 28rpx; | 
					
						
							|  |  |  |       font-family: PingFang SC-Regular; | 
					
						
							|  |  |  |       font-weight: NaN; | 
					
						
							|  |  |  |       text-align: left; | 
					
						
							|  |  |  |       white-space: nowrap; | 
					
						
							|  |  |  |       line-height: 28rpx; | 
					
						
							|  |  |  |       margin-top: 20rpx; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2025-03-15 17:32:23 +08:00
										 |  |  | </style> |