From 7504753468ffbd0af41b07de66c0ccebf73680ea Mon Sep 17 00:00:00 2001
From: lisy <linlangsur163@163.com>
Date: 星期一, 14 八月 2023 15:47:20 +0800
Subject: [PATCH] 管理后台:添加优惠券的字段优化

---
 cloud-server-activity/src/main/java/com/dsh/activity/controller/PointMercharsController.java |   56 ++++++++++++++++++++++++++++++++++++++++++++++++++------
 1 files changed, 50 insertions(+), 6 deletions(-)

diff --git a/cloud-server-activity/src/main/java/com/dsh/activity/controller/PointMercharsController.java b/cloud-server-activity/src/main/java/com/dsh/activity/controller/PointMercharsController.java
index dce6685..24697ee 100644
--- a/cloud-server-activity/src/main/java/com/dsh/activity/controller/PointMercharsController.java
+++ b/cloud-server-activity/src/main/java/com/dsh/activity/controller/PointMercharsController.java
@@ -12,6 +12,7 @@
 import com.dsh.activity.feignclient.other.StoreClient;
 import com.dsh.activity.feignclient.other.model.StoreDetailOfCourse;
 import com.dsh.activity.model.PointMerchandiseVo;
+import com.dsh.activity.model.request.AppUserGoodResp;
 import com.dsh.activity.model.request.CommodityRequest;
 import com.dsh.activity.service.*;
 import com.dsh.activity.util.GDMapGeocodingUtil;
@@ -74,6 +75,7 @@
         List<IntegralCommodity> commodity = new ArrayList<>();
         List<PointsMerchandise> merchandises = pmdsService.list(new QueryWrapper<PointsMerchandise>()
                 .eq("state",1)
+                .eq("shelves",1)
                 .gt("endTime",new Date()));
         if (merchandises.size() > 0){
             for (PointsMerchandise merchandise : merchandises) {
@@ -110,7 +112,8 @@
         }
 
         list = pmdsService.list(new QueryWrapper<PointsMerchandise>()
-                .eq("state", 1));
+                .eq("state", 1)
+                .eq("shelves",1));
         if (list.size() > 0 ){
             Iterator<PointsMerchandise> iterator = list.iterator();
             while (iterator.hasNext()) {
@@ -160,7 +163,7 @@
                 int coursePackageNums = upmseService.count(new QueryWrapper<UserPointsMerchandise>()
                         .eq("pointsMerchandiseId",merchandise.getId() ));
                 detailsVo.setRedeemedNum(coursePackageNums);
-                detailsVo.setResidueNum(merchandise.getQuantityIssued() - coursePackageNums);
+                detailsVo.setResidueNum(Math.max(merchandise.getQuantityIssued() - coursePackageNums, 0));
                 detailsVo.setPerLimit(merchandise.getPickUpQuantity());
                 if (merchandise.getRedemptionMethod() == 1){
                     detailsVo.setExchangeType(1);
@@ -224,7 +227,7 @@
                 int count = upmseService.count(new QueryWrapper<UserPointsMerchandise>()
                         .eq("pointsMerchandiseId",merchandise.getId() ));
                 detailsVo.setRedeemedNum(count);
-                detailsVo.setResidueNum(merchandise.getQuantityIssued()-count);
+                detailsVo.setResidueNum(Math.max(merchandise.getQuantityIssued() - count, 0));
                 detailsVo.setPerLimit(merchandise.getPickUpQuantity());
                 detailsVo.setExchangeType(merchandise.getRedemptionMethod());
                 if (merchandise.getRedemptionMethod() == 1){
@@ -235,10 +238,13 @@
                 }
                 detailsVo.setCost(merchandise.getPrice());
                 if (merchandise.getUseScope() == 1){
+                    detailsVo.setExchangeAddrType(1);
                     detailsVo.setBelongs("全国通用");
                 }else if (merchandise.getUseScope() == 2){
+                    detailsVo.setExchangeAddrType(2);
                     detailsVo.setBelongs(merchandise.getProvince()+"|"+merchandise.getCity() + "用户可用");
                 }else {
+                    detailsVo.setExchangeAddrType(3);
                     List<PointsMerchandiseStore> list = pmdstoService.list(new QueryWrapper<PointsMerchandiseStore>()
                             .eq("pointsMerchandiseId",merchandise.getId() ));
                     PointsMerchandiseStore pointsMerchandiseStore = list.get(0);
@@ -273,10 +279,10 @@
                 });
                 detailsVo.setGoodName(coupon.getName());
                 detailsVo.setBelongsScope(coupon.getUserPopulation());
-                int couponNums = uconService.count(new QueryWrapper<UserCoupon>()
-                        .eq("couponId",coupon.getId() ));
+                int couponNums = upmseService.count(new QueryWrapper<UserPointsMerchandise>()
+                        .eq("pointsMerchandiseId",merchandise.getId() ));
                 detailsVo.setRedeemedNum(couponNums);
-                detailsVo.setResidueNum(coupon.getQuantityIssued()-couponNums);
+                detailsVo.setResidueNum(Math.max(coupon.getQuantityIssued() - couponNums, 0));
                 detailsVo.setPerLimit(coupon.getPickUpQuantity());
                 detailsVo.setExchangeType(coupon.getRedemptionMethod());
                 if (coupon.getRedemptionMethod() == 1){
@@ -286,14 +292,17 @@
                     detailsVo.setCash(coupon.getCash());
                 }
                 if (coupon.getUseScope() == 1){
+                    detailsVo.setExchangeAddrType(1);
                     detailsVo.setBelongs("全国通用");
                 }else if (coupon.getUseScope() == 2){
+                    detailsVo.setExchangeAddrType(2);
                     List<CouponCity> list = ccityService.list(new LambdaQueryWrapper<CouponCity>()
                             .eq(CouponCity::getCouponId, coupon.getId()));
                     if (list.size() > 0){
                         detailsVo.setBelongs(list.get(0).getProvince()+"|"+list.get(0).getCity() + "用户可用");
                     }
                 }else {
+                    detailsVo.setExchangeAddrType(3);
                     List<CouponStore> list = cstoreService.list(new QueryWrapper<CouponStore>()
                             .eq("couponId",coupon.getId() ));
                     StoreDetailOfCourse courseOfStore = stoClient.getCourseOfStore(list.get(0).getStoreId());
@@ -483,4 +492,39 @@
         return storeIds;
     }
 
+    /**
+     * 获取用户已兑换商品的数量
+     * @param goodResp
+     * @return 数量
+     */
+    @ResponseBody
+    @PostMapping("/base/pointMerchars/queryUserHasGoodsNums")
+    public int queryUserHasGoodsNums(@RequestBody AppUserGoodResp goodResp){
+        int count = upmseService.count(new LambdaQueryWrapper<UserPointsMerchandise>()
+                .eq(UserPointsMerchandise::getUserId,goodResp.getGoodId())
+                .eq(UserPointsMerchandise::getPointsMerchandiseId,goodResp.getGoodId()));
+        System.out.println(count);
+        return count;
+    }
+
+
+    /**
+     * 变更兑换商品的的状态
+     * @param code
+     * @return 数量
+     */
+    @ResponseBody
+    @PostMapping("/base/pointMerchars/deletePaymentRecord")
+    public void deletePaymentRecord(@RequestBody String code){
+        List<UserPointsMerchandise> list = upmseService.list(new LambdaQueryWrapper<UserPointsMerchandise>()
+                .eq(UserPointsMerchandise::getCode,code));
+        if (list.size() > 0 ){
+            for (UserPointsMerchandise pointsMerchandise : list) {
+                pointsMerchandise.setState(2);
+                upmseService.updateById(pointsMerchandise);
+            }
+        }
+
+    }
+
 }

--
Gitblit v1.7.1