From 4c9035836c18886883d3f69d8443c53d15b068fc Mon Sep 17 00:00:00 2001
From: 无关风月 <443237572@qq.com>
Date: 星期五, 22 八月 2025 14:39:53 +0800
Subject: [PATCH] 会员支付相关

---
 cloud-server-activity/src/main/java/com/dsh/activity/controller/CouponController.java |   72 ++++++++++++++++++++++++++++--------
 1 files changed, 56 insertions(+), 16 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 fc7cf21..e894f41 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
@@ -20,6 +20,7 @@
 import com.dsh.activity.feignclient.other.OperatorClient;
 import com.dsh.activity.feignclient.other.RegionClient;
 import com.dsh.activity.feignclient.other.StoreClient;
+import com.dsh.activity.feignclient.other.VipClient;
 import com.dsh.activity.feignclient.other.model.CityDataAndProvinceDataVo;
 import com.dsh.activity.feignclient.other.model.Store;
 import com.dsh.activity.feignclient.other.model.StoreInfoDto;
@@ -27,10 +28,8 @@
 import com.dsh.activity.model.CouponListVo;
 import com.dsh.activity.model.CouponRecordQuery;
 import com.dsh.activity.model.VipDetailVO;
-import com.dsh.activity.model.request.CommodityRequest;
-import com.dsh.activity.model.request.CouponDataVo;
-import com.dsh.activity.model.request.CouponPackageReq;
-import com.dsh.activity.model.request.VipDetailDto;
+import com.dsh.activity.model.VipPaymentVO;
+import com.dsh.activity.model.request.*;
 import com.dsh.activity.model.response.CouponPackageResp;
 import com.dsh.activity.service.*;
 import com.dsh.activity.util.GDMapGeocodingUtil;
@@ -70,9 +69,12 @@
 
     @Autowired
     private TokenUtil tokenUtil;
+    @Autowired
+    private VipClient vipClient;
 
     @Autowired
     private UserCouponService ucService;
+
 
     @Autowired
     private GDMapGeocodingUtil gdMapGeocodingUtil;
@@ -102,18 +104,21 @@
 
     @Resource
     private StudentClient studentClient;
+    @Resource
+    private PointsMerchandiseService pointsMerchandiseService;
 
 
 
 
     @PostMapping("/base/coupon/vipDetail")
     @ResponseBody
-    List<VipDetailVO> vipDetail(VipDetailDto vipDetailDto){
+    List<VipDetailVO> vipDetail(@RequestBody VipDetailDto vipDetailDto){
+        List<PointsMerchandise> pointsMerchandiseList = pointsMerchandiseService.list();
         List<VipDetailVO> vipDetailVOS = new ArrayList<>();
         List<VipDetail> list = vipDetailService.lambdaQuery()
-                .in(!vipDetailDto.getVipIds().isEmpty(), VipDetail::getVipId, vipDetailDto.getVipIds())
-                .in(!vipDetailDto.getUserIds().isEmpty(), VipDetail::getAppUserId, vipDetailDto.getUserIds())
-                .in(!vipDetailDto.getStoreIds().isEmpty(), VipDetail::getUseStoreId, vipDetailDto.getStoreIds())
+                .in(vipDetailDto.getVipIds()!=null&&!vipDetailDto.getVipIds().isEmpty(), VipDetail::getVipId, vipDetailDto.getVipIds())
+                .in(vipDetailDto.getUserIds()!=null&&!vipDetailDto.getUserIds().isEmpty(), VipDetail::getAppUserId, vipDetailDto.getUserIds())
+                .in(vipDetailDto.getStoreIds()!=null&&!vipDetailDto.getStoreIds().isEmpty(), VipDetail::getUseStoreId, vipDetailDto.getStoreIds())
                 .ge(StringUtils.hasLength(vipDetailDto.getStartTime()), VipDetail::getInsertTime, vipDetailDto.getStartTime())
                 .le(StringUtils.hasLength(vipDetailDto.getEndTime()), VipDetail::getInsertTime, vipDetailDto.getEndTime())
                 .ge(StringUtils.hasLength(vipDetailDto.getUseStartTime()), VipDetail::getUseTime, vipDetailDto.getUseStartTime())
@@ -135,12 +140,21 @@
                 if (coupon!=null){
                     vipDetailVO.setTicketName(coupon.getName());
                     vipDetailVO.setGoodsName(coupon.getName());
+                    if (coupon.getType()==4){
+                        // 查询抵扣商品
+                        PointsMerchandise pointsMerchandise1 = pointsMerchandiseList.stream().filter(pointsMerchandise -> pointsMerchandise.getId().equals(coupon.getGoodsId()))
+                                .findFirst().orElse(null);
+                        if (pointsMerchandise1 != null){
+                            vipDetailVO.setGoodsName(pointsMerchandise1.getName());
+                        }
+                    }
                 }
-            }
 
+            }
         }
         return vipDetailVOS;
     }
+
 
     /**
      * 查询注册赠送优惠券 判断当前优惠券限领数量
@@ -185,24 +199,45 @@
     @PostMapping("/api/coupon/queryCouponList")
     @ApiOperation(value = "获取优惠券列表", tags = {"APP-成为会员", ""})
     @ApiImplicitParams({
-            @ApiImplicitParam(value = "1=积分购买,2=注册赠送", name = "distributionMethod", dataType = "int", required = true),
+            @ApiImplicitParam(value = "vipId", name = "vipId", dataType = "int", required = true),
             @ApiImplicitParam(name = "Authorization", value = "用户token(Bearer +token)", required = true, dataType = "String", paramType = "header", defaultValue = "Bearer eyJhbGciOiJIUzUxMiJ9.....")
     })
-    public ResultUtil<List<CouponListVo>> queryCouponList(Integer distributionMethod) {
-        if (null == distributionMethod) {
-            return ResultUtil.paranErr("distributionMethod");
+    public ResultUtil<VipCouponTicketListResp> queryCouponList(Integer vipId) {
+        if (null == vipId) {
+            return ResultUtil.paranErr("vipId");
         }
+        VipCouponTicketListResp vipCouponTicketListResp = new VipCouponTicketListResp();
         try {
             Integer uid = tokenUtil.getUserIdFormRedis();
             if (null == uid) {
                 return ResultUtil.tokenErr();
             }
-            List<CouponListVo> listVos = couponService.queryCouponList(uid, distributionMethod);
-            return ResultUtil.success(listVos);
+            List<Vip> vips = vipClient.listAll();
+            Vip vip = vips.stream().filter(e -> e.getId().equals(vipId)).findFirst().orElse(null);
+            if (vip!=null){
+                List<CouponVipResp> couponVipResps = new ArrayList<>();
+                List<TicketVipResp> ticketVipResps = new ArrayList<>();
+                List<CouponVipResp> couponList = vip.getCouponList();
+                for (CouponVipResp couponVipResp : couponList) {
+                    for (Integer i = 0; i < couponVipResp.getCount(); i++) {
+                        couponVipResps.add(couponVipResp);
+                    }
+                }
+                List<TicketVipResp> ticketList = vip.getTicketList();
+                for (TicketVipResp ticketVipResp : ticketList) {
+                    for (Integer i = 0; i < ticketVipResp.getCount(); i++) {
+                        ticketVipResps.add(ticketVipResp);
+                    }
+                }
+                vipCouponTicketListResp.setCouponVipRespList(couponVipResps);
+                vipCouponTicketListResp.setTicketVipRespList(ticketVipResps);
+                return ResultUtil.success(vipCouponTicketListResp);
+            }
         } catch (Exception e) {
             e.printStackTrace();
             return ResultUtil.success();
         }
+        return ResultUtil.success();
     }
 
 
@@ -884,7 +919,12 @@
         List<CouponCity> list = cityService.list(new LambdaQueryWrapper<CouponCity>());
         return list;
     }
-
+    @ResponseBody
+    @PostMapping("/base/coupon/queryAllPointGoods")
+    public List<PointsMerchandise> queryAllPointGoods(){
+        List<PointsMerchandise> pointsMerchandiseList = pointsMerchandiseService.list();
+        return pointsMerchandiseList;
+    }
     @ResponseBody
     @PostMapping("/base/coupon/queryStore")
     public List<Integer> queryStore(@RequestBody Integer id) {

--
Gitblit v1.7.1