tearoom/page_shanghu/toufsb.vue
2025-03-05 17:42:13 +08:00

724 lines
15 KiB
Vue
Raw Permalink 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='48' id="navbar">
</u-navbar>
<view class="box">
<view class="ulbox">
<view class="one">
设施
</view>
<view class="two">
店门
</view>
</view>
<view class="ulbox" @click="showone = true">
<view class="one">
开锁方式
</view>
<view class="two">
{{ksfs}} <image src="https://api.ccttiot.com/smartmeter/img/static/uS5JydUQDmvbMyg4nsdo" mode=""></image>
</view>
</view>
<view class="ulbox" @click="showtwo = true">
<view class="one">
开锁时长
</view>
<view class="two">
{{kstime == null ? '' : kstime + '秒'}} <image src="https://api.ccttiot.com/smartmeter/img/static/uS5JydUQDmvbMyg4nsdo" mode=""></image>
</view>
</view>
<view class="ulbox" @click="showthr = true">
<view class="one">
开锁条件
</view>
<view class="two">
{{kstj}} <image src="https://api.ccttiot.com/smartmeter/img/static/uS5JydUQDmvbMyg4nsdo" mode=""></image>
</view>
</view>
<view class="ulbox" @click="btnewm">
<view class="one">
生成二维码
</view>
<view class="two">
<image src="https://api.ccttiot.com/smartmeter/img/static/uS5JydUQDmvbMyg4nsdo" mode=""></image>
</view>
</view>
<view class="ulbox" style="border: none;" @click="addmenflag = true">
<view class="one">
设备绑定
</view>
<view class="two">
{{xxobj.gateSn == null ? '' : xxobj.gateSn}} <image src="https://api.ccttiot.com/smartmeter/img/static/uS5JydUQDmvbMyg4nsdo" mode=""></image>
</view>
</view>
<u-select v-model="showone" :list="listone" @confirm="btnone"></u-select>
<u-picker mode="time" v-model="showtwo" :params="params" @confirm="btntwo"></u-picker>
<u-select v-model="showthr" :list="listthr" @confirm="btnthr"></u-select>
<view class="anniu">
<view class="tougang" style="margin-right: 30rpx;" @click="btnjieb" v-if="xxobj.gateId != null">
解绑
</view>
<view class="tougang" @click="btnshop">
修改
</view>
</view>
</view>
<view class="mask" style="z-index: 3;" v-if="addmenflag"></view>
<view class="addmen" v-if="addmenflag">
<view class="top">
<view class="cha" @click="addmenflag = false">
×
</view>
<view class="name">
请选择投放设备方式
</view>
</view>
<view class="one" @click="btnsaoma">
<view class="lt">
<view class="saoma">
扫码投放
</view>
<view class="saomas">
扫描设备上的二维码
</view>
<view class="saomas">
设置大门
</view>
</view>
<view class="rt">
<image src="https://api.ccttiot.com/smartmeter/img/static/ukzEfdUUjPKUUOxonIgm" mode=""></image>
</view>
</view>
<view class="one" @click="btntouf">
<view class="lt">
<view class="saoma">
未投放设备列表投放
</view>
<view class="saomas">
选择未投放列表中的设备
</view>
<view class="saomas">
设置大门
</view>
</view>
<view class="rt">
<image src="https://api.ccttiot.com/smartmeter/img/static/ukzEfdUUjPKUUOxonIgm" mode=""></image>
</view>
</view>
</view>
<!-- 生成房间码 -->
<view class="roomma" v-if="roommaflag">
<view class="name">
生成房间码
</view>
<input type="number" v-model="roomma" placeholder="请随机输入六位数字"/>
<view class="annius">
<view class="qx" @click="roommaflag = false">
取消
</view>
<view class="qd" @click="btnshop">
确定
</view>
</view>
</view>
<view class="mask" v-if="roommaflag"></view>
</view>
</template>
<script>
export default {
data() {
return {
roomma:'',
roommaflag:false,
bgc: {
backgroundColor: "#fff",
},
listone:[{
value: '1',
label: '通电开锁'
},{
alue: '2',
label: '断电开锁'
}],
listthr:[
{
value: '1',
label: '有当前订单可进入'
},{
value: '2',
label: '有历史订单可进入'
},{
value: '3',
label: '无条件'
}],
params: {
year: false,
month: false,
day: false,
hour: false,
minute: false,
second: true
},
showone:false,
showtwo:false,
showthr:false,
xxobj:{},
obj:{},
storeId:'',
sn:'',
ksfs:'',
kstime:'',
kstj:'',
ksfsid:'',
kstjid:'',
addmenflag:false,
codeid:''
}
},
onLoad(option) {
this.storeId = option.storeId
},
onShow() {
this.getmendian()
},
methods: {
// 点击去生成二维码
btnewm(){
if(this.codeid == null || this.codeid == ''){
this.roommaflag = true
this.roomma = ''
}else{
uni.navigateTo({
url:'/page_shanghu/erwm?storeId=' + this.codeid + '&obj=' + JSON.stringify(this.obj)
})
}
},
// 点击解绑店门
btnjieb(){
let that = this
uni.showModal({
title: '温馨提示',
content: '您确定要解绑该设备吗?',
success: function (res) {
if (res.confirm) {
that.$u.post(`app/device/offline/${that.xxobj.gateId}`).then(res => {
if (res.code == 200) {
uni.showToast({
title: '解绑成功',
icon: 'success',
duration: 2000
})
setTimeout(()=>{
uni.navigateBack()
},1000)
}else{
uni.showToast({
title: res.msg,
icon: 'none',
duration: 2000
})
}
})
} else if (res.cancel) {
}
}
})
},
// 请求大门详情
getmendian(){
this.$u.get(`app/store/mch/${this.storeId}`).then(res =>{
if(res.code == 200){
this.obj = res.data
this.codeid = res.data.code
this.xxobj = res.data.gate
this.kstime = res.data.unlockTime
this.ksfsid = res.data.unlockMode
this.kstjid = res.data.unlockCondition
if(res.data.unlockMode == 1){
this.ksfs = '通电开锁'
}else if(res.data.unlockMode == 2){
this.ksfs = '断电开锁'
}
if(res.data.unlockCondition == 1){
this.kstj = '有当前订单可进入'
}else if(res.data.unlockCondition == 2){
this.kstj = '有历史订单可进入'
}else if(res.data.unlockCondition == 3){
this.kstj = '无条件'
}
}
})
},
// 点击选择未投放设备
btntouf() {
this.addmenflag = false
uni.navigateTo({
url: '/page_shanghu/weishebei?storeId=' + this.storeId
})
},
// 大门配置点击扫码配置
btnsaoma() {
uni.scanCode({
onlyFromCamera: true,
scanType: ['qrCode'],
success: res => {
function getQueryParam(url, paramName) {
let regex = new RegExp(`[?&]${paramName}=([^&]*)`)
let results = regex.exec(url);
return results ? decodeURIComponent(results[1].replace(/\+/g, ' ')) : null
}
console.log(res);
let sceneValue = res.result
let decodedValue = decodeURIComponent(sceneValue)
let id = getQueryParam(decodedValue, 'sn')
let that = this
let data = {
sn: id,
storeId: this.storeId
}
that.$u.put(`/app/store/bandGate`, data).then(res => {
if (res.code == 200) {
uni.showToast({
title: '绑定成功',
icon: 'success',
duration: 2000
})
that.xuanzeflag = false
that.addmenflag = false
that.getmendian()
} else {
uni.showToast({
title: res.msg,
icon: 'none',
duration: 2000
})
}
})
}
})
},
// 点击选择门店
btnshop(){
let data = {
storeId:this.storeId,
code:'D' + this.roomma,
unlockMode:this.ksfsid,
unlockCondition:this.kstjid,
unlockTime:this.kstime
}
this.$u.put(`/app/store/gateAuth`,data).then(res => {
if (res.code == 200) {
uni.showToast({
title: '操作成功',
icon: 'success',
duration:2000
})
this.getmendian()
this.roommaflag = false
}else{
uni.showToast({
title: res.msg,
icon: 'none',
duration:2000
})
}
})
},
// 确认选择开锁方式
btnone(e){
this.ksfs = e[0].label
this.ksfsid = e[0].value
},
// 确认选择开锁时间
btntwo(e){
this.kstime = e.second
},
// 确认开锁条件
btnthr(e){
this.kstj = e[0].label
this.kstjid = e[0].value
},
}
}
</script>
<style lang="scss">
/deep/ .u-iconfont,
/deep/ .u-title{
padding-bottom: 20rpx;
box-sizing: border-box;
}
.roomma{
position: fixed;
top: 40%;
left: 50%;
transform: translateX(-50%);
width: 500rpx;
height: 300rpx;
background-color: #fff;
border-radius: 30rpx;
z-index: 1;
padding: 20rpx;
box-sizing: border-box;
.name{
width: 100%;
text-align: center;
font-size: 32rpx;
font-weight: 600;
margin-top: 20rpx;
}
input{
width: 100%;
height: 60rpx;
background-color: #D8D8D8;
border-radius: 10rpx;
padding-left: 20rpx;
box-sizing: border-box;
margin-top: 20rpx;
}
.annius{
display: flex;
justify-content: space-between;
padding: 0 40rpx;
box-sizing: border-box;
margin-top: 10rpx;
.qx,
.qd{
margin-top: 20rpx;
width: 180rpx;
height: 80rpx;
line-height: 80rpx;
text-align: center;
border-radius: 10rpx;
border: 1px solid #48893B;
font-size: 32rpx;
}
.qd{
background-color: #48893B;
color: #fff;
}
}
}
.mask {
width: 100%;
height: 100vh;
background-color: #000;
opacity: .3;
position: fixed;
top: 0;
left: 0;
}
.addmen {
width: 694rpx;
height: 702rpx;
background: linear-gradient(180deg, #DEF1DA 0%, #FFFFFF 100%, #FFFFFF 100%);
border-radius: 36rpx 36rpx 36rpx 36rpx;
position: fixed;
top: 464rpx;
left: 50%;
transform: translateX(-50%);
z-index: 3;
box-shadow: 1px 2px 4px -3px;
.one {
display: flex;
align-items: center;
justify-content: space-between;
width: 100%;
.rt {
image {
width: 60rpx;
height: 60rpx;
}
}
.saoma {
font-weight: 600;
font-size: 36rpx;
color: #48893B;
margin-top: 10rpx;
}
.saomas {
font-size: 28rpx;
color: #48893B;
margin-top: 10rpx;
}
width: 584rpx;
height: 224rpx;
border: 2rpx solid #48893B;
border-radius: 20rpx;
margin: auto;
margin-top: 48rpx;
padding: 38rpx 44rpx;
box-sizing: border-box;
}
.top {
display: flex;
flex-wrap: wrap;
padding: 0 26rpx;
box-sizing: border-box;
.name {
font-weight: 600;
font-size: 44rpx;
color: #48893B;
width: 100%;
text-align: center;
position: absolute;
top: 56rpx;
left: 50%;
transform: translateX(-50%);
}
.cha {
font-size: 68rpx;
font-weight: 600;
width: 100%;
text-align: right;
}
}
}
.jieb{
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;
bottom: 0;
left: 0;
.bt{
width: 680rpx;
height: 104rpx;
background: #48893B;
margin: auto;
margin-top: 24rpx;
border-radius: 24rpx;
font-weight: 600;
font-size: 36rpx;
color: #FFFFFF;
text-align: center;
line-height: 104rpx;
}
}
.lianwang{
width: 680rpx;
height: 112rpx;
background: #FFFFFF;
display: flex;
align-items: center;
justify-content: space-between;
margin: auto;
margin-top: 22rpx;
border-radius: 24rpx;
padding: 36rpx 32rpx;
box-sizing: border-box;
.two{
font-size: 32rpx;
color: #7C7C7C;
}
.thr{
font-size: 32rpx;
color: #3D3D3D;
display: flex;
align-items: center;
image{
width: 12rpx;
height: 34rpx;
margin-left: 10rpx;
}
}
}
.jichuxx{
width: 680rpx;
max-height: 458rpx;
background: #FFFFFF;
box-sizing: border-box;
padding: 44rpx 34rpx;
box-sizing: border-box;
margin: auto;
margin-top: 22rpx;
border-radius: 20rpx;
.top{
border-left: 14rpx solid #48893B;
font-weight: 600;
font-size: 36rpx;
color: #3D3D3D;
padding-left: 24rpx;
box-sizing: border-box;
}
.one{
display: flex;
justify-content: space-between;
align-items: center;
margin-top: 28rpx;
.two{
font-size: 32rpx;
color: #7C7C7C;
}
.thr{
font-size: 32rpx;
color: #3D3D3D;
}
}
}
.toufangbox{
width: 680rpx;
height: 284rpx;
background: #FFFFFF;
border-radius: 24rpx 24rpx 24rpx 24rpx;
margin: auto;
margin-top: 22rpx;
padding: 44rpx 34rpx;
box-sizing: border-box;
.shebeibj{
display: flex;
justify-content: space-between;
.lt{
.name{
font-weight: 600;
font-size: 40rpx;
color: #262B37;
}
.zt{
font-size: 28rpx;
color: #5B5B5B;
margin-top: 12rpx;
text{
color: #00BA88;
}
}
}
.rt{
image{
width: 196rpx;
height: 196rpx;
}
}
}
}
.xuanze{
width: 750rpx;
height: 494rpx;
background: #FFFFFF;
border-radius: 40rpx 40rpx 0 0;
position: fixed;
left: 0;
bottom: 0;
z-index: 1;
padding: 42rpx 62rpx;
box-sizing: border-box;
.changj{
display: flex;
justify-content: space-between;
flex-wrap: wrap;
.changj_item{
width: 302rpx;
height: 110rpx;
background: #F0F0F0;
border-radius: 6rpx 6rpx 6rpx 6rpx;
font-weight: 600;
text-align: center;
line-height: 110rpx;
font-size: 36rpx;
margin-top: 40rpx;
color: #3D3D3D;
}
}
.top{
display: flex;
justify-content: space-between;
view{
font-weight: 600;
font-size: 36rpx;
color: #3D3D3D;
image{
width: 50rpx;
height: 50rpx;
}
}
}
}
.mask{
width: 100%;
height: 100vh;
background-color: #000;
opacity: .3;
position: fixed;
top: 0;
left: 0;
}
.anniu{
width: 100%;
height: 152rpx;
background: #FFFFFF;
box-shadow: 0rpx 8rpx 20rpx 0rpx rgba(0,0,0,0.3);
border-radius: 0rpx 0rpx 0rpx 0rpx;
display: flex;
padding: 24rpx 36rpx;
box-sizing: border-box;
justify-content: space-between;
text-align: center;
position: fixed;
left: 0;
bottom: 0;
.tougang{
width: 680rpx;
margin: auto;
height: 104rpx;
background: #48893B;
font-size: 36rpx;
color: #FFFFFF;
line-height: 104rpx;
border-radius: 20rpx;
}
}
.box{
width: 680rpx;
max-height: 708rpx;
background: #FFFFFF;
border-radius: 20rpx;
margin: auto;
margin-top: 28rpx;
padding: 0 30rpx;
box-sizing: border-box;
.ulbox{
width: 100%;
height: 118rpx;
line-height: 118rpx;
display: flex;
justify-content: space-between;
border-bottom: 1px solid #D8D8D8;
.one{
font-size: 32rpx;
color: #3D3D3D;
}
.two{
font-size: 32rpx;
color: #7C7C7C;
display: flex;
align-items: center;
image{
width: 14rpx;
height: 42rpx;
margin-left: 20rpx;
}
}
}
}
page {
background: #F6F6F6;
}
</style>