471 lines
10 KiB
Vue
471 lines
10 KiB
Vue
<template>
|
|
<view class="page">
|
|
<u-navbar title="套餐设置" :border-bottom="false" :background="bgc" title-color='#fff' back-icon-color="#fff"
|
|
title-size='36' height='50'></u-navbar>
|
|
<view class="box">
|
|
<view class="list">
|
|
<view class="" style="display: flex;
|
|
justify-content: space-between;
|
|
width: 100%;
|
|
align-items: center;">
|
|
<view class="title">
|
|
套餐名称
|
|
</view>
|
|
<input type="text" v-model="name" placeholder="输入套餐名称" />
|
|
</view>
|
|
<view class="" style="display: flex;
|
|
justify-content: space-between;
|
|
width: 100%;
|
|
align-items: center;margin-top: 30rpx;">
|
|
<view class="title">
|
|
价格(元)
|
|
</view>
|
|
<input type="text" v-model="price" placeholder="输入价格" />
|
|
</view>
|
|
<view class="" style="display: flex;
|
|
justify-content: space-between;
|
|
width: 100%;
|
|
align-items: center;margin-top: 30rpx;">
|
|
<view class="title">
|
|
通电时长
|
|
</view>
|
|
<view class="" style="display: flex;justify-content: space-between;position: relative;">
|
|
<input type="number" v-model="value" placeholder="输入通电时长" />
|
|
<view class="picker" @click="btnxz">
|
|
{{array[index]}} <u-icon v-if="arrflag" name="arrow-down" color="#000" size="24"></u-icon>
|
|
<u-icon v-else name="arrow-right" color="#000" size="24"></u-icon>
|
|
</view>
|
|
<view class="arr_list" v-if="arrflag">
|
|
<view class="arr_item" v-for="(item,index) in array" :key="index" @click="btnxl(index)">
|
|
{{item}}
|
|
</view>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
<view class="title" style="margin-top: 30rpx;margin-bottom: 20rpx;">
|
|
详细说明
|
|
</view>
|
|
<textarea v-model="description" placeholder="输入说明解释" auto-height="true" />
|
|
</view>
|
|
|
|
<!-- 应用设备 -->
|
|
<!-- <view class="shebei">
|
|
<view class="sbtit">应用设备</view>
|
|
<view class="sbarr">
|
|
<view class="sbarrval" v-for="(item,index) in 5" :key="index">
|
|
扫码开关
|
|
</view>
|
|
</view>
|
|
<view class="btnsbadd" @click="btnaddsb">
|
|
+
|
|
</view>
|
|
</view> -->
|
|
|
|
<view class="trues" @click="btnadd">
|
|
{{title}}
|
|
</view>
|
|
<view v-if="title == '修改'" class="truess" @click="btndel">
|
|
删除
|
|
</view>
|
|
<view v-else class="trueqx" @click="btnqx">
|
|
取消
|
|
</view>
|
|
</view>
|
|
|
|
</view>
|
|
</template>
|
|
|
|
<script>
|
|
export default {
|
|
data() {
|
|
return {
|
|
deviceId: '',
|
|
name: '',
|
|
value: '',
|
|
description: '',
|
|
price: '',
|
|
title: '',
|
|
suitId: '',
|
|
array: ['天', '时', '分钟', '秒'],
|
|
index: 2,
|
|
timewz: '',
|
|
arrflag: false,
|
|
bgc: {
|
|
backgroundColor: "#8883f0",
|
|
},
|
|
}
|
|
},
|
|
onLoad(option) {
|
|
if (option.suitId) {
|
|
this.deviceId = option.id
|
|
this.title = '修改'
|
|
this.suitId = option.suitId
|
|
this.gettaocan(option.suitId)
|
|
} else {
|
|
this.deviceId = option.id
|
|
this.title = '确定'
|
|
}
|
|
},
|
|
// 分享到好友(会话)
|
|
onShareAppMessage: function() {
|
|
return {
|
|
title: '创想物联',
|
|
path: '/pages/shouye/index'
|
|
}
|
|
},
|
|
|
|
// 分享到朋友圈
|
|
onShareTimeline: function() {
|
|
return {
|
|
title: '创想物联',
|
|
query: '',
|
|
path: '/pages/shouye/index'
|
|
}
|
|
},
|
|
methods: {
|
|
btnqx(){
|
|
uni.navigateBack()
|
|
},
|
|
// bindPickerChange(e) {
|
|
// this.index = e.detail.value
|
|
// },
|
|
// 跳转选择设备
|
|
btnaddsb(){
|
|
uni.navigateTo({
|
|
url:'/page_components/shebeixz'
|
|
})
|
|
},
|
|
btnxl(index) {
|
|
this.index = index
|
|
this.arrflag = false
|
|
},
|
|
btnxz() {
|
|
if (this.arrflag == true) {
|
|
this.arrflag = false
|
|
} else {
|
|
this.arrflag = true
|
|
}
|
|
},
|
|
|
|
gettaocan(suitId) {
|
|
this.$u.get(`/app/suit/${suitId}`).then((res) => {
|
|
if (res.code == 200) {
|
|
this.name = res.data.name
|
|
this.price = res.data.price
|
|
this.value = res.data.value
|
|
this.description = res.data.description
|
|
this.index = Number(res.data.timeUnit) - 1
|
|
}
|
|
})
|
|
},
|
|
btndel() {
|
|
let that = this
|
|
uni.showModal({
|
|
title: '提示',
|
|
content: '您确定要删除该套餐吗?',
|
|
success: function(res) {
|
|
if (res.confirm) {
|
|
that.$u.delete(`/app/suit/${that.suitId}`).then((res) => {
|
|
if (res.code == 200) {
|
|
uni.showToast({
|
|
title: '删除成功',
|
|
icon: 'success',
|
|
duration: 1000,
|
|
})
|
|
setTimeout(() => {
|
|
uni.navigateBack()
|
|
}, 1000)
|
|
} else {
|
|
uni.showToast({
|
|
title: res.msg,
|
|
icon: 'none',
|
|
duration: 1000,
|
|
})
|
|
}
|
|
})
|
|
} else if (res.cancel) {
|
|
|
|
}
|
|
}
|
|
})
|
|
},
|
|
|
|
btnadd() {
|
|
let regex = /^\d+(\.\d{1,2})?$/
|
|
let regexs = /^\d+$/
|
|
if (this.name == '') {
|
|
uni.showToast({
|
|
title: '套餐名称不能为空',
|
|
icon: 'none',
|
|
duration: 1000,
|
|
})
|
|
} else if (this.price == '') {
|
|
uni.showToast({
|
|
title: '价格不能为空',
|
|
icon: 'none',
|
|
duration: 1000,
|
|
})
|
|
} else if (!regex.test(this.price)) {
|
|
uni.showToast({
|
|
title: '价格必须是数字且小数点只能两位',
|
|
icon: 'none',
|
|
duration: 2000,
|
|
})
|
|
} else if (this.value == '') {
|
|
uni.showToast({
|
|
title: '时长不能为空',
|
|
icon: 'none',
|
|
duration: 1000,
|
|
})
|
|
} else if (!regexs.test(this.value)) {
|
|
uni.showToast({
|
|
title: '时长必须是整数',
|
|
icon: 'none',
|
|
duration: 2000,
|
|
})
|
|
} else if (this.description == '') {
|
|
uni.showToast({
|
|
title: '详细说明不能为空',
|
|
icon: 'none',
|
|
duration: 1000,
|
|
})
|
|
} else {
|
|
if (this.title == '确定') {
|
|
let data = {
|
|
// deviceId: this.deviceId,
|
|
name: this.name,
|
|
value: this.value,
|
|
price: this.price,
|
|
description: this.description,
|
|
timeUnit: Number(this.index) + 1
|
|
}
|
|
this.$u.post('/app/suit', data).then((res) => {
|
|
if (res.code == 200) {
|
|
uni.showToast({
|
|
title: '新建套餐成功',
|
|
icon: 'success',
|
|
duration: 1000,
|
|
})
|
|
setTimeout(() => {
|
|
uni.navigateBack()
|
|
}, 1000)
|
|
}
|
|
})
|
|
} else {
|
|
let data = {
|
|
suitId: this.suitId,
|
|
// deviceId: this.deviceId,
|
|
name: this.name,
|
|
value: this.value,
|
|
price: this.price,
|
|
description: this.description,
|
|
timeUnit: Number(this.index) + 1
|
|
}
|
|
this.$u.put('/app/suit', data).then((res) => {
|
|
if (res.code == 200) {
|
|
uni.showToast({
|
|
title: '修改套餐成功',
|
|
icon: 'success',
|
|
duration: 1000,
|
|
})
|
|
setTimeout(() => {
|
|
uni.navigateBack()
|
|
}, 1000)
|
|
} else {
|
|
uni.showToast({
|
|
title: res.msg,
|
|
icon: 'none',
|
|
duration: 1000,
|
|
})
|
|
}
|
|
})
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
</script>
|
|
|
|
<style lang="scss">
|
|
/deep/ .u-title {
|
|
padding-bottom: 22rpx;
|
|
}
|
|
|
|
/deep/ .u-icon__icon {
|
|
padding-bottom: 22rpx;
|
|
}
|
|
|
|
.shebei {
|
|
width: 654rpx;
|
|
max-height: 100%;
|
|
background: #FFFFFF;
|
|
box-shadow: 0rpx 16rpx 40rpx 0rpx rgba(42, 130, 228, 0.1);
|
|
-webkit-filter: blur(0px);
|
|
filter: blur(0px);
|
|
margin: auto;
|
|
border-radius: 30rpx;
|
|
padding: 28rpx 38rpx;
|
|
box-sizing: border-box;
|
|
margin-top: 150rpx;
|
|
|
|
.sbtit {
|
|
font-size: 32rpx;
|
|
color: #000000;
|
|
font-weight: 600;
|
|
}
|
|
.sbarr{
|
|
display: flex;
|
|
flex-wrap: wrap;
|
|
width: 100%;
|
|
justify-content: space-between;
|
|
.sbarrval{
|
|
width: 48%;
|
|
height: 80rpx;
|
|
line-height: 80rpx;
|
|
background-color: #8883F0;
|
|
color: #fff;
|
|
text-align: center;
|
|
border-radius: 30rpx;
|
|
margin-top: 20rpx;
|
|
font-size: 30rpx;
|
|
}
|
|
}
|
|
.btnsbadd{
|
|
width: 48%;
|
|
height: 80rpx;
|
|
line-height: 70rpx;
|
|
background-color: #8883F0;
|
|
color: #fff;
|
|
text-align: center;
|
|
border-radius: 30rpx;
|
|
margin-top: 20rpx;
|
|
font-size: 65rpx;
|
|
}
|
|
|
|
}
|
|
|
|
page {
|
|
background: linear-gradient(180deg, #8883F0 0%, rgba(255, 255, 255, 0) 100%);
|
|
}
|
|
@keyframes fadeIn {
|
|
from { opacity: 0; }
|
|
to { opacity: 1; }
|
|
}
|
|
.arr_list {
|
|
position: absolute;
|
|
top: 50rpx;
|
|
right: -20rpx;
|
|
background: #FFFFFF;
|
|
width: 140rpx;
|
|
height: 245rpx;
|
|
box-shadow: 0rpx 16rpx 40rpx 0rpx rgba(42, 130, 228, 0.1);
|
|
padding: 5rpx 0;
|
|
box-sizing: border-box;
|
|
border-radius: 10rpx;
|
|
z-index: 99;
|
|
opacity: 0;
|
|
animation-name: fadeIn;
|
|
animation-duration: .5s;
|
|
animation-fill-mode: forwards;
|
|
.arr_item:last-child {
|
|
border: none !important;
|
|
}
|
|
|
|
.arr_item {
|
|
text-align: center;
|
|
height: 60rpx;
|
|
line-height: 60rpx;
|
|
border-bottom: 1px solid #ccc;
|
|
}
|
|
}
|
|
|
|
.picker {
|
|
// margin-top: 30rpx;
|
|
margin-left: 20rpx;
|
|
}
|
|
|
|
.page {
|
|
width: 750rpx;
|
|
.box {
|
|
width: 750rpx;
|
|
background: #F4F5F7;
|
|
border-radius: 0rpx 0rpx 0rpx 0rpx;
|
|
padding-top: 32rpx;
|
|
padding-bottom: 400rpx;
|
|
box-sizing: border-box;
|
|
height: 100vh;
|
|
overflow: scroll;
|
|
overflow: hidden;
|
|
.list {
|
|
width: 654rpx;
|
|
max-height: 100%;
|
|
background: #FFFFFF;
|
|
box-shadow: 0rpx 16rpx 40rpx 0rpx rgba(42, 130, 228, 0.1);
|
|
filter: blur(0px);
|
|
margin: auto;
|
|
border-radius: 30rpx;
|
|
padding: 30rpx 38rpx;
|
|
box-sizing: border-box;
|
|
|
|
.title {
|
|
font-size: 32rpx;
|
|
color: #000000;
|
|
font-weight: 600;
|
|
}
|
|
|
|
input {
|
|
// margin-top: 30rpx;
|
|
// padding-left: 100rpx;
|
|
text-align: right;
|
|
}
|
|
}
|
|
|
|
.trues {
|
|
width: 290rpx;
|
|
height: 84rpx;
|
|
background: #8883F0;
|
|
filter: blur(0px);
|
|
text-align: center;
|
|
line-height: 84rpx;
|
|
position: fixed;
|
|
bottom: 76rpx;
|
|
left: 75%;
|
|
transform: translateX(-50%);
|
|
font-size: 36rpx;
|
|
color: #FFFFFF;
|
|
border-radius: 50rpx;
|
|
}
|
|
|
|
.truess {
|
|
width: 290rpx;
|
|
height: 84rpx;
|
|
background: red;
|
|
filter: blur(0px);
|
|
text-align: center;
|
|
line-height: 84rpx;
|
|
position: fixed;
|
|
bottom: 76rpx;
|
|
right: 33%;
|
|
transform: translateX(-50%);
|
|
font-size: 36rpx;
|
|
color: #FFFFFF;
|
|
border-radius: 50rpx;
|
|
}
|
|
.trueqx {
|
|
width: 290rpx;
|
|
height: 84rpx;
|
|
background: #ccc;
|
|
filter: blur(0px);
|
|
text-align: center;
|
|
line-height: 84rpx;
|
|
position: fixed;
|
|
bottom: 76rpx;
|
|
right: 33%;
|
|
transform: translateX(-50%);
|
|
font-size: 36rpx;
|
|
color: #FFFFFF;
|
|
border-radius: 50rpx;
|
|
}
|
|
}
|
|
}
|
|
</style> |