order_room.vue 6.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215
  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">周四入住</text>
  17. <text class="select-list-time">07月21日</text>
  18. </view>
  19. <view class="select-center">
  20. <view class="select-line1"></view>
  21. <view class="select-circle">1晚</view>
  22. <view class="select-line2"></view>
  23. </view>
  24. <view class="select-time-one">
  25. <text class="select-list">周五离店</text>
  26. <text class="select-list-time">07月22日</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">01户型</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);">20.00</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> <text class="zhushi-mark">入住免房费</text> <text class="zhushi-mark">提前选好房</text>
  70. </view>
  71. <!-- 支付框 -->
  72. <view class="fukuan">
  73. <view class="fu-price"><text style="font-size: 28rpx;">总计:</text>¥20.00</view>
  74. <view class="fu-zhifu">立即支付</view>
  75. </view>
  76. </view>
  77. </template>
  78. <script>
  79. /**
  80. * 获取任意时间
  81. */
  82. function getDate(date, AddDayCount = 0) {
  83. if (!date) {
  84. date = new Date()
  85. }
  86. if (typeof date !== 'object') {
  87. date = date.replace(/-/g, '/')
  88. }
  89. const dd = new Date(date)
  90. dd.setDate(dd.getDate() + AddDayCount) // 获取AddDayCount天后的日期
  91. var a = new Array("日", "一", "二", "三", "四", "五", "六");
  92. var week = new Date().getDay();
  93. var week2 = new Date().getDay()+1;
  94. const y = dd.getFullYear()
  95. const m = dd.getMonth() + 1 < 10 ? '0' + (dd.getMonth() + 1) : dd.getMonth() + 1 // 获取当前月份的日期,不足10补0
  96. const d = dd.getDate() < 10 ? '0' + dd.getDate() : dd.getDate() // 获取当前几号,不足10补0
  97. const h = dd.getHours() < 10 ? '0' + dd.getHours() : dd.getHours()
  98. const f = dd.getMinutes() < 10 ? '0' + dd.getMinutes() : dd.getMinutes()
  99. const s = dd.getSeconds() < 10 ? '0' + dd.getSeconds() : dd.getSeconds()
  100. return {
  101. fullDate: y + '-' + m + '-' + d,
  102. fullDate2: y + '-' + m + '-' + d+' '+h+':'+f+':'+s,
  103. fullTime: m + '月' + d + '日',
  104. year: y,
  105. month: m,
  106. date: d,
  107. day: dd.getDay(),
  108. sWeek:"周"+ a[week],
  109. eWeek:"周"+ a[week2]
  110. }
  111. }
  112. export default {
  113. data() {
  114. return {
  115. showCalendar: false,
  116. info: {
  117. lunar: true,
  118. range: true,
  119. insert: true,
  120. selected: [],
  121. startDate:'',
  122. date:'',
  123. endDate:''
  124. },
  125. startTime:'',//到店日期
  126. endTime:'',//离店日期
  127. array: ['18:00前到店', '19:00前到店', '20:00前到店', '21:00前到店'],
  128. index: 0,
  129. textNum:0,//输入框当前字数
  130. cardName:'',//用户名
  131. cardPhone:'',//用户电话
  132. cardIdentity:'',//身份
  133. }
  134. },
  135. onLoad() {
  136. this.getUserInfo()
  137. },
  138. onReady() {
  139. this.$nextTick(() => {
  140. this.showCalendar = true
  141. })
  142. // TODO 模拟请求异步同步数据
  143. setTimeout(() => {
  144. // console.log('date:'+getDate(new Date()).fullDate)
  145. // console.log('startDate:'+getDate(new Date()).fullDate)
  146. // console.log('endDate:'+getDate(new Date(),6).fullDate)
  147. this.info.date = getDate(new Date()).fullDate
  148. this.info.startDate = getDate(new Date()).fullDate
  149. this.info.endDate = getDate(new Date(),6).fullDate
  150. }, 2000)
  151. },
  152. methods: {
  153. // 获取用户信息
  154. getUserInfo() {
  155. let _self = this
  156. this.$axios.get("/ihotel/hotelUser/userInfo",
  157. {
  158. headers:{
  159. 'user_token':localStorage.getItem('user_token')
  160. }
  161. }).then(res => {
  162. res = res.data
  163. if (res.success) {
  164. if (res.data.statu == '1') {
  165. _self.cardName=res.data.name
  166. _self.cardPhone=res.data.cardNumber
  167. _self.cardIdentity=res.data.identityType
  168. }else {
  169. alert('您没有权限,请联系客服')
  170. }
  171. } else {
  172. console.log('获取用户信息失败')
  173. }
  174. });
  175. },
  176. //日历选择器
  177. openCalendar() {
  178. this.$refs.popup_picker.open()
  179. },
  180. change(e) {
  181. console.log('1change 返回:', e)
  182. // 模拟动态打卡
  183. if (this.info.selected.length > 5) return
  184. this.info.selected.push({
  185. date: e.range.before,
  186. info: '到店'
  187. })
  188. this.info.selected.push({
  189. date: e.range.after,
  190. info: '离店'
  191. })
  192. },
  193. //选择器
  194. bindPickerChange: function(e) {
  195. // console.log('picker发送选择改变,携带值为', e.detail.value)
  196. this.index = e.detail.value
  197. },
  198. // 输入框
  199. bindTextAreaBlur: function (e) {
  200. // console.log(e.detail.cursor)
  201. // console.log(e.detail.value)
  202. this.textNum=e.detail.cursor
  203. }
  204. }
  205. }
  206. </script>
  207. <style>
  208. @import url("./css/order_room.css");
  209. </style>