| 
									
										
										
										
											2024-08-22 19:34:47 +08:00
										 |  |  | <template> | 
					
						
							|  |  |  | 	<view> | 
					
						
							|  |  |  | 		<view class="orderCard" @click="onShowDetail"> | 
					
						
							|  |  |  | 			<view class="orderCardHeader"> | 
					
						
							| 
									
										
										
										
											2024-08-22 22:04:46 +08:00
										 |  |  | 				<text class="orderCardType">{{ getRescueTypeStr() }}</text> | 
					
						
							| 
									
										
										
										
											2024-08-22 19:34:47 +08:00
										 |  |  | 				<text class="orderCardTitle">{{ orderData.rescuePosition }}</text> | 
					
						
							|  |  |  | 			</view> | 
					
						
							|  |  |  | 			<view class="orderCardStatus"> | 
					
						
							|  |  |  | 				<view class="orderCardStatusData"> | 
					
						
							| 
									
										
										
										
											2024-08-23 23:34:34 +08:00
										 |  |  | 					<view v-if="orderData.rescueStatus == 1" class="orderCardSendOrders"> | 
					
						
							| 
									
										
										
										
											2024-08-23 23:26:40 +08:00
										 |  |  | 						预约单 | 
					
						
							|  |  |  | 					</view> | 
					
						
							| 
									
										
										
										
											2024-08-23 23:17:22 +08:00
										 |  |  | 					<view v-if="orderData.rescueStatus == 2" class="orderCardSendOrders"> | 
					
						
							|  |  |  | 						系统正在派单中... | 
					
						
							|  |  |  | 					</view> | 
					
						
							| 
									
										
										
										
											2024-08-23 20:04:25 +08:00
										 |  |  | 					<template v-if="orderData.rescueStatus == 3"> | 
					
						
							| 
									
										
										
										
											2024-08-22 19:34:47 +08:00
										 |  |  | 						<image src="@/static/icons/homeOrderCard/dhjl.png" class="orderCardDistanceIcon" mode="aspectFit"></image> | 
					
						
							|  |  |  | 						<text class="orderCardDistanceValue">{{orderData.distance / 1000 || 0}}KM</text> | 
					
						
							|  |  |  | 						  | 
					
						
							| 
									
										
										
										
											2024-09-06 09:18:25 +08:00
										 |  |  | 						<!-- #ifdef MP --> | 
					
						
							| 
									
										
										
										
											2024-08-22 19:34:47 +08:00
										 |  |  | 						<image src="@/static/icons/homeOrderCard/yjsj.png" class="orderCardPredictIcon"></image> | 
					
						
							| 
									
										
										
										
											2024-09-06 09:18:25 +08:00
										 |  |  | 						<!-- #endif --> | 
					
						
							|  |  |  | 						<!-- #ifndef MP --> | 
					
						
							|  |  |  | 						<image src="@/static/icons/homeOrderCard/yjsj.svg" class="orderCardPredictIcon"></image> | 
					
						
							|  |  |  | 						<!-- #endif --> | 
					
						
							| 
									
										
										
										
											2024-08-22 19:34:47 +08:00
										 |  |  | 						<text class="orderCardPredictDate">{{orderData.needTime || 0}}分钟</text> | 
					
						
							|  |  |  | 						到达 | 
					
						
							|  |  |  | 					</template> | 
					
						
							|  |  |  | 				</view> | 
					
						
							| 
									
										
										
										
											2024-08-24 12:03:33 +08:00
										 |  |  | 				<text v-if="statusStr" :class="{ toRescued: status == 2 || status == 3 || status == 4, inRescue: status == 5 || status == 1 }" | 
					
						
							| 
									
										
										
										
											2024-08-22 19:34:47 +08:00
										 |  |  | 					class="orderCardFlag"> | 
					
						
							| 
									
										
										
										
											2024-08-24 12:03:33 +08:00
										 |  |  | 					<template>{{statusStr}}</template> | 
					
						
							| 
									
										
										
										
											2024-08-22 19:34:47 +08:00
										 |  |  | 				</text> | 
					
						
							|  |  |  | 			</view> | 
					
						
							|  |  |  | 			<view class="orderCardProcess"> | 
					
						
							|  |  |  | 				<view v-if="orderData.rescueStatus > 2"> | 
					
						
							| 
									
										
										
										
											2024-08-22 22:04:46 +08:00
										 |  |  | 					<text class="orderCardDriver">{{ orderData.driverName || "" }}</text> | 
					
						
							| 
									
										
										
										
											2024-08-22 19:34:47 +08:00
										 |  |  | 					驾驶 | 
					
						
							| 
									
										
										
										
											2024-08-22 22:04:46 +08:00
										 |  |  | 					<text class="orderCardCarNo">{{ orderData.driverCarNum || "" }}</text> | 
					
						
							| 
									
										
										
										
											2024-08-22 19:34:47 +08:00
										 |  |  | 				</view> | 
					
						
							|  |  |  | 			</view> | 
					
						
							|  |  |  | 			<view class="orderCardFooter"> | 
					
						
							| 
									
										
										
										
											2024-08-22 22:04:46 +08:00
										 |  |  | 				<text class="orderCardDateTime">{{ orderData.rescueTime || "" }}</text> | 
					
						
							| 
									
										
										
										
											2024-08-22 19:34:47 +08:00
										 |  |  | 				<view class="orderCardBtnGroup"> | 
					
						
							| 
									
										
										
										
											2024-08-27 21:45:25 +08:00
										 |  |  | 					<template v-if="hasRole('ddzx') && orderData.rescueStatus <= 2"> | 
					
						
							| 
									
										
										
										
											2024-08-22 19:34:47 +08:00
										 |  |  | 						<view @click.stop="deleteId" class="orderCardBtnGroupItem" style="background-color: #fff;color: #317DFA"> | 
					
						
							|  |  |  | 							删除订单</view> | 
					
						
							|  |  |  | 						<view @click.stop="getzhipai" class="orderCardBtnGroupItem">指派司机</view> | 
					
						
							|  |  |  | 					</template> | 
					
						
							|  |  |  | 					<template v-else-if="orderData.rescueStatus > 2"> | 
					
						
							|  |  |  | 						<view @click.stop="gettel" class="orderCardBtnGroupItem">联系司机</view> | 
					
						
							|  |  |  | 					</template> | 
					
						
							|  |  |  | 				</view> | 
					
						
							|  |  |  | 			</view> | 
					
						
							|  |  |  | 		</view> | 
					
						
							|  |  |  | 		<u-picker :show="show" :columns="columns" @confirm="confirms" @cancel="cancels" keyName="realName"></u-picker> | 
					
						
							|  |  |  | 		<u-modal :show="showDelete" title="是否确认删除" :showCancelButton="true" @confirm="deleteOk" | 
					
						
							|  |  |  | 			@cancel="deleteCancel"></u-modal> | 
					
						
							|  |  |  | 	</view> | 
					
						
							|  |  |  | </template> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | <script> | 
					
						
							|  |  |  | 	import request from '../../utils/request'; | 
					
						
							| 
									
										
										
										
											2024-08-27 21:45:25 +08:00
										 |  |  |   import {hasRole} from "@/utils/auth"; | 
					
						
							| 
									
										
										
										
											2024-08-22 19:34:47 +08:00
										 |  |  | 	export default { | 
					
						
							|  |  |  | 		props: { | 
					
						
							|  |  |  | 			orderData: { | 
					
						
							|  |  |  | 				type: Object, | 
					
						
							|  |  |  | 				default: () => { | 
					
						
							|  |  |  | 					return {} | 
					
						
							|  |  |  | 				} | 
					
						
							| 
									
										
										
										
											2024-08-24 12:03:33 +08:00
										 |  |  | 			}, | 
					
						
							|  |  |  | 			status: { | 
					
						
							|  |  |  | 				type: [String, Number], | 
					
						
							|  |  |  | 				default: '' | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		computed: { | 
					
						
							|  |  |  | 			statusStr() { | 
					
						
							|  |  |  | 				console.log('this.status: ',this.status); | 
					
						
							|  |  |  | 				if (this.status == '1') { | 
					
						
							|  |  |  | 					return '救援中' | 
					
						
							|  |  |  | 				} else if (this.status == '2') { | 
					
						
							|  |  |  | 					return '待支付' | 
					
						
							|  |  |  | 				} else if (this.status == '3') { | 
					
						
							|  |  |  | 					return '待取车' | 
					
						
							|  |  |  | 				} else if (this.status == '4') { | 
					
						
							|  |  |  | 					return '待评价' | 
					
						
							|  |  |  | 				} else if (this.status == '5') { | 
					
						
							|  |  |  | 					return '已完成' | 
					
						
							|  |  |  | 				} else { | 
					
						
							|  |  |  | 					return '' | 
					
						
							|  |  |  | 				} | 
					
						
							| 
									
										
										
										
											2024-08-22 19:34:47 +08:00
										 |  |  | 			} | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		data() { | 
					
						
							|  |  |  | 			return { | 
					
						
							|  |  |  | 				columns: [], | 
					
						
							|  |  |  | 				id: '', | 
					
						
							|  |  |  | 				show: false, | 
					
						
							|  |  |  | 				showDelete: false, | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		methods: { | 
					
						
							| 
									
										
										
										
											2024-08-27 21:45:25 +08:00
										 |  |  |       hasRole, | 
					
						
							| 
									
										
										
										
											2024-08-22 22:04:46 +08:00
										 |  |  |       getRescueTypeStr(){ | 
					
						
							|  |  |  |         if(this.orderData.rescueTypeStr){ | 
					
						
							|  |  |  |           return this.orderData.rescueTypeStr | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         switch (this.orderData.rescueType){ | 
					
						
							|  |  |  |           case '1': | 
					
						
							|  |  |  |             return '拖车' | 
					
						
							|  |  |  |           case '2': | 
					
						
							|  |  |  |             return '送油' | 
					
						
							|  |  |  |           case '3': | 
					
						
							|  |  |  |             return '搭电' | 
					
						
							|  |  |  |           case '4': | 
					
						
							|  |  |  |             return '换胎' | 
					
						
							|  |  |  |           case '5': | 
					
						
							|  |  |  |             return '扣车' | 
					
						
							|  |  |  |           case '6': | 
					
						
							|  |  |  |             return '事故' | 
					
						
							|  |  |  |           case '7': | 
					
						
							|  |  |  |             return '秩序' | 
					
						
							|  |  |  |           default: | 
					
						
							|  |  |  |             return '' | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       }, | 
					
						
							| 
									
										
										
										
											2024-08-22 19:34:47 +08:00
										 |  |  | 			onShowDetail() { | 
					
						
							|  |  |  | 				uni.navigateTo({ | 
					
						
							|  |  |  | 					url: '/pages/details/details?id=' + this.orderData.id | 
					
						
							|  |  |  | 				}) | 
					
						
							|  |  |  | 			}, | 
					
						
							|  |  |  | 			// zhi指派司机
 | 
					
						
							|  |  |  | 			getzhipai() { | 
					
						
							|  |  |  | 				console.log('getzhipai: ', this.getzhipai); | 
					
						
							|  |  |  | 				this.getsjlist() | 
					
						
							|  |  |  | 				this.show = true | 
					
						
							|  |  |  | 			}, | 
					
						
							|  |  |  | 			// 获取司机列表
 | 
					
						
							|  |  |  | 			getsjlist() { | 
					
						
							|  |  |  | 				this.columns = [] | 
					
						
							|  |  |  | 				// 获取司机信息
 | 
					
						
							|  |  |  | 				request({ | 
					
						
							|  |  |  | 					url: '/app/rescueInfo/driverInMap?searchValue=', | 
					
						
							|  |  |  | 					method: 'get', | 
					
						
							|  |  |  | 				}).then((res) => { | 
					
						
							|  |  |  | 					this.columns.push(res.data) | 
					
						
							|  |  |  | 				}) | 
					
						
							|  |  |  | 			}, | 
					
						
							|  |  |  | 			// 指派确定
 | 
					
						
							|  |  |  | 			confirms(e) { | 
					
						
							|  |  |  | 				console.log(e); | 
					
						
							|  |  |  | 				let data = { | 
					
						
							|  |  |  | 					rescueId: this.orderData.id, | 
					
						
							|  |  |  | 					driverId: e.value[0].id | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 				request({ | 
					
						
							|  |  |  | 					url: '/system/rescueInfo/designateDriver', | 
					
						
							|  |  |  | 					method: 'post', | 
					
						
							|  |  |  | 					params: data | 
					
						
							|  |  |  | 				}).then((res) => { | 
					
						
							|  |  |  | 					console.log('确认司机', res); | 
					
						
							|  |  |  | 					if (res.code == 200) { | 
					
						
							|  |  |  | 						uni.showToast({ | 
					
						
							|  |  |  | 							title: '指派成功' | 
					
						
							|  |  |  | 						}) | 
					
						
							|  |  |  | 						this.$emit('refresh') | 
					
						
							|  |  |  | 					} | 
					
						
							|  |  |  | 				}) | 
					
						
							|  |  |  | 				this.show = false | 
					
						
							|  |  |  | 			}, | 
					
						
							|  |  |  | 			// 指派取消
 | 
					
						
							|  |  |  | 			cancels() { | 
					
						
							|  |  |  | 				this.show = false | 
					
						
							|  |  |  | 			}, | 
					
						
							|  |  |  | 			// 删除订单
 | 
					
						
							|  |  |  | 			deleteId() { | 
					
						
							|  |  |  | 				this.showDelete = true | 
					
						
							|  |  |  | 				return | 
					
						
							|  |  |  | 			}, | 
					
						
							|  |  |  | 			deleteOk() { | 
					
						
							|  |  |  | 				request({ | 
					
						
							|  |  |  | 					url: "/app/rescueInfo/delRescueInfo?id=" + this.orderData.id, | 
					
						
							|  |  |  | 					method: 'post', | 
					
						
							|  |  |  | 				}).then(res => { | 
					
						
							|  |  |  | 					if (res.code == 200) { | 
					
						
							|  |  |  | 						uni.showToast({ | 
					
						
							|  |  |  | 							title: "删除成功" | 
					
						
							|  |  |  | 						}) | 
					
						
							|  |  |  | 						this.$emit('deleteOk') | 
					
						
							|  |  |  | 					} | 
					
						
							|  |  |  | 				}) | 
					
						
							|  |  |  | 				this.showDelete = false | 
					
						
							|  |  |  | 			}, | 
					
						
							|  |  |  | 			deleteCancel() { | 
					
						
							|  |  |  | 				console.log("取消"); | 
					
						
							|  |  |  | 				this.showDelete = false | 
					
						
							|  |  |  | 			}, | 
					
						
							|  |  |  | 			// 联系司机
 | 
					
						
							|  |  |  | 			gettel() { | 
					
						
							|  |  |  | 				uni.makePhoneCall({ | 
					
						
							|  |  |  | 					phoneNumber: this.orderData.driverPhoneNum //仅为示例
 | 
					
						
							|  |  |  | 				}); | 
					
						
							|  |  |  | 			}, | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | </script> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | <style lang="scss" scoped> | 
					
						
							|  |  |  | 	.orderCard { | 
					
						
							|  |  |  | 		background-color: #fff; | 
					
						
							|  |  |  | 		padding: 24rpx; | 
					
						
							|  |  |  | 		border-radius: 16rpx; | 
					
						
							|  |  |  | 		display: flex; | 
					
						
							|  |  |  | 		flex-direction: column; | 
					
						
							|  |  |  | 		row-gap: 22rpx; | 
					
						
							|  |  |  | 		box-shadow: 2rpx 4rpx 8rpx rgba(0, 0, 0, 0.1); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	.orderCardHeader { | 
					
						
							|  |  |  | 		line-height: 1.5; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		.orderCardType { | 
					
						
							|  |  |  | 			background-color: #EAF1FE; | 
					
						
							|  |  |  | 			color: #317DFA; | 
					
						
							| 
									
										
										
										
											2024-08-24 10:25:25 +08:00
										 |  |  | 			padding: 8rpx 16rpx; | 
					
						
							| 
									
										
										
										
											2024-08-22 19:34:47 +08:00
										 |  |  | 			border-radius: 16rpx 0 16rpx 0; | 
					
						
							|  |  |  | 			font-size: 24rpx; | 
					
						
							|  |  |  | 			margin-right: 12rpx; | 
					
						
							| 
									
										
										
										
											2024-08-24 10:25:25 +08:00
										 |  |  | 			line-height: 1; | 
					
						
							| 
									
										
										
										
											2024-08-22 19:34:47 +08:00
										 |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		.orderCardTitle { | 
					
						
							|  |  |  | 			color: #000; | 
					
						
							|  |  |  | 			font-weight: bold; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	.orderCardStatus { | 
					
						
							|  |  |  | 		display: flex; | 
					
						
							|  |  |  | 		justify-content: space-between; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	.orderCardStatusData { | 
					
						
							|  |  |  | 		display: flex; | 
					
						
							|  |  |  | 		align-items: center; | 
					
						
							|  |  |  | 		column-gap: 4rpx; | 
					
						
							|  |  |  | 		font-size: 24rpx; | 
					
						
							| 
									
										
										
										
											2024-08-24 10:25:25 +08:00
										 |  |  | 		line-height: 1; | 
					
						
							| 
									
										
										
										
											2024-08-22 19:34:47 +08:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	.orderCardDistanceIcon, | 
					
						
							|  |  |  | 	.orderCardPredictIcon { | 
					
						
							|  |  |  | 		width: 36rpx; | 
					
						
							|  |  |  | 		height: 36rpx; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	.orderCardDistanceValue { | 
					
						
							|  |  |  | 		color: #919191; | 
					
						
							|  |  |  | 		margin-right: 16rpx; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	.orderCardPredictDate { | 
					
						
							|  |  |  | 		color: #317DFA; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	.orderCardFlag { | 
					
						
							|  |  |  | 		font-size: 24rpx; | 
					
						
							| 
									
										
										
										
											2024-08-24 10:25:25 +08:00
										 |  |  | 		padding: 8rpx 16rpx; | 
					
						
							|  |  |  | 		line-height: 1; | 
					
						
							|  |  |  | 		border-radius: 8rpx; | 
					
						
							| 
									
										
										
										
											2024-08-22 19:34:47 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		&.inRescue { | 
					
						
							|  |  |  | 			background-color: #ECF8EA; | 
					
						
							|  |  |  | 			color: #2FB821; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		&.toRescued { | 
					
						
							|  |  |  | 			background-color: #FAE9E9; | 
					
						
							|  |  |  | 			color: #D42424; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	.orderCardProcess { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-23 23:17:22 +08:00
										 |  |  | 		 | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	.orderCardSendOrders, | 
					
						
							|  |  |  | 	.orderCardDriver, | 
					
						
							|  |  |  | 	.orderCardCarNo { | 
					
						
							|  |  |  | 		color: #317DFA; | 
					
						
							| 
									
										
										
										
											2024-08-22 19:34:47 +08:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	.orderCardFooter { | 
					
						
							|  |  |  | 		display: flex; | 
					
						
							|  |  |  | 		justify-content: space-between; | 
					
						
							|  |  |  | 		align-items: center; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		.orderCardDateTime { | 
					
						
							|  |  |  | 			color: #919191; | 
					
						
							|  |  |  | 			font-size: 24rpx; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		.orderCardBtnGroup { | 
					
						
							|  |  |  | 			display: flex; | 
					
						
							|  |  |  | 			align-items: center; | 
					
						
							|  |  |  | 			column-gap: 16rpx; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		.orderCardBtnGroupItem { | 
					
						
							|  |  |  | 			background-color: #317DFA; | 
					
						
							|  |  |  | 			color: #fff; | 
					
						
							|  |  |  | 			border: 1px solid #317DFA; | 
					
						
							|  |  |  | 			padding: 8rpx 16rpx; | 
					
						
							|  |  |  | 			border-radius: 28rpx; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2024-08-22 22:04:46 +08:00
										 |  |  | </style> |