调试后台接口

修复选择日期时时间戳为当前时间的BUG,改为选择日期的00:00:00
完成首页认证、预约会议室页面、会议室详情页面、预约功能的调试
This commit is contained in:
471615499@qq.com 2024-09-25 22:10:57 +08:00
parent ee09115377
commit ba13f9c97f
13 changed files with 284 additions and 221 deletions

View File

@ -98,8 +98,14 @@ Page({
}, },
// 跳转会议预约页面 // 跳转会议预约页面
goRes(e) { goRes(e) {
let date = new Date(e.detail);
let year = date.getFullYear()
let month = date.getMonth() + 1
let day = date.getDate()
let chooseTime = year + '-' + month + '-' + day + ' 00:00:00'
let chooseTimeStr = new Date(chooseTime).getTime()
wx.navigateTo({ wx.navigateTo({
url: '/pages/meeting/meetingReservation/meetingReservation?time=' + e.detail + '&dep=' + this.data.depName + '&depId=' + this.data.depId, url: '/pages/meeting/meetingReservation/meetingReservation?time=' + chooseTimeStr + '&dep=' + this.data.depName + '&depId=' + this.data.depId,
}) })
}, },
// 跳转菜单 // 跳转菜单

View File

@ -307,16 +307,23 @@ Page({
meetingRoomList() { meetingRoomList() {
let _this = this; let _this = this;
let queryParam = _this.data.queryParam; let queryParam = _this.data.queryParam;
let roomItemList = queryParam.itemDict.list.filter(item => item.select).map(item => { let devicesArr = []
return { for (let key in queryParam.itemDict.list) {
"id": item.value, let eachObj = queryParam.itemDict.list[key]
"name": item.text if (eachObj.select) {
devicesArr.push(eachObj.value)
} }
}) }
// let roomItemList = queryParam.itemDict.list.filter(item => item.select).map(item => {
// return {
// "id": item.value,
// "name": item.text
// }
// })
let param = { let param = {
floor: queryParam.meetingTypeDict.value, // 楼层 floor: queryParam.meetingTypeDict.value, // 楼层
capacityNum: queryParam.personDict.value, // 人数 capacityNum: queryParam.personDict.value, // 人数
device: '', // 设备 devices: devicesArr, // 设备
typeName: queryParam.shapeDict.value, // 形状 typeName: queryParam.shapeDict.value, // 形状
timeFormat: queryParam.timeRangeDict.value, // 预约时间格式0 任意时间管理员1上午2下午3晚上 4 全天。值为0时读取startTime和endTime为预约会议时间范围其他值读取mrdate再拼接时间为预约会议时间范围。 timeFormat: queryParam.timeRangeDict.value, // 预约时间格式0 任意时间管理员1上午2下午3晚上 4 全天。值为0时读取startTime和endTime为预约会议时间范围其他值读取mrdate再拼接时间为预约会议时间范围。
mrdate: _this.data.dateStr mrdate: _this.data.dateStr
@ -350,7 +357,7 @@ Page({
timeRange = timeRange ? timeRange : 0 timeRange = timeRange ? timeRange : 0
// 跳转预约详情 // 跳转预约详情
wx.navigateTo({ wx.navigateTo({
url: "/pages/meeting/meetingRoom/meetingRoom?id=" + e.currentTarget.dataset.id + '&time=' + this.data.date + '&timeRange=' + timeRange + '&rId=' + this.data.rId + '&dep=' + this.data.dep + '&depId=' + this.data.depId url: "/pages/meeting/meetingRoom/meetingRoom?status="+ e.currentTarget.dataset.status +"&id=" + e.currentTarget.dataset.id + '&time=' + this.data.date + '&timeRange=' + timeRange + '&rId=' + this.data.rId + '&dep=' + this.data.dep + '&depId=' + this.data.depId
}) })
}, },

View File

@ -25,11 +25,21 @@
<view class="meetingRoomView"> <view class="meetingRoomView">
<view wx:for="{{roomDataList}}"> <view wx:for="{{roomDataList}}">
<view class="roomType">{{item.name}}</view> <view class="roomType">{{item.name}}</view>
<view class="meetingRoomItem" bind:tap="jumpMeetingRoom" wx:for="{{item.list}}" wx:for-item="room" wx:key="*this" data-id="{{room.id}}"> <view class="meetingRoomItem" bind:tap="jumpMeetingRoom" wx:for="{{item.list}}" wx:for-item="room" wx:key="*this" data-id="{{room.id}}" data-status="{{room.status}}">
<view class="content"> <view class="content" wx:if="{{room.status === 0}}">
<view class="title">{{room.roomNum}}</view> <view class="title">{{room.roomNum}}</view>
<view class="priceView"> <view class="priceView">
<view class="unit">{{room.capacityNum}}人 {{room.typeName}}</view> <view class="unit">
{{room.capacityNum}}人 {{room.typeName}}
</view>
</view>
</view>
<view class="content disabled" wx:if="{{room.status === 1}}">
<view class="title">{{room.roomNum}}</view>
<view class="priceView">
<view class="unit">
不可预约
</view>
</view> </view>
</view> </view>
<!-- <view class="imgView"> <!-- <view class="imgView">

View File

@ -113,13 +113,12 @@ Page({
startTime = parseInt(date) + (parseInt(startTimeArr[0]) * 60 * 60 + parseInt(startTimeArr[1]) * 60) * 1000 startTime = parseInt(date) + (parseInt(startTimeArr[0]) * 60 * 60 + parseInt(startTimeArr[1]) * 60) * 1000
let endTimeArr = endTime.split(':') let endTimeArr = endTime.split(':')
endTime = parseInt(date) + (parseInt(endTimeArr[0]) * 60 * 60 + parseInt(endTimeArr[1]) * 60) * 1000 endTime = parseInt(date) + (parseInt(endTimeArr[0]) * 60 * 60 + parseInt(endTimeArr[1]) * 60) * 1000
let paramUrl = "?meetingRoomId=" + meetingRoomId + "&startTime=" + selfFormatTimeYMDHMS(startTime) + "&endTime=" + selfFormatTimeYMDHMS(endTime) + '&rId=' + _this.data.rId + '&dep=' + _this.data.dep + '&depId=' + _this.data.depId; let paramUrl = "?meetingRoomId=" + meetingRoomId + "&startTime=" + selfFormatTimeYMDHMS(startTime) + "&endTime=" + selfFormatTimeYMDHMS(endTime) + '&timeRange=' + _this.data.timeRange + '&rId=' + _this.data.rId + '&dep=' + _this.data.dep + '&depId=' + _this.data.depId;
// 结束时间不能小于开始时间 // 结束时间不能小于开始时间
if (startTime >= endTime) { if (startTime >= endTime) {
Notify('结束时间不能小于开始时间!') Notify('结束时间不能小于开始时间!')
return return
} }
wx.navigateTo({ wx.navigateTo({
url: "/pages/meeting/meetingRoom/meetingOrder/meetingOrder" + paramUrl, url: "/pages/meeting/meetingRoom/meetingOrder/meetingOrder" + paramUrl,
}) })

View File

@ -33,6 +33,7 @@ Page({
IMG_NAME: app.IMG_NAME, IMG_NAME: app.IMG_NAME,
detail: {}, detail: {},
meetingRoomId: null, meetingRoomId: null,
timeRange: null,
startTime: null, startTime: null,
endTime: null, endTime: null,
selectDay: null, selectDay: null,
@ -108,7 +109,8 @@ Page({
_this.setData({ _this.setData({
meetingRoomId: _meetingRoomId, meetingRoomId: _meetingRoomId,
startTime: res.data.startTime, startTime: res.data.startTime,
endTime: res.data.endDate endTime: res.data.endDate,
timeRange: res.data.timeRange
}) })
let serviceId = [] let serviceId = []
for (let key in res.data.reservationServes) { for (let key in res.data.reservationServes) {
@ -147,9 +149,9 @@ Page({
}).then(res => { }).then(res => {
let detail = res.room let detail = res.room
let bannerList = [] let bannerList = []
if (detail.indoorPicUrl) { if (detail.imgs) {
try { try {
bannerList = JSON.parse(detail.indoorPicUrl).map(item => item.url) bannerList = detail.imgs.map(item => item.url)
} catch (error) { } catch (error) {
console.log(`JSON error : ${error}`); console.log(`JSON error : ${error}`);
} }
@ -177,7 +179,7 @@ Page({
}) })
}) })
}, },
getService() { getService(serveId) {
let _this = this; let _this = this;
meetingRoomDict().then(res => { meetingRoomDict().then(res => {
console.log('meetingRoomDict', res) console.log('meetingRoomDict', res)
@ -188,15 +190,19 @@ Page({
for (let key in dataObj.services) { for (let key in dataObj.services) {
let eachObj = dataObj.services[key] let eachObj = dataObj.services[key]
const keys = Object.keys(eachObj) const keys = Object.keys(eachObj)
let isSel = false
let sId = eachObj[keys[0]]
if (serveId.includes(sId)) {
isSel = true
}
serviceList.push({ serviceList.push({
serveId: eachObj[keys[0]], serveId: eachObj[keys[0]],
serveName: keys[0], serveName: keys[0],
isSelect: false, isSelect: isSel,
num: '', num: '',
type: 'free' type: 'free'
}) })
} }
console.log(serviceList)
// queryParam.shapeDict.list = typeList // queryParam.shapeDict.list = typeList
_this.setData({ _this.setData({
serviceList: serviceList serviceList: serviceList
@ -210,15 +216,16 @@ Page({
let _this = this let _this = this
let name = e.currentTarget.dataset.name let name = e.currentTarget.dataset.name
let value = e.detail let value = e.detail
let data = _this.data let _data = _this.data.detail
data['detail'][name] = value _data[name] = value
this.setData({ this.setData({
...data ..._data
}) })
}, },
// 跳转-空间设施 // 跳转-空间设施
jumpMeetingFacilities() { jumpMeetingFacilities() {
console.log(this.data.serviceList)
let meetingRoomId = this.data.meetingRoomId; let meetingRoomId = this.data.meetingRoomId;
let serviceListJsonStr = JSON.stringify(this.data.serviceList) let serviceListJsonStr = JSON.stringify(this.data.serviceList)
wx.navigateTo({ wx.navigateTo({
@ -273,10 +280,8 @@ Page({
// 处理一下serviceList // 处理一下serviceList
let service = [] let service = []
let serviceList = _this.data.serviceList let serviceList = _this.data.serviceList
// console.log(serviceList)
for (let key in serviceList) { for (let key in serviceList) {
let eachObj = serviceList[key] let eachObj = serviceList[key]
console.log(eachObj)
if (eachObj.isSelect === true) { if (eachObj.isSelect === true) {
service.push({ service.push({
name: eachObj['serveName'], name: eachObj['serveName'],
@ -285,15 +290,13 @@ Page({
}) })
} }
} }
// console.log(service) let data = {
// return "mr": {
saveChangyangMeetingRecordRq({
mr: {
"roomId": _this.data.meetingRoomId, "roomId": _this.data.meetingRoomId,
"start": _this.data.startTime, "start": _this.data.startTime,
"end": _this.data.endTime, "end": _this.data.endTime,
"mrdate": "2024-09-27", "mrdate": _this.data.selectDay,
"timeFormat": "0", "timeFormat": _this.data.timeRange,
"title": _this.data.detail.title, "title": _this.data.detail.title,
"personNum": _this.data.detail.personNum, "personNum": _this.data.detail.personNum,
"leader": _this.data.detail.leader, "leader": _this.data.detail.leader,
@ -303,12 +306,14 @@ Page({
"bookingUserPhone": _this.data.detail.orderTel, "bookingUserPhone": _this.data.detail.orderTel,
"remark": _this.data.detail.remark, "remark": _this.data.detail.remark,
}, },
serve: service "serve": service
}).then(res => { }
console.log('saveData', data)
saveChangyangMeetingRecordRq(data).then(res => {
console.log('saveMeetingRecordRq', res); console.log('saveMeetingRecordRq', res);
if (res.code == 0) { if (res.code == 0) {
wx.reLaunch({ wx.reLaunch({
url: '/pages/meeting/pay/waitComplete/waitComplete?id=' + res.reservationId, url: '/pages/meeting/pay/waitComplete/waitComplete',
}) })
} else { } else {
// 错误提示 // 错误提示

View File

@ -14,8 +14,7 @@
<view class="detailView"> <view class="detailView">
<view class="title">{{room.floor}} | {{room.roomNum}} | {{room.capacityNum}}人 | {{room.typeName}}</view> <view class="title">{{room.floor}} | {{room.roomNum}} | {{room.capacityNum}}人 | {{room.typeName}}</view>
<view class="itemList"> <view class="itemList">
<view class="item" wx:for="{{room.roomItemList}}" wx:for-item="serviceItem" wx:key="*this">#{{serviceItem.name}}</view> {{room.device}}
<view class="item" wx:for="{{room.roomServeList}}" wx:for-item="serveItem" wx:key="*this">#{{serveItem.serveName}}</view>
</view> </view>
</view> </view>
<!-- <view class="priceView"> <!-- <view class="priceView">

View File

@ -34,12 +34,14 @@ Page({
console.log('onLoad', options); console.log('onLoad', options);
let time = options.time let time = options.time
let timeRange = options.timeRange let timeRange = options.timeRange
let status = options.status
_this.setData({ _this.setData({
date: time, date: time,
timeRange: timeRange, timeRange: timeRange,
rId: options.rId, rId: options.rId,
dep: options.dep, dep: options.dep,
depId: options.depId depId: options.depId,
canRes: status === "1" ? false : true
}) })
let meetingRoomId = options.id; let meetingRoomId = options.id;
meetingRoomDetailRq({ meetingRoomDetailRq({
@ -47,15 +49,32 @@ Page({
}).then(res => { }).then(res => {
console.log('meetingRoomDetailRq', res); console.log('meetingRoomDetailRq', res);
let detail = res.room let detail = res.room
let recordList = res.mr
let bannerList = [] let bannerList = []
if (detail.indoorPicUrl) { if (detail.imgs) {
try { try {
bannerList = JSON.parse(detail.indoorPicUrl).map(item => item.url) bannerList = detail.imgs.map(item => item.url)
} catch (error) { } catch (error) {
console.log(`JSON error : ${error}`); console.log(`JSON error : ${error}`);
} }
} }
let _recordList = []
for (let key in recordList) {
let eachObj = recordList[key]
let sTime = eachObj['start']
let sTimeStr = new Date(sTime).getTime()
let sTimeData = new Date(sTimeStr)
let eTime = eachObj['end']
let eTimeStr = new Date(eTime).getTime()
let eTimeData = new Date(eTimeStr)
let sTimeFormat = sTimeData.getHours().toString().padStart(2, '0') + ':' + sTimeData.getMinutes().toString().padStart(2, '0')
let eTimeFormat = eTimeData.getHours().toString().padStart(2, '0') + ':' + eTimeData.getMinutes().toString().padStart(2, '0')
eachObj['time'] = sTimeFormat + ' - ' + eTimeFormat
_recordList.push(eachObj)
}
_this.setData({ _this.setData({
recordList: _recordList,
meetingRoomId, meetingRoomId,
detail, detail,
bannerList bannerList

View File

@ -28,7 +28,7 @@
<view class="resView"> <view class="resView">
<view class="leftLineTitle">预约情况</view> <view class="leftLineTitle">预约情况</view>
<van-cell-group> <van-cell-group>
<van-cell wx:for="{{recordList}}" title="{{item.date}}" value="{{item.time}}" label="{{item.dep}} | {{item.user}} | {{item.tel}}" /> <van-cell wx:for="{{recordList}}" title="{{item.date}}" value="{{item.time}}" label="{{item.userOrg}} | {{item.bookingUserName}} | {{item.bookingUserPhone}}" />
</van-cell-group> </van-cell-group>
</view> </view>
@ -60,5 +60,5 @@
</view> --> </view> -->
<!-- 预约 --> <!-- 预约 -->
<view wx:if="canRes" class="submitBtn" bind:tap="jumpMeetingBooked">会议预约</view> <view wx:if="{{canRes}}" class="submitBtn" bind:tap="jumpMeetingBooked">会议预约</view>
</view> </view>

View File

@ -33,11 +33,12 @@ Page({
serviceList serviceList
}) })
// 获取数据 // 获取数据
_this.getData(); // _this.getData();
}, },
// 获取数据 // 获取数据,不需要
getData() { getData() {
return
let _this = this; let _this = this;
if (!(_this.data.serviceList && _this.data.serviceList.length > 0)) { if (!(_this.data.serviceList && _this.data.serviceList.length > 0)) {
// 查询服务列表 // 查询服务列表

View File

@ -19,7 +19,6 @@ Page({
// 跳转-会议预约记录 // 跳转-会议预约记录
jumpMeetingRecord() { jumpMeetingRecord() {
let _id = this.data.id
wx.reLaunch({ wx.reLaunch({
url: "/pages/meeting/reservationRecord/meetingRecord/meetingRecord", url: "/pages/meeting/reservationRecord/meetingRecord/meetingRecord",
}) })

View File

@ -448,9 +448,15 @@ Page({
// 跳转会议预约页面 // 跳转会议预约页面
goRes(e) { goRes(e) {
let _this = this let _this = this
let date = new Date(e.detail);
let year = date.getFullYear()
let month = date.getMonth() + 1
let day = date.getDate()
let chooseTime = year + '-' + month + '-' + day + ' 00:00:00'
let chooseTimeStr = new Date(chooseTime).getTime()
// 加入rId参数为预约id用于重新修改 // 加入rId参数为预约id用于重新修改
wx.navigateTo({ wx.navigateTo({
url: '/pages/meeting/meetingReservation/meetingReservation?rId=' + _this.data.editId + '&time=' + e.detail, url: '/pages/meeting/meetingReservation/meetingReservation?rId=' + _this.data.editId + '&time=' + chooseTimeStr,
}) })
}, },
pass() { pass() {

View File

@ -382,9 +382,15 @@ Page({
// 跳转会议预约页面 // 跳转会议预约页面
goRes(e) { goRes(e) {
let _this = this let _this = this
let date = new Date(e.detail);
let year = date.getFullYear()
let month = date.getMonth() + 1
let day = date.getDate()
let chooseTime = year + '-' + month + '-' + day + ' 00:00:00'
let chooseTimeStr = new Date(chooseTime).getTime()
// 加入rId参数为预约id用于重新修改 // 加入rId参数为预约id用于重新修改
wx.navigateTo({ wx.navigateTo({
url: '/pages/meeting/meetingReservation/meetingReservation?rId=' + _this.data.detail.id + '&time=' + e.detail, url: '/pages/meeting/meetingReservation/meetingReservation?rId=' + _this.data.detail.id + '&time=' + chooseTimeStr,
}) })
}, },

View File

@ -497,9 +497,15 @@ Page({
// 跳转会议预约页面 // 跳转会议预约页面
goRes(e) { goRes(e) {
let _this = this let _this = this
let date = new Date(e.detail);
let year = date.getFullYear()
let month = date.getMonth() + 1
let day = date.getDate()
let chooseTime = year + '-' + month + '-' + day + ' 00:00:00'
let chooseTimeStr = new Date(chooseTime).getTime()
// 加入rId参数为预约id用于重新修改 // 加入rId参数为预约id用于重新修改
wx.navigateTo({ wx.navigateTo({
url: '/pages/meeting/meetingReservation/meetingReservation?rId=' + _this.data.editId + '&time=' + e.detail, url: '/pages/meeting/meetingReservation/meetingReservation?rId=' + _this.data.editId + '&time=' + chooseTimeStr,
}) })
}, },
/** /**