前端 + 后端:支付界面~

pull/1/head
YunaiV 2019-04-21 02:00:11 +08:00
parent 3a27ae5d96
commit 0b35a92b01
10 changed files with 91 additions and 36 deletions

24
mobile-web/src/api/pay.js Normal file
View File

@ -0,0 +1,24 @@
import request from "../config/request";
export function getTransaction(appId, orderId) {
return request({
url: '/pay-api/users/transaction/get',
method: 'get',
params: {
appId,
orderId
}
});
}
export function submitTransaction(appId, orderId, payChannel) {
return request({
url: '/pay-api/users/transaction/submit',
method: 'post',
params: {
appId,
orderId,
payChannel
}
});
}

View File

@ -21,11 +21,11 @@ const serviceRouter = function(requestUrl) {
}, },
'/promotion-api': { '/promotion-api': {
prefix: '/promotion-api', prefix: '/promotion-api',
target: 'http://127.0.0.1:18085//promotion-api', target: 'http://127.0.0.1:18085/promotion-api',
}, },
'/pay-api': { '/pay-api': {
prefix: '/pay-api', prefix: '/pay-api',
target: 'http://127.0.0.1:18084//promotion-api', target: 'http://127.0.0.1:18084/pay-api',
}, },
}; };
@ -48,7 +48,7 @@ const serviceRouter = function(requestUrl) {
}, },
'/pay-api': { '/pay-api': {
prefix: '/pay-api', prefix: '/pay-api',
target: 'http://api.shop.iocoder.cn:18099/promotion-api', target: 'http://api.shop.iocoder.cn:18099/pay-api',
}, },
}; };

View File

@ -203,6 +203,13 @@ const routes = [
meta: { meta: {
title: '优惠劵领取' title: '优惠劵领取'
} }
},
{
path: '/pay',
component: () => import('../page/pay/index'),
meta: {
title: '收银台'
}
} }
]; ];

View File

@ -1,50 +1,46 @@
<template> <template>
<div> <div>
<headerNav title="收银台"/>
<van-cell-group> <van-cell-group>
<van-cell title="优惠劵编号" :value="couponTemplate.id" /> <van-cell title="订单商品名" :value="transaction.orderSubject" />
<van-cell title="优惠劵名" :value="couponTemplate.title"/> <van-cell title="价格" :value="transaction.price / 100.0" />
</van-cell-group> </van-cell-group>
<van-button slot="button" size="small" type="primary" @click="onFetchClick"></van-button> <van-button slot="button" size="small" type="primary" @click="submit(9999)"></van-button>
</div> </div>
</template> </template>
<script> <script>
import { getCouponTemplate, doAddCouponCard } from '../../api/promotion'; import { getTransaction, submitTransaction } from '../../api/pay';
import pingpp from 'pingpp-js';
import { Dialog } from 'vant'; import { Dialog } from 'vant';
import { setLoginToken } from '../../utils/cache';
export default { export default {
data() { data() {
return { return {
couponTemplate: { appId: this.$route.query.appId,
} orderId: this.$route.query.orderId,
transaction: {},
} }
}, },
mounted() { mounted() {
let id = this.$route.query.id; let response = getTransaction(this.appId, this.orderId);
let response = getCouponTemplate(id);
response.then(data => { response.then(data => {
this.couponTemplate = data; this.transaction = data;
}); });
}, },
methods: { methods: {
onFetchClick: function () { submit(payChannel) {
let that = this; let that = this;
let id = this.$route.query.id; debugger;
let response = doAddCouponCard(id); submitTransaction(this.appId, this.orderId, payChannel).then(data => {
response.then(data => { pingpp.createPayment(data.invokeResponse, function(result, err) {
Dialog.alert({ debugger;
title: '系统提示', console.log(result);
message: '领取成功', console.log(err.msg);
beforeClose: function (action, done) { console.log(err.extra);
//
done();
//
that.$router.push('/user/coupon');
}
}); });
}); });
} }

View File

@ -38,7 +38,9 @@
<van-button v-if="[3,4,5].indexOf(item.status) != -1" size="small"></van-button> <van-button v-if="[3,4,5].indexOf(item.status) != -1" size="small"></van-button>
</router-link> </router-link>
<van-button v-if="item.status === 3 " size="small" v-on:click="clickConfirmReceiving(item)"></van-button> <van-button v-if="item.status === 3 " size="small" v-on:click="clickConfirmReceiving(item)"></van-button>
<van-button v-if="item.status === 1 " size="small" type="danger"></van-button> <van-button v-if="item.status === 1 " size="small" type="danger" @click="goPay(item.orderid)">
支付
</van-button>
</div> </div>
</van-panel> </van-panel>
</van-cell-group> </van-cell-group>
@ -60,6 +62,10 @@
} }
}, },
methods: { methods: {
goPay(itemId) {
this.$router.push('/pay?appId=POd4RC6a&orderId=' + itemId);
},
onTabChange(index) { onTabChange(index) {
// status tab index // status tab index
const statusArray = [null, 1, 3, 4, 5]; const statusArray = [null, 1, 3, 4, 5];

View File

@ -27,6 +27,11 @@
<artifactId>admin-sdk</artifactId> <artifactId>admin-sdk</artifactId>
<version>1.0-SNAPSHOT</version> <version>1.0-SNAPSHOT</version>
</dependency> </dependency>
<dependency>
<groupId>cn.iocoder.mall</groupId>
<artifactId>user-sdk</artifactId>
<version>1.0-SNAPSHOT</version>
</dependency>
<dependency> <dependency>
<groupId>org.springframework.boot</groupId> <groupId>org.springframework.boot</groupId>

View File

@ -3,15 +3,14 @@ package cn.iocoder.mall.pay.application.controller.users;
import cn.iocoder.common.framework.util.HttpUtil; import cn.iocoder.common.framework.util.HttpUtil;
import cn.iocoder.common.framework.vo.CommonResult; import cn.iocoder.common.framework.vo.CommonResult;
import cn.iocoder.mall.pay.api.PayTransactionService; import cn.iocoder.mall.pay.api.PayTransactionService;
import cn.iocoder.mall.pay.api.bo.PayTransactionBO;
import cn.iocoder.mall.pay.api.bo.PayTransactionSubmitBO; import cn.iocoder.mall.pay.api.bo.PayTransactionSubmitBO;
import cn.iocoder.mall.pay.api.constant.PayChannelEnum; import cn.iocoder.mall.pay.api.constant.PayChannelEnum;
import cn.iocoder.mall.pay.api.dto.PayTransactionSubmitDTO; import cn.iocoder.mall.pay.api.dto.PayTransactionSubmitDTO;
import cn.iocoder.mall.user.sdk.context.UserSecurityContextHolder;
import com.alibaba.dubbo.config.annotation.Reference; import com.alibaba.dubbo.config.annotation.Reference;
import org.springframework.http.MediaType; import org.springframework.http.MediaType;
import org.springframework.web.bind.annotation.PostMapping; import org.springframework.web.bind.annotation.*;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;
import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletRequest;
import java.io.BufferedReader; import java.io.BufferedReader;
@ -24,6 +23,12 @@ public class PayTransactionController {
@Reference(validation = "true") @Reference(validation = "true")
private PayTransactionService payService; private PayTransactionService payService;
@GetMapping("/get")
public CommonResult<PayTransactionBO> get(@RequestParam("appId") String appId,
@RequestParam("orderId") String orderId) {
return payService.getTransaction(UserSecurityContextHolder.getContext().getUserId(), appId, orderId);
}
@PostMapping("/submit") // TODO api 注释 @PostMapping("/submit") // TODO api 注释
// TODO result 后面改下 // TODO result 后面改下
public CommonResult<PayTransactionSubmitBO> submit(HttpServletRequest request, public CommonResult<PayTransactionSubmitBO> submit(HttpServletRequest request,

View File

@ -8,6 +8,8 @@ import cn.iocoder.mall.pay.api.dto.PayTransactionSubmitDTO;
public interface PayTransactionService { public interface PayTransactionService {
CommonResult<PayTransactionBO> getTransaction(Integer userId, String appId, String orderId);
CommonResult<PayTransactionBO> createTransaction(PayTransactionCreateDTO payTransactionCreateDTO); CommonResult<PayTransactionBO> createTransaction(PayTransactionCreateDTO payTransactionCreateDTO);
CommonResult<PayTransactionSubmitBO> submitTransaction(PayTransactionSubmitDTO payTransactionSubmitDTO); CommonResult<PayTransactionSubmitBO> submitTransaction(PayTransactionSubmitDTO payTransactionSubmitDTO);

View File

@ -14,9 +14,9 @@ public enum PayErrorCodeEnum {
// ========== TRANSACTION 模块 ========== // ========== TRANSACTION 模块 ==========
PAY_TRANSACTION_NOT_FOUND(100401000, "支付交易单不存在"), PAY_TRANSACTION_NOT_FOUND(100401000, "支付交易单不存在"),
PAY_TRANSACTION_STATUS_IS_NOT_WAITING(100401001, "支付交易单不处于待支付"), PAY_TRANSACTION_STATUS_IS_NOT_WAITING(100401001, "支付交易单不处于待支付"),
PAY_TRANSACTION_EXTENSION_NOT_FOUND(100401002, "支付交易拓展单不存在"), PAY_TRANSACTION_EXTENSION_NOT_FOUND(100401002, "支付交易拓展单不存在"),
PAY_TRANSACTION_EXTENSION_STATUS_IS_NOT_WAITING(100401003, "支付交易拓展单不处于待支付"), PAY_TRANSACTION_EXTENSION_STATUS_IS_NOT_WAITING(100401003, "支付交易拓展单不处于待支付"),
PAY_TRANSACTION_ERROR_USER(100401004, "支付交易单用户不正确"),
; ;
private final int code; private final int code;

View File

@ -53,6 +53,16 @@ public class PayServiceImpl implements PayTransactionService {
@Resource @Resource
private RocketMQTemplate rocketMQTemplate; private RocketMQTemplate rocketMQTemplate;
@Override
public CommonResult<PayTransactionBO> getTransaction(Integer userId, String appId, String orderId) {
PayTransactionDO payTransaction = payTransactionMapper.selectByAppIdAndOrderId(appId, orderId);
if (payTransaction == null) {
return ServiceExceptionUtil.error(PayErrorCodeEnum.PAY_TRANSACTION_NOT_FOUND.getCode());
}
// TODO 芋艿 userId 的校验
return CommonResult.success(PayTransactionConvert.INSTANCE.convert(payTransaction));
}
@Override @Override
@SuppressWarnings("Duplicates") @SuppressWarnings("Duplicates")
public CommonResult<PayTransactionBO> createTransaction(PayTransactionCreateDTO payTransactionCreateDTO) { public CommonResult<PayTransactionBO> createTransaction(PayTransactionCreateDTO payTransactionCreateDTO) {