tearoom/page_shanghu/bangding.vue
2025-01-08 15:23:53 +08:00

600 lines
16 KiB
Vue
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

<template>
<view class="page">
<u-navbar title="设备绑定" :border-bottom="false" :background="bgc" back-icon-color="#262B37"
title-color='#262B37' title-size='36' height='50' id="navbar">
</u-navbar>
<view class="box">
<view class="tongji">
<view class="one" @click="btngundong('section1',0)">
<view class="gn">店门</view>
<image v-if="tabindex == 0" src="https://api.ccttiot.com/smartmeter/img/static/uZNimi3DEsGWsjfJm2Bg" mode=""></image>
</view>
<view class="xian"></view>
<view class="one" @click="btngundong('section2',1)">
<view class="gn">房间</view>
<image v-if="tabindex == 1" src="https://api.ccttiot.com/smartmeter/img/static/uZNimi3DEsGWsjfJm2Bg" mode=""></image>
</view>
<view class="xian"></view>
<view class="one" @click="btngundong('section3',2)">
<view class="gn">大厅</view>
<image v-if="tabindex == 2" src="https://api.ccttiot.com/smartmeter/img/static/uZNimi3DEsGWsjfJm2Bg" mode=""></image>
</view>
<view class="xian"></view>
<view class="one" @click="btngundong('section4',3)">
<view class="gn">卫生间</view>
<image v-if="tabindex == 3" src="https://api.ccttiot.com/smartmeter/img/static/uZNimi3DEsGWsjfJm2Bg" mode=""></image>
</view>
</view>
<!-- 店门 --><!-- 店门 --><!-- 店门 --><!-- 店门 --><!-- 店门 --><!-- 店门 --><!-- 店门 --><!-- 店门 --><!-- 店门 --><!-- 店门 --><!-- 店门 --><!-- 店门 -->
<view class="damen" id="section1" style="margin-top: 10vh;">
<view class="name">
店门
</view>
<view class="menbj" :id="gateSnobj.device.sn == null ? 'active' : ''" @click="btnmendian">
<view class="top">
<view class="lt">
<text style="font-weight: 600;font-size: 32rpx;">店门</text>
</view>
<view class="rt" :id="gateSnobj.device.sn == null ? 'active' : ''">
<text :id="gateSnobj.device.sn == null ? 'active' : ''"></text> {{gateSnobj.device.sn == null ? '未绑定' : '已绑定'}}
</view>
</view>
<view class="bot" v-if="gateSnobj.device.sn != null">
<view class="lt">
有当前订单才能进入门店
</view>
<view class="rt">
SN{{gateSnobj.device.sn}}
</view>
</view>
</view>
</view>
<!-- 房间 --><!-- 房间 --><!-- 房间 --><!-- 房间 --><!-- 房间 --><!-- 房间 --><!-- 房间 --><!-- 房间 --><!-- 房间 --><!-- 房间 --><!-- 房间 --><!-- 房间 -->
<view class="" id="section2">
<view class="damen" v-for="(item,index) in roomList" :key="index">
<view class="name">
{{item.roomName}}
</view>
<view class="fjlist">
<view class="fj_item" v-for="(val,indexs) in item.equipmentList" :key="indexs" @click="btnfj(indexs,item)" :id="val.device.sn == null ? 'active' : ''">
<view class="name">
<text :id="val.device.sn == null ? 'active' : ''">{{val.name}}</text> <text style="font-size: 28rpx;color: #3D3D3D;" :id="val.device.sn == null ? 'active' : ''">
<text style="margin-bottom: 6rpx;" :id="val.device.sn == null ? 'active' : ''"></text> {{val.device.sn == null ? '未绑定' : '已绑定'}}</text>
</view>
<view class="zt" v-if="val.device.sn != null">
SN{{val.device.sn}}
</view>
</view>
</view>
</view>
</view>
<!-- 大厅 --><!-- 大厅 --><!-- 大厅 --><!-- 大厅 --><!-- 大厅 --><!-- 大厅 --><!-- 大厅 --><!-- 大厅 --><!-- 大厅 --><!-- 大厅 --><!-- 大厅 --><!-- 大厅 -->
<view class="damen" id="section3">
<view class="name">
大厅
</view>
<view class="menbj" v-for="(item,index) in datingobj.equipmentList" :key="index" :id="item.device.sn == null ? 'active' : ''" @click="btndating(index)">
<view class="top">
<view class="lt" :id="item.device.sn == null ? 'active' : ''">
<text style="font-weight: 600;" :id="item.device.sn == null ? 'active' : ''">{{item.name}}</text>
</view>
<view class="rt" :id="item.device.sn == null ? 'active' : ''">
<text :id="item.device.sn == null ? 'active' : ''"></text> {{item.device.sn == null ? '未绑定' : '已绑定'}}
</view>
</view>
<view class="bot" v-if="item.device.sn != null">
<view class="lt" :id="item.device.sn == null ? 'active' : ''">
SN{{item.device.sn}}
</view>
<view class="rt">
</view>
</view>
</view>
</view>
<!-- 厕所 --><!-- 厕所 --><!-- 厕所 --><!-- 厕所 --><!-- 厕所 --><!-- 厕所 --><!-- 厕所 --><!-- 厕所 --><!-- 厕所 -->
<view class="damen" id="section4">
<view class="name">
卫生间配置
</view>
<view class="" v-for="(val,index) in cesuolist" :key="index">
<view class="menbj" v-for="(item,index) in val.equipmentList" :key="index" :id="item.device.sn == null ? 'active' : ''" @click="btncesuo(index)">
<view class="top">
<view class="lt" :id="item.device.sn == null ? 'active' : ''">
<text style="font-weight: 600;" :id="item.device.sn == null ? 'active' : ''">{{item.name}}</text>
</view>
<view class="rt" :id="item.device.sn == null ? 'active' : ''">
<text :id="item.device.sn == null ? 'active' : ''"></text> {{item.device.sn == null ? '未绑定' : '已绑定'}}
</view>
</view>
<view class="bot" v-if="item.device.sn != null">
<view class="lt" :id="item.device.sn == null ? 'active' : ''">
SN{{item.device.sn}}
</view>
<view class="rt">
</view>
</view>
</view>
</view>
</view>
</view>
</view>
</template>
<script>
export default {
data() {
return {
bgc: {
backgroundColor: "#fff",
},
storeId: '',
xuanzeflag:false,
roomList: [],
datingobj:{},
cesuolist:[],
list: [],
show: false,
roomId: '',
gateSnobj:{},
objxq:{},
deviceId:'',
tabindex:0
}
},
onLoad(option) {
this.storeId = option.storeId
this.deviceId = option.deviceId
this.getxq()
this.getmendian()
},
methods: {
// 点击tab进行滚动查找
btngundong(section,index) {
this.tabindex = index
const query = uni.createSelectorQuery().in(this);
query.select(`#${section}`).boundingClientRect((rectObj) => {
if (rectObj) {
uni.pageScrollTo({
scrollTop: rectObj.top - 180,
duration: 300
})
} else {
console.error('Element with ID ' + section + ' not found, but this should not happen if the callback is executed.')
}
}).exec()
},
// 点击门店是否绑定
btnmendian(){
if(this.gateSnobj.device == null){
let that = this
uni.showModal({
title: '温馨提示',
content: '您确定要绑定到该设施上吗?',
success: function (res) {
if (res.confirm) {
let data = {
storeId:that.storeId,
deviceId:that.deviceId
}
that.$u.put(`/app/store/bandGate`,data).then(res => {
if(res.code == 200){
uni.showToast({
title: '绑定成功',
icon: 'success',
duration:2000
})
that.getxq()
setTimeout(()=>{
uni.navigateBack({
delta:3
})
},1000)
}else{
uni.showToast({
title: res.msg,
icon: 'none',
duration:2000
})
}
})
} else if (res.cancel) {
}
}
})
}else{
uni.showToast({
title: '该设施已被绑定',
icon: 'none',
duration:2000
})
}
},
// 点击房间是否绑定
btnfj(index,item){
let deviceIds = this.roomList?.[0]?.equipmentList?.[index]?.deviceList?.[0]?.deviceId ?? null
let equipmentId = item.equipmentList[index].equipmentId
console.log(equipmentId)
if(deviceIds == null){
let that = this
uni.showModal({
title: '温馨提示',
content: '您确定要绑定到该设施上吗?',
success: function (res) {
if (res.confirm) {
that.$u.post(`/app/device/placement/${equipmentId}/${that.deviceId}`).then(res => {
if(res.code == 200){
uni.showToast({
title: '绑定成功',
icon: 'success',
duration:2000
})
that.getxq()
setTimeout(()=>{
uni.navigateBack({
delta:3
})
},1000)
}else{
uni.showToast({
title: res.msg,
icon: 'none',
duration:2000
})
}
})
} else if (res.cancel) {
}
}
})
}else{
uni.showToast({
title: '该设施已被绑定',
icon: 'none',
duration:2000
})
}
},
// 点击大厅是否绑定
btndating(index){
let deviceIds = this.datingobj?.equipmentList?.[index]?.deviceList?.[0]?.deviceId ?? null
let equipmentId = this.datingobj.equipmentList[index].equipmentId
console.log(deviceIds,equipmentId,'大厅');
if(deviceIds == null){
let that = this
uni.showModal({
title: '温馨提示',
content: '您确定要绑定到该设施上吗?',
success: function (res) {
if (res.confirm) {
that.$u.post(`/app/device/placement/${equipmentId}/${that.deviceId}`).then(res => {
if(res.code == 200){
uni.showToast({
title: '绑定成功',
icon: 'success',
duration:2000
})
that.getxq()
setTimeout(()=>{
uni.navigateBack({
delta:3
})
},1000)
}else{
uni.showToast({
title: res.msg,
icon: 'none',
duration:2000
})
}
})
} else if (res.cancel) {
}
}
})
}else{
uni.showToast({
title: '该设施已被绑定',
icon: 'none',
duration:2000
})
}
},
// 点击厕所是否绑定
btncesuo(index){
let deviceIds = this.cesuolist?.[0]?.equipmentList?.[index]?.deviceList?.[0]?.deviceId ?? null
let equipmentId = this.cesuolist[0].equipmentList[index].equipmentId
console.log(deviceIds,equipmentId,'厕所');
if(deviceIds == null){
let that = this
uni.showModal({
title: '温馨提示',
content: '您确定要绑定到该设施上吗?',
success: function (res) {
if (res.confirm) {
that.$u.post(`/app/device/placement/${equipmentId}/${that.deviceId}`).then(res => {
if(res.code == 200){
uni.showToast({
title: '绑定成功',
icon: 'success',
duration:2000
})
that.getxq()
setTimeout(()=>{
uni.navigateBack({
delta:3
})
},1000)
}else{
uni.showToast({
title: res.msg,
icon: 'none',
duration:2000
})
}
})
} else if (res.cancel) {
}
}
})
}else{
uni.showToast({
title: '该设施已被绑定',
icon: 'none',
duration:2000
})
}
},
// 根据店铺查大门
getmendian(){
this.$u.get(`/app/equipment/gateGate?storeId=${this.storeId}`).then(res =>{
if(res.code == 200){
this.gateSnobj = res.data
}
})
},
// 获取门店详情
getxq(){
this.$u.get(`app/store/mch/${this.storeId}`).then(res => {
if (res.code == 200) {
this.objxq = res.data
this.roomList = []
this.cesuolist = []
this.datingobj = {}
res.data.roomList.forEach(item => {
if (item.type2 == 1) {
this.roomList.push(item)
} else if (item.type2 == 2) {
this.datingobj = item;
} else if (item.type2 == 3) {
this.cesuolist.push(item)
}
})
}
})
}
}
}
</script>
<style lang="scss">
/deep/ .u-iconfont,
/deep/ .u-title{
padding-bottom: 20rpx;
}
#active{
background-color: #DEF1DA !important;
color: #48893B !important;
}
page {
background: #F6F6F6;
}
.box{
width: 100%;
// height: 88vh;
// overflow: scroll;
padding-bottom: 210rpx;
box-sizing: border-box;
}
.damen{
padding: 0 30rpx;
box-sizing: border-box;
margin-top: 38rpx;
.fjlist{
display: flex;
flex-wrap: wrap;
justify-content: space-between;
margin-top: 16rpx;
width: 100%;
max-height: 1408rpx;
background: #FFFFFF;
padding: 16rpx;
padding-top: 0;
box-sizing: border-box;
border-radius: 20rpx 20rpx 20rpx 20rpx;
.fj_item{
margin-top: 16rpx;
width: 318rpx;
max-height: 178rpx;
background: #F9F9F9;
padding: 26rpx;
box-sizing: border-box;
.zt{
font-size: 28rpx;
margin-top: 24rpx;
}
.name{
display: flex;
justify-content: space-between;
align-items: center;
text{
font-weight: 600;
font-size: 36rpx;
color: #3D3D3D;
text{
width: 10rpx;
height: 10rpx;
background-color: #3D3D3D;
border-radius: 50%;
margin-right: 10rpx;
display: inline-block;
}
}
}
}
}
.name{
font-weight: 600;
font-size: 36rpx;
color: #3D3D3D;
text-align: left;
}
.menbj{
width: 686rpx;
max-height: 170rpx;
background: #FFFFFF;
border-radius: 20rpx 20rpx 20rpx 20rpx;
padding: 30rpx;
box-sizing: border-box;
margin-top: 28rpx;
.bot{
display: flex;
justify-content: space-between;
align-items: center;
margin-top: 20rpx;
.lt{
font-size: 28rpx;
color: #3D3D3D;
}
.rt{
image{
width: 50rpx;
height: 50rpx;
}
}
}
.top{
display: flex;
justify-content: space-between;
.lt{
text{
font-size: 28rpx;
color: #3D3D3D;
margin-right: 54rpx;
}
}
.rt{
display: flex;
align-items: center;
font-size: 28rpx;
color: #3D3D3D;
font-weight: 600;
text{
width: 10rpx;
height: 10rpx;
background-color: #3D3D3D;
border-radius: 50%;
margin-right: 10rpx;
}
}
}
}
}
.tongji{
width: 750rpx;
height: 150rpx;
background: #FFFFFF;
border-radius: 0rpx 0rpx 0rpx 0rpx;
box-sizing: border-box;
margin-top: 14rpx;
display: flex;
align-items: center;
position: fixed;
top: 10vh;
.one{
width: 188rpx;
text-align: center;
.kg{
font-weight: 600;
font-size: 24rpx;
color: #3D3D3D;
text{
color: #48893B;
margin-left: 4rpx;
}
}
.gn{
font-weight: 600;
font-size: 32rpx;
color: #3D3D3D;
margin-top: 10rpx;
}
image{
width: 58rpx;
height: 14rpx;
}
}
.xian{
width: 1px;
height: 62rpx;
background-color: #3D3D3D;
}
}
.list {
margin-top: 30rpx;
height: 70vh;
overflow: scroll;
.list_item {
width: 100%;
height: 200rpx;
line-height: 100rpx;
text-align: center;
border: 1px solid;
}
}
.anniu{
width: 750rpx;
height: 152rpx;
background: #FFFFFF;
box-shadow: 0rpx 8rpx 20rpx 0rpx rgba(0,0,0,0.3);
border-radius: 0rpx 0rpx 0rpx 0rpx;
position: fixed;
left: 0;
bottom: 0;
display: flex;
justify-content: space-between;
padding: 0 36rpx;
box-sizing: border-box;
padding-top: 24rpx;
.queren{
width: 330rpx;
height: 104rpx;
background: #48893B;
text-align: center;
line-height: 104rpx;
font-weight: 600;
font-size: 36rpx;
color: #FFFFFF;
border-radius: 20rpx;
}
.xinjian{
width: 330rpx;
height: 104rpx;
border: 2rpx solid #48893B;
border-radius: 20rpx;
text-align: center;
line-height: 104rpx;
font-weight: 600;
font-size: 36rpx;
color: #48893B;
}
}
</style>