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.
597 lines
16 KiB
597 lines
16 KiB
<template>
|
|
<view class="page container-with-lines full-height-with-titile">
|
|
<view class="page full-height-with-titile" style="overflow: auto;" v-if="!showResult">
|
|
<!-- 主内容区域 -->
|
|
<view class="content" @click="hideKeyboard">
|
|
<!-- <view v-show="step === 1" style="width: 100%;">
|
|
<u-subsection style="width: 100%;" activeColor="#FDBE44" :list="['代付', '代收']" :current="0" @change="handleUserTypeChg"></u-subsection>
|
|
</view> -->
|
|
<view v-if="false" class="withdraw-amount" style="margin-bottom: 20rpx;">
|
|
<text>支付类型</text>
|
|
<view style="display: grid; grid-template-columns: repeat(3,1fr); width: 100%; margin: 10px auto;">
|
|
<view v-for="item in payType" @click="param.payType = item.key" :class="{'active': param.payType === item.key}" style="display: flex; flex-direction: column;justify-content: center; border-radius: 8px; align-items: center; padding: 5px 0;">
|
|
<u--image style="height: 40px;" :src="item.img" mode="widthFix" width="40" shape="circle"></u--image>
|
|
<text class="text">{{item.name}}</text>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
<!-- 代理信息 -->
|
|
<view v-show="step === 1" class="withdraw-amount">
|
|
<text>{{$languageData.functions.proxyInfo}}</text>
|
|
<uni-section :title="$languageData.functions.pName" type="line" padding>
|
|
<view class="amount-input-area">
|
|
<u-input border="none" type="text" v-model="param.cname" :fontSize="12"
|
|
:placeholder="$languageData.functions.pNamePh"/>
|
|
</view>
|
|
</uni-section>
|
|
<uni-section :title="$languageData.functions.pPhone" type="line" padding>
|
|
<view class="amount-input-area">
|
|
<u-input border="none" type="text" v-model="param.phone" :fontSize="12"
|
|
:placeholder="$languageData.functions.pPhonePh"/>
|
|
</view>
|
|
</uni-section>
|
|
<uni-section :title="$languageData.functions.pIdCard" type="line">
|
|
<view style="display: flex; width: 100%; justify-content: space-around;">
|
|
<u-radio-group
|
|
v-model="param.idType"
|
|
placement="row"
|
|
style="justify-content: space-around;"
|
|
>
|
|
<u-radio
|
|
size="25"
|
|
:customStyle="{marginBottom: '8px'}"
|
|
v-for="(item, index) in [{name:$languageData.functions.idCard, key:'id'},{name:$languageData.functions.passport, key:'pp'}]"
|
|
:key="index"
|
|
:label="item.name"
|
|
:name="item.key"
|
|
>
|
|
</u-radio>
|
|
</u-radio-group>
|
|
</view>
|
|
</uni-section>
|
|
<uni-section :title="$languageData.functions.pIdCardNum" type="line" padding>
|
|
<view class="amount-input-area">
|
|
<u-input border="none" type="text" v-model="param.idNum" :fontSize="12"
|
|
:placeholder="$languageData.functions.pIdCardNumPh"/>
|
|
</view>
|
|
</uni-section>
|
|
<uni-section :title="$languageData.functions.pAmount" type="line" padding>
|
|
<view class="amount-input-area">
|
|
<u-input border="none" type="number" v-model="param.amount" :fontSize="12"
|
|
:placeholder="$languageData.functions.pAmountPh"/>
|
|
<text class="currency">KIP</text>
|
|
</view>
|
|
</uni-section>
|
|
<uni-section :title="$languageData.functions.pUsage" type="line" padding>
|
|
<view class="amount-input-area">
|
|
<u-input border="none" type="text" v-model="param.pUsage" :fontSize="12"
|
|
:placeholder="$languageData.functions.pUsagePh"/>
|
|
</view>
|
|
</uni-section>
|
|
</view>
|
|
<!-- 收款方信息 -->
|
|
<view v-show="step === 1" class="withdraw-amount" style="margin-top: 15rpx;">
|
|
<text>{{$languageData.functions.reciInfo}}</text>
|
|
<uni-section :title="$languageData.functions.reciWay" type="line">
|
|
<view style="display: flex; width: 100%; justify-content: space-around;">
|
|
<u-radio-group
|
|
v-model="param.reciWay"
|
|
placement="row"
|
|
style="justify-content: space-around;"
|
|
>
|
|
<u-radio
|
|
size="25"
|
|
:customStyle="{marginBottom: '8px'}"
|
|
v-for="(item, index) in reciWay"
|
|
:key="index"
|
|
:label="item.name"
|
|
:name="item.key"
|
|
>
|
|
</u-radio>
|
|
</u-radio-group>
|
|
</view>
|
|
</uni-section>
|
|
<uni-section :title="param.reciWay === 'u' ? this.$languageData.functions.accNum:this.$languageData.functions.bankCardNum" type="line" padding>
|
|
<view class="amount-input-area">
|
|
<u-input border="none" type="text" cursor-spacing="15" v-model="param.famId" :fontSize="12"
|
|
:placeholder="(param.reciWay === 'u' ? this.$languageData.functions.accNum:this.$languageData.functions.bankCardNum)"/>
|
|
</view>
|
|
</uni-section>
|
|
</view>
|
|
<!-- 付款方信息 -->
|
|
<view v-show="step === 2" class="withdraw-amount" style="margin: 20rpx 0;">
|
|
<text>{{$languageData.functions.payInfo}}</text>
|
|
<uni-section :title="languageData.functions.payWay" type="line" padding>
|
|
<view class="bank-info" @click="showBankList">
|
|
<view v-if="bankList.length>0" class="bank-detail">
|
|
<text class="bank-name">{{userAccount.bankName}}</text>
|
|
<text class="bank-number">{{userAccount.cardNum2}}</text>
|
|
</view>
|
|
<view v-if="bankList.length<=0">
|
|
<text class="bank-name">{{languageData.account.noCard}}</text>
|
|
</view>
|
|
<uni-icons type="right" size="16" color="#999999" v-if="bankList.length>0"/>
|
|
<uni-icons type="plus" size="16" color="#999999" v-if="bankList.length<=0"/>
|
|
</view>
|
|
</uni-section>
|
|
</view>
|
|
<!-- 底部按钮 -->
|
|
<view class="bottom-button">
|
|
<button v-if="step === 1" class="submit-btn" @click="step = 2" style="background-color: #2A79FF; color: white;">{{this.$languageData.functions.nextStep}}</button>
|
|
<button v-if="step === 2" class="submit-btn" @click="step = 1" style="background-color: lightgray; color: white;">{{this.$languageData.functions.lastStep}}</button>
|
|
<button v-if="step === 2" class="submit-btn" @click="onSubmit" style="margin-top: 30rpx;">{{this.$languageData.functions.payimme}}</button>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
|
|
<!-- 银行卡列表弹出层 -->
|
|
<uni-popup ref="bankListPopup" type="bottom">
|
|
<view class="popup-content">
|
|
<view class="popup-header">
|
|
<text class="popup-title">{{languageData.account.selectBankCard}}</text>
|
|
<uni-icons @click="closeBankList" type="close" size="20" color="#666666" />
|
|
</view>
|
|
<view class="bank-list">
|
|
<view v-for="(bank, index) in bankList" :key="index" class="bank-item" @click="selectBank(bank)">
|
|
<text class="bank-item-name">{{bank.bankName}}</text>
|
|
<text class="bank-item-number">{{bank.cardNum2}}</text>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
</uni-popup>
|
|
|
|
<!-- 键盘 -->
|
|
<payPopup ref="clearPwd" :show.sync="show" @getPassword="getPassword"></payPopup>
|
|
<!-- 弹出层 -->
|
|
<uni-popup ref="message" type="center">
|
|
<view class="popup-content2">
|
|
<text>{{ tipMessage }}</text>
|
|
<button type="primary" style="margin-top: 20rpx;" @click="closePopup">{{languageData.overview.close}}</button>
|
|
</view>
|
|
</uni-popup>
|
|
<loading ref="loading":custom="false" :shadeClick="false" :type="1" />
|
|
</view>
|
|
</template>
|
|
|
|
<script>
|
|
import { createTopUp } from '@/api/home/qrcode.js'
|
|
import { getBalance } from '@/api/account/userAccount.js'
|
|
import { getBankList2 } from '@/api/bank/index.js'
|
|
import payPopup from '@/components/keyboard/payPopup.vue'
|
|
import { checkPwd } from '@/api/mine/payPwd.js'
|
|
import keyboard from "@/components/master-keyboard/master-keyboard.vue";
|
|
import payResult from '@/components/payResult/index.vue'
|
|
|
|
export default {
|
|
components: {
|
|
payPopup,
|
|
payResult
|
|
},
|
|
data() {
|
|
return {
|
|
reciWay:[
|
|
{
|
|
key: 'u',
|
|
name: this.$languageData.functions.sysUsr,
|
|
img: '/static/img/electricity.png'
|
|
},
|
|
{
|
|
key: 'c',
|
|
name: this.$languageData.functions.bankCard,
|
|
img:'/static/img/water.png'
|
|
}
|
|
],
|
|
payWay:[
|
|
{
|
|
key: 'u',
|
|
name: '系统账户余额',
|
|
img: '/static/img/electricity.png'
|
|
},
|
|
{
|
|
key: 'c',
|
|
name: this.$languageData.functions.bankCard,
|
|
img:'/static/img/water.png'
|
|
}
|
|
],
|
|
step: 1,
|
|
amount: 0,
|
|
|
|
success:true,
|
|
showResult:false,
|
|
bankList: [],
|
|
userAccount:{},
|
|
tipMessage:"",
|
|
param: {
|
|
payType: '',
|
|
reciWay: 'u',
|
|
payWay: '',
|
|
usage: '',
|
|
idType: 'id',
|
|
fromId: null,
|
|
fromAccount: null,
|
|
toId: null,
|
|
toAccount: null,
|
|
amount: null
|
|
},
|
|
show: false,
|
|
paramPwd: {
|
|
payPasswd: null
|
|
},
|
|
userId:this.$store.state.user.userId,
|
|
}
|
|
},
|
|
onLoad() {
|
|
this.getBalance();
|
|
},
|
|
created() {
|
|
this.languageData = this.$languageData;
|
|
},
|
|
methods: {
|
|
// // 监听输入框
|
|
// handleInput(value) {
|
|
// console.log("---------value",value)
|
|
// // 如果输入内容以小数点开头
|
|
// if (value.startsWith(".")) {
|
|
// // 在前面加上 0
|
|
// this.param.amount = "0" + value;
|
|
// } else {
|
|
// // 正常输入,保持原值
|
|
// this.param.amount = value;
|
|
// }
|
|
// },
|
|
closePopup(){
|
|
this.$refs.message.close();
|
|
},
|
|
//获取用户输入的支付密码
|
|
getPassword(data) {
|
|
//验证支付密码
|
|
this.getChangePwd(data.password);
|
|
},
|
|
getChangePwd(pwd) {
|
|
this.paramPwd.payPasswd = pwd;
|
|
checkPwd(this.paramPwd).then(res => {
|
|
if (res.data != null) {
|
|
//支付
|
|
this.show = false;
|
|
this.cashOut();
|
|
} else {
|
|
//密码错误
|
|
this.$nextTick(() => {
|
|
this.$refs.clearPwd.errorPwd();
|
|
})
|
|
}
|
|
})
|
|
},
|
|
selectBankList(){
|
|
let params = {
|
|
userId : this.userId
|
|
}
|
|
getBankList2(params).then(res=>{
|
|
this.bankList = res
|
|
let account = {
|
|
bankName:this.languageData.tmp.zsyh,
|
|
cardNum2:'**************3910'
|
|
}
|
|
this.bankList.unshift(account)
|
|
account = {
|
|
bankName:this.languageData.tmp.gsyh,
|
|
cardNum2:'**************9527'
|
|
}
|
|
this.bankList.unshift(account)
|
|
account = {
|
|
bankName:this.$languageData.functions.accBalance,
|
|
cardNum2: this.userAccount.availableBalance +' KIP'
|
|
}
|
|
this.bankList.unshift(account)
|
|
this.userAccount.bankName = res[0].bankName
|
|
this.userAccount.cardNum2 = res[0].cardNum2
|
|
}).catch(e=>{
|
|
let account = {
|
|
bankName:this.languageData.wallet.balance,
|
|
cardNum2:this.param.fromAccount
|
|
}
|
|
this.bankList = account
|
|
})
|
|
},
|
|
goBack() {
|
|
uni.navigateBack();
|
|
},
|
|
showBankList() {
|
|
// console.log("---this.bankList---",this.bankList)
|
|
if(this.bankList!=null){
|
|
this.$refs.bankListPopup.open();
|
|
}else{
|
|
// 添加银行卡
|
|
}
|
|
},
|
|
closeBankList() {
|
|
this.$refs.bankListPopup.close();
|
|
},
|
|
selectBank(bank) {
|
|
this.userAccount = bank;
|
|
this.param.fromAccount = bank.cardNum
|
|
this.closeBankList();
|
|
},
|
|
hideKeyboard() {
|
|
// uni.hideKeyboard();
|
|
},
|
|
getBalance(){
|
|
getBalance().then(res=>{
|
|
this.userAccount.availableBalance = res.data.accountAmount;
|
|
this.param.fromId = res.data.userId;
|
|
this.param.toId = res.data.userId;
|
|
this.param.toAccount = res.data.accountId;
|
|
this.param.fromAccount = res.data.accountId;
|
|
this.selectBankList();
|
|
}).catch(e=>{
|
|
this.selectBankList();
|
|
})
|
|
},
|
|
cashOut(){
|
|
this.$refs.loading.open();
|
|
createTopUp(JSON.stringify(this.param)).then(res => {
|
|
if (res.data.status == '2') {
|
|
setTimeout(()=>{
|
|
this.$refs.loading.close();
|
|
uni.showToast({
|
|
title: this.languageData.submitSuccess,
|
|
icon: 'success',
|
|
duration:1000
|
|
});
|
|
let obj = {
|
|
number:this.param.amount,
|
|
success:true
|
|
}
|
|
this.param.amount = null
|
|
uni.navigateTo({
|
|
url: `/components/payResult/indexNew?data=${encodeURIComponent(JSON.stringify(obj))}`
|
|
})
|
|
// this.showResult = true
|
|
// setTimeout(()=>{
|
|
// this.$tab.navigateTo('/pages/mine/wallet/index')
|
|
// },1000)
|
|
},1000)
|
|
}else if(res.data.status == '0'){
|
|
setTimeout(()=>{
|
|
this.$refs.loading.close();
|
|
this.$refs.message.open();
|
|
this.paramPwd.payPasswd = ''
|
|
this.$refs.clearPwd.clearPwd();
|
|
this.tipMessage = res.data.remark
|
|
},1000)
|
|
}
|
|
}).catch(e=>{
|
|
setTimeout(()=>{
|
|
this.$refs.loading.close();
|
|
this.$refs.clearPwd.clearPwd();
|
|
uni.showToast({
|
|
title: this.languageData.sysError,
|
|
icon: 'error',
|
|
duration:1000
|
|
});
|
|
},1000)
|
|
})
|
|
},
|
|
onSubmit() {
|
|
// if(!this.param.payType || this.param.payType.length === 0){
|
|
// uni.showToast({
|
|
// title: this.languageData.functions.payTypePh,
|
|
// icon: 'none',
|
|
// duration:1000
|
|
// });
|
|
// return;
|
|
// }
|
|
// if(!this.param.famId || this.param.famId.length === 0){
|
|
// uni.showToast({
|
|
// title: this.languageData.functions.famIdPh,
|
|
// icon: 'none',
|
|
// duration:1000
|
|
// });
|
|
// return;
|
|
// }
|
|
// if(isNaN(this.param.amount) || this.param.amount <= 0){
|
|
// uni.showToast({
|
|
// title: this.languageData.account.cannot0,
|
|
// icon: 'none',
|
|
// duration:1000
|
|
// });
|
|
// return;
|
|
// }
|
|
this.show = true;
|
|
}
|
|
}
|
|
}
|
|
</script>
|
|
<style lang="scss" scoped>
|
|
|
|
.active{
|
|
border: 1px solid #FDBF44;
|
|
background-color: rgba(253, 191, 68, .2);
|
|
}
|
|
|
|
|
|
.popup-content2 {
|
|
background-color: #fff;
|
|
padding: 20px;
|
|
border-radius: 10px;
|
|
font-size: 20rpx;
|
|
text-align: center;
|
|
}
|
|
|
|
.page {
|
|
padding: 0;
|
|
display: flex;
|
|
flex-direction: column;
|
|
}
|
|
|
|
.nav-bar {
|
|
height: 88rpx;
|
|
background-color: #333333;
|
|
display: flex;
|
|
align-items: center;
|
|
padding: 0 30rpx;
|
|
position: relative;
|
|
}
|
|
|
|
.back-icon {
|
|
width: 20px;
|
|
height: 20px;
|
|
}
|
|
|
|
.nav-title {
|
|
position: absolute;
|
|
left: 50%;
|
|
transform: translateX(-50%);
|
|
color: #FFFFFF;
|
|
font-size: 16px;
|
|
font-weight: 500;
|
|
}
|
|
|
|
.content {
|
|
flex: 1;
|
|
padding: 20rpx 30rpx;
|
|
}
|
|
|
|
.bank-card {
|
|
background-color: #FFFFFF;
|
|
border-radius: 12rpx;
|
|
padding: 30rpx;
|
|
padding-bottom: 10rpx;
|
|
margin-top: 30rpx;
|
|
}
|
|
|
|
.section-title {
|
|
font-size: 14px;
|
|
color: #333333;
|
|
margin-bottom: 14rpx;
|
|
padding-bottom: 14rpx;
|
|
display: block;
|
|
}
|
|
|
|
.bank-info {
|
|
display: flex;
|
|
justify-content: space-between;
|
|
align-items: center;
|
|
}
|
|
|
|
.bank-detail {
|
|
display: flex;
|
|
flex-direction: column;
|
|
}
|
|
|
|
.bank-name {
|
|
font-size: 16px;
|
|
color: #333333;
|
|
margin-bottom: 8rpx;
|
|
}
|
|
|
|
.bank-number {
|
|
font-size: 14px;
|
|
color: #666666;
|
|
}
|
|
|
|
.withdraw-amount {
|
|
background-color: #FFFFFF;
|
|
border-radius: 12rpx;
|
|
padding: 20rpx;
|
|
padding-bottom: 15rpx;
|
|
}
|
|
|
|
.amount-header {
|
|
display: flex;
|
|
justify-content: space-between;
|
|
align-items: center;
|
|
}
|
|
|
|
.withdraw-all {
|
|
font-size: 14px;
|
|
color: #f4d994;
|
|
}
|
|
|
|
.amount-input-area {
|
|
display: flex;
|
|
align-items: center;
|
|
border-bottom: 1px solid #EEEEEE;
|
|
}
|
|
|
|
.u-input ::v-deep .uni-input-input {
|
|
font-size: 58rpx;
|
|
font-weight: 500;
|
|
color: #333333;
|
|
height: 100rpx;
|
|
line-height: 100rpx;
|
|
}
|
|
|
|
.currency {
|
|
font-size: 30px;
|
|
color: #333333;
|
|
margin-left: 20rpx;
|
|
}
|
|
|
|
.amount-footer {
|
|
display: flex;
|
|
justify-content: space-between;
|
|
align-items: center;
|
|
}
|
|
|
|
.available-amount {
|
|
font-size: 14px;
|
|
color: #999999;
|
|
}
|
|
|
|
.bottom-button {
|
|
padding: 50rpx 0;
|
|
}
|
|
|
|
.submit-btn {
|
|
background-color: #FDBF44;
|
|
color: #000;
|
|
font-size: 16px;
|
|
height: 88rpx;
|
|
line-height: 88rpx;
|
|
border-radius: 24rpx;
|
|
}
|
|
|
|
.popup-content {
|
|
background-color: #FFFFFF;
|
|
border-top-left-radius: 20rpx;
|
|
border-top-right-radius: 20rpx;
|
|
padding-bottom: env(safe-area-inset-bottom);
|
|
}
|
|
|
|
.popup-header {
|
|
display: flex;
|
|
justify-content: space-between;
|
|
align-items: center;
|
|
padding: 30rpx;
|
|
border-bottom: 1px solid #EEEEEE;
|
|
}
|
|
|
|
.popup-title {
|
|
font-size: 16px;
|
|
color: #333333;
|
|
font-weight: 500;
|
|
}
|
|
|
|
.bank-list {
|
|
max-height: 600rpx;
|
|
overflow-y: auto;
|
|
}
|
|
|
|
.bank-item {
|
|
padding: 30rpx;
|
|
border-bottom: 1px solid #EEEEEE;
|
|
}
|
|
|
|
.bank-item-name {
|
|
font-size: 16px;
|
|
color: #333333;
|
|
margin-bottom: 8rpx;
|
|
display: block;
|
|
}
|
|
|
|
.bank-item-number {
|
|
font-size: 14px;
|
|
color: #666666;
|
|
}
|
|
</style>
|