From 9486766c806fe1d9e082b2fd02ea1cc558f1b443 Mon Sep 17 00:00:00 2001
From: 无关风月 <443237572@qq.com>
Date: 星期四, 08 五月 2025 09:21:57 +0800
Subject: [PATCH] bug修改

---
 cloud-server-activity/src/main/java/com/dsh/activity/service/impl/UserCouponServiceImpl.java |  274 ++++++++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 274 insertions(+), 0 deletions(-)

diff --git a/cloud-server-activity/src/main/java/com/dsh/activity/service/impl/UserCouponServiceImpl.java b/cloud-server-activity/src/main/java/com/dsh/activity/service/impl/UserCouponServiceImpl.java
index d646a5b..12804de 100644
--- a/cloud-server-activity/src/main/java/com/dsh/activity/service/impl/UserCouponServiceImpl.java
+++ b/cloud-server-activity/src/main/java/com/dsh/activity/service/impl/UserCouponServiceImpl.java
@@ -1,10 +1,42 @@
 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.entity.CouponCity;
+import com.dsh.activity.entity.CouponStore;
 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.course.CoursePackageClient;
+import com.dsh.activity.feignclient.course.model.CoursePackage;
+import com.dsh.activity.feignclient.other.SiteClient;
+import com.dsh.activity.feignclient.other.StoreClient;
+import com.dsh.activity.feignclient.other.model.Site;
+import com.dsh.activity.feignclient.other.model.StoreDetailOfCourse;
+import com.dsh.activity.mapper.CouponCityMapper;
+import com.dsh.activity.mapper.CouponMapper;
+import com.dsh.activity.mapper.CouponStoreMapper;
 import com.dsh.activity.mapper.UserCouponMapper;
+import com.dsh.activity.model.ConponJsonRuleModel;
+import com.dsh.activity.model.CouponListVo;
+import com.dsh.activity.model.request.CouponPackageReq;
+import com.dsh.activity.model.response.CouponPackageResp;
 import com.dsh.activity.service.UserCouponService;
+import com.dsh.activity.util.DateUtil;
+import com.dsh.activity.util.GDMapGeocodingUtil;
+import org.springframework.beans.factory.annotation.Autowired;
 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;
+import java.util.stream.Collectors;
 
 /**
  * <p>
@@ -17,4 +49,246 @@
 @Service
 public class UserCouponServiceImpl extends ServiceImpl<UserCouponMapper, UserCoupon> implements UserCouponService {
 
+    @Resource
+    private CoursePackageClient coursePackageClient;
+
+    @Autowired
+    private GDMapGeocodingUtil gdMapGeocodingUtil;
+
+    @Resource
+    private AppUserClient appClient;
+
+    @Resource
+    private StudentClient studentClient;
+
+    @Resource
+    private CouponMapper couponMapper;
+
+    @Resource
+    private CouponCityMapper couponCityMapper;
+
+    @Resource
+    private StoreClient storeClient;
+
+    @Resource
+    private CouponStoreMapper csMapper;
+
+    @Resource
+    private SiteClient siteClient;
+
+
+    /**
+     * 获取购买课程可用优惠券列表
+     *
+     * @param uid
+     * @param coursePackageId
+     * @return
+     */
+    @Override
+    public List<CouponListVo> queryAvailableCouponList(Integer uid, Integer coursePackageId, Double price, String lon, String lat) throws Exception {
+        CoursePackage coursePackage = coursePackageClient.queryCoursePackageById(coursePackageId);
+        Integer storeId = coursePackage.getStoreId();
+        Map<String, String> geocode = gdMapGeocodingUtil.geocode(lon, lat);
+        String provinceCode = geocode.get("provinceCode");
+        String cityCode = geocode.get("cityCode");
+        List<Map<String, Object>> userCoupons = this.baseMapper.queryAvailableCouponList(uid, storeId, provinceCode, cityCode);
+        List<CouponListVo> listVos = new ArrayList<>();
+        for (Map<String, Object> userCoupon : userCoupons) {
+            Integer type = Integer.valueOf(userCoupon.get("type").toString());
+            CouponListVo couponListVo = new CouponListVo();
+            couponListVo.setId(Long.valueOf(userCoupon.get("id").toString()));
+            couponListVo.setName(userCoupon.get("name").toString());
+            couponListVo.setType(type);
+            couponListVo.setEffectiveTime(userCoupon.get("endTime").toString());
+            String content = userCoupon.get("content").toString();
+            if (type == 1) {//满减{"num1":1,"num2":1}
+                JSONObject jsonObject = JSON.parseObject(content);
+                Double num1 = jsonObject.getDouble("conditionalAmount");
+                if (price.compareTo(num1) < 0) {
+                    continue;
+                }
+                couponListVo.setUseCondition("满¥" + num1 + "元可用");
+                couponListVo.setFavorable(jsonObject.getString("deductionAmount"));
+            }
+            if (type == 2) {//代金券{"num1":1}
+                JSONObject jsonObject = JSON.parseObject(content);
+                Double num1 = jsonObject.getDouble("conditionalAmount");
+                if (num1 == null) {
+                    num1 = 0d;
+                }
+                if (price.compareTo(num1) < 0) {
+                    continue;
+                }
+                couponListVo.setUseCondition("");
+                couponListVo.setFavorable(num1 + "");
+            }
+            if (type == 3) {//体验券{"num1":1}
+                JSONObject jsonObject = JSON.parseObject(content);
+                couponListVo.setUseCondition("");
+                couponListVo.setFavorable(jsonObject.getString("experienceName"));
+            }
+            listVos.add(couponListVo);
+        }
+        return listVos;
+    }
+
+
+    /**
+     * 获取预约场地可用优惠券列表
+     *
+     * @param siteId
+     * @param price
+     * @return
+     * @throws Exception
+     */
+    @Override
+    public List<CouponListVo> querySiteCouponList(Integer uid, Integer siteId, Double price, String lon, String lat) throws Exception {
+        Site site = siteClient.querySiteById(siteId);
+        Integer storeId = site.getStoreId();
+        Map<String, String> geocode = gdMapGeocodingUtil.geocode(lon, lat);
+        String provinceCode = geocode.get("provinceCode");
+        String cityCode = geocode.get("cityCode");
+        List<Map<String, Object>> userCoupons = this.baseMapper.queryAvailableCouponList(uid, storeId, provinceCode, cityCode);
+        List<CouponListVo> listVos = new ArrayList<>();
+        for (Map<String, Object> userCoupon : userCoupons) {
+            Integer type = Integer.valueOf(userCoupon.get("type").toString());
+            CouponListVo couponListVo = new CouponListVo();
+            couponListVo.setId(Long.valueOf(userCoupon.get("id").toString()));
+            couponListVo.setName(userCoupon.get("name").toString());
+            couponListVo.setType(type);
+            couponListVo.setEffectiveTime(userCoupon.get("endTime").toString());
+            String content = userCoupon.get("content").toString();
+            if (type == 1) {//满减{"num1":1,"num2":1}
+                JSONObject jsonObject = JSON.parseObject(content);
+                Double num1 = jsonObject.getDouble("conditionalAmount");
+                if (price.compareTo(num1) < 0) {
+                    continue;
+                }
+                couponListVo.setUseCondition("满" + num1 + "元可用");
+                couponListVo.setFavorable(jsonObject.getString("deductionAmount"));
+            }
+            if (type == 2) {//代金券{"num1":1}
+                JSONObject jsonObject = JSON.parseObject(content);
+                Double num1 = jsonObject.getDouble("conditionalAmount");
+                if (num1 == null) {
+                    num1 = 0d;
+                }
+                if (price.compareTo(num1) < 0) {
+                    continue;
+                }
+                couponListVo.setUseCondition("");
+                couponListVo.setFavorable(num1 + "");
+            }
+            if (type == 3) {//体验券{"num1":1}
+                JSONObject jsonObject = JSON.parseObject(content);
+                couponListVo.setUseCondition("");
+                couponListVo.setFavorable(jsonObject.getString("experienceName"));
+            }
+            listVos.add(couponListVo);
+        }
+        return listVos;
+    }
+
+    @Override
+    public List<CouponPackageResp> queryCouponPackagesList(Integer uid, CouponPackageReq req) {
+        List<CouponPackageResp> respList = new ArrayList<>();
+        AppUser appUser = appClient.queryAppUser(uid);
+        if (null != appUser) {
+            List<UserCoupon> userCoupons = this.baseMapper.selectList(new QueryWrapper<UserCoupon>()
+                    .eq("userId", appUser.getId())
+                    .orderByDesc("insertTime"));
+            if (userCoupons.size() > 0) {
+                for (UserCoupon userCoupon : userCoupons) {
+                    Coupon coupon = couponMapper.selectById(userCoupon.getCouponId());
+                    CouponPackageResp packageResp = new CouponPackageResp();
+                    packageResp.setId(coupon.getId());
+                    packageResp.setName(coupon.getName());
+                    packageResp.setType(coupon.getType());
+                    packageResp.setUseCondition(coupon.getUseScope());
+                    switch (coupon.getUseScope()) {
+                        case 1:
+                            packageResp.setAvailable("全国通用");
+                            break;
+                        case 2:
+                            packageResp.setAvailable("指定城市可用");
+                            List<CouponCity> couponId = couponCityMapper.selectList(new QueryWrapper<CouponCity>().eq("couponId", coupon.getId()));
+                            StringBuilder stringBuilder = new StringBuilder();
+                            for (CouponCity couponCity : couponId) {
+                                stringBuilder.append(couponCity.getCity());
+                            }
+                            packageResp.setCityOrStore(String.valueOf(stringBuilder));
+                            break;
+                        case 3:
+                            packageResp.setAvailable("指定门店可用");
+                            CouponStore couponStore = csMapper.selectOne(new QueryWrapper<CouponStore>()
+                                    .eq("couponId", coupon.getId()).last("limit 1"));
+                            StoreDetailOfCourse courseOfStore = storeClient.getCourseOfStore(couponStore.getStoreId());
+//                            packageResp.setCityOrStore(courseOfStore.getStoreName()+","+courseOfStore.getStoreAddr());
+                            packageResp.setCityOrStore(courseOfStore.getStoreName());
+                            break;
+                        default:
+                            break;
+                    }
+                    packageResp.setInstructionsForUse(coupon.getIllustrate());
+                    ConponJsonRuleModel ruleModel = new ConponJsonRuleModel();
+                    JSONObject jsonObject = JSON.parseObject(coupon.getContent());
+                    switch (coupon.getType()) {
+                        case 1:
+//                        {"conditionalAmount":50,"deductionAmount":10,"experienceName":""}
+//                            满减券
+                            Double num1 = jsonObject.getDouble("conditionalAmount");
+                            Double num2 = jsonObject.getDouble("deductionAmount");
+                            ruleModel.setConditionalAmount("满" + num1 + "可用");
+                            ruleModel.setDeductionAmount("¥ " + num2);
+                            ruleModel.setExperienceName("");
+                            break;
+                        case 2:
+//                            代金券
+                            Double jsonObjectDouble = jsonObject.getDouble("conditionalAmount");
+                            ruleModel.setConditionalAmount("");
+                            ruleModel.setDeductionAmount("¥ " + jsonObjectDouble);
+                            ruleModel.setExperienceName("");
+                            break;
+                        case 3:
+//                            体验券
+                            ruleModel.setConditionalAmount("");
+                            ruleModel.setDeductionAmount("");
+                            ruleModel.setExperienceName(jsonObject.getString("experienceName"));
+                            break;
+                        default:
+                            break;
+                    }
+                    packageResp.setRuleModel(ruleModel);
+
+                    SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd");
+                    packageResp.setEffectiveTime(simpleDateFormat.format(coupon.getEndTime()));
+
+                    if (userCoupon.getStatus() == 1) {
+                        if (DateUtil.getDate().before(coupon.getEndTime())) {
+                            packageResp.setUseStatus(1);
+                        } else {
+                            packageResp.setUseStatus(3);
+                        }
+                    }
+                    if (userCoupon.getStatus() == 2) {
+                        packageResp.setUseStatus(2);
+                    }
+                    respList.add(packageResp);
+                }
+                if (null != req.getCouponType()) {
+                    respList = respList.stream()
+                            .filter(couponPackageResp -> couponPackageResp.getType().equals(req.getCouponType()))
+                            .collect(Collectors.toList());
+                }
+                if (null != req.getUseStatus()) {
+                    respList = respList.stream()
+                            .filter(couponPackageResp -> couponPackageResp.getUseStatus().equals(req.getUseStatus()))
+                            .collect(Collectors.toList());
+                }
+            }
+
+        }
+        return respList;
+    }
+
 }

--
Gitblit v1.7.1