From 696a4c0f5cf267bcf2cd721484afd2694bf8ca4e Mon Sep 17 00:00:00 2001
From: Hentua <wangdoubleone@gmail.com>
Date: Thu, 25 Jan 2024 21:24:17 +0800
Subject: [PATCH] fix

---
 src/main/java/cc/mrbird/febs/mall/vo/OrderListVo.java                         |    3 +
 src/main/java/cc/mrbird/febs/vip/service/impl/MallVipConfigServiceImpl.java   |    9 ++++
 src/main/java/cc/mrbird/febs/common/enumerates/DataDictionaryEnum.java        |    7 +++
 src/main/java/cc/mrbird/febs/vip/service/impl/MallVipBenefitsServiceImpl.java |   52 ++++++++++++++++++++++++++
 src/main/resources/mapper/modules/MallOrderInfoMapper.xml                     |    3 +
 src/main/java/cc/mrbird/febs/mall/entity/MallOrderInfo.java                   |    3 +
 src/main/java/cc/mrbird/febs/vip/entity/MallVipBenefitsRecord.java            |   28 ++++++++++++++
 src/main/java/cc/mrbird/febs/vip/mapper/MallVipBenefitsRecordMapper.java      |    7 +++
 8 files changed, 110 insertions(+), 2 deletions(-)

diff --git a/src/main/java/cc/mrbird/febs/common/enumerates/DataDictionaryEnum.java b/src/main/java/cc/mrbird/febs/common/enumerates/DataDictionaryEnum.java
index 31e3827..e3b8023 100644
--- a/src/main/java/cc/mrbird/febs/common/enumerates/DataDictionaryEnum.java
+++ b/src/main/java/cc/mrbird/febs/common/enumerates/DataDictionaryEnum.java
@@ -59,7 +59,12 @@
     WIN_CASH("WIN_PROBABILITY", "WIN_CASH"),
     RANK_BONUS("BONUS_TYPE", "RANK_BONUS"),
     CASHOUT_SETTING("CASHOUT_SET", "CASHOUT_SETTING"),
-    INDIRECT_BONUS_SETTING("INDIRECT_BONUS_SETTING", "");
+    INDIRECT_BONUS_SETTING("INDIRECT_BONUS_SETTING", ""),
+
+    /**
+     * 会员日
+     */
+    VIP_DATE("VIP_DATE", "VIP_DATE");
 
     private String type;
 
diff --git a/src/main/java/cc/mrbird/febs/mall/entity/MallOrderInfo.java b/src/main/java/cc/mrbird/febs/mall/entity/MallOrderInfo.java
index 56224de..98d59df 100644
--- a/src/main/java/cc/mrbird/febs/mall/entity/MallOrderInfo.java
+++ b/src/main/java/cc/mrbird/febs/mall/entity/MallOrderInfo.java
@@ -139,4 +139,7 @@
 
     @TableField(exist = false)
     private String orderIds;
+
+    @TableField(exist = false)
+    private String expressNo;
 }
diff --git a/src/main/java/cc/mrbird/febs/mall/vo/OrderListVo.java b/src/main/java/cc/mrbird/febs/mall/vo/OrderListVo.java
index 335a4be..fb76c4f 100644
--- a/src/main/java/cc/mrbird/febs/mall/vo/OrderListVo.java
+++ b/src/main/java/cc/mrbird/febs/mall/vo/OrderListVo.java
@@ -57,4 +57,7 @@
 
     @ApiModelProperty(value = "是否送货上门  1:是 2:否")
     private Integer isHome;
+
+    @ApiModelProperty(value = "快递单号")
+    private String expressNo;
 }
diff --git a/src/main/java/cc/mrbird/febs/vip/entity/MallVipBenefitsRecord.java b/src/main/java/cc/mrbird/febs/vip/entity/MallVipBenefitsRecord.java
new file mode 100644
index 0000000..57a3792
--- /dev/null
+++ b/src/main/java/cc/mrbird/febs/vip/entity/MallVipBenefitsRecord.java
@@ -0,0 +1,28 @@
+package cc.mrbird.febs.vip.entity;
+
+import cc.mrbird.febs.common.entity.BaseEntity;
+import com.baomidou.mybatisplus.annotation.TableName;
+import lombok.Data;
+
+import java.util.Date;
+
+@Data
+@TableName(value = "mall_vip_benefits_record")
+public class MallVipBenefitsRecord extends BaseEntity {
+
+    private String memberId ;
+    /** 权益名称 */
+    private String benefitsName ;
+    /** 权益类型; 1-会员日 2-生日 */
+    private Integer benefitsType ;
+    /** 领取名称 */
+    private String receiveName ;
+    /** 领取数量 */
+    private Integer receiveCnt ;
+    /** 领取时间 */
+    private Date receiveTime ;
+    /** 领取类型;2-商品 3-优惠券 */
+    private Integer receiveType ;
+    /** 领取ID */
+    private Long receiveId ;
+}
diff --git a/src/main/java/cc/mrbird/febs/vip/mapper/MallVipBenefitsRecordMapper.java b/src/main/java/cc/mrbird/febs/vip/mapper/MallVipBenefitsRecordMapper.java
new file mode 100644
index 0000000..149aea4
--- /dev/null
+++ b/src/main/java/cc/mrbird/febs/vip/mapper/MallVipBenefitsRecordMapper.java
@@ -0,0 +1,7 @@
+package cc.mrbird.febs.vip.mapper;
+
+import cc.mrbird.febs.vip.entity.MallVipBenefitsRecord;
+import com.baomidou.mybatisplus.core.mapper.BaseMapper;
+
+public interface MallVipBenefitsRecordMapper extends BaseMapper<MallVipBenefitsRecord> {
+}
diff --git a/src/main/java/cc/mrbird/febs/vip/service/impl/MallVipBenefitsServiceImpl.java b/src/main/java/cc/mrbird/febs/vip/service/impl/MallVipBenefitsServiceImpl.java
index 636c8c4..bf1757a 100644
--- a/src/main/java/cc/mrbird/febs/vip/service/impl/MallVipBenefitsServiceImpl.java
+++ b/src/main/java/cc/mrbird/febs/vip/service/impl/MallVipBenefitsServiceImpl.java
@@ -1,6 +1,7 @@
 package cc.mrbird.febs.vip.service.impl;
 
 import cc.mrbird.febs.common.entity.QueryRequest;
+import cc.mrbird.febs.common.enumerates.DataDictionaryEnum;
 import cc.mrbird.febs.common.enumerates.OrderStatusEnum;
 import cc.mrbird.febs.common.exception.FebsException;
 import cc.mrbird.febs.common.utils.LoginUserUtil;
@@ -11,14 +12,18 @@
 import cc.mrbird.febs.mall.vo.AdminMallNewsInfoVo;
 import cc.mrbird.febs.vip.entity.MallVipBenefits;
 import cc.mrbird.febs.vip.entity.MallVipBenefitsDetails;
+import cc.mrbird.febs.vip.entity.MallVipBenefitsRecord;
 import cc.mrbird.febs.vip.mapper.MallVipBenefitsDetailsMapper;
 import cc.mrbird.febs.vip.mapper.MallVipBenefitsMapper;
+import cc.mrbird.febs.vip.mapper.MallVipBenefitsRecordMapper;
 import cc.mrbird.febs.vip.service.IMallVipBenefitsDetailsService;
 import cc.mrbird.febs.vip.service.IMallVipBenefitsService;
 import cn.hutool.core.collection.CollUtil;
+import cn.hutool.core.date.DatePattern;
 import cn.hutool.core.date.DateUtil;
 import cn.hutool.core.util.IdUtil;
 import cn.hutool.core.util.ObjectUtil;
+import cn.hutool.core.util.StrUtil;
 import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import com.baomidou.mybatisplus.core.metadata.IPage;
 import com.baomidou.mybatisplus.core.metadata.OrderItem;
@@ -31,6 +36,7 @@
 
 import java.math.BigDecimal;
 import java.util.Date;
+import java.util.List;
 
 @Slf4j
 @Service
@@ -44,6 +50,8 @@
     private final MallAddressInfoMapper mallAddressInfoMapper;
     private final MallOrderInfoMapper mallOrderInfoMapper;
     private final MallOrderItemMapper mallOrderItemMapper;
+    private final MallVipBenefitsRecordMapper mallVipBenefitsRecordMapper;
+    private final DataDictionaryCustomMapper dataDictionaryCustomMapper;
 
     @Override
     public IPage<MallVipBenefits> vipBenefitsListInPage(QueryRequest request) {
@@ -115,7 +123,48 @@
             throw new FebsException("权益不存在");
         }
 
+        MallVipBenefits vipBenefits = this.baseMapper.selectById(benefits.getId());
+        if (vipBenefits == null) {
+            throw new FebsException("权益不存在");
+        }
+
+
         Integer linkType = benefits.getLinkType();
+
+        if (vipBenefits.getGainType() == 2) {
+            String today = DateUtil.format(new Date(), DatePattern.NORM_DATE_PATTERN);
+            boolean isBirthday = member.getBirthday().compareTo(DateUtil.parseDate(today)) == 0;
+            if (!isBirthday) {
+                throw new FebsException("未达到权益领取条件:未到生日");
+            }
+        }
+
+        if (vipBenefits.getGainType() == 3) {
+            DataDictionaryCustom data = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(DataDictionaryEnum.VIP_DATE.getType(), DataDictionaryEnum.VIP_DATE.getCode());
+
+            String today = DateUtil.format(new Date(), "MM-dd");
+            if (!StrUtil.equals(data.getValue(), today)) {
+                throw new FebsException("未达到权益领取条件:未到会员日");
+            }
+        }
+
+        LambdaQueryWrapper<MallVipBenefitsRecord> recordQuery = new LambdaQueryWrapper<>();
+        recordQuery.ge(MallVipBenefitsRecord::getReceiveTime, DateUtil.beginOfDay(new Date()))
+                .le(MallVipBenefitsRecord::getReceiveTime, DateUtil.endOfDay(new Date()))
+                .eq(MallVipBenefitsRecord::getMemberId, member.getId())
+                .eq(MallVipBenefitsRecord::getBenefitsType, vipBenefits.getType())
+                .eq(MallVipBenefitsRecord::getReceiveId, Long.parseLong(benefits.getContent()));
+        List<MallVipBenefitsRecord> mallVipBenefitsRecords = mallVipBenefitsRecordMapper.selectList(recordQuery);
+        if (CollUtil.isNotEmpty(mallVipBenefitsRecords)) {
+            throw new FebsException("已领取过权益");
+        }
+
+        MallVipBenefitsRecord record = new MallVipBenefitsRecord();
+        record.setBenefitsType(vipBenefits.getGainType());
+        record.setBenefitsName(vipBenefits.getName());
+        record.setReceiveTime(new Date());
+        record.setReceiveType(linkType);
+        record.setReceiveId(Long.parseLong(benefits.getContent()));
 
         // 商品
         if (linkType == 2) {
@@ -181,6 +230,7 @@
                 orderItem.setCostPrice(sku.getCostPrice());
             }
 
+            record.setReceiveName(goods.getGoodsName());
             mallOrderInfoMapper.insert(orderInfo);
             mallOrderItemMapper.insert(orderItem);
         }
@@ -200,6 +250,8 @@
             memberCoupon.setExpireTime(DateUtil.offsetDay(DateUtil.date(), coupon.getExpireDay()));
             memberCoupon.setMemberId(member.getId());
             mallMemberCouponMapper.insert(memberCoupon);
+
+            record.setReceiveName(coupon.getName());
         }
     }
 
diff --git a/src/main/java/cc/mrbird/febs/vip/service/impl/MallVipConfigServiceImpl.java b/src/main/java/cc/mrbird/febs/vip/service/impl/MallVipConfigServiceImpl.java
index 35bea61..e3d030d 100644
--- a/src/main/java/cc/mrbird/febs/vip/service/impl/MallVipConfigServiceImpl.java
+++ b/src/main/java/cc/mrbird/febs/vip/service/impl/MallVipConfigServiceImpl.java
@@ -1,8 +1,11 @@
 package cc.mrbird.febs.vip.service.impl;
 
 import cc.mrbird.febs.common.entity.QueryRequest;
+import cc.mrbird.febs.common.enumerates.DataDictionaryEnum;
 import cc.mrbird.febs.common.exception.FebsException;
+import cc.mrbird.febs.mall.entity.DataDictionaryCustom;
 import cc.mrbird.febs.mall.entity.MallMember;
+import cc.mrbird.febs.mall.mapper.DataDictionaryCustomMapper;
 import cc.mrbird.febs.mall.mapper.MallMemberMapper;
 import cc.mrbird.febs.vip.entity.MallVipBenefits;
 import cc.mrbird.febs.vip.entity.MallVipConfig;
@@ -33,6 +36,7 @@
 
     private final IMallVipConfigBenefitsService mallVipConfigBenefitsService;
     private final MallMemberMapper mallMemberMapper;
+    private final DataDictionaryCustomMapper dataDictionaryCustomMapper;
 
     @Override
     public IPage<MallVipConfig> vipConfigList(QueryRequest request) {
@@ -117,8 +121,11 @@
                 return true;
             }
 
+            DataDictionaryCustom data = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(DataDictionaryEnum.VIP_DATE.getType(), DataDictionaryEnum.VIP_DATE.getCode());
+
+            String todayTime = DateUtil.format(new Date(), "MM-dd");
             // 会员日
-            return item.getGainType() == 1;
+            return item.getGainType() == 1 && StrUtil.equals(data.getValue(), todayTime);
         }).max(Comparator.comparing(MallVipBenefits::getScoreMultiple));
 
         return max.orElseGet(max::get);
diff --git a/src/main/resources/mapper/modules/MallOrderInfoMapper.xml b/src/main/resources/mapper/modules/MallOrderInfoMapper.xml
index e1f180e..7a5741d 100644
--- a/src/main/resources/mapper/modules/MallOrderInfoMapper.xml
+++ b/src/main/resources/mapper/modules/MallOrderInfoMapper.xml
@@ -386,12 +386,15 @@
         <result column="city" property="city" />
         <result column="township" property="township" />
         <result column="detail_address" property="detailAddress" />
+        <result column="express_no" property="expressNo" />
     </resultMap>
 
     <select id="selectNewApiOrderListInPage" resultMap="NewOrderInfoMap">
         select
         a.*
+        ,express.express_no
         from mall_order_info a
+            left join mall_express_info express on a.id=express.order_id
         <where>
             a.del_flag=2
             <if test="record.memberId != null">

--
Gitblit v1.9.1