From 8033ea73b898357ad8853524ba558b18c42c2bbe Mon Sep 17 00:00:00 2001
From: nickchange <126672920+nickchange@users.noreply.github.com>
Date: 星期三, 01 十一月 2023 20:27:51 +0800
Subject: [PATCH] 10.31.6

---
 cloud-server-activity/src/main/java/com/dsh/activity/controller/CouponController.java |   43 +++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 43 insertions(+), 0 deletions(-)

diff --git a/cloud-server-activity/src/main/java/com/dsh/activity/controller/CouponController.java b/cloud-server-activity/src/main/java/com/dsh/activity/controller/CouponController.java
index e4d115e..d9bac30 100644
--- a/cloud-server-activity/src/main/java/com/dsh/activity/controller/CouponController.java
+++ b/cloud-server-activity/src/main/java/com/dsh/activity/controller/CouponController.java
@@ -91,7 +91,42 @@
     @Autowired
     private AppUserClient appUserClient;
 
+    /**
+     * 查询注册赠送优惠券 判断当前优惠券限领数量
+     */
+    @ResponseBody
+    @PostMapping("/coupon/queryCouponByUser/{userId}")
+    public List<Integer> queryCouponByUser(@PathVariable("userId") Integer userId){
+        List<Coupon> list = couponService.list(new QueryWrapper<Coupon>().eq("distributionMethod", 2)
+                .le("startTime", new Date()).ge("endTime", new Date()).eq("auditStatus", 2)
+                .eq("state", 1));
 
+        for (Coupon coupon : list) {
+            // 发放数量
+            Integer quantityIssued = coupon.getQuantityIssued();
+            // 限领数量
+            Integer pickUpQuantity = coupon.getPickUpQuantity();
+            // 优惠券已领取数量
+            int couponId = ucService.count(new QueryWrapper<UserCoupon>().eq("couponId", coupon.getId()));
+            // 用户已领取该优惠券数量
+            int count = ucService.count(new QueryWrapper<UserCoupon>().eq("couponId", coupon.getId()
+            ).eq("userId", userId));
+            if (couponId>=quantityIssued){
+                continue;
+            }
+            if (count>=pickUpQuantity){
+                continue;
+            }
+            // 条件满足 将优惠券送给用户
+            UserCoupon userCoupon = new UserCoupon();
+            userCoupon.setCouponId(coupon.getId());
+            userCoupon.setUserId(userId);
+            userCoupon.setStatus(1);
+            userCoupon.setInsertTime(new Date());
+            ucService.save(userCoupon);
+        }
+        return null;
+    }
 
     @ResponseBody
     @PostMapping("/api/coupon/queryCouponList")
@@ -526,6 +561,14 @@
             if(dataVo.getObjType()!=1){
                 coupon.setAuditStatus(1);
             }
+            if (dataVo.getUserType()==1){
+                coupon.setAuditStatus(2);
+            }else{
+                coupon.setAuditStatus(1);
+            }
+            if(dataVo.getObjType()!=1){
+                coupon.setAuditStatus(1);
+            }
 
             boolean save = couponService.save(coupon);
             if (save){

--
Gitblit v1.7.1