From ac3e9a7f0b21fb630049f9e191bd760eefd21467 Mon Sep 17 00:00:00 2001 From: 无关风月 <443237572@qq.com> Date: 星期六, 16 八月 2025 18:04:38 +0800 Subject: [PATCH] 管理后台会员管理 --- cloud-server-activity/src/main/java/com/dsh/activity/controller/UserCouponController.java | 266 ++++++++++++++++++++++++++++++++++++++++++++++------- 1 files changed, 231 insertions(+), 35 deletions(-) diff --git a/cloud-server-activity/src/main/java/com/dsh/activity/controller/UserCouponController.java b/cloud-server-activity/src/main/java/com/dsh/activity/controller/UserCouponController.java index be425d3..3b49b8b 100644 --- a/cloud-server-activity/src/main/java/com/dsh/activity/controller/UserCouponController.java +++ b/cloud-server-activity/src/main/java/com/dsh/activity/controller/UserCouponController.java @@ -1,14 +1,24 @@ package com.dsh.activity.controller; +import com.alibaba.fastjson.JSON; +import com.alibaba.fastjson.JSONArray; +import com.alibaba.fastjson.JSONObject; +import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; -import com.dsh.activity.entity.Coupon; -import com.dsh.activity.entity.CouponStore; -import com.dsh.activity.entity.UserCoupon; +import com.dsh.activity.entity.*; +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.model.CouponStuAvailableVo; +import com.dsh.activity.feignclient.model.QueryUserCouponByIdAndUserId; import com.dsh.activity.model.CouponListVo; +import com.dsh.activity.model.GrantCoupon; +import com.dsh.activity.model.SendCouponReq; import com.dsh.activity.service.CouponStoreService; import com.dsh.activity.service.ICouponService; import com.dsh.activity.service.UserCouponService; +import com.dsh.activity.service.VipDetailService; +import com.dsh.activity.util.DateUtil; import com.dsh.activity.util.ResultUtil; import com.dsh.activity.util.TokenUtil; import io.swagger.annotations.Api; @@ -16,10 +26,13 @@ import io.swagger.annotations.ApiImplicitParams; import io.swagger.annotations.ApiOperation; import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.util.StringUtils; import org.springframework.web.bind.annotation.*; +import javax.annotation.Resource; import java.text.SimpleDateFormat; import java.util.ArrayList; +import java.util.Date; import java.util.List; import java.util.Map; import java.util.stream.Collectors; @@ -39,9 +52,16 @@ @Autowired private UserCouponService userCouponService; - @Autowired private CouponStoreService csServie; + + @Resource + private AppUserClient appUserClient; + + @Resource + private StudentClient studentClient; + @Autowired + private VipDetailService vipDetailService; @@ -49,14 +69,14 @@ private final SimpleDateFormat format = new SimpleDateFormat("yyyy-MM"); @PostMapping("/base/userConpon/getStuOfConpons") - public List<CouponStuAvailableVo> queryUserWithConponList(@RequestParam("appUserId") Integer appUserId){ + public List<CouponStuAvailableVo> queryUserWithConponList(@RequestParam("appUserId") Integer appUserId) { List<CouponStuAvailableVo> availableVos = new ArrayList<>(); List<UserCoupon> list = userCouponService.list(new QueryWrapper<UserCoupon>() .eq("userId", appUserId) - .eq("status",1)); - if (list.size() > 0){ + .eq("status", 1)); + if (list.size() > 0) { List<Integer> collect = list.stream().map(UserCoupon::getCouponId).collect(Collectors.toList()); List<Coupon> conponList = cService.list(new QueryWrapper<Coupon>() .in("id", collect)); @@ -65,8 +85,8 @@ availableVo.setConponId(coupon.getId()); availableVo.setConponName(coupon.getName()); availableVo.setConponType(coupon.getType()); - Map<String,Object> conponRuleMap = cService.queryConponRuleOfJson(coupon.getId()); - switch (coupon.getType()){ + Map<String, Object> conponRuleMap = cService.queryConponRuleOfJson(coupon.getId()); + switch (coupon.getType()) { case 1: Object conditionalAmount = conponRuleMap.get("conditionalAmount"); Object deductionAmount = conponRuleMap.get("deductionAmount"); @@ -75,7 +95,7 @@ break; case 2: Object amount = conponRuleMap.get("deductionAmount"); - availableVo.setAmount((double)amount); + availableVo.setAmount((double) amount); break; default: break; @@ -88,10 +108,20 @@ } @PostMapping("/base/userConpon/queryCouponRules") - public Map<String,Object> getCouponRules(@RequestBody Integer couponId){ + public Map<String, Object> getCouponRules(@RequestBody Integer couponId) { return cService.queryConponRuleOfJson(couponId); } + @ResponseBody + @PostMapping("/base/userConpon/getCoupons") + public List<Coupon> getCoupons(@RequestBody String couponIds) { + ArrayList<Integer> integers = new ArrayList<>(); + for (String s : couponIds.split(",")) { + Integer integer = Integer.valueOf(s); + integers.add(integer); + } + return cService.list(new LambdaQueryWrapper<Coupon>().in(Coupon::getId, integers)); + } @ResponseBody @@ -104,21 +134,19 @@ @ApiImplicitParam(value = "纬度", name = "lat", dataType = "string", required = true), @ApiImplicitParam(name = "Authorization", value = "用户token(Bearer +token)", required = true, dataType = "String", paramType = "header", defaultValue = "Bearer eyJhbGciOiJIUzUxMiJ9.....") }) - public ResultUtil<List<CouponListVo>> queryAvailableCouponList(Integer coursePackageId, Double price, String lon, String lat){ + public ResultUtil<List<CouponListVo>> queryAvailableCouponList(Integer coursePackageId, Double price, String lon, String lat) { try { Integer uid = tokenUtil.getUserIdFormRedis(); - if(null == uid){ + if (null == uid) { return ResultUtil.tokenErr(); } List<CouponListVo> listVos = userCouponService.queryAvailableCouponList(uid, coursePackageId, price, lon, lat); return ResultUtil.success(listVos); - }catch (Exception e){ + } catch (Exception e) { e.printStackTrace(); return ResultUtil.runErr(); } } - - @ResponseBody @@ -131,72 +159,240 @@ @ApiImplicitParam(value = "纬度", name = "lat", dataType = "string", required = true), @ApiImplicitParam(name = "Authorization", value = "用户token(Bearer +token)", required = true, dataType = "String", paramType = "header", defaultValue = "Bearer eyJhbGciOiJIUzUxMiJ9.....") }) - public ResultUtil<List<CouponListVo>> querySiteCouponList(Integer siteId, Double price, String lon, String lat){ + public ResultUtil<List<CouponListVo>> querySiteCouponList(Integer siteId, Double price, String lon, String lat) { try { Integer uid = tokenUtil.getUserIdFormRedis(); - if(null == uid){ + if (null == uid) { return ResultUtil.tokenErr(); } List<CouponListVo> listVos = userCouponService.querySiteCouponList(uid, siteId, price, lon, lat); return ResultUtil.success(listVos); - }catch (Exception e){ + } catch (Exception e) { e.printStackTrace(); return ResultUtil.runErr(); } } - - /** * 根据id获取用户优惠券数据 - * @param id + * + * @param * @return */ @ResponseBody @PostMapping("/userCoupon/queryUserCouponById") - public UserCoupon queryUserCouponById(@RequestBody Long id){ + public UserCoupon queryUserCouponById(@RequestBody QueryUserCouponByIdAndUserId userCouponByIdAndUserId) { try { - UserCoupon userCoupon = userCouponService.getById(id); + UserCoupon userCoupon = userCouponService.getOne(new LambdaQueryWrapper<UserCoupon>().eq(UserCoupon::getId, userCouponByIdAndUserId.getId()).eq(UserCoupon::getUserId, userCouponByIdAndUserId.getUserId())); return userCoupon; - }catch (Exception e){ + } catch (Exception e) { e.printStackTrace(); return null; + } + } + + @ResponseBody + @PostMapping("/userCoupon/queryUserCouponById1") + public UserCoupon queryUserCouponById1(@RequestBody Long id) { + try { + UserCoupon userCoupon = userCouponService.getOne(new LambdaQueryWrapper<UserCoupon>().eq(UserCoupon::getId, id)); + return userCoupon; + } catch (Exception e) { + e.printStackTrace(); + return null; + } + } + + @Autowired + private ICouponService couponService; + + @PostMapping("/userCoupon/edit") + public void edit(@RequestBody UserCoupon userCoupon) { + userCoupon.setUserId(null); + userCouponService.updateById(userCoupon); + + } + + @PostMapping("/userCoupon/sendUserCoupon") + public void sendUserCoupon(@RequestBody SendCouponReq sendCouponReq) { + try { + String couponIds = sendCouponReq.getCouponIds(); + for (String s : couponIds.split(",")) { + Coupon coupon = couponService.getById(s); + Integer userId = sendCouponReq.getUserId(); + if(coupon.getAuditStatus() != 2){ + continue; + } + if(coupon.getStatus() != 2){ + continue; + } + if(coupon.getState() != 1){ + continue; + } + if(coupon.getUserPopulation() == 2){ + AppUser appUser = appUserClient.queryAppUser(userId); + if(appUser.getIsVip() == 0){ + continue; + } + } + if(coupon.getUserPopulation() == 3){ + List<TStudent> tStudents = studentClient.queryStudentList(userId); + if(tStudents.size() == 0){ + continue; + } + } + if (new Date().before(coupon.getStartTime()) && new Date().after(coupon.getEndTime())) { + continue; + } + //查询该优惠卷的数量够不够 + List<Integer> queryIds = new ArrayList<>(); + queryIds.add(coupon.getId()); + int counts = userCouponService.count(new QueryWrapper<UserCoupon>().eq("couponId", s)); + if (coupon.getQuantityIssued() <= counts) { + continue; + } + counts = userCouponService.count(new QueryWrapper<UserCoupon>().eq("couponId", s).eq("userId", userId)); + if (coupon.getPickUpQuantity() <= counts) { + continue; + } + + UserCoupon userCoupon = new UserCoupon(); + userCoupon.setCouponId(Integer.valueOf(s)); + userCoupon.setUserId(sendCouponReq.getUserId()); + userCoupon.setStatus(1); + userCoupon.setInsertTime(new Date()); + userCouponService.save(userCoupon); + } + } catch (Exception e) { + e.printStackTrace(); } } /** * 修改优惠券数据 + * * @param userCoupon */ @ResponseBody @PostMapping("/userCoupon/updateUserCoupon") - public void updateUserCoupon(@RequestBody UserCoupon userCoupon){ + public void updateUserCoupon(@RequestBody UserCoupon userCoupon) { try { + userCoupon.setUserId(null); userCouponService.updateById(userCoupon); - }catch (Exception e){ + } catch (Exception e) { e.printStackTrace(); } } - - - + + @ResponseBody @PostMapping("/userCoupon/queryCouponOfStore") - public List<Integer> getCouponStoreIds(@RequestBody Integer couponId){ + public List<Integer> getCouponStoreIds(@RequestBody Integer couponId) { try { List<Integer> storeIds = new ArrayList<>(); List<CouponStore> list = csServie.list(new QueryWrapper<CouponStore>() - .eq("couponId",couponId)); - if (list.size() > 0 ){ + .eq("couponId", couponId)); + if (list.size() > 0) { storeIds = list.stream().map(CouponStore::getStoreId).collect(Collectors.toList()); } + if (storeIds.size() == 0) { + storeIds.add(-1); + } return storeIds; - }catch (Exception e){ + } catch (Exception e) { e.printStackTrace(); return null; } } - + + + @ResponseBody + @PostMapping("/userCoupon/queryCounts") + public Integer queryCounts(@RequestBody List<Integer> queryIds) { + return userCouponService.count(new QueryWrapper<UserCoupon>().eq("couponId", queryIds.get(0))); + + + } + + + @ResponseBody + @PostMapping("/userCoupon/queryCounts1") + public Integer queryCounts1(@RequestBody List<Integer> queryIds) { + return userCouponService.count(new QueryWrapper<UserCoupon>().eq("couponId", queryIds.get(0)).eq("userId", queryIds.get(1))); + } + + // 开通会员后 赠送优惠券和门票 + @ResponseBody + @PostMapping("/userCoupon/grantCoupon") + public void grantCoupon(@RequestBody GrantCoupon grantCoupon) { + String couponJson = grantCoupon.getCouponJson(); + if (StringUtils.hasLength(couponJson)) { + + // 赠送优惠券 + JSONArray objects = JSON.parseArray(couponJson); + for (Object object : objects) { + JSONObject jsonObject = (JSONObject) object; + // 优惠券id + String id = jsonObject.getString("id"); + // 优惠券数量 + String value = jsonObject.getString("value"); + for (Integer i = 0; i < Integer.valueOf(value); i++) { + UserCoupon userCoupon = new UserCoupon(); + userCoupon.setCouponId(Integer.valueOf(id)); + userCoupon.setUserId(grantCoupon.getUserId()); + userCoupon.setStatus(1); + userCoupon.setVerificationUserId(null); + userCoupon.setVerificationTime(null); + userCoupon.setInsertTime(new Date()); + userCoupon.setIsVipGrant(1); + userCouponService.save(userCoupon); + // 生成对应的权益明细记录 + VipDetail vipDetail = new VipDetail(); + vipDetail.setAppUserId(grantCoupon.getUserId()); + vipDetail.setStatus(1); + vipDetail.setInsertTime(new Date()); + vipDetail.setVipId(grantCoupon.getVipId()); + vipDetail.setType(1); + vipDetail.setVipPaymentId(grantCoupon.getVipPaymentId()); + vipDetail.setCouponId(Integer.valueOf(id)); + vipDetail.setUserCouponId(userCoupon.getId()); + vipDetailService.save(vipDetail); + } + } + } + String ticketJson = grantCoupon.getTicketJson(); + if (StringUtils.hasLength(ticketJson)) { + // 赠送优惠券 + JSONArray objects = JSON.parseArray(ticketJson); + for (Object object : objects) { + JSONObject jsonObject = (JSONObject) object; + // 门票名称 + String name = jsonObject.getString("name"); + // 领取后x天有效 + String time = jsonObject.getString("time"); + Integer days = Integer.valueOf(time); + // 可用次数 + String count = jsonObject.getString("count"); + for (Integer i = 0; i < Integer.valueOf(count); i++) { + // 生成对应的权益明细记录 + VipDetail vipDetail = new VipDetail(); + vipDetail.setTicketName(name); + vipDetail.setStartTime(new Date()); + Date date = new Date(); + // 加X天 + Date tomorrow = new Date(date.getTime() + 24 * 60 * 60 * 1000L * days); + vipDetail.setEndTime(tomorrow); + vipDetail.setAppUserId(grantCoupon.getUserId()); + vipDetail.setStatus(1); + vipDetail.setInsertTime(new Date()); + vipDetail.setVipId(grantCoupon.getVipPaymentId()); + vipDetail.setType(2); + vipDetail.setVipPaymentId(grantCoupon.getVipPaymentId()); + vipDetailService.save(vipDetail); + } + } + } + } } -- Gitblit v1.7.1