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 | 170 ++++++++++++++++++++++++++++++++++++++++++++++++++++++-- 1 files changed, 162 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..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 @@ -1,26 +1,180 @@ 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.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.service.CouponService; +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; /** - * <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; + + + + + @Autowired + private UserCouponService userCouponService; + + @Autowired + private ICouponService couponService; + + /** + * 获取购买会员支付成功页面的优惠券 + * @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<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"); + + + + 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) {//满减 +// {"conditionalAmount":50,"deductionAmount":10,"experienceName":""} + JSONObject jsonObject = JSON.parseObject(content); + 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("conditionalAmount")); + } + if (coupon.getType() == 3) {//体验券{"num1":1} + JSONObject jsonObject = JSON.parseObject(content); + couponListVo.setUseCondition(""); + couponListVo.setFavorable(jsonObject.getString("experienceName")); + } + listVos.add(couponListVo); + } + } + return listVos; + } + + @Override public Map<String, Object> queryConponRuleOfJson(Integer id) { return this.baseMapper.queryConponRuleOfJson(id); } + + @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.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