kaiguan-zfb/page_user/yetx.vue

470 lines
11 KiB
Vue
Raw Normal View History

2024-05-10 17:37:36 +08:00
<template>
<view>
<u-navbar title="余额提现" :border-bottom="false" :background="bgc" title-color='#fff' back-icon-color="#fff" title-size='36'
2024-06-03 16:47:25 +08:00
height='50'></u-navbar>
2024-05-10 17:37:36 +08:00
<view class="cont">
<view class="top_box">
<view class="tip">账户余额()</view>
<view class="txt">
{{userinfo.balance == undefined ? '' : userinfo.balance}}
2024-05-10 17:37:36 +08:00
</view>
<view class="tip">累计提现{{userinfo.withDrawlAmount == undefined ? '' : userinfo.withDrawlAmount}}</view>
2024-05-10 17:37:36 +08:00
</view>
<view class="tit">
2024-07-27 18:43:42 +08:00
<view class="" style="display: flex;">
<view class="tit_line" style="margin-top: 4rpx;"></view>
余额提现
</view>
<view class="" style="color: #8883f0;" @click="btntxrecord">
2024-07-29 18:03:40 +08:00
提现记录
2024-05-10 17:37:36 +08:00
</view>
</view>
<view class="input_box">
<view class="yuan">
</view>
<view class="ipt">
2024-07-30 18:02:27 +08:00
<u-input v-model="money" type="number" @input="change" placeholder='输入自定义金额' placeholder-style='font-size: 24rpx;'/>
2024-05-10 17:37:36 +08:00
</view>
<view class="altx" @click="all()">
全部提现
</view>
</view>
2024-07-29 18:03:40 +08:00
<view class="" style="color: red;font-size: 24rpx;padding-top: 30rpx;box-sizing: border-box;">
2024-07-30 18:02:27 +08:00
提现服务费为 {{roundToTwoDecimalsTraditional(this.serviceRates)}}
</view>
2024-05-10 17:37:36 +08:00
<view class="tit">
2024-07-27 18:43:42 +08:00
<view class="" style="display: flex;">
<view class="tit_line" style="margin-top: 4rpx;">
</view>
提现方式
2024-05-10 17:37:36 +08:00
</view>
2024-07-30 18:02:27 +08:00
</view>
<view class="pay_type" style="width: 100%;">
<view class="type_box" v-if="listflag" v-for="(item,index) in txlist" :key="index" @click="pay(index,item.channelId)">
2024-05-10 17:37:36 +08:00
<view class="box_left">
2024-07-30 18:02:27 +08:00
<image :src="item.picture" mode=""></image>
2024-05-10 17:37:36 +08:00
<view class="text">
2024-07-30 18:02:27 +08:00
{{item.name}}
2024-05-10 17:37:36 +08:00
</view>
</view>
2024-07-30 18:02:27 +08:00
<view class="box_right" :class="currentindex==index?'act1':''">
<span v-if="currentindex==index" style="color: #fff;"> <u-icon style="margin-top: 22rpx;" name="checkbox-mark" color="#fff" size="28"></u-icon> </span>
</view>
</view>
<view v-if="!listflag" class="wutx" style="width: 100%;margin-top: 230rpx;text-align: center;">
<view class="" style="font-size: 32rpx;">
当前暂无提现方式
</view>
<view class="addtj" @click="btnadd">
去添加
2024-05-10 17:37:36 +08:00
</view>
</view>
2024-07-29 18:03:40 +08:00
<!-- <view class="type_box" @click="pay(1,'3')">
<view class="box_left">
<image style="border-radius: 50%;" src="https://api.ccttiot.com/smartmeter/img/static/umHaHtYaD540zBB7NXQ7" mode=""></image>
<view class="text">
银行卡提现
</view>
</view>
<view class="box_right" :class="currentindex==1?'act1':''">
<span v-if="currentindex==1" style="color: #fff;"> <u-icon style="margin-top: 22rpx;" name="checkbox-mark" color="#fff" size="28"></u-icon> </span>
</view>
2024-07-29 18:03:40 +08:00
</view> -->
2024-05-10 17:37:36 +08:00
<!-- <view class="type_box" @click="pay(1,'2')">
<view class="box_left">
<image src="https://api.ccttiot.com/smartmeter/img/static/uRsKrUoCa4XXCKyIMTwb" mode=""></image>
<view class="text">
支付宝提现
</view>
</view>
<view class="box_right" :class="currentindex==1?'act1':''">
<span v-if="currentindex==1"> </span>
</view>
</view> -->
2024-07-29 18:03:40 +08:00
<!-- <view class="type_box" v-for="(item,index) in infoList.BANK_CARD" :key="index" @click="pay(index+2,'3',item.accountNo)">
2024-05-10 17:37:36 +08:00
<view class="box_left">
<image :src="'http://bkaear.market.alicloudapi.com/banklogo/' + item.cardInfo.Icon" mode=""></image>
<view class="text">
{{item.cardInfo.bankName}}
</view>
</view>
<view class="box_right" :class="currentindex==index+2?'act1':''">
<span v-if="currentindex==index+2"> </span>
</view>
2024-07-29 18:03:40 +08:00
</view> -->
2024-05-10 17:37:36 +08:00
</view>
2024-07-30 18:02:27 +08:00
<view class="btn" v-if="listflag" @click="sub()">
2024-05-10 17:37:36 +08:00
确认提现
</view>
</view>
</view>
</template>
<script>
export default {
data() {
return {
bgc: {
2024-05-21 18:02:34 +08:00
backgroundColor: "#8883f0",
2024-05-10 17:37:36 +08:00
},
name:'',
idnum:'',
money:'',
infoList:{},
2024-07-30 18:02:27 +08:00
currentindex:-1,
2024-05-10 17:37:36 +08:00
payType:1,
accountNo:'',
2024-07-29 18:03:40 +08:00
userinfo:{},
serviceType:'',
serviceRate:'',
serviceRates:'',
2024-07-30 18:02:27 +08:00
sjmeoey:'',
txlist:'',
channelId:'',
listflag:true
2024-05-10 17:37:36 +08:00
}
},
onShow() {
2024-07-30 18:02:27 +08:00
this.gettxlist()
2024-07-29 18:03:40 +08:00
this.getfuwu()
2024-05-10 17:37:36 +08:00
this.getinfo()
this.getuserinfo()
},
2024-07-17 17:59:51 +08:00
// 分享到好友(会话)
onShareAppMessage: function () {
return {
title: '创想物联',
path: '/pages/shouye/index'
}
},
// 分享到朋友圈
onShareTimeline: function () {
return {
title: '创想物联',
query: '',
path: '/pages/shouye/index'
}
},
2024-05-10 17:37:36 +08:00
methods: {
2024-07-30 18:02:27 +08:00
// 添加提现方式
btnadd(){
uni.navigateTo({
url:'/page_user/skzh'
})
},
// 获取提现渠道列表
gettxlist(){
this.$u.get('/app/channel/recharge/enabledWithdrawList').then(res => {
if(res.code == 200){
if(res.data.length > 0){
this.listflag = true
this.txlist = res.data
}else{
this.listflag = false
}
}
})
},
2024-07-29 18:03:40 +08:00
change(){
if(this.serviceType == 2){
this.serviceRates = this.serviceRate
this.sjmeoey = Number(this.money) - Number(this.serviceRates)
}else{
let qian = this.money * this.serviceRate / 100
2024-07-30 18:02:27 +08:00
this.serviceRates = qian
2024-07-29 18:03:40 +08:00
this.sjmeoey = Number(this.money) - Number(this.serviceRates)
}
},
2024-07-30 18:02:27 +08:00
// 计算小数
roundToTwoDecimalsTraditional(num) {
return Math.round(num * 100) / 100;
},
2024-07-27 18:43:42 +08:00
// 跳转到提现记录
btntxrecord(){
uni.navigateTo({
url:'/page_user/txrecord'
})
},
2024-05-10 17:37:36 +08:00
getinfo(){
this.$u.get('/app/account' ).then((res) => {
if (res.code == 200) {
2024-07-30 18:02:27 +08:00
// console.log(res)
2024-05-10 17:37:36 +08:00
this.infoList=res.data
}
})
},
2024-07-30 18:02:27 +08:00
pay(index,id){
this.channelId = id
2024-05-10 17:37:36 +08:00
this.currentindex=index
},
all(){
this.money=this.userinfo.balance
2024-07-29 18:03:40 +08:00
if(this.serviceType == 2){
this.serviceRates = this.serviceRate
this.sjmeoey = Number(this.money) - Number(this.serviceRates)
}else{
let qian = this.money * this.serviceRate / 100
this.serviceRates = qian
this.sjmeoey = Number(this.money) - Number(this.serviceRates)
}
},
// 获取提现服务费
getfuwu(){
this.$u.get('/app/bill/getWithdrawService?channelId=1').then((res) => {
if (res.code == 200) {
this.serviceType = res.data.serviceType
this.serviceRate = res.data.serviceRate
if(this.serviceType == 2){
this.serviceRates = this.serviceRate
}else{
this.serviceRates = 0
}
}
})
2024-05-10 17:37:36 +08:00
},
sub(){
if(this.money<20){
uni.showToast({
title: '提现金额不能低于20元',
icon: 'none',
duration: 2000
});
}else if (this.money>this.userinfo.balance){
uni.showToast({
title: '提现金额不能大于余额',
icon: 'none',
duration: 2000
});
2024-07-30 18:02:27 +08:00
}else if(this.currentindex == -1){
uni.showToast({
title: '请选择提现方式',
icon: 'none',
duration: 2000
})
} else{
2024-05-10 17:37:36 +08:00
let data ={
money:this.money,
2024-07-30 18:02:27 +08:00
arrivalAmount:this.roundToTwoDecimalsTraditional(Number(this.money) - Number(this.roundToTwoDecimalsTraditional(this.serviceRates))),
serviceCharge:this.roundToTwoDecimalsTraditional(this.serviceRates),
channelId:this.channelId,
2024-07-29 18:03:40 +08:00
serviceRate:this.serviceRate , //服务费
serviceType:this.serviceType //服务费收取方式
2024-05-10 17:37:36 +08:00
}
this.$u.post('/app/bill/withdraw',data).then((res) => {
if (res.code == 200) {
this.getuserinfo()
uni.showToast({
title: '提现成功',
icon: 'none',
duration: 2000
2024-07-30 18:02:27 +08:00
})
this.serviceRates = 0
2024-05-10 17:37:36 +08:00
}
})
}
},
getuserinfo() {
this.$u.get("/app/user/userInfo").then((res) => {
// this.$forceUpdate()
if (res.code == 200) {
this.userinfo=res.data
2024-05-24 16:48:42 +08:00
this.money = ''
// console.log(this.userinfo);
2024-05-10 17:37:36 +08:00
}
});
},
}
}
</script>
<style lang="scss" >
2024-05-24 16:48:42 +08:00
/deep/ .u-title{
2024-06-03 16:47:25 +08:00
padding-bottom: 22rpx;
2024-05-24 16:48:42 +08:00
}
/deep/ .u-icon__icon{
2024-06-03 16:47:25 +08:00
padding-bottom: 22rpx;
2024-05-24 16:48:42 +08:00
}
2024-05-10 17:37:36 +08:00
page{
background: #F7FAFE;
}
2024-07-30 18:02:27 +08:00
.addtj{
margin-top: 44rpx;
width: 646rpx;
height: 88rpx;
background: #E4E3FB;
box-shadow: 0rpx 16rpx 40rpx 0rpx rgba(42, 130, 228, 0.1);
border-radius: 20rpx 20rpx 20rpx 20rpx;
text-align: center;
line-height: 88rpx;
font-size: 36rpx;
color: #8883F0;
}
2024-05-10 17:37:36 +08:00
.cont{
display: flex;
// justify-content: center;
flex-wrap: wrap;
margin: 0 auto;
width: 634rpx;
.top_box{
padding: 28rpx 32rpx;
margin-top: 38rpx;
width: 634rpx;
height: 246rpx;
background: #8883F0;
border-radius: 28rpx 28rpx 28rpx 28rpx;
border-radius: 20rpx;
.tip{
font-weight: 400;
font-size: 28rpx;
color: #FFFFFF;
line-height: 38rpx;
}
.txt{
margin-top: 28rpx;
margin-bottom: 28rpx;
font-weight: 500;
font-size: 40rpx;
color: #FFFFFF;
line-height: 54rpx;
}
}
.tit{
margin-top: 38rpx;
display: flex;
flex-wrap: nowrap;
align-items: center;
font-weight: 500;
font-size: 28rpx;
color: #3D3D3D;
line-height: 38rpx;
2024-07-27 18:43:42 +08:00
display: flex;
justify-content: space-between;
width: 100%;
2024-05-10 17:37:36 +08:00
.tit_line{
margin-right: 12rpx;
width: 4rpx;
height: 32rpx;
background: #8883F0;
border-radius: 0rpx 0rpx 0rpx 0rpx;
}
}
.input_box{
display: flex;
flex-wrap: nowrap;
align-items: center;
margin-top: 36rpx;
width: 634rpx;
height: 86rpx;
background: #FFFFFF;
box-shadow: 0rpx 16rpx 40rpx 0rpx rgba(42,130,228,0.1);
border-radius: 20rpx;
.yuan{
margin-left: 36rpx;
font-weight: 500;
font-size: 52rpx;
color: #8883F0;
line-height: 72rpx;
}
.ipt{
width: 60%;
2024-07-29 18:03:40 +08:00
// .u-input::placeholder {
// font-size: 20px;
// color: red;
// }
2024-05-10 17:37:36 +08:00
}
.altx{
display: flex;
align-items: center;
justify-content: center;
width: 158rpx;
height: 56rpx;
background: #FFFFFF;
box-shadow: 0rpx 0rpx 8rpx 0rpx rgba(0,0,0,0.2);
border-radius: 12rpx 12rpx 12rpx 12rpx;
font-weight: 400;
font-size: 28rpx;
color: #8883F0;
line-height: 38rpx;
}
}
.pay_type{
.type_box{
width: 100%;
margin-top: 26rpx;
display: flex;
align-items: center;
flex-wrap: nowrap;
width: 634rpx;
height: 86rpx;
background: #FFFFFF;
box-shadow: 0rpx 16rpx 40rpx 0rpx rgba(42,130,228,0.1);
border-radius: 20rpx;
.box_left{
display: flex;
align-items: center;
flex-wrap: nowrap;
margin-left:22rpx ;
image{
width: 50rpx;
height: 50rpx;
}
.text{
margin-left: 30rpx;
font-weight: 400;
font-size: 32rpx;
color: #3D3D3D;
line-height: 44rpx;
}
}
.box_right{
display: flex;
align-items: center;
justify-content: center;
margin-left: auto;
margin-right: 34rpx;
width: 44rpx;
height: 44rpx;
border: 2rpx solid #444444 ;
border-radius: 50%;
}
.act1{
color: #FFFFFF;
background-color: #8883F0;
}
}
}
.btn{
margin-left: 20rpx;
display: flex;
align-items: center;
justify-content: center;
margin-top: 218rpx;
width: 590rpx;
height: 84rpx;
2024-05-21 18:02:34 +08:00
background: #8883f0;
2024-05-10 17:37:36 +08:00
border-radius: 40rpx;
font-family: AlibabaPuHuiTi, AlibabaPuHuiTi;
font-weight: 400;
font-size: 36rpx;
color: #FFFFFF;
}
}
</style>