tearoom/pages/myorder/index.vue

1567 lines
40 KiB
Vue
Raw Permalink Normal View History

2024-12-20 09:02:40 +08:00
<template>
<view class="page">
<u-navbar title="包厢预定" :border-bottom="false" :background="bgc" back-icon-color="#262B37" title-color='#262B37'
title-size='36' height='36' id="navbar">
</u-navbar>
<image src="https://api.ccttiot.com/smartmeter/img/static/umk1caLMk7f1elQ2T78c" mode="" class="imgbj"></image>
<view class="boxda">
<view class="fangjian">
<view class="top">
<text></text>{{shopobj.storeName == null ? '--' : shopobj.storeName}}
</view>
<view class="bd">
<view class="lt">
<image :src="shopobj.picture" mode=""></image>
</view>
<view class="rt">
<view class="name">
{{shopobj.roomName == null ? '--' : shopobj.roomName}}
</view>
<view class="leixing">
<view class="" v-for="(item,index) in shopobj.tags">
{{item}}
</view>
</view>
<view class="price">
{{shopobj.hour == null ? '--' : shopobj.hour}}/小时
</view>
</view>
</view>
</view>
<view class="appointment">
<view class="riqi">
<view class="yyshijian">
<view class="shijian_item" v-for="(item,index) in weekdayAndDateSequence"
:id="indexone == index ? 'active' : ''" :key="index" @click="btnyd(index,item)">
<view class="xingqi">{{item.weekday}}</view>
<view class="yueri">{{item.date.slice(-5)}}</view>
</view>
</view>
</view>
<view class="tcxz">
<view class="tcxzname">
套餐选择
</view>
<view class="taocan">
<view class="tclist" v-for="(item,index) in tclist" :id="indextwo == index ? 'active' : ''"
:key="index" @click="btntc(index,item)">
<view style="font-weight: 600;" :id="indextwo == index ? 'active' : ''">{{item.explain == null ? '--' : item.explain}}</view>
<view style="font-weight: 600;" :id="indextwo == index ? 'active' : ''">{{item.price == null ? '--' : item.price}}</view>
</view>
</view>
</view>
<view class="shichangxz">
<view class="tcxzname">
时长选择
</view>
<view class="shijianinp">
<view class="kaishi" @click="btnks">
{{kstime}}
</view>
<view class="kaishi" style="background-color: #eee;">
{{jstime}}
</view>
</view>
</view>
<view class="bot">
<view class="duan">
<view v-for="(isReserved, hourStr) in roomList" :key="hourStr"
:class="['hour-item', { 'is-reserved': isReserved }]">
</view>
</view>
<view class="shijian">
<view style="width: 16rpx;" v-for="(item,index) in hourPointsArray" :key="index">
{{item == '00:00:00' ? '次日' : item.slice(0,2)}}
</view>
</view>
<view class="ydshiduan">
<view class="yi">
<text></text> 已被预订时段
</view>
<view class="wei">
<text></text> 可预订时段
</view>
</view>
</view>
</view>
<view class="money">
<image src="https://api.ccttiot.com/smartmeter/img/static/uP8ymRHTDQ6YdwwnxQAb" mode="" class="moneyimg">
</image>
<view class="moneytop">
<view class="zongjia">
<view class="">订单总价</view>
<view class="pricered">{{price == null ? '--' : price}}</view>
</view>
<view class="yuding">
<view class="">预定时长</view>
<view class="">{{hourstime == null ? '--' : hourstime}}小时</view>
</view>
<view class="yudingtime">
<view class="">预定时间段</view>
<view class="time" v-if="ksriqi != '' && kstime !=''">
{{timeshijian.slice(0,-3) + '至'}}{{jstime == null ? '--' : jstime}}</view>
<view class="time" v-else>--</view>
</view>
</view>
<view class="moneybot">
<view class="xudan">
<view class="">续单</view>
<view class="">{{shopobj.hour == null ? '--' : shopobj.hour}}/小时</view>
</view>
<!-- <view class="yu_e" @click="btnchongzhi">
<view class="">账户余额</view>
<view class="yu_eno" v-if="price > (user.balance == null ? '0' : user.balance)"> 余额不足请充值 <image
src="https://api.ccttiot.com/smartmeter/img/static/uYHtrgPzlait1i05RQYy" mode=""></image>
</view>
<view class="yu_eno" v-else> {{user.balance == null ? '0' : user.balance}}
<image src="https://api.ccttiot.com/smartmeter/img/static/uYHtrgPzlait1i05RQYy" mode=""></image>
</view>
</view> @click="shows = true"-->
<view class="koukuan" >
<view class="">扣款策略</view>
<view class="">{{zfss}}
<image src="https://api.ccttiot.com/smartmeter/img/static/uYHtrgPzlait1i05RQYy" mode=""></image>
</view>
</view>
</view>
</view>
</view>
<view class="heji">
<view class="lt">
<view class="hejitishi">
合计
</view>
<view class="price">
<text>{{price == null ? '--' : price}}</text> {{hourstime == null ? '--' : hourstime}}小时
</view>
</view>
<view class="rt">
<view class="qdyd" @click="btnqdyd">
确认预定
</view>
</view>
</view>
<view class="mask" v-if="yudingflag"></view>
<view class="yudingtrue" v-if="yudingflag">
<view class="top">
<image src="https://api.ccttiot.com/smartmeter/img/static/usPNNZmaPaHGnzKkwwa9" mode=""></image>
<view class="name">
预定信息确认
</view>
</view>
<view class="bd">
<view class="">
预约门店{{shopobj.storeName == null ? '--' : shopobj.storeName}}
</view>
<view class="">
预定包间{{shopobj.roomName == null ? '--' : shopobj.roomName}}
</view>
<view class="">
开始时间{{timeshijian.slice(0,-3)}}
</view>
<view class="">
预定时长{{hourstime}}小时
</view>
</view>
<view class="shuom">
<view class="xuzhi">
预定须知
</view>
<view class="">
1预定的订单将全时段保留迟到不可顺延和退款
</view>
<view class="">
2为避免包厢被其他用户预约而给您带来不好的体 如需续单请提前续单!
</view>
<view class="">
3订单开始前1小时内取消订单需核收15%退单费 请合理规划您的时间;
</view>
</view>
<view class="anniu">
<view class="fanhui" @click=" yudingflag = false ">
返回修改
</view>
<view class="ljyd" @click="btnljyd">
立即预订
</view>
</view>
</view>
<u-select v-model="show" mode="mutil-column" title="选择时长" confirm-color="#48893B" :list="list"
@confirm="confirm"></u-select>
<u-select v-model="shows" title="选择扣款方式" confirm-color="#48893B" :list="lists" @confirm="confirms"></u-select>
</view>
</template>
<script>
export default {
data() {
return {
bgc: {
backgroundColor: "",
},
indexone: -1,
indextwo: -1,
yudingflag: false,
show: false,
shows: false,
lists: [{
value: 'ye',
label: '使用门店余额'
}, {
value: 'wx',
label: '微信支付'
}],
list: [
[{
value: '1',
label: '00'
},
{
value: '2',
label: '01'
}, {
value: '3',
label: '02'
}, {
value: '4',
label: '03'
}, {
value: '5',
label: '04'
}, {
value: '6',
label: '05'
}, {
value: '7',
label: '06'
}, {
value: '8',
label: '07'
}, {
value: '9',
label: '08'
}, {
value: '10',
label: '09'
}, {
value: '11',
label: '10'
}, {
value: '12',
label: '11'
}, {
value: '13',
label: '12'
}, {
value: '14',
label: '13'
}, {
value: '15',
label: '14'
}, {
value: '16',
label: '15'
}, {
value: '17',
label: '16'
}, {
value: '18',
label: '17'
}, {
value: '19',
label: '18'
}, {
value: '20',
label: '19'
}, {
value: '21',
label: '20'
}, {
value: '22',
label: '21'
}, {
value: '23',
label: '22'
}, {
value: '24',
label: '23'
},
],
[{
value: '3',
label: '00'
},
{
value: '4',
label: '30'
}
],
],
kstime: '',
jstime: '',
timetype: '',
roomId: '',
shopobj: {},
hourPointsArray: [],
roomList: [],
hours: [],
reservationStatus: {},
weekdayAndDateSequence: [],
tclist: [],
arr: [],
huors: [],
tcobj: {},
pricedd: '',
price: '',
hourstime: '',
ksriqi: '',
user: {},
zfss: '微信支付',
zfssid: 'wx',
timeshijian:''
}
},
onLoad(option) {
this.roomId = option.roomId
this.getstoredetail()
this.gettaocan()
this.hourPointsArray = this.getCurrentHourPoints() //计算从当前时间往后推24小时
},
onShow() {
this.getinfo()
},
mounted() {
let arr = this.getCurrentWeekdayAndNextFiveDays();
this.weekdayAndDateSequence = this.convertDates(arr)
console.log(this.weekdayAndDateSequence);
},
methods: {
convertDates(array) {
return array.map(item => {
// 将日期字符串转换为 Date 对象
// 注意:这里的解析可能需要根据实际的日期字符串格式进行调整
let dateStr = item.date;
let dateParts = dateStr.match(/(\w+) (\w+) (\d+) (\d+)/);
if (!dateParts) {
console.error('日期字符串格式不正确:', dateStr);
return item; // 或者你可以抛出一个错误,或者返回一个特殊值
}
let [, weekday, monthName, day, year] = dateParts;
let monthMap = {
Jan: '01', Feb: '02', Mar: '03', Apr: '04',
May: '05', Jun: '06', Jul: '07', Aug: '08',
Sep: '09', Oct: '10', Nov: '11', Dec: '12'
};
let month = monthMap[monthName];
if (!month) {
console.error('无法识别的月份:', monthName);
return item; // 或者处理错误
}
// 构建新的日期字符串
let newDateStr = `${year.slice(2,4)}-${month}-${day.padStart(2, '0')}`;
// 返回一个新的对象,或者你可以直接修改原始对象(但通常不推荐这样做,因为它会改变原始数据)
return {
...item,
date: newDateStr
};
});
},
// 拿到当前时间后24小时格式成两位数
initializeData() {
// 获取当前时间
const now = new Date()
// 获取当前时间的小时部分0-23
const currentHour = now.getHours()
// 初始化小时数组
this.hours = [];
this.arr = []
// 遍历从当前小时开始的24个小时
for (let i = 0; i < 24; i++) {
// 计算小时数注意要处理超过23点的情况
let hour = (currentHour + i) % 24
let arrsum = currentHour + i
if (hour == '00') { //如果是00:00 则改成24:00
hour = 24
} else {
hour = hour
}
// 推入数组
this.arr.push(arrsum)
this.hours.push(hour)
}
},
// 更新房间的预订状态且与initializeData进行匹对
updateRoomReservationStatus() {
this.roomList.forEach(room => {
room.reservationStatus = {} // 为每个房间创建一个新的预订状态对象
this.hours.forEach(hour => {
room.reservationStatus[hour] = false // 初始化为未预订状态
})
// console.log(room.reservationStatus,'02.0230.');
// room.forEach(period => {
let startHour = room.startTime.slice(room.startTime.length - 8, room.startTime.length -
6) //取预定开始时间小时
let endHour = room.endTime.slice(room.endTime.length - 8, room.endTime.length - 6) //取预定结束时间小时
let timefen = room.startTime.slice(room.endTime.length - 5, room.endTime.length -
3) //取预定结束时间分钟
// 获取当前日期
const now = new Date();
const year = now.getFullYear();
const month = String(now.getMonth() + 1).padStart(2, '0'); // 月份从0开始所以要加1并用padStart确保是两位数
const day = String(now.getDate()).padStart(2, '0'); // 用padStart确保是两位数
let riqione = `${year}-${month}-${day}` //当前日期
let riqitwo = room.endTime.slice(0, 10) //预定结束日期
let dateOne = new Date(riqione)
let dateTwo = new Date(riqitwo)
if (dateOne < dateTwo) { //将开始和结束日期进行对比 判断是否是第二天
if (endHour < startHour) {
endHour = 24 + Number(endHour)
} else {
endHour = 24 + Number(endHour)
startHour = 24 + Number(startHour)
}
} else {
console.log("第一个日期不小于第二个日期")
}
console.log(startHour, endHour, room.startTime, room.endTime)
for (let i = 0; i < 24; i++) {
if (timefen == '00') { //判断预定结束是否包含分钟 不包含正常走判断 包含则将时间往后延长1
if (this.arr[i] > startHour && this.arr[i] <= endHour) {
room.reservationStatus[i] = true
}
} else {
if (this.arr[i] > startHour && Number(this.arr[i] - 1) <= endHour) {
room.reservationStatus[i] = true
}
}
}
})
this.roomList = this.mergeReservationStatuses(this.roomList)
},
// 将this.roomlist中的三个数组合并成一个
mergeReservationStatuses(array) {
let mergedStatus = {}
array.forEach(obj => {
for (let time in obj.reservationStatus) {
if (!(time in mergedStatus)) {
mergedStatus[time] = false
}
mergedStatus[time] = mergedStatus[time] || obj.reservationStatus[time]
}
})
return mergedStatus
},
//计算从当前时间往后推24小时
getCurrentHourPoints() {
const now = new Date();
const startHour = now.getHours();
const startDate = new Date(now);
startDate.setMinutes(0, 0, 0); // 确保分钟、秒和毫秒都是0
const options = {
year: 'numeric',
month: '2-digit',
day: '2-digit',
hour: '2-digit',
minute: '2-digit',
second: '2-digit'
};
const hourPoints = [];
for (let i = 0; i < 24; i++) {
const newDate = new Date(startDate);
newDate.setHours((startHour + i) % 24, 0, 0, 0);
if (newDate.getHours() === 0 && i !== 0) {
newDate.setDate(newDate.getDate() + 1);
}
const hours = String(newDate.getHours()).padStart(2, '0');
const minutes = String(newDate.getMinutes()).padStart(2, '0');
const seconds = String(newDate.getSeconds()).padStart(2, '0');
const formattedDateString = `${hours}:${minutes}:${seconds}`;
hourPoints.push(formattedDateString);
}
return hourPoints;
},
// 获取当前时间和日期+后面五天时间
getCurrentWeekdayAndNextFiveDays() {
// 获取当前日期和时间
const now = new Date();
// 获取当前是星期几0代表周日1代表周一...6代表周六
const currentWeekday = now.getDay();
const result = [];
result.push({
date: now.toLocaleDateString('zh-CN', {
year: '2-digit',
month: '2-digit',
day: '2-digit'
}),
weekday: ['周日', '周一', '周二', '周三', '周四', '周五', '周六'][currentWeekday]
});
// 往后推五天,并添加到数组中
for (let i = 1; i < 5; i++) {
const newDate = new Date(now);
newDate.setDate(now.getDate() + i);
result.push({
date: newDate.toLocaleDateString('zh-CN', {
year: '2-digit',
month: '2-digit',
day: '2-digit'
}),
weekday: ['周日', '周一', '周二', '周三', '周四', '周五', '周六'][newDate.getDay()]
})
}
return result
},
// 根据房间id获取套餐
gettaocan() {
this.$u.get(`/app/rule/getListByRoomId?roomId=${this.roomId}`).then(res => {
if (res.code == 200) {
this.tclist = res.data
}
})
},
// 查询个人信息
getinfo() {
this.$u.get(`/getAppInfo`).then(res => {
if (res.code == 200) {
this.user = res.user
}else if(res.code == 401){
uni.showModal({
title: '温馨提示',
content: '您该操作需登录,请前去登录',
success: function (res) {
if (res.confirm) {
uni.navigateTo({
url:'/pages/login/index'
})
}else if(res.cancel){
uni.navigateBack()
}
}
})
}
})
},
// 点击立即预定
btnljyd() {
// let time = '20' + this.ksriqi + ' ' + this.kstime + ':00'
// let formattedDateString = time.replace(/\//g, "-")
let data = {
roomId: this.roomId,
payType: this.zfssid,
ruleId: this.tcobj.ruleId,
type: 1,
reserveStartTime: this.timeshijian,
mode: 2,
hours: this.hourstime,
price: this.price
}
this.$u.post(`/app/order/createOrder`, data).then(res => {
if (res.code == 200) {
let orderNo = res.data.orderNo
uni.requestPayment({
provider: 'wxpay',
timeStamp: res.data.response.timeStamp,
nonceStr: res.data.response.nonceStr,
package: res.data.response.packageVal,
signType: res.data.response.signType,
paySign: res.data.response.paySign,
success: (res) => {
console.log(res, '支付成功')
uni.navigateTo({
url:'/page_user/dingdanxq?orderNo=' + orderNo
})
},
fail(err) {
uni.showToast({
title: '支付失败',
icon: 'none',
duration: 2000
})
}
})
}else if(res.code == 401){
uni.showModal({
title: '温馨提示',
content: '您该操作需登录,是否前去登录?',
success: function (res) {
if (res.confirm) {
uni.navigateTo({
url:'/pages/login/index'
})
} else if (res.cancel) {
}
}
})
} else {
uni.showToast({
title: res.msg,
icon: 'none',
duration: 2000
})
}
})
},
// 确认选择支付方式
confirms(e) {
this.zfss = e[0].label
this.zfssid = e[0].value
},
// 点击确定预定进行判断
btnqdyd() {
if (this.ksriqi == '') {
uni.showToast({
title: '请先选择日期',
icon: 'none',
duration: 2000
})
} else if (!this.tcobj.hours) {
uni.showToast({
title: '请先选择套餐',
icon: 'none',
duration: 2000
})
} else if (this.kstime == '') {
uni.showToast({
title: '请先选择开始时间',
icon: 'none',
duration: 2000
})
} else if (this.zfss == '') {
uni.showToast({
title: '请先选择扣款方式',
icon: 'none',
duration: 2000
})
} else if (this.zfss == '使用门店余额') {
if (this.user.balance == null || this.user.balance == undefined || this.user.balance < this.price) {
uni.showToast({
title: '您的余额不足,请先充值',
icon: 'none',
duration: 2000
})
} else {
let mergedData = this.hourPointsArray.map((time, index) => {
let roomNumber = Object.keys(this.roomList)[index]
let roomStatus = this.roomList[roomNumber]
return {
roomNumber: parseInt(roomNumber, 10),
roomStatus: roomStatus,
time: time
}
})
let kaishi = this.kstime + ':00'
let jieshu = this.jstime + ':00'
let isBooked = false; // 假设没有预订
mergedData.forEach(item => {
let itemTime = item.time
if ((itemTime >= kaishi && itemTime <= jieshu) && item.roomStatus) {
isBooked = true // 如果有预订,设置 isBooked 为 true
}
})
// 根据 isBooked 的值来执行操作
if (!isBooked) {
let timeshijian = this.timeshijian
let targetDate = new Date(timeshijian.replace(/-/g, '/'))
let currentDate = new Date();
console.log(targetDate,currentDate,'020202');
if (targetDate < currentDate) {
uni.showToast({
title: '请选择当前时间之后',
icon: 'none',
duration: 2000
})
} else {
this.yudingflag = true
}
} else {
uni.showToast({
title: '该时间段已被预订,请选择其他时间段',
icon: 'none',
duration: 2000
})
}
}
} else {
let mergedData = this.hourPointsArray.map((time, index) => {
let roomNumber = Object.keys(this.roomList)[index]
let roomStatus = this.roomList[roomNumber]
return {
roomNumber: parseInt(roomNumber, 10),
roomStatus: roomStatus,
time: time
}
})
let kaishi = this.kstime + ':00'
let jieshu = this.jstime + ':00'
let isBooked = false; // 假设没有预订
mergedData.forEach(item => {
let itemTime = item.time
if ((itemTime >= kaishi && itemTime <= jieshu) && item.roomStatus) {
isBooked = true // 如果有预订,设置 isBooked 为 true
}
})
// 根据 isBooked 的值来执行操作
if (!isBooked) {
let timeshijian = this.timeshijian
let targetDate = new Date(timeshijian.replace(/-/g, '/'))
let currentDate = new Date();
console.log(targetDate,currentDate,'020202');
if (targetDate < currentDate) {
uni.showToast({
title: '请选择当前时间之后',
icon: 'none',
duration: 2000
})
} else {
this.yudingflag = true
}
} else {
uni.showToast({
title: '该时间段已被预订,请选择其他时间段',
icon: 'none',
duration: 2000
})
}
}
},
// 点击跳转到充值页
btnchongzhi() {
uni.navigateTo({
url: '/page_user/chongzhi'
})
},
// 确认选择时间
confirm(e) {
this.kstime = e[0].label + ':' + e[1].label
let shijian = '20' + this.ksriqi + ' ' + this.kstime
console.log(shijian,shijian.slice(2,5));
if(shijian.slice(2,5) == 'Wed'){
this.timeshijian = this.formatDate(shijian)
}else{
this.timeshijian = this.parseTime(shijian)
}
if (this.tcobj.hours) {
this.jstime = this.addOneHourToTime(this.kstime)
}
},
// 判断是否需要格式化
isValidDateFormatOnly(inputString) {
const parts = inputString.split(/[\s/]/);
return parts.length === 5 &&
!isNaN(parts[0]) && parts[0].length === 4 && // 年份
!isNaN(parts[1]) && parts[1].length === 2 && // 月份
!isNaN(parts[2]) && parts[2].length === 2 && // 日期
!isNaN(parts[3]) && parts[3].length === 2 && // 小时
!isNaN(parts[4]) && parts[4].length === 2; // 分钟
},
// 计算结束时间
addOneHourToTime(timeString, date = new Date()) {
let [hours, minutes] = timeString.split(':').map(Number)
let timeDate = new Date(date.getFullYear(), date.getMonth(), date.getDate(), hours, minutes, 0, 0)
timeDate.setHours(timeDate.getHours() + Number(this.tcobj.hours)) //加上套餐中的小时
let newHours = timeDate.getHours()
let newMinutes = String(timeDate.getMinutes()).padStart(2, '0') // 格式化分钟为两位数
return `${String(newHours).padStart(2, '0')}:${newMinutes}`
},
// 请求门店详细信息
getstoredetail() {
this.$u.get(`/app/room/${this.roomId}`).then(res => {
if (res.code == 200) {
this.shopobj = res.data
if(res.data.reservedTimePeriods == ''){
this.roomList = []
for(let i = 0;i < 24;i++){
this.roomList.push(false)
}
}else{
this.roomList = res.data.reservedTimePeriods
this.initializeData()
this.updateRoomReservationStatus()
}
}
})
},
// 选择开始时间
btnks() {
this.show = true
},
// 选择日期
btnyd(index, item) {
this.ksriqi = item.date
let shijian = '20' + this.ksriqi + ' ' + this.kstime
if(shijian.slice(2,5) == 'Wed'){
this.timeshijian = this.formatDate(shijian)
}else{
this.timeshijian = this.parseTime(shijian)
}
if (this.tcobj.hours && this.kstime != '') {
this.jstime = this.addOneHourToTime(this.kstime)
}
this.indexone = index
if(index != 0){
this.$u.get(`/app/order/getReservedTimePeriods?roomId=${this.roomId}&startTime=${'20' + this.ksriqi}`).then(res => {
if (res.code == 200) {
if(res.data == ''){
this.roomList = []
for(let i = 0;i < 24;i++){
this.roomList.push(false)
}
this.hourPointsArray = this.getDangtiantime()
}else{
this.roomList = res.data
this.hourPointsArray = this.getDangtiantime()
this.arr = this.getDangtiantimes()
this.getgengxinriqiday()
}
}
})
}else{
this.getstoredetail()
this.gettaocan()
this.hourPointsArray = this.getCurrentHourPoints() //计算从当前时间往后推24小时
}
},
// 更新日期
getgengxinriqiday() {
this.roomList.forEach(room => {
room.reservationStatus = {} // 为每个房间创建一个新的预订状态对象
this.hours.forEach(hour => {
room.reservationStatus[hour] = false // 初始化为未预订状态
})
let startHour = room.startTime.slice(room.startTime.length - 8, room.startTime.length - 6) //取预定开始时间小时
let endHour = room.endTime.slice(room.endTime.length - 8, room.endTime.length - 6) //取预定结束时间小时
let timefen = room.startTime.slice(room.endTime.length - 5, room.endTime.length - 3) //取预定结束时间分钟
// 获取当前日期
const now = new Date();
const year = now.getFullYear();
const month = String(now.getMonth() + 1).padStart(2, '0'); // 月份从0开始所以要加1并用padStart确保是两位数
const day = String(now.getDate()).padStart(2, '0'); // 用padStart确保是两位数
if(endHour < startHour){
startHour = '00'
}
console.log(startHour, endHour, room.startTime, room.endTime)
for (let i = 0; i < 24; i++) {
if (timefen == '00') { //判断预定结束是否包含分钟 不包含正常走判断 包含则将时间往后延长1
if (this.arr[i].slice(0,2) > startHour && this.arr[i].slice(0,2) <= endHour) {
room.reservationStatus[i] = true
}
} else {
if (this.arr[i].slice(0,2) > startHour && Number(this.arr[i].slice(0,2) - 1) <= Number(endHour)) {
room.reservationStatus[i] = true
}
}
}
})
this.roomList = this.mergeReservationStatuses(this.roomList)
},
// 展示this.hourPointsArray使用方法 01:00 - 24:00
getDangtiantime() {
let hourPoints = [];
let timeString = ''
for (let hour = 0; hour < 24; hour++) {
let formattedHour = String(hour).padStart(2, '0')
if(formattedHour == '00'){
timeString = `00:00:01`;
}else{
timeString = `${formattedHour}:00:00`
}
hourPoints.push(timeString);
}
return hourPoints;
},
// this.arr使用方法 00:00 - 23:00
getDangtiantimes() {
const hourPoints = [];
for (let hour = 0; hour < 24; hour++) {
const formattedHour = String(hour).padStart(2, '0');
const timeString = `${formattedHour}:00:00`;
hourPoints.push(timeString);
}
return hourPoints;
},
// 选择套餐
btntc(index, item) {
this.tcobj = item
this.price = item.price //订单金额
this.hourstime = item.hours //订单时间
this.indextwo = index
if (this.kstime != '') {
this.jstime = this.addOneHourToTime(this.kstime)
}
},
// 日期格式化
parseTime(time, pattern) {
if (arguments.length === 0 || !time) {
return null
}
const format = pattern || '{y}-{m}-{d} {h}:{i}:{s}'
let date
if (typeof time === 'object') {
date = time
} else {
if ((typeof time === 'string') && (/^[0-9]+$/.test(time))) {
time = parseInt(time)
} else if (typeof time === 'string') {
time = time.replace(new RegExp(/-/gm), '/').replace('T', ' ').replace(new RegExp(/\.[\d]{3}/gm), '');
}
if ((typeof time === 'number') && (time.toString().length === 10)) {
time = time * 1000
}
date = new Date(time)
}
const formatObj = {
y: date.getFullYear(),
m: date.getMonth() + 1,
d: date.getDate(),
h: date.getHours(),
i: date.getMinutes(),
s: date.getSeconds(),
a: date.getDay()
}
const time_str = format.replace(/{(y|m|d|h|i|s|a)+}/g, (result, key) => {
let value = formatObj[key]
// Note: getDay() returns 0 on Sunday
if (key === 'a') { return ['日', '一', '二', '三', '四', '五', '六'][value] }
if (result.length > 0 && value < 10) {
value = '0' + value
}
return value || 0
})
return time_str
},
formatDate(inputDate) {
const parts = inputDate.match(/(\d+)\D+(\w+)\s+(\w+)\s+(\d+)\s+(\d+)\s+(\d+):(\d+)/);
if (!parts) {
throw new Error('Invalid date format');
}
const [, dayOfMonth, , month, , year, hour, minute] = parts;
const monthMap = {
Jan: '01', Feb: '02', Mar: '03', Apr: '04',
May: '05', Jun: '06', Jul: '07', Aug: '08',
Sep: '09', Oct: '10', Nov: '11', Dec: '12'
};
const monthNum = monthMap[month];
let formattedHour = (parseInt(hour, 10) + 1).toString().padStart(2, '0');
let formattedMinute = minute.padStart(2, '0');
let formattedSecond = '00'; // 原始字符串中没有秒所以默认为00
const formattedDate = `${year}-${monthNum}-${dayOfMonth.padStart(2, '0')} ${formattedHour}:${formattedMinute}:${formattedSecond}`;
return formattedDate;
}
}
}
</script>
<style lang="scss">
.hour-item {
width: 100%;
text-align: center;
margin: 2px 0;
background-color: gray;
/* 默认灰色 */
color: white;
/* 确保文本在灰色背景上清晰可见 */
}
.hour-item.is-reserved {
background-color: #48893B !important;
}
#active {
background: #48893B !important;
border: 2rpx solid #48893B !important;
color: #fff !important;
}
.boxda{
width: 100%;
height: 88vh;
overflow: scroll;
padding-bottom: 200rpx;
box-sizing: border-box;
}
page {
background: #fff;
margin-top: 18rpx;
padding-bottom: 220rpx;
box-sizing: border-box;
.yudingtrue {
width: 600rpx;
height: 806rpx;
background: #FFFFFF;
border-radius: 32rpx 32rpx 32rpx 32rpx;
padding: 0 20rpx;
box-sizing: border-box;
position: fixed;
top: 388rpx;
left: 50%;
transform: translateX(-50%);
.shuom {
.xuzhi {
font-weight: 600;
font-size: 28rpx;
color: #FF1818;
margin-top: 22rpx;
}
view {
font-size: 24rpx;
color: #FF1818;
margin-top: 12rpx;
}
}
.anniu {
display: flex;
justify-content: space-between;
margin-top: 36rpx;
padding: 0 40rpx;
box-sizing: border-box;
.fanhui {
width: 212rpx;
height: 62rpx;
border: 1rpx solid #48893B;
font-weight: 600;
font-size: 32rpx;
color: #48893B;
text-align: center;
line-height: 62rpx;
border-radius: 50rpx;
}
.ljyd {
width: 212rpx;
height: 62rpx;
background: #48893B;
border-radius: 50rpx;
font-weight: 600;
font-size: 32rpx;
color: #FFFFFF;
text-align: center;
line-height: 62rpx;
}
}
.bd {
width: 100%;
margin-top: 24rpx;
border-bottom: 1rpx solid #D8D8D8;
box-sizing: border-box;
padding-bottom: 36rpx;
view {
width: 100%;
padding: 0 10rpx;
box-sizing: border-box;
font-size: 28rpx;
color: #7C7C7C;
margin-top: 12rpx;
}
}
.top {
width: 100%;
border-bottom: 1rpx solid #D8D8D8;
text-align: center;
position: relative;
padding-top: 100rpx;
box-sizing: border-box;
padding-bottom: 20rpx;
image {
position: absolute;
top: -100rpx;
left: 50%;
transform: translateX(-50%);
width: 188rpx;
height: 188rpx;
}
.name {
font-weight: 600;
font-size: 32rpx;
color: #3D3D3D;
}
}
}
.mask {
width: 100%;
height: 100vh;
position: fixed;
top: 0;
left: 0;
opacity: .5;
background-color: #000;
}
.heji {
width: 750rpx;
height: 166rpx;
background: #FFFFFF;
box-shadow: 0rpx 8rpx 20rpx 0rpx rgba(0, 0, 0, 0.3);
border-radius: 0rpx 0rpx 0rpx 0rpx;
position: fixed;
bottom: 0;
left: 0;
display: flex;
justify-content: space-between;
padding: 40rpx 38rpx;
box-sizing: border-box;
.lt {
.hejitishi {
font-weight: 600;
font-size: 32rpx;
color: #3D3D3D;
}
.price {
font-size: 28rpx;
color: #3D3D3D;
text {
font-weight: 600;
font-size: 40rpx;
color: #FF4848;
margin-right: 30rpx;
}
}
}
.rt {
width: 302rpx;
height: 86rpx;
background: #48893B;
border-radius: 49rpx 49rpx 49rpx 49rpx;
font-weight: 600;
font-size: 40rpx;
color: #FFFFFF;
text-align: center;
line-height: 86rpx;
}
}
.money {
width: 710rpx;
margin: auto;
position: relative;
overflow: hidden;
.moneybot {
padding: 30rpx 38rpx;
box-sizing: border-box;
.xudan {
display: flex;
justify-content: space-between;
view {
font-size: 28rpx;
color: #3D3D3D;
}
}
.yu_e {
display: flex;
justify-content: space-between;
margin-top: 20rpx;
view {
font-size: 28rpx;
color: #3D3D3D;
display: flex;
align-items: center;
}
.yu_eno {
color: #FF1818;
display: flex;
align-items: center;
image {
width: 14rpx;
height: 36rpx;
display: flex;
align-items: center;
margin-left: 12rpx;
}
}
}
.koukuan {
display: flex;
justify-content: space-between;
margin-top: 20rpx;
view {
font-size: 28rpx;
color: #3D3D3D;
display: flex;
align-items: center;
image {
width: 14rpx;
height: 36rpx;
display: flex;
align-items: center;
margin-left: 12rpx;
}
}
}
}
.moneytop {
padding: 46rpx 38rpx;
box-sizing: border-box;
.yudingtime {
font-size: 28rpx;
color: #3D3D3D;
display: flex;
justify-content: space-between;
margin-top: 20rpx;
.time {
color: #48893B;
}
}
.yuding {
margin-top: 34rpx;
display: flex;
justify-content: space-between;
font-size: 28rpx;
color: #3D3D3D;
}
.zongjia {
display: flex;
justify-content: space-between;
border-bottom: 1px solid #D8D8D8;
padding-bottom: 20rpx;
box-sizing: border-box;
view {
font-weight: 600;
font-size: 36rpx;
color: #3D3D3D;
}
.pricered {
font-size: 36rpx;
color: #FF1818;
font-weight: 600;
}
}
}
.moneyimg {
width: 710rpx;
height: 529rpx;
position: absolute;
top: 0;
left: 0;
z-index: -1;
}
}
.fangjian {
width: 674rpx;
height: 332rpx;
background: #FFFFFF;
box-shadow: 0rpx 2rpx 12rpx 0rpx rgba(0, 0, 0, 0.15);
border-radius: 18rpx 18rpx 18rpx 18rpx;
margin: auto;
margin-top: 20rpx;
padding: 30rpx 32rpx;
box-sizing: border-box;
.top {
display: flex;
align-items: center;
text {
display: inline-block;
width: 8rpx;
height: 44rpx;
background: #48893B;
border-radius: 6rpx 6rpx 6rpx 6rpx;
margin-right: 12rpx;
}
}
.bd {
margin-top: 40rpx;
display: flex;
.rt {
.name {
font-size: 32rpx;
color: #3D3D3D;
font-weight: 600;
}
.price {
font-size: 32rpx;
color: #7C7C7C;
margin-top: 20rpx;
}
.leixing {
margin-top: 24rpx;
display: flex;
text-align: center;
view {
margin-right: 14rpx;
width: 94rpx;
height: 46rpx;
border-radius: 6rpx 6rpx 6rpx 6rpx;
border: 1rpx solid #48893B;
font-size: 26rpx;
color: #48893B;
line-height: 46rpx;
}
}
}
.lt {
margin-right: 42rpx;
image {
width: 176rpx;
height: 176rpx;
border-radius: 10rpx;
}
}
}
}
.imgbj {
width: 750rpx;
height: 424rpx;
position: fixed;
top: 0;
left: 0;
z-index: -1;
}
.bot {
margin-top: 28rpx;
.ydshiduan {
display: flex;
margin-top: 30rpx;
.yi {
display: flex;
align-items: center;
margin-right: 32rpx;
text {
display: inline-block;
width: 28rpx;
height: 4rpx;
background: #48893B;
margin-right: 14rpx;
}
font-size: 24rpx;
color: #48893B;
}
.wei {
display: flex;
align-items: center;
text {
display: inline-block;
width: 28rpx;
height: 4rpx;
background: #B8B8B8;
margin-right: 14rpx;
}
font-size: 24rpx;
color: #3D3D3D;
}
}
.duan {
width: 100%;
display: flex;
justify-content: center;
view {
width: 28rpx;
height: 4rpx;
background-color: #B8B8B8;
margin-right: 1rpx;
}
}
.shijian {
display: flex;
font-size: 16rpx;
color: #3D3D3D;
justify-content: center;
justify-content: space-between;
box-sizing: border-box;
padding-right: 6rpx;
}
}
.shichangxz {
display: flex;
align-items: center;
margin-top: 50rpx;
// width: 3000rpx;
justify-content: space-between;
.shijianinp {
display: flex;
align-items: center;
.kaishi {
width: 148rpx;
height: 54rpx;
border-radius: 27rpx 27rpx 27rpx 27rpx;
border: 2rpx solid #7C7C7C;
text-align: center;
line-height: 54rpx;
margin-right: 20rpx;
margin-left: 20rpx;
}
}
.tcxzname {
font-size: 32rpx;
color: #3D3D3D;
font-weight: 600;
width: 160rpx;
}
}
.tcxz {
display: flex;
align-items: center;
margin-top: 50rpx;
width: 3000rpx;
}
.tcxz .tcxzname {
font-size: 32rpx;
color: #3D3D3D;
font-weight: 600;
width: 160rpx;
}
.tcxz .taocan {
display: flex;
width: 420rpx;
overflow-x: auto;
-webkit-overflow-scrolling: touch;
}
.tcxz .taocan .tclist {
width: 186rpx;
height: 110rpx;
border-radius: 10rpx;
border: 2rpx solid #7C7C7C;
text-align: center;
display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
margin-right: 16rpx;
}
.tcxz .taocan .tclist view {
font-size: 32rpx;
color: #3D3D3D;
// font-weight: 600;
box-sizing: border-box;
width: 182rpx;
}
.riqi {
margin-top: 42rpx;
image {
width: 54rpx;
height: 54rpx;
}
.yyshijian {
display: flex;
justify-content: space-between;
.shijian_item {
width: 112rpx;
height: 88rpx;
background: #fff;
border-radius: 8rpx 8rpx 8rpx 8rpx;
border: 2rpx solid #fff;
text-align: center;
padding-top: 6rpx;
box-sizing: border-box;
margin-right: 10rpx;
}
}
}
.appointment {
width: 674rpx;
max-height: 1104rpx;
background: #FFFFFF;
box-shadow: 0rpx 8rpx 20rpx 0rpx rgba(0, 0, 0, 0.15);
border-radius: 30rpx;
padding: 38rpx;
box-sizing: border-box;
margin: auto;
overflow: hidden;
margin-top: 24rpx;
.top {
display: flex;
justify-content: space-between;
.yytime {
font-size: 36rpx;
color: #3D3D3D;
font-weight: 600;
}
.yincang {
image {
width: 50rpx;
height: 50rpx;
}
}
}
}
}
/deep/ .u-indicator-item-number {
padding: 12rpx 16rpx !important;
margin-bottom: 60rpx !important;
border-radius: 10rpx !important;
height: 52rpx !important;
color: #fff !important;
}
/deep/ .u-swiper-indicator {
padding: 0 44rpx !important;
}
</style>