From 24a0c40654afc75c9da879ebb4c9a4c93c57e806 Mon Sep 17 00:00:00 2001
From: Hentua <wangdoubleone@gmail.com>
Date: Wed, 07 Jun 2023 12:00:54 +0800
Subject: [PATCH] 微信支付

---
 src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallOrderInfoServiceImpl.java |   30 ++++++++++++++++++++++++------
 1 files changed, 24 insertions(+), 6 deletions(-)

diff --git a/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallOrderInfoServiceImpl.java b/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallOrderInfoServiceImpl.java
index 7f8115e..e63d158 100644
--- a/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallOrderInfoServiceImpl.java
+++ b/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallOrderInfoServiceImpl.java
@@ -3,6 +3,7 @@
 import cc.mrbird.febs.common.entity.FebsResponse;
 import cc.mrbird.febs.common.enumerates.*;
 import cc.mrbird.febs.common.exception.FebsException;
+import cc.mrbird.febs.common.exception.GeneratorException;
 import cc.mrbird.febs.common.utils.AppContants;
 import cc.mrbird.febs.common.utils.LoginUserUtil;
 import cc.mrbird.febs.common.utils.MallUtils;
@@ -23,6 +24,8 @@
 import cc.mrbird.febs.pay.service.UnipayService;
 import cc.mrbird.febs.rabbit.producter.AgentProducer;
 import cn.hutool.core.collection.CollUtil;
+import cn.hutool.core.date.DateField;
+import cn.hutool.core.date.DateTime;
 import cn.hutool.core.date.DateUnit;
 import cn.hutool.core.date.DateUtil;
 import cn.hutool.core.thread.ThreadUtil;
@@ -142,6 +145,14 @@
 
                 if (MallGoods.ISSALE_STATUS_DISABLED.equals(mallGoods.getIsSale())) {
                     throw new FebsException(mallGoods.getGoodsName() + "已下架");
+                }
+
+                if (mallGoods.getRulesTimes() != null && mallGoods.getRulesCnt() != null) {
+                    DateTime startDate = DateUtil.offset(new Date(), DateField.DAY_OF_YEAR, -mallGoods.getRulesTimes());
+                    List<MallOrderInfo> orderInfos = this.baseMapper.selectScoreOrderListInDate(DateUtil.beginOfDay(startDate), DateUtil.endOfDay(new Date()), mallGoods.getId());
+                    if (CollUtil.isNotEmpty(orderInfos) && orderInfos.size() >= mallGoods.getRulesCnt()) {
+                        throw new FebsException("超出领取最大限制");
+                    }
                 }
 
                 BigDecimal amount = mallGoods.getScore().multiply(BigDecimal.valueOf(item.getCnt()));
@@ -290,6 +301,14 @@
                     orderInfo.setName("商品");
                 }else{
                     orderInfo.setName(itemsWx.get(0).getGoodsName());
+                }
+
+                if (orderInfo.getScoreCnt().compareTo(BigDecimal.ZERO) > 0) {
+                    int reduce = memberWalletService.reduce(orderInfo.getScoreCnt(), member.getId(), "prizeScore");
+                    if (reduce == 2) {
+                        throw new FebsException("积分不足");
+                    }
+                    mallMoneyFlowService.addMoneyFlow(member.getId(), orderInfo.getScoreCnt().negate(), MoneyFlowTypeEnum.PAY.getValue(), orderInfo.getOrderNo(), FlowTypeEnum.PRIZE_SCORE.getValue());
                 }
 
                 payResultStr = wechatPayService.pay(orderInfo);
@@ -529,16 +548,15 @@
             orderDetailVo.setRemainTime(remainTime);
         }
         if(2 == deliverType){
-            MallShopApply mallShopApply = mallShopApplyMapper.selectById(orderInfo.getShopId());
+            MallShop mallShopApply = mallShopMapper.selectById(orderInfo.getShopId());
             if(ObjectUtil.isNotEmpty(mallShopApply)){
                 ApiShopApplyVo apiShopApplyVo = new ApiShopApplyVo();
-                apiShopApplyVo.setName(mallShopApply.getName());
+                apiShopApplyVo.setName(mallShopApply.getShopName());
                 apiShopApplyVo.setPhone(mallShopApply.getPhone());
-                apiShopApplyVo.setSaleArea(mallShopApply.getSaleArea());
-                apiShopApplyVo.setLatitude(mallShopApply.getLatitude());
-                apiShopApplyVo.setLongitude(mallShopApply.getLongitude());
+                apiShopApplyVo.setLatitude(mallShopApply.getLatitude().toPlainString());
+                apiShopApplyVo.setLongitude(mallShopApply.getLongitude().toPlainString());
                 apiShopApplyVo.setShopName(mallShopApply.getShopName());
-                apiShopApplyVo.setAddress(mallShopApply.getAddress());
+                apiShopApplyVo.setAddress(mallShopApply.getShopAddress());
                 orderDetailVo.setApiShopApplyVo(apiShopApplyVo);
             }
         }

--
Gitblit v1.9.1