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/UserCouponServiceImpl.java | 106 ++++++++++++++++++++++++++++++++++++++++++++++------ 1 files changed, 93 insertions(+), 13 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 105743f..807b4bc 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; @@ -12,8 +13,11 @@ 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; @@ -61,10 +65,20 @@ private CouponMapper couponMapper; @Resource + private CouponCityMapper couponCityMapper; + + @Resource private StoreClient storeClient; @Resource private CouponStoreMapper csMapper; + + @Resource + private SiteClient siteClient; + + + + /** * 获取购买课程可用优惠券列表 @@ -92,20 +106,79 @@ 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.setFavorable(jsonObject.getDouble("deductionAmount") + "元"); + couponListVo.setUseCondition("满¥" + num1 + "元可用"); + couponListVo.setFavorable(jsonObject.getString("deductionAmount")); } if (type == 2) {//代金券{"num1":1} JSONObject jsonObject = JSON.parseObject(content); - Double num1 = jsonObject.getDouble("deductionAmount"); - if(price.compareTo(num1) <= 0){ + Double num1 = jsonObject.getDouble("conditionalAmount"); + if(num1==null){ + num1=0d; + } + if(price.compareTo(num1) < 0){ continue; } couponListVo.setUseCondition(""); - couponListVo.setFavorable(num1 + "元"); + 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); @@ -139,14 +212,20 @@ 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; @@ -156,16 +235,17 @@ JSONObject jsonObject = JSON.parseObject(coupon.getContent()); switch (coupon.getType()) { case 1: +// {"conditionalAmount":50,"deductionAmount":10,"experienceName":""} // 满减券 - Double num1 = jsonObject.getDouble("num1"); - Double num2 = jsonObject.getDouble("num2"); + 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("num1"); + Double jsonObjectDouble = jsonObject.getDouble("conditionalAmount"); ruleModel.setConditionalAmount(""); ruleModel.setDeductionAmount("¥ "+jsonObjectDouble); ruleModel.setExperienceName(""); @@ -174,7 +254,7 @@ // 体验券 ruleModel.setConditionalAmount(""); ruleModel.setDeductionAmount(""); - ruleModel.setExperienceName(jsonObject.getString("num1")); + ruleModel.setExperienceName(jsonObject.getString("experienceName")); break; default: break; -- Gitblit v1.7.1