You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
580 lines
15 KiB
580 lines
15 KiB
11 months ago
|
<template>
|
||
|
|
||
|
<BaseContainer class="gold-coin">
|
||
|
<NavBar title="金币充值" />
|
||
|
<view class="header">
|
||
|
<view class="cont">
|
||
|
<view class="text">
|
||
|
我的{{ gold_name }}
|
||
|
<view class="num">{{ amount }}</view>
|
||
|
</view>
|
||
|
<navigator class="link" url="/pages/my/gold_coin">明细</navigator>
|
||
|
</view>
|
||
|
</view>
|
||
|
<view class="main" v-if="updateOptions.length">
|
||
|
<!-- 数量选择 -->
|
||
|
<view class="wrap select">
|
||
|
<view class="head">数量选择</view>
|
||
|
<view class="cont">
|
||
|
<view class="list">
|
||
|
<view v-for="(item, index) in updateOptions" :class="{active :coinChecked===index}"
|
||
|
@click="handleToggleOptions(index)" :key="index" class="item pos">
|
||
|
<view class="item-cont" :class="{ active: coinChecked == item }">
|
||
|
<view class="text">
|
||
|
<view :style="{ backgroundImage: 'url(' + gold_image + ')' }" class="num">
|
||
|
{{ item.coin }}
|
||
|
</view>
|
||
|
{{ item.money }}元
|
||
|
</view>
|
||
|
</view>
|
||
|
<view class="abs full" :data-idx="index"></view>
|
||
|
</view>
|
||
|
</view>
|
||
|
<view :class="{ checked: coinChecked === options.length }" class="input">
|
||
|
<view class="cell flex flex-center-x">
|
||
|
<input v-model.number="moneyInput" :class="{ on: !moneyInput }" type="number" @focus="inputFocus"
|
||
|
@blur="inputBlur" />
|
||
|
元
|
||
|
</view>
|
||
|
<view :style="{ backgroundImage: 'url(' + gold_image + ')' }" class="cell">
|
||
|
{{ moneyToCoin }}
|
||
|
</view>
|
||
|
</view>
|
||
|
</view>
|
||
|
</view>
|
||
|
<view class="handle">
|
||
|
<view class="btn flex flex-center" @click="callPay">立即充值</view>
|
||
|
</view>
|
||
|
</view>
|
||
|
|
||
|
<!-- 支付弹窗 -->
|
||
|
<PayDialog :open.sync="payDialogOpen" :money="moneyPay" :now_money="now_money" :special_id="moneyPay"
|
||
|
:pay_type_num="payTypeNum" :is-Wechat="isWechat" :is-alipay="is_alipay" :is-balance="is_yue" :wxpay-h5="wxpayH5"
|
||
|
@change="changeVal" />
|
||
|
</BaseContainer>
|
||
|
</template>
|
||
|
|
||
|
<script>
|
||
|
import { getRechargeInitData, getUserGoldNum, aliPayApp, aliPayWap } from "@/api/special";
|
||
|
import PayDialog from "@/components/PayDialog/index.vue";
|
||
|
|
||
|
export default {
|
||
|
components: {
|
||
|
PayDialog,
|
||
|
},
|
||
|
data() {
|
||
|
return {
|
||
|
// 我的金币
|
||
|
gold_name: "金币",
|
||
|
gold_image: "",
|
||
|
amount: 0,
|
||
|
// 换算率
|
||
|
rate: 10,
|
||
|
// 金币选项
|
||
|
options: [],
|
||
|
// 选中金额
|
||
|
coinChecked: 0,
|
||
|
// 输入金额
|
||
|
moneyInput: 0,
|
||
|
// 支付方式选中项
|
||
|
payChecked: 0,
|
||
|
// 是否显示支付弹窗
|
||
|
payDialogOpen: false,
|
||
|
// 登录弹窗隐藏
|
||
|
loginShow: false,
|
||
|
loginUrl: "",
|
||
|
siteName: "",
|
||
|
payTypeNum: 30, //金币充值
|
||
|
is_alipay: false, //支付宝是否开启
|
||
|
is_yue: false, //余额是否开启
|
||
|
now_money: 0, //余额
|
||
|
urlStr: "",
|
||
|
from: "my",
|
||
|
streamName: "",
|
||
|
wxpayH5: false,
|
||
|
site_name: "",
|
||
|
isOpenWeixing: false
|
||
|
};
|
||
|
},
|
||
|
computed: {
|
||
|
updateOptions() {
|
||
|
var that = this,
|
||
|
Obj = {},
|
||
|
Arr = [];
|
||
|
that.options.map(function (value) {
|
||
|
Obj.coin = value;
|
||
|
Obj.money = (value / that.rate).toFixed(2);
|
||
|
Arr.push(Obj);
|
||
|
Obj = {};
|
||
|
});
|
||
|
return Arr;
|
||
|
},
|
||
|
// 金额换算金币
|
||
|
moneyToCoin() {
|
||
|
return this.moneyInput * this.rate;
|
||
|
},
|
||
|
// 支付金额
|
||
|
moneyPay() {
|
||
|
return this.coinChecked == -1
|
||
|
? this.moneyInput
|
||
|
: this.options[this.coinChecked] / this.rate;
|
||
|
},
|
||
|
// 是否微信
|
||
|
isWechat() {
|
||
|
return false;
|
||
|
// var agent = navigator.userAgent.toLowerCase();
|
||
|
// return agent.match(/MicroMessenger/i) == "micromessenger";
|
||
|
},
|
||
|
},
|
||
|
onShow() {
|
||
|
if (this.isOpenWeixing && this.orderId) {
|
||
|
this.$util.wxh5PayIsSuccess(this.orderId, 3, this)
|
||
|
this.isOpenWeixing = false
|
||
|
}
|
||
|
},
|
||
|
onLoad({ from }) {
|
||
|
if (from) this.from = from;
|
||
|
this.getData();
|
||
|
this.my_user_gold_num();
|
||
|
},
|
||
|
methods: {
|
||
|
handleToggleOptions(e) {
|
||
|
this.coinChecked = e;
|
||
|
},
|
||
|
getData() {
|
||
|
getRechargeInitData().then(({ data }) => {
|
||
|
const {
|
||
|
gold_name,
|
||
|
recharge_price_list,
|
||
|
gold_info,
|
||
|
user_info,
|
||
|
is_yue,
|
||
|
wxpayH5,
|
||
|
is_alipay,
|
||
|
callback_url,
|
||
|
site_name,
|
||
|
} = data;
|
||
|
Object.assign(this, {
|
||
|
now_money: Number(user_info.now_money),
|
||
|
is_alipay: is_alipay == 1,
|
||
|
is_yue: is_yue == 1,
|
||
|
wxpayH5: wxpayH5 == 1,
|
||
|
site_name,
|
||
|
callback_url,
|
||
|
gold_name: gold_name || "金币",
|
||
|
gold_image: gold_info.gold_image,
|
||
|
rate: gold_info.gold_rate ? gold_info.gold_rate : 10,
|
||
|
options: recharge_price_list,
|
||
|
});
|
||
|
});
|
||
|
},
|
||
|
// 获取我的金币总数
|
||
|
my_user_gold_num() {
|
||
|
getUserGoldNum().then(({ data }) => {
|
||
|
this.amount = data.user_gold_num;
|
||
|
});
|
||
|
},
|
||
|
getUrlStr(name) {
|
||
|
let pattern = new RegExp("(^|&)" + name + "=([^&]*)(&|$)", "i"),
|
||
|
array = document.location.search.slice(1).match(pattern);
|
||
|
if (array) {
|
||
|
return decodeURI(array[2]);
|
||
|
}
|
||
|
return null;
|
||
|
},
|
||
|
inputFocus() {
|
||
|
this.coinChecked = -1;
|
||
|
if (this.moneyInput) {
|
||
|
this.moneyInput = "";
|
||
|
}
|
||
|
},
|
||
|
inputBlur() {
|
||
|
if (!this.moneyInput) {
|
||
|
this.moneyInput = 0;
|
||
|
this.coinChecked = 0;
|
||
|
}
|
||
|
},
|
||
|
// 支付弹窗调起
|
||
|
callPay() {
|
||
|
if (this.coinChecked == -1 && this.moneyInput <= 0)
|
||
|
return this.$util.showMsg("请输入正确值");
|
||
|
|
||
|
this.$util.checkLogin(() => {
|
||
|
this.payDialogOpen = true;
|
||
|
}, true);
|
||
|
},
|
||
|
closeLogin: function (params) {
|
||
|
if (typeof params !== "object") {
|
||
|
return;
|
||
|
}
|
||
|
switch (params.action) {
|
||
|
case "loginClose":
|
||
|
this.loginShow = false;
|
||
|
break;
|
||
|
case "logComplete":
|
||
|
this.loginShow = false;
|
||
|
this.payDialogOpen = true;
|
||
|
break;
|
||
|
}
|
||
|
},
|
||
|
logComplete: function (data) {
|
||
|
var that = this;
|
||
|
that.loginShow = false;
|
||
|
if (!data) {
|
||
|
return;
|
||
|
}
|
||
|
if (!data.isfollow && is_official_account_switch) {
|
||
|
that.codeUrl = data.url;
|
||
|
that.isfollow = true;
|
||
|
} else {
|
||
|
window.location.reload();
|
||
|
}
|
||
|
},
|
||
|
//所有插件回调处理事件
|
||
|
changeVal: function (opt) {
|
||
|
if (typeof opt != "object") opt = {};
|
||
|
var action = opt.action || "";
|
||
|
var value = opt.value || "";
|
||
|
this[action] && this[action](value);
|
||
|
},
|
||
|
pay_order: function (data) {
|
||
|
this.orderId = data.data.result.order_id || "";
|
||
|
switch (data.data.status) {
|
||
|
case "PAY_ERROR":
|
||
|
case "ORDER_EXIST":
|
||
|
case "ORDER_ERROR":
|
||
|
this.extendOrder(data.msg);
|
||
|
break;
|
||
|
case "WECHAT_PAY":
|
||
|
this.wechatPay(data.data.result.jsConfig);
|
||
|
break;
|
||
|
case "WECHAT_H5_PAY":
|
||
|
this.payDialogOpen = false;
|
||
|
this.$util.wechatH5Pay(data.data.result.jsConfig, this);
|
||
|
break;
|
||
|
case "WECHAT_ROUTINE_PAY":
|
||
|
this.$util.wechatRoutinePay(data.data.result.jsConfig, this);
|
||
|
break;
|
||
|
case "SUCCESS":
|
||
|
this.successOrder(data.data);
|
||
|
break;
|
||
|
case "ZHIFUBAO_PAY":
|
||
|
this.aliPay(data.data.result, "recharge")
|
||
|
break;
|
||
|
case 'TOUTIAO_PAY':
|
||
|
this.$util.toutiaoPay(data.data.result.jsConfig, this);
|
||
|
break;
|
||
|
case 'KUAISHOU_PAY':
|
||
|
this.$util.kuaishouPay(data.data.result.jsConfig, this);
|
||
|
break
|
||
|
}
|
||
|
},
|
||
|
aliPay(msn, type) {
|
||
|
this.$util.aliPay(msn, type, this)
|
||
|
},
|
||
|
wechatPay: function (config) {
|
||
|
this.$util.weixinpay(config, this)
|
||
|
},
|
||
|
successOrder: function (data) {
|
||
|
var that = this,
|
||
|
msg,
|
||
|
result;
|
||
|
if (data) {
|
||
|
msg = data.msg;
|
||
|
result = data.result;
|
||
|
that.payDialogOpen = false;
|
||
|
this.$util.showMsg("支付成功");
|
||
|
uni.showToast({
|
||
|
title: '支付成功',
|
||
|
duration: 2000,
|
||
|
success: function () {
|
||
|
if (that.from == "live") {
|
||
|
setTimeout(() => {
|
||
|
uni.navigateBack({
|
||
|
delta: 1
|
||
|
});
|
||
|
}, 1500);
|
||
|
} else {
|
||
|
that.my_user_gold_num();
|
||
|
}
|
||
|
}
|
||
|
});
|
||
|
|
||
|
} else {
|
||
|
this.$util.refreshPage(this.$mp.page.route + `?from=${this.from}`)
|
||
|
|
||
|
}
|
||
|
},
|
||
|
extendOrder: function (msg) {
|
||
|
if (typeof msg === "object") {
|
||
|
if (msg.errMsg === "chooseWXPay:cancel") {
|
||
|
msg = "微信支付取消";
|
||
|
} else {
|
||
|
msg = "支付失败";
|
||
|
}
|
||
|
} else {
|
||
|
msg = "支付失败";
|
||
|
}
|
||
|
this.$util.showMsg(msg);
|
||
|
this.$util.refreshPage(this.$mp.page.route)
|
||
|
},
|
||
|
},
|
||
|
};
|
||
|
</script>
|
||
|
|
||
|
<style scoped lang="scss">
|
||
|
.gold-coin .header {
|
||
|
height: 350rpx;
|
||
|
background: #2c8eff url(@/static/images/coin-bg.png) center/cover no-repeat;
|
||
|
}
|
||
|
|
||
|
.gold-coin .header .cont {
|
||
|
position: relative;
|
||
|
height: 263rpx;
|
||
|
line-height: 263rpx;
|
||
|
text-align: center;
|
||
|
}
|
||
|
|
||
|
.gold-coin .header .text {
|
||
|
display: inline-block;
|
||
|
max-width: 100%;
|
||
|
vertical-align: middle;
|
||
|
overflow: hidden;
|
||
|
font-size: 26rpx;
|
||
|
line-height: 1.5;
|
||
|
color: #ffffff;
|
||
|
}
|
||
|
|
||
|
.gold-coin .header .num {
|
||
|
margin-top: 30rpx;
|
||
|
font-weight: bold;
|
||
|
font-size: 78rpx;
|
||
|
}
|
||
|
|
||
|
.gold-coin .header .link {
|
||
|
position: absolute;
|
||
|
top: 74rpx;
|
||
|
right: 0;
|
||
|
height: 54rpx;
|
||
|
padding-right: 32rpx;
|
||
|
padding-left: 47rpx;
|
||
|
border-top-left-radius: 27rpx;
|
||
|
border-bottom-left-radius: 27rpx;
|
||
|
background-color: #feb720;
|
||
|
font-size: 30rpx;
|
||
|
line-height: 54rpx;
|
||
|
color: #ffffff;
|
||
|
}
|
||
|
|
||
|
.gold-coin .main {
|
||
|
min-height: 87rpx;
|
||
|
border-top-left-radius: 24rpx;
|
||
|
border-top-right-radius: 24rpx;
|
||
|
margin-top: -87rpx;
|
||
|
background-color: #ffffff;
|
||
|
}
|
||
|
|
||
|
.gold-coin .main .wrap {
|
||
|
padding-right: 30rpx;
|
||
|
padding-left: 30rpx;
|
||
|
}
|
||
|
|
||
|
.gold-coin .main .wrap .wrap {
|
||
|
margin-top: 10rpx;
|
||
|
}
|
||
|
|
||
|
.gold-coin .wrap .head {
|
||
|
height: 108rpx;
|
||
|
font-size: 30rpx;
|
||
|
line-height: 108rpx;
|
||
|
color: #282828;
|
||
|
}
|
||
|
|
||
|
.gold-coin .select .list::after {
|
||
|
content: " ";
|
||
|
display: block;
|
||
|
height: 0;
|
||
|
clear: both;
|
||
|
visibility: hidden;
|
||
|
}
|
||
|
|
||
|
.gold-coin .select .list .item {
|
||
|
float: left;
|
||
|
display: block;
|
||
|
margin-top: 21rpx;
|
||
|
margin-right: 21rpx;
|
||
|
}
|
||
|
|
||
|
.gold-coin .select .list .item:nth-child(-n + 3) {
|
||
|
margin-top: 0;
|
||
|
}
|
||
|
|
||
|
.gold-coin .select .list .item:nth-child(3n + 3) {
|
||
|
margin-right: 0;
|
||
|
}
|
||
|
|
||
|
.gold-coin .select .list .item-cont {
|
||
|
width: 216rpx;
|
||
|
height: 120rpx;
|
||
|
border: 1px solid #eee;
|
||
|
border-radius: 12rpx;
|
||
|
line-height: 120rpx;
|
||
|
text-align: center;
|
||
|
}
|
||
|
|
||
|
.gold-coin .select .list .active .item-cont {
|
||
|
border-color: #539dfd;
|
||
|
}
|
||
|
|
||
|
.gold-coin .select .list .text {
|
||
|
display: inline-block;
|
||
|
vertical-align: middle;
|
||
|
font-size: 28rpx;
|
||
|
line-height: 1;
|
||
|
color: #999999;
|
||
|
}
|
||
|
|
||
|
.gold-coin .select .list .num {
|
||
|
padding-right: 46rpx;
|
||
|
margin-bottom: 16rpx;
|
||
|
background: url(@/static/icon/coin.png) right center/36rpx 36rpx no-repeat;
|
||
|
font-weight: bold;
|
||
|
font-size: 36rpx;
|
||
|
color: #282828;
|
||
|
}
|
||
|
|
||
|
.gold-coin .input {
|
||
|
display: block;
|
||
|
height: 86rpx;
|
||
|
border: 1px solid #eee;
|
||
|
border-radius: 12rpx;
|
||
|
margin-top: 21rpx;
|
||
|
line-height: 86rpx;
|
||
|
}
|
||
|
|
||
|
.gold-coin .checked {
|
||
|
border-color: #539dfd;
|
||
|
}
|
||
|
|
||
|
.gold-coin .input::after {
|
||
|
content: " ";
|
||
|
display: block;
|
||
|
height: 0;
|
||
|
clear: both;
|
||
|
visibility: hidden;
|
||
|
}
|
||
|
|
||
|
.gold-coin .input .cell {
|
||
|
float: left;
|
||
|
width: 50%;
|
||
|
}
|
||
|
|
||
|
.gold-coin .input .cell:first-child {
|
||
|
padding-right: 61rpx;
|
||
|
padding-left: 28rpx;
|
||
|
margin-right: -16rpx;
|
||
|
background: url("") right center/.31rem no-repeat;
|
||
|
font-size: 30rpx;
|
||
|
color: #999999;
|
||
|
}
|
||
|
|
||
|
.gold-coin .input input {
|
||
|
flex: 1;
|
||
|
min-width: 0;
|
||
|
color: #282828;
|
||
|
}
|
||
|
|
||
|
.gold-coin .input input.on {
|
||
|
color: #999999;
|
||
|
}
|
||
|
|
||
|
.gold-coin .input input::placeholder {
|
||
|
color: #999999;
|
||
|
}
|
||
|
|
||
|
.gold-coin .input .cell:last-child {
|
||
|
padding-left: 102rpx;
|
||
|
background: url(@/static/icon/coin.png) 46rpx center/36rpx 36rpx no-repeat;
|
||
|
}
|
||
|
|
||
|
.gold-coin .method .item {
|
||
|
display: block;
|
||
|
}
|
||
|
|
||
|
.gold-coin .method .item .item {
|
||
|
margin-top: 19rpx;
|
||
|
}
|
||
|
|
||
|
.gold-coin .method input {
|
||
|
display: none;
|
||
|
}
|
||
|
|
||
|
.gold-coin .method .item-cont {
|
||
|
border: 1px solid #eee;
|
||
|
border-radius: 6rpx;
|
||
|
font-size: 28rpx;
|
||
|
color: #282828;
|
||
|
}
|
||
|
|
||
|
.gold-coin .method input:checked+.item-cont {
|
||
|
border-color: #539dfd;
|
||
|
color: #539dfd;
|
||
|
}
|
||
|
|
||
|
.gold-coin .method .item-cont::after {
|
||
|
content: " ";
|
||
|
display: block;
|
||
|
height: 0;
|
||
|
clear: both;
|
||
|
visibility: hidden;
|
||
|
}
|
||
|
|
||
|
.gold-coin .method .cell {
|
||
|
float: left;
|
||
|
width: 50%;
|
||
|
height: 86rpx;
|
||
|
line-height: 86rpx;
|
||
|
}
|
||
|
|
||
|
.gold-coin .method .cell:first-child {
|
||
|
padding-left: 150rpx;
|
||
|
background: url(@/static/icon/wxpay.png) 86rpx center/44rpx no-repeat;
|
||
|
}
|
||
|
|
||
|
.gold-coin .method .item:last-child .cell:first-child {
|
||
|
background-image: url(@/static/icon/alipay.png);
|
||
|
}
|
||
|
|
||
|
.gold-coin .method .cell:last-child {
|
||
|
position: relative;
|
||
|
font-size: 26rpx;
|
||
|
text-align: center;
|
||
|
color: #aaa;
|
||
|
}
|
||
|
|
||
|
.gold-coin .method .cell:last-child::before {
|
||
|
content: " ";
|
||
|
position: absolute;
|
||
|
top: 50%;
|
||
|
left: 0;
|
||
|
width: 1px;
|
||
|
height: 30rpx;
|
||
|
background-color: #eee;
|
||
|
margin-top: -15rpx;
|
||
|
}
|
||
|
|
||
|
.gold-coin .handle {
|
||
|
padding-right: 41rpx;
|
||
|
padding-left: 41rpx;
|
||
|
margin-top: 74rpx;
|
||
|
}
|
||
|
|
||
|
.gold-coin .handle .btn {
|
||
|
width: 100%;
|
||
|
height: 86rpx;
|
||
|
border-radius: 43rpx;
|
||
|
background-color: #539dfd;
|
||
|
font-size: 30rpx;
|
||
|
color: #ffffff;
|
||
|
}
|
||
|
</style>
|