wxapp/pages/pay/cashier.vue
2024-08-03 19:57:17 +08:00

227 lines
5.3 KiB
Vue

<template>
<view class="container" v-if="userInfo.id">
<view class="account-panel dis-flex flex-y-center">
<view class="panel-lable">
<text>会员账户余额</text>
</view>
<view class="panel-balance flex-box">
<text>¥{{ userInfo.balance }}</text>
</view>
</view>
<view class="recharge-panel">
<view class="recharge-label">
<text>收款金额</text>
</view>
<!-- 收款金额输入框 -->
<view class="recharge-input">
<input type="digit" placeholder="请输入收款金额" v-model="inputValue" @input="onChangeMoney" />
</view>
<view class="remark-input">
<input type="text" v-model="remark" placeholder="请输入收款备注"/>
</view>
<!-- 确认按钮 -->
<view class="recharge-submit btn-submit">
<form @submit="onSubmit">
<button class="button" formType="submit" :disabled="disabled">立即收款</button>
</form>
</view>
</view>
</view>
</template>
<script>
import * as UserApi from '@/api/user'
import * as BalanceApi from '@/api/balance'
import * as SettlementApi from '@/api/settlement'
import { wxPayment } from '@/utils/app'
export default {
data() {
return {
// 正在加载
isLoading: true,
// 会员二维码
userCode: "",
// 会员信息
userInfo: {},
// 按钮禁用
disabled: false,
// 收款备注
remark: '',
// 自定义金额
inputValue: '',
}
},
/**
* 生命周期函数--监听页面加载
*/
onLoad(options) {
this.userCode = options.code
// 获取页面数据
this.getPageData()
},
methods: {
// 收款金额输入框
onChangeMoney(e) {
this.inputValue = e.target.value;
this.rechargeAmount = 0;
},
// 获取页面数据
getPageData() {
const app = this
app.isLoading = true
Promise.all([app.getUserInfo()])
.then(() => app.isLoading = false)
},
// 获取会员信息
getUserInfo() {
const app = this
return new Promise((resolve, reject) => {
UserApi.info({ code: app.userCode })
.then(result => {
app.userInfo = result.data.userInfo;
resolve(app.userInfo);
})
})
},
// 立即收款
onSubmit(e) {
const app = this
if (app.inputValue.length < 1) {
app.$error('请输入收款金额!');
return false;
}
// 按钮禁用
app.disabled = true
// 提交到后端
SettlementApi.doCashier({ type: 'payment', cashierPayAmount: app.inputValue, cashierDiscountAmount: 0, payType: 'BALANCE', userId: app.userInfo.id, remark: app.remark })
.then(result => app.onSubmitCallback(result))
.catch(err => {
if (err.result) {
const errData = err.result.data;
if (errData) {
return false;
}
}
})
},
// 收款回调
onSubmitCallback(result) {
const app = this
if (result.code != '200') {
app.$error(result.message ? result.message : '收款失败!');
app.disabled = false;
return false;
}
uni.showModal({
title: '收款结果',
content: '收款成功!',
showCancel: false,
success(o) {
if (o.confirm) {
app.inputValue = '';
app.remark = '';
app.disabled = false;
app.getPageData();
}
}
})
}
}
}
</script>
<style lang="scss" scoped>
page,
.container {
background: #fff;
}
.container {
padding-bottom: 70rpx;
}
/* 账户面板 */
.account-panel {
width: 650rpx;
height: 180rpx;
margin: 50rpx auto;
padding: 0 60rpx;
box-sizing: border-box;
border-radius: 8rpx;
color: #fff;
background: #00acac;
box-shadow: 0 5px 22px 0 rgba(0, 0, 0, 0.26);
}
.panel-lable {
font-size: 32rpx;
}
.recharge-label {
color: rgb(51, 51, 51);
font-size: 32rpx;
margin-bottom: 25rpx;
}
.panel-balance {
text-align: right;
font-size: 46rpx;
}
.recharge-panel {
margin-top: 60rpx;
padding: 0 60rpx;
}
.recharge-input {
margin-top: 25rpx;
input {
border: 1rpx solid rgb(228, 228, 228);
border-radius: 6rpx;
padding: 15rpx 16rpx;
font-size: 26rpx;
}
}
.remark-input {
margin-top: 50rpx;
input {
border: 1rpx solid rgb(228, 228, 228);
border-radius: 6rpx;
padding: 15rpx 16rpx;
font-size: 26rpx;
}
}
/* 立即充值 */
.recharge-submit {
margin-top: 70rpx;
}
.btn-submit {
.button {
font-size: 30rpx;
background: linear-gradient(to right, #f9211c, #ff6335);
border: none;
color: white;
border-radius: 40rpx;
padding: 0 120rpx;
line-height: 3;
}
.button[disabled] {
background: #ff6335;
border-color: #ff6335;
color: white;
}
}
</style>