From b64d67ef01e81a857046f19dd556b4e4f0695e1c Mon Sep 17 00:00:00 2001 From: liujie <liujie> Date: 星期三, 02 八月 2023 16:41:51 +0800 Subject: [PATCH] 后台代码 门店管理 --- cloud-server-activity/src/main/java/com/dsh/activity/service/impl/CouponServiceImpl.java | 103 +++++++++++++++++++++++++++++++++++++++++++++++---- 1 files changed, 95 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..0043c63 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,113 @@ 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.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.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 order by insertTime desc")); + 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.getString("num2")); + } + if (coupon.getType() == 2) {//代金券{"num1":1} + JSONObject jsonObject = JSON.parseObject(content); + couponListVo.setUseCondition(""); + couponListVo.setFavorable(jsonObject.getString("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); } + + @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.getPage()); + } + + @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()); + } + } -- Gitblit v1.7.1