From acad524bfb7f376c09ff8e6600fab207780156e1 Mon Sep 17 00:00:00 2001
From: 44323 <443237572@qq.com>
Date: 星期四, 23 十一月 2023 18:46:05 +0800
Subject: [PATCH] Merge branch 'master' of http://120.76.84.145:10101/gitblit/r/java/PlayPai

---
 cloud-server-activity/src/main/java/com/dsh/activity/service/impl/CouponServiceImpl.java |  111 ++++++++++++++++++++++++++++++++++++++++++++++---------
 1 files changed, 92 insertions(+), 19 deletions(-)

diff --git a/cloud-server-activity/src/main/java/com/dsh/activity/service/impl/CouponServiceImpl.java b/cloud-server-activity/src/main/java/com/dsh/activity/service/impl/CouponServiceImpl.java
index 4278dd6..031bf29 100644
--- a/cloud-server-activity/src/main/java/com/dsh/activity/service/impl/CouponServiceImpl.java
+++ b/cloud-server-activity/src/main/java/com/dsh/activity/service/impl/CouponServiceImpl.java
@@ -4,21 +4,30 @@
 import com.alibaba.fastjson.JSON;
 import com.alibaba.fastjson.JSONObject;
 import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
+import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
 import com.dsh.activity.entity.Coupon;
+import com.dsh.activity.entity.TStudent;
+import com.dsh.activity.entity.UserCoupon;
 import com.dsh.activity.feignclient.account.AppUserClient;
 import com.dsh.activity.feignclient.account.StudentClient;
 import com.dsh.activity.feignclient.account.model.AppUser;
 import com.dsh.activity.feignclient.account.model.Student;
+import com.dsh.activity.feignclient.model.CouponExamineListSearch;
 import com.dsh.activity.feignclient.model.CouponListOfSearch;
 import com.dsh.activity.mapper.CouponMapper;
 import com.dsh.activity.model.CouponListVo;
+import com.dsh.activity.model.request.IntegralGoodsOfSearch;
 import com.dsh.activity.service.ICouponService;
+import com.dsh.activity.service.UserCouponService;
+import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
 
 import javax.annotation.Resource;
 import java.text.SimpleDateFormat;
+import java.time.LocalDateTime;
 import java.util.ArrayList;
+import java.util.Date;
 import java.util.List;
 import java.util.Map;
 
@@ -38,7 +47,11 @@
 
 
 
+    @Autowired
+    private UserCouponService userCouponService;
 
+    @Autowired
+    private ICouponService couponService;
 
     /**
      * 获取购买会员支付成功页面的优惠券
@@ -51,40 +64,72 @@
         AppUser appUser = appUserClient.queryAppUser(uid);
         List<CouponListVo> listVos = new ArrayList<>();
         if (null != appUser) {
-            List<Integer> userPopulation = new ArrayList<>();
-            userPopulation.add(1);//全部用户
-            if (1 == appUser.getIsVip()) {
-                userPopulation.add(2);//年度会员
-            }
-            List<Student> students = studentClient.queryStudentList(uid);
-            if (students.size() > 0) {
-                userPopulation.add(3);//已有学员用户
-            }
-            List<Coupon> list = this.list(new QueryWrapper<Coupon>().eq("distributionMethod", distributionMethod).in("userPopulation", userPopulation)
-                    .eq("auditStatus", 2).eq("status", 2).eq("state", 1)
-                    .last(" and now() between startTime and endTime order by insertTime desc"));
+//            List<Integer> userPopulation = new ArrayList<>();
+//            userPopulation.add(1);//全部用户
+//            if (1 == appUser.getIsVip()) {
+//                userPopulation.add(2);//年度会员
+//            }
+//            List<TStudent> students = studentClient.queryStudentList(uid);
+//            if (students.size() > 0) {
+//                userPopulation.add(3);//已有学员用户
+//            }
+
+
+//            List<Coupon> list = this.list(new QueryWrapper<Coupon>().eq("distributionMethod", distributionMethod)
+//                    .in("userPopulation", userPopulation)
+//                    .eq("auditStatus", 2).eq("status", 2).eq("state", 1)
+//                    .last(" and now() between startTime and endTime order by insertTime desc"));
+
+
+//            List<Coupon> list = this.list(new QueryWrapper<Coupon>().eq("distributionMethod", 2).eq("userPopulation",2)
+//                    .le("startTime", new Date()).ge("endTime", new Date()).eq("auditStatus", 2)
+//                    .eq("state", 1));
             SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
-            for (Coupon coupon : list) {
+
+
+
+            LocalDateTime currentTime = LocalDateTime.now();
+            LocalDateTime oneMinuteAgo = currentTime.minusSeconds(6000);
+
+
+
+            List<UserCoupon> list = userCouponService.list(new QueryWrapper<UserCoupon>().eq("userId", uid).ge("insertTime", oneMinuteAgo));
+            List<Integer> ids = new ArrayList<>();
+            for (UserCoupon userCoupon : list) {
+                ids.add(userCoupon.getCouponId());
+            }
+            List<Coupon> userId = new ArrayList<>();
+            if (ids.size()>0) {
+
+                userId = couponService.list(new QueryWrapper<Coupon>().in("id", ids));
+            }
+
+
+            for (Coupon coupon : userId) {
+                if (coupon.getDistributionMethod()!=2){
+                    continue;
+                }
                 CouponListVo couponListVo = new CouponListVo();
                 couponListVo.setId(coupon.getId().longValue());
                 couponListVo.setName(coupon.getName());
                 couponListVo.setType(coupon.getType());
                 couponListVo.setEffectiveTime(sdf.format(coupon.getStartTime()) + "-" + sdf.format(coupon.getEndTime()));
                 String content = coupon.getContent();
-                if (coupon.getType() == 1) {//满减{"num1":1,"num2":1}
+                if (coupon.getType() == 1) {//满减
+//                    {"conditionalAmount":50,"deductionAmount":10,"experienceName":""}
                     JSONObject jsonObject = JSON.parseObject(content);
-                    couponListVo.setUseCondition("满" + jsonObject.getDouble("num1") + "元可用");
-                    couponListVo.setFavorable(jsonObject.getString("num2"));
+                    couponListVo.setUseCondition("满" + jsonObject.getDouble("conditionalAmount") + "元可用");
+                    couponListVo.setFavorable(jsonObject.getString("deductionAmount"));
                 }
                 if (coupon.getType() == 2) {//代金券{"num1":1}
                     JSONObject jsonObject = JSON.parseObject(content);
                     couponListVo.setUseCondition("");
-                    couponListVo.setFavorable(jsonObject.getString("num1"));
+                    couponListVo.setFavorable(jsonObject.getString("conditionalAmount"));
                 }
                 if (coupon.getType() == 3) {//体验券{"num1":1}
                     JSONObject jsonObject = JSON.parseObject(content);
                     couponListVo.setUseCondition("");
-                    couponListVo.setFavorable(jsonObject.getString("num1"));
+                    couponListVo.setFavorable(jsonObject.getString("experienceName"));
                 }
                 listVos.add(couponListVo);
             }
@@ -101,7 +146,35 @@
 
     @Override
     public List<Map<String, Object>> queryCouponListOfSearch(CouponListOfSearch ofSearch) {
-        return this.baseMapper.queryCouponListOfSearch(ofSearch.getName(),ofSearch.getType(),ofSearch.getDistributionMethod(),ofSearch.getUserPopulation(),ofSearch.getStatus(),ofSearch.getState(),ofSearch.getPage());
+        return this.baseMapper.queryCouponListOfSearch(ofSearch.getName(),
+                ofSearch.getType(),
+                ofSearch.getDistributionMethod(),
+                ofSearch.getUserPopulation(),
+                ofSearch.getStatus(),
+                ofSearch.getState(),
+                ofSearch.getCityCode(),
+                ofSearch.getStoreId(),
+                ofSearch.getOperatorId(),
+                ofSearch.getObjType());
+    }
+
+    @Override
+    public List<Map<String, Object>> queryCouponListOfSearch1(CouponListOfSearch ofSearch) {
+        return this.baseMapper.queryCouponListOfSearch1(ofSearch.getName(),ofSearch.getType(),ofSearch.getDistributionMethod(),ofSearch.getUserPopulation(),ofSearch.getStatus(),ofSearch.getState(),ofSearch.getPage(),ofSearch.getCityCode(),ofSearch.getStoreId());
+    }
+    @Override
+    public List<Map<String, Object>> queryCouponExamineList(CouponExamineListSearch ofSearch) {
+        return this.baseMapper.queryCouponExamineList(ofSearch.getName(),ofSearch.getType(),ofSearch.getUserPopulation(),ofSearch.getDistributionMethod(),ofSearch.getAuditStatus(),ofSearch.getPage());
+    }
+
+    @Override
+    public List<Map<String, Object>> listRecord(Page<Object> objectPage, Integer id, List<Integer> ids, Integer type) {
+        return this.baseMapper.listRecord(objectPage,id,ids,type);
+    }
+
+    @Override
+    public void updateType(Long id) {
+        this.baseMapper.updateType(id);
     }
 
 }

--
Gitblit v1.7.1