From c27c1f2beb4ca89a94eaa854fce6b4553db8f2f8 Mon Sep 17 00:00:00 2001 From: xuhy <3313886187@qq.com> Date: 星期三, 15 一月 2025 19:58:12 +0800 Subject: [PATCH] 修改 --- ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/controller/UserCouponController.java | 81 ++++++++++++++++++++++++++++++++-------- 1 files changed, 65 insertions(+), 16 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 82a2c24..fe902b7 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 @@ -4,6 +4,7 @@ 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; @@ -21,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; @@ -72,11 +74,18 @@ @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(); - 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)); + LambdaQueryChainWrapper<UserCoupon> chainWrapper = userCouponService.lambdaQuery() + .eq(UserCoupon::getAppUserId, userid); + 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()); CouponInfo data = couponClient.detail(record.getCouponId()).getData(); @@ -89,7 +98,9 @@ List<Goods> data1 = goodsClient.getAllGoods().getData(); List<String> collect = data1.stream().map(Goods::getName).collect(Collectors.toList()); goodNames.addAll(collect); - }else{ + }else if(StringUtils.isEmpty(data.getForGoodIds())){ + goodNames.addAll(JSON.parseArray(data.getGoodsNameJson(), String.class)); + }else { String[] split = vo.getForGoodIds().split(","); R<List<Goods>> goodsById = goodsClient.getGoodsById(split); if (goodsById.getData()!=null){ @@ -97,20 +108,20 @@ goodNames.add(datum.getName()); } } - vo.setGoodNames(goodNames); } + vo.setGoodNames(goodNames); } record.setCouponInfoVo(vo); - if (record.getUseTime()==null){ - record.setStatus(1); - if (record.getEndTime().isBefore(LocalDateTime.now())){ - record.setStatus(3); - } - }else { + 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()); @@ -121,11 +132,36 @@ @GetMapping("/mine/list1") @ApiOperation(value = "已领取列表", tags = {"管理后台-优惠劵"}) - public R<Page<UserCoupon>> list1(@RequestParam Integer pageNum, @RequestParam Integer pageSize, @ApiParam("1未使用2已使用3已过期") Integer status, Integer id) { + 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) .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()); @@ -208,7 +244,7 @@ appUserService.updateById(byId); UserPoint userPoint = new UserPoint(); - userPoint.setType(11); + userPoint.setType(15); userPoint.setHistoricalPoint(lavePoint); userPoint.setVariablePoint(point); userPoint.setBalance(byId.getLavePoint()); @@ -351,5 +387,18 @@ 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