From 640ff18d2d7f4be02ddb7f8f75e899f05545eb98 Mon Sep 17 00:00:00 2001
From: puzhibing <393733352@qq.com>
Date: 星期一, 05 二月 2024 11:56:52 +0800
Subject: [PATCH] 更新bug修改

---
 cloud-server-activity/src/main/java/com/dsh/activity/service/impl/UserCouponServiceImpl.java |   66 +++++++++++++++++++--------------
 1 files changed, 38 insertions(+), 28 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 ad19807..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
@@ -5,6 +5,7 @@
 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;
@@ -16,6 +17,7 @@
 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;
@@ -63,6 +65,9 @@
     private CouponMapper couponMapper;
 
     @Resource
+    private CouponCityMapper couponCityMapper;
+
+    @Resource
     private StoreClient storeClient;
 
     @Resource
@@ -72,11 +77,9 @@
     private SiteClient siteClient;
 
 
-
-
-
     /**
      * 获取购买课程可用优惠券列表
+     *
      * @param uid
      * @param coursePackageId
      * @return
@@ -101,19 +104,19 @@
             if (type == 1) {//满减{"num1":1,"num2":1}
                 JSONObject jsonObject = JSON.parseObject(content);
                 Double num1 = jsonObject.getDouble("conditionalAmount");
-                if(price.compareTo(num1) < 0){
+                if (price.compareTo(num1) < 0) {
                     continue;
                 }
-                couponListVo.setUseCondition("满" + num1 + "元可用");
+                couponListVo.setUseCondition("满¥" + num1 + "元可用");
                 couponListVo.setFavorable(jsonObject.getString("deductionAmount"));
             }
             if (type == 2) {//代金券{"num1":1}
                 JSONObject jsonObject = JSON.parseObject(content);
-                Double num1 = jsonObject.getDouble("deductionAmount");
-                if(num1==null){
-                    num1=0d;
+                Double num1 = jsonObject.getDouble("conditionalAmount");
+                if (num1 == null) {
+                    num1 = 0d;
                 }
-                if(price.compareTo(num1) < 0){
+                if (price.compareTo(num1) < 0) {
                     continue;
                 }
                 couponListVo.setUseCondition("");
@@ -132,6 +135,7 @@
 
     /**
      * 获取预约场地可用优惠券列表
+     *
      * @param siteId
      * @param price
      * @return
@@ -157,7 +161,7 @@
             if (type == 1) {//满减{"num1":1,"num2":1}
                 JSONObject jsonObject = JSON.parseObject(content);
                 Double num1 = jsonObject.getDouble("conditionalAmount");
-                if(price.compareTo(num1) < 0){
+                if (price.compareTo(num1) < 0) {
                     continue;
                 }
                 couponListVo.setUseCondition("满" + num1 + "元可用");
@@ -166,10 +170,10 @@
             if (type == 2) {//代金券{"num1":1}
                 JSONObject jsonObject = JSON.parseObject(content);
                 Double num1 = jsonObject.getDouble("conditionalAmount");
-                if(num1==null){
-                    num1=0d;
+                if (num1 == null) {
+                    num1 = 0d;
                 }
-                if(price.compareTo(num1) < 0){
+                if (price.compareTo(num1) < 0) {
                     continue;
                 }
                 couponListVo.setUseCondition("");
@@ -191,9 +195,9 @@
         AppUser appUser = appClient.queryAppUser(uid);
         if (null != appUser) {
             List<UserCoupon> userCoupons = this.baseMapper.selectList(new QueryWrapper<UserCoupon>()
-                    .eq("userId",appUser.getId() )
+                    .eq("userId", appUser.getId())
                     .orderByDesc("insertTime"));
-            if (userCoupons.size() > 0){
+            if (userCoupons.size() > 0) {
                 for (UserCoupon userCoupon : userCoupons) {
                     Coupon coupon = couponMapper.selectById(userCoupon.getCouponId());
                     CouponPackageResp packageResp = new CouponPackageResp();
@@ -201,20 +205,26 @@
                     packageResp.setName(coupon.getName());
                     packageResp.setType(coupon.getType());
                     packageResp.setUseCondition(coupon.getUseScope());
-                    switch (coupon.getUseScope()){
+                    switch (coupon.getUseScope()) {
                         case 1:
                             packageResp.setAvailable("全国通用");
                             break;
                         case 2:
                             packageResp.setAvailable("指定城市可用");
-                            packageResp.setCityOrStore("");
+                            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()));
+                                    .eq("couponId", coupon.getId()).last("limit 1"));
                             StoreDetailOfCourse courseOfStore = storeClient.getCourseOfStore(couponStore.getStoreId());
-                            packageResp.setCityOrStore(courseOfStore.getStoreName()+","+courseOfStore.getStoreAddr());
+//                            packageResp.setCityOrStore(courseOfStore.getStoreName()+","+courseOfStore.getStoreAddr());
+                            packageResp.setCityOrStore(courseOfStore.getStoreName());
                             break;
                         default:
                             break;
@@ -228,15 +238,15 @@
 //                            满减券
                             Double num1 = jsonObject.getDouble("conditionalAmount");
                             Double num2 = jsonObject.getDouble("deductionAmount");
-                            ruleModel.setConditionalAmount("满"+num1+"可用");
-                            ruleModel.setDeductionAmount("¥ "+num2);
+                            ruleModel.setConditionalAmount("满" + num1 + "可用");
+                            ruleModel.setDeductionAmount("¥ " + num2);
                             ruleModel.setExperienceName("");
                             break;
                         case 2:
 //                            代金券
                             Double jsonObjectDouble = jsonObject.getDouble("conditionalAmount");
                             ruleModel.setConditionalAmount("");
-                            ruleModel.setDeductionAmount("¥ "+jsonObjectDouble);
+                            ruleModel.setDeductionAmount("¥ " + jsonObjectDouble);
                             ruleModel.setExperienceName("");
                             break;
                         case 3:
@@ -253,24 +263,24 @@
                     SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd");
                     packageResp.setEffectiveTime(simpleDateFormat.format(coupon.getEndTime()));
 
-                    if (userCoupon.getStatus() == 1){
-                        if (DateUtil.getDate().before(coupon.getEndTime())){
+                    if (userCoupon.getStatus() == 1) {
+                        if (DateUtil.getDate().before(coupon.getEndTime())) {
                             packageResp.setUseStatus(1);
-                        }else {
+                        } else {
                             packageResp.setUseStatus(3);
                         }
                     }
-                    if (userCoupon.getStatus() == 2){
+                    if (userCoupon.getStatus() == 2) {
                         packageResp.setUseStatus(2);
                     }
                     respList.add(packageResp);
                 }
-                if (null != req.getCouponType()){
+                if (null != req.getCouponType()) {
                     respList = respList.stream()
                             .filter(couponPackageResp -> couponPackageResp.getType().equals(req.getCouponType()))
                             .collect(Collectors.toList());
                 }
-                if (null != req.getUseStatus()){
+                if (null != req.getUseStatus()) {
                     respList = respList.stream()
                             .filter(couponPackageResp -> couponPackageResp.getUseStatus().equals(req.getUseStatus()))
                             .collect(Collectors.toList());

--
Gitblit v1.7.1