oil-station/gasStation-uni/pagesMy/fleetMember/addMember.vue

282 lines
6.9 KiB
Vue
Raw Normal View History

2024-09-23 13:41:19 +08:00
<template>
2024-10-16 13:28:52 +08:00
<view class="content">
<view class="container">
<view class="box-hang">
<view class=""><span style="color: red;">*</span>姓名</view>
<view class="dis">
<input v-model="memberInfo.name" style="text-align: right;" placeholder="请输入"></input>
</view>
</view>
<view class="box-hang">
<view class=""><span style="color: red;">*</span>手机号</view>
<view class="dis">
<input v-model="memberInfo.mobile" style="text-align: right;" placeholder="请输入"></input>
</view>
</view>
<view class="box-hang">
<view class="">会员卡号</view>
<view class="dis">
<input v-model="memberInfo.userCardNum" style="text-align: right;" placeholder="请输入"></input>
</view>
</view>
<view class="box-hang">
<view class="">车牌号</view>
<view class="dis" @click="show1 = !show1">
<input v-model="memberInfo.carNum" style="text-align: right;" placeholder="请输入"></input>
</view>
</view>
<view class="box-hang">
<view class=""><span style="color: red;">*</span>副卡类型</view>
<view class="dis" @click="show = !show">
<text v-if="memberInfo.secondaryCardType==1">共享副卡-不限额</text>
<text v-if="memberInfo.secondaryCardType==2">共享副卡-限额</text>
<text v-if="memberInfo.secondaryCardType==3">独立副卡</text>
<uni-icons type="right" size="16"></uni-icons>
</view>
</view>
<view class="box-hang" style="margin-top: 10px;">
<view class=""><span style="color: red;">*</span>是否开启消费通知</view>
<view class="dis">
<u-switch v-model="memberInfo.isOpenNotice" :activeValue='0' :inactiveValue='1' activeColor="#6DD400"
inactiveColor="rgb(230, 230, 230)"></u-switch>
</view>
</view>
<view class="box-hang">
<view class=""><span style="color: red;">*</span>是否启用</view>
<view class="dis">
<u-switch v-model="memberInfo.status" activeValue='qy' inactiveValue='jy' activeColor="#6DD400"
inactiveColor="rgb(230, 230, 230)"></u-switch>
</view>
</view>
<view class="box-end">
<view style="display: flex;">
<view style="height: 14px;margin-right: 5px;">
<u-icon name="info-circle"></u-icon>
</view>
<view></view>
</view>
<view>
<view>共享副卡-不限额副卡与主卡共享钱包同步余额</view>
<view>共享副卡-限额副卡与主卡共享钱包副卡可设置限额</view>
<view>独立副卡副卡与主卡独立钱包独立余额</view>
</view>
</view>
2024-09-23 13:41:19 +08:00
2024-10-16 13:28:52 +08:00
<view class="but-sub" @click="submitFrom()">保存</view>
2024-09-23 13:41:19 +08:00
2024-10-16 13:28:52 +08:00
<u-picker :show="show" :columns="columns" @cancel="cancel" @confirm="confirm"></u-picker>
<u-keyboard ref="uKeyboard" mode="car" @change="valChange" @backspace="backspace" :show="show1"
@confirm="confirm1" @cancel="cancel1" :overlay="false"></u-keyboard>
</view>
2024-09-23 13:41:19 +08:00
2024-10-16 13:28:52 +08:00
</view>
2024-09-23 13:41:19 +08:00
</template>
<script>
2024-10-16 13:28:52 +08:00
import request from '../../utils/request';
2024-09-23 13:41:19 +08:00
2024-10-16 13:28:52 +08:00
export default {
data() {
return {
title: '',
List: [],
pageNo: 1,
pageSize: 10,
totalPage: '',
value: "",
value1: true,
value2: true,
show: false,
show1: false,
columns: [
['共享副卡-不限额', '共享副卡-限额', '独立副卡']
],
memberInfo: {
carNum: '',
isOpenNotice: '0',
status: 'qy',
secondaryCardType: 1
},
fleetId: '',
memberId: '',
}
},
onLoad(e) {
if (e.fleetId) {
this.fleetId = e.fleetId
this.memberInfo.fleetId = e.fleetId
}
if (e.memberId) {
this.memberId = e.memberId
this.getInfo()
}
},
onPullDownRefresh() {
//下拉刷新
2024-09-27 17:33:11 +08:00
2024-10-16 13:28:52 +08:00
},
onReachBottom() {
// 触底加载
if (this.pageNo >= this.totalPage) {
2024-09-23 13:41:19 +08:00
2024-10-16 13:28:52 +08:00
} else {
this.pageNo++
2024-09-23 13:41:19 +08:00
2024-10-16 13:28:52 +08:00
}
},
2024-09-23 13:41:19 +08:00
2024-10-16 13:28:52 +08:00
components: {},
methods: {
getInfo() {
request({
url: '/fleetMember/' + this.memberId,
method: 'get',
}).then(res => {
this.memberInfo = res.data
})
},
submitFrom() {
if (!this.memberInfo.name) {
uni.showToast({
title: '姓名不能为空',
icon: 'none'
})
return
}
if (!this.memberInfo.mobile) {
uni.showToast({
title: '手机号不能为空',
icon: 'none'
})
return
}
if (this.memberInfo.id) {
request({
url: '/fleetMember',
method: 'put',
data: this.memberInfo
}).then(res => {
uni.navigateBack()
})
} else {
request({
url: '/fleetMember/addUni',
method: 'post',
data: this.memberInfo
}).then(res => {
if (res.data == 0) {
uni.showToast({
title: '该用户已绑定车队',
icon: 'none'
})
}else {
uni.navigateBack()
}
})
}
},
// 按键被点击(点击退格键不会触发此事件)
valChange(val) {
// 将每次按键的值拼接到value变量中注意+=写法
this.memberInfo.carNum += val
},
// 退格键被点击
backspace() {
// 删除value的最后一个字符
if (this.memberInfo.carNum.length) this.memberInfo.carNum = this.memberInfo.carNum.substr(0, this
.memberInfo.carNum.length - 1);
},
cancel1() {
this.show1 = false
},
confirm1() {
this.show1 = false
},
cancel() {
this.show = false
},
confirm(e) {
this.memberInfo.secondaryCardType = e.indexs[0] + 1
this.show = false
},
goback() {
uni.navigateBack()
}
}
}
2024-09-23 13:41:19 +08:00
</script>
<style scoped lang="scss">
2024-10-16 13:28:52 +08:00
.content {
background: #f4f5f6;
}
2024-09-23 13:41:19 +08:00
2024-10-16 13:28:52 +08:00
.container {
width: 100%;
height: 100vh;
box-sizing: border-box;
padding-top: 10px;
}
2024-09-23 13:41:19 +08:00
2024-10-16 13:28:52 +08:00
.my-header {
width: 100%;
height: 88px;
background: #ffffff;
display: flex;
align-items: center;
justify-content: space-between;
color: #000;
box-sizing: border-box;
padding: 0px 15px;
padding-top: 40px;
z-index: 99999;
2024-09-23 13:41:19 +08:00
2024-10-16 13:28:52 +08:00
.my-icons {
width: 20px;
2024-09-23 13:41:19 +08:00
2024-10-16 13:28:52 +08:00
}
2024-09-23 13:41:19 +08:00
2024-10-16 13:28:52 +08:00
position: fixed;
top: 0px;
}
2024-09-23 13:41:19 +08:00
2024-10-16 13:28:52 +08:00
.box-hang {
background-color: white;
width: 100%;
display: flex;
align-items: center;
justify-content: space-between;
box-sizing: border-box;
padding: 15px 15px;
border-bottom: 1px solid #f4f5f6;
}
2024-09-23 13:41:19 +08:00
2024-10-16 13:28:52 +08:00
.dis {
color: #a69999;
}
2024-09-23 13:41:19 +08:00
2024-10-16 13:28:52 +08:00
.box-end {
margin-top: 10px;
display: flex;
color: #999999;
font-size: 12px;
padding: 0 15px;
}
2024-09-23 13:41:19 +08:00
2024-10-16 13:28:52 +08:00
.but-sub {
width: 305px;
height: 40px;
line-height: 40px;
margin: 0 auto;
background-color: #FF9655;
color: white;
border-radius: 50px;
text-align: center;
position: absolute;
bottom: 40px;
left: 11%;
}
</style>