From 780ddc0d6df50bbb59b84ef61668da7c2deacc21 Mon Sep 17 00:00:00 2001
From: xiaoyong931011 <15274802129@163.com>
Date: Mon, 11 Sep 2023 10:32:26 +0800
Subject: [PATCH] 优惠卷

---
 src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallMemberServiceImpl.java |   41 +++++++++++++++++++++++++++++++++++++++++
 1 files changed, 41 insertions(+), 0 deletions(-)

diff --git a/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallMemberServiceImpl.java b/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallMemberServiceImpl.java
index b369f4a..0722003 100644
--- a/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallMemberServiceImpl.java
+++ b/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallMemberServiceImpl.java
@@ -19,6 +19,7 @@
 import cc.mrbird.febs.pay.service.IXcxPayService;
 import cn.hutool.core.bean.BeanUtil;
 import cn.hutool.core.collection.CollUtil;
+import cn.hutool.core.date.DateUtil;
 import cn.hutool.core.util.IdUtil;
 import cn.hutool.core.util.ObjectUtil;
 import cn.hutool.core.util.StrUtil;
@@ -69,6 +70,10 @@
     private final IMallMoneyFlowService mallMoneyFlowService;
     private final IMallMemberCollectionService mallMemberCollectionService;
     private final IMallMemberFootprintService mallMemberFootprintService;
+    private final SalemanCouponMapper salemanCouponMapper;
+    private final CouponGoodsMapper couponGoodsMapper;
+    private final MallGoodsCouponMapper mallGoodsCouponMapper;
+    private final MallMemberCouponMapper mallMemberCouponMapper;
 
 
     @Value("${spring.profiles.active}")
@@ -869,6 +874,42 @@
         return new FebsResponse().success().data(apiMallAgentRecordVo);
     }
 
+    @Override
+    public FebsResponse getCoupon(GetCouponDto getCouponDto) {
+        Long memberId = LoginUserUtil.getLoginUser().getId();
+        //通过邀请人信息,获取能领取的优惠卷信息
+        MallMember mallMember = this.baseMapper.selectInfoByInviteId(getCouponDto.getInviteId());
+        SalemanCoupon salemanCoupon = salemanCouponMapper.selectByMemberId(mallMember.getId());
+        if(ObjectUtil.isNotEmpty(salemanCoupon)){
+            Long couponId = salemanCoupon.getCouponId();
+            Long goodsId = getCouponDto.getGoodsId();
+            //商品优惠卷如果绑定了,那么当前登陆者获取一张卷
+            List<CouponGoods> couponGoodsList = couponGoodsMapper.selectByGoodIdAndCouponId(goodsId,couponId);
+            MallGoodsCoupon mallGoodsCoupon = mallGoodsCouponMapper.selectById(couponId);
+            if(CollUtil.isNotEmpty(couponGoodsList)){
+                MallMemberCoupon mallMemberCoupon = new MallMemberCoupon();
+                mallMemberCoupon.setCouponId(couponId);
+                mallMemberCoupon.setCouponName(mallGoodsCoupon.getName());
+                mallMemberCoupon.setMemberId(memberId);
+                mallMemberCoupon.setInviteId(mallMemberCoupon.getInviteId());
+                mallMemberCoupon.setState(1);
+                mallMemberCoupon.setExpireTime(DateUtil.offsetDay(DateUtil.date(),mallGoodsCoupon.getExpireDay()));
+                mallMemberCouponMapper.insert(mallMemberCoupon);
+            }
+        }
+
+        return new FebsResponse().success();
+    }
+
+    @Override
+    public FebsResponse memberCoupon(MallMemberCouponDto mallMemberCouponDto) {
+        Long memberId = LoginUserUtil.getLoginUser().getId();
+        IPage<MallMemberCouponVo> page = new Page<>(mallMemberCouponDto.getPageNum(), mallMemberCouponDto.getPageSize());
+        mallMemberCouponDto.setMemberId(memberId);
+        IPage<MallMemberCouponVo> pages = mallMemberCouponMapper.selectListInPage(page, mallMemberCouponDto);
+        return new FebsResponse().success().data(pages);
+    }
+
     private  String getXcxLoginUrl(String code) {
         String wechatLoginUrl =xcxProperties.getWecharLoginUrl();
         return String.format(wechatLoginUrl, xcxProperties.getXcxAppid(), xcxProperties.getXcxSecret(), code);

--
Gitblit v1.9.1