From 188b7916433efa3d8a686d899d0a926b696623cd Mon Sep 17 00:00:00 2001 From: 无关风月 <443237572@qq.com> Date: 星期五, 09 八月 2024 09:36:12 +0800 Subject: [PATCH] 优惠券管理代码提交 --- ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/mapper/TAppCouponMapper.java | 3 ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/service/impl/TAppCouponServiceImpl.java | 64 +++++++++++++++++++++ ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/vo/ExchangeRecordVO.java | 19 +++++- ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/controller/TExchangeOrderController.java | 46 +++++++++++++++ ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/query/ExchangeRecordGoodsQuery.java | 6 +- ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/model/TAppCoupon.java | 4 + ruoyi-service/ruoyi-account/src/main/resources/mapper/account/TAppCouponMapper.xml | 34 +++++++++++ 7 files changed, 167 insertions(+), 9 deletions(-) diff --git a/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/model/TAppCoupon.java b/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/model/TAppCoupon.java index 882c0a5..0f6d8d1 100644 --- a/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/model/TAppCoupon.java +++ b/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/model/TAppCoupon.java @@ -73,7 +73,9 @@ @ApiModelProperty(value = "状态(1=未使用,2=已使用)") @TableField("status") private Integer status; - + @ApiModelProperty(value = "订单id 后台发放的优惠券没有订单id") + @TableField("orderId") + private Long orderId; diff --git a/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/query/ExchangeRecordGoodsQuery.java b/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/query/ExchangeRecordGoodsQuery.java index 573f3a5..894791d 100644 --- a/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/query/ExchangeRecordGoodsQuery.java +++ b/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/query/ExchangeRecordGoodsQuery.java @@ -8,10 +8,10 @@ @Data @ApiModel("管理后台 优惠券兑换记录") public class ExchangeRecordGoodsQuery extends BasePage { - @ApiModelProperty(value = "用户名称") - private String name; + @ApiModelProperty(value = "用户手机号") + private String phone; @ApiModelProperty(value = "状态1未使用 2已使用 3已过期 4已取消") - private Integer state; + private Integer status; @ApiModelProperty(value = "优惠券id",required = true) private Integer couponId; } diff --git a/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/vo/ExchangeRecordVO.java b/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/vo/ExchangeRecordVO.java index 9519eee..43c0f6d 100644 --- a/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/vo/ExchangeRecordVO.java +++ b/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/vo/ExchangeRecordVO.java @@ -5,21 +5,32 @@ import io.swagger.annotations.ApiModelProperty; import lombok.Data; +import java.time.LocalDateTime; + @Data @ApiModel("管理后台 优惠券兑换记录列表返回VO") public class ExchangeRecordVO { @ApiModelProperty(value = "获得时间") - private String name; + private String createTime; @ApiModelProperty(value = "获得用户") - private String state; + private String phone; @ApiModelProperty(value = "优惠金额") private String discountAmount; @ApiModelProperty(value = "使用门槛") private String meetTheConditions; - @ApiModelProperty(value = "使用状态 1未使用 2已使用") + @ApiModelProperty(value = "使用状态 1未使用 2已使用 3已过期 4已取消") private Integer status; @ApiModelProperty(value = "失效时间") - private String endTime; + private String endTime1; + @ApiModelProperty(value = "失效时间 前端忽略") + private LocalDateTime endTime; @ApiModelProperty(value = "关联订单") private String orderId; + @ApiModelProperty(value = " 前端忽略 获取方式 1=积分兑换 2现金购买") + private Integer waysToObtain; + @ApiModelProperty(value = " 是否删除0否1是") + private Integer delFlag; + @ApiModelProperty(value = "三方支付流水号 前端忽略") + private String serialNumber; + } diff --git a/ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/mapper/TAppCouponMapper.java b/ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/mapper/TAppCouponMapper.java index e2d3e98..9bbf837 100644 --- a/ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/mapper/TAppCouponMapper.java +++ b/ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/mapper/TAppCouponMapper.java @@ -5,6 +5,7 @@ import com.ruoyi.account.api.query.ExchangeRecordGoodsQuery; import com.ruoyi.account.api.vo.ExchangeRecordVO; import com.ruoyi.common.core.web.page.PageInfo; +import org.apache.ibatis.annotations.Param; import java.util.List; @@ -18,5 +19,5 @@ */ public interface TAppCouponMapper extends BaseMapper<TAppCoupon> { - List<ExchangeRecordVO> pageList(PageInfo<ExchangeRecordVO> pageInfo, ExchangeRecordGoodsQuery dto); + List<ExchangeRecordVO> pageList(@Param("pageInfo")PageInfo<ExchangeRecordVO> pageInfo,@Param("req") ExchangeRecordGoodsQuery dto); } diff --git a/ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/service/impl/TAppCouponServiceImpl.java b/ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/service/impl/TAppCouponServiceImpl.java index f626664..6bc6d16 100644 --- a/ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/service/impl/TAppCouponServiceImpl.java +++ b/ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/service/impl/TAppCouponServiceImpl.java @@ -6,11 +6,14 @@ import com.ruoyi.account.api.vo.ExchangeRecordVO; import com.ruoyi.account.mapper.TAppCouponMapper; import com.ruoyi.account.service.TAppCouponService; +import com.ruoyi.common.core.utils.DateUtils; import com.ruoyi.common.core.web.page.PageInfo; import com.ruoyi.other.api.domain.TCoupon; import org.springframework.stereotype.Service; import org.springframework.util.StringUtils; +import java.text.SimpleDateFormat; +import java.util.Date; import java.util.List; /** @@ -26,8 +29,69 @@ @Override public PageInfo<ExchangeRecordVO> pagelist(ExchangeRecordGoodsQuery dto) { + SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); PageInfo<ExchangeRecordVO> pageInfo = new PageInfo<>(dto.getPageCurr(),dto.getPageSize()); List<ExchangeRecordVO> list = this.baseMapper.pageList(pageInfo,dto); + // 现金优惠券 + StringBuilder stringBuilder = new StringBuilder(); + // 积分优惠券 + StringBuilder stringBuilder1 = new StringBuilder(); + + for (ExchangeRecordVO exchangeRecordVO : list) { + switch (exchangeRecordVO.getWaysToObtain()){ + case 1: + if (exchangeRecordVO.getSerialNumber()!=null){ + stringBuilder.append(exchangeRecordVO.getSerialNumber()).append(","); + }else{ + stringBuilder.append("0").append(","); + } + break; + case 2: + if (exchangeRecordVO.getSerialNumber()!=null){ + stringBuilder1.append(exchangeRecordVO.getSerialNumber()).append(","); + }else{ + stringBuilder1.append("0").append(","); + } + break; + } + + Date date = DateUtils.toDate(exchangeRecordVO.getEndTime()); + exchangeRecordVO.setEndTime1(format.format(date)); + if (exchangeRecordVO.getStatus()==1){ + if (exchangeRecordVO.getDelFlag() == 1){ + // 删除了 就是已取消状态 + exchangeRecordVO.setStatus(4); + }else{ + // 未删除 判断endTime是否过期 + // 设置了过期时间 + if (exchangeRecordVO.getEndTime().isBefore(java.time.LocalDateTime.now())){ + exchangeRecordVO.setStatus(3); + }else{ + // 没过期 + exchangeRecordVO.setStatus(1); + } + } + } + if (exchangeRecordVO.getStatus()==2){ + if (exchangeRecordVO.getDelFlag() == 1){ + // 删除了 就是已取消状态 + exchangeRecordVO.setStatus(4); + }else{ + exchangeRecordVO.setStatus(2); + } + } + // 根据购买方式 查询对应订单号 + } + + // 去除最后一个字符 + if (StringUtils.hasText(stringBuilder.toString())){ + String string = stringBuilder.deleteCharAt(stringBuilder.length() - 1).toString(); + // 远程调用 查询关联的现金优惠券订单编号 + } + if (StringUtils.hasText(stringBuilder.toString())){ + String string = stringBuilder.deleteCharAt(stringBuilder.length() - 1).toString(); + // 远程调用 查询关联的积分兑换优惠券订单编号 + } pageInfo.setRecords(list); return pageInfo; } diff --git a/ruoyi-service/ruoyi-account/src/main/resources/mapper/account/TAppCouponMapper.xml b/ruoyi-service/ruoyi-account/src/main/resources/mapper/account/TAppCouponMapper.xml index da0679a..7b8852a 100644 --- a/ruoyi-service/ruoyi-account/src/main/resources/mapper/account/TAppCouponMapper.xml +++ b/ruoyi-service/ruoyi-account/src/main/resources/mapper/account/TAppCouponMapper.xml @@ -23,5 +23,39 @@ <sql id="Base_Column_List"> id, app_user_id, coupon_id, end_time, ways_to_obtain, redeem_points, payment_amount, payment_type, serial_number, payment_time, status, create_time, del_flag </sql> + <select id="pageList" resultType="com.ruoyi.account.api.vo.ExchangeRecordVO"> + select t1.id,t1.app_user_id as appUserId, t1.coupon_id as couponId, + t1.end_time as endTime, t1.ways_to_obtain as waysToObtain, + t1.redeem_points as redeemPoints, + t1.payment_amount as paymentAmount, + t1.payment_type as paymentType, + t1.serial_number as serialNumber, + t1.payment_time as paymentTime, + t1.status, + t1.create_time AS createTime, + t1.del_flag AS delFlag, + t2.phone + from t_app_coupon t1 + left join t_app_user t2 on t1.app_user_id = t2.id + <where> + and t1.coupon_id = #{req.couponId} + <if test="req.phone != null and req.phone != ''"> + AND t2.phone LIKE concat('%',#{req.phone}, '%') + </if> + <if test="req.status != null and req.status = 1"> + AND t1.status =1 and t1.endTime >= now() + </if> + <if test="req.status != null and req.status = 2"> + AND t1.status =2 + </if> + <if test="req.status != null and req.status = 3"> + AND t1.status =1 and t1.endTime <= now() and t1.del_flag = 0 + </if> + <if test="req.status != null and req.status = 4"> + AND t1.del_flag = 0 + </if> + </where> + ORDER BY create_time DESC + </select> </mapper> diff --git a/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/controller/TExchangeOrderController.java b/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/controller/TExchangeOrderController.java index 1c24499..5b79243 100644 --- a/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/controller/TExchangeOrderController.java +++ b/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/controller/TExchangeOrderController.java @@ -15,6 +15,7 @@ import org.springframework.web.bind.annotation.RestController; import java.util.ArrayList; +import java.util.Arrays; import java.util.List; /** @@ -67,5 +68,50 @@ } return R.ok(res); } + /** + * 管理后台 根据t_app_coupon流水号查询现金优惠券的订单编号 + * @param goodsIds 订单号-商品类型 + * @return + */ + @PostMapping("/getCodeBySerialNumber") + public R<List<String>> getCodeBySerialNumber(String goodsIds){ + String[] split = goodsIds.split("-"); + List<String> strings = new ArrayList<>(); + for (String s : split) { + TShoppingOrder one = tShoppingOrderService.getOne(new QueryWrapper<TShoppingOrder>() + .eq("order_type", 2) + .eq("serial_number", s)); + if (one != null){ + strings.add(one.getCode()); + }else{ + strings.add(""); + } + } + + return R.ok(strings); + } + /** + * 管理后台 根据t_app_coupon流水号查询积分兑换优惠券的订单编号 + * @param goodsIds 订单号-商品类型 + * @return + */ + @PostMapping("/getCodeBySerialNumberIntegral") + public R<List<String>> getCodeBySerialNumberIntegral(String goodsIds){ + String[] split = goodsIds.split("-"); + List<String> strings = new ArrayList<>(); + for (String s : split) { + TExchangeOrder one = exchangeOrderService.getOne(new QueryWrapper<TExchangeOrder + >() + .eq("order_type", 2) + .eq("serial_number", s)); + if (one != null){ + strings.add(one.getCode()); + }else{ + strings.add(""); + } + } + + return R.ok(strings); + } } -- Gitblit v1.7.1