2024-12-20 09:02:40 +08:00
|
|
|
|
<template>
|
|
|
|
|
<view class="page">
|
2025-01-21 17:13:46 +08:00
|
|
|
|
<u-navbar :title="tit" :border-bottom="false" :background="bgc" back-icon-color="#262B37" title-color='#262B37'
|
2024-12-20 09:02:40 +08:00
|
|
|
|
title-size='36' height='40' id="navbar">
|
|
|
|
|
</u-navbar>
|
2024-12-20 18:09:41 +08:00
|
|
|
|
<view class="dalist">
|
|
|
|
|
<view class="box">
|
|
|
|
|
<view class="name">
|
|
|
|
|
<view class="lt">
|
|
|
|
|
名称
|
|
|
|
|
</view>
|
|
|
|
|
<view class="rt">
|
2025-02-12 17:59:03 +08:00
|
|
|
|
<input type="text" v-model="roomName" placeholder="请输入名称"/> <image src="https://api.ccttiot.com/smartmeter/img/static/uCta8cp7uXd1lGjZS6sc" mode=""></image>
|
2024-12-20 18:09:41 +08:00
|
|
|
|
</view>
|
|
|
|
|
</view>
|
2025-01-21 17:13:46 +08:00
|
|
|
|
<view class="name" style="border: none;" v-if="type2 == 1">
|
2024-12-20 18:09:41 +08:00
|
|
|
|
<view class="lt">
|
2025-01-21 17:13:46 +08:00
|
|
|
|
房间类型
|
2024-12-20 18:09:41 +08:00
|
|
|
|
</view>
|
|
|
|
|
<view class="rt" @click="show = true">
|
|
|
|
|
{{leixing}} <image src="https://api.ccttiot.com/smartmeter/img/static/uCta8cp7uXd1lGjZS6sc" mode=""></image>
|
|
|
|
|
</view>
|
|
|
|
|
</view>
|
2025-01-21 17:13:46 +08:00
|
|
|
|
<view class="name" style="border: none;" v-if="type2 == 2">
|
|
|
|
|
<view class="lt">
|
|
|
|
|
设施类型
|
|
|
|
|
</view>
|
|
|
|
|
<view class="rt" @click="shows = true">
|
|
|
|
|
{{leixing}} <image src="https://api.ccttiot.com/smartmeter/img/static/uCta8cp7uXd1lGjZS6sc" mode=""></image>
|
|
|
|
|
</view>
|
|
|
|
|
</view>
|
2024-12-20 18:09:41 +08:00
|
|
|
|
</view>
|
|
|
|
|
<view class="biaoqian">
|
|
|
|
|
<view class="name">
|
|
|
|
|
标签设置
|
|
|
|
|
</view>
|
|
|
|
|
<view class="bqliat">
|
|
|
|
|
<view
|
|
|
|
|
class="bqitem"
|
|
|
|
|
v-for="(item, index) in biaoqianlist"
|
|
|
|
|
:key="index"
|
|
|
|
|
@click="btnbq(item.dictValue,index)"
|
2024-12-27 18:03:26 +08:00
|
|
|
|
:class="{ 'active': isSelected(item.dictValue) }">
|
2024-12-20 18:09:41 +08:00
|
|
|
|
{{ item.dictLabel }}
|
|
|
|
|
</view>
|
|
|
|
|
</view>
|
|
|
|
|
</view>
|
|
|
|
|
<view class="biaoqian">
|
|
|
|
|
<view class="name">
|
2025-01-21 17:13:46 +08:00
|
|
|
|
图像展示
|
2024-12-20 18:09:41 +08:00
|
|
|
|
</view>
|
|
|
|
|
<image v-if="imgurl == ''" @click="getImage" src="https://api.ccttiot.com/smartmeter/img/static/uRBDOOtzMZgSbCcXQPGH" mode=""></image>
|
2024-12-27 18:03:26 +08:00
|
|
|
|
<image v-else :src="imgurl" @click="getImage" mode=""></image>
|
2024-12-20 18:09:41 +08:00
|
|
|
|
<ksp-cropper mode="free" :width="150" :height="150" :maxWidth="1024" :maxHeight="1024" :url="url"
|
|
|
|
|
@cancel="oncancel" @ok="onok"></ksp-cropper>
|
|
|
|
|
</view>
|
|
|
|
|
|
|
|
|
|
<view class="biaoqian">
|
|
|
|
|
<view class="name">
|
2024-12-27 18:03:26 +08:00
|
|
|
|
收费设置
|
2024-12-20 18:09:41 +08:00
|
|
|
|
</view>
|
|
|
|
|
<view class="shoufei" @click="btnshoufei">
|
|
|
|
|
<view class="shang">
|
|
|
|
|
<view class="">
|
|
|
|
|
收费方式
|
|
|
|
|
</view>
|
|
|
|
|
<view class="">
|
2024-12-27 18:03:26 +08:00
|
|
|
|
<image src="https://api.ccttiot.com/smartmeter/img/static/u0rIwef50qNN4aaeqSfl" mode=""></image>
|
2024-12-20 18:09:41 +08:00
|
|
|
|
</view>
|
|
|
|
|
</view>
|
2024-12-27 18:03:26 +08:00
|
|
|
|
<view class="" style="margin-top: 10rpx;">
|
|
|
|
|
<text style="margin-right: 20rpx;color: #48893B;" v-for="(item,index) in namelist" :key="index">{{item}}</text>
|
2024-12-20 09:02:40 +08:00
|
|
|
|
</view>
|
2024-12-20 18:09:41 +08:00
|
|
|
|
</view>
|
|
|
|
|
</view>
|
|
|
|
|
|
2025-01-21 17:13:46 +08:00
|
|
|
|
<u-select v-model="shows" :list="lists" @confirm="confirms"></u-select>
|
2024-12-20 18:09:41 +08:00
|
|
|
|
<u-select v-model="show" :list="list" @confirm="confirm"></u-select>
|
|
|
|
|
<view class="anniu">
|
|
|
|
|
<view class="xinjian" @click="btndt">
|
|
|
|
|
取消
|
|
|
|
|
</view>
|
|
|
|
|
<view class="queren" @click="btnmd">
|
|
|
|
|
确认新建
|
|
|
|
|
</view>
|
|
|
|
|
</view>
|
|
|
|
|
</view>
|
2024-12-20 09:02:40 +08:00
|
|
|
|
</view>
|
|
|
|
|
</template>
|
|
|
|
|
|
|
|
|
|
<script>
|
|
|
|
|
export default {
|
|
|
|
|
data() {
|
|
|
|
|
return {
|
|
|
|
|
bgc: {
|
|
|
|
|
backgroundColor: "#fff",
|
|
|
|
|
},
|
|
|
|
|
leixing:'请选择类型',
|
|
|
|
|
show:false,
|
2025-01-21 17:13:46 +08:00
|
|
|
|
shows:false,
|
2024-12-20 18:09:41 +08:00
|
|
|
|
checked:false,
|
2024-12-20 09:02:40 +08:00
|
|
|
|
list:[
|
|
|
|
|
{
|
|
|
|
|
value: '2',
|
|
|
|
|
label: '棋牌'
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
value: '1',
|
|
|
|
|
label: '茶室'
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
value: '3',
|
|
|
|
|
label: '台球'
|
|
|
|
|
},
|
|
|
|
|
],
|
2025-01-21 17:13:46 +08:00
|
|
|
|
lists:[
|
|
|
|
|
{
|
|
|
|
|
value: '1',
|
|
|
|
|
label: '麻将桌'
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
value: '2',
|
|
|
|
|
label: '台球桌'
|
|
|
|
|
}
|
|
|
|
|
],
|
2024-12-20 09:02:40 +08:00
|
|
|
|
type:'',
|
2024-12-20 18:09:41 +08:00
|
|
|
|
biaoqianlist:[],
|
|
|
|
|
selectedIndices:[],
|
|
|
|
|
token:'',
|
|
|
|
|
url:'',
|
2024-12-27 18:03:26 +08:00
|
|
|
|
imgurl:'',
|
|
|
|
|
namelist:[],
|
|
|
|
|
ruleIdlist:[],
|
|
|
|
|
roomName:'',
|
2025-01-21 17:13:46 +08:00
|
|
|
|
storeId:'',
|
|
|
|
|
tit:'',
|
|
|
|
|
type2:'',
|
|
|
|
|
equType:''
|
2024-12-20 09:02:40 +08:00
|
|
|
|
}
|
|
|
|
|
},
|
2024-12-27 18:03:26 +08:00
|
|
|
|
onLoad(option) {
|
|
|
|
|
this.storeId = option.storeId
|
2025-01-21 17:13:46 +08:00
|
|
|
|
if(option.dating){
|
|
|
|
|
this.tit = '新建设施'
|
|
|
|
|
this.type2 = 2
|
|
|
|
|
}else{
|
|
|
|
|
this.tit = '新建房间'
|
|
|
|
|
this.type2 = 1
|
|
|
|
|
}
|
2024-12-20 18:09:41 +08:00
|
|
|
|
},
|
|
|
|
|
onShow() {
|
|
|
|
|
this.getbiaoqian()
|
|
|
|
|
this.getQiniuToken()
|
2024-12-27 18:03:26 +08:00
|
|
|
|
if(uni.getStorageSync('namelist') && uni.getStorageSync('ruleIdlist')){
|
|
|
|
|
this.namelist = uni.getStorageSync('namelist')
|
|
|
|
|
this.ruleIdlist = uni.getStorageSync('ruleIdlist')
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
onHide() {
|
|
|
|
|
// 移除存储中的数据
|
|
|
|
|
uni.removeStorageSync('namelist')
|
|
|
|
|
uni.removeStorageSync('ruleIdlist')
|
|
|
|
|
},
|
|
|
|
|
onUnload() {
|
|
|
|
|
// 移除存储中的数据
|
|
|
|
|
uni.removeStorageSync('namelist')
|
|
|
|
|
uni.removeStorageSync('ruleIdlist')
|
2024-12-20 09:02:40 +08:00
|
|
|
|
},
|
|
|
|
|
methods: {
|
2024-12-20 18:09:41 +08:00
|
|
|
|
// 点击选择收费
|
|
|
|
|
btnshoufei(){
|
|
|
|
|
uni.navigateTo({
|
|
|
|
|
url:'/page_moban/shoufei'
|
|
|
|
|
})
|
|
|
|
|
},
|
|
|
|
|
// 点击选择标签
|
|
|
|
|
btnbq(dictValue,index) {
|
2024-12-27 18:03:26 +08:00
|
|
|
|
const indexExists = this.selectedIndices.includes(dictValue);
|
2024-12-20 18:09:41 +08:00
|
|
|
|
if (indexExists) {
|
2024-12-27 18:03:26 +08:00
|
|
|
|
this.selectedIndices = this.selectedIndices.filter(i => i !== dictValue);
|
2024-12-20 18:09:41 +08:00
|
|
|
|
} else {
|
2024-12-27 18:03:26 +08:00
|
|
|
|
this.selectedIndices.push(dictValue);
|
2024-12-20 18:09:41 +08:00
|
|
|
|
}
|
|
|
|
|
},
|
2024-12-27 18:03:26 +08:00
|
|
|
|
isSelected(dictValue) {
|
|
|
|
|
return this.selectedIndices.includes(dictValue);
|
2024-12-20 18:09:41 +08:00
|
|
|
|
},
|
|
|
|
|
// 获取标签
|
|
|
|
|
getbiaoqian(){
|
|
|
|
|
this.$u.get(`/appVerify/getDictData?dictType=ss_room_tags`).then((res) => {
|
|
|
|
|
if (res.code == 200) {
|
|
|
|
|
this.biaoqianlist = res.data
|
|
|
|
|
}
|
|
|
|
|
})
|
|
|
|
|
},
|
|
|
|
|
// 点击上传图片
|
|
|
|
|
getImage() {
|
|
|
|
|
uni.chooseImage({
|
|
|
|
|
count: 1,
|
|
|
|
|
success: (rst) => {
|
|
|
|
|
this.url = rst.tempFilePaths[0]
|
|
|
|
|
}
|
|
|
|
|
})
|
|
|
|
|
},
|
|
|
|
|
onok(ev) {
|
|
|
|
|
this.url = ""
|
|
|
|
|
this.path = ev.path
|
|
|
|
|
let _this = this
|
|
|
|
|
let math = 'static/' + _this.$u.guid(20)
|
|
|
|
|
wx.uploadFile({
|
|
|
|
|
url: 'https://up-z2.qiniup.com',
|
|
|
|
|
name: 'file',
|
|
|
|
|
filePath: _this.path,
|
|
|
|
|
formData: {
|
|
|
|
|
token: _this.token, //后端返回的token
|
|
|
|
|
key: 'smartmeter/img/' + math
|
|
|
|
|
},
|
|
|
|
|
success: function(res) {
|
|
|
|
|
let str = JSON.parse(res.data)
|
|
|
|
|
_this.imgurl = 'https://lxnapi.ccttiot.com/' + str.key
|
|
|
|
|
}
|
|
|
|
|
})
|
|
|
|
|
},
|
|
|
|
|
oncancel() {
|
|
|
|
|
// url设置为空,隐藏控件
|
|
|
|
|
this.url = "";
|
|
|
|
|
},
|
|
|
|
|
// 获取上传七牛云token
|
|
|
|
|
getQiniuToken() {
|
|
|
|
|
this.$u.get("/common/qiniu/uploadInfo").then((res) => {
|
|
|
|
|
if (res.code == 200) {
|
|
|
|
|
this.token = res.token
|
|
|
|
|
}
|
|
|
|
|
})
|
|
|
|
|
},
|
2025-01-21 17:13:46 +08:00
|
|
|
|
// 确认选择房间类型
|
2024-12-20 09:02:40 +08:00
|
|
|
|
confirm(e){
|
|
|
|
|
this.type = e[0].value
|
|
|
|
|
this.leixing =e[0].label
|
|
|
|
|
},
|
2025-01-21 17:13:46 +08:00
|
|
|
|
// 确认选择房间类型
|
|
|
|
|
confirms(e){
|
|
|
|
|
this.equType = e[0].value
|
|
|
|
|
this.leixing =e[0].label
|
|
|
|
|
},
|
|
|
|
|
// 点击确定新建房间或者设施
|
2024-12-20 09:02:40 +08:00
|
|
|
|
btnmd(){
|
2024-12-27 18:03:26 +08:00
|
|
|
|
let data = {
|
|
|
|
|
roomName:this.roomName,
|
|
|
|
|
storeId:this.storeId,
|
|
|
|
|
type:this.type,
|
|
|
|
|
picture:this.imgurl,
|
|
|
|
|
ruleIds:this.ruleIdlist,
|
2025-01-21 17:13:46 +08:00
|
|
|
|
tags:this.selectedIndices,
|
|
|
|
|
type2:this.type2,
|
|
|
|
|
equType:this.equType
|
2024-12-27 18:03:26 +08:00
|
|
|
|
}
|
|
|
|
|
this.$u.post(`/app/room`,data).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
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
})
|
2024-12-20 09:02:40 +08:00
|
|
|
|
},
|
|
|
|
|
// 点击取消
|
|
|
|
|
btndt(){
|
|
|
|
|
uni.navigateBack()
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
</script>
|
|
|
|
|
|
|
|
|
|
<style lang="scss">
|
2024-12-20 18:09:41 +08:00
|
|
|
|
.active{
|
|
|
|
|
background-color: #48893B !important;
|
|
|
|
|
color: #fff !important;
|
|
|
|
|
}
|
2024-12-27 18:03:26 +08:00
|
|
|
|
/deep/ .panel{
|
|
|
|
|
position: fixed;
|
|
|
|
|
left: 0;
|
|
|
|
|
}
|
2024-12-20 09:02:40 +08:00
|
|
|
|
page {
|
|
|
|
|
background: #F6F6F6;
|
|
|
|
|
}
|
2024-12-20 18:09:41 +08:00
|
|
|
|
.dalist{
|
|
|
|
|
width: 100%;
|
|
|
|
|
height: 80vh;
|
|
|
|
|
overflow: scroll;
|
|
|
|
|
padding-bottom: 40rpx;
|
|
|
|
|
box-sizing: border-box;
|
|
|
|
|
}
|
|
|
|
|
.biaoqian{
|
|
|
|
|
width: 680rpx;
|
|
|
|
|
max-height: 1624rpx;
|
|
|
|
|
background: #FFFFFF;
|
|
|
|
|
padding: 44rpx 34rpx;
|
|
|
|
|
box-sizing: border-box;
|
|
|
|
|
margin: auto;
|
|
|
|
|
margin-top: 22rpx;
|
|
|
|
|
border-radius: 20rpx;
|
|
|
|
|
.shoufei{
|
|
|
|
|
margin-top: 30rpx;
|
|
|
|
|
.wz{
|
|
|
|
|
font-size: 24rpx;
|
|
|
|
|
color: #3D3D3D;
|
|
|
|
|
margin-top: 24rpx;
|
|
|
|
|
margin-bottom: 20rpx;
|
|
|
|
|
}
|
|
|
|
|
.shichang{
|
|
|
|
|
margin-top: 34rpx;
|
|
|
|
|
.stop{
|
|
|
|
|
display: flex;
|
|
|
|
|
width: 618rpx;
|
|
|
|
|
height: 76rpx;
|
|
|
|
|
line-height: 76rpx;
|
|
|
|
|
background: #F0F0F0;
|
|
|
|
|
view{
|
|
|
|
|
width: 50%;
|
|
|
|
|
text-align: center;
|
|
|
|
|
font-size: 28rpx;
|
|
|
|
|
color: #3D3D3D;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
.shang{
|
|
|
|
|
display: flex;
|
|
|
|
|
justify-content: space-between;
|
|
|
|
|
align-items: center;
|
|
|
|
|
width: 100%;
|
|
|
|
|
view{
|
|
|
|
|
font-size: 32rpx;
|
|
|
|
|
color: #3D3D3D;
|
|
|
|
|
display: flex;
|
|
|
|
|
align-items: center;
|
|
|
|
|
image{
|
|
|
|
|
width: 14rpx;
|
|
|
|
|
height: 42rpx;
|
|
|
|
|
margin-top: 0;
|
|
|
|
|
margin-right: 10rpx;
|
2024-12-27 18:03:26 +08:00
|
|
|
|
border-radius: 20rpx;
|
2024-12-20 18:09:41 +08:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
image{
|
|
|
|
|
width: 144rpx;
|
|
|
|
|
height: 144rpx;
|
2024-12-27 18:03:26 +08:00
|
|
|
|
// margin-top: 30rpx;
|
2024-12-20 18:09:41 +08:00
|
|
|
|
}
|
|
|
|
|
.name{
|
|
|
|
|
font-weight: 600;
|
|
|
|
|
font-size: 36rpx;
|
|
|
|
|
color: #3D3D3D;
|
2024-12-27 18:03:26 +08:00
|
|
|
|
margin-bottom: 30rpx;
|
2024-12-20 18:09:41 +08:00
|
|
|
|
}
|
|
|
|
|
.bqliat{
|
|
|
|
|
margin-top: 30rpx;
|
|
|
|
|
display: flex;
|
|
|
|
|
flex-wrap: wrap;
|
|
|
|
|
.bqitem{
|
|
|
|
|
margin-right: 10rpx;
|
|
|
|
|
border: 1px solid #48893B;
|
|
|
|
|
color: #48893B;
|
|
|
|
|
padding: 10rpx;
|
|
|
|
|
margin-top: 10rpx;
|
|
|
|
|
}
|
|
|
|
|
image{
|
|
|
|
|
width: 226rpx;
|
|
|
|
|
height: 58rpx;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
2024-12-20 09:02:40 +08:00
|
|
|
|
.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: 314rpx;
|
|
|
|
|
height: 104rpx;
|
|
|
|
|
background: #48893B;
|
|
|
|
|
text-align: center;
|
|
|
|
|
line-height: 104rpx;
|
|
|
|
|
font-weight: 600;
|
|
|
|
|
font-size: 36rpx;
|
|
|
|
|
color: #FFFFFF;
|
|
|
|
|
border-radius: 20rpx;
|
|
|
|
|
}
|
|
|
|
|
.xinjian{
|
|
|
|
|
width: 314rpx;
|
|
|
|
|
height: 104rpx;
|
|
|
|
|
border: 2rpx solid #48893B;
|
|
|
|
|
border-radius: 20rpx;
|
|
|
|
|
text-align: center;
|
|
|
|
|
line-height: 104rpx;
|
|
|
|
|
font-weight: 600;
|
|
|
|
|
font-size: 36rpx;
|
|
|
|
|
color: #48893B;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
.box{
|
|
|
|
|
width: 680rpx;
|
2024-12-20 18:09:41 +08:00
|
|
|
|
max-height: 408rpx;
|
2024-12-20 09:02:40 +08:00
|
|
|
|
background: #FFFFFF;
|
|
|
|
|
margin: auto;
|
|
|
|
|
margin-top: 22rpx;
|
|
|
|
|
border-radius: 20rpx;
|
|
|
|
|
.name{
|
|
|
|
|
display: flex;
|
|
|
|
|
justify-content: space-between;
|
|
|
|
|
align-items: center;
|
|
|
|
|
width: 618rpx;
|
|
|
|
|
margin: auto;
|
|
|
|
|
height: 110rpx;
|
|
|
|
|
border-bottom: 1px solid #D8D8D8;
|
|
|
|
|
.lt{
|
|
|
|
|
font-size: 32rpx;
|
|
|
|
|
color: #3D3D3D;
|
|
|
|
|
}
|
|
|
|
|
.rt{
|
|
|
|
|
display: flex;
|
|
|
|
|
align-items: center;
|
|
|
|
|
input{
|
|
|
|
|
text-align: right;
|
|
|
|
|
}
|
|
|
|
|
image{
|
|
|
|
|
width: 14rpx;
|
|
|
|
|
height: 42rpx;
|
|
|
|
|
margin-left: 10rpx;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
</style>
|