From bbe0a2fd03063316e50cf141986bda984599bbda Mon Sep 17 00:00:00 2001
From: 935090232@qq.com <ak473600000>
Date: Tue, 22 Feb 2022 23:41:42 +0800
Subject: [PATCH] Merge branch 'developer'

---
 zq-erp/src/main/java/com/matrix/system/shopXcx/api/action/WxShopActivitiesSignAction.java |  123 +++++++++++++++++++++++++++++++++++-----
 1 files changed, 106 insertions(+), 17 deletions(-)

diff --git a/zq-erp/src/main/java/com/matrix/system/shopXcx/api/action/WxShopActivitiesSignAction.java b/zq-erp/src/main/java/com/matrix/system/shopXcx/api/action/WxShopActivitiesSignAction.java
index a54a119..2385215 100644
--- a/zq-erp/src/main/java/com/matrix/system/shopXcx/api/action/WxShopActivitiesSignAction.java
+++ b/zq-erp/src/main/java/com/matrix/system/shopXcx/api/action/WxShopActivitiesSignAction.java
@@ -9,7 +9,7 @@
 import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
 import com.baomidou.mybatisplus.core.metadata.IPage;
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
-import com.matrix.component.redis.RedisUserLoginUtils;
+import com.matrix.system.common.init.UserCacheManager;
 import com.matrix.core.pojo.AjaxResult;
 import com.matrix.core.tools.StringUtils;
 import com.matrix.system.activity.dao.ActivitySignAwardSetDao;
@@ -20,19 +20,17 @@
 import com.matrix.system.activity.entity.ActivitySignReceiveRecord;
 import com.matrix.system.activity.entity.ActivitySignRecord;
 import com.matrix.system.activity.entity.ActivitySignWriteoff;
+import com.matrix.system.common.constance.AppConstance;
 import com.matrix.system.hive.bean.SysVipInfo;
+import com.matrix.system.score.entity.ScoreVipDetail;
+import com.matrix.system.score.service.ScoreVipDetailService;
 import com.matrix.system.shopXcx.api.dto.SeeAwardTextDto;
 import com.matrix.system.shopXcx.api.dto.SignAwardDto;
 import com.matrix.system.shopXcx.api.service.WxShopLogisticsQueryService;
+import com.matrix.system.shopXcx.api.tools.WxShopCouponUtil;
 import com.matrix.system.shopXcx.api.vo.*;
-import com.matrix.system.shopXcx.bean.ShopActivities;
-import com.matrix.system.shopXcx.bean.ShopDeliveryInfo;
-import com.matrix.system.shopXcx.bean.ShopLogisticsInfo;
-import com.matrix.system.shopXcx.bean.ShopReceiveAddress;
-import com.matrix.system.shopXcx.dao.ShopActivitiesDao;
-import com.matrix.system.shopXcx.dao.ShopDeliveryInfoDao;
-import com.matrix.system.shopXcx.dao.ShopLogisticsInfoDao;
-import com.matrix.system.shopXcx.dao.ShopReceiveAddressDao;
+import com.matrix.system.shopXcx.bean.*;
+import com.matrix.system.shopXcx.dao.*;
 import com.matrix.system.shopXcx.vo.SalesOrderVo;
 import io.swagger.annotations.Api;
 import io.swagger.annotations.ApiOperation;
@@ -58,7 +56,7 @@
     private ShopActivitiesDao shopActivitiesDao;
 	
 	@Autowired
-    private RedisUserLoginUtils redisUserLoginUtils;
+    private UserCacheManager userCacheManager;
 	
 	@Autowired
 	private ActivitySignAwardSetDao activitySignAwardSetDao;
@@ -82,6 +80,14 @@
 
     @Autowired
     private WxShopLogisticsQueryService wxShopLogisticsQueryService;
+    @Autowired
+    private ScoreVipDetailService scoreVipDetailService;
+    @Autowired
+    private ShopCouponDao shopCouponDao;
+    @Autowired
+    private WxShopCouponUtil wxShopCouponUtil;
+    @Autowired
+    private ShopCouponRecordDao shopCouponRecordDao;
 	
 	@ApiOperation(value = "获取签到基本信息", notes = "")
 	@ApiResponses({
@@ -90,7 +96,7 @@
     @GetMapping(value = "/getSignBasicInfo")
     public AjaxResult getSignBasicInfo() {
 		//获取登录人信息
-		SysVipInfo loginUser = redisUserLoginUtils.getLoginUser(SysVipInfo.class);
+		SysVipInfo loginUser = userCacheManager.getLoginUser();
 		Long companyId = loginUser.getCompanyId();
 		Long userId = loginUser.getId();
 		//获取签到活动的信息
@@ -171,7 +177,7 @@
     @ResponseBody
     public AjaxResult getSignRecord(@PathVariable("actId") long actId,@PathVariable("month") String dateStr) {
         //获取登录人信息
-        SysVipInfo loginUser = redisUserLoginUtils.getLoginUser(SysVipInfo.class);
+        SysVipInfo loginUser = userCacheManager.getLoginUser();
         Long companyId = loginUser.getCompanyId();
         Long userId = loginUser.getId();
         Date date = DateUtil.parse(dateStr);
@@ -257,7 +263,7 @@
     @ResponseBody
     @Transactional
     public AjaxResult clickSign(@PathVariable("actId") long actId) {
-        SysVipInfo user = redisUserLoginUtils.getLoginUser(SysVipInfo.class);
+        SysVipInfo user = userCacheManager.getLoginUser();
         Long userId = user.getId();
         Long companyId = user.getCompanyId();
         /**
@@ -339,6 +345,48 @@
         	signSuccessVo.setAwardName(activitySignAwardSetNormal.getAwardName());
         	signSuccessVo.setAwardImg(activitySignAwardSetNormal.getIntroduceImg());
             signSuccessVos.add(signSuccessVo);
+            
+            //日常奖励积分,对应用户积分加减
+            int awardType = activitySignAwardSetNormal.getAwardType();
+            if(ActivitySignAwardSet.AWARDTYPE_SCORE == awardType){
+                int scoreCnt = activitySignAwardSetNormal.getScoreCnt();
+                if(scoreCnt > 0){
+                    scoreVipDetailService.addScore(userId,null,null,scoreCnt,
+                            activitySignReceiveRecord.getId(), ScoreVipDetail.SCORE_VIP_TYPE_JOIN_ACTIVE,"签到积分");
+                }
+            }
+            //获取优惠券
+            if(ActivitySignAwardSet.AWARDTYPE_COUPON == awardType){
+                //获取优惠券
+                int couponId = Integer.parseInt(activitySignAwardSetNormal.getCouponId());
+                ShopCoupon shopCoupon = shopCouponDao.selectById(couponId);
+                // 如果没有找到该优惠券
+                if (shopCoupon == null) {
+                    return new AjaxResult(AjaxResult.STATUS_FAIL, "没有找到该优惠券!");
+                }
+                // 如果优惠券有数量限制并且已经领完
+                if (shopCoupon.getMaxQuantity() >= 0 && (shopCoupon.getMaxQuantity() <= shopCoupon.getQuantityReceive())) {
+                    return new AjaxResult(AjaxResult.STATUS_FAIL, "优惠券已领完!");
+                }
+                boolean newPeople = wxShopCouponUtil.verifyIsNewPeople(userId);
+                // 如果改券是新人专属且当前用户不是新人
+                if (AppConstance.COUPON_GET_LIMT_NEW.equals(shopCoupon.getGetLimit()) && !newPeople) {
+                    return new AjaxResult(AjaxResult.STATUS_FAIL, "该优惠券为新人专享优惠券!");
+                }
+                ShopCouponRecord insertRecord = new ShopCouponRecord();
+                insertRecord.setCreateBy(AppConstance.SYSTEM_USER);
+                insertRecord.setUpdateBy(AppConstance.SYSTEM_USER);
+                insertRecord.setCId(couponId);
+                insertRecord.setUserId(userId);
+                insertRecord.setIsUsing(2);
+                int i = shopCouponRecordDao.insert(insertRecord);
+                // 如果插入领取记录表失败
+                if (i < 0) {
+                    return new AjaxResult(AjaxResult.STATUS_FAIL, "优惠券领取失败!");
+                }
+                shopCoupon.setQuantityReceive(shopCoupon.getQuantityReceive() + 1);
+                shopCouponDao.updateByModel(shopCoupon);
+            }
         }
         //获取当前累计天数
         int cumulativeDay = getCumulativeDay(actId, userId, date, 0);
@@ -425,8 +473,48 @@
                     //3:优惠券
                     if(ActivitySignAwardSet.AWARDTYPE_COUPON == activitySignAwardSetCumulativeDay.getAwardType()) {
                         signSuccessVo.setCouponName(activitySignAwardSetCumulativeDay.getCouponName());
+                        //获取优惠券
+                        int couponId = Integer.parseInt(activitySignAwardSetCumulativeDay.getCouponId());
+                        ShopCoupon shopCoupon = shopCouponDao.selectById(couponId);
+                        // 如果没有找到该优惠券
+                        if (shopCoupon == null) {
+                            return new AjaxResult(AjaxResult.STATUS_FAIL, "没有找到该优惠券!");
+                        }
+                        // 如果优惠券有数量限制并且已经领完
+                        if (shopCoupon.getMaxQuantity() >= 0 && (shopCoupon.getMaxQuantity() <= shopCoupon.getQuantityReceive())) {
+                            return new AjaxResult(AjaxResult.STATUS_FAIL, "优惠券已领完!");
+                        }
+                        boolean newPeople = wxShopCouponUtil.verifyIsNewPeople(userId);
+                        // 如果改券是新人专属且当前用户不是新人
+                        if (AppConstance.COUPON_GET_LIMT_NEW.equals(shopCoupon.getGetLimit()) && !newPeople) {
+                            return new AjaxResult(AjaxResult.STATUS_FAIL, "该优惠券为新人专享优惠券!");
+                        }
+                        ShopCouponRecord insertRecord = new ShopCouponRecord();
+                        insertRecord.setCreateBy(AppConstance.SYSTEM_USER);
+                        insertRecord.setUpdateBy(AppConstance.SYSTEM_USER);
+                        insertRecord.setCId(couponId);
+                        insertRecord.setUserId(userId);
+                        insertRecord.setIsUsing(2);
+                        int i = shopCouponRecordDao.insert(insertRecord);
+                        // 如果插入领取记录表失败
+                        if (i < 0) {
+                            return new AjaxResult(AjaxResult.STATUS_FAIL, "优惠券领取失败!");
+                        }
+                        shopCoupon.setQuantityReceive(shopCoupon.getQuantityReceive() + 1);
+                        shopCouponDao.updateByModel(shopCoupon);
                     }
                     activitySignReceiveRecordDao.insert(activitySignReceiveRecord);
+                    //累计奖励积分,对应用户积分加减
+                    if(ActivitySignAwardSet.AWARDTYPE_SCORE == activitySignAwardSetCumulativeDay.getAwardType()) {
+                        int awardType = activitySignAwardSetCumulativeDay.getAwardType();
+                        if(ActivitySignAwardSet.AWARDTYPE_SCORE == awardType){
+                            int scoreCnt = activitySignAwardSetCumulativeDay.getScoreCnt();
+                            if(scoreCnt > 0){
+                                scoreVipDetailService.addScore(userId,null,null,scoreCnt,
+                                        activitySignReceiveRecord.getId(), ScoreVipDetail.SCORE_VIP_TYPE_JOIN_ACTIVE,"签到积分");
+                            }
+                        }
+                    }
                     //生成核销记录
                     if(ActivitySignAwardSet.AWARDTYPE_CUSTOMIZE == activitySignAwardSetCumulativeDay.getAwardType()) {
                         ActivitySignWriteoff activitySignWriteoff = new ActivitySignWriteoff();
@@ -476,7 +564,8 @@
         DateTime offsetDay = DateUtil.offsetDay(date, -i);
         return getCumulativeDay(actId,userId,offsetDay,i);
     }
-    
+
+
     /**
      * 获取累计的签到奖品
      *
@@ -488,7 +577,7 @@
             @ApiResponse(code = 200, message = "ok", response = SignAwardListVo.class)
     })
     public AjaxResult getSignAwardList(@RequestBody @Validated SignAwardDto signAwardDto) {
-        SysVipInfo loginUser = redisUserLoginUtils.getLoginUser(SysVipInfo.class);
+        SysVipInfo loginUser = userCacheManager.getLoginUser();
         Page<SalesOrderVo> page=new Page<>(signAwardDto.getPageNum(),signAwardDto.getPageSize());
         if(StringUtils.isBlank(signAwardDto.getSort())){
         	signAwardDto.setSort("create_time");
@@ -512,7 +601,7 @@
             @ApiResponse(code = 200, message = "ok", response = SeeAwardTextVo.class)
     })
     public AjaxResult seeAwardText(@RequestBody @Validated SeeAwardTextDto seeAwardTextDto) {
-        SysVipInfo loginUser = redisUserLoginUtils.getLoginUser(SysVipInfo.class);
+        SysVipInfo loginUser = userCacheManager.getLoginUser();
         seeAwardTextDto.setUserId(loginUser.getId());
         seeAwardTextDto.setCompanyId(loginUser.getCompanyId());
         SeeAwardTextVo seeAwardTextVO = activitySignReceiveRecordDao.selectSeeAwardTextVOById(seeAwardTextDto);
@@ -531,7 +620,7 @@
             @ApiResponse(code = 200, message = "ok", response = SeeAwardTextVo.class)
     })
     public AjaxResult logisticsInsure(@RequestBody @Validated SeeAwardTextDto seeAwardTextDto) {
-        SysVipInfo loginUser = redisUserLoginUtils.getLoginUser(SysVipInfo.class);
+        SysVipInfo loginUser = userCacheManager.getLoginUser();
         seeAwardTextDto.setUserId(loginUser.getId());
         seeAwardTextDto.setCompanyId(loginUser.getCompanyId());
         SeeAwardTextVo seeAwardTextVO = activitySignReceiveRecordDao.selectSeeAwardTextVOById(seeAwardTextDto);

--
Gitblit v1.9.1