From 4c07eb5512914ebd38e1c1e4455094577864c9f0 Mon Sep 17 00:00:00 2001 From: 无关风月 <443237572@qq.com> Date: 星期二, 19 八月 2025 11:47:43 +0800 Subject: [PATCH] 会员支付相关 --- cloud-server-activity/src/main/java/com/dsh/activity/controller/CouponController.java | 57 ++++++++++++++++++++++++++++++++++++++++++++++----------- 1 files changed, 46 insertions(+), 11 deletions(-) diff --git a/cloud-server-activity/src/main/java/com/dsh/activity/controller/CouponController.java b/cloud-server-activity/src/main/java/com/dsh/activity/controller/CouponController.java index 730d3b4..73af208 100644 --- a/cloud-server-activity/src/main/java/com/dsh/activity/controller/CouponController.java +++ b/cloud-server-activity/src/main/java/com/dsh/activity/controller/CouponController.java @@ -7,10 +7,7 @@ import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; -import com.dsh.activity.entity.Coupon; -import com.dsh.activity.entity.CouponCity; -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.CityClient; import com.dsh.activity.feignclient.account.StoreStaffClient; @@ -29,14 +26,11 @@ import com.dsh.activity.feignclient.other.model.TOperatorCity; import com.dsh.activity.model.CouponListVo; import com.dsh.activity.model.CouponRecordQuery; -import com.dsh.activity.model.request.CommodityRequest; -import com.dsh.activity.model.request.CouponDataVo; -import com.dsh.activity.model.request.CouponPackageReq; +import com.dsh.activity.model.VipDetailVO; +import com.dsh.activity.model.VipPaymentVO; +import com.dsh.activity.model.request.*; import com.dsh.activity.model.response.CouponPackageResp; -import com.dsh.activity.service.CouponCityService; -import com.dsh.activity.service.CouponStoreService; -import com.dsh.activity.service.ICouponService; -import com.dsh.activity.service.UserCouponService; +import com.dsh.activity.service.*; import com.dsh.activity.util.GDMapGeocodingUtil; import com.dsh.activity.util.ResultUtil; import com.dsh.activity.util.TokenUtil; @@ -47,7 +41,9 @@ import io.swagger.annotations.ApiOperation; import io.swagger.models.auth.In; import org.checkerframework.checker.units.qual.A; +import org.springframework.beans.BeanUtils; import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.util.StringUtils; import org.springframework.web.bind.annotation.*; import javax.annotation.Resource; @@ -67,6 +63,8 @@ @Autowired private ICouponService couponService; + @Autowired + private VipDetailService vipDetailService; @Autowired private TokenUtil tokenUtil; @@ -106,6 +104,40 @@ + @PostMapping("/base/coupon/vipDetail") + @ResponseBody + List<VipDetailVO> vipDetail(@RequestBody VipDetailDto vipDetailDto){ + List<VipDetailVO> vipDetailVOS = new ArrayList<>(); + List<VipDetail> list = vipDetailService.lambdaQuery() + .in(!vipDetailDto.getVipIds().isEmpty(), VipDetail::getVipId, vipDetailDto.getVipIds()) + .in(!vipDetailDto.getUserIds().isEmpty(), VipDetail::getAppUserId, vipDetailDto.getUserIds()) + .in(!vipDetailDto.getStoreIds().isEmpty(), VipDetail::getUseStoreId, vipDetailDto.getStoreIds()) + .ge(StringUtils.hasLength(vipDetailDto.getStartTime()), VipDetail::getInsertTime, vipDetailDto.getStartTime()) + .le(StringUtils.hasLength(vipDetailDto.getEndTime()), VipDetail::getInsertTime, vipDetailDto.getEndTime()) + .ge(StringUtils.hasLength(vipDetailDto.getUseStartTime()), VipDetail::getUseTime, vipDetailDto.getUseStartTime()) + .le(StringUtils.hasLength(vipDetailDto.getUseEndTime()), VipDetail::getUseTime, vipDetailDto.getUseEndTime()) + .eq(vipDetailDto.getOperatorId() != null, VipDetail::getOperatorId, vipDetailDto.getOperatorId()) + .eq(vipDetailDto.getType() != null, VipDetail::getType, vipDetailDto.getType()) + .eq(vipDetailDto.getStatus() != null, VipDetail::getStatus, vipDetailDto.getStatus()).list(); + + // 使用 Stream + 手动拷贝提升性能和可读性(或使用 MapStruct) + vipDetailVOS = list.stream().map(vipDetail -> { + VipDetailVO vo = new VipDetailVO(); + BeanUtils.copyProperties(vo, vipDetail); // 注意参数顺序是否正确 + return vo; + }).collect(Collectors.toList()); + List<Coupon> coupons = couponService.list(); + for (VipDetailVO vipDetailVO : vipDetailVOS) { + if (vipDetailVO.getType()==1){ + Coupon coupon = coupons.stream().filter(coupon1 -> coupon1.getId().equals(vipDetailVO.getCouponId())).findFirst().orElse(null); + if (coupon!=null){ + vipDetailVO.setTicketName(coupon.getName()); + vipDetailVO.setGoodsName(coupon.getName()); + } + } + } + return vipDetailVOS; + } /** @@ -667,6 +699,9 @@ stringObjectHashMap.put("experienceName", dataVo.getExperience()); coupon.setContent(gson.toJson(stringObjectHashMap)); break; + case 4: + coupon.setGoodsId(dataVo.getGoodsId()); + break; default: break; } -- Gitblit v1.7.1