From fd7b8fb7c89832c28a838b0449bbb8a392433ee2 Mon Sep 17 00:00:00 2001 From: Pu Zhibing <393733352@qq.com> Date: 星期二, 22 四月 2025 14:33:02 +0800 Subject: [PATCH] 将华为云短信替换成阿里云短信 --- ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/controller/UserCouponController.java | 174 ++++++++++++++++++++++++++++++++++++++++++++++++++++------ 1 files changed, 156 insertions(+), 18 deletions(-) diff --git a/ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/controller/UserCouponController.java b/ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/controller/UserCouponController.java index a08b7cf..e607e75 100644 --- a/ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/controller/UserCouponController.java +++ b/ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/controller/UserCouponController.java @@ -2,7 +2,9 @@ import com.alibaba.fastjson2.JSON; +import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper; +import com.baomidou.mybatisplus.extension.conditions.query.LambdaQueryChainWrapper; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.ruoyi.account.api.model.AppUser; import com.ruoyi.account.api.model.UserCoupon; @@ -20,6 +22,7 @@ import com.ruoyi.other.api.domain.PointSetting; import com.ruoyi.other.api.feignClient.GoodsClient; import com.ruoyi.other.api.feignClient.PointSettingClient; +import org.springframework.util.CollectionUtils; import org.springframework.web.bind.annotation.*; import javax.annotation.Resource; @@ -71,11 +74,96 @@ @ApiOperation(value = "已领取列表", tags = {"小程序-个人中心-优惠劵"}) public R<Page<UserCoupon>> minelist(@RequestParam Integer pageNum, @RequestParam Integer pageSize, @ApiParam("1未使用2已使用3已过期") Integer status) { Long userid = tokenService.getLoginUserApplet().getUserid(); + LambdaQueryChainWrapper<UserCoupon> chainWrapper = userCouponService.lambdaQuery() + .eq(UserCoupon::getAppUserId, userid) + .isNotNull(UserCoupon::getCouponInfo); + if(null != status && 1 == status){ + chainWrapper.isNull(UserCoupon::getUseTime).gt(UserCoupon::getEndTime, LocalDateTime.now()); + } + if(null != status && 2 == status){ + chainWrapper.isNotNull(UserCoupon::getUseTime); + } + if(null != status && 3 == status){ + chainWrapper.isNull(UserCoupon::getUseTime).lt(UserCoupon::getEndTime, LocalDateTime.now()); + } + Page<UserCoupon> page = chainWrapper.page(Page.of(pageNum-1, pageSize)); + for (UserCoupon record : page.getRecords()) { + record.setIdStr(record.getId().toString()); + String couponInfo = record.getCouponInfo(); + CouponInfoVo vo = JSON.parseObject(couponInfo, CouponInfoVo.class); +// BeanUtils.copyProperties(data,vo); + //如果是商品券,将商品名称返回 + if (vo != null && vo.getCouponType()==4){ + List<String> goodNames = new ArrayList<>(); + if (vo.getForGoodIds().equals("-1")){ + List<Goods> data1 = goodsClient.getAllGoods().getData(); + List<String> collect = data1.stream().map(Goods::getName).collect(Collectors.toList()); + goodNames.addAll(collect); + }else if(StringUtils.isEmpty(vo.getForGoodIds())){ + goodNames.addAll(JSON.parseArray(vo.getGoodsNameJson(), String.class)); + }else { + String[] split = vo.getForGoodIds().split(","); + R<List<Goods>> goodsById = goodsClient.getGoodsById(split); + if (goodsById.getData()!=null){ + for (Goods datum : goodsById.getData()) { + goodNames.add(datum.getName()); + } + } + } + vo.setGoodNames(goodNames); + } + + record.setCouponInfoVo(vo); + if(null != record.getUseTime()){ + record.setStatus(2); + }else{ + if(record.getEndTime().isBefore(LocalDateTime.now())){ + record.setStatus(3); + }else{ + record.setStatus(1); + } + } + AppUser appUser = appUserService.getById(record.getAppUserId()); + record.setUserName(appUser.getName()); + record.setPhone(appUser.getPhone()); + } + return R.ok(page); + } + + + @GetMapping("/mine/list1") + @ApiOperation(value = "已领取列表", tags = {"管理后台-优惠劵"}) + public R<Page<UserCoupon>> list1(@RequestParam Integer pageNum, + @RequestParam Integer pageSize, + String userName, + @ApiParam("1未使用2已使用3已过期") Integer status, + String phone, + Integer id) { + + LambdaQueryWrapper<AppUser> queryWrapper = new LambdaQueryWrapper<>(); + + if (!StringUtils.isEmpty(phone)) { + queryWrapper.like(AppUser::getPhone, phone); + } + if (!StringUtils.isEmpty(userName)) { + queryWrapper.like(AppUser::getName, userName); + } + + List<AppUser> appUserList = appUserService.list(queryWrapper); + + if (CollectionUtils.isEmpty(appUserList)) { + return R.ok(Page.of(pageNum, pageSize)); + } + + List<Long> appUserIds = appUserList.stream().map(AppUser::getId).distinct().collect(Collectors.toList()); + + Page<UserCoupon> page = userCouponService.lambdaQuery() .isNull(status!=null&&(status==1||status==3),UserCoupon::getUseTime) .isNotNull(status!=null&&status==2,UserCoupon::getUseTime) - .lt(status!=null&&status==3,UserCoupon::getEndTime, LocalDateTime.now()) - .eq(UserCoupon::getAppUserId, userid).page(Page.of(pageNum-1, pageSize)); + .eq(UserCoupon::getCouponId, id) + .in(!CollectionUtils.isEmpty(appUserIds),UserCoupon::getAppUserId, appUserIds) + .lt(status!=null&&status==3,UserCoupon::getEndTime, LocalDateTime.now()).page(Page.of(pageNum-1, pageSize)); for (UserCoupon record : page.getRecords()) { record.setIdStr(record.getId().toString()); CouponInfo data = couponClient.detail(record.getCouponId()).getData(); @@ -85,7 +173,7 @@ if (vo.getCouponType()==4){ List<String> goodNames = new ArrayList<>(); if (vo.getForGoodIds().equals("-1")){ - goodNames.add("全部商品"); + goodNames.add("全部商品"); }else{ String[] split = vo.getForGoodIds().split(","); R<List<Goods>> goodsById = goodsClient.getGoodsById(split); @@ -98,8 +186,6 @@ } } - - record.setCouponInfoVo(vo); if (record.getUseTime()==null){ record.setStatus(1); @@ -110,13 +196,13 @@ record.setStatus(2); } - AppUser appUser = appUserService.getById(record.getAppUserId()); record.setUserName(appUser.getName()); record.setPhone(appUser.getPhone()); } return R.ok(page); } + @GetMapping("/get") @@ -132,6 +218,19 @@ if (data==null){ return R.fail("当前优惠券不存在,请刷新后重试"); } + if(data.getDelFlag() == 1 || data.getShelfStatus() == 0){ + return R.fail("当前优惠券不存在,请刷新后重试"); + } + long count = userCouponService.count(new LambdaQueryWrapper<UserCoupon>().eq(UserCoupon::getCouponId, couponId).eq(UserCoupon::getDelFlag, 0)); + if(data.getSendNum() <= count){ + return R.fail("当前优惠券已全部领取完毕"); + } + count = userCouponService.count(new LambdaQueryWrapper<UserCoupon>().eq(UserCoupon::getCouponId, couponId) + .eq(UserCoupon::getAppUserId, userid).eq(UserCoupon::getDelFlag, 0)); + if(data.getMaxNum() <= count){ + return R.fail("当前优惠券已达到最大领取限制"); + } + if (data.getSendType()!=1&& byId.getLavePoint().compareTo(data.getNeedPoint().intValue()) < 0){ return R.fail("当前积分不足,兑换失败"); } @@ -148,19 +247,23 @@ byId.setLavePoint(byId.getLavePoint() - point); appUserService.updateById(byId); - UserPoint userPoint = new UserPoint(); - userPoint.setType(4); - userPoint.setHistoricalPoint(lavePoint); - userPoint.setVariablePoint(point); - userPoint.setBalance(byId.getLavePoint()); - userPoint.setAppUserId(userid); - userPoint.setObjectId(Long.valueOf(data.getId())); - userPoint.setCreateTime(LocalDateTime.now()); - userPointService.save(userPoint); + if(point > 0){ + UserPoint userPoint = new UserPoint(); + userPoint.setType(15); + userPoint.setVariablePoint(point); + userPoint.setAppUserId(userid); + userPoint.setObjectId(Long.valueOf(data.getId())); + userPoint.setCreateTime(LocalDateTime.now()); + userPoint.setChangeDirection(-1); + userPointService.save(userPoint); + } } + + //增加优惠券记录,根据时间类型设置开始结束时间 UserCoupon userCoupon = new UserCoupon(); userCoupon.setAppUserId(userid); + userCoupon.setCouponInfo(JSON.toJSONString(data)); if (data.getPeriodType()==1) { userCoupon.setStartTime(data.getPeriodStartTime().atTime(0, 0, 0)); userCoupon.setEndTime(data.getPeriodEndTime().atTime(23, 59, 59)); @@ -199,9 +302,8 @@ @PostMapping("/getCouponInfo") public R<CouponInfoVo> getCouponInfo(@RequestParam("userCouponId") Long userCouponId){ UserCoupon userCoupon = userCouponService.getById(userCouponId); - CouponInfo data = couponClient.detail(userCoupon.getCouponId()).getData(); - CouponInfoVo couponInfoVo = new CouponInfoVo(); - BeanUtils.copyProperties(data, couponInfoVo); + String jsonStr = userCoupon.getCouponInfo(); + CouponInfoVo couponInfoVo = JSON.parseObject(jsonStr, CouponInfoVo.class); return R.ok(couponInfoVo); } @@ -269,5 +371,41 @@ userCouponService.updateById(userCoupon); return R.ok(); } + + + /** + * 获取用户优惠券详情 + * @param id + * @return + */ + @PostMapping("/getUserCoupon") + public R<UserCoupon> getUserCoupon(@RequestParam("id") Long id){ + UserCoupon userCoupon = userCouponService.getById(id); + return R.ok(userCoupon); + } + + + /** + * 编辑用户优惠券 + * @return + */ + @PostMapping("/editUserCoupon") + public R editUserCoupon(@RequestBody UserCoupon userCoupon){ + userCouponService.updateById(userCoupon); + return R.ok(); + } + + + /** + * 编辑用户优惠券使用时间 + * @param userCoupon + * @return + */ + @PostMapping("/editReturnUse") + public R editReturnUse(@RequestBody UserCoupon userCoupon){ + userCouponService.update(new LambdaUpdateWrapper<UserCoupon>().eq(UserCoupon::getId, userCoupon.getId()) + .set(UserCoupon::getUseTime, userCoupon.getUseTime())); + return R.ok(); + } } -- Gitblit v1.7.1