From 4dfc81531cba8e10ea569559389cdcbd50f4bacd Mon Sep 17 00:00:00 2001 From: 无关风月 <443237572@qq.com> Date: 星期三, 27 十一月 2024 19:24:52 +0800 Subject: [PATCH] 代码提交 --- xinquan-modules/xinquan-user/src/main/java/com/xinquan/user/controller/client/ClientAppUserController.java | 1 xinquan-modules/xinquan-order/src/main/java/com/xinquan/order/controller/client/ClientOrderController.java | 103 +++++++++++++++++++++++++++++++++- xinquan-modules/xinquan-order/src/main/java/com/xinquan/order/service/impl/OrderServiceImpl.java | 35 ++++++++++- 3 files changed, 131 insertions(+), 8 deletions(-) diff --git a/xinquan-modules/xinquan-order/src/main/java/com/xinquan/order/controller/client/ClientOrderController.java b/xinquan-modules/xinquan-order/src/main/java/com/xinquan/order/controller/client/ClientOrderController.java index 5a5e1d1..e67f753 100644 --- a/xinquan-modules/xinquan-order/src/main/java/com/xinquan/order/controller/client/ClientOrderController.java +++ b/xinquan-modules/xinquan-order/src/main/java/com/xinquan/order/controller/client/ClientOrderController.java @@ -223,8 +223,9 @@ orderCourseVO.setCourseTitle(data1.getMeditationTitle()); orderCourseVO.setDescription(data1.getCoverDescription()); orderCourseVO.setCoverUrl(data1.getCoverUrl()); - orderCourseVO.setGeneralPrice(data1.getGeneralPrice()); - orderCourseVO.setIosPrice(data1.getIosPrice()); + Order byId = orderService.getById(orderCourseVO.getId()); + orderCourseVO.setGeneralPrice(byId.getRealPayAmount()); + orderCourseVO.setIosPrice(byId.getRealPayAmount()); orderCourseVO.setCount(data1.getRealLearnedNum()+data1.getVirtualLearnedNum()); orderCourseVO.setChargeType(data1.getChargeType()); orderCourseVO.setCoverDescription(data1.getCoverDescription()); @@ -243,6 +244,9 @@ Long data9 = remoteAppUserService.getCourseChapterHistoryCount(courseChapter.getId()).getData(); b+=data9; } + Order byId1 = orderService.getById(orderCourseVO.getId()); + orderCourseVO.setGeneralPrice(byId1.getRealPayAmount()); + orderCourseVO.setIosPrice(byId1.getRealPayAmount()); orderCourseVO.setCount(b+temp); if (data4!=null){ orderCourseVO.setCourseTitle(data4.getCourseTitle()); @@ -342,7 +346,99 @@ @RequestParam(value = "vipType", required = false) Integer vipType) { + LoginUser loginUser = tokenService.getLoginUser(); + if (loginUser==null){ + return R.tokenError("登录失效"); + } + Long userId = loginUser.getUserid(); try { + if (orderId!=null){ + Order order = orderService.getById(orderId); + if (order.getRealPayAmount().compareTo(new BigDecimal("0")) == 0 ){ + // 无需付款 + switch (orderFrom){ + case 1: + Meditation data1 = remoteMeditationService.getMeditationById(targetId).getData(); + order.setBuyContent("购买疗愈【"+data1.getMeditationTitle()+"】"); + switch (payType){ + case 1: + order.setTotalAmount(data1.getGeneralPrice()); + order.setRealPayAmount(data1.getGeneralPrice()); + + break; + case 2: + order.setTotalAmount(data1.getIosPrice()); + order.setRealPayAmount(data1.getIosPrice()); + break; + } + + + break; + case 2: + Course data = remoteCourseService.getCourseById(targetId).getData(); + + order.setBuyContent("购买课程【"+data.getCourseTitle()+"】"); + switch (payType){ + case 1: + order.setTotalAmount(data.getGeneralPrice()); + order.setRealPayAmount(data.getGeneralPrice()); + + break; + case 2: + order.setTotalAmount(data.getIosPrice()); + order.setRealPayAmount(data.getIosPrice()); + break; + } + if (receiverId!=null){ + remoteAppUserService.addNotice(receiverId + "", data.getId() + "", + userId + "", order.getTotalAmount() + ""); + } + + break; + } + orderService.updateById(order); + switch (orderFrom){ + case 2: + if (receiverId!=null){ + remoteAppUserService.addAppUserCourse(order.getBusinessId(),order.getGiveUserId(),order.getId(),1); + remoteAppUserService.addNotice(receiverId+"",order.getBusinessId()+"",order.getAppUserId()+"",order.getTotalAmount()+""); + }else{ + // 自己购买 + remoteAppUserService.addAppUserCourse(order.getBusinessId(),order.getAppUserId(),order.getId(),2); + } + break; + } + + OrderPaymentRecord one = orderPaymentRecordService.lambdaQuery().eq(OrderPaymentRecord::getOrderId, order.getId()) + .eq(OrderPaymentRecord::getPaymentType, 4).one(); + if (one!=null){ + one.setOrderId(order.getId()); + one.setPaymentType(4); + one.setPayAmount(new BigDecimal("0")); + one.setPaymentStatus(2); + orderPaymentRecordService.updateById(one); + }else{ + OrderPaymentRecord orderPaymentRecord = new OrderPaymentRecord(); + orderPaymentRecord.setOrderId(order.getId()); + orderPaymentRecord.setPaymentType(4); + orderPaymentRecord.setPayAmount(new BigDecimal("0")); + orderPaymentRecord.setPaymentStatus(2); + orderPaymentRecordService.save(orderPaymentRecord); + } + OrderPaymentRecord orderPaymentRecord = new OrderPaymentRecord(); + orderPaymentRecord.setOrderId(order.getId()); + orderPaymentRecord.setPaymentType(4); + orderPaymentRecord.setPayAmount(order.getTotalAmount()); + orderPaymentRecord.setPaymentStatus(2); + orderPaymentRecordService.save(orderPaymentRecord); + ClientPlaceOrderVO clientPlaceOrderVO = new ClientPlaceOrderVO(); + clientPlaceOrderVO.setId(order.getId()); + clientPlaceOrderVO.setOrderNo(order.getBizOrderNo()); + return R.ok(clientPlaceOrderVO); + } + + } + ClientPlaceOrderVO clientPlaceOrderVO = orderService.placeOrder(targetId, orderFrom, receiverId, orderId, balanceFlag, payType, amount, vipType,type); System.err.println("支付返回参数"+clientPlaceOrderVO); @@ -581,7 +677,8 @@ one.setPaymentStatus(2); one.setPaymentTime(LocalDateTime.now()); OrderPaymentRecord one2 = orderPaymentRecordService.lambdaQuery().eq(OrderPaymentRecord::getOrderId, one.getId()) - .ne(OrderPaymentRecord::getPaymentType, 4).one(); + .ne(OrderPaymentRecord::getPaymentType, 4) + .eq(OrderPaymentRecord::getPayOrderNo,string2).one(); if (one2!=null){ one2.setPaymentStatus(2); one2.setPayOrderNo(string2); diff --git a/xinquan-modules/xinquan-order/src/main/java/com/xinquan/order/service/impl/OrderServiceImpl.java b/xinquan-modules/xinquan-order/src/main/java/com/xinquan/order/service/impl/OrderServiceImpl.java index b92359d..a780673 100644 --- a/xinquan-modules/xinquan-order/src/main/java/com/xinquan/order/service/impl/OrderServiceImpl.java +++ b/xinquan-modules/xinquan-order/src/main/java/com/xinquan/order/service/impl/OrderServiceImpl.java @@ -117,7 +117,9 @@ this.save(order); }else{ order = this.getById(orderId); + order.setBizOrderNo(orderNo); order.setBuyContent("购买疗愈【"+meditationTitle+"】"); + this.updateById(order); } Long orderId9 = order.getId(); @@ -178,6 +180,8 @@ }else{ order = this.getById(orderId); order.setBuyContent("购买课程【"+courseTitle+"】"); + order.setBizOrderNo(orderNo); + this.updateById(order); } Long orderId8 = order.getId(); @@ -299,7 +303,12 @@ balancePaymentRecord.setPayAmount(one.getRealPayAmount()); balancePaymentRecord.setPaymentType(PaymentTypeEnum.BALANCE_PAY.getCode()); balancePaymentRecord.setPaymentStatus(PaymentStatusEnum.COMPLETED.getCode()); - orderPaymentRecordService.save(balancePaymentRecord); + List<OrderPaymentRecord> list = orderPaymentRecordService.lambdaQuery().eq(OrderPaymentRecord::getOrderId, orderId) + .eq(OrderPaymentRecord::getPaymentType, 4).list(); + if (list.isEmpty()){ + orderPaymentRecordService.save(balancePaymentRecord); + } + return new BigDecimal("0"); }else { // 更新用户余额 @@ -313,7 +322,11 @@ balancePaymentRecord.setPaymentType(PaymentTypeEnum.BALANCE_PAY.getCode()); balancePaymentRecord.setPaymentStatus(PaymentStatusEnum.COMPLETED.getCode()); balancePaymentRecord.setPayAmount(appUser.getBalance()); - orderPaymentRecordService.save(balancePaymentRecord); + List<OrderPaymentRecord> list = orderPaymentRecordService.lambdaQuery().eq(OrderPaymentRecord::getOrderId, orderId) + .eq(OrderPaymentRecord::getPaymentType, 4).list(); + if (list.isEmpty()){ + orderPaymentRecordService.save(balancePaymentRecord); + } // 计算除去余额还需支付的金额 return one.getRealPayAmount() .subtract(appUser.getBalance()); @@ -372,7 +385,14 @@ clientPlaceOrderVO.setOrderId(payInfo.getString("id")); paymentRecord.setPaymentStatus(PaymentStatusEnum.TO_BE_PAID.getCode()); paymentRecord.setPayAmount(needPayAmount); - orderPaymentRecordService.save(paymentRecord); + OrderPaymentRecord list = orderPaymentRecordService.lambdaQuery().eq(OrderPaymentRecord::getOrderId, orderId) + .ne(OrderPaymentRecord::getPaymentType, 4).one(); + if (list==null){ + orderPaymentRecordService.save(paymentRecord); + }else{ + list.setPayOrderNo(payInfo.getString("id")); + orderPaymentRecordService.updateById(list); + } // 设置订单是否需要支付标识 clientPlaceOrderVO.setZeroFlag(DisabledEnum.NO.getCode()); }else{ @@ -396,7 +416,14 @@ paymentRecord.setPaymentType(PaymentTypeEnum.ALI_PAY.getCode()); paymentRecord.setPaymentStatus(PaymentStatusEnum.TO_BE_PAID.getCode()); paymentRecord.setPayOrderNo(payInfo.getString("id")); - orderPaymentRecordService.save(paymentRecord); + OrderPaymentRecord list = orderPaymentRecordService.lambdaQuery().eq(OrderPaymentRecord::getOrderId, orderId) + .ne(OrderPaymentRecord::getPaymentType, 4).one(); + if (list==null){ + orderPaymentRecordService.save(paymentRecord); + }else{ + list.setPayOrderNo(payInfo.getString("id")); + orderPaymentRecordService.updateById(list); + } clientPlaceOrderVO.setPayAmt(payInfo.getString("pay_amt")); clientPlaceOrderVO.setOrderId(payInfo.getString("id")); // 设置订单是否需要支付标识 diff --git a/xinquan-modules/xinquan-user/src/main/java/com/xinquan/user/controller/client/ClientAppUserController.java b/xinquan-modules/xinquan-user/src/main/java/com/xinquan/user/controller/client/ClientAppUserController.java index 5eb9ca8..aa804a6 100644 --- a/xinquan-modules/xinquan-user/src/main/java/com/xinquan/user/controller/client/ClientAppUserController.java +++ b/xinquan-modules/xinquan-user/src/main/java/com/xinquan/user/controller/client/ClientAppUserController.java @@ -558,7 +558,6 @@ } } byId.setTotalEnergyValue(byId.getTotalEnergyValue()+energyValue); - byId.setEnergyValue(byId.getEnergyValue()+energyValue); appUserService.updateById(byId); AppUserEnergyRecord appUserEnergyRecord = new AppUserEnergyRecord(); appUserEnergyRecord.setAppUserId(byId.getId()); -- Gitblit v1.7.1