From c5d38d650d2ac4101b1293a4f17346e7d5420076 Mon Sep 17 00:00:00 2001
From: huliguo <2023611923@qq.com>
Date: 星期五, 04 七月 2025 20:39:58 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/2.0' into 2.0

---
 ruoyi-modules/ruoyi-member/src/main/java/com/ruoyi/member/service/impl/member/MemberCouponServiceImpl.java |  203 ++++++++++++++++++++++++++++++++++++++++----------
 1 files changed, 161 insertions(+), 42 deletions(-)

diff --git a/ruoyi-modules/ruoyi-member/src/main/java/com/ruoyi/member/service/impl/member/MemberCouponServiceImpl.java b/ruoyi-modules/ruoyi-member/src/main/java/com/ruoyi/member/service/impl/member/MemberCouponServiceImpl.java
index eb96ac3..14e1a02 100644
--- a/ruoyi-modules/ruoyi-member/src/main/java/com/ruoyi/member/service/impl/member/MemberCouponServiceImpl.java
+++ b/ruoyi-modules/ruoyi-member/src/main/java/com/ruoyi/member/service/impl/member/MemberCouponServiceImpl.java
@@ -1,15 +1,22 @@
 package com.ruoyi.member.service.impl.member;
 
+import com.baomidou.dynamic.datasource.annotation.DS;
 import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
+import com.ruoyi.common.core.domain.R;
 import com.ruoyi.common.core.exception.ServiceException;
+import com.ruoyi.common.core.utils.DateUtils;
 import com.ruoyi.common.core.utils.StringUtils;
 import com.ruoyi.member.domain.dto.AppMemberCouponPageDto;
 import com.ruoyi.member.domain.dto.MemberSelectCouponDto;
 import com.ruoyi.member.domain.dto.MerGoodsCouponListDto;
+import com.ruoyi.member.domain.pojo.coupon.Coupon;
 import com.ruoyi.member.domain.vo.AppMemberCouponPageVo;
+import com.ruoyi.member.mapper.coupon.CouponMapper;
 import com.ruoyi.member.mapper.member.MemberCouponMapper;
+import com.ruoyi.member.service.coupon.CouponService;
+import com.ruoyi.member.service.coupon.MemberCouponRecordService;
 import com.ruoyi.member.service.member.MemberCouponService;
 import com.ruoyi.system.api.constant.AppErrorConstant;
 import com.ruoyi.system.api.domain.dto.MerBaseDto;
@@ -42,18 +49,28 @@
  * @since 2023-04-25
  */
 @Service
+@DS("sharding")
 public class MemberCouponServiceImpl extends ServiceImpl<MemberCouponMapper, MemberCoupon> implements MemberCouponService {
-
+    
     @Resource
     private MemberCouponMapper memberCouponMapper;
-
+    
     @Resource
     private RemoteGoodsService remoteGoodsService;
-
+    
     @Resource
     private RemoteShopService remoteShopService;
-
-
+    
+    @Resource
+    private CouponService couponService;
+    
+    @Resource
+    private MemberCouponRecordService memberCouponRecordService;
+    
+    @Resource
+    private CouponMapper couponMapper;
+    
+    
     /**
      * @description: TODO
      * @author jqs34
@@ -61,11 +78,11 @@
      * @version 1.0
      */
     @Override
-    public List<AppMemberCouponVo> listVoMemberCouponByUserId(MerBaseDto merBaseDto){
+    public List<AppMemberCouponVo> listVoMemberCouponByUserId(MerBaseDto merBaseDto) {
         List<AppMemberCouponVo> appMemberCouponVoList = memberCouponMapper.listVoMemberCouponByUserId(merBaseDto);
         return appMemberCouponVoList;
     }
-
+    
     /**
      * @description  核销优惠券
      * @author  jqs
@@ -74,7 +91,7 @@
      * @return  void
      */
     @Override
-    public MerVerifyCouponGetVo getVerifyCoupon(String verifyCoupon){
+    public MerVerifyCouponGetVo getVerifyCoupon(Long verifyCoupon){
         MemberCoupon memberCoupon = this.getById(verifyCoupon);
         // 检查是否存在该优惠券
         if (memberCoupon == null) {
@@ -110,7 +127,7 @@
         merVerifyCouponGetVo.setMemberCoupon(memberCoupon);
         return merVerifyCouponGetVo;
     }
-
+    
     /**
      * @description  核销优惠券
      * @author  jqs
@@ -119,7 +136,7 @@
      * @return  MerVerifyCouponGetVo
      */
     @Override
-    public MerVerifyCouponGetVo sureVerifyCoupon(String memberCouponId){
+    public MerVerifyCouponGetVo sureVerifyCoupon(Long memberCouponId){
         MemberCoupon memberCoupon = this.getById(memberCouponId);
         if(memberCoupon==null||memberCoupon.getDelFlag()==1){
             throw new ServiceException(AppErrorConstant.COUPON_NO_FIND);
@@ -148,13 +165,13 @@
             merVerifyCouponGetVo.setCouponFrom("平台");
         }
         memberCoupon.setCouponStatus(2);
-
+    
         memberCoupon.setUseTime(new Date());
         this.saveOrUpdate(memberCoupon);
         merVerifyCouponGetVo.setMemberCoupon(memberCoupon);
         return merVerifyCouponGetVo;
     }
-
+    
     /**
      * @description
      * @author  jqs
@@ -171,7 +188,7 @@
         Integer total = this.count(queryWrapper);
         return total;
     }
-
+    
     /**
      * @description 用户分页获取已领取优惠券列表
      * @author  jqs
@@ -186,7 +203,8 @@
         if(!memberCouponPageVoList.isEmpty()){
             String relGoodsIds;
             HashSet<Long> shopIdSet = new HashSet<>();
-            HashSet<Long> goodsIdSet = new HashSet<>();
+            HashSet<String> goodsIdSet = new HashSet<>();
+            String[] goodsIdArr;
             for(AppMemberCouponPageVo appGetAbleCouponPageVo : memberCouponPageVoList){
                 if(appGetAbleCouponPageVo.getShopId()!=null){
                     shopIdSet.add(appGetAbleCouponPageVo.getShopId());
@@ -194,21 +212,29 @@
                 if(appGetAbleCouponPageVo.getCouponType()==4){
                     appGetAbleCouponPageVo.setVerifyCode("2-"+appGetAbleCouponPageVo.getMemberCouponId());
                 }
-                if(StringUtils.isNotBlank(appGetAbleCouponPageVo.getRelGoodsIds())&&!appGetAbleCouponPageVo.getRelGoodsIds().contains(",")){
-                    goodsIdSet.add(Long.valueOf(appGetAbleCouponPageVo.getRelGoodsIds()));
+                if(StringUtils.isNotBlank(appGetAbleCouponPageVo.getRelGoodsIds())){
+                    relGoodsIds = appGetAbleCouponPageVo.getRelGoodsIds();
+                    goodsIdArr = relGoodsIds.split(",");
+                    for(String str : goodsIdArr){
+                        goodsIdSet.add(str);
+                    }
                 }
             }
             //获取关联商户和商品信息并转换为Map
-            String shopJoinedString = String.join(",", shopIdSet.stream().map(Object::toString).collect(Collectors.toList()));
+            String shopJoinedString;
+            Map<Long, MgtSimpleShopVo> shopMap = null;
+            if(shopIdSet!=null&&!shopIdSet.isEmpty()) {
+                shopJoinedString = String.join(",", shopIdSet.stream().map(Object::toString).collect(Collectors.toList()));
+                MgtBaseBathDto mgtBaseBathDto = new MgtBaseBathDto();
+                mgtBaseBathDto.setIds(shopJoinedString);
+                List<MgtSimpleShopVo> simpleShopVoList = remoteShopService.listShopSimpleVoByIds(mgtBaseBathDto).getData();
+                shopMap = simpleShopVoList.stream()
+                        .collect(Collectors.toMap(MgtSimpleShopVo::getShopId, Function.identity()));
+            }
             String goodsJoinedString = null;
             if(goodsIdSet!=null&&!goodsIdSet.isEmpty()){
                 goodsJoinedString = String.join(",", goodsIdSet.stream().map(Object::toString).collect(Collectors.toList()));
             }
-            MgtBaseBathDto mgtBaseBathDto = new MgtBaseBathDto();
-            mgtBaseBathDto.setIds(shopJoinedString);
-            List<MgtSimpleShopVo> simpleShopVoList = remoteShopService.listShopSimpleVoByIds(mgtBaseBathDto).getData();
-            Map<Long, MgtSimpleShopVo> shopMap = simpleShopVoList.stream()
-                    .collect(Collectors.toMap(MgtSimpleShopVo::getShopId, Function.identity()));
             Map<String, Goods> goodsMap = null;
             if(goodsJoinedString!=null){
                 List<Goods> goodsList = remoteGoodsService.listGoodsByGoodsId(goodsJoinedString).getData();
@@ -216,20 +242,30 @@
                         .collect(Collectors.toMap(Goods::getGoodsId, Function.identity()));
             }
             //处理返回信息
-            String shopLimit = "全场通用";
-            String goodsLimit = null;
+            String shopLimit = "全门店通用";
+            String goodsLimit;
+            StringJoiner goodsNameSj;
             for(AppMemberCouponPageVo appGetAbleCouponPageVo : memberCouponPageVoList){
+                goodsLimit = null;
+                goodsNameSj = new StringJoiner(",");
                 //商户限制
                 if(appGetAbleCouponPageVo.getShopId()!=null){
-                    if(!member.getRelationShopId().equals(appGetAbleCouponPageVo.getShopId())){
-                        shopLimit = shopMap.get(appGetAbleCouponPageVo.getShopId()).getShopName()+"可用";
-                    }
+                    shopLimit = shopMap.get(appGetAbleCouponPageVo.getShopId()).getShopName()+"可用";
                 }
                 appGetAbleCouponPageVo.setShopLimit(shopLimit);
                 //商品限制
                 relGoodsIds = appGetAbleCouponPageVo.getRelGoodsIds();
-                if(StringUtils.isNotBlank(relGoodsIds)&&!relGoodsIds.contains(",")){
-                    goodsLimit = goodsMap.get(relGoodsIds).getGoodsName();
+                if(StringUtils.isNotBlank(relGoodsIds)){
+                    relGoodsIds = appGetAbleCouponPageVo.getRelGoodsIds();
+                    goodsIdArr = relGoodsIds.split(",");
+                    for(String goodsIs : goodsIdArr){
+                        if(goodsMap.get(goodsIs)!=null){
+                            goodsNameSj.add(goodsMap.get(goodsIs).getGoodsName());
+                        }else{
+                            log.debug("用户优惠券未找到关联商品"+appGetAbleCouponPageVo.getMemberCouponId()+"-"+appGetAbleCouponPageVo.getRelGoodsIds());
+                        }
+                    }
+                    goodsLimit = goodsNameSj.toString();
                 }
                 appGetAbleCouponPageVo.setGoodsLimit(goodsLimit);
                 //核销商店
@@ -240,7 +276,7 @@
         }
         return memberCouponPageVoList;
     }
-
+    
     /**
      * @description  定时检查优惠券过期
      * @author  jqs
@@ -252,7 +288,7 @@
     public void timingCheckMemberCoupon(){
         memberCouponMapper.timingCheckMemberCoupon();
     }
-
+    
     /**
      * @description  使用优惠券
      * @author  jqs
@@ -265,7 +301,7 @@
     public void useMemberCoupon(String memberCouponIds){
         memberCouponMapper.useMemberCoupon(memberCouponIds);
     }
-
+    
     /**
      * @description  使用优惠券
      * @author  jqs
@@ -277,7 +313,7 @@
     public void backMemberCoupon(String memberCouponIds){
         memberCouponMapper.backMemberCoupon(memberCouponIds);
     }
-
+    
     /**
      * @description
      * @author  jqs
@@ -290,8 +326,8 @@
         List<MerMemberCouponVo> merMemberCouponVoList = memberCouponMapper.listMerShopGoodsMemberCoupon(merGoodsCouponListDto);
         if(merMemberCouponVoList!=null&&merMemberCouponVoList.size()>0){
             List<MemberSelectCouponDto> goodsCpuponList = merGoodsCouponListDto.getGoodsCpuponList();
-            List<String> selectCouponList =  new ArrayList<>();
-            Map<String, String>  selectCouponMap = new HashMap<>();
+            List<Long> selectCouponList =  new ArrayList<>();
+            Map<Long, String>  selectCouponMap = new HashMap<>();
             Boolean checkSelect = false;
             if(merGoodsCouponListDto.getGoodsCpuponList()!=null&&merGoodsCouponListDto.getGoodsCpuponList().size()>0) {
                 for (MemberSelectCouponDto couponDto : goodsCpuponList) {
@@ -326,18 +362,101 @@
         }
         return merMemberCouponVoList;
     }
-
-
+    
+    
     /**
-     * @description  确认核销优惠券
-     * @author  jqs
-     * @date    2023/8/15 11:21
      * @param memberCouponId
      * @param shopId
-     * @return  void
+     * @return void
+     * @description 确认核销优惠券
+     * @author jqs
+     * @date 2023/8/15 11:21
      */
     @Override
-    public void sureMemberCoupon(String memberCouponId,Long shopId){
+    public void sureMemberCoupon(Long memberCouponId, Long shopId) {
         memberCouponMapper.sureMemberCoupon(memberCouponId, shopId);
     }
+    
+    @Override
+    @Transactional(propagation = Propagation.REQUIRES_NEW, rollbackFor = Exception.class)
+    public void insert(MemberCoupon memberCoupon) {
+        this.baseMapper.insert(memberCoupon);
+    }
+    
+    
+    /**
+     * 手动添加用户优惠券
+     *
+     * @param couponId
+     * @param number
+     * @return
+     */
+    @Override
+    public R addMemberCoupon(String couponId, Integer number, Long userId) {
+        Coupon coupon = couponService.getById(couponId);
+        if (null == coupon) {
+            return R.fail("优惠券不存在");
+        }
+        List<MemberCoupon> memberCouponList = new ArrayList<>();
+        MemberCoupon memberCoupon;
+        Integer sendTotal = 0;
+        Integer sendPerson = 0;
+        Integer sendUserTotal;
+        for (int i = 0; i < number; i++) {
+            memberCoupon = new MemberCoupon();
+            memberCoupon.setDelFlag(0);
+            memberCoupon.setCouponId(coupon.getCouponId());
+            memberCoupon.setUserId(userId);
+            memberCoupon.setShopId(coupon.getShopId());
+            memberCoupon.setCouponType(coupon.getCouponType());
+            if (coupon.getCouponType() == 1) {
+                memberCoupon.setMoneyThreshold(coupon.getMoneyThreshold());
+                memberCoupon.setDiscountMoney(coupon.getDiscountMoney());
+            } else if (coupon.getCouponType() == 2) {
+                memberCoupon.setDiscountPercent(coupon.getDiscountPercent());
+            } else if (coupon.getCouponType() == 3) {
+                memberCoupon.setDiscountMoney(coupon.getDiscountMoney());
+            } else {
+                memberCoupon.setRelGoodsIds(coupon.getRelGoodsIds());
+            }
+            memberCoupon.setCouponStatus(coupon.getCouponStatus());
+            memberCoupon.setCouponName(coupon.getCouponName());
+            memberCoupon.setSendType(coupon.getSendType());
+            memberCoupon.setSendTarget(coupon.getSendTarget());
+            memberCoupon.setSendTimeType(coupon.getSendTimeType());
+            memberCoupon.setSendTime(coupon.getSendTime());
+            memberCoupon.setUseScope(coupon.getUseScope());
+            if (memberCoupon.getUseScope() == 2) {
+                memberCoupon.setRelGoodsIds(coupon.getRelGoodsIds());
+            }
+            memberCoupon.setValidTimeType(coupon.getValidTimeType());
+            memberCoupon.setValidStartTime(coupon.getValidStartTime());
+            memberCoupon.setValidEndTime(coupon.getValidEndTime());
+            memberCoupon.setValidDay(coupon.getValidDay());
+            memberCoupon.setCouponFrom(coupon.getCouponFrom());
+            memberCoupon.setReceiveTime(new Date());
+            //有效期处理1.时间段2.领取之日起
+            if (coupon.getValidTimeType() == 1) {
+                memberCoupon.setDeadlineTime(coupon.getValidEndTime());
+            } else if (coupon.getValidTimeType() == 2) {
+                memberCoupon.setDeadlineTime(DateUtils.addDays(new Date(), coupon.getValidDay()));
+            }
+            memberCouponList.add(memberCoupon);
+            sendTotal = sendTotal + 1;
+            if (coupon.getSendType() == 1) {
+                sendUserTotal = this.totalMemberCouponByUserAndCoupon(userId, coupon.getCouponId());
+                if (sendUserTotal != null && sendUserTotal > 0) {
+                } else {
+                    sendPerson = sendPerson + 1;
+                }
+            }
+            memberCouponRecordService.updateMemberCouponRecord(coupon, userId, 1);
+        }
+        this.saveBatch(memberCouponList);
+        //处理优惠券统计
+        if (sendTotal > 0) {
+            couponMapper.updateCouponTotal(coupon.getCouponId(), sendTotal, sendPerson);
+        }
+        return R.ok();
+    }
 }

--
Gitblit v1.7.1