时味苏州
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.

441 lines
12 KiB

1 week ago
<template>
<view class="bg">
<uni-page-head uni-page-head-type="default">
<div class="uni-page-head" style="background-color: rgb(248, 248, 248); color: rgb(0, 0, 0);">
<div class="uni-page-head-hd">
<div class="uni-page-head-btn" @click="clickBack()">
<uni-icons type="left" size="27"></uni-icons>
</div>
<div class="uni-page-head-ft"></div>
</div>
<div class="uni-page-head-bd">
<div class="uni-page-head__title" style="font-size: 16px; opacity: 1;">
支付
</div>
</div>
<div class="uni-page-head-ft"></div>
</div>
<div class="uni-placeholder"></div>
</uni-page-head>
<view class="title">支付剩余时间</view>
<view class="time-box">
<uni-countdown :font-size="40" :show-day="false" :hour="times.hours" :minute="times.minutes"
:second="times.seconds" @timeup="timeup"></uni-countdown>
</view>
<view class="money-box" style="padding-bottom: 30rpx;">
<view>应付金额</view>
<view style="color: red;">{{detail.paid_money / 100}}</view>
</view>
<view class="money-box" style="border-bottom: none;">
<view>支付方式:</view>
</view>
<!-- 优惠券 -->
<view v-if="coupon_activity">
<view class="pay-box" @click="payType = 1" v-if="pay_type.includes('WEIXIN')">
<view style="display: flex; align-items: center;">
<image src="https://static.ticket.sz-trip.com/jundaosuzhou/images/wxPay.png" mode="widthFix"></image>
微信支付
</view>
<view class="select-box">
<view class="select" v-if="payType == 1"></view>
</view>
</view>
<view v-if="walletList.length > 0 && pay_type.includes('SUBWALLET')">
<view class="pay-box">
<view style="display: flex; align-items: center;">
<image src="https://static.ticket.sz-trip.com/jundaosuzhou/images/numLogo.png" mode="widthFix">
</image>
数字人民币子钱包支付
</view>
<image src="https://static.ticket.sz-trip.com/jundaosuzhou/images/selectB.png" class="select-img"
mode="widthFix" :style="{'transform': showMore ? 'rotate(180deg)' : ''}"
@click="showMore = !showMore"></image>
</view>
<view v-show="showMore" style="padding-left: 40rpx;">
<view class="pay-box" v-for="(item,index) in walletList" :key="index" @click="payType = 2;walletIndex = index">
<view style="display: flex; align-items: center;">
<image :src="item.bank_logo" mode="widthFix"></image>
{{item.bank_name}}
</view>
<view class="select-box">
<view class="select" v-if="payType == 2 && walletIndex === index"></view>
</view>
</view>
</view>
</view>
</view>
<view class="" v-else>
<view class="pay-box" @click="payType = 1">
<view style="display: flex; align-items: center;">
<image src="https://static.ticket.sz-trip.com/jundaosuzhou/images/wxPay.png" mode="widthFix"></image>
微信支付
</view>
<view class="select-box">
<view class="select" v-if="payType == 1"></view>
</view>
</view>
<view v-if="walletList.length > 0">
<view class="pay-box">
<view style="display: flex; align-items: center;">
<image src="https://static.ticket.sz-trip.com/jundaosuzhou/images/numLogo.png" mode="widthFix">
</image>
数字人民币子钱包支付
</view>
<image src="https://static.ticket.sz-trip.com/jundaosuzhou/images/selectB.png" class="select-img"
mode="widthFix" :style="{'transform': showMore ? 'rotate(180deg)' : ''}"
@click="showMore = !showMore"></image>
</view>
<view v-show="showMore" style="padding-left: 40rpx;">
<view class="pay-box" v-for="(item,index) in walletList" :key="index" @click="payType = 2;walletIndex = index">
<view style="display: flex; align-items: center;">
<image :src="item.bank_logo" mode="widthFix"></image>
{{item.bank_name}}
</view>
<view class="select-box">
<view class="select" v-if="payType == 2 && walletIndex === index"></view>
</view>
</view>
</view>
</view>
</view>
<view class="btn" @click="pay">
立即付款
</view>
</view>
</template>
<script>
export default {
data() {
return {
id: '',
token: {},
detail: {},
closeTime: 1000 * 60 * 30,
times: {},
showMore: true,
walletList: [],
walletIndex: 0,
payType: null,
coupon_activity: false,
pay_type: "",
JDSZAPIURL: 'https://api.cloud.sz-trip.com'
}
},
onReady() {
},
onLoad(option) {
this.id = option.orderId
// this.Post({}, '/api/subwallet.ermb/wallet').then(res => {
// this.walletList = res.data
// })
this.Post({order_id: option.orderId}, "/api/order/query").then(res => {
// 选择优惠券需要判断优惠券支付方式
if(res.data.coupon_activity && res.data.coupon_activity.pay_type) {
this.coupon_activity = true
this.pay_type = res.data.coupon_activity.pay_type
}
if(res.data.paid_money == 0) {
uni.redirectTo({
url: '/subPackages/order/trades'
})
return;
}
this.detail = res.data
let createTime = new Date((this.detail.create_time + "").replace(/-/g, "/")).getTime();
createTime += this.detail.auto_close_time * 1000;
this.closeTime = createTime - new Date().getTime();
const hours = parseInt((this.closeTime % (1000 * 60 * 60 * 24)) / (1000 * 60 * 60));
const minutes = parseInt((this.closeTime % (1000 * 60 * 60)) / (1000 * 60));
const seconds = (this.closeTime % (1000 * 60)) / 1000;
this.times = {
hours: hours,
minutes: minutes,
seconds: seconds
}
})
},
onShow() {
},
onBackPress() {
return true; // 返回 true 表示阻止默认返回行为
},
methods: {
// 返回
clickBack () {
let pages = getCurrentPages()
let prePage = null
// 看上个页面
if (pages.length>=2) {
prePage = pages[pages.length - 2];
} else {
uni.redirectTo({
url: "/subPackages/order/trades"
})
return
}
// 有问题
if (prePage.$page.fullPath.indexOf('trades')>=0 || prePage.$page.fullPath.indexOf('orderDetail')>=0) {
uni.navigateBack()
} else {
uni.redirectTo({
url: "/subPackages/order/trades"
})
}
},
// 倒计时时间到触发事件
timeup() {
let flag = false
setTimeout(() => {
flag = true
}, 2000)
if (flag) {
console.log('倒计时结束')
}
},
// 支付
pay() {
if(this.payType == null) {
uni.showToast({
title: '请选择支付方式',
icon: 'none'
})
return;
}
uni.showLoading({
title: '加载中'
})
if(this.payType == 1) {
6 days ago
// uni.request({
// method: 'POST',
// url: "/api/api/order/pay",
// header: {
// 'content-type': 'application/json',
// 'token': "35cda449-d338-46d8-b95a-20a19bd1e58f"
// },
// data: {
// order_id: "46022510201010554631",
// pay_method: "ICBC_WECHAT",
// pay_platform: "JSAPI",
// return_url: "https://m.cloud.sz-trip.com/OrderWaiting",
// token: "35cda449-d338-46d8-b95a-20a19bd1e58f"
// },
// success: (resTwo) => {
// let resObj = {}
// try {
// resObj = JSON.parse(resTwo)
// } catch(e) {}
// WeixinJSBridge.invoke('getBrandWCPayRequest', {
// "appId": resObj.appId || resObj.appid, //公众号ID,由商户传入
// "timeStamp": resObj.timeStamp || resObj.timestamp, //时间戳,自1970年以来的秒数
// "nonceStr": resObj.nonceStr || resObj.noncestr, //随机串
// "package": resObj.package,
// "signType": resObj.signType, //微信签名方式:
// "paySign": resObj.paySign|| resObj.sign, //微信签名
// },
// function(res) {
// console.log(res)
// });
// }
// })
// return
1 week ago
// 微信支付
6 days ago
this.Post({
order_id: this.id,
code: "",
pay_method: "ICBC_WECHAT",
pay_platform: "JSAPI",
return_url: "https://" + window.location.host + "/OrderWaiting",
}, "/api/order/pay").then(resTwo => {
let resObj = {}
try {
resObj = JSON.parse(resTwo)
} catch(e) {}
WeixinJSBridge.invoke('getBrandWCPayRequest', {
"appId": resObj.appId || resObj.appid, //公众号ID,由商户传入
"timeStamp": resObj.timeStamp || resObj.timestamp, //时间戳,自1970年以来的秒数
"nonceStr": resObj.nonceStr || resObj.noncestr, //随机串
"package": resObj.package,
"signType": resObj.signType, //微信签名方式:
"paySign": resObj.paySign|| resObj.sign, //微信签名
1 week ago
},
6 days ago
function(res) {
// that.$router.push('/OrderWaiting')
});
1 week ago
})
6 days ago
1 week ago
}else if(this.payType == 2) {
// 数币支付
uni.request({
method: 'POST',
url: this.JDSZAPIURL + '/api/subwallet.ermb/wallet',
header: {
'content-type': 'application/json',
'token': this.token
},
data: {
order_id: this.id,
pay_method: "SUBWALLET",
pay_platform: "MWEB",
ins_no: this.walletList[this.walletIndex].ins_no,
return_url: "https://m.cloud.sz-trip.com/OrderWaiting",
},
success: res => {
uni.request({
method: 'POST',
url: this.JDSZAPIURL + '/api/order/pay',
header: {
'content-type': 'application/json',
'token': this.token
},
data: {
order_id: this.id,
pay_method: "SUBWALLET",
pay_platform: "MWEB",
ins_no: this.walletList[this.walletIndex].ins_no,
return_url: "https://https://m.cloud.sz-trip.com/OrderWaiting",
},
success: res => {
let data = JSON.parse(res.data.data);
if(data && data.RESULT && data.RESULT=='Y'){
uni.request({
method: 'POST',
url: this.JDSZAPIURL + '/api/order/query',
header: {
'content-type': 'application/json',
'token': this.token
},
data: {
order_id: this.id,
},
success: res => {
uni.hideLoading()
if (res.data.data.state != "UNPAID") {
uni.redirectTo({
url: '/subPackages/order/trades'
})
} else {
uni.showToast({
title: '未查询到支付结果!',
icon: 'none'
})
}
},
complete: (res) => {uni.hideLoading()}
})
} else {
uni.hideLoading()
if (res.data.code!=1 && res.data.msg) {
uni.showToast({
title: res.data.msg,
icon: 'none'
})
}
}
},
})
},
})
}
}
}
}
</script>
<style scoped lang="scss">
.bg {
box-sizing: border-box;
}
.title {
text-align: center;
font-size: 35rpx;
line-height: 60rpx;
padding-top: 100rpx;
}
.time-box {
display: flex;
justify-content: center;
align-items: center;
margin-bottom: 100rpx;
}
.money-box {
width: 670rpx;
margin: 30rpx auto 0;
font-size: 35rpx;
display: flex;
justify-content: space-between;
border-bottom: 1rpx solid #000;
height: 60rpx;
align-items: center;
}
.pay-box {
padding: 0 40rpx;
display: flex;
justify-content: space-between;
align-items: center;
font-size: 35rpx;
margin-top: 40rpx;
image {
width: 70rpx;
margin-right: 20rpx;
}
.select-box {
width: 35rpx;
height: 35rpx;
display: flex;
justify-content: center;
align-items: center;
border: 1rpx solid #000;
border-radius: 50%;
.select {
width: 15rpx;
height: 15rpx;
background: #000;
border-radius: 50%;
}
}
.select-img {
width: 50rpx;
height: 50rpx;
margin-right: 0rpx;
}
}
.btn {
margin: 80rpx auto 0;
width: 670rpx;
line-height: 80rpx;
text-align: center;
font-size: 40rpx;
background: #d62828;
color: #fff;
border-radius: 40rpx;
}
</style>