| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451 |
- <template>
- <view class="content">
- <!-- 第一层表单 -->
- <view class="two_all">
- <view class="select-time" @click="openCalendar">
- <view class="select-time-one">
- <text class="select-list-time">{{startTime}}
- <text class="select-list">{{startWeek}}</text>
- </text>
- </view>
- <view class="select-center">
- <view class="select-line1"></view>
- <view class="select-circle">{{ruzhu_num}}晚</view>
- <view class="select-line2"></view>
- </view>
- <view class="select-time-one">
- <text class="select-list-time">{{endTime}}
- <text class="select-list">{{endWeek}}</text>
- </text>
- </view>
- </view>
- <!-- 房型信息 -->
- <view class="select_name">大床房</view>
- <view class="select_type">包吃住型</view>
- <view class="select_detail">
- 16-20㎡
- <text style="margin-left: 20px;">双人床</text>
- <text style="margin-left: 20px;">窗户位于走廊/窗户较小</text>
- </view>
- <uni-popup ref="popup_picker" :mask-click="true">
- <view class=popup_bg_picker>
- <uni-calendar :selected="info.selected" class="uni-calendar--hook" :clear-date="true" :date="info.date" :insert="info.insert" :lunar="info.lunar" :startDate="info.startDate"
- :endDate="info.endDate" :range="info.range" @change="change"/>
- </view>
- </uni-popup>
- </view>
- <!-- 第二层基本信息 -->
- <view class="second_basic">
- <view class="form_title">入住信息</view>
- <view class="form-line1"></view>
- <view class="form-num">房间数量:
- <text class="list-text">1间</text></view>
- <view class="form-line2"></view>
- <view class="form-name">住客姓名:
- <text class="list-text">{{cardName}}</text></view>
- <view class="form-line"></view>
- <view class="form-phone">联系电话:
- <text class="list-text">{{cardPhone}}</text></view>
- <view class="form-line" style="margin-top: 381rpx;"></view>
- <view class="uni-list-cell-db">预计到店:
- <picker style="margin-left: 70px;margin-top: -22px;"
- @change="bindPickerChange" :value="index" :range="array">
- <view class="uni-input" style="color: rgba(0, 0, 0, 1);">{{array[index]}}</view>
- <text class="jiantou">〉</text>
- </picker>
- </view>
- </view>
- <!-- 第三层表单 -->
- <view class="third_basic">
- <view class="third_title">费用明细</view>
- <view class="third-line1"></view>
- <view class="third-num">在线支付:
- <text class="third-text">1间1晚</text>
- <text style="margin-left: 10rpx;">共
- <text class="third-text2">¥280.00</text>
- </text>
- </view>
- </view>
- <!-- 第四层房费 -->
- <view class="four_basic">
- <view class="four_title">房费
- <text style="margin-left: 533rpx;">¥280</text>
- </view>
- <view class="four-line1"></view>
- <view class="four-num">2023-08-01</view>
- <view class="four-num2">2023-08-02</view>
- <view class="four-all">1 x ¥280</view>
- </view>
- <!-- 支付框 -->
- <view class="fukuan">
- <view class="fu-price">¥{{payMount}}</view>
- <view class="fu-zhifu" :class="{'room-button2': freeRoom == 0}">
- <text v-if="freeRoom==0">房间已满</text>
- <text v-else @click="getOrderSubmit('warn')">立即支付</text>
- </view>
- </view>
- <!-- 提交订单时弹框 -->
- <uni-popup ref="popup_order" type="dialog">
- <uni-popup-dialog :type="msgType" cancelText="关闭" confirmText="确定" :content="order_txt" @confirm="dialogConfirm"
- @close="dialogClose"></uni-popup-dialog>
- </uni-popup>
-
- </view>
- </template>
- <script>
- import {
- getsubmittoken,
- getorderconfirm,
- getuserinfo,
- getsubmit
- } from '../../utils/api_hotel.js'
- /**
- * 获取任意时间
- */
- function getDate(date, AddDayCount = 0) {
- if (!date) {
- date = new Date()
- }
- if (typeof date !== 'object') {
- date = date.replace(/-/g, '/')
- }
- const dd = new Date(date)
-
- dd.setDate(dd.getDate() + AddDayCount) // 获取AddDayCount天后的日期
-
- var a = new Array("日", "一", "二", "三", "四", "五", "六");
- var week = new Date().getDay();
- var week2 = new Date().getDay()+1;
- const y = dd.getFullYear()
- const m = dd.getMonth() + 1 < 10 ? '0' + (dd.getMonth() + 1) : dd.getMonth() + 1 // 获取当前月份的日期,不足10补0
- const d = dd.getDate() < 10 ? '0' + dd.getDate() : dd.getDate() // 获取当前几号,不足10补0
- const h = dd.getHours() < 10 ? '0' + dd.getHours() : dd.getHours()
- const f = dd.getMinutes() < 10 ? '0' + dd.getMinutes() : dd.getMinutes()
- const s = dd.getSeconds() < 10 ? '0' + dd.getSeconds() : dd.getSeconds()
- return {
- fullDate: y + '-' + m + '-' + d,
- fullDate2: y + '-' + m + '-' + d+' '+h+':'+f+':'+s,
- fullTime: m + '月' + d + '日',
- year: y,
- month: m,
- date: d,
- day: dd.getDay(),
- sWeek:"周"+ a[week],
- eWeek:"周"+ a[week2]
- }
- }
- export default {
- data() {
- return {
- showCalendar: false,
- info: {
- lunar: true,
- range: true,
- insert: true,
- selected: [],
- startDate:'',
- date:'',
- endDate:''
- },
- startTime:'',//到店日期
- endTime:'',//离店日期
- startDate:'',//默认到店日期接口数据
- endDate:'',//默认离店日期接口数据
- startWeek:'',// 默认入店日
- endWeek:'',// 默认离店
- array: ['18:00前到店', '19:00前到店', '20:00前到店', '21:00前到店'],
- index: 0,
- mayTime:'',// 预计到店时间
- typeName:'',//户型名
- textNum:0,//输入框当前字数
- cardName:'',//用户名
- cardPhone:'',//用户电话
- cardIdentity:'',//身份
- submitToken:'',//请求令牌
- roomTypeId:'',//房间类型id
- remark:'',//备注要求
- payMount:0,//应付金额
- freeRoom:0,//剩余房间
- ruzhu_num:1,//入住夜晚
- order_txt:'',//提交订单时信息
- msgType:'warn',
- }
- },
- onLoad(option) {
- console.log(option)
- // this.payMount=Number(option.payMount)
- // this.ruzhu_num=option.ruzhu_num
- // this.freeRoom=option.freeRoom
- localStorage.setItem('roomTypeId',option.roomTypeId)
- localStorage.setItem('typeName',option.typeName)
- localStorage.setItem('startTime',option.startTime)
- localStorage.setItem('endTime',option.endTime)
- localStorage.setItem('enableStartTime',option.enableStartTime)
- localStorage.setItem('enableEndTime',option.enableEndTime)
-
- },
- mounted() {
- this.roomTypeId=localStorage.getItem('roomTypeId')
- this.typeName=localStorage.getItem('typeName')
- this.startTime=localStorage.getItem('startTime')
- this.endTime=localStorage.getItem('endTime')
- this.startDate=localStorage.getItem('enableStartTime').substring(0,11)+"12:00:00"
- this.endDate=localStorage.getItem('enableEndTime').substring(0,11)+"14:00:00"
- this.startWeek=this.getweekday(this.startDate)
- this.endWeek=this.getweekday(this.endDate)
- this.mayTime=this.startDate.substring(0,11)+"18:00:00"
- // console.log(this.getweekday(this.startDate))
- this.getTokenSubmit()
- // window.location.href ='https://open.weixin.qq.com/connect/oauth2/authorize?appid=wxa46ef222053a1047&redirect_uri=https://chtech.ncjti.edu.cn/hotel/ihotel-api/ihotel/hotelUser/weixinAuth&response_type=code&scope=snsapi_base&state=pages/order_room/order_room#wechat_redirect';
- this.getUserInfo()
- this.getOrderConfirm('warn')
- },
- onReady() {
- this.$nextTick(() => {
- this.showCalendar = true
- })
- // TODO 模拟请求异步同步数据
- setTimeout(() => {
- this.info.date = getDate(new Date()).fullDate
- this.info.startDate = getDate(new Date()).fullDate
- this.info.endDate = getDate(new Date(),6).fullDate
- this.startTime = getDate(new Date()).fullTime
- this.endTime = getDate(new Date(),1).fullTime
- this.startWeek = getDate(new Date()).sWeek
- this.endWeek = getDate(new Date(),1).eWeek
- this.ruzhu_num=1
- }, 20)
- },
- methods: {
- // 获取请求令牌
- getTokenSubmit() {
- let _self = this
- getsubmittoken().then((res) => {
- if (res.success) {
- this.submitToken=res.data.submitToken
- return;
- } else {
- console.log('获取请求令牌失败')
- }
- }).catch((err) => {
- this.$message.error(err.message)
- });
- // this.$axios.get("/hotel/ihotel-api/ihotel/hotelOrder/user/submit/token",
- // {
- // headers:{
- // 'user_token':localStorage.getItem('token')
- // }
- // }).then(res => {
- // res = res.data
- // if (res.success) {
- // this.submitToken=res.data.submitToken
- // } else {
- // console.log('获取请求令牌失败')
- // }
- // });
- },
- // 获取用户信息
- getUserInfo() {
- let _self = this
- getuserinfo().then((res) => {
- if (res.success) {
- if (res.data.statu == '1') {
- _self.cardName=res.data.name
- _self.cardPhone=res.data.telPhone
- _self.cardIdentity=res.data.identityType
- }else {
- alert('您没有权限,请联系客服')
- }
- return;
- } else {
- console.log('获取用户信息失败')
- }
- }).catch((err) => {
- this.$message.error(err.message)
- });
- // this.$axios.get("/hotel/ihotel-api/ihotel/hotelUser/userInfo",
- // {
- // headers:{
- // 'user_token':localStorage.getItem('token')
- // }
- // }).then(res => {
- // res = res.data
- // if (res.success) {
- // if (res.data.statu == '1') {
- // _self.cardName=res.data.name
- // _self.cardPhone=res.data.telPhone
- // _self.cardIdentity=res.data.identityType
- // }else {
- // alert('您没有权限,请联系客服')
- // }
- // } else {
- // console.log('获取用户信息失败')
- // }
- // });
- },
- // 确认订单
- getOrderConfirm(type) {
- let _self = this
- var data="?startTime="+this.startDate.substring(0,10)+
- "&endTime="+this.endDate.substring(0,10)+
- '&roomTypeId='+this.roomTypeId
- getorderconfirm(data).then((res) => {
- if (res.success) {
- this.payMount=res.data.totalAmount
- this.freeRoom=res.data.freeNum
- this.ruzhu_num=res.data.nums
- return;
- } else {
- this.msgType = type
- this.order_txt=res.message
- this.$refs.popup_order.open()
- }
- }).catch((err) => {
- this.$message.error(err.message)
- });
- // this.$axios.get("/hotel/ihotel-api/ihotel/hotelOrder/user/order/confirm?startTime="+this.startDate.substring(0,10)+"&endTime="+this.endDate.substring(0,10)+'&roomTypeId='+this.roomTypeId).then(res => {
- // res = res.data
- // if (res.success) {
- // this.payMount=res.data.totalAmount
- // this.freeRoom=res.data.freeNum
- // this.ruzhu_num=res.data.nums
- // } else {
- // this.msgType = type
- // this.order_txt=res.message
- // this.$refs.popup_order.open()
- // }
- // });
- },
- // 提交订单
- getOrderSubmit(type) {
- uni.navigateTo({
- url:'/pages/submit_order/submit_order'
- })
- this.payUrl=''
- let _self = this
- this.$axios.defaults.headers.common['user_token'] = localStorage.getItem('token');
- this.$axios.defaults.headers.common['request_token'] = this.submitToken;
- this.$axios.defaults.headers.common['Content-Type'] ='application/json'
- var data={
- "enableStartTime":this.startDate,//入住时间
- "enableEndTime":this.endDate,//离店时间
- "roomTypeId":this.roomTypeId,//房间类型id
- "payAmount":this.payMount,//需支付金额
- "userName":this.cardName,
- "userPhone":this.cardPhone,
- "mayIntoTime":this.mayTime,
- "remark":this.remark,
- }
- getsubmit(data).then((res) => {
- if (res.success) {
- uni.navigateTo({
- url:'/pages/submit_order/submit_order'
- })
- // if(res.data.payAmount==0) {
- // uni.navigateTo({
- // url:'../zhifuchenggong/zhifuchenggong?orderId='+res.data.orderId
- // })
- // } else {
- // window.location.href = res.data.payUrl;
- // }
- // return;
- } else {
- this.msgType = type
- this.order_txt=res.message
- this.$refs.popup_order.open()
- }
- }).catch((err) => {
- this.$message.error(err.message)
- });
- // this.$axios.post("/hotel/ihotel-api/ihotel/hotelOrder/user/order/submit",
- // {
- // "enableStartTime":this.startDate,//入住时间
- // "enableEndTime":this.endDate,//离店时间
- // "roomTypeId":this.roomTypeId,//房间类型id
- // "payAmount":this.payMount,//需支付金额
- // "userName":this.cardName,
- // "userPhone":this.cardPhone,
- // "mayIntoTime":this.mayTime,
- // "remark":this.remark,
- // }
- // ).then(res => {
- // res = res.data
- // if (res.success) {
- // if(res.data.payAmount==0) {
- // uni.navigateTo({
- // url:'../zhifuchenggong/zhifuchenggong?orderId='+res.data.orderId
- // })
- // } else {
- // window.location.href = res.data.payUrl;
- // }
-
- // } else {
- // this.msgType = type
- // this.order_txt=res.message
- // this.$refs.popup_order.open()
- // }
- // });
- },
- // 计算指定时间是周几
- getweekday(date){
- // date例如:'2022-03-05'
- var weekArray = new Array("周日","周一", "周二", "周三", "周四", "周五", "周六")
- var weeka = weekArray[new Date(date).getDay()]
- return weeka
- },
- //日历选择器
- openCalendar() {
- this.$refs.popup_picker.open()
- },
- change(e) {
- console.log('1change 返回:', e)
- // 模拟动态打卡
- // if (this.info.selected.length > 5) return
- this.info.selected=[
- {
- date: e.range.before,
- info: '到店'
- },
- {
- date: e.range.after,
- info: '离店'
- }
- ]
- if(e.range.before!=''&&e.range.after=='') {
- this.startWeek='周'+e.lunar.ncWeek.substring(2,3)
- } else if(e.range.before!=''&&e.range.after!=''){
- if((new Date(e.range.after).getTime())<(new Date(e.range.before).getTime())) {
- this.order_txt='离店日期不能小于到店日期'
- this.$refs.popup_order.open()
- }else{
- this.endWeek='周'+e.lunar.ncWeek.substring(2,3)
- this.startTime=e.range.before.substring(5,7)+'月'+e.range.before.substring(8,10)+'日'
- this.endTime=e.range.after.substring(5,7)+'月'+e.range.after.substring(8,10)+'日'
- this.startDate = e.range.before +' 14:00:00'
- this.endDate = e.range.after +' 12:00:00'
- this.ruzhu_num=parseInt(((new Date(e.range.after).getTime())-(new Date(e.range.before).getTime()))/1000/60/60/24)
- }
- }
- },
- //选择器
- bindPickerChange: function(e) {
- console.log('picker发送选择改变,携带值为', e.detail.value)
- this.index = e.detail.value
- this.mayTime = this.startDate.substring(0,11)+this.array[this.index].substring(0,5)+":00"
- // console.log(this.mayTime)
- },
- // 输入框
- bindTextAreaBlur: function (e) {
- // console.log(e.detail.cursor)
- // console.log(e.detail.value)
- this.textNum=e.detail.cursor
- this.remark=e.detail.value
- }
- }
- }
- </script>
- <style>
- @import url("./css/order_room.css");
- </style>
|