251 lines
		
	
	
		
			5.2 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
		
		
			
		
	
	
			251 lines
		
	
	
		
			5.2 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
|  | <template> | |||
|  | 	<view class="container"> | |||
|  | 		<VNavigationBar titleColor="rgba(0,0,0,0.9)" leftTitle="true" backgroundColor="transparent" title="我的订单"> | |||
|  | 		</VNavigationBar> | |||
|  | 		<view class="body"> | |||
|  | 			<view class="tabList"> | |||
|  | 				<view @click="changeTabFun(item.id)" v-for="(item, index) in tabList" :key="index" class="tabItem" | |||
|  | 					:class="{actived: item.id === activeKey}"> | |||
|  | 					{{ item.title }} | |||
|  | 					<view v-if="activeKey === item.id" class="activeLine"></view> | |||
|  | 				</view> | |||
|  | 			</view> | |||
|  | 			<view class="orderList"> | |||
|  | 				<view v-for="(item, index) in orderList" :key="index" class="orderItem"> | |||
|  | 					<view class="line1"> | |||
|  | 						<view class="orderNo"> | |||
|  | 							订单编号:{{item.orderNo}} | |||
|  | 						</view> | |||
|  | 						<text class="orderStatus" :class="['status_' + item.status]"> | |||
|  | 							{{ getStatus(item.status) }} | |||
|  | 						</text> | |||
|  | 					</view> | |||
|  | 					<view class="orderInfo"> | |||
|  | 						<image class="orderInfoIcon" src="" mode="aspectFit"></image> | |||
|  | 						<text class="orderInfoText">{{ item.busiTypeStr }}</text> | |||
|  | 					</view> | |||
|  | 					<view class="orderInfo"> | |||
|  | 						<image class="orderInfoIcon" src="" mode="aspectFit"></image> | |||
|  | 						<text class="orderInfoText">{{ item.address }}</text> | |||
|  | 					</view> | |||
|  | 					<view class="line2"> | |||
|  | 						<view> | |||
|  | 							共计 | |||
|  | 							<text class="orderAmountUnit">¥</text> | |||
|  | 							<text class="orderAmount">781</text> | |||
|  | 						</view> | |||
|  | 						<text>{{ item.date }}</text> | |||
|  | 					</view> | |||
|  | 					<view class="line3"> | |||
|  | 						<view @click="gotoDetail(item)" class="showOrder" v-if="item.status === '1'">查看订单</view> | |||
|  | 						<view @click="gotoEvaluate(item)" class="evaluate" v-if="item.status === '2'">评价订单</view> | |||
|  | 					</view> | |||
|  | 				</view> | |||
|  | 			</view> | |||
|  | 		</view> | |||
|  | 		<tabBarVue msg="2"></tabBarVue> | |||
|  | 	</view> | |||
|  | </template> | |||
|  | 
 | |||
|  | <script> | |||
|  | 	import VNavigationBar from '@/components/VNavigationBar.vue' | |||
|  | 	import tabBarVue from '@/components/tabBar/tabBar.vue' | |||
|  | 
 | |||
|  | 	export default { | |||
|  | 		components: { | |||
|  | 			tabBarVue, | |||
|  | 			VNavigationBar | |||
|  | 		}, | |||
|  | 		data() { | |||
|  | 			return { | |||
|  | 				activeKey: 0, | |||
|  | 				tabList: [{ | |||
|  | 						id: 0, | |||
|  | 						title: '全部订单' | |||
|  | 					}, | |||
|  | 					{ | |||
|  | 						id: 1, | |||
|  | 						title: '维修中' | |||
|  | 					}, | |||
|  | 					{ | |||
|  | 						id: 2, | |||
|  | 						title: '待评价' | |||
|  | 					}, | |||
|  | 				], | |||
|  | 				orderList: [{ | |||
|  | 						orderNo: '20198104817050157810', | |||
|  | 						status: '1', | |||
|  | 						busiTypeStr: '维修轮胎', | |||
|  | 						address: '顺捷汽车维修搭电救援补胎中心', | |||
|  | 						amount: '781', | |||
|  | 						date: '2024-07-02  12:00' | |||
|  | 					}, | |||
|  | 					{ | |||
|  | 						orderNo: '20198104817050157810', | |||
|  | 						status: '2', | |||
|  | 						busiTypeStr: '维修轮胎', | |||
|  | 						address: '顺捷汽车维修搭电救援补胎中心', | |||
|  | 						amount: '781', | |||
|  | 						date: '2024-07-02  12:00' | |||
|  | 					} | |||
|  | 				] | |||
|  | 			} | |||
|  | 		}, | |||
|  | 		methods: { | |||
|  | 			changeTabFun(id) { | |||
|  | 				this.activeKey = id | |||
|  | 			}, | |||
|  | 			getStatus(status) { | |||
|  | 				switch (status) { | |||
|  | 					case '1': | |||
|  | 						return '维修中' | |||
|  | 					case '2': | |||
|  | 						return '待评价' | |||
|  | 					default: | |||
|  | 						break; | |||
|  | 				} | |||
|  | 			}, | |||
|  | 			gotoDetail() { | |||
|  | 				uni.navigateTo({ | |||
|  | 					url: '/pages/orderDetail/orderDetail' | |||
|  | 				}) | |||
|  | 			}, | |||
|  | 			gotoEvaluate() { | |||
|  | 				uni.navigateTo({ | |||
|  | 					url: '/pages/orderDetail/evaluate' | |||
|  | 				}) | |||
|  | 			} | |||
|  | 		} | |||
|  | 	} | |||
|  | </script> | |||
|  | 
 | |||
|  | <style scoped lang="less"> | |||
|  | 	.container { | |||
|  | 		height: 100%; | |||
|  | 		background: #F3F5F7; | |||
|  | 		display: flex; | |||
|  | 		flex-direction: column; | |||
|  | 		color: #333333; | |||
|  | 
 | |||
|  | 		.body { | |||
|  | 			flex: 1; | |||
|  | 			height: 0; | |||
|  | 			padding: 24rpx 32rpx; | |||
|  | 		} | |||
|  | 
 | |||
|  | 		.tabList { | |||
|  | 			background: #FFFFFF; | |||
|  | 			border-radius: 12rpx 12rpx 12rpx 12rpx; | |||
|  | 			display: flex; | |||
|  | 			align-items: center; | |||
|  | 			padding: 0 40rpx; | |||
|  | 
 | |||
|  | 			.tabItem { | |||
|  | 				padding: 30rpx; | |||
|  | 				flex: 1; | |||
|  | 				text-align: center; | |||
|  | 				position: relative; | |||
|  | 				font-size: 24rpx; | |||
|  | 
 | |||
|  | 				&.actived { | |||
|  | 					color: #0174F6; | |||
|  | 				} | |||
|  | 
 | |||
|  | 				.activeLine { | |||
|  | 					position: absolute; | |||
|  | 					bottom: 0; | |||
|  | 					left: 50%; | |||
|  | 					transform: translateX(-50%); | |||
|  | 					width: 96rpx; | |||
|  | 					height: 6rpx; | |||
|  | 					background: #0174F6; | |||
|  | 					border-radius: 4rpx 4rpx 0rpx 0rpx; | |||
|  | 				} | |||
|  | 			} | |||
|  | 		} | |||
|  | 
 | |||
|  | 		.orderList { | |||
|  | 			padding: 30rpx 0; | |||
|  | 			display: flex; | |||
|  | 			flex-direction: column; | |||
|  | 			row-gap: 20rpx; | |||
|  | 
 | |||
|  | 			.orderItem { | |||
|  | 				padding: 30rpx; | |||
|  | 				background: #FFFFFF; | |||
|  | 				border-radius: 12rpx 12rpx 12rpx 12rpx; | |||
|  | 			} | |||
|  | 			.line1 { | |||
|  | 				margin-bottom: 30rpx; | |||
|  | 				display: flex; | |||
|  | 				align-items: center; | |||
|  | 				justify-content: space-between; | |||
|  | 				font-size: 24rpx; | |||
|  | 				.orderNo { | |||
|  | 					flex: 1; | |||
|  | 					width: 0; | |||
|  | 					font-weight: 500; | |||
|  | 					color: #858BA0; | |||
|  | 				} | |||
|  | 				.status_1 { | |||
|  | 					color: #0174F6; | |||
|  | 				} | |||
|  | 				.status_2 { | |||
|  | 					color: #999999; | |||
|  | 				} | |||
|  | 			} | |||
|  | 			.orderInfo { | |||
|  | 				margin-bottom: 20rpx; | |||
|  | 				display: flex; | |||
|  | 				align-items: center; | |||
|  | 				column-gap: 10rpx; | |||
|  | 				.orderInfoIcon { | |||
|  | 					width: 28rpx; | |||
|  | 					height: 28rpx; | |||
|  | 					background: #ddd; | |||
|  | 				} | |||
|  | 				.orderInfoText { | |||
|  | 					font-weight: bold; | |||
|  | 					font-size: 28rpx; | |||
|  | 					color: #333333; | |||
|  | 				} | |||
|  | 			} | |||
|  | 			.line2 { | |||
|  | 				margin: 30rpx 0; | |||
|  | 				display: flex; | |||
|  | 				align-items: center; | |||
|  | 				justify-content: space-between; | |||
|  | 				font-size: 12px; | |||
|  | 				color: #858BA0; | |||
|  | 				.orderAmountUnit { | |||
|  | 					color: #F92C2C; | |||
|  | 				} | |||
|  | 				.orderAmount { | |||
|  | 					color: #F92C2C; | |||
|  | 					font-weight: bold; | |||
|  | 					font-size: 40rpx; | |||
|  | 				} | |||
|  | 			} | |||
|  | 			.line3 { | |||
|  | 				display: flex; | |||
|  | 				align-items: center; | |||
|  | 				justify-content: flex-end; | |||
|  | 				.showOrder, .evaluate { | |||
|  | 					width: 172rpx; | |||
|  | 					height: 60rpx; | |||
|  | 					border-radius: 30rpx 30rpx 30rpx 30rpx; | |||
|  | 					border: 2rpx solid #0174F6; | |||
|  | 					display: flex; | |||
|  | 					align-items: center; | |||
|  | 					justify-content: center; | |||
|  | 					font-size: 28rpx; | |||
|  | 					color: #0174F6; | |||
|  | 				} | |||
|  | 				.evaluate { | |||
|  | 					border: 1rpx solid #EEEEEE; | |||
|  | 					color: #333333; | |||
|  | 				} | |||
|  | 			} | |||
|  | 		} | |||
|  | 	} | |||
|  | </style> |