434 lines
8.8 KiB
Vue
434 lines
8.8 KiB
Vue
|
<template>
|
|||
|
<view class="recharge">
|
|||
|
<view class="block">
|
|||
|
<view class="title">
|
|||
|
我的账户
|
|||
|
</view>
|
|||
|
<view class="content">
|
|||
|
<view class="my">
|
|||
|
我的账户余额:
|
|||
|
<text class="balance" :class="'text-' + themeColor.name">{{
|
|||
|
(userInfo.allPredeposit ) || '0'
|
|||
|
}}</text>
|
|||
|
元
|
|||
|
</view>
|
|||
|
</view>
|
|||
|
</view>
|
|||
|
<view class="block">
|
|||
|
<view class="title">
|
|||
|
充值金额
|
|||
|
</view>
|
|||
|
<view class="content">
|
|||
|
<view class="amount">
|
|||
|
<view class="list">
|
|||
|
<view
|
|||
|
class="box"
|
|||
|
v-for="(amount, index) in amountList"
|
|||
|
:key="index"
|
|||
|
@tap="select(amount)"
|
|||
|
:class="amount.price == inputAmount ? 'bg-' + themeColor.name : 'on'"
|
|||
|
>
|
|||
|
<view class="real">{{ amount.price }}元</view>
|
|||
|
<text class="give">赠送 {{ amount.give_price }}元</text>
|
|||
|
</view>
|
|||
|
</view>
|
|||
|
<view class="num">
|
|||
|
<view class="text">
|
|||
|
自定义充值金额
|
|||
|
</view>
|
|||
|
<view class="input">
|
|||
|
<input
|
|||
|
type="number"
|
|||
|
:class="'text-' + themeColor.name"
|
|||
|
@input="handleInputAmountChange"
|
|||
|
v-model="inputAmount"
|
|||
|
/>
|
|||
|
</view>
|
|||
|
<text class="give" :class="'text-' + themeColor.name" v-if="inputAmountGive > 0"
|
|||
|
>赠送 {{ inputAmountGive }}元</text
|
|||
|
>
|
|||
|
</view>
|
|||
|
</view>
|
|||
|
</view>
|
|||
|
</view>
|
|||
|
<view class="block">
|
|||
|
<view class="title">
|
|||
|
选择支付方式
|
|||
|
</view>
|
|||
|
<view class="content">
|
|||
|
<view class="pay-list">
|
|||
|
<!-- #ifndef MP-WEIXIN -->
|
|||
|
<view class="row" @tap="payType = '2'" v-if="parseInt(payTypeList.order_ali_pay, 10) === 1 && !isWechat">
|
|||
|
<text class="icon iconfont iconalipay"></text>
|
|||
|
<view class="center">
|
|||
|
支付宝支付
|
|||
|
</view>
|
|||
|
<view class="right">
|
|||
|
<radio :checked="payType == '2'" :color="themeColor.color" />
|
|||
|
</view>
|
|||
|
</view>
|
|||
|
<!--#endif-->
|
|||
|
<view class="row" @tap="payType = '1'" v-if="parseInt(payTypeList.order_wechat_pay, 10) === 1">
|
|||
|
<i class="icon iconfont iconweixinzhifu"></i>
|
|||
|
<view class="center">
|
|||
|
微信支付
|
|||
|
</view>
|
|||
|
<view class="right">
|
|||
|
<radio :checked="payType == '1'" :color="themeColor.color" />
|
|||
|
</view>
|
|||
|
</view>
|
|||
|
</view>
|
|||
|
</view>
|
|||
|
</view>
|
|||
|
<view class="pay">
|
|||
|
<view class="btn" :class="'bg-' + themeColor.name" @tap="pay">立即充值</view>
|
|||
|
<view class="tis">
|
|||
|
点击立即充值,即代表您同意
|
|||
|
<view class="terms" @tap="toTipDetail">
|
|||
|
《充值协议》
|
|||
|
</view>
|
|||
|
</view>
|
|||
|
</view>
|
|||
|
<!--加载动画-->
|
|||
|
<rfLoading isFullScreen :active="pageLoading"></rfLoading>
|
|||
|
</view>
|
|||
|
</template>
|
|||
|
|
|||
|
<script>
|
|||
|
import { memberInfo, rechargeConfigIndex } from '@/api/userInfo';
|
|||
|
import { configList } from '@/api/basic';
|
|||
|
export default {
|
|||
|
data() {
|
|||
|
return {
|
|||
|
inputAmount: 0, // 金额
|
|||
|
inputAmountGive: 0, // 金额
|
|||
|
amountList: [{price:0.01,give_price:5},{price:100,give_price:10},{price:200,give_price:20}], // 预设3个可选快捷金额
|
|||
|
payType: 1, // 支付类型
|
|||
|
userInfo: {},
|
|||
|
loading: false,
|
|||
|
providerList: [],
|
|||
|
payTypeList: {order_ali_pay: 1,order_wechat_pay: 1},
|
|||
|
isWechat: this.$mPayment.isWechat(),
|
|||
|
pageLoading: true,
|
|||
|
code: ''
|
|||
|
};
|
|||
|
},
|
|||
|
onLoad(options) {
|
|||
|
this.initData(options);
|
|||
|
|
|||
|
},
|
|||
|
methods: {
|
|||
|
// 计算充值送的钱 后台配置
|
|||
|
handleInputAmountChange(e) {
|
|||
|
this.inputAmount = parseFloat(e.detail.value);
|
|||
|
if (this.inputAmount < this.amountList[0].price) {
|
|||
|
this.inputAmountGive = 0;
|
|||
|
return;
|
|||
|
}
|
|||
|
if (
|
|||
|
this.inputAmount >= this.amountList[this.amountList.length - 1].price
|
|||
|
) {
|
|||
|
this.inputAmountGive = this.amountList[
|
|||
|
this.amountList.length - 1
|
|||
|
].give_price;
|
|||
|
return;
|
|||
|
}
|
|||
|
for (let i = 0; i < this.amountList.length; i++) {
|
|||
|
if (
|
|||
|
this.inputAmount >= this.amountList[i].price &&
|
|||
|
this.inputAmount < this.amountList[i + 1].price
|
|||
|
) {
|
|||
|
this.inputAmountGive = this.amountList[i].give_price;
|
|||
|
}
|
|||
|
}
|
|||
|
},
|
|||
|
async pay() {
|
|||
|
if (this.payTypeList.order_ali_pay === '0' && this.payTypeList.order_wechat_pay === '0') return;
|
|||
|
const params = {};
|
|||
|
params.money = parseFloat(this.inputAmount);
|
|||
|
switch (parseInt(this.payType, 10)) {
|
|||
|
case 1: // 微信支付
|
|||
|
await this.$mPayment.weixinRecharge('recharge', params, '/pages/user/account/account', this.code);
|
|||
|
break;
|
|||
|
case 2: // 支付宝支付
|
|||
|
await this.$mPayment.aliPayRecharge('recharge', params, '/pages/user/account/account');
|
|||
|
break;
|
|||
|
default:
|
|||
|
break;
|
|||
|
}
|
|||
|
},
|
|||
|
// 充值成功后更新用户信息
|
|||
|
async getMemberInfo() {
|
|||
|
this.$http.get(memberInfo).then(r => {
|
|||
|
uni.setStorage({
|
|||
|
key: 'userInfo',
|
|||
|
data: r
|
|||
|
});
|
|||
|
this.userInfo = r || undefined;
|
|||
|
});
|
|||
|
},
|
|||
|
toTipDetail() {
|
|||
|
this.$mRouter.push({
|
|||
|
route: '/pages/set/about/detail?field=protocol_recharge&title=充值协议'
|
|||
|
});
|
|||
|
},
|
|||
|
// 初始化数据
|
|||
|
async initData(options) {
|
|||
|
this.code = options.code;
|
|||
|
this.userInfo = uni.getStorageSync('userInfo') || undefined;
|
|||
|
|
|||
|
this.pageLoading = false;
|
|||
|
|
|||
|
// #ifdef H5
|
|||
|
if (uni.getSystemInfoSync().platform === 'android') {
|
|||
|
await this.$mPayment.wxConfigH5(window.location.href);
|
|||
|
}
|
|||
|
// #endif
|
|||
|
// #ifdef APP-PLUS
|
|||
|
uni.getProvider({
|
|||
|
service: 'payment',
|
|||
|
success: e => {
|
|||
|
let providerList = [];
|
|||
|
e.provider.map(value => {
|
|||
|
switch (value) {
|
|||
|
case 'alipay':
|
|||
|
providerList.push({
|
|||
|
name: '支付宝',
|
|||
|
id: value,
|
|||
|
loading: false
|
|||
|
});
|
|||
|
break;
|
|||
|
case 'wxpay':
|
|||
|
providerList.push({
|
|||
|
name: '微信',
|
|||
|
id: value,
|
|||
|
loading: false
|
|||
|
});
|
|||
|
break;
|
|||
|
default:
|
|||
|
break;
|
|||
|
}
|
|||
|
});
|
|||
|
this.providerList = providerList;
|
|||
|
},
|
|||
|
fail: e => {}
|
|||
|
});
|
|||
|
// #endif
|
|||
|
},
|
|||
|
// 获取支付类型列表
|
|||
|
async getPayTypeList() {
|
|||
|
await this.$http
|
|||
|
.get(`${configList}`, {
|
|||
|
field: 'order_balance_pay,order_wechat_pay,order_ali_pay'
|
|||
|
})
|
|||
|
.then(r => {
|
|||
|
this.payTypeList = r;
|
|||
|
});
|
|||
|
},
|
|||
|
select(item) {
|
|||
|
this.inputAmount = item.price;
|
|||
|
this.inputAmountGive = item.give_price;
|
|||
|
}
|
|||
|
}
|
|||
|
};
|
|||
|
</script>
|
|||
|
|
|||
|
<style lang="scss">
|
|||
|
page {
|
|||
|
background-color: $color-white;
|
|||
|
}
|
|||
|
|
|||
|
.block {
|
|||
|
width: 100%;
|
|||
|
padding: 20upx;
|
|||
|
|
|||
|
.title {
|
|||
|
width: 100%;
|
|||
|
font-size: 34upx;
|
|||
|
}
|
|||
|
|
|||
|
.content {
|
|||
|
.my {
|
|||
|
width: 100%;
|
|||
|
height: 120upx;
|
|||
|
display: flex;
|
|||
|
align-items: center;
|
|||
|
font-size: $font-lg;
|
|||
|
border-bottom: solid 1upx #eee;
|
|||
|
|
|||
|
.balance {
|
|||
|
margin-right: 6upx;
|
|||
|
font-size: $font-lg + 4upx;
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
.amount {
|
|||
|
width: 100%;
|
|||
|
|
|||
|
.list {
|
|||
|
display: flex;
|
|||
|
justify-content: space-between;
|
|||
|
padding-top: 20upx;
|
|||
|
flex-wrap: wrap;
|
|||
|
|
|||
|
.box {
|
|||
|
width: 31%;
|
|||
|
margin-bottom: 20upx;
|
|||
|
height: 120upx;
|
|||
|
text-align: center;
|
|||
|
border-radius: 10upx;
|
|||
|
box-shadow: 0upx 5upx 20upx rgba(0, 0, 0, 0.05);
|
|||
|
&.on {
|
|||
|
background-color: #f1f1f1;
|
|||
|
color: #333;
|
|||
|
}
|
|||
|
|
|||
|
.real {
|
|||
|
font-size: $font-lg;
|
|||
|
margin-top: 10upx;
|
|||
|
}
|
|||
|
|
|||
|
.give {
|
|||
|
display: block;
|
|||
|
font-size: $font-sm;
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
.num {
|
|||
|
margin-top: 10upx;
|
|||
|
display: flex;
|
|||
|
justify-content: flex-end;
|
|||
|
align-items: center;
|
|||
|
|
|||
|
.text {
|
|||
|
padding-right: 10upx;
|
|||
|
font-size: 30upx;
|
|||
|
}
|
|||
|
|
|||
|
.give {
|
|||
|
font-size: $font-sm;
|
|||
|
}
|
|||
|
|
|||
|
.input {
|
|||
|
width: 28.2vw;
|
|||
|
border-bottom: solid 2upx;
|
|||
|
justify-content: flex-end;
|
|||
|
align-items: center;
|
|||
|
|
|||
|
input {
|
|||
|
margin: 0 20upx;
|
|||
|
height: 60upx;
|
|||
|
font-size: 30upx;
|
|||
|
justify-content: flex-end;
|
|||
|
align-items: center;
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
.pay-list {
|
|||
|
width: 100%;
|
|||
|
border-bottom: solid 1upx #eee;
|
|||
|
|
|||
|
.row {
|
|||
|
width: 100%;
|
|||
|
height: 120upx;
|
|||
|
display: flex;
|
|||
|
align-items: center;
|
|||
|
|
|||
|
.icon {
|
|||
|
width: 100upx;
|
|||
|
font-size: 52upx;
|
|||
|
margin-left: 15upx;
|
|||
|
}
|
|||
|
|
|||
|
.iconerjiye-yucunkuan {
|
|||
|
color: #fe8e2e;
|
|||
|
}
|
|||
|
|
|||
|
.iconweixinzhifu {
|
|||
|
color: #36cb59;
|
|||
|
}
|
|||
|
|
|||
|
.iconalipay {
|
|||
|
color: #01aaef;
|
|||
|
}
|
|||
|
|
|||
|
.center {
|
|||
|
width: 100%;
|
|||
|
font-size: 30upx;
|
|||
|
}
|
|||
|
|
|||
|
.right {
|
|||
|
width: 100upx;
|
|||
|
flex-shrink: 0;
|
|||
|
display: flex;
|
|||
|
justify-content: flex-end;
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
.pay {
|
|||
|
margin-top: 20upx;
|
|||
|
width: 100%;
|
|||
|
display: flex;
|
|||
|
justify-content: center;
|
|||
|
flex-wrap: wrap;
|
|||
|
|
|||
|
.btn {
|
|||
|
width: 70%;
|
|||
|
height: 80upx;
|
|||
|
border-radius: 80upx;
|
|||
|
display: flex;
|
|||
|
justify-content: center;
|
|||
|
align-items: center;
|
|||
|
color: #fff;
|
|||
|
box-shadow: 0upx 5upx 10upx rgba(0, 0, 0, 0.2);
|
|||
|
}
|
|||
|
|
|||
|
.tis {
|
|||
|
margin-top: 10upx;
|
|||
|
width: 100%;
|
|||
|
font-size: 24upx;
|
|||
|
display: flex;
|
|||
|
justify-content: center;
|
|||
|
align-items: baseline;
|
|||
|
color: #999;
|
|||
|
|
|||
|
.terms {
|
|||
|
color: #5a9ef7;
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
.rmbLogo {
|
|||
|
font-size: 40upx;
|
|||
|
}
|
|||
|
|
|||
|
button {
|
|||
|
background-color: #007aff;
|
|||
|
color: #ffffff;
|
|||
|
}
|
|||
|
|
|||
|
.uni-h1.uni-center {
|
|||
|
display: flex;
|
|||
|
flex-direction: row;
|
|||
|
justify-content: center;
|
|||
|
align-items: flex-end;
|
|||
|
}
|
|||
|
|
|||
|
.price {
|
|||
|
border-bottom: 1px solid #eee;
|
|||
|
width: 200upx;
|
|||
|
height: 80upx;
|
|||
|
padding-bottom: 4upx;
|
|||
|
}
|
|||
|
|
|||
|
.ipaPayBtn {
|
|||
|
margin-top: 30upx;
|
|||
|
}
|
|||
|
</style>
|