order_room.vue 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329
  1. <template>
  2. <view class="content">
  3. <!-- 背景图 -->
  4. <view class="index_bg">
  5. <view class="welcome">
  6. <image class="welcome_img" src="../../static/index/welcome.png"></image>
  7. </view>
  8. </view>
  9. <!-- 第一层标题 -->
  10. <view class="touming_bg">
  11. <view class="touming_title">墨轩湖姬子公寓(南昌交通学院)</view>
  12. <view class="touming_txt">尊敬的老师,您辛苦了,欢迎入住!</view>
  13. </view>
  14. <!-- 第二层表单 -->
  15. <view class="two_all">
  16. <view class="select-time" @click="openCalendar">
  17. <view class="select-time-one">
  18. <text class="select-list">{{startWeek}}入住</text>
  19. <text class="select-list-time">{{startTime}}</text>
  20. </view>
  21. <view class="select-center">
  22. <view class="select-line1"></view>
  23. <view class="select-circle">{{ruzhu_num}}晚</view>
  24. <view class="select-line2"></view>
  25. </view>
  26. <view class="select-time-one">
  27. <text class="select-list">{{endWeek}}离店</text>
  28. <text class="select-list-time">{{endTime}}</text>
  29. </view>
  30. </view>
  31. <uni-popup ref="popup_picker" :mask-click="true">
  32. <view class=popup_bg_picker>
  33. <uni-calendar :selected="info.selected" class="uni-calendar--hook" :clear-date="true" :date="info.date" :insert="info.insert"
  34. :lunar="info.lunar" :startDate="info.startDate" :endDate="info.endDate" :range="info.range" @change="change" />
  35. </view>
  36. </uni-popup>
  37. <view class="form_bg">
  38. <view class="form_title">{{typeName}}</view>
  39. <!-- 自定义表单 -->
  40. <view class="form-name">{{cardName}}</view>
  41. <view class="form-line"></view>
  42. <view class="form-phone">{{cardPhone}}</view>
  43. <view class="form-line" style="margin-top: 389rpx;"></view>
  44. </view>
  45. </view>
  46. <!-- 注释 -->
  47. <view class="zhushi">
  48. <text class="zhushi-mark"><text class="zhushi-circle"></text>低价保证</text>
  49. <text class="zhushi-mark"><text class="zhushi-circle"></text>入住免房费</text>
  50. <text class="zhushi-mark"><text class="zhushi-circle"></text>提前选好房</text>
  51. </view>
  52. <!-- 支付框 -->
  53. <view class="fukuan">
  54. <view class="fu-price"><text style="font-size: 28rpx;">总计:</text>¥{{payMount}}</view>
  55. <view class="fu-zhifu" :class="{'room-button2': freeRoom == 0}">
  56. <text v-if="freeRoom==0">房间已满</text>
  57. <text v-else @click="getOrderSubmit('warn')">立即支付</text>
  58. </view>
  59. </view>
  60. <!-- 提交订单时弹框 -->
  61. <uni-popup ref="popup_order" type="dialog">
  62. <uni-popup-dialog :type="msgType" cancelText="关闭" confirmText="确定" :content="order_txt" @confirm="dialogConfirm"
  63. @close="dialogClose"></uni-popup-dialog>
  64. </uni-popup>
  65. </view>
  66. </template>
  67. <script>
  68. /**
  69. * 获取任意时间
  70. */
  71. function getDate(date, AddDayCount = 0) {
  72. if (!date) {
  73. date = new Date()
  74. }
  75. if (typeof date !== 'object') {
  76. date = date.replace(/-/g, '/')
  77. }
  78. const dd = new Date(date)
  79. dd.setDate(dd.getDate() + AddDayCount) // 获取AddDayCount天后的日期
  80. var a = new Array("日", "一", "二", "三", "四", "五", "六");
  81. var week = new Date().getDay();
  82. var week2 = new Date().getDay() + 1;
  83. const y = dd.getFullYear()
  84. const m = dd.getMonth() + 1 < 10 ? '0' + (dd.getMonth() + 1) : dd.getMonth() + 1 // 获取当前月份的日期,不足10补0
  85. const d = dd.getDate() < 10 ? '0' + dd.getDate() : dd.getDate() // 获取当前几号,不足10补0
  86. const h = dd.getHours() < 10 ? '0' + dd.getHours() : dd.getHours()
  87. const f = dd.getMinutes() < 10 ? '0' + dd.getMinutes() : dd.getMinutes()
  88. const s = dd.getSeconds() < 10 ? '0' + dd.getSeconds() : dd.getSeconds()
  89. return {
  90. fullDate: y + '-' + m + '-' + d,
  91. fullDate2: y + '-' + m + '-' + d + ' ' + h + ':' + f + ':' + s,
  92. fullTime: m + '月' + d + '日',
  93. year: y,
  94. month: m,
  95. date: d,
  96. day: dd.getDay(),
  97. sWeek: "周" + a[week],
  98. eWeek: "周" + a[week2]
  99. }
  100. }
  101. export default {
  102. data() {
  103. return {
  104. showCalendar: false,
  105. info: {
  106. lunar: true,
  107. range: true,
  108. insert: true,
  109. selected: [],
  110. startDate: '',
  111. date: '',
  112. endDate: ''
  113. },
  114. startTime: '', //到店日期
  115. endTime: '', //离店日期
  116. startDate: '', //默认到店日期接口数据
  117. endDate: '', //默认离店日期接口数据
  118. startWeek: '', // 默认入店日
  119. endWeek: '', // 默认离店
  120. array: ['18:00前到店', '19:00前到店', '20:00前到店', '21:00前到店'],
  121. index: 0,
  122. mayTime: '', // 预计到店时间
  123. typeName: '', //户型名
  124. textNum: 0, //输入框当前字数
  125. cardName: '', //用户名
  126. cardPhone: '', //用户电话
  127. cardIdentity: '', //身份
  128. submitToken: '', //请求令牌
  129. roomTypeId: '', //房间类型id
  130. remark: '', //备注要求
  131. payMount: 0, //应付金额
  132. freeRoom: 0, //剩余房间
  133. ruzhu_num: 1, //入住夜晚
  134. order_txt: '', //提交订单时信息
  135. msgType: 'warn',
  136. }
  137. },
  138. onLoad(option) {
  139. console.log(option)
  140. // this.payMount=Number(option.payMount)
  141. // this.ruzhu_num=option.ruzhu_num
  142. // this.freeRoom=option.freeRoom
  143. this.roomTypeId = option.roomTypeId
  144. this.typeName = option.typeName
  145. this.startTime = option.startTime
  146. this.endTime = option.endTime
  147. this.startDate = option.enableStartTime.substring(0, 11) + "12:00:00"
  148. this.endDate = option.enableEndTime.substring(0, 11) + "14:00:00"
  149. this.startWeek = this.getweekday(this.startDate)
  150. this.endWeek = this.getweekday(this.endDate)
  151. this.mayTime = this.startDate.substring(0, 11) + "18:00:00"
  152. // console.log(this.getweekday(this.startDate))
  153. this.getTokenSubmit()
  154. },
  155. mounted() {
  156. this.getUserInfo()
  157. this.getOrderConfirm('warn')
  158. },
  159. onReady() {
  160. this.$nextTick(() => {
  161. this.showCalendar = true
  162. })
  163. // TODO 模拟请求异步同步数据
  164. setTimeout(() => {
  165. this.info.date = getDate(new Date()).fullDate
  166. this.info.startDate = getDate(new Date()).fullDate
  167. this.info.endDate = getDate(new Date(), 6).fullDate
  168. this.startTime = getDate(new Date()).fullTime
  169. this.endTime = getDate(new Date(), 1).fullTime
  170. this.startWeek = getDate(new Date()).sWeek
  171. this.endWeek = getDate(new Date(), 1).eWeek
  172. this.ruzhu_num = 1
  173. }, 20)
  174. },
  175. methods: {
  176. // 获取请求令牌
  177. getTokenSubmit() {
  178. let _self = this
  179. this.$axios.get("/hotel/ihotel-api/ihotel/hotelOrder/user/submit/token", {
  180. headers: {
  181. 'user_token': localStorage.getItem('token')
  182. }
  183. }).then(res => {
  184. res = res.data
  185. if (res.success) {
  186. this.submitToken = res.data.submitToken
  187. } else {
  188. console.log('获取请求令牌失败')
  189. }
  190. });
  191. },
  192. // 获取用户信息
  193. getUserInfo() {
  194. let _self = this
  195. this.$axios.get("/hotel/ihotel-api/ihotel/hotelUser/userInfo", {
  196. headers: {
  197. 'user_token': localStorage.getItem('token')
  198. }
  199. }).then(res => {
  200. res = res.data
  201. if (res.success) {
  202. if (res.data.statu == '1') {
  203. _self.cardName = res.data.name
  204. _self.cardPhone = res.data.telPhone
  205. _self.cardIdentity = res.data.identityType
  206. } else {
  207. alert('您没有权限,请联系客服')
  208. }
  209. } else {
  210. console.log('获取用户信息失败')
  211. }
  212. });
  213. },
  214. // 确认订单
  215. getOrderConfirm(type) {
  216. let _self = this
  217. this.$axios.get("/hotel/ihotel-api/ihotel/hotelOrder/user/order/confirm?startTime=" + this.startDate.substring(0, 10) + "&endTime=" + this.endDate
  218. .substring(0, 10) + '&roomTypeId=' + this.roomTypeId).then(res => {
  219. res = res.data
  220. if (res.success) {
  221. this.payMount = res.data.totalAmount
  222. this.freeRoom = res.data.freeNum
  223. this.ruzhu_num = res.data.nums
  224. } else {
  225. this.msgType = type
  226. this.order_txt = res.message
  227. this.$refs.popup_order.open()
  228. }
  229. });
  230. },
  231. // 提交订单
  232. getOrderSubmit(type) {
  233. this.payUrl = ''
  234. let _self = this
  235. this.$axios.defaults.headers.common['user_token'] = localStorage.getItem('token');
  236. this.$axios.defaults.headers.common['request_token'] = this.submitToken;
  237. this.$axios.defaults.headers.common['Content-Type'] = 'application/json'
  238. this.$axios.post("/hotel/ihotel-api/ihotel/hotelOrder/user/order/submit", {
  239. "enableStartTime": this.startDate, //入住时间
  240. "enableEndTime": this.endDate, //离店时间
  241. "roomTypeId": this.roomTypeId, //房间类型id
  242. "payAmount": this.payMount, //需支付金额
  243. "userName": this.cardName,
  244. "userPhone": this.cardPhone,
  245. "mayIntoTime": this.mayTime,
  246. "remark": this.remark,
  247. }).then(res => {
  248. res = res.data
  249. if (res.success) {
  250. if (res.data.payAmount == 0) {
  251. uni.navigateTo({
  252. url: '../zhifuchenggong/zhifuchenggong?orderId=' + res.data.orderId
  253. })
  254. } else {
  255. window.location.href = res.data.payUrl;
  256. }
  257. } else {
  258. this.msgType = type
  259. this.order_txt = res.message
  260. this.$refs.popup_order.open()
  261. }
  262. });
  263. },
  264. // 计算指定时间是周几
  265. getweekday(date) {
  266. // date例如:'2022-03-05'
  267. var weekArray = new Array("周日", "周一", "周二", "周三", "周四", "周五", "周六")
  268. var weeka = weekArray[new Date(date).getDay()]
  269. return weeka
  270. },
  271. //日历选择器
  272. openCalendar() {
  273. this.$refs.popup_picker.open()
  274. },
  275. change(e) {
  276. console.log('1change 返回:', e)
  277. // 模拟动态打卡
  278. // if (this.info.selected.length > 5) return
  279. this.info.selected = [{
  280. date: e.range.before,
  281. info: '到店'
  282. },
  283. {
  284. date: e.range.after,
  285. info: '离店'
  286. }
  287. ]
  288. if (e.range.before != '' && e.range.after == '') {
  289. this.startWeek = '周' + e.lunar.ncWeek.substring(2, 3)
  290. } else if (e.range.before != '' && e.range.after != '') {
  291. if ((new Date(e.range.after).getTime()) < (new Date(e.range.before).getTime())) {
  292. this.order_txt = '离店日期不能小于到店日期'
  293. this.$refs.popup_order.open()
  294. } else {
  295. this.endWeek = '周' + e.lunar.ncWeek.substring(2, 3)
  296. this.startTime = e.range.before.substring(5, 7) + '月' + e.range.before.substring(8, 10) + '日'
  297. this.endTime = e.range.after.substring(5, 7) + '月' + e.range.after.substring(8, 10) + '日'
  298. this.startDate = e.range.before + ' 14:00:00'
  299. this.endDate = e.range.after + ' 12:00:00'
  300. this.ruzhu_num = parseInt(((new Date(e.range.after).getTime()) - (new Date(e.range.before).getTime())) / 1000 / 60 / 60 / 24)
  301. }
  302. }
  303. },
  304. //选择器
  305. bindPickerChange: function(e) {
  306. console.log('picker发送选择改变,携带值为', e.detail.value)
  307. this.index = e.detail.value
  308. this.mayTime = this.startDate.substring(0, 11) + this.array[this.index].substring(0, 5) + ":00"
  309. // console.log(this.mayTime)
  310. },
  311. // 输入框
  312. bindTextAreaBlur: function(e) {
  313. // console.log(e.detail.cursor)
  314. // console.log(e.detail.value)
  315. this.textNum = e.detail.cursor
  316. this.remark = e.detail.value
  317. }
  318. }
  319. }
  320. </script>
  321. <style>
  322. @import url("./css/order_room.css");
  323. </style>