order_room.vue 10 KB

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