From aa43a92c7ec9053dbaef92fe5ccb3011b670442c Mon Sep 17 00:00:00 2001
From: puzhibing <393733352@qq.com>
Date: 星期三, 12 七月 2023 11:46:21 +0800
Subject: [PATCH] 更新线上视频奖励模块接口

---
 cloud-server-activity/src/main/java/com/dsh/activity/service/impl/CouponServiceImpl.java |   91 +++++++++++++++++++++++++++++++++++++++++----
 1 files changed, 83 insertions(+), 8 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 83949b6..8187b53 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
@@ -1,26 +1,101 @@
 package com.dsh.activity.service.impl;
 
+
+import com.alibaba.fastjson.JSON;
+import com.alibaba.fastjson.JSONObject;
+import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
 import com.dsh.activity.entity.Coupon;
+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.mapper.CouponMapper;
-import com.dsh.activity.service.CouponService;
+import com.dsh.activity.model.CouponListVo;
+import com.dsh.activity.service.ICouponService;
 import org.springframework.stereotype.Service;
 
+import javax.annotation.Resource;
+import java.text.SimpleDateFormat;
+import java.util.ArrayList;
+import java.util.List;
 import java.util.Map;
 
 /**
- * <p>
- * 优惠券 服务实现类
- * </p>
- *
- * @author jqs
- * @since 2023-06-29
+ * @author zhibing.pu
+ * @date 2023/6/24 11:26
  */
 @Service
-public class CouponServiceImpl extends ServiceImpl<CouponMapper, Coupon> implements CouponService {
+public class CouponServiceImpl extends ServiceImpl<CouponMapper, Coupon> implements ICouponService {
+
+    @Resource
+    private AppUserClient appUserClient;
+
+    @Resource
+    private StudentClient studentClient;
+
+
+
+
+
+
+    /**
+     * 获取购买会员支付成功页面的优惠券
+     * @param uid
+     * @return
+     * @throws Exception
+     */
+    @Override
+    public List<CouponListVo> queryCouponList(Integer uid, Integer distributionMethod) throws Exception {
+        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").orderByDesc("insertTime"));
+            SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
+            for (Coupon coupon : list) {
+                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}
+                    JSONObject jsonObject = JSON.parseObject(content);
+                    couponListVo.setUseCondition("满" + jsonObject.getDouble("num1") + "元可用");
+                    couponListVo.setFavorable(jsonObject.getDouble("num2") + "元");
+                }
+                if (coupon.getType() == 2) {//代金券{"num1":1}
+                    JSONObject jsonObject = JSON.parseObject(content);
+                    couponListVo.setUseCondition("");
+                    couponListVo.setFavorable(jsonObject.getDouble("num1") + "元");
+                }
+                if (coupon.getType() == 3) {//体验券{"num1":1}
+                    JSONObject jsonObject = JSON.parseObject(content);
+                    couponListVo.setUseCondition("");
+                    couponListVo.setFavorable(jsonObject.getString("num1"));
+                }
+                listVos.add(couponListVo);
+            }
+        }
+        return listVos;
+    }
+
+
 
     @Override
     public Map<String, Object> queryConponRuleOfJson(Integer id) {
         return this.baseMapper.queryConponRuleOfJson(id);
     }
+
 }

--
Gitblit v1.7.1