no message
Showing
7 changed files
with
284 additions
and
2 deletions
| ... | @@ -21,3 +21,18 @@ export function getHotelRooms(id) { | ... | @@ -21,3 +21,18 @@ export function getHotelRooms(id) { |
| 21 | } | 21 | } |
| 22 | }) | 22 | }) |
| 23 | } | 23 | } |
| 24 | |||
| 25 | export function checkResidueRoom(data) { | ||
| 26 | return request({ | ||
| 27 | url: `/ota/orderRoom/checkResidueRoom`, | ||
| 28 | method: 'post', | ||
| 29 | data: data | ||
| 30 | }) | ||
| 31 | } | ||
| 32 | export function newsSubmitOrderHotel(data) { | ||
| 33 | return request({ | ||
| 34 | url: `/ota/norder/submitOrderRoom`, | ||
| 35 | method: 'post', | ||
| 36 | data: data | ||
| 37 | }) | ||
| 38 | } | ... | ... |
src/assets/dance/fm_副本.jpg
deleted
100644 → 0
25.8 KB
src/assets/dance/logo3.png
deleted
100644 → 0
8.73 KB
| ... | @@ -362,6 +362,12 @@ export const constantRoutes = [ | ... | @@ -362,6 +362,12 @@ export const constantRoutes = [ |
| 362 | meta: { title: 'Hotel Reservation' } | 362 | meta: { title: 'Hotel Reservation' } |
| 363 | }, | 363 | }, |
| 364 | { | 364 | { |
| 365 | path: 'hotel/:cptId/:hotelId/:roomId', | ||
| 366 | component: () => import('@/viewsPc/booking/hotelOrder'), | ||
| 367 | name: 'hotelOrder', | ||
| 368 | meta: { title: 'Hotel Reservation' } | ||
| 369 | }, | ||
| 370 | { | ||
| 365 | path: 'car/:cptId', | 371 | path: 'car/:cptId', |
| 366 | component: () => import('@/viewsPc/booking/car'), | 372 | component: () => import('@/viewsPc/booking/car'), |
| 367 | name: 'car', | 373 | name: 'car', | ... | ... |
| ... | @@ -61,8 +61,8 @@ | ... | @@ -61,8 +61,8 @@ |
| 61 | const list = ref([]) | 61 | const list = ref([]) |
| 62 | const loading = ref(false) | 62 | const loading = ref(false) |
| 63 | onMounted(()=>{ | 63 | onMounted(()=>{ |
| 64 | query.value.activityId = route.params.cptId | ||
| 64 | getList() | 65 | getList() |
| 65 | cptId.value = route.params.cptId | ||
| 66 | }) | 66 | }) |
| 67 | 67 | ||
| 68 | function getList() { | 68 | function getList() { |
| ... | @@ -78,7 +78,8 @@ | ... | @@ -78,7 +78,8 @@ |
| 78 | router.push({ | 78 | router.push({ |
| 79 | name:'hotelDetail', | 79 | name:'hotelDetail', |
| 80 | params:{ | 80 | params:{ |
| 81 | hotelId:item.hotelId | 81 | hotelId:item.hotelId, |
| 82 | id:item.id | ||
| 82 | } | 83 | } |
| 83 | }) | 84 | }) |
| 84 | } | 85 | } | ... | ... |
This diff is collapsed.
Click to expand it.
src/viewsPc/booking/hotelOrder.vue
0 → 100644
| 1 | <template> | ||
| 2 | <div> | ||
| 3 | <div class="box"> | ||
| 4 | <el-card :body-style="{ padding: '0px' }" class="mt20"> | ||
| 5 | <div slot="header"> | ||
| 6 | <div class="bg-lineg">{{ language == 0 ? '酒店预约下单' : 'Hotel booking order' }}</div> | ||
| 7 | </div> | ||
| 8 | |||
| 9 | <el-row class="pd20" :gutter="20"> | ||
| 10 | <el-col :span="14" > | ||
| 11 | <div class="border-info"> | ||
| 12 | <h3>{{hotelName}}</h3> | ||
| 13 | <!-- <div class="roomType">{{room.roomType}}</div>--> | ||
| 14 | <div class="room"> | ||
| 15 | <span>{{room.bedType}}</span> | ||
| 16 | <span>{{ ' | ' + room.area}}m²</span> | ||
| 17 | <span>{{ ' | ' + room.occupantsNum}}人入住</span> | ||
| 18 | <span v-show="room.breakfastFlag=='1'">{{ ' | ' + room.breakfastNum}} 份早餐</span> | ||
| 19 | <span v-show="room.breakfastFlag=='0'"> | 无早餐</span> | ||
| 20 | <span v-show="room.bathroomFlag=='1'"> | 独立卫生间</span> | ||
| 21 | <span v-show="room.windowFlag=='1'"> | 有窗</span> | ||
| 22 | <span v-show="room.addBedFlag=='1'"> | 允许加床</span> | ||
| 23 | </div> | ||
| 24 | </div> | ||
| 25 | |||
| 26 | <div class="leftboderTT">{{ language == 0 ? '预约信息' : 'Reservation information' }}</div> | ||
| 27 | <div class="border-rr mt20 pd20"> | ||
| 28 | <el-form :model="form" label-width="100px"> | ||
| 29 | <el-form-item label="入住日期"> | ||
| 30 | <el-date-picker | ||
| 31 | v-model="rzRange" | ||
| 32 | type="daterange" | ||
| 33 | placeholder="选择日期" | ||
| 34 | value-format="yyyy-MM-dd" | ||
| 35 | :picker-options="pickerOptions" | ||
| 36 | /> | ||
| 37 | </el-form-item> | ||
| 38 | <el-form-item label="房间数"> | ||
| 39 | <el-input-number v-model="form.roomNum" :min="0" :max="canOrderNum" @change="changeRoomNum" /> | ||
| 40 | <div class="red" v-if="rzRange[1]" style="margin:0 8px;display: block;width: 8em;"> | ||
| 41 | <span>剩余房间数:{{canOrderNum}}</span> | ||
| 42 | </div> | ||
| 43 | </el-form-item> | ||
| 44 | <el-form-item v-for="(n,index) in form.roomNum" :key="index" :label="`入住人${index+1}`"> | ||
| 45 | <el-input v-model="rzUserArr[index]" placeholder="每间填一位住客姓名"/> | ||
| 46 | </el-form-item> | ||
| 47 | <el-form-item label="预计到店"> | ||
| 48 | |||
| 49 | </el-form-item> | ||
| 50 | <el-form-item label="联系电话"> | ||
| 51 | <el-input v-model="form.phone"/> | ||
| 52 | </el-form-item> | ||
| 53 | |||
| 54 | <div v-if="room.addBedFlag=='1'"> | ||
| 55 | <el-form-item label="是否加床"> | ||
| 56 | <el-radio-group> | ||
| 57 | <el-radio v-model="form.isAddbed" label="1">是</el-radio> | ||
| 58 | <el-radio v-model="form.isAddbed" label="0">否</el-radio> | ||
| 59 | </el-radio-group> | ||
| 60 | </el-form-item> | ||
| 61 | <el-form-item label="加床张数"> | ||
| 62 | <el-input-number v-model="form.addNum" :min="0" :max="1" @change="changeBed" /> | ||
| 63 | </el-form-item> | ||
| 64 | <div class="tip" v-if="form.isAddbed=='1'">* 一个房间最多加一张床</div> | ||
| 65 | </div> | ||
| 66 | </el-form> | ||
| 67 | </div> | ||
| 68 | </el-col> | ||
| 69 | <el-col :span="10"> | ||
| 70 | <div class="leftboderTT">{{ language == 0 ? '订单明细' : 'Order details' }}</div> | ||
| 71 | <div class="border-rr mt20 pd20 ccitemBox"> | ||
| 72 | <label> 房费 | ||
| 73 | <span class="fr">¥{{(room.roomPrice*form.roomNum*choseRooms.length).toFixed(2)}}</span> | ||
| 74 | </label> | ||
| 75 | <div class="ccitem" v-for="(c, index) in choseRooms" :key="index"> | ||
| 76 | {{ c }} | ||
| 77 | <text>{{form.roomNum}}*¥{{room.roomPrice}}</text> | ||
| 78 | </div> | ||
| 79 | |||
| 80 | <label v-if="form.isAddbed=='1'">加床费 | ||
| 81 | <span class="fr">¥{{(room.bedPrice*form.addNum*choseRooms.length).toFixed(2)}}</span> | ||
| 82 | </label> | ||
| 83 | |||
| 84 | <div v-if="form.isAddbed=='1'" class="ccitem" v-for="(c, index) in choseRooms" :key="index"> | ||
| 85 | {{ c }} | ||
| 86 | <text>{{form.addNum}}*¥{{room.bedPrice}}</text> | ||
| 87 | </div> | ||
| 88 | |||
| 89 | <label>共计<span class="fr bigMoney">¥{{money}}</span></label> | ||
| 90 | |||
| 91 | </div> | ||
| 92 | </el-col> | ||
| 93 | </el-row> | ||
| 94 | </el-card> | ||
| 95 | <div style="height: 60px;"></div> | ||
| 96 | |||
| 97 | </div> | ||
| 98 | </div> | ||
| 99 | </template> | ||
| 100 | |||
| 101 | <script setup> | ||
| 102 | import {useRouter,useRoute} from "vue-router"; | ||
| 103 | import {ref, reactive, onMounted} from "vue"; | ||
| 104 | import {useStorage} from "@vueuse/core/index"; | ||
| 105 | import { checkResidueRoom,newsSubmitOrderHotel } from "@/apiPc/booking" | ||
| 106 | import dayjs from 'dayjs' | ||
| 107 | import {ElMessage} from "element-plus"; | ||
| 108 | const language = useStorage('language', 0) | ||
| 109 | const router = useRouter() | ||
| 110 | const route = useRoute() | ||
| 111 | const room = ref({}) | ||
| 112 | const hotelName = ref('') | ||
| 113 | const canOrderStart = ref('') | ||
| 114 | const canOrderNum = ref(0) | ||
| 115 | const form = ref({ | ||
| 116 | roomNum: 0, | ||
| 117 | addNum: 0 | ||
| 118 | }) | ||
| 119 | const rzRange = ref([]) | ||
| 120 | const rzUserArr = ref([]) | ||
| 121 | const money = ref(0) | ||
| 122 | const choseRooms = ref([]) | ||
| 123 | let usedays = 0 | ||
| 124 | onMounted(()=>{ | ||
| 125 | console.log(route.query) | ||
| 126 | room.value = JSON.parse(decodeURIComponent(route.query.room)) | ||
| 127 | hotelName.value = route.query.hotelName | ||
| 128 | money.value = 0 | ||
| 129 | const today = dayjs() | ||
| 130 | canOrderStart.value = today | ||
| 131 | if (room.value.hqNewStart < canOrderStart.value) { | ||
| 132 | room.value.hqNewStart = canOrderStart.value | ||
| 133 | } | ||
| 134 | }) | ||
| 135 | function changeRoomNum(e) { | ||
| 136 | if (form.value.addNum > e) { | ||
| 137 | form.value.addNum = e | ||
| 138 | } | ||
| 139 | countMoney() | ||
| 140 | } | ||
| 141 | function changeBed() { | ||
| 142 | countMoney() | ||
| 143 | } | ||
| 144 | function checkreRooms() { | ||
| 145 | var obj = { | ||
| 146 | ahrId: room.value.id, | ||
| 147 | rzStart: rzRange.value[0], | ||
| 148 | rzEnd: rzRange.value[1] | ||
| 149 | } | ||
| 150 | checkResidueRoom(obj).then(res => { | ||
| 151 | canOrderNum.value = res.data.useCount | ||
| 152 | }) | ||
| 153 | } | ||
| 154 | function countMoney() { | ||
| 155 | money.value = ((room.value.roomPrice * form.value.roomNum * usedays) + (room.value.bedPrice * form.value | ||
| 156 | .addNum * usedays)).toFixed(2) | ||
| 157 | // console.log(usedays,money.value) | ||
| 158 | } | ||
| 159 | function submit() { | ||
| 160 | if (usedays == 0) { | ||
| 161 | ElMessage.error(language.value == 0 ? '入住时间跨度需大于一天' :'Check-in time must be greater than one day') | ||
| 162 | return | ||
| 163 | } | ||
| 164 | form.value.rzStart = rzRange.value[0] | ||
| 165 | form.value.rzEnd = rzRange.value[1] | ||
| 166 | |||
| 167 | form.value.rzUsers = arr.toString() | ||
| 168 | form.value.activeId = room.value.activityId | ||
| 169 | form.value.ahId = room.value.hotelId | ||
| 170 | form.value.ahrId = room.value.id | ||
| 171 | form.value.orderName = hotelName.value | ||
| 172 | form.value.roomName =room.value.roomType | ||
| 173 | var str = '' | ||
| 174 | var str2 = '' | ||
| 175 | if (form.value.addNum && form.value.addNum > 0) { | ||
| 176 | str = `加床${form.value.addNum}张` | ||
| 177 | } else { | ||
| 178 | str = `未加床` | ||
| 179 | } | ||
| 180 | if (room.value.breakfastNum && room.value.breakfastNum > 0) { | ||
| 181 | str2 = `${room.value.breakfastNum}份早餐` | ||
| 182 | } else { | ||
| 183 | str2 = `无早餐` | ||
| 184 | } | ||
| 185 | form.value.room = `${form.value.roomNum} 间·${usedays}晚·${str}·${str2}` | ||
| 186 | console.log(form.value.room) | ||
| 187 | |||
| 188 | // 提交确认 | ||
| 189 | ElMessage.confirm(language.value == 0 ? '确认提交订单吗?' :'Confirm to submit the order?', { | ||
| 190 | confirmButtonText: language.value == 0 ? '确定' :'Confirm', | ||
| 191 | cancelButtonText: language.value == 0 ? '取消' :'Cancel', | ||
| 192 | type: 'warning' | ||
| 193 | }).then(() => { | ||
| 194 | newsSubmitOrderHotel(form.value).then(res=>{ | ||
| 195 | if (res.data) { | ||
| 196 | if (res.data.roomNum == -100) { | ||
| 197 | ElMessage.warning(language.value == 0 ? '剩余房间数不足' :'The remaining number of rooms is insufficient') | ||
| 198 | checkreRooms() | ||
| 199 | } else { | ||
| 200 | //去付钱 | ||
| 201 | } | ||
| 202 | } else { | ||
| 203 | ElMessage.warning(language.value == 0 ? '无可预定的房间' :'No rooms available to book') | ||
| 204 | } | ||
| 205 | }) | ||
| 206 | }) | ||
| 207 | } | ||
| 208 | </script> | ||
| 209 | |||
| 210 | <style scoped lang="scss"> | ||
| 211 | .bigMoney{font-size: 36px!important; | ||
| 212 | font-family: DIN Alternate; | ||
| 213 | font-weight: bold;} | ||
| 214 | .bg-lineg { | ||
| 215 | height: 40px; | ||
| 216 | line-height: 40px; | ||
| 217 | font-size: 18px; | ||
| 218 | text-align: center; | ||
| 219 | } | ||
| 220 | .leftboderTT { | ||
| 221 | font-weight: 600; | ||
| 222 | font-size: 16px; | ||
| 223 | color: #453DEA; | ||
| 224 | } | ||
| 225 | .border-rr{border-radius: 5px; | ||
| 226 | border: 1px solid #DCDFE6;} | ||
| 227 | .room{font-weight: 400; | ||
| 228 | font-size: 14px; | ||
| 229 | color: #929AA0;} | ||
| 230 | .ccitemBox { | ||
| 231 | overflow: auto; | ||
| 232 | |||
| 233 | label { | ||
| 234 | margin: 10px 0; | ||
| 235 | display: block; | ||
| 236 | |||
| 237 | span { | ||
| 238 | color: #FF8124;font-family: DIN Alternate; | ||
| 239 | font-size: 24px; | ||
| 240 | } | ||
| 241 | } | ||
| 242 | } | ||
| 243 | |||
| 244 | .ccitem { | ||
| 245 | display: flex; | ||
| 246 | justify-content: space-between; | ||
| 247 | font-size: 14px; | ||
| 248 | color: #666; | ||
| 249 | margin: 5px 0; | ||
| 250 | |||
| 251 | label { | ||
| 252 | font-size: 16px; | ||
| 253 | color: #000; | ||
| 254 | } | ||
| 255 | |||
| 256 | span { | ||
| 257 | font-size: 13px; | ||
| 258 | } | ||
| 259 | } | ||
| 260 | </style> |
-
Please register or sign in to post a comment