|
|
|
|
@ -1,67 +1,180 @@
|
|
|
|
|
<template>
|
|
|
|
|
<div>
|
|
|
|
|
<h1>确认订单</h1>
|
|
|
|
|
<div v-if="ticket">
|
|
|
|
|
<div v-for="(ticket, index) in selectedTicketInfo" :key="index" class="ticket-box">
|
|
|
|
|
<div class="departure-info">
|
|
|
|
|
<p class="time">{{ ticket.departure_time }}</p>
|
|
|
|
|
<p class="station">{{ ticket.departure_station }}</p>
|
|
|
|
|
</div>
|
|
|
|
|
<div class="train-info">
|
|
|
|
|
<h2 class="train-no">{{ ticket.trainno }}</h2>
|
|
|
|
|
<p class="date">{{ ticket.date }}</p>
|
|
|
|
|
</div>
|
|
|
|
|
<div class="arrival-info">
|
|
|
|
|
<p class="time">{{ ticket.arrival_time }}</p>
|
|
|
|
|
<p class="station">{{ ticket.arrival_station }}</p>
|
|
|
|
|
</div>
|
|
|
|
|
<div class="ticket-info">
|
|
|
|
|
<div class="departure-info">
|
|
|
|
|
<p class="time">{{ departure_time }}</p>
|
|
|
|
|
<p class="station">{{ departure }}</p>
|
|
|
|
|
</div>
|
|
|
|
|
<div class="train-info">
|
|
|
|
|
<h2 class="train-no">{{ ticketno }}</h2>
|
|
|
|
|
<p class="date">{{ date }}</p>
|
|
|
|
|
</div>
|
|
|
|
|
<div class="arrival-info">
|
|
|
|
|
<p class="time">{{ arrival_time }}</p>
|
|
|
|
|
<p class="station"> {{ arrival }}</p>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
<div id="app">
|
|
|
|
|
<div class="seat-selection">
|
|
|
|
|
<div class="seat-options">
|
|
|
|
|
<label class="seat-option" :class="{ active: selectedSeat === 'business' }">
|
|
|
|
|
<input type="radio" v-model="selectedSeat" value="business"> 商务座
|
|
|
|
|
</label>
|
|
|
|
|
<label class="seat-option" :class="{ active: selectedSeat === 'firstClass' }">
|
|
|
|
|
<input type="radio" v-model="selectedSeat" value="firstClass"> 一等座
|
|
|
|
|
</label>
|
|
|
|
|
<label class="seat-option" :class="{ active: selectedSeat === 'secondClass' }">
|
|
|
|
|
<input type="radio" v-model="selectedSeat" value="secondClass"> 二等座
|
|
|
|
|
</label>
|
|
|
|
|
<label class="seat-option" :class="{ active: selectedSeat === 'noSeat' }">
|
|
|
|
|
<input type="radio" v-model="selectedSeat" value="noSeat"> 无座
|
|
|
|
|
</label>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
<div class="passenger-selection">
|
|
|
|
|
<h2>乘车人选择</h2>
|
|
|
|
|
<button class="add-btn" @click="addPassenge">添加乘车人</button>
|
|
|
|
|
</div>
|
|
|
|
|
<view v-if="ticketData">
|
|
|
|
|
<div class="container">
|
|
|
|
|
<!-- 二等座 -->
|
|
|
|
|
<div
|
|
|
|
|
class="seat-box Second"
|
|
|
|
|
@click="selectSeat('Second')"
|
|
|
|
|
:class="{ selected: selectedSeat === 'Second' }"
|
|
|
|
|
>
|
|
|
|
|
<p>二等座</p>
|
|
|
|
|
<p class="price">¥{{ ticketData.secondseatprice }}</p>
|
|
|
|
|
<p class="num">{{ ticketData.secondseatnum }}</p>
|
|
|
|
|
</div>
|
|
|
|
|
|
|
|
|
|
<!-- 一等座 -->
|
|
|
|
|
<div
|
|
|
|
|
class="seat-box First"
|
|
|
|
|
@click="selectSeat('First')"
|
|
|
|
|
:class="{ selected: selectedSeat === 'First' }"
|
|
|
|
|
>
|
|
|
|
|
<p>一等座</p>
|
|
|
|
|
<p class="price">¥{{ ticketData.firstseatprice }}</p>
|
|
|
|
|
<p class="num">{{ ticketData.firstseatnum }}</p>
|
|
|
|
|
</div>
|
|
|
|
|
|
|
|
|
|
<!-- 商务座 -->
|
|
|
|
|
<div
|
|
|
|
|
class="seat-box Business"
|
|
|
|
|
@click="selectSeat('Business')"
|
|
|
|
|
:class="{ selected: selectedSeat === 'Business' }"
|
|
|
|
|
>
|
|
|
|
|
<p>商务座</p>
|
|
|
|
|
<p class="price">¥{{ ticketData.businessseatprice }}</p>
|
|
|
|
|
<p class="num">{{ ticketData.businessseatnum }}</p>
|
|
|
|
|
</div>
|
|
|
|
|
|
|
|
|
|
<!-- 无座 -->
|
|
|
|
|
<div
|
|
|
|
|
class="seat-box NO"
|
|
|
|
|
@click="selectSeat('NO')"
|
|
|
|
|
:class="{ selected: selectedSeat === 'NO' }"
|
|
|
|
|
>
|
|
|
|
|
<p>无座</p>
|
|
|
|
|
<p class="price">¥{{ ticketData.noseatprice }}</p>
|
|
|
|
|
<p class="num">{{ ticketData.noseatnum }}</p>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
</view>
|
|
|
|
|
<div>
|
|
|
|
|
<button class="add-btn" @click="addPassenge">选座乘车人</button>
|
|
|
|
|
<view>
|
|
|
|
|
<block v-for="(passenger, index) in selectedPassengers" :key="index">
|
|
|
|
|
<view>
|
|
|
|
|
<text>{{ passenger.name }} - {{ passenger.passengerstate }} - {{ passenger.idcardno }} - {{ passenger.mobileno }}</text>
|
|
|
|
|
</view>
|
|
|
|
|
</block>
|
|
|
|
|
</view>
|
|
|
|
|
</div>
|
|
|
|
|
<button class="submit-btn" @click="submitOrder">提交订单</button>
|
|
|
|
|
</div>
|
|
|
|
|
</template>
|
|
|
|
|
|
|
|
|
|
<script>
|
|
|
|
|
export default {
|
|
|
|
|
data() {
|
|
|
|
|
return {
|
|
|
|
|
ticket: {} // 存储车票信息的变量
|
|
|
|
|
};
|
|
|
|
|
},
|
|
|
|
|
mounted() {
|
|
|
|
|
// 从本地存储中读取车票信息
|
|
|
|
|
if (this.$route.query.data) {
|
|
|
|
|
this.selectedData = JSON.parse(this.$route.query.data);
|
|
|
|
|
}
|
|
|
|
|
export default {
|
|
|
|
|
data() {
|
|
|
|
|
return {
|
|
|
|
|
selectedSeat: null,
|
|
|
|
|
ticketno: '',
|
|
|
|
|
date: '',
|
|
|
|
|
departure: '',
|
|
|
|
|
arrival: '',
|
|
|
|
|
departure_time:'',
|
|
|
|
|
arrival_time:'',
|
|
|
|
|
ticketData: null,
|
|
|
|
|
selectedPassengers: []
|
|
|
|
|
};
|
|
|
|
|
},
|
|
|
|
|
onLoad(query) {
|
|
|
|
|
// 从上一个页面的参数中获取车票信息
|
|
|
|
|
this.ticketno = query.ticketno || '';
|
|
|
|
|
this.date = query.date || '';
|
|
|
|
|
this.departure = query.departure || '';
|
|
|
|
|
this.arrival = query.arrival || '';
|
|
|
|
|
this.departure_time = query.departure_time || '';
|
|
|
|
|
this.arrival_time = query.arrival_time || '';
|
|
|
|
|
},
|
|
|
|
|
onshow(){
|
|
|
|
|
this.fetchTicketInfo();
|
|
|
|
|
this.loadSelectedPassengers();
|
|
|
|
|
},
|
|
|
|
|
mounted() {
|
|
|
|
|
this.fetchTicketInfo();
|
|
|
|
|
this.loadSelectedPassengers();
|
|
|
|
|
},
|
|
|
|
|
methods: {
|
|
|
|
|
selectSeat(seatType) {
|
|
|
|
|
this.selectedSeat = seatType; // 更新当前选中的座位类型
|
|
|
|
|
},
|
|
|
|
|
loadSelectedPassengers(){
|
|
|
|
|
const passengers = localStorage.getItem('selectedPassenger');
|
|
|
|
|
if (passengers) {
|
|
|
|
|
this.selectedPassengers = JSON.parse(passengers);
|
|
|
|
|
} else {
|
|
|
|
|
console.error('No passengers found in local storage.');
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
submitOrder() {
|
|
|
|
|
uni.navigateTo({
|
|
|
|
|
url: '/pages/index/Payment'
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
addPassenge(){
|
|
|
|
|
uni.navigateTo({
|
|
|
|
|
url: '/pages/index/passenge-list'
|
|
|
|
|
});
|
|
|
|
|
},
|
|
|
|
|
fetchTicketInfo() {
|
|
|
|
|
const formData = {
|
|
|
|
|
date:this.date,
|
|
|
|
|
trainno:this.ticketno,
|
|
|
|
|
};
|
|
|
|
|
// 发送POST请求,确保将formData转换为JSON字符串
|
|
|
|
|
uni.request({
|
|
|
|
|
url: 'http://localhost:8000/book_ticket/',
|
|
|
|
|
method: 'POST',
|
|
|
|
|
data: JSON.stringify(formData), // 将formData转换为JSON字符串
|
|
|
|
|
header: {
|
|
|
|
|
'content-type': 'application/json' // 明确指定请求头为JSON格式
|
|
|
|
|
},
|
|
|
|
|
success: (res) => {
|
|
|
|
|
// 请求成功处理,检查返回的状态码和数据
|
|
|
|
|
if (res.statusCode === 200) { // 确保状态码为200
|
|
|
|
|
const data = res.data;
|
|
|
|
|
if (data.message === '选座成功') {
|
|
|
|
|
console.log('请求成功',data);
|
|
|
|
|
this.ticketData = data.tickets;
|
|
|
|
|
uni.showToast({
|
|
|
|
|
title: '查询成功',
|
|
|
|
|
icon: 'success'
|
|
|
|
|
});
|
|
|
|
|
} else {
|
|
|
|
|
// 如果有其他错误消息,显示给用户
|
|
|
|
|
const data = res.data;
|
|
|
|
|
console.log('请求成功', data);
|
|
|
|
|
uni.showToast({
|
|
|
|
|
title: data.message + (data.reason ? ': ' + data.reason : ''),
|
|
|
|
|
icon: 'none'
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
fail: (err) => {
|
|
|
|
|
// 请求失败处理
|
|
|
|
|
console.error('请求失败', err);
|
|
|
|
|
uni.showToast({
|
|
|
|
|
title: '请求失败,请重试',
|
|
|
|
|
icon: 'none'
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
},
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
</script>
|
|
|
|
|
@ -73,7 +186,8 @@ h1 {
|
|
|
|
|
margin-bottom: 20px;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.ticket-box {
|
|
|
|
|
|
|
|
|
|
.ticket-info {
|
|
|
|
|
display: flex;
|
|
|
|
|
justify-content: space-between;
|
|
|
|
|
align-items: center;
|
|
|
|
|
@ -90,15 +204,15 @@ h1 {
|
|
|
|
|
text-align: center;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.time {
|
|
|
|
|
font-size: 8px; /* 设置时间的字体大小 */
|
|
|
|
|
.time .num,.price {
|
|
|
|
|
font-size: 12px; /* 设置时间的字体大小 */
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.station {
|
|
|
|
|
font-size: 16px; /* 设置车站名称的字体大小 */
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.train-no {
|
|
|
|
|
.train-no,{
|
|
|
|
|
font-size: 20px; /* 设置车次的字体大小 */
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@ -106,36 +220,44 @@ h1 {
|
|
|
|
|
font-size: 10px; /* 设置日期的字体大小 */
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.seat-selection {
|
|
|
|
|
.container {
|
|
|
|
|
display: flex;
|
|
|
|
|
justify-content: center;
|
|
|
|
|
margin-top: 20px;
|
|
|
|
|
justify-content: space-between; /* 均匀分布每个子元素 */
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.seat-options {
|
|
|
|
|
.container > div { /* 选择 container 中的每一个直接子元素 */
|
|
|
|
|
flex: 1; /* 每个子元素平分父容器的宽度 */
|
|
|
|
|
border: 1px solid #ccc;
|
|
|
|
|
padding: 10px;
|
|
|
|
|
margin-right: 10px;
|
|
|
|
|
display: flex;
|
|
|
|
|
flex-direction: column;
|
|
|
|
|
justify-content: center;
|
|
|
|
|
align-items: center;
|
|
|
|
|
box-sizing: border-box;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.seat-option {
|
|
|
|
|
border: 1px solid #ccc;
|
|
|
|
|
padding: 10px 20px;
|
|
|
|
|
border-radius: 8px;
|
|
|
|
|
cursor: pointer;
|
|
|
|
|
transition: background-color 0.3s, border-color 0.3s;
|
|
|
|
|
margin-right: 10px;
|
|
|
|
|
.container > div:last-child {
|
|
|
|
|
margin-right: 0; /* 移除最后一个子元素的右边距 */
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.seat-option:last-child {
|
|
|
|
|
margin-right: 0;
|
|
|
|
|
.container {
|
|
|
|
|
display: flex;
|
|
|
|
|
flex-wrap: wrap;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.seat-option input[type="radio"] {
|
|
|
|
|
display: none;
|
|
|
|
|
.seat-box {
|
|
|
|
|
width: 100px;
|
|
|
|
|
padding: 10px;
|
|
|
|
|
margin: 10px;
|
|
|
|
|
border: 1px solid #ccc;
|
|
|
|
|
text-align: center;
|
|
|
|
|
cursor: pointer;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.seat-option.active {
|
|
|
|
|
border-color: #007bff;
|
|
|
|
|
background-color: #d0e6ff;
|
|
|
|
|
.seat-box.selected {
|
|
|
|
|
background-color: #4cd964;; /* 选中的座位框变绿 */
|
|
|
|
|
color: white;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.submit-btn {
|
|
|
|
|
|