From 8d2faa25d8d6139eb08b34de3665774e54c4c30c Mon Sep 17 00:00:00 2001
From: 陶杰 <1378534974@qq.com>
Date: 星期四, 29 八月 2024 15:51:54 +0800
Subject: [PATCH] 1.优惠券相关代码提交
---
src/main/java/com/mzl/flower/entity/coupon/CouponRecordDO.java | 107 +
src/main/java/com/mzl/flower/entity/coupon/CouponTemplateDO.java | 142 +
src/main/java/com/mzl/flower/dto/request/coupon/CreateCouponTemplatePointDTO.java | 90 +
src/main/java/com/mzl/flower/dto/response/coupon/CouponRecordResultVO.java | 129 +
src/main/java/com/mzl/flower/dto/request/coupon/QueryCouponStatisticsDTO.java | 17
src/main/java/com/mzl/flower/web/v2/coupon/CouponTemplateVipController.java | 142 +
src/main/java/com/mzl/flower/service/coupon/CouponTemplateService2.java | 66
src/main/java/com/mzl/flower/service/impl/coupon/CouponRecordServiceImpl.java | 288 +++
src/main/java/com/mzl/flower/web/v2/coupon/CouponTemplateActivyController.java | 202 ++
src/main/java/com/mzl/flower/web/v2/coupon/CouponTemplateCustomerController.java | 15
src/main/java/com/mzl/flower/enums/CouponUsageTypeEnum.java | 23
src/main/java/com/mzl/flower/web/v2/coupon/CouponRecordController.java | 114 +
src/main/java/com/mzl/flower/dto/request/coupon/CreateCouponTemplateVipDTO.java | 64
src/main/java/com/mzl/flower/enums/VipGradeEnum.java | 24
src/main/java/com/mzl/flower/utils/ConverterUtil.java | 73
src/main/java/com/mzl/flower/web/v2/coupon/CouponTemplatePointController.java | 215 ++
src/main/java/com/mzl/flower/enums/TrueOrFalseEnum.java | 17
src/main/java/com/mzl/flower/mapper/coupon/CouponTemplateMapper.java | 16
src/main/java/com/mzl/flower/dto/request/coupon/QueryCouponVipDTO.java | 21
src/main/java/com/mzl/flower/enums/CouponUsageTimeTypeEnum.java | 23
src/main/java/com/mzl/flower/entity/system/User.java | 4
src/main/java/com/mzl/flower/dto/response/coupon/CouponTemplateActivyVO.java | 134 +
src/main/java/com/mzl/flower/dto/response/coupon/CouponTemplateUserVO.java | 99 +
src/main/java/com/mzl/flower/mapper/coupon/CouponRecordMapperCustom.java | 32
src/main/java/com/mzl/flower/web/v2/coupon/CouponTemplateUserController.java | 186 ++
src/main/java/com/mzl/flower/service/impl/coupon/CouponTemplateCustomerServiceImpl.java | 36
src/main/java/com/mzl/flower/service/impl/coupon/CouponTemplateServiceImpl2.java | 311 ++++
src/main/java/com/mzl/flower/dto/request/coupon/CreateCouponTemplateBO.java | 149 +
src/main/java/com/mzl/flower/dto/response/coupon/CouponTemplateVO.java | 232 +++
src/main/java/com/mzl/flower/dto/request/coupon/BatchCouponTemplateDTO.java | 23
src/main/java/com/mzl/flower/enums/CouponCategoryEnum.java | 22
src/main/java/com/mzl/flower/dto/request/coupon/CreateCouponRecordDTO.java | 74
src/main/resources/mapper/coupon/CouponTemplateCustomerMapper.xml | 12
src/main/java/com/mzl/flower/service/coupon/CouponTemplateCustomerService.java | 31
src/main/java/com/mzl/flower/entity/coupon/CouponTemplateCustomerDO.java | 35
src/main/java/com/mzl/flower/mapper/coupon/CouponTemplateCustomerMapper.java | 16
src/main/java/com/mzl/flower/web/v2/coupon/CouponTemplateController.java | 158 ++
src/main/java/com/mzl/flower/dto/response/coupon/CouponTemplateVipVO.java | 100 +
src/main/java/com/mzl/flower/dto/request/coupon/QueryCouponStatisticsBO.java | 18
src/main/java/com/mzl/flower/dto/request/coupon/CreateCouponTemplateDTO.java | 142 +
src/main/java/com/mzl/flower/enums/CouponUsedStatusEnum.java | 23
src/main/resources/mapper/coupon/CouponTemplateMapperCustom.xml | 101 +
src/main/java/com/mzl/flower/service/coupon/CouponRecordService.java | 52
src/main/java/com/mzl/flower/enums/CouponGetUserTypeEnum.java | 22
src/main/java/com/mzl/flower/enums/CouponStatusEnum.java | 22
src/main/resources/mapper/coupon/CouponRecordMapper.xml | 32
src/main/java/com/mzl/flower/dto/request/coupon/CreateCouponTemplateActivyDTO.java | 142 +
src/main/java/com/mzl/flower/dto/request/coupon/QueryCouponDTO.java | 29
src/main/java/com/mzl/flower/dto/request/coupon/CreateCouponTemplateUserDTO.java | 77 +
src/main/java/com/mzl/flower/dto/request/coupon/QueryCouponRecordDTO.java | 38
src/main/java/com/mzl/flower/dto/response/coupon/CouponTemplatePointVO.java | 90 +
src/main/java/com/mzl/flower/dto/response/coupon/CouponRecordVO.java | 41
src/main/resources/mapper/coupon/CouponTemplateMapper.xml | 40
src/main/java/com/mzl/flower/mapper/coupon/CouponRecordMapper.java | 16
src/main/java/com/mzl/flower/mapper/coupon/CouponTemplateMapperCustom.java | 45
src/main/resources/application.yml | 2
src/main/java/com/mzl/flower/enums/CouponTypeEnum.java | 23
src/main/resources/mapper/coupon/CouponRecordMapperCustom.xml | 101 +
58 files changed, 4,497 insertions(+), 1 deletions(-)
diff --git a/src/main/java/com/mzl/flower/dto/request/coupon/BatchCouponTemplateDTO.java b/src/main/java/com/mzl/flower/dto/request/coupon/BatchCouponTemplateDTO.java
new file mode 100644
index 0000000..019aadd
--- /dev/null
+++ b/src/main/java/com/mzl/flower/dto/request/coupon/BatchCouponTemplateDTO.java
@@ -0,0 +1,23 @@
+package com.mzl.flower.dto.request.coupon;
+
+
+import io.swagger.annotations.ApiModel;
+import io.swagger.annotations.ApiModelProperty;
+import lombok.Data;
+
+import javax.validation.constraints.NotNull;
+import java.util.List;
+
+@ApiModel("优惠券批量操作")
+@Data
+public class BatchCouponTemplateDTO {
+
+
+ @ApiModelProperty(value = "ID列表不能为空")
+ @NotNull(message = "ID列表不能为空")
+ private List<String> idList;
+
+ @ApiModelProperty(hidden = true)
+ private String updateBy;
+
+}
diff --git a/src/main/java/com/mzl/flower/dto/request/coupon/CreateCouponRecordDTO.java b/src/main/java/com/mzl/flower/dto/request/coupon/CreateCouponRecordDTO.java
new file mode 100644
index 0000000..4386cad
--- /dev/null
+++ b/src/main/java/com/mzl/flower/dto/request/coupon/CreateCouponRecordDTO.java
@@ -0,0 +1,74 @@
+package com.mzl.flower.dto.request.coupon;
+
+import io.swagger.annotations.ApiModelProperty;
+import lombok.Data;
+
+import javax.validation.constraints.NotEmpty;
+
+@Data
+public class CreateCouponRecordDTO {
+
+ @ApiModelProperty(value = "id")
+ private String id;
+
+ /**
+ * 优惠券ID
+ */
+ @ApiModelProperty(value = "优惠券ID")
+ @NotEmpty(message = "优惠券ID不能为空")
+ private String couponId;
+
+ /**
+ * 用户id
+ */
+
+ @ApiModelProperty(value = "用户id")
+// @NotEmpty(message = "用户id不能为空")
+ private String userId;
+
+ /**
+ * 商户ID
+ */
+ @ApiModelProperty(value = "商户ID")
+ @NotEmpty(message = "商户ID不能为空")
+ private String customerId;
+
+ /**
+ * 状态(coupon_record_status)未使用、已使用、已过期
+ */
+// @ApiModelProperty(value = "状态")
+// private String status;
+
+ /**
+ * 有效开始时间
+ */
+// @ApiModelProperty(value = "有效开始时间")
+// @JsonFormat(pattern="yyyy-MM-dd HH:mm:ss" ,timezone="GMT+8")
+// @DateTimeFormat
+// @NotNull(message = "有效开始时间不能为空")
+// private LocalDateTime effectiveStart;
+
+ /**
+ * 有效结束时间
+ */
+// @ApiModelProperty(value = "有效结束时间")
+// @JsonFormat(pattern="yyyy-MM-dd HH:mm:ss" ,timezone="GMT+8")
+// @DateTimeFormat
+// @NotNull(message = "有效结束时间不能为空")
+// private LocalDateTime effectiveEnd;
+
+ /**
+ * 使用订单
+ */
+// @ApiModelProperty(value = "订单号")
+// private String orderId;
+
+ /**
+ * 使用时间
+ */
+// @ApiModelProperty(value = "使用时间")
+// @JsonFormat(pattern="yyyy-MM-dd HH:mm:ss" ,timezone="GMT+8")
+// @DateTimeFormat
+// private LocalDateTime usedTime;
+
+}
diff --git a/src/main/java/com/mzl/flower/dto/request/coupon/CreateCouponTemplateActivyDTO.java b/src/main/java/com/mzl/flower/dto/request/coupon/CreateCouponTemplateActivyDTO.java
new file mode 100644
index 0000000..316ead0
--- /dev/null
+++ b/src/main/java/com/mzl/flower/dto/request/coupon/CreateCouponTemplateActivyDTO.java
@@ -0,0 +1,142 @@
+package com.mzl.flower.dto.request.coupon;
+
+
+import com.fasterxml.jackson.annotation.JsonFormat;
+import io.swagger.annotations.ApiModelProperty;
+import lombok.Data;
+import org.springframework.format.annotation.DateTimeFormat;
+
+import javax.validation.constraints.Min;
+import javax.validation.constraints.NotEmpty;
+import javax.validation.constraints.NotNull;
+import java.math.BigDecimal;
+import java.time.LocalDateTime;
+
+@Data
+public class CreateCouponTemplateActivyDTO {
+
+ @ApiModelProperty(value = "id")
+ private String id;
+
+ /**
+ * 优惠券名称
+ */
+ @ApiModelProperty(value = "couponName")
+ @NotEmpty(message = "优惠券名称不能为空")
+ private String couponName;
+
+ /**
+ * 优惠券类型(COUPON_TYPE)满减和无门槛
+ */
+ @ApiModelProperty(value = "优惠券类型(COUPON_TYPE)")
+ @NotEmpty(message = "优惠券类型不能为空(COUPON_TYPE)")
+ private String couponDiscountType;
+
+ /**
+ * 领取渠道(COUPON_GET_TYPE)首页弹窗、活动入口、领券中心
+ */
+ @ApiModelProperty(value = "领取渠道(COUPON_GET_TYPE)")
+ @NotEmpty(message = "领取渠道不能为空(COUPON_GET_TYPE)")
+ private String getType;
+
+
+ /**
+ * 优惠券描述(使用规则)
+ */
+ @ApiModelProperty(value = "使用规则")
+ @NotEmpty(message = "使用规则不能为空")
+ private String couponDescription;
+
+
+ /**
+ * 领取开始时间
+ */
+ @ApiModelProperty(value = "领取开始时间")
+ @JsonFormat(pattern="yyyy-MM-dd HH:mm:ss" ,timezone="GMT+8")
+ @DateTimeFormat
+ @NotNull(message = "领取开始时间不能为空")
+ private LocalDateTime getStartDate;
+
+ /**
+ * 领取结束时间
+ */
+ @ApiModelProperty(value = "领取结束时间")
+ @JsonFormat(pattern="yyyy-MM-dd HH:mm:ss" ,timezone="GMT+8")
+ @DateTimeFormat
+ @NotNull(message = "领取结束时间不能为空")
+ private LocalDateTime getEndDate;
+
+
+ /**
+ * 使用时间类型(COUPON_USAGE_TYPE)与领取时间一致、固定时间、领取后有效
+ */
+ @ApiModelProperty(value = "使用时间类型(COUPON_USAGE_TYPE)")
+ @NotEmpty(message = "使用时间类型不能为空(COUPON_USAGE_TYPE)")
+ private String usageType;
+
+
+ /**
+ * 领取后有效类型(COUPON_usage_time_type)天、小时、分钟
+ */
+ @ApiModelProperty(value = "领取后有效类型 (COUPON_USAGE_TIME_TYPE)")
+ private String usageTimeType;
+
+ /**
+ * 领取后有效时间整数,比如90(天,小时,分钟)
+ */
+ @ApiModelProperty(value = "领取后有效时间整数")
+ private Integer usageTimeNum;
+
+
+ /**
+ * 使用开始时间
+ */
+ @ApiModelProperty(value = "使用时间-固定时间-开始日期")
+ @JsonFormat(pattern="yyyy-MM-dd HH:mm:ss" ,timezone="GMT+8")
+ @DateTimeFormat
+ private LocalDateTime usageStartDate;
+
+ /**
+ * 使用结束时间
+ */
+ @ApiModelProperty(value = "使用时间-固定时间-结束日期")
+ @JsonFormat(pattern="yyyy-MM-dd HH:mm:ss" ,timezone="GMT+8")
+ @DateTimeFormat
+ private LocalDateTime usageEndDate;
+
+
+ /**
+ * 使用条件,最小订单金额(可选)=》使用条件
+ */
+ @ApiModelProperty(value = "使用条件,满多少钱")
+ @NotNull(message = "使用条件不能为空")
+ private BigDecimal minOrderAmount;
+
+ /**
+ * 优惠券面值 折扣值(百分比或金额)
+ */
+ @ApiModelProperty(value = "优惠券面值")
+ @NotNull(message = "优惠券面值不能为空")
+ private BigDecimal couponDiscountValue;
+
+
+
+ /**
+ * 发放数量
+ */
+ @ApiModelProperty(value = "发放数量")
+ @NotNull(message = "发放数量不能为空")
+ @Min(value = 1,message = "发放数量必须大于0")
+ private Integer couponAmount;
+
+
+ /**
+ * 每人限领
+ */
+ @ApiModelProperty(value = "每人限领")
+ @NotNull(message = "每人限领不能为空")
+ @Min(value = 1,message = "每人限领必须大于0")
+ private Integer getLimit;
+
+
+}
diff --git a/src/main/java/com/mzl/flower/dto/request/coupon/CreateCouponTemplateBO.java b/src/main/java/com/mzl/flower/dto/request/coupon/CreateCouponTemplateBO.java
new file mode 100644
index 0000000..b3df572
--- /dev/null
+++ b/src/main/java/com/mzl/flower/dto/request/coupon/CreateCouponTemplateBO.java
@@ -0,0 +1,149 @@
+package com.mzl.flower.dto.request.coupon;
+
+import io.swagger.annotations.ApiModelProperty;
+import lombok.AllArgsConstructor;
+import lombok.Data;
+import lombok.NoArgsConstructor;
+
+import javax.validation.constraints.NotEmpty;
+import javax.validation.constraints.NotNull;
+import java.math.BigDecimal;
+import java.time.LocalDateTime;
+import java.util.List;
+
+@NoArgsConstructor
+@AllArgsConstructor
+@Data
+public class CreateCouponTemplateBO {
+
+ private String id;
+
+
+ /**
+ * 优惠券种类(活动优惠券、用户优惠券、会员优惠券,积分优惠券)
+ */
+ private String category;
+ /**
+ * 优惠券代码(唯一)
+ */
+ private String couponCode;
+
+ /**
+ * 优惠券名称
+ */
+ private String couponName;
+
+ /**
+ * 优惠券描述(使用规则)
+ */
+ private String couponDescription;
+
+ /**
+ * 发放数量
+ */
+ private Integer couponAmount;
+
+ /**
+ * 优惠券类型(COUPON_TYPE)满减和无门槛
+ */
+ private String couponDiscountType;
+
+ /**
+ * 优惠券面值 折扣值(百分比或金额)
+ */
+ private BigDecimal couponDiscountValue;
+
+ /**
+ * 使用条件,最小订单金额(可选)=》使用条件
+ */
+ private BigDecimal minOrderAmount;
+
+ /**
+ * 最大折扣金额(可选,仅对百分比折扣类型适用)
+ */
+ private BigDecimal maxDiscountAmount;
+
+ /**
+ * 领取渠道(COUPON_GET_TYPE)首页弹窗、活动入口、领券中心
+ */
+ private String getType;
+
+ /**
+ * 领取用户类型(COUPON_GET_USER_TYPE)全部用户,指定用户
+ */
+ private String getUserType;
+
+ /**
+ * 领取开始时间
+ */
+ private LocalDateTime getStartDate;
+
+ /**
+ * 领取结束时间
+ */
+ private LocalDateTime getEndDate;
+
+ /**
+ * 每人限领
+ */
+ private Integer getLimit;
+
+ /**
+ * 使用时间类型(COUPON_USAGE_TIME_TYPE)与领取时间一致、固定时间、领取后有效
+ */
+ private String usageType;
+
+ /**
+ * 使用次数限制
+ */
+ private Integer usageLimit;
+
+ /**
+ * 每个用户的使用次数限制
+ */
+ private Integer usagePerUser;
+
+ /**
+ * 使用开始时间
+ */
+ private LocalDateTime usageStartDate;
+
+ /**
+ * 使用结束时间
+ */
+ private LocalDateTime usageEndDate;
+
+ /**
+ * 领取后有效类型(COUPON_usage_time_type)天、小时、分钟
+ */
+ private String usageTimeType;
+
+ /**
+ * 领取后有效时间整数,比如90(天,小时,分钟)
+ */
+ private Integer usageTimeNum;
+
+ /**
+ * 优惠券状态(COUPON_STATUS)
+ */
+ private String status;
+
+ /**
+ * 兑换积分
+ */
+ private Integer point;
+
+
+ /**
+ *
+ */
+ @ApiModelProperty(value = "会员等级")
+ @NotEmpty(message = "会员等级不能为空")
+ private String vipGrade;
+
+
+ @ApiModelProperty(value = "指定的用户列表id")
+ @NotNull(message = "指定的用户列表id不能为空")
+ private List<String> pointCostomIdList;
+
+}
diff --git a/src/main/java/com/mzl/flower/dto/request/coupon/CreateCouponTemplateDTO.java b/src/main/java/com/mzl/flower/dto/request/coupon/CreateCouponTemplateDTO.java
new file mode 100644
index 0000000..a77ac93
--- /dev/null
+++ b/src/main/java/com/mzl/flower/dto/request/coupon/CreateCouponTemplateDTO.java
@@ -0,0 +1,142 @@
+package com.mzl.flower.dto.request.coupon;
+
+
+import com.fasterxml.jackson.annotation.JsonFormat;
+import com.mzl.flower.base.BaseAutoEntity;
+import com.mzl.flower.base.BaseEntity;
+import io.swagger.annotations.ApiModelProperty;
+import lombok.Data;
+import org.springframework.format.annotation.DateTimeFormat;
+
+import javax.validation.constraints.NotEmpty;
+import javax.validation.constraints.NotNull;
+import java.math.BigDecimal;
+import java.time.LocalDateTime;
+import java.util.List;
+
+@Data
+public class CreateCouponTemplateDTO {
+
+ @ApiModelProperty(value = "id")
+ private String id;
+
+ /**
+ * 优惠券名称
+ */
+ @ApiModelProperty(value = "couponName")
+ @NotEmpty(message = "优惠券名称不能为空")
+ private String couponName;
+
+ /**
+ * 优惠券类型(COUPON_TYPE)满减和无门槛
+ */
+ @ApiModelProperty(value = "优惠券类型")
+ @NotEmpty(message = "优惠券类型不能为空")
+ private String couponDiscountType;
+
+ /**
+ * 领取渠道(COUPON_GET_TYPE)首页弹窗、活动入口、领券中心
+ */
+ @ApiModelProperty(value = "领取渠道")
+ @NotEmpty(message = "领取渠道不能为空")
+ private String getType;
+
+
+ /**
+ * 优惠券描述(使用规则)
+ */
+ @ApiModelProperty(value = "使用规则")
+ @NotEmpty(message = "使用规则不能为空")
+ private String couponDescription;
+
+
+ /**
+ * 领取开始时间
+ */
+ @ApiModelProperty(value = "领取开始时间")
+ @JsonFormat(pattern="yyyy-MM-dd HH:mm:ss" ,timezone="GMT+8")
+ @DateTimeFormat
+ @NotNull(message = "领取开始时间不能为空")
+ private LocalDateTime getStartDate;
+
+ /**
+ * 领取结束时间
+ */
+ @ApiModelProperty(value = "领取结束时间")
+ @JsonFormat(pattern="yyyy-MM-dd HH:mm:ss" ,timezone="GMT+8")
+ @DateTimeFormat
+ @NotNull(message = "领取结束时间不能为空")
+ private LocalDateTime getEndDate;
+
+
+ /**
+ * 使用时间类型(COUPON_USAGE_TIME_TYPE)与领取时间一致、固定时间、领取后有效
+ */
+ @ApiModelProperty(value = "使用时间类型")
+ @NotEmpty(message = "使用时间类型不能为空")
+ private String usageType;
+
+
+ /**
+ * 领取后有效类型(COUPON_usage_time_type)天、小时、分钟
+ */
+ @ApiModelProperty(value = "领取后有效类型 天、小时、分钟")
+ private String usageTimeType;
+
+ /**
+ * 领取后有效时间整数,比如90(天,小时,分钟)
+ */
+ @ApiModelProperty(value = "领取后有效时间整数")
+ private Integer usageTimeNum;
+
+
+ /**
+ * 使用开始时间
+ */
+ @ApiModelProperty(value = "使用时间-固定时间-开始日期")
+ @JsonFormat(pattern="yyyy-MM-dd HH:mm:ss" ,timezone="GMT+8")
+ @DateTimeFormat
+ private LocalDateTime usageStartDate;
+
+ /**
+ * 使用结束时间
+ */
+ @ApiModelProperty(value = "使用时间-固定时间-结束日期")
+ @JsonFormat(pattern="yyyy-MM-dd HH:mm:ss" ,timezone="GMT+8")
+ @DateTimeFormat
+ private LocalDateTime usageEndDate;
+
+
+ /**
+ * 使用条件,最小订单金额(可选)=》使用条件
+ */
+ @ApiModelProperty(value = "使用条件,满多少钱")
+ @NotNull(message = "使用条件不能为空")
+ private BigDecimal minOrderAmount;
+
+ /**
+ * 优惠券面值 折扣值(百分比或金额)
+ */
+ @ApiModelProperty(value = "优惠券面值")
+ @NotNull(message = "优惠券面值不能为空")
+ private BigDecimal couponDiscountValue;
+
+
+
+ /**
+ * 发放数量
+ */
+ @ApiModelProperty(value = "发放数量")
+ @NotNull(message = "发放数量不能为空")
+ private Integer couponAmount;
+
+
+ /**
+ * 每人限领
+ */
+ @ApiModelProperty(value = "每人限领")
+ @NotNull(message = "每人限领不能为空")
+ private Integer getLimit;
+
+
+}
diff --git a/src/main/java/com/mzl/flower/dto/request/coupon/CreateCouponTemplatePointDTO.java b/src/main/java/com/mzl/flower/dto/request/coupon/CreateCouponTemplatePointDTO.java
new file mode 100644
index 0000000..5e89876
--- /dev/null
+++ b/src/main/java/com/mzl/flower/dto/request/coupon/CreateCouponTemplatePointDTO.java
@@ -0,0 +1,90 @@
+package com.mzl.flower.dto.request.coupon;
+
+
+import io.swagger.annotations.ApiModelProperty;
+import lombok.Data;
+
+import javax.validation.constraints.Min;
+import javax.validation.constraints.NotEmpty;
+import javax.validation.constraints.NotNull;
+import java.math.BigDecimal;
+import java.util.List;
+
+/**
+ * 积分优惠券
+ */
+@Data
+public class CreateCouponTemplatePointDTO {
+
+ @ApiModelProperty(value = "id")
+ private String id;
+
+ /**
+ * 优惠券名称
+ */
+
+ @ApiModelProperty(value = "优惠券名称")
+ @NotEmpty(message = "优惠券名称不能为空")
+ private String couponName;
+
+
+ /**
+ * 优惠券类型(COUPON_TYPE)满减和无门槛
+ */
+ @ApiModelProperty(value = "优惠券类型")
+ @NotEmpty(message = "优惠券类型不能为空")
+ private String couponDiscountType;
+
+ /**
+ * 优惠券描述(使用规则)
+ */
+ @ApiModelProperty(value = "使用规则")
+ @NotEmpty(message = "使用规则不能为空")
+ private String couponDescription;
+
+ /**
+ * 领取后有效类型(COUPON_usage_time_type)天、小时、分钟
+ */
+ @ApiModelProperty(value = "领取后有效类型(COUPON_USAGE_TYPE)天、小时、分钟")
+ @NotEmpty(message = "领取后有效类型不能为空")
+ private String usageTimeType;
+
+ /**
+ * 领取后有效时间整数,比如90(天,小时,分钟)
+ */
+ @ApiModelProperty(value ="领取后有效时间整数,比如90(天,小时,分钟)" )
+ @NotNull(message = "领取后有效时间不能为空")
+ @Min(value = 1,message = "领取后有效时间必须大于等于1")
+ private Integer usageTimeNum;
+
+ /**
+ * 使用条件,最小订单金额(可选)=》使用条件
+ */
+ @ApiModelProperty(value = "使用条件")
+ @NotNull(message = "使用条件不能为空")
+ private BigDecimal minOrderAmount;
+
+ /**
+ * 优惠券面值 折扣值(百分比或金额)
+ */
+ @ApiModelProperty(value = "优惠券面值")
+ @NotNull(message = "优惠券面值不能为空")
+ @Min(value = 1,message = "优惠券面值大于0")
+ private BigDecimal couponDiscountValue;
+
+ /**
+ * 库存
+ */
+ @ApiModelProperty(value = "库存")
+ @NotNull(message = "库存不能为空")
+ @Min(value = 1,message = "库存数量必须大于0")
+ private Integer couponAmount;
+
+
+ @ApiModelProperty(value = "积分数量")
+ @NotNull(message = "积分数量不能为空")
+ @Min(value = 1,message = "积分数量必须大于0")
+ private Integer point;
+
+
+}
diff --git a/src/main/java/com/mzl/flower/dto/request/coupon/CreateCouponTemplateUserDTO.java b/src/main/java/com/mzl/flower/dto/request/coupon/CreateCouponTemplateUserDTO.java
new file mode 100644
index 0000000..01a29b8
--- /dev/null
+++ b/src/main/java/com/mzl/flower/dto/request/coupon/CreateCouponTemplateUserDTO.java
@@ -0,0 +1,77 @@
+package com.mzl.flower.dto.request.coupon;
+
+
+import io.swagger.annotations.ApiModelProperty;
+import lombok.Data;
+
+import javax.validation.constraints.Min;
+import javax.validation.constraints.NotEmpty;
+import javax.validation.constraints.NotNull;
+import java.math.BigDecimal;
+import java.util.List;
+
+@Data
+public class CreateCouponTemplateUserDTO {
+
+ @ApiModelProperty(value = "id")
+ private String id;
+
+ /**
+ * 优惠券名称
+ */
+
+ @ApiModelProperty(value = "优惠券名称")
+ @NotEmpty(message = "优惠券名称不能为空")
+ private String couponName;
+
+
+ /**
+ * 优惠券类型(COUPON_TYPE)满减和无门槛
+ */
+ @ApiModelProperty(value = "优惠券类型")
+ @NotEmpty(message = "优惠券类型不能为空")
+ private String couponDiscountType;
+
+ /**
+ * 优惠券描述(使用规则)
+ */
+ @ApiModelProperty(value = "使用规则")
+ @NotEmpty(message = "使用规则不能为空")
+ private String couponDescription;
+
+ /**
+ * 领取后有效类型(COUPON_usage_time_type)天、小时、分钟
+ */
+ @ApiModelProperty(value = "领取后有效类型(COUPON_USAGE_TYPE)天、小时、分钟")
+ @NotEmpty(message = "领取后有效类型不能为空")
+ private String usageTimeType;
+
+ /**
+ * 领取后有效时间整数,比如90(天,小时,分钟)
+ */
+ @ApiModelProperty(value ="领取后有效时间整数,比如90(天,小时,分钟)" )
+ @NotNull(message = "领取后有效时间不能为空")
+ @Min(value = 1,message = "领取后有效时间必须大于0")
+ private Integer usageTimeNum;
+
+ /**
+ * 使用条件,最小订单金额(可选)=》使用条件
+ */
+ @ApiModelProperty(value = "使用条件")
+ @NotNull(message = "使用条件不能为空")
+ private BigDecimal minOrderAmount;
+
+ /**
+ * 优惠券面值 折扣值(百分比或金额)
+ */
+ @ApiModelProperty(value = "优惠券面值")
+ @NotNull(message = "优惠券面值不能为空")
+ @Min(value = 1,message = "优惠券面值大于0")
+ private BigDecimal couponDiscountValue;
+
+
+ @ApiModelProperty(value = "指定的用户列表id")
+ @NotNull(message = "指定的用户列表id不能为空")
+ private List<String> pointCostomIdList;
+
+}
diff --git a/src/main/java/com/mzl/flower/dto/request/coupon/CreateCouponTemplateVipDTO.java b/src/main/java/com/mzl/flower/dto/request/coupon/CreateCouponTemplateVipDTO.java
new file mode 100644
index 0000000..6db8384
--- /dev/null
+++ b/src/main/java/com/mzl/flower/dto/request/coupon/CreateCouponTemplateVipDTO.java
@@ -0,0 +1,64 @@
+package com.mzl.flower.dto.request.coupon;
+
+
+import com.fasterxml.jackson.annotation.JsonFormat;
+import io.swagger.annotations.ApiModelProperty;
+import lombok.Data;
+import org.springframework.format.annotation.DateTimeFormat;
+
+import javax.validation.constraints.NotEmpty;
+import javax.validation.constraints.NotNull;
+import java.math.BigDecimal;
+import java.time.LocalDateTime;
+
+@Data
+public class CreateCouponTemplateVipDTO {
+
+ @ApiModelProperty(value = "id")
+ private String id;
+
+ /**
+ * 优惠券名称
+ */
+
+ @ApiModelProperty(value = "优惠券名称")
+ @NotEmpty(message = "优惠券名称不能为空")
+ private String couponName;
+
+ /**
+ * 优惠券描述(使用规则)
+ */
+ @ApiModelProperty(value = "使用规则")
+ @NotEmpty(message = "使用规则不能为空")
+ private String couponDescription;
+
+ /**
+ * 优惠券类型(COUPON_TYPE)满减和无门槛
+ */
+ @ApiModelProperty(value = "优惠券类型")
+ @NotEmpty(message = "优惠券类型不能为空")
+ private String couponDiscountType;
+
+ /**
+ * 优惠券面值 折扣值(百分比或金额)
+ */
+ @ApiModelProperty(value = "优惠券面值")
+ @NotNull(message = "优惠券面值不能为空")
+ private BigDecimal couponDiscountValue;
+
+ /**
+ * 使用条件,最小订单金额(可选)=》使用条件
+ */
+ @ApiModelProperty(value = "使用条件")
+ @NotNull(message = "使用条件不能为空")
+ private BigDecimal minOrderAmount;
+
+
+ /**
+ * 会员等级
+ */
+ @ApiModelProperty(value = "会员等级")
+ @NotEmpty(message = "会员等级不能为空")
+ private String vipGrade;
+
+}
diff --git a/src/main/java/com/mzl/flower/dto/request/coupon/QueryCouponDTO.java b/src/main/java/com/mzl/flower/dto/request/coupon/QueryCouponDTO.java
new file mode 100644
index 0000000..105e331
--- /dev/null
+++ b/src/main/java/com/mzl/flower/dto/request/coupon/QueryCouponDTO.java
@@ -0,0 +1,29 @@
+package com.mzl.flower.dto.request.coupon;
+
+import io.swagger.annotations.ApiModelProperty;
+import lombok.Data;
+
+
+@Data
+public class QueryCouponDTO extends QueryCouponVipDTO {
+
+
+ @ApiModelProperty(value = "id")
+ private String id;
+
+ @ApiModelProperty(value = "优惠券名称")
+ private String name;
+
+ @ApiModelProperty(value = "优惠券类型")
+ private String couponDiscountType;
+
+ @ApiModelProperty(value = "领取渠道")
+ private String getType;
+
+ @ApiModelProperty(value = "领取用户类型")
+ private String getUserType;
+
+ @ApiModelProperty(value = "优惠券种类(活动优惠券、用户优惠券、会员优惠券,积分优惠券)")
+ private String category;
+
+}
diff --git a/src/main/java/com/mzl/flower/dto/request/coupon/QueryCouponRecordDTO.java b/src/main/java/com/mzl/flower/dto/request/coupon/QueryCouponRecordDTO.java
new file mode 100644
index 0000000..817f790
--- /dev/null
+++ b/src/main/java/com/mzl/flower/dto/request/coupon/QueryCouponRecordDTO.java
@@ -0,0 +1,38 @@
+package com.mzl.flower.dto.request.coupon;
+
+import io.swagger.annotations.ApiModelProperty;
+import lombok.Data;
+
+
+@Data
+public class QueryCouponRecordDTO {
+
+
+ @ApiModelProperty(value = "id")
+ private String id;
+
+ @ApiModelProperty(value = "优惠券名称")
+ private String name;
+
+ @ApiModelProperty(value = "优惠券类型")
+ private String couponDiscountType;
+
+ @ApiModelProperty(value = "订单号")
+ private String orderNo;
+
+ @ApiModelProperty(value = "用户id/店铺名称")
+ private String keyword;
+
+ @ApiModelProperty(value = "联系方式")
+ private String tel;
+
+ @ApiModelProperty(value = "领取渠道")
+ private String getType;
+
+ @ApiModelProperty(value = "状态")
+ private String status;
+
+ @ApiModelProperty(value = "领取用户类型-全部用户,指定用户")
+ private String getUserType;
+
+}
diff --git a/src/main/java/com/mzl/flower/dto/request/coupon/QueryCouponStatisticsBO.java b/src/main/java/com/mzl/flower/dto/request/coupon/QueryCouponStatisticsBO.java
new file mode 100644
index 0000000..0454617
--- /dev/null
+++ b/src/main/java/com/mzl/flower/dto/request/coupon/QueryCouponStatisticsBO.java
@@ -0,0 +1,18 @@
+package com.mzl.flower.dto.request.coupon;
+
+import lombok.Data;
+
+
+@Data
+public class QueryCouponStatisticsBO extends QueryCouponStatisticsDTO{
+
+// @ApiModelProperty(value = "优惠券名称")
+// private String name;
+ /**
+ * 优惠券总数
+ */
+ private String category;
+
+
+
+}
diff --git a/src/main/java/com/mzl/flower/dto/request/coupon/QueryCouponStatisticsDTO.java b/src/main/java/com/mzl/flower/dto/request/coupon/QueryCouponStatisticsDTO.java
new file mode 100644
index 0000000..548c919
--- /dev/null
+++ b/src/main/java/com/mzl/flower/dto/request/coupon/QueryCouponStatisticsDTO.java
@@ -0,0 +1,17 @@
+package com.mzl.flower.dto.request.coupon;
+
+import io.swagger.annotations.ApiModelProperty;
+import lombok.Data;
+
+
+@Data
+public class QueryCouponStatisticsDTO {
+
+// @ApiModelProperty(value = "优惠券名称")
+// private String name;
+
+ @ApiModelProperty(hidden = true)
+ private String category;
+
+
+}
diff --git a/src/main/java/com/mzl/flower/dto/request/coupon/QueryCouponVipDTO.java b/src/main/java/com/mzl/flower/dto/request/coupon/QueryCouponVipDTO.java
new file mode 100644
index 0000000..9abcb4c
--- /dev/null
+++ b/src/main/java/com/mzl/flower/dto/request/coupon/QueryCouponVipDTO.java
@@ -0,0 +1,21 @@
+package com.mzl.flower.dto.request.coupon;
+
+import io.swagger.annotations.ApiModelProperty;
+import lombok.Data;
+
+
+@Data
+public class QueryCouponVipDTO {
+
+ @ApiModelProperty(value = "优惠券名称")
+ private String name;
+
+ @ApiModelProperty(value = "优惠券类型")
+ private String couponDiscountType;
+
+
+ @ApiModelProperty(value = "id")
+ private String id;
+
+
+}
diff --git a/src/main/java/com/mzl/flower/dto/response/coupon/CouponRecordResultVO.java b/src/main/java/com/mzl/flower/dto/response/coupon/CouponRecordResultVO.java
new file mode 100644
index 0000000..6584d80
--- /dev/null
+++ b/src/main/java/com/mzl/flower/dto/response/coupon/CouponRecordResultVO.java
@@ -0,0 +1,129 @@
+package com.mzl.flower.dto.response.coupon;
+
+import com.fasterxml.jackson.annotation.JsonFormat;
+import com.mzl.flower.base.AbstractTransDTO;
+import com.mzl.flower.base.annotation.DictTrans;
+import com.mzl.flower.entity.coupon.CouponTemplateDO;
+import io.swagger.annotations.ApiModelProperty;
+import lombok.Data;
+import org.springframework.format.annotation.DateTimeFormat;
+
+import java.math.BigDecimal;
+import java.time.LocalDateTime;
+
+@Data
+public class CouponRecordResultVO extends AbstractTransDTO {
+
+ @ApiModelProperty(value = "ID ")
+ private String id;
+
+
+
+ @ApiModelProperty(value = "领取用户类型(COUPON_GET_USER_TYPE)")
+ @DictTrans(target = "getUserTypeName",codeType = "COUPON_GET_USER_TYPE")
+ private String getUserType;
+
+ /**
+ * 领取用户类型(COUPON_GET_USER_TYPE)全部用户,指定用户
+ */
+ @ApiModelProperty(value = "领取用户类型")
+ private String getUserTypeName;
+
+
+
+ /**
+ * 商户名称
+ */
+ @ApiModelProperty(value = "店铺名称")
+ private String customerName;
+
+ /**
+ * 电话
+ */
+ @ApiModelProperty(value = "联系方式")
+ private String tel;
+
+ /**
+ * 优惠券名称
+ */
+ @ApiModelProperty(value = "优惠券名称")
+ private String couponName;
+
+
+ @ApiModelProperty(value = "优惠券类型(COUPON_TYPE) ")
+ @DictTrans(target = "couponDiscountTypeName",codeType = "COUPON_TYPE")
+ private String couponDiscountType;
+
+
+ @ApiModelProperty(value = "优惠券类型 ")
+ private String couponDiscountTypeName;
+
+
+ @ApiModelProperty(value = "状态(COUPON_RECORD_STATUS)")
+ @DictTrans(target = "statusName",codeType = "COUPON_USED_STATUS")
+ private String status;
+ /**
+ * 状态名称
+ */
+ @ApiModelProperty(value = "状态名称")
+ private String statusName;
+
+ /**
+ * 领取结束时间
+ */
+ @ApiModelProperty(value = "领取时间")
+ @JsonFormat(pattern="yyyy-MM-dd HH:mm:ss" ,timezone="GMT+8")
+ @DateTimeFormat
+ private LocalDateTime createTime;
+
+ /**
+ * 有效开始时间
+ */
+ @ApiModelProperty(value = "有效开始时间")
+ @JsonFormat(pattern="yyyy-MM-dd HH:mm:ss" ,timezone="GMT+8")
+ @DateTimeFormat
+ private LocalDateTime effectiveStart;
+
+ /**
+ * 有效结束时间
+ */
+ @ApiModelProperty(value = "有效结束时间")
+ @JsonFormat(pattern="yyyy-MM-dd HH:mm:ss" ,timezone="GMT+8")
+ @DateTimeFormat
+ private LocalDateTime effectiveEnd;
+
+
+ /**
+ * 优惠券面值
+ */
+ @ApiModelProperty(value = "优惠券面值")
+ private BigDecimal couponDiscountValue;
+
+ /**
+ * 使用条件(满多少钱)
+ */
+ @ApiModelProperty(value = "使用条件")
+ private BigDecimal minOrderAmount;
+
+ /**
+ * 领取渠道(COUPON_GET_TYPE)首页弹窗、活动入口、领券中心
+ */
+ @ApiModelProperty(value = "领取渠道(COUPON_GET_TYPE)")
+ @DictTrans(target = "getTypeName",codeType = "COUPON_GET_TYPE")
+ private String getType;
+
+ /**
+ * 领取渠道(COUPON_GET_TYPE)首页弹窗、活动入口、领券中心
+ */
+ @ApiModelProperty(value = "领取渠道")
+ private String getTypeName;
+
+
+ /**
+ * 订单号
+ */
+ @ApiModelProperty(value = "订单号")
+ private String orderNo;
+
+
+}
diff --git a/src/main/java/com/mzl/flower/dto/response/coupon/CouponRecordVO.java b/src/main/java/com/mzl/flower/dto/response/coupon/CouponRecordVO.java
new file mode 100644
index 0000000..9817309
--- /dev/null
+++ b/src/main/java/com/mzl/flower/dto/response/coupon/CouponRecordVO.java
@@ -0,0 +1,41 @@
+package com.mzl.flower.dto.response.coupon;
+
+import com.mzl.flower.entity.coupon.CouponRecordDO;
+import lombok.Data;
+
+@Data
+public class CouponRecordVO extends CouponRecordDO {
+
+ /**
+ * 优惠券类型名称 COUPON_TYPE)满减和无门槛
+ */
+ private String couponDiscountTypeName;
+
+ /**
+ * 领取渠道(COUPON_GET_TYPE)首页弹窗、活动入口、领券中心
+ */
+ private String getTypeName;
+
+ /**
+ * 领取用户类型(COUPON_GET_USER_TYPE)全部用户,指定用户
+ */
+ private String getUserTypeName;
+
+
+ /**
+ * 状态名称
+ */
+ private String statusName;
+
+ /**
+ * 商户名称
+ */
+ private String customerName;
+
+ /**
+ * 电话
+ */
+ private String tel;
+
+
+}
diff --git a/src/main/java/com/mzl/flower/dto/response/coupon/CouponTemplateActivyVO.java b/src/main/java/com/mzl/flower/dto/response/coupon/CouponTemplateActivyVO.java
new file mode 100644
index 0000000..46d75e6
--- /dev/null
+++ b/src/main/java/com/mzl/flower/dto/response/coupon/CouponTemplateActivyVO.java
@@ -0,0 +1,134 @@
+package com.mzl.flower.dto.response.coupon;
+
+import com.fasterxml.jackson.annotation.JsonFormat;
+import com.mzl.flower.base.AbstractTransDTO;
+import com.mzl.flower.base.annotation.DictTrans;
+import com.mzl.flower.entity.coupon.CouponTemplateDO;
+import io.swagger.annotations.ApiModel;
+import io.swagger.annotations.ApiModelProperty;
+import lombok.Data;
+import org.springframework.format.annotation.DateTimeFormat;
+
+import java.math.BigDecimal;
+import java.time.LocalDateTime;
+
+@Data
+@ApiModel("活动优惠券")
+public class CouponTemplateActivyVO extends AbstractTransDTO {
+
+ @ApiModelProperty(value = "ID")
+ private String id;
+
+ /**
+ * 优惠券名称
+ */
+ @ApiModelProperty(value = "优惠券名称")
+ private String couponName;
+
+ /**
+ * 优惠券描述(使用规则)
+ */
+ @ApiModelProperty(value = "优惠券描述(使用规则)")
+ private String couponDescription;
+
+ /**
+ * 发放数量
+ */
+ @ApiModelProperty(value = "总数")
+ private Integer couponAmount;
+
+ /**
+ * 优惠券类型(COUPON_TYPE)满减和无门槛
+ */
+ @ApiModelProperty(value = "优惠券类型(COUPON_TYPE) ")
+ @DictTrans(target = "couponDiscountTypeName",codeType = "COUPON_TYPE")
+ private String couponDiscountType;
+
+ @ApiModelProperty(value = "领取用户类型")
+ @DictTrans(target = "getUserTypeName",codeType = "COUPON_GET_USER_TYPE")
+ private String getUserType;
+
+ /**
+ * 优惠券面值 折扣值(百分比或金额)
+ */
+ @ApiModelProperty(value = "优惠券面值")
+ private BigDecimal couponDiscountValue;
+
+ /**
+ * 使用条件,最小订单金额(可选)=》使用条件
+ */
+ @ApiModelProperty(value = "使用条件")
+ private BigDecimal minOrderAmount;
+
+
+ /**
+ * 领取开始时间
+ */
+ @ApiModelProperty(value = "领取开始时间")
+ @JsonFormat(pattern="yyyy-MM-dd HH:mm:ss" ,timezone="GMT+8")
+ @DateTimeFormat
+ private LocalDateTime getStartDate;
+
+ /**
+ * 领取结束时间
+ */
+ @ApiModelProperty(value = "领取结束时间")
+ @JsonFormat(pattern="yyyy-MM-dd HH:mm:ss" ,timezone="GMT+8")
+ @DateTimeFormat
+ private LocalDateTime getEndDate;
+
+
+ /**
+ * 优惠券状态(COUPON_STATUS)
+ */
+ @ApiModelProperty(value = "优惠券状态(COUPON_STATUS)")
+ @DictTrans(target = "statusName",codeType = "COUPON_STATUS")
+ private String status;
+
+
+
+ @ApiModelProperty(value = "使用开始时间")
+ @JsonFormat(pattern="yyyy-MM-dd HH:mm:ss" ,timezone="GMT+8")
+ @DateTimeFormat
+ private LocalDateTime usageStartDate;
+
+ /**
+ * 使用结束时间
+ */
+ @ApiModelProperty(value = "使用结束时间")
+ @JsonFormat(pattern="yyyy-MM-dd HH:mm:ss" ,timezone="GMT+8")
+ @DateTimeFormat
+ private LocalDateTime usageEndDate;
+
+
+ /**
+ * 优惠券类型名称 COUPON_TYPE)满减和无门槛
+ */
+ @ApiModelProperty(value = "优惠券类型名称 ")
+ private String couponDiscountTypeName;
+
+ /**
+ * 状态名称
+ */
+ @ApiModelProperty(value = "状态名称")
+ private String statusName;
+
+ @ApiModelProperty(value = "操作人")
+ private String createByName;
+
+ @ApiModelProperty(value = "领取用户类型")
+ private String getUserTypeName;
+
+ /**
+ * 已经领取数
+ */
+ @ApiModelProperty(value = "已经领取数")
+ private Integer getNum;
+
+ /**
+ * 未领取数
+ */
+ @ApiModelProperty(value = "未领取数")
+ private Integer unGetNum;
+
+}
diff --git a/src/main/java/com/mzl/flower/dto/response/coupon/CouponTemplatePointVO.java b/src/main/java/com/mzl/flower/dto/response/coupon/CouponTemplatePointVO.java
new file mode 100644
index 0000000..96d57a3
--- /dev/null
+++ b/src/main/java/com/mzl/flower/dto/response/coupon/CouponTemplatePointVO.java
@@ -0,0 +1,90 @@
+package com.mzl.flower.dto.response.coupon;
+
+import com.fasterxml.jackson.annotation.JsonFormat;
+import com.mzl.flower.base.AbstractTransDTO;
+import com.mzl.flower.base.annotation.DictTrans;
+import io.swagger.annotations.ApiModel;
+import io.swagger.annotations.ApiModelProperty;
+import lombok.Data;
+import org.springframework.format.annotation.DateTimeFormat;
+
+import java.math.BigDecimal;
+import java.time.LocalDateTime;
+
+@Data
+@ApiModel("积分记录")
+public class CouponTemplatePointVO extends AbstractTransDTO {
+
+
+ @ApiModelProperty(value = "ID")
+ private String id;
+
+
+ /**
+ * 优惠券名称
+ */
+ @ApiModelProperty(value = "优惠券名称")
+ private String couponName;
+
+ /**
+ * 优惠券描述(使用规则)
+ */
+ @ApiModelProperty(value = "优惠券描述(使用规则)")
+ private String couponDescription;
+
+ /**
+ * 发放数量
+ */
+ @ApiModelProperty(value = "库存")
+ private Integer couponAmount;
+
+ /**
+ * 优惠券类型(COUPON_TYPE)满减和无门槛
+ */
+ @ApiModelProperty(value = "优惠券类型(COUPON_TYPE) ")
+ @DictTrans(target = "couponDiscountTypeName",codeType = "COUPON_TYPE")
+ private String couponDiscountType;
+
+ /**
+ * 优惠券面值 折扣值(百分比或金额)
+ */
+ @ApiModelProperty(value = "优惠券面值")
+ private BigDecimal couponDiscountValue;
+
+ /**
+ * 使用条件,最小订单金额(可选)=》使用条件
+ */
+ @ApiModelProperty(value = "使用条件")
+ private BigDecimal minOrderAmount;
+
+
+
+ /**
+ * 优惠券状态(COUPON_STATUS)
+ */
+ @ApiModelProperty(value = "优惠券状态(COUPON_STATUS)")
+ @DictTrans(target = "statusName",codeType = "COUPON_STATUS")
+ private String status;
+
+ /**
+ * 兑换积分
+ */
+ @ApiModelProperty(value = "所需积分数量")
+ private Integer point;
+
+ /**
+ * 优惠券类型名称 COUPON_TYPE)满减和无门槛
+ */
+ @ApiModelProperty(value = "优惠券类型名称 ")
+ private String couponDiscountTypeName;
+
+
+ /**
+ * 状态名称
+ */
+ @ApiModelProperty(value = "状态名称")
+ private String statusName;
+
+
+
+}
diff --git a/src/main/java/com/mzl/flower/dto/response/coupon/CouponTemplateUserVO.java b/src/main/java/com/mzl/flower/dto/response/coupon/CouponTemplateUserVO.java
new file mode 100644
index 0000000..99fd2eb
--- /dev/null
+++ b/src/main/java/com/mzl/flower/dto/response/coupon/CouponTemplateUserVO.java
@@ -0,0 +1,99 @@
+package com.mzl.flower.dto.response.coupon;
+
+import com.fasterxml.jackson.annotation.JsonFormat;
+import com.mzl.flower.base.AbstractTransDTO;
+import com.mzl.flower.base.annotation.DictTrans;
+import io.swagger.annotations.ApiModel;
+import io.swagger.annotations.ApiModelProperty;
+import lombok.Data;
+import org.springframework.format.annotation.DateTimeFormat;
+
+import java.math.BigDecimal;
+import java.time.LocalDateTime;
+
+@Data
+@ApiModel("用户优惠券")
+public class CouponTemplateUserVO extends AbstractTransDTO {
+
+
+ @ApiModelProperty(value = "ID")
+ private String id;
+
+ /**
+ * 优惠券名称
+ */
+ @ApiModelProperty(value = "优惠券名称")
+ private String couponName;
+
+ /**
+ * 优惠券描述(使用规则)
+ */
+ @ApiModelProperty(value = "优惠券描述(使用规则)")
+ private String couponDescription;
+
+ /**
+ * 发放数量
+ */
+ @ApiModelProperty(value = "总数")
+ private Integer couponAmount;
+
+ /**
+ * 优惠券类型(COUPON_TYPE)满减和无门槛
+ */
+ @ApiModelProperty(value = "优惠券类型(COUPON_TYPE) ")
+ @DictTrans(target = "couponDiscountTypeName",codeType = "COUPON_TYPE")
+ private String couponDiscountType;
+
+ /**
+ * 优惠券面值 折扣值(百分比或金额)
+ */
+ @ApiModelProperty(value = "优惠券面值")
+ private BigDecimal couponDiscountValue;
+
+ /**
+ * 使用条件,最小订单金额(可选)=》使用条件
+ */
+ @ApiModelProperty(value = "使用条件")
+ private BigDecimal minOrderAmount;
+
+
+
+ /**
+ * 优惠券状态(COUPON_STATUS)
+ */
+ @ApiModelProperty(value = "优惠券状态(COUPON_STATUS)")
+ @DictTrans(target = "statusName",codeType = "COUPON_STATUS")
+ private String status;
+
+
+
+ @ApiModelProperty(value = "使用开始时间")
+ @JsonFormat(pattern="yyyy-MM-dd HH:mm:ss" ,timezone="GMT+8")
+ @DateTimeFormat
+ private LocalDateTime usageStartDate;
+
+ /**
+ * 使用结束时间
+ */
+ @ApiModelProperty(value = "使用结束时间")
+ @JsonFormat(pattern="yyyy-MM-dd HH:mm:ss" ,timezone="GMT+8")
+ @DateTimeFormat
+ private LocalDateTime usageEndDate;
+
+
+ /**
+ * 优惠券类型名称 COUPON_TYPE)满减和无门槛
+ */
+ @ApiModelProperty(value = "优惠券类型名称 ")
+ private String couponDiscountTypeName;
+
+ /**
+ * 状态名称
+ */
+ @ApiModelProperty(value = "状态名称")
+ private String statusName;
+
+ @ApiModelProperty(value = "操作人")
+ private String createByName;
+
+}
diff --git a/src/main/java/com/mzl/flower/dto/response/coupon/CouponTemplateVO.java b/src/main/java/com/mzl/flower/dto/response/coupon/CouponTemplateVO.java
new file mode 100644
index 0000000..8181d9b
--- /dev/null
+++ b/src/main/java/com/mzl/flower/dto/response/coupon/CouponTemplateVO.java
@@ -0,0 +1,232 @@
+package com.mzl.flower.dto.response.coupon;
+
+import com.fasterxml.jackson.annotation.JsonFormat;
+import com.mzl.flower.base.AbstractTransDTO;
+import com.mzl.flower.base.annotation.DictTrans;
+import com.mzl.flower.entity.coupon.CouponTemplateDO;
+import io.swagger.annotations.ApiModelProperty;
+import lombok.Data;
+import org.springframework.format.annotation.DateTimeFormat;
+
+import java.math.BigDecimal;
+import java.time.LocalDateTime;
+
+@Data
+public class CouponTemplateVO extends AbstractTransDTO {
+
+ @ApiModelProperty(value = "主键")
+ @DictTrans(target = "id",codeType = "id")
+ private String id;
+
+ /**
+ * 优惠券种类(活动优惠券、用户优惠券、会员优惠券,积分优惠券)
+ */
+ @ApiModelProperty(value = "优惠券种类")
+ @DictTrans(target = "categoryName",codeType = "COUPON_CATEGORY")
+ private String category;
+ /**
+ * 优惠券代码(唯一)
+ */
+ @ApiModelProperty(value = "优惠券代码")
+ private String couponCode;
+
+ /**
+ * 优惠券名称
+ */
+ @ApiModelProperty(value = "优惠券名称")
+ private String couponName;
+
+ /**
+ * 优惠券描述(使用规则)
+ */
+ @ApiModelProperty(value = "优惠券描述(使用规则)")
+ private String couponDescription;
+
+ /**
+ * 发放数量
+ */
+ @ApiModelProperty(value = "发放数量")
+ private Integer couponAmount;
+
+ /**
+ * 优惠券类型(COUPON_TYPE)满减和无门槛
+ */
+ @ApiModelProperty(value = "优惠券类型 ")
+ @DictTrans(target = "couponDiscountTypeName",codeType = "COUPON_TYPE")
+ private String couponDiscountType;
+
+ /**
+ * 优惠券面值 折扣值(百分比或金额)
+ */
+ @ApiModelProperty(value = "优惠券面值")
+ private BigDecimal couponDiscountValue;
+
+ /**
+ * 使用条件,最小订单金额(可选)=》使用条件
+ */
+ @ApiModelProperty(value = "使用条件")
+ private BigDecimal minOrderAmount;
+
+ /**
+ * 最大折扣金额(可选,仅对百分比折扣类型适用)
+ */
+ private BigDecimal maxDiscountAmount;
+
+ /**
+ * 领取渠道(COUPON_GET_TYPE)首页弹窗、活动入口、领券中心
+ */
+ @ApiModelProperty(value = "领取渠道(COUPON_GET_TYPE)")
+ @DictTrans(target = "getTypeName",codeType = "COUPON_GET_TYPE")
+ private String getType;
+
+ /**
+ * 领取用户类型(COUPON_GET_USER_TYPE)全部用户,指定用户
+ */
+ @ApiModelProperty(value = "领取用户类型(COUPON_GET_USER_TYPE)")
+ @DictTrans(target = "getUserTypeName",codeType = "COUPON_GET_USER_TYPE")
+ private String getUserType;
+
+ /**
+ * 领取开始时间
+ */
+ @ApiModelProperty(value = "领取开始时间")
+ @JsonFormat(pattern="yyyy-MM-dd HH:mm:ss" ,timezone="GMT+8")
+ @DateTimeFormat
+ private LocalDateTime getStartDate;
+
+ /**
+ * 领取结束时间
+ */
+ @ApiModelProperty(value = "领取结束时间")
+ @JsonFormat(pattern="yyyy-MM-dd HH:mm:ss" ,timezone="GMT+8")
+ @DateTimeFormat
+ private LocalDateTime getEndDate;
+
+ /**
+ * 每人限领
+ */
+ @ApiModelProperty(value = "每人限领")
+ private Integer getLimit;
+
+ /**
+ * 使用时间类型(COUPON_USAGE_TYPE)与领取时间一致、固定时间、领取后有效
+ */
+ @ApiModelProperty(value = "使用时间类型(COUPON_USAGE_TYPE)")
+ @DictTrans(target = "usageTypeName",codeType = "COUPON_USAGE_TYPE")
+ private String usageType;
+
+ /**
+ * 使用次数限制
+ */
+ @ApiModelProperty(value = "使用次数限制")
+ private Integer usageLimit;
+
+ /**
+ * 每个用户的使用次数限制
+ */
+ @ApiModelProperty(value = "每个用户的使用次数限制")
+ private Integer usagePerUser;
+
+ /**
+ * 使用开始时间
+ */
+ @ApiModelProperty(value = "使用开始时间")
+ @JsonFormat(pattern="yyyy-MM-dd HH:mm:ss" ,timezone="GMT+8")
+ @DateTimeFormat
+ private LocalDateTime usageStartDate;
+
+ /**
+ * 使用结束时间
+ */
+ @ApiModelProperty(value = "使用结束时间")
+ @JsonFormat(pattern="yyyy-MM-dd HH:mm:ss" ,timezone="GMT+8")
+ @DateTimeFormat
+ private LocalDateTime usageEndDate;
+
+ /**
+ * 领取后有效类型(COUPON_usage_time_type)天、小时、分钟
+ */
+ @ApiModelProperty(value = "领取后有效类型(COUPON_USAGE_TIME_TYPE)")
+ @DictTrans(target = "usageTimeTypeName",codeType = "COUPON_USAGE_TIME_TYPE")
+ private String usageTimeType;
+
+ /**
+ * 领取后有效时间整数,比如90(天,小时,分钟)
+ */
+ @ApiModelProperty(value = "领取后有效时间整数")
+ private Integer usageTimeNum;
+
+ /**
+ * 优惠券状态(COUPON_STATUS)
+ */
+ @ApiModelProperty(value = "优惠券状态(COUPON_STATUS)")
+ @DictTrans(target = "statusName",codeType = "COUPON_STATUS")
+ private String status;
+
+ /**
+ * 兑换积分
+ */
+ @ApiModelProperty(value = "兑换积分")
+ private Integer point;
+
+ /**
+ * 优惠券类型名称 COUPON_TYPE)满减和无门槛
+ */
+ @ApiModelProperty(value = "优惠券类型名称 ")
+ private String couponDiscountTypeName;
+
+ /**
+ * 领取渠道(COUPON_GET_TYPE)首页弹窗、活动入口、领券中心
+ */
+ @ApiModelProperty(value = "领取渠道(COUPON_GET_TYPE)")
+ private String getTypeName;
+
+ /**
+ * 领取用户类型(COUPON_GET_USER_TYPE)全部用户,指定用户
+ */
+ @ApiModelProperty(value = "领取用户类型")
+ private String getUserTypeName;
+
+ /**
+ * 已经领取数
+ */
+ @ApiModelProperty(value = "已经领取数")
+ private Integer getNum;
+
+ /**
+ * 未领取数
+ */
+ @ApiModelProperty(value = "未领取数")
+ private Integer unGetNum;
+
+ @ApiModelProperty(value = "优惠券种类名称")
+ private String categoryName;
+
+ /**
+ * 状态名称
+ */
+ @ApiModelProperty(value = "状态名称")
+ private String statusName;
+
+ @ApiModelProperty(value = "领取后有效类型")
+ private String usageTimeTypeName;
+
+ @ApiModelProperty(value = "使用时间类型")
+ private String usageTypeName;
+
+ /**
+ * 创建人名称
+ */
+ @ApiModelProperty(value = "创建人名称")
+ private String createByName;
+
+ /**
+ * 更新人名称
+ */
+ @ApiModelProperty(value = "更新人名称")
+ private String updateByName;
+
+ @ApiModelProperty(value = "会员等级")
+ private String vipGrade;
+
+}
diff --git a/src/main/java/com/mzl/flower/dto/response/coupon/CouponTemplateVipVO.java b/src/main/java/com/mzl/flower/dto/response/coupon/CouponTemplateVipVO.java
new file mode 100644
index 0000000..dd9d82b
--- /dev/null
+++ b/src/main/java/com/mzl/flower/dto/response/coupon/CouponTemplateVipVO.java
@@ -0,0 +1,100 @@
+package com.mzl.flower.dto.response.coupon;
+
+import com.fasterxml.jackson.annotation.JsonFormat;
+import com.mzl.flower.base.AbstractTransDTO;
+import com.mzl.flower.base.annotation.DictTrans;
+import com.mzl.flower.entity.coupon.CouponTemplateDO;
+import io.swagger.annotations.ApiModelProperty;
+import lombok.Data;
+import org.springframework.format.annotation.DateTimeFormat;
+
+import java.math.BigDecimal;
+import java.time.LocalDateTime;
+
+@Data
+public class CouponTemplateVipVO extends AbstractTransDTO {
+
+
+ @ApiModelProperty(value = "ID")
+ private String id;
+
+ /**
+ * 优惠券名称
+ */
+ @ApiModelProperty(value = "优惠券名称")
+ private String couponName;
+
+ /**
+ * 优惠券描述(使用规则)
+ */
+ @ApiModelProperty(value = "优惠券描述(使用规则)")
+ private String couponDescription;
+
+
+ /**
+ * 优惠券类型(COUPON_TYPE)满减和无门槛
+ */
+ @ApiModelProperty(value = "优惠券类型(COUPON_TYPE) ")
+ @DictTrans(target = "couponDiscountTypeName",codeType = "COUPON_TYPE")
+ private String couponDiscountType;
+
+
+
+ /**
+ * 优惠券面值 折扣值(百分比或金额)
+ */
+ @ApiModelProperty(value = "优惠券面值")
+ private BigDecimal couponDiscountValue;
+
+ /**
+ * 使用条件,最小订单金额(可选)=》使用条件
+ */
+ @ApiModelProperty(value = "使用条件")
+ private BigDecimal minOrderAmount;
+
+
+ /**
+ * 优惠券状态(COUPON_STATUS)
+ */
+ @ApiModelProperty(value = "优惠券状态(COUPON_STATUS)")
+ @DictTrans(target = "statusName",codeType = "COUPON_STATUS")
+ private String status;
+
+
+ @ApiModelProperty(value = "使用开始时间")
+ @JsonFormat(pattern="yyyy-MM-dd HH:mm:ss" ,timezone="GMT+8")
+ @DateTimeFormat
+ private LocalDateTime usageStartDate;
+
+ /**
+ * 使用结束时间
+ */
+ @ApiModelProperty(value = "使用结束时间")
+ @JsonFormat(pattern="yyyy-MM-dd HH:mm:ss" ,timezone="GMT+8")
+ @DateTimeFormat
+ private LocalDateTime usageEndDate;
+
+
+ /**
+ * 优惠券类型名称 COUPON_TYPE)满减和无门槛
+ */
+ @ApiModelProperty(value = "优惠券类型名称 ")
+ private String couponDiscountTypeName;
+
+ /**
+ * 状态名称
+ */
+ @ApiModelProperty(value = "状态名称")
+ private String statusName;
+
+ @ApiModelProperty(value = "操作人")
+ private String createByName;
+
+ /**
+ * 已经领取数
+ */
+ @ApiModelProperty(value = "已经领取数")
+ private Integer getNum;
+
+
+}
diff --git a/src/main/java/com/mzl/flower/entity/coupon/CouponRecordDO.java b/src/main/java/com/mzl/flower/entity/coupon/CouponRecordDO.java
new file mode 100644
index 0000000..964e122
--- /dev/null
+++ b/src/main/java/com/mzl/flower/entity/coupon/CouponRecordDO.java
@@ -0,0 +1,107 @@
+package com.mzl.flower.entity.coupon;
+
+import com.baomidou.mybatisplus.annotation.TableName;
+import com.mzl.flower.base.BaseEntity;
+import lombok.Data;
+import lombok.EqualsAndHashCode;
+import lombok.experimental.Accessors;
+
+import java.math.BigDecimal;
+import java.time.LocalDateTime;
+
+/**
+ * @author @TaoJie
+ * @since 2024-08-27
+ */
+@Data
+@EqualsAndHashCode(callSuper = true)
+@Accessors(chain = true)
+@TableName("t_coupon_record")
+public class CouponRecordDO extends BaseEntity {
+
+
+ /**
+ * 优惠券ID
+ */
+ private String couponId;
+
+ /**
+ * 用户id
+ */
+ private String userId;
+
+ /**
+ * 商户ID
+ */
+ private String customerId;
+
+ /**
+ * 状态(coupon_record_status)未使用、已使用、已过期
+ */
+ private String status;
+
+ /**
+ * 有效开始时间
+ */
+ private LocalDateTime effectiveStart;
+
+ /**
+ * 有效结束时间
+ */
+ private LocalDateTime effectiveEnd;
+
+ /**
+ * 使用订单
+ */
+ private String orderId;
+
+ /**
+ * 使用时间
+ */
+ private LocalDateTime usedTime;
+
+ /**
+ * 优惠券面值
+ */
+ private BigDecimal couponDiscountValue;
+
+ /**
+ * 使用条件(满多少钱)
+ */
+ private BigDecimal minOrderAmount;
+
+ /**
+ * 优惠券种类(活动优惠券、用户优惠券、会员优惠券,积分优惠券)
+ */
+ private String category;
+
+ /**
+ * 优惠券代码
+ */
+ private String couponCode;
+
+ /**
+ * 优惠券名称
+ */
+ private String couponName;
+
+ private String couponDiscountType;
+
+ private String getType;
+
+ /**
+ * 用户获取类型
+ */
+ private String getUserType;
+
+ /**
+ * 积分数量
+ */
+ private Integer point;
+
+ /**
+ * 订单号
+ */
+ private String orderNo;
+
+}
diff --git a/src/main/java/com/mzl/flower/entity/coupon/CouponTemplateCustomerDO.java b/src/main/java/com/mzl/flower/entity/coupon/CouponTemplateCustomerDO.java
new file mode 100644
index 0000000..50e96a5
--- /dev/null
+++ b/src/main/java/com/mzl/flower/entity/coupon/CouponTemplateCustomerDO.java
@@ -0,0 +1,35 @@
+package com.mzl.flower.entity.coupon;
+
+import com.baomidou.mybatisplus.annotation.TableField;
+import com.baomidou.mybatisplus.annotation.TableId;
+import com.baomidou.mybatisplus.annotation.TableName;
+import lombok.Data;
+import lombok.experimental.Accessors;
+
+/**
+ * @author @TaoJie
+ * @since 2024-08-24
+ */
+@Data
+@Accessors(chain = true)
+@TableName("t_coupon_template_customer")
+public class CouponTemplateCustomerDO {
+
+
+ @TableId("id")
+ private String id;
+
+ /**
+ * 优惠券id
+ */
+ @TableField("coupon_id")
+ private String couponId;
+
+ /**
+ * 指定的顾客id
+ */
+ @TableField("custom_id")
+ private String customId;
+
+
+}
diff --git a/src/main/java/com/mzl/flower/entity/coupon/CouponTemplateDO.java b/src/main/java/com/mzl/flower/entity/coupon/CouponTemplateDO.java
new file mode 100644
index 0000000..3360098
--- /dev/null
+++ b/src/main/java/com/mzl/flower/entity/coupon/CouponTemplateDO.java
@@ -0,0 +1,142 @@
+package com.mzl.flower.entity.coupon;
+
+import com.baomidou.mybatisplus.annotation.TableName;
+import com.mzl.flower.base.BaseEntity;
+import io.swagger.annotations.ApiModelProperty;
+import lombok.Data;
+import lombok.EqualsAndHashCode;
+import lombok.experimental.Accessors;
+
+import java.math.BigDecimal;
+import java.time.LocalDateTime;
+
+/**
+ * @author @TaoJie
+ * @since 2024-08-22
+ */
+@Data
+@EqualsAndHashCode(callSuper = true)
+@Accessors(chain = true)
+@TableName("t_coupon_template")
+public class CouponTemplateDO extends BaseEntity {
+
+
+ /**
+ * 优惠券种类(活动优惠券、用户优惠券、会员优惠券,积分优惠券)
+ */
+ private String category;
+ /**
+ * 优惠券代码(唯一)
+ */
+ private String couponCode;
+
+ /**
+ * 优惠券名称
+ */
+ private String couponName;
+
+ /**
+ * 优惠券描述(使用规则)
+ */
+ private String couponDescription;
+
+ /**
+ * 发放数量
+ */
+ private Integer couponAmount;
+
+ /**
+ * 优惠券类型(COUPON_TYPE)满减和无门槛
+ */
+ private String couponDiscountType;
+
+ /**
+ * 优惠券面值 折扣值(百分比或金额)
+ */
+ private BigDecimal couponDiscountValue;
+
+ /**
+ * 使用条件,最小订单金额(可选)=》使用条件
+ */
+ private BigDecimal minOrderAmount;
+
+ /**
+ * 最大折扣金额(可选,仅对百分比折扣类型适用)
+ */
+ private BigDecimal maxDiscountAmount;
+
+ /**
+ * 领取渠道(COUPON_GET_TYPE)首页弹窗、活动入口、领券中心
+ */
+ private String getType;
+
+ /**
+ * 领取用户类型(COUPON_GET_USER_TYPE)全部用户,指定用户
+ */
+ private String getUserType;
+
+ /**
+ * 领取开始时间
+ */
+ private LocalDateTime getStartDate;
+
+ /**
+ * 领取结束时间
+ */
+ private LocalDateTime getEndDate;
+
+ /**
+ * 每人限领
+ */
+ private Integer getLimit;
+
+ /**
+ * 使用时间类型(COUPON_USAGE_TYPE)与领取时间一致、固定时间、领取后有效
+ */
+ private String usageType;
+
+ /**
+ * 使用次数限制
+ */
+ private Integer usageLimit;
+
+ /**
+ * 每个用户的使用次数限制
+ */
+ private Integer usagePerUser;
+
+ /**
+ * 使用开始时间
+ */
+ private LocalDateTime usageStartDate;
+
+ /**
+ * 使用结束时间
+ */
+ private LocalDateTime usageEndDate;
+
+ /**
+ * 领取后有效类型(COUPON_usage_time_type)天、小时、分钟
+ */
+ private String usageTimeType;
+
+ /**
+ * 领取后有效时间整数,比如90(天,小时,分钟)
+ */
+ private Integer usageTimeNum;
+
+ /**
+ * 优惠券状态(COUPON_STATUS)
+ */
+ private String status;
+
+ /**
+ * 兑换积分
+ */
+ private Integer point;
+
+ @ApiModelProperty(value = "会员等级")
+ private String vipGrade;
+
+
+}
diff --git a/src/main/java/com/mzl/flower/entity/system/User.java b/src/main/java/com/mzl/flower/entity/system/User.java
index ae798e1..bcdcd1a 100644
--- a/src/main/java/com/mzl/flower/entity/system/User.java
+++ b/src/main/java/com/mzl/flower/entity/system/User.java
@@ -35,4 +35,8 @@
@TableField("third_id")
private String thirdId;
+
+ @TableField("vip_grade")
+ private String vipGrade;
+
}
\ No newline at end of file
diff --git a/src/main/java/com/mzl/flower/enums/CouponCategoryEnum.java b/src/main/java/com/mzl/flower/enums/CouponCategoryEnum.java
new file mode 100644
index 0000000..a43218c
--- /dev/null
+++ b/src/main/java/com/mzl/flower/enums/CouponCategoryEnum.java
@@ -0,0 +1,22 @@
+package com.mzl.flower.enums;
+
+import lombok.Getter;
+
+public enum CouponCategoryEnum {
+
+ ACTIVITY("activity","活动优惠券"),
+ USER("user","用户优惠券"),
+ MEMBER("member","会员优惠券"),
+ POINT("point","积分优惠券"),
+ ;
+
+ @Getter
+ private String status;
+
+ private String desc;
+ private CouponCategoryEnum(String status, String desc){
+ this.status=status;
+ this.desc=desc;
+ }
+
+}
diff --git a/src/main/java/com/mzl/flower/enums/CouponGetUserTypeEnum.java b/src/main/java/com/mzl/flower/enums/CouponGetUserTypeEnum.java
new file mode 100644
index 0000000..c39fbd7
--- /dev/null
+++ b/src/main/java/com/mzl/flower/enums/CouponGetUserTypeEnum.java
@@ -0,0 +1,22 @@
+package com.mzl.flower.enums;
+
+import lombok.Getter;
+
+public enum CouponGetUserTypeEnum {
+
+
+ ALL("all","全部用户"),
+ POINT("point","指定用户"),
+
+ ;
+
+ @Getter
+ private String type;
+
+ private String desc;
+ private CouponGetUserTypeEnum(String type, String desc){
+ this.type=type;
+ this.desc=desc;
+ }
+
+}
diff --git a/src/main/java/com/mzl/flower/enums/CouponStatusEnum.java b/src/main/java/com/mzl/flower/enums/CouponStatusEnum.java
new file mode 100644
index 0000000..8879187
--- /dev/null
+++ b/src/main/java/com/mzl/flower/enums/CouponStatusEnum.java
@@ -0,0 +1,22 @@
+package com.mzl.flower.enums;
+
+import lombok.Getter;
+
+public enum CouponStatusEnum {
+
+
+ INACTIVE("inactive","未发布"),
+ ACTIVE("active","已发布"),
+ EXPIRED("expired","下架"),
+ ;
+
+ @Getter
+ private String status;
+
+ private String desc;
+ private CouponStatusEnum(String status,String desc){
+ this.status=status;
+ this.desc=desc;
+ }
+
+}
diff --git a/src/main/java/com/mzl/flower/enums/CouponTypeEnum.java b/src/main/java/com/mzl/flower/enums/CouponTypeEnum.java
new file mode 100644
index 0000000..0dcfb9b
--- /dev/null
+++ b/src/main/java/com/mzl/flower/enums/CouponTypeEnum.java
@@ -0,0 +1,23 @@
+package com.mzl.flower.enums;
+
+import lombok.Getter;
+
+public enum CouponTypeEnum {
+
+
+ DISCOUNT("discount","满减"),
+ ZERO("zero","无门槛"),
+
+
+ ;
+
+ @Getter
+ private String type;
+
+ private String desc;
+ private CouponTypeEnum(String type, String desc){
+ this.type=type;
+ this.desc=desc;
+ }
+
+}
diff --git a/src/main/java/com/mzl/flower/enums/CouponUsageTimeTypeEnum.java b/src/main/java/com/mzl/flower/enums/CouponUsageTimeTypeEnum.java
new file mode 100644
index 0000000..d5acc44
--- /dev/null
+++ b/src/main/java/com/mzl/flower/enums/CouponUsageTimeTypeEnum.java
@@ -0,0 +1,23 @@
+package com.mzl.flower.enums;
+
+import lombok.Getter;
+
+public enum CouponUsageTimeTypeEnum {
+
+
+ DAY("day","天"),
+ HOUR("hour","小时"),
+ MINUTE("minute","分钟"),
+
+ ;
+
+ @Getter
+ private String type;
+
+ private String desc;
+ private CouponUsageTimeTypeEnum(String type, String desc){
+ this.type=type;
+ this.desc=desc;
+ }
+
+}
diff --git a/src/main/java/com/mzl/flower/enums/CouponUsageTypeEnum.java b/src/main/java/com/mzl/flower/enums/CouponUsageTypeEnum.java
new file mode 100644
index 0000000..a988154
--- /dev/null
+++ b/src/main/java/com/mzl/flower/enums/CouponUsageTypeEnum.java
@@ -0,0 +1,23 @@
+package com.mzl.flower.enums;
+
+import lombok.Getter;
+
+public enum CouponUsageTypeEnum {
+
+
+ GET("get","与领取时间一致"),
+ FIXED("fixed","固定时间"),
+ GET_AFTER_TIME("get_after_time","领取后有效时间"),
+
+ ;
+
+ @Getter
+ private String type;
+
+ private String desc;
+ private CouponUsageTypeEnum(String type, String desc){
+ this.type=type;
+ this.desc=desc;
+ }
+
+}
diff --git a/src/main/java/com/mzl/flower/enums/CouponUsedStatusEnum.java b/src/main/java/com/mzl/flower/enums/CouponUsedStatusEnum.java
new file mode 100644
index 0000000..4a0257e
--- /dev/null
+++ b/src/main/java/com/mzl/flower/enums/CouponUsedStatusEnum.java
@@ -0,0 +1,23 @@
+package com.mzl.flower.enums;
+
+import lombok.Getter;
+
+public enum CouponUsedStatusEnum {
+
+ UNUSED("unused","待使用"),
+ USED("used","已使用"),
+ EXPIRED("expired","过期"),
+
+ ;
+
+ @Getter
+ private String type;
+
+ private String desc;
+ private CouponUsedStatusEnum(String type, String desc){
+ this.type=type;
+ this.desc=desc;
+ }
+
+
+}
diff --git a/src/main/java/com/mzl/flower/enums/TrueOrFalseEnum.java b/src/main/java/com/mzl/flower/enums/TrueOrFalseEnum.java
new file mode 100644
index 0000000..8dfbe95
--- /dev/null
+++ b/src/main/java/com/mzl/flower/enums/TrueOrFalseEnum.java
@@ -0,0 +1,17 @@
+package com.mzl.flower.enums;
+
+import lombok.Getter;
+
+public enum TrueOrFalseEnum {
+
+
+ TRUE(true),
+ FALSE(false),
+ ;
+
+ @Getter
+ private boolean flag;
+ private TrueOrFalseEnum(boolean flag){
+ this.flag=flag;
+ }
+}
diff --git a/src/main/java/com/mzl/flower/enums/VipGradeEnum.java b/src/main/java/com/mzl/flower/enums/VipGradeEnum.java
new file mode 100644
index 0000000..3bbe6d3
--- /dev/null
+++ b/src/main/java/com/mzl/flower/enums/VipGradeEnum.java
@@ -0,0 +1,24 @@
+package com.mzl.flower.enums;
+
+import lombok.Getter;
+
+public enum VipGradeEnum {
+
+ NORMAL("0","普通会员"),
+ SILVER("1","银卡会员"),
+ GOLD("2","金卡会员"),
+ DIAMOND("3","钻石会员"),
+
+ ;
+
+ @Getter
+ private String type;
+
+ private String desc;
+ private VipGradeEnum(String type, String desc){
+ this.type=type;
+ this.desc=desc;
+ }
+
+
+}
diff --git a/src/main/java/com/mzl/flower/mapper/coupon/CouponRecordMapper.java b/src/main/java/com/mzl/flower/mapper/coupon/CouponRecordMapper.java
new file mode 100644
index 0000000..bccaf11
--- /dev/null
+++ b/src/main/java/com/mzl/flower/mapper/coupon/CouponRecordMapper.java
@@ -0,0 +1,16 @@
+package com.mzl.flower.mapper.coupon;
+
+import com.mzl.flower.entity.coupon.CouponRecordDO;
+import com.baomidou.mybatisplus.core.mapper.BaseMapper;
+
+/**
+ * <p>
+ * Mapper 接口
+ * </p>
+ *
+ * @author @TaoJie
+ * @since 2024-08-27
+ */
+public interface CouponRecordMapper extends BaseMapper<CouponRecordDO> {
+
+}
diff --git a/src/main/java/com/mzl/flower/mapper/coupon/CouponRecordMapperCustom.java b/src/main/java/com/mzl/flower/mapper/coupon/CouponRecordMapperCustom.java
new file mode 100644
index 0000000..40373f4
--- /dev/null
+++ b/src/main/java/com/mzl/flower/mapper/coupon/CouponRecordMapperCustom.java
@@ -0,0 +1,32 @@
+package com.mzl.flower.mapper.coupon;
+
+import com.baomidou.mybatisplus.core.mapper.BaseMapper;
+import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import com.mzl.flower.dto.request.coupon.QueryCouponRecordDTO;
+import com.mzl.flower.dto.request.coupon.QueryCouponStatisticsBO;
+import com.mzl.flower.dto.response.coupon.CouponRecordVO;
+import com.mzl.flower.entity.coupon.CouponRecordDO;
+import org.apache.ibatis.annotations.Param;
+
+import java.util.List;
+
+/**
+ * <p>
+ * Mapper 接口
+ * </p>
+ *
+ * @author @TaoJie
+ * @since 2024-08-27
+ */
+public interface CouponRecordMapperCustom extends BaseMapper<CouponRecordDO> {
+
+ List<CouponRecordVO> getPage(Page page, @Param("param") QueryCouponRecordDTO dto);
+
+ List<CouponRecordVO> getList(@Param("param") QueryCouponRecordDTO dto);
+
+ int statisCouponTemplateCount(@Param("param") QueryCouponStatisticsBO queryCouponStatisticsBO);
+
+ int statisCouponTemplateCurMonCount(@Param("param") QueryCouponStatisticsBO queryCouponStatisticsBO);
+
+ int statisCouponPointCurMonPointAmonut(@Param("param") QueryCouponStatisticsBO queryCouponStatisticsBO);
+}
diff --git a/src/main/java/com/mzl/flower/mapper/coupon/CouponTemplateCustomerMapper.java b/src/main/java/com/mzl/flower/mapper/coupon/CouponTemplateCustomerMapper.java
new file mode 100644
index 0000000..1ad55c8
--- /dev/null
+++ b/src/main/java/com/mzl/flower/mapper/coupon/CouponTemplateCustomerMapper.java
@@ -0,0 +1,16 @@
+package com.mzl.flower.mapper.coupon;
+
+import com.mzl.flower.entity.coupon.CouponTemplateCustomerDO;
+import com.baomidou.mybatisplus.core.mapper.BaseMapper;
+
+/**
+ * <p>
+ * Mapper 接口
+ * </p>
+ *
+ * @author @TaoJie
+ * @since 2024-08-24
+ */
+public interface CouponTemplateCustomerMapper extends BaseMapper<CouponTemplateCustomerDO> {
+
+}
diff --git a/src/main/java/com/mzl/flower/mapper/coupon/CouponTemplateMapper.java b/src/main/java/com/mzl/flower/mapper/coupon/CouponTemplateMapper.java
new file mode 100644
index 0000000..db8ab11
--- /dev/null
+++ b/src/main/java/com/mzl/flower/mapper/coupon/CouponTemplateMapper.java
@@ -0,0 +1,16 @@
+package com.mzl.flower.mapper.coupon;
+
+import com.mzl.flower.entity.coupon.CouponTemplateDO;
+import com.baomidou.mybatisplus.core.mapper.BaseMapper;
+
+/**
+ * <p>
+ * Mapper 接口
+ * </p>
+ *
+ * @author @TaoJie
+ * @since 2024-08-22
+ */
+public interface CouponTemplateMapper extends BaseMapper<CouponTemplateDO> {
+
+}
diff --git a/src/main/java/com/mzl/flower/mapper/coupon/CouponTemplateMapperCustom.java b/src/main/java/com/mzl/flower/mapper/coupon/CouponTemplateMapperCustom.java
new file mode 100644
index 0000000..ba8767d
--- /dev/null
+++ b/src/main/java/com/mzl/flower/mapper/coupon/CouponTemplateMapperCustom.java
@@ -0,0 +1,45 @@
+package com.mzl.flower.mapper.coupon;
+
+import com.baomidou.mybatisplus.core.mapper.BaseMapper;
+import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import com.mzl.flower.dto.request.coupon.BatchCouponTemplateDTO;
+import com.mzl.flower.dto.request.coupon.QueryCouponDTO;
+import com.mzl.flower.dto.response.coupon.CouponTemplateVO;
+import com.mzl.flower.entity.coupon.CouponTemplateDO;
+import org.apache.ibatis.annotations.Param;
+
+import java.util.List;
+
+/**
+ * <p>
+ * Mapper 接口
+ * </p>
+ *
+ * @author @TaoJie
+ * @since 2024-08-22
+ */
+public interface CouponTemplateMapperCustom extends BaseMapper<CouponTemplateDO> {
+
+ /**
+ * 获取普通分页信息
+ * @param page
+ * @param dto
+ * @return
+ */
+ List<CouponTemplateVO> getCouponTemplatePage(Page page,@Param("param") QueryCouponDTO dto);
+
+ /**
+ * 获取普通会员全部列表信息
+ * @param dto
+ * @return
+ */
+ List<CouponTemplateVO> getList(@Param("param") QueryCouponDTO dto);
+
+ int deleteBatchCouponTemplate(@Param("param") BatchCouponTemplateDTO dto);
+
+ int activeBatchCouponTemplate(@Param("param") BatchCouponTemplateDTO dto);
+
+ int expireBatchCouponTemplate(@Param("param") BatchCouponTemplateDTO dto);
+
+
+}
diff --git a/src/main/java/com/mzl/flower/service/coupon/CouponRecordService.java b/src/main/java/com/mzl/flower/service/coupon/CouponRecordService.java
new file mode 100644
index 0000000..a4b5162
--- /dev/null
+++ b/src/main/java/com/mzl/flower/service/coupon/CouponRecordService.java
@@ -0,0 +1,52 @@
+package com.mzl.flower.service.coupon;
+
+import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import com.mzl.flower.dto.request.coupon.CreateCouponRecordDTO;
+import com.mzl.flower.dto.request.coupon.QueryCouponRecordDTO;
+import com.mzl.flower.dto.request.coupon.QueryCouponStatisticsBO;
+import com.mzl.flower.dto.response.coupon.CouponRecordVO;
+import com.mzl.flower.entity.coupon.CouponRecordDO;
+import com.baomidou.mybatisplus.extension.service.IService;
+
+import java.util.List;
+
+/**
+ * <p>
+ * 服务类
+ * </p>
+ *
+ * @author @TaoJie
+ * @since 2024-08-27
+ */
+public interface CouponRecordService extends IService<CouponRecordDO> {
+
+ List<CouponRecordVO> getList(QueryCouponRecordDTO dto) ;
+ boolean createCouponRecord(CreateCouponRecordDTO dto);
+
+ boolean updateCouponRecord(CreateCouponRecordDTO dto);
+
+ boolean deleteCouponRecord(String id);
+
+ CouponRecordVO getCouponRecordById(String id);
+
+ Page<CouponRecordVO> getPage(Page page, QueryCouponRecordDTO dto);
+
+ /**
+ * 会员定时任务
+ * 根据会员等级定时下发刷优惠券
+ * @return
+ */
+ boolean grantVipCouponRecordList();
+
+ /**
+ * 根据当月日期设置上个月的日期的优惠券过期
+ * @return
+ */
+ boolean expiredCouponRecordByListCurMonth();
+
+ int statisCouponTemplateCount(QueryCouponStatisticsBO queryCouponStatisticsBO);
+
+ int statisCouponTemplateCurMonCount(QueryCouponStatisticsBO queryCouponStatisticsBO);
+
+ int statisCouponPointCurMonPontAmonut(QueryCouponStatisticsBO queryCouponStatisticsBO);
+}
diff --git a/src/main/java/com/mzl/flower/service/coupon/CouponTemplateCustomerService.java b/src/main/java/com/mzl/flower/service/coupon/CouponTemplateCustomerService.java
new file mode 100644
index 0000000..bea9410
--- /dev/null
+++ b/src/main/java/com/mzl/flower/service/coupon/CouponTemplateCustomerService.java
@@ -0,0 +1,31 @@
+package com.mzl.flower.service.coupon;
+
+import com.mzl.flower.entity.coupon.CouponTemplateCustomerDO;
+import com.baomidou.mybatisplus.extension.service.IService;
+
+import java.util.List;
+
+/**
+ * <p>
+ * 服务类
+ * </p>
+ *
+ * @author @TaoJie
+ * @since 2024-08-24
+ */
+public interface CouponTemplateCustomerService extends IService<CouponTemplateCustomerDO> {
+
+ /**
+ * 根据优惠券的id查找关联关系
+ * @param couponTemplateId
+ * @return
+ */
+ List<CouponTemplateCustomerDO> getPointCustomReList(String couponTemplateId);
+
+ /**
+ * 根据优惠券的模版id删除关联关系
+ * @param couponTemplateId
+ * @return
+ */
+ boolean deleteByCouponTemplateId(String couponTemplateId);
+}
diff --git a/src/main/java/com/mzl/flower/service/coupon/CouponTemplateService2.java b/src/main/java/com/mzl/flower/service/coupon/CouponTemplateService2.java
new file mode 100644
index 0000000..858c401
--- /dev/null
+++ b/src/main/java/com/mzl/flower/service/coupon/CouponTemplateService2.java
@@ -0,0 +1,66 @@
+package com.mzl.flower.service.coupon;
+
+import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import com.baomidou.mybatisplus.extension.service.IService;
+import com.mzl.flower.dto.request.coupon.*;
+import com.mzl.flower.dto.response.coupon.CouponTemplateVO;
+import com.mzl.flower.entity.coupon.CouponTemplateDO;
+
+import java.util.List;
+
+/**
+ * <p>
+ * 服务类
+ * </p>
+ *
+ * @author @TaoJie
+ * @since 2024-08-22
+ */
+public interface CouponTemplateService2 extends IService<CouponTemplateDO> {
+
+ boolean createCouponTemplate(CreateCouponTemplateBO dto);
+
+
+ boolean updateCouponTemplate(CreateCouponTemplateBO dto);
+
+ List<CouponTemplateVO> getList(QueryCouponDTO dto);
+
+ Page<CouponTemplateVO> getPage(Page page, QueryCouponDTO dto);
+
+ /**
+ * 详情
+ * @param id
+ * @return
+ */
+ CouponTemplateVO getDetailById(String id);
+
+ boolean deleteCouponTemplate(String id);
+
+ boolean activeCouponTemplate(String id);
+ /**
+ * 活动-下架优惠券
+ * @param id
+ * @return
+ */
+ boolean expireCouponTemplate(String id);
+
+
+ /**
+ * 获取所有会员优惠券模版
+ * @return
+ */
+ List<CouponTemplateDO> getVipCouponTemplate();
+
+ boolean deleteBatchCouponTemplate(BatchCouponTemplateDTO dto);
+
+ boolean activeBatchCouponTemplate(BatchCouponTemplateDTO dto);
+
+ boolean expireBatchCouponTemplate(BatchCouponTemplateDTO dto);
+
+ /**
+ * 积分统计
+ * @param queryCouponStatisticsBO
+ * @return
+ */
+ CouponTemplateVO statisCouponTemplatePoint(QueryCouponStatisticsBO queryCouponStatisticsBO);
+}
diff --git a/src/main/java/com/mzl/flower/service/impl/coupon/CouponRecordServiceImpl.java b/src/main/java/com/mzl/flower/service/impl/coupon/CouponRecordServiceImpl.java
new file mode 100644
index 0000000..de6d5f1
--- /dev/null
+++ b/src/main/java/com/mzl/flower/service/impl/coupon/CouponRecordServiceImpl.java
@@ -0,0 +1,288 @@
+package com.mzl.flower.service.impl.coupon;
+
+import cn.hutool.core.util.IdUtil;
+import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
+import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
+import com.mzl.flower.config.exception.ValidationException;
+import com.mzl.flower.config.security.SecurityUtils;
+import com.mzl.flower.dto.request.coupon.CreateCouponRecordDTO;
+import com.mzl.flower.dto.request.coupon.QueryCouponRecordDTO;
+import com.mzl.flower.dto.request.coupon.QueryCouponStatisticsBO;
+import com.mzl.flower.dto.response.coupon.CouponRecordVO;
+import com.mzl.flower.entity.coupon.CouponRecordDO;
+import com.mzl.flower.entity.coupon.CouponTemplateDO;
+import com.mzl.flower.entity.customer.Customer;
+import com.mzl.flower.entity.system.User;
+import com.mzl.flower.enums.CouponCategoryEnum;
+import com.mzl.flower.enums.CouponUsageTimeTypeEnum;
+import com.mzl.flower.enums.CouponUsageTypeEnum;
+import com.mzl.flower.enums.CouponUsedStatusEnum;
+import com.mzl.flower.mapper.coupon.CouponRecordMapper;
+import com.mzl.flower.mapper.coupon.CouponRecordMapperCustom;
+import com.mzl.flower.mapper.customer.CustomerMapper;
+import com.mzl.flower.service.coupon.CouponRecordService;
+import com.mzl.flower.service.coupon.CouponTemplateService2;
+import com.mzl.flower.service.system.UserService;
+import lombok.extern.slf4j.Slf4j;
+import org.apache.commons.collections4.CollectionUtils;
+import org.apache.commons.lang3.StringUtils;
+import org.springframework.beans.BeanUtils;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.stereotype.Service;
+import org.springframework.transaction.annotation.Transactional;
+
+import java.time.LocalDateTime;
+import java.time.temporal.TemporalAdjusters;
+import java.util.List;
+import java.util.stream.Collectors;
+
+/**
+ * <p>
+ * 服务实现类
+ * </p>
+ *
+ * @author @TaoJie
+ * @since 2024-08-27
+ */
+@Slf4j
+@Service
+public class CouponRecordServiceImpl extends ServiceImpl<CouponRecordMapper, CouponRecordDO> implements CouponRecordService {
+
+ @Autowired
+ private CouponRecordMapperCustom couponRecordMapperCustom;
+
+ @Autowired
+ private CouponTemplateService2 couponTemplateService;
+
+ @Autowired
+ private UserService userService;
+
+ @Autowired
+ private CustomerMapper customerMapper;
+
+ @Override
+ public List<CouponRecordVO> getList(QueryCouponRecordDTO dto) {
+ return couponRecordMapperCustom.getList(dto);
+ }
+
+ @Override
+ public boolean createCouponRecord(CreateCouponRecordDTO dto) {
+
+ final Customer customer = customerMapper.selectById(dto.getCustomerId());
+ if(null==customer){
+ throw new ValidationException("商户信息不存在");
+ }
+
+ CouponRecordDO couponRecordDO=new CouponRecordDO();
+ BeanUtils.copyProperties(dto,couponRecordDO);
+ couponRecordDO.create(SecurityUtils.getUserId());
+ // 设置为待使用状态
+ couponRecordDO.setStatus(CouponUsedStatusEnum.UNUSED.getType());
+
+ // 优惠券字段冗余
+ final CouponTemplateDO couponTemplateDO = couponTemplateService.getById(dto.getCouponId());
+ if(null!=couponTemplateDO){
+ couponRecordDO.setCategory(couponTemplateDO.getGetUserType());
+ couponRecordDO.setCouponCode(couponTemplateDO.getCouponCode());
+ couponRecordDO.setCouponName(couponTemplateDO.getCouponName());
+ couponRecordDO.setCouponDiscountValue(couponTemplateDO.getCouponDiscountValue());
+ couponRecordDO.setMinOrderAmount(couponTemplateDO.getMinOrderAmount());
+ couponRecordDO.setGetType(couponTemplateDO.getGetType());
+ couponRecordDO.setCouponDiscountType(couponTemplateDO.getCouponDiscountType());
+ couponRecordDO.setGetUserType(couponTemplateDO.getGetUserType());
+ couponRecordDO.setPoint(couponTemplateDO.getPoint());
+
+
+ // 根据优惠券模板来计算优惠券的生效开始时间和结束时间
+ if(StringUtils.isNotBlank(couponTemplateDO.getCategory()) && couponTemplateDO.getCategory().equals(CouponCategoryEnum.MEMBER.getStatus())){
+ // 如果是会员优惠券的话,则设置为优惠券的使用条件为优惠券的时间
+ couponRecordDO.setEffectiveStart(couponTemplateDO.getUsageStartDate());
+ couponRecordDO.setEffectiveEnd(couponTemplateDO.getUsageEndDate());
+ }else{
+ // 非会员的根据领取时间类型来计算优惠券的时间
+ if(StringUtils.isNotBlank(couponTemplateDO.getUsageType()) && couponTemplateDO.getUsageType().equals(CouponUsageTypeEnum.GET.getType())){
+ // 与领取时间一致
+ couponRecordDO.setEffectiveStart(couponTemplateDO.getGetStartDate());
+ couponRecordDO.setEffectiveEnd(couponTemplateDO.getGetEndDate());
+ }
+ if(StringUtils.isNotBlank(couponTemplateDO.getUsageType()) && couponTemplateDO.getUsageType().equals(CouponUsageTypeEnum.FIXED.getType())){
+ // 固定时间
+ couponRecordDO.setEffectiveStart(couponTemplateDO.getUsageStartDate());
+ couponRecordDO.setEffectiveEnd(couponTemplateDO.getUsageEndDate());
+ }
+ if(StringUtils.isNotBlank(couponTemplateDO.getUsageType()) && couponTemplateDO.getUsageType().equals(CouponUsageTypeEnum.GET_AFTER_TIME.getType())){
+ // 领取后有段时间 领取后有效时间
+ // 根据发放后有效期来设置时间
+ if (couponTemplateDO.getUsageTimeNum() == null || couponTemplateDO.getUsageTimeNum() <= 0) {
+ throw new IllegalArgumentException("使用时间数量必须为正整数");
+ }
+ LocalDateTime currentTime = LocalDateTime.now();
+ couponRecordDO.setEffectiveStart(currentTime);
+ if (couponTemplateDO.getUsageTimeType().equals(CouponUsageTimeTypeEnum.DAY.getType())) {
+ // 天
+ couponRecordDO.setEffectiveEnd(currentTime.plusDays(couponTemplateDO.getUsageTimeNum()));
+ }
+ if (couponTemplateDO.getUsageTimeType().equals(CouponUsageTimeTypeEnum.HOUR.getType())) {
+ // 小时
+ couponRecordDO.setEffectiveEnd(currentTime.plusDays(couponTemplateDO.getUsageTimeNum()));
+ }
+ if (couponTemplateDO.getUsageTimeType().equals(CouponUsageTimeTypeEnum.MINUTE.getType())) {
+ // 分钟
+ couponRecordDO.setEffectiveEnd(currentTime.plusDays(couponTemplateDO.getUsageTimeNum()));
+ }
+
+ }
+ }
+
+ }
+
+
+ return baseMapper.insert(couponRecordDO)>0;
+ }
+
+ @Override
+ public boolean updateCouponRecord(CreateCouponRecordDTO dto) {
+ CouponRecordDO couponRecordDO=baseMapper.selectById(dto.getId());
+ BeanUtils.copyProperties(dto,couponRecordDO);
+ couponRecordDO.update(SecurityUtils.getUserId());
+
+ // 优惠券字段冗余
+ final CouponTemplateDO couponTemplateDO = couponTemplateService.getById(dto.getCouponId());
+ if(null!=couponTemplateDO){
+ couponRecordDO.setCategory(couponTemplateDO.getGetUserType());
+ couponRecordDO.setCouponCode(couponTemplateDO.getCouponCode());
+ couponRecordDO.setCouponName(couponTemplateDO.getCouponName());
+ couponRecordDO.setCouponDiscountValue(couponTemplateDO.getCouponDiscountValue());
+ couponRecordDO.setMinOrderAmount(couponTemplateDO.getMinOrderAmount());
+ }
+
+
+ return baseMapper.updateById(couponRecordDO)>0;
+ }
+
+ @Override
+ public boolean deleteCouponRecord(String id) {
+ return baseMapper.deleteById(id)>0;
+ }
+
+ @Override
+ public CouponRecordVO getCouponRecordById(String id) {
+ QueryCouponRecordDTO dto=new QueryCouponRecordDTO();
+ dto.setId(id);
+ final List<CouponRecordVO> list = couponRecordMapperCustom.getList(dto);
+ if(CollectionUtils.isNotEmpty(list)){
+ return list.get(0);
+ }
+ return null;
+ }
+
+ @Override
+ public Page<CouponRecordVO> getPage(Page page, QueryCouponRecordDTO dto) {
+ List<CouponRecordVO> result=couponRecordMapperCustom.getPage(page,dto);
+ return page.setRecords(result);
+ }
+
+ @Transactional
+ @Override
+ public boolean grantVipCouponRecordList() {
+
+ try{
+ LocalDateTime now = LocalDateTime.now();
+ LocalDateTime firstDayStart = now.with(TemporalAdjusters.firstDayOfMonth()).withHour(0).withMinute(0).withSecond(0).withNano(0);
+ LocalDateTime lastDayEnd = now.with(TemporalAdjusters.lastDayOfMonth()).withHour(23).withMinute(59).withSecond(59).withNano(0);
+
+ // 获取所有会员模版列表
+ List<CouponTemplateDO> vipTemplateList= couponTemplateService.getVipCouponTemplate();
+
+ // 遍历所有相同等级用户信息,并根据优惠券设置的规则构造优惠券
+ final List<CouponTemplateDO> updateCouponTemplateList = vipTemplateList.stream().map(couponTemplateDO -> {
+ final List<User> vipGradeUserList = userService.getVipGradeUserList(couponTemplateDO.getVipGrade());
+ final List<CouponRecordDO> gradeCouponRecordList = vipGradeUserList.stream().map(user -> {
+ CouponRecordDO couponRecordDO = new CouponRecordDO();
+ BeanUtils.copyProperties(couponTemplateDO, couponRecordDO);
+ couponRecordDO.setId(IdUtil.simpleUUID());
+ couponRecordDO.setCouponId(couponTemplateDO.getId());
+ couponRecordDO.setUserId(user.getId());
+ couponRecordDO.setStatus(CouponUsedStatusEnum.UNUSED.getType());
+ couponRecordDO.setEffectiveStart(firstDayStart);
+ couponRecordDO.setEffectiveEnd(lastDayEnd);
+
+ // 创建信息
+ couponRecordDO.create();
+ return couponRecordDO;
+ }).collect(Collectors.toList());
+
+ // 批量保存等级下的优惠券信息
+ saveBatch(gradeCouponRecordList);
+
+ couponTemplateDO.setUsageStartDate(firstDayStart);
+ couponTemplateDO.setUsageEndDate(lastDayEnd);
+ couponTemplateDO.setGetStartDate(firstDayStart);
+ couponTemplateDO.setGetEndDate(lastDayEnd);
+
+ // 设置默认类型固定
+ couponTemplateDO.setUsageType(CouponUsageTypeEnum.FIXED.getType());
+
+ return couponTemplateDO;
+
+ }).collect(Collectors.toList());
+
+ // 批量更新原模版时间
+ couponTemplateService.updateBatchById(updateCouponTemplateList);
+
+ return true;
+ }catch (Exception e){
+ // 报错日志信息报错
+ log.error(e.getMessage());
+ return false;
+ }
+ }
+
+ @Override
+ public boolean expiredCouponRecordByListCurMonth() {
+
+ try{
+ LocalDateTime now = LocalDateTime.now();
+ LocalDateTime firstDayStart = now.with(TemporalAdjusters.firstDayOfMonth()).withHour(0).withMinute(0).withSecond(0).withNano(0);
+ LocalDateTime lastDayEnd = now.with(TemporalAdjusters.lastDayOfMonth()).withHour(23).withMinute(59).withSecond(59).withNano(0);
+
+ // 只要找出时间小于当月的首天的设置成过期就可以
+
+ QueryWrapper<CouponRecordDO> queryWrapper=new QueryWrapper<>();
+ queryWrapper.lambda().eq(CouponRecordDO::getOrderId,"")
+ .lt(CouponRecordDO::getEffectiveEnd,firstDayStart);
+
+ final List<CouponRecordDO> couponRecordDOS = baseMapper.selectList(queryWrapper);
+
+ final List<CouponRecordDO> expiredCouponRecordList = couponRecordDOS.stream().map(couponRecordDO -> {
+ couponRecordDO.setStatus(CouponUsedStatusEnum.EXPIRED.getType());
+ return couponRecordDO;
+ }).collect(Collectors.toList());
+
+ //更新
+ updateBatchById(expiredCouponRecordList);
+
+ return true;
+ }catch (Exception e){
+ log.error(e.getMessage());
+ return false;
+ }
+
+
+ }
+
+ @Override
+ public int statisCouponTemplateCount(QueryCouponStatisticsBO queryCouponStatisticsBO) {
+ return couponRecordMapperCustom.statisCouponTemplateCount(queryCouponStatisticsBO);
+ }
+ @Override
+ public int statisCouponTemplateCurMonCount(QueryCouponStatisticsBO queryCouponStatisticsBO) {
+ return couponRecordMapperCustom.statisCouponTemplateCurMonCount(queryCouponStatisticsBO);
+ }
+
+ @Override
+ public int statisCouponPointCurMonPontAmonut(QueryCouponStatisticsBO queryCouponStatisticsBO) {
+ return couponRecordMapperCustom.statisCouponPointCurMonPointAmonut(queryCouponStatisticsBO);
+ }
+}
diff --git a/src/main/java/com/mzl/flower/service/impl/coupon/CouponTemplateCustomerServiceImpl.java b/src/main/java/com/mzl/flower/service/impl/coupon/CouponTemplateCustomerServiceImpl.java
new file mode 100644
index 0000000..df405c4
--- /dev/null
+++ b/src/main/java/com/mzl/flower/service/impl/coupon/CouponTemplateCustomerServiceImpl.java
@@ -0,0 +1,36 @@
+package com.mzl.flower.service.impl.coupon;
+
+import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
+import com.mzl.flower.entity.coupon.CouponTemplateCustomerDO;
+import com.mzl.flower.mapper.coupon.CouponTemplateCustomerMapper;
+import com.mzl.flower.service.coupon.CouponTemplateCustomerService;
+import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
+import org.springframework.stereotype.Service;
+
+import java.util.List;
+
+/**
+ * <p>
+ * 服务实现类
+ * </p>
+ *
+ * @author @TaoJie
+ * @since 2024-08-24
+ */
+@Service
+public class CouponTemplateCustomerServiceImpl extends ServiceImpl<CouponTemplateCustomerMapper, CouponTemplateCustomerDO> implements CouponTemplateCustomerService {
+
+ @Override
+ public List<CouponTemplateCustomerDO> getPointCustomReList(String id) {
+ QueryWrapper<CouponTemplateCustomerDO> queryWrapper=new QueryWrapper<>();
+ queryWrapper.lambda().eq(CouponTemplateCustomerDO::getCouponId,id);
+ return baseMapper.selectList(queryWrapper);
+ }
+
+ @Override
+ public boolean deleteByCouponTemplateId(String couponTemplateId) {
+ QueryWrapper<CouponTemplateCustomerDO> queryWrapper=new QueryWrapper<>();
+ queryWrapper.lambda().eq(CouponTemplateCustomerDO::getCouponId,couponTemplateId);
+ return baseMapper.delete(queryWrapper)>0;
+ }
+}
diff --git a/src/main/java/com/mzl/flower/service/impl/coupon/CouponTemplateServiceImpl2.java b/src/main/java/com/mzl/flower/service/impl/coupon/CouponTemplateServiceImpl2.java
new file mode 100644
index 0000000..d64b382
--- /dev/null
+++ b/src/main/java/com/mzl/flower/service/impl/coupon/CouponTemplateServiceImpl2.java
@@ -0,0 +1,311 @@
+package com.mzl.flower.service.impl.coupon;
+
+import cn.hutool.core.util.IdUtil;
+import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
+import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
+import com.mzl.flower.config.security.SecurityUtils;
+import com.mzl.flower.dto.request.coupon.*;
+import com.mzl.flower.dto.response.coupon.CouponTemplateVO;
+import com.mzl.flower.entity.coupon.CouponRecordDO;
+import com.mzl.flower.entity.coupon.CouponTemplateCustomerDO;
+import com.mzl.flower.entity.coupon.CouponTemplateDO;
+import com.mzl.flower.entity.customer.Customer;
+import com.mzl.flower.enums.*;
+import com.mzl.flower.mapper.coupon.CouponTemplateMapper;
+import com.mzl.flower.mapper.coupon.CouponTemplateMapperCustom;
+import com.mzl.flower.mapper.customer.CustomerMapper;
+import com.mzl.flower.service.coupon.CouponRecordService;
+import com.mzl.flower.service.coupon.CouponTemplateCustomerService;
+import com.mzl.flower.service.coupon.CouponTemplateService2;
+import com.mzl.flower.service.payment.OrderService;
+import org.apache.commons.collections4.CollectionUtils;
+import org.apache.commons.lang3.StringUtils;
+import org.springframework.beans.BeanUtils;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.stereotype.Service;
+import org.springframework.transaction.annotation.Transactional;
+
+import java.time.LocalDateTime;
+import java.util.List;
+import java.util.stream.Collectors;
+
+/**
+ * <p>
+ * 服务实现类
+ * </p>
+ *
+ * @author @TaoJie
+ * @since 2024-08-22
+ */
+@Service
+public class CouponTemplateServiceImpl2 extends ServiceImpl<CouponTemplateMapper, CouponTemplateDO> implements CouponTemplateService2 {
+
+ @Autowired
+ private CouponTemplateMapperCustom couponTemplateMapperCustom;
+
+ @Autowired
+ private CouponTemplateCustomerService pointCustomReService;
+
+ @Autowired
+ private CouponRecordService couponRecordService;
+
+ @Autowired
+ private CustomerMapper customerMapper;
+
+ @Autowired
+ private OrderService orderService;
+
+ @Transactional
+ @Override
+ public boolean createCouponTemplate(CreateCouponTemplateBO dto) {
+ CouponTemplateDO couponTemplateDO = new CouponTemplateDO();
+ BeanUtils.copyProperties(dto, couponTemplateDO);
+ // 设置id,关联使用到的id
+ couponTemplateDO.setId(IdUtil.simpleUUID());
+
+ couponTemplateDO.create(SecurityUtils.getUserId());
+ if (StringUtils.isBlank(dto.getStatus())) {
+ // 优惠券状态 初始化为未激活状态
+ couponTemplateDO.setStatus(CouponStatusEnum.INACTIVE.getStatus());
+ }
+
+ // 指定会员:需要添加制定用户的关联信息
+ if (CollectionUtils.isNotEmpty(dto.getPointCostomIdList())) {
+
+ final List<CouponTemplateCustomerDO> couponCustomList = dto.getPointCostomIdList().stream().map(customId -> {
+ CouponTemplateCustomerDO customReDO = new CouponTemplateCustomerDO();
+ customReDO.setCouponId(couponTemplateDO.getId());
+ customReDO.setCustomId(customId);
+ return customReDO;
+ }).collect(Collectors.toList());
+
+ // 批量插入 优惠券与指定用户关联关系
+ pointCustomReService.saveBatch(couponCustomList);
+
+ // 设置优惠券的数量
+ couponTemplateDO.setCouponAmount(dto.getPointCostomIdList().size());
+
+ }
+
+ return baseMapper.insert(couponTemplateDO) > 0;
+ }
+
+ @Transactional
+ @Override
+ public boolean updateCouponTemplate(CreateCouponTemplateBO dto) {
+ CouponTemplateDO couponTemplateDO = baseMapper.selectById(dto.getId());
+ BeanUtils.copyProperties(dto, couponTemplateDO);
+ couponTemplateDO.update(SecurityUtils.getUserId());
+
+ if (CollectionUtils.isNotEmpty(dto.getPointCostomIdList())) {
+ // 根据优惠券的信息删除关联信息
+ pointCustomReService.deleteByCouponTemplateId(couponTemplateDO.getId());
+ }
+ // 指定会员:需要添加制定用户的关联信息
+ if (CollectionUtils.isNotEmpty(dto.getPointCostomIdList())) {
+
+ final List<CouponTemplateCustomerDO> couponCustomList = dto.getPointCostomIdList().stream().map(customId -> {
+ CouponTemplateCustomerDO customReDO = new CouponTemplateCustomerDO();
+ customReDO.setCouponId(couponTemplateDO.getId());
+ customReDO.setCustomId(customId);
+ return customReDO;
+ }).collect(Collectors.toList());
+
+ // 批量插入 优惠券与指定用户关联关系
+ pointCustomReService.saveBatch(couponCustomList);
+
+ // 设置优惠券总数当前人数
+ couponTemplateDO.setCouponAmount(couponCustomList.size());
+
+ }
+
+
+ return baseMapper.updateById(couponTemplateDO) > 0;
+ }
+
+ @Override
+ public List<CouponTemplateVO> getList(QueryCouponDTO dto) {
+
+ List<CouponTemplateVO> list = couponTemplateMapperCustom.getList(dto);
+ return list;
+ }
+
+ @Override
+ public Page<CouponTemplateVO> getPage(Page page, QueryCouponDTO dto) {
+ List<CouponTemplateVO> result = couponTemplateMapperCustom.getCouponTemplatePage(page, dto);
+ return page.setRecords(result);
+ }
+
+ @Override
+ public CouponTemplateVO getDetailById(String id) {
+ QueryCouponDTO dto = new QueryCouponDTO();
+ dto.setId(id);
+ final List<CouponTemplateVO> list = getList(dto);
+ if (CollectionUtils.isNotEmpty(list)) {
+ return list.get(0);
+ }
+ return null;
+ }
+
+ @Transactional
+ @Override
+ public boolean deleteCouponTemplate(String id) {
+ return baseMapper.deleteById(id) > 0;
+ }
+
+ @Transactional
+ @Override
+ public boolean activeCouponTemplate(String id) {
+
+ CouponTemplateDO couponTemplateDO = baseMapper.selectById(id);
+ couponTemplateDO.setStatus(CouponStatusEnum.ACTIVE.getStatus());
+
+ // 判断当前的优惠券的用户类型是指定用户还是全部用户,如果是指定用户的情况下需要发布优惠券
+ if (StringUtils.isNotBlank(couponTemplateDO.getGetUserType())
+ && StringUtils.isNotBlank(couponTemplateDO.getCategory())
+ && couponTemplateDO.getGetUserType().equals(CouponGetUserTypeEnum.POINT.getType())
+ && couponTemplateDO.getCategory().equals(CouponCategoryEnum.USER.getStatus())
+ ) {
+
+ // 获取当前优惠券下的指定人员信息
+ List<CouponTemplateCustomerDO> couponTemplateCustomerDOList = pointCustomReService.getPointCustomReList(id);
+
+ if (CollectionUtils.isNotEmpty(couponTemplateCustomerDOList)) {
+
+ // 根据发放后有效期来设置时间
+ if (couponTemplateDO.getUsageTimeNum() == null || couponTemplateDO.getUsageTimeNum() <= 0) {
+ throw new IllegalArgumentException("使用时间数量必须为正整数");
+ }
+ LocalDateTime currentTime = LocalDateTime.now();
+ couponTemplateDO.setUsageStartDate(currentTime);
+ if (couponTemplateDO.getUsageTimeType().equals(CouponUsageTimeTypeEnum.DAY.getType())) {
+ // 天
+ couponTemplateDO.setUsageEndDate(currentTime.plusDays(couponTemplateDO.getUsageTimeNum()));
+ }
+ if (couponTemplateDO.getUsageTimeType().equals(CouponUsageTimeTypeEnum.HOUR.getType())) {
+ // 小时
+ couponTemplateDO.setUsageEndDate(currentTime.plusDays(couponTemplateDO.getUsageTimeNum()));
+ }
+ if (couponTemplateDO.getUsageTimeType().equals(CouponUsageTimeTypeEnum.MINUTE.getType())) {
+ // 分钟
+ couponTemplateDO.setUsageEndDate(currentTime.plusDays(couponTemplateDO.getUsageTimeNum()));
+ }
+
+ // 优惠券的总数等于下发人员的总数
+ couponTemplateDO.setCouponAmount(couponTemplateCustomerDOList.size());
+
+ List<CouponRecordDO> couponUsageDOList = couponTemplateCustomerDOList.stream().map(pointCustomRe -> {
+
+ CouponRecordDO couponRecordDO = new CouponRecordDO();
+ couponRecordDO.setCouponId(pointCustomRe.getCouponId());
+ couponRecordDO.setCustomerId(pointCustomRe.getCustomId());
+ final Customer customer = customerMapper.selectById(pointCustomRe.getCustomId());
+ if (null != customer && StringUtils.isNotBlank(customer.getUserId())) {
+ // 设置所属用户id
+ couponRecordDO.setUserId(customer.getUserId());
+ }
+ couponRecordDO.setStatus(CouponUsedStatusEnum.UNUSED.getType());
+
+ // 设置优惠券的使用开始时间
+ couponRecordDO.setEffectiveStart(couponTemplateDO.getUsageStartDate());
+ // 设置优惠券的使用结束时间
+ couponRecordDO.setEffectiveEnd(couponTemplateDO.getUsageEndDate());
+
+ // 优惠券的冗余字段
+ couponRecordDO.setCouponCode(couponTemplateDO.getCouponCode());
+ couponRecordDO.setCouponName(couponTemplateDO.getCouponName());
+ // 优惠券种类
+ couponRecordDO.setCategory(couponTemplateDO.getGetUserType());
+ couponRecordDO.setMinOrderAmount(couponTemplateDO.getMinOrderAmount());
+ couponRecordDO.setCouponDiscountValue(couponTemplateDO.getCouponDiscountValue());
+ couponRecordDO.setGetType(couponTemplateDO.getGetType());
+ couponRecordDO.setCouponDiscountType(couponTemplateDO.getCouponDiscountType());
+ couponRecordDO.setGetUserType(couponTemplateDO.getGetUserType());
+ couponRecordDO.setPoint(couponTemplateDO.getPoint());
+
+ // 创建相关信息
+ couponRecordDO.create(SecurityUtils.getUserId());
+
+ return couponRecordDO;
+ }).collect(Collectors.toList());
+
+ // 批量保存优惠券信息
+ couponRecordService.saveBatch(couponUsageDOList);
+ }
+ }
+ return baseMapper.updateById(couponTemplateDO) > 0;
+ }
+
+ @Transactional
+ @Override
+ public boolean expireCouponTemplate(String id) {
+ CouponTemplateDO couponTemplateDO = baseMapper.selectById(id);
+ couponTemplateDO.setStatus(CouponStatusEnum.EXPIRED.getStatus());
+ return baseMapper.updateById(couponTemplateDO) > 0;
+ }
+
+ /**
+ * 获取所有会员优惠券模版
+ *
+ * @return
+ */
+ @Transactional
+ @Override
+ public List<CouponTemplateDO> getVipCouponTemplate() {
+ QueryWrapper<CouponTemplateDO> queryWrapper = new QueryWrapper<>();
+ queryWrapper.lambda()
+ .eq(CouponTemplateDO::getDeleted, TrueOrFalseEnum.FALSE.isFlag())
+ .eq(CouponTemplateDO::getCategory, CouponCategoryEnum.MEMBER.getStatus())
+ .eq(CouponTemplateDO::getStatus, CouponStatusEnum.ACTIVE.getStatus());
+
+ return baseMapper.selectList(queryWrapper);
+
+ }
+
+ @Transactional
+ @Override
+ public boolean deleteBatchCouponTemplate(BatchCouponTemplateDTO dto) {
+
+ if (CollectionUtils.isNotEmpty(dto.getIdList())) {
+ dto.setUpdateBy(SecurityUtils.getUserId());
+ return couponTemplateMapperCustom.deleteBatchCouponTemplate(dto) > 0;
+ }
+ return false;
+ }
+
+ @Transactional
+ @Override
+ public boolean activeBatchCouponTemplate(BatchCouponTemplateDTO dto) {
+ if (CollectionUtils.isNotEmpty(dto.getIdList())) {
+ dto.setUpdateBy(SecurityUtils.getUserId());
+ return couponTemplateMapperCustom.activeBatchCouponTemplate(dto) > 0;
+ }
+ return false;
+ }
+
+ @Transactional
+ @Override
+ public boolean expireBatchCouponTemplate(BatchCouponTemplateDTO dto) {
+ if (CollectionUtils.isNotEmpty(dto.getIdList())) {
+ dto.setUpdateBy(SecurityUtils.getUserId());
+ return couponTemplateMapperCustom.expireBatchCouponTemplate(dto) > 0;
+ }
+ return false;
+ }
+
+ @Override
+ public CouponTemplateVO statisCouponTemplatePoint(QueryCouponStatisticsBO queryCouponStatisticsBO) {
+
+ //TODO 优惠券总数
+ couponRecordService.statisCouponTemplateCount(queryCouponStatisticsBO);
+
+ //TODO 本月兑换优惠券总数
+ couponRecordService.statisCouponTemplateCurMonCount(queryCouponStatisticsBO);
+
+ //TODO 本月兑换积分总数
+ couponRecordService.statisCouponPointCurMonPontAmonut(queryCouponStatisticsBO);
+
+ return null;
+ }
+}
diff --git a/src/main/java/com/mzl/flower/utils/ConverterUtil.java b/src/main/java/com/mzl/flower/utils/ConverterUtil.java
new file mode 100644
index 0000000..dfca4e6
--- /dev/null
+++ b/src/main/java/com/mzl/flower/utils/ConverterUtil.java
@@ -0,0 +1,73 @@
+package com.mzl.flower.utils;
+
+import org.springframework.beans.BeanUtils;
+import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+
+import java.util.ArrayList;
+import java.util.List;
+import java.util.Objects;
+import java.util.stream.Collectors;
+
+public class ConverterUtil {
+
+ /**
+ * 单个对象的转换
+ * @param source 源对象
+ * @param targetClass 目标类的类型
+ * @param <T> 源类型
+ * @param <R> 目标类型
+ * @return 转换后的目标对象
+ */
+ public static <T, R> R transObject(T source, Class<R> targetClass) {
+ if (source == null) {
+ return null;
+ }
+ try {
+ R targetObject = targetClass.getDeclaredConstructor().newInstance();
+ BeanUtils.copyProperties(source, targetObject);
+ return targetObject;
+ } catch (Exception e) {
+ throw new RuntimeException("对象转换失败", e);
+ }
+ }
+
+ /**
+ * List对象的转换
+ * @param sourceList 源List对象
+ * @param targetClass 目标类的类型
+ * @param <T> 源类型
+ * @param <R> 目标类型
+ * @return 转换后的目标List对象
+ */
+ public static <T, R> List<R> transList(List<T> sourceList, Class<R> targetClass) {
+ if (sourceList == null || sourceList.isEmpty()) {
+ return new ArrayList<>();
+ }
+ return sourceList.stream()
+ .filter(Objects::nonNull)
+ .map(sourceObject -> transObject(sourceObject, targetClass))
+ .collect(Collectors.toList());
+ }
+
+ /**
+ * Page对象的转换
+ * @param sourcePage 源Page对象
+ * @param targetClass 目标类的类型
+ * @param <T> 源类型
+ * @param <R> 目标类型
+ * @return 转换后的目标Page对象
+ */
+ public static <T, R> Page<R> transPage(Page<T> sourcePage, Class<R> targetClass) {
+ if (sourcePage == null) {
+ return new Page<>();
+ }
+
+ // 创建一个新的 Page 对象用于存放转换后的目标类型对象
+ Page<R> targetPage = new Page<>(sourcePage.getCurrent(), sourcePage.getSize(), sourcePage.getTotal());
+
+ // 转换列表并设置到 Page 对象中
+ List<R> targetList = transList(sourcePage.getRecords(), targetClass);
+ targetPage.setRecords(targetList);
+ return targetPage;
+ }
+}
diff --git a/src/main/java/com/mzl/flower/web/v2/coupon/CouponRecordController.java b/src/main/java/com/mzl/flower/web/v2/coupon/CouponRecordController.java
new file mode 100644
index 0000000..8a137ef
--- /dev/null
+++ b/src/main/java/com/mzl/flower/web/v2/coupon/CouponRecordController.java
@@ -0,0 +1,114 @@
+package com.mzl.flower.web.v2.coupon;
+
+
+import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import com.mzl.flower.base.BaseController;
+import com.mzl.flower.base.R;
+import com.mzl.flower.base.ReturnDataDTO;
+import com.mzl.flower.config.exception.ValidationException;
+import com.mzl.flower.dto.request.coupon.CreateCouponRecordDTO;
+import com.mzl.flower.dto.request.coupon.QueryCouponRecordDTO;
+import com.mzl.flower.dto.response.coupon.CouponRecordResultVO;
+import com.mzl.flower.dto.response.coupon.CouponRecordVO;
+import com.mzl.flower.entity.coupon.CouponRecordDO;
+import com.mzl.flower.entity.coupon.CouponTemplateDO;
+import com.mzl.flower.enums.CouponStatusEnum;
+import com.mzl.flower.service.coupon.CouponRecordService;
+import com.mzl.flower.service.coupon.CouponTemplateService2;
+import com.mzl.flower.utils.ConverterUtil;
+import io.swagger.annotations.Api;
+import io.swagger.annotations.ApiOperation;
+import org.apache.commons.lang3.StringUtils;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.http.ResponseEntity;
+import org.springframework.validation.annotation.Validated;
+import org.springframework.web.bind.annotation.*;
+
+
+/**
+* @author @TaoJie
+* @since 2024-08-27
+*/
+@RestController
+@RequestMapping("/v2/coupon-record")
+@Api(value = "优惠券记录管理-活动", tags = "优惠券记录管理")
+@Validated
+public class CouponRecordController extends BaseController {
+
+ @Autowired
+ CouponRecordService couponRecordService;
+
+ @Autowired
+ private CouponTemplateService2 couponTemplateService;
+
+
+
+ @PostMapping("")
+ @ApiOperation(value = "新增", notes = "新增")
+ public ResponseEntity<ReturnDataDTO> create(@Validated @RequestBody CreateCouponRecordDTO dto) {
+
+ final CouponTemplateDO couponTemplateDO = couponTemplateService.getById(dto.getCouponId());
+ if(null==couponTemplateDO){
+ throw new ValidationException("优惠券不存在");
+ }
+
+ if(StringUtils.isNotBlank(couponTemplateDO.getStatus()) && !couponTemplateDO.getStatus().equals(CouponStatusEnum.INACTIVE.getStatus())){
+ throw new ValidationException("优惠券还未发布");
+ }
+ if(StringUtils.isNotBlank(couponTemplateDO.getStatus()) && !couponTemplateDO.getStatus().equals(CouponStatusEnum.EXPIRED.getStatus())){
+ throw new ValidationException("优惠券已下架");
+ }
+
+
+ couponRecordService.createCouponRecord(dto);
+ return returnData(R.SUCCESS.getCode(), null);
+ }
+
+ @PutMapping("/{id}")
+ @ApiOperation(value = "修改", notes = "修改")
+ public ResponseEntity<ReturnDataDTO> update(@Validated @RequestBody CreateCouponRecordDTO dto) {
+
+ CouponRecordDO couponRecordDO= couponRecordService.getById(dto.getId());
+ if(null==couponRecordDO){
+ throw new ValidationException("优惠券记录不存在");
+ }
+
+ return returnData(R.SUCCESS.getCode(), couponRecordService.updateCouponRecord(dto));
+ }
+
+ @DeleteMapping("/{id}")
+ @ApiOperation(value = "删除", notes = "删除")
+ public ResponseEntity<ReturnDataDTO> delete(@PathVariable String id ) {
+
+ CouponRecordDO couponRecordDO= couponRecordService.getById(id);
+ if(null==couponRecordDO){
+ throw new ValidationException("优惠券记录不存在");
+ }
+ couponRecordService.deleteCouponRecord(id);
+ return returnData(R.SUCCESS.getCode(), null);
+ }
+
+ @GetMapping("/{id}")
+ @ApiOperation(value = "详情", notes = "详情")
+ public ResponseEntity<ReturnDataDTO> get(@PathVariable String id) {
+ CouponRecordVO couponRecordVO=couponRecordService.getCouponRecordById(id);
+ return returnData(R.SUCCESS.getCode(),ConverterUtil.transObject(couponRecordVO, CouponRecordResultVO.class));
+ }
+
+ @GetMapping("/page")
+ @ApiOperation(value = "查询-分页", notes = "查询-分页")
+ public ResponseEntity<ReturnDataDTO<Page<CouponRecordVO>>> page(
+ Page page, QueryCouponRecordDTO dto
+ ) {
+ return returnData(R.SUCCESS.getCode(), ConverterUtil.transPage(couponRecordService.getPage(page,dto), CouponRecordResultVO.class));
+ }
+
+ @GetMapping("/list")
+ @ApiOperation(value = "查询-全部", notes = "查询-全部")
+ public ResponseEntity<ReturnDataDTO<Page<CouponRecordVO>>> list(QueryCouponRecordDTO dto
+ ) {
+ return returnData(R.SUCCESS.getCode(),ConverterUtil.transList(couponRecordService.getList(dto), CouponRecordResultVO.class));
+
+ }
+
+}
\ No newline at end of file
diff --git a/src/main/java/com/mzl/flower/web/v2/coupon/CouponTemplateActivyController.java b/src/main/java/com/mzl/flower/web/v2/coupon/CouponTemplateActivyController.java
new file mode 100644
index 0000000..b0d20bc
--- /dev/null
+++ b/src/main/java/com/mzl/flower/web/v2/coupon/CouponTemplateActivyController.java
@@ -0,0 +1,202 @@
+package com.mzl.flower.web.v2.coupon;
+
+
+import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import com.mzl.flower.base.BaseController;
+import com.mzl.flower.base.R;
+import com.mzl.flower.base.ReturnDataDTO;
+import com.mzl.flower.config.exception.ValidationException;
+import com.mzl.flower.dto.request.coupon.*;
+import com.mzl.flower.dto.response.coupon.CouponTemplateActivyVO;
+import com.mzl.flower.dto.response.coupon.CouponTemplatePointVO;
+import com.mzl.flower.dto.response.coupon.CouponTemplateVO;
+import com.mzl.flower.entity.coupon.CouponTemplateDO;
+import com.mzl.flower.enums.CouponCategoryEnum;
+import com.mzl.flower.enums.CouponGetUserTypeEnum;
+import com.mzl.flower.enums.CouponTypeEnum;
+import com.mzl.flower.enums.CouponUsageTypeEnum;
+import com.mzl.flower.service.coupon.CouponTemplateService2;
+import com.mzl.flower.utils.ConverterUtil;
+import io.swagger.annotations.Api;
+import io.swagger.annotations.ApiOperation;
+import org.apache.commons.lang3.StringUtils;
+import org.springframework.beans.BeanUtils;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.http.ResponseEntity;
+import org.springframework.validation.annotation.Validated;
+import org.springframework.web.bind.annotation.*;
+
+import java.math.BigDecimal;
+
+
+/**
+ * @author @TaoJie
+ * @since 2024-08-22
+ */
+@RestController
+@RequestMapping("/api/v2/coupon/avtivy")
+@Api(value = "优惠券管理-活动", tags = "优惠券管理-活动")
+@Validated
+public class CouponTemplateActivyController extends BaseController {
+
+ @Autowired
+ CouponTemplateService2 couponTemplateService;
+
+ @PostMapping("")
+ @ApiOperation(value = "新增", notes = "新增")
+ public ResponseEntity<ReturnDataDTO> create(@Validated @RequestBody CreateCouponTemplateActivyDTO dto) {
+
+ // 信息验证
+ valid(dto);
+
+ CreateCouponTemplateBO couponTemplateBO = new CreateCouponTemplateBO();
+ BeanUtils.copyProperties(dto, couponTemplateBO);
+
+ // 设置成积分优惠券
+ couponTemplateBO.setCategory(CouponCategoryEnum.ACTIVITY.getStatus());
+ couponTemplateBO.setGetUserType(CouponGetUserTypeEnum.ALL.getType());
+
+
+ couponTemplateService.createCouponTemplate(couponTemplateBO);
+ return returnData(R.SUCCESS.getCode(), null);
+
+
+ }
+
+ @PutMapping("/{id}")
+ @ApiOperation(value = "修改", notes = "修改")
+ public ResponseEntity<ReturnDataDTO> update(@Validated @RequestBody CreateCouponTemplateActivyDTO dto) {
+
+ // 信息验证
+ valid(dto);
+
+ CouponTemplateDO couponTemplateDO = couponTemplateService.getById(dto.getId());
+ if (null == couponTemplateDO) {
+ throw new ValidationException("优惠券不存在");
+ }
+
+ CreateCouponTemplateBO couponTemplateBO = new CreateCouponTemplateBO();
+ BeanUtils.copyProperties(dto, couponTemplateBO);
+
+ // 设置成积分优惠券
+ couponTemplateBO.setCategory(CouponCategoryEnum.ACTIVITY.getStatus());
+ couponTemplateBO.setGetUserType(CouponGetUserTypeEnum.ALL.getType());
+
+ couponTemplateService.updateCouponTemplate(couponTemplateBO);
+
+ return returnData(R.SUCCESS.getCode(), null);
+ }
+
+ @DeleteMapping("/{id}")
+ @ApiOperation(value = "删除", notes = "删除")
+ public ResponseEntity<ReturnDataDTO> delete(@PathVariable String id) {
+
+ CouponTemplateDO couponTemplateDO = couponTemplateService.getById(id);
+ if (null == couponTemplateDO) {
+ throw new ValidationException("优惠券不存在");
+ }
+ couponTemplateService.deleteCouponTemplate(id);
+ return returnData(R.SUCCESS.getCode(), null);
+ }
+
+ @GetMapping("/{id}")
+ @ApiOperation(value = "详情", notes = "详情")
+ public ResponseEntity<ReturnDataDTO> get(@PathVariable String id) {
+ CouponTemplateVO couponTemplateVO = couponTemplateService.getDetailById(id);
+ return returnData(R.SUCCESS.getCode(), ConverterUtil.transObject(couponTemplateVO, CouponTemplateActivyVO.class));
+ }
+
+ @GetMapping("/page")
+ @ApiOperation(value = "查询-分页", notes = "查询-分页")
+ public ResponseEntity<ReturnDataDTO<Page<CouponTemplatePointVO>>> page(Page page, QueryCouponDTO dto) {
+ // 设置只查询积分优惠券的
+ dto.setCategory(CouponCategoryEnum.ACTIVITY.getStatus());
+ Page<CouponTemplateVO> resultPage = couponTemplateService.getPage(page, dto);
+ return returnData(R.SUCCESS.getCode(), ConverterUtil.transPage(resultPage, CouponTemplateActivyVO.class));
+ }
+
+ @GetMapping("/list")
+ @ApiOperation(value = "查询-全部", notes = "查询-全部")
+ public ResponseEntity<ReturnDataDTO<Page<CouponTemplateVO>>> list(QueryCouponDTO dto) {
+ // 设置只查询积分优惠券的
+ dto.setCategory(CouponCategoryEnum.ACTIVITY.getStatus());
+ return returnData(R.SUCCESS.getCode(), ConverterUtil.transList(couponTemplateService.getList(dto), CouponTemplateActivyVO.class));
+ }
+
+
+ @PutMapping("/active/{id}")
+ @ApiOperation(value = "发布", notes = "发布")
+ public ResponseEntity<ReturnDataDTO> active(@PathVariable String id) {
+
+ CouponTemplateDO couponTemplateDO = couponTemplateService.getById(id);
+ if (null == couponTemplateDO) {
+ throw new ValidationException("优惠券不存在");
+ }
+
+ couponTemplateService.activeCouponTemplate(id);
+
+ return returnData(R.SUCCESS.getCode(), null);
+ }
+
+ @PutMapping("/expire/{id}")
+ @ApiOperation(value = "下架", notes = "下架")
+ public ResponseEntity<ReturnDataDTO> expire(@PathVariable String id) {
+
+ CouponTemplateDO couponTemplateDO = couponTemplateService.getById(id);
+ if (null == couponTemplateDO) {
+ throw new ValidationException("优惠券不存在");
+ }
+
+ couponTemplateService.expireCouponTemplate(id);
+
+ return returnData(R.SUCCESS.getCode(), null);
+ }
+
+
+ private void valid(CreateCouponTemplateActivyDTO dto){
+
+ if (StringUtils.isNotBlank(dto.getCouponDiscountType())
+ && dto.getCouponDiscountType().equals(CouponTypeEnum.DISCOUNT.getType())
+ && dto.getMinOrderAmount().compareTo(dto.getCouponDiscountValue()) < 0) {
+ throw new ValidationException("订单金额不能小于折扣金额");
+ }
+ if (StringUtils.isNotBlank(dto.getCouponDiscountType())
+ && dto.getCouponDiscountType().equals(CouponTypeEnum.DISCOUNT.getType())
+ && dto.getCouponDiscountValue().compareTo(BigDecimal.ZERO) <= 0) {
+ throw new ValidationException("折扣金额必须大于0");
+ }
+
+ if (StringUtils.isNotBlank(dto.getCouponDiscountType())
+ && dto.getCouponDiscountType().equals(CouponTypeEnum.ZERO.getType())
+ && dto.getMinOrderAmount().compareTo(BigDecimal.ZERO) != 0) {
+ throw new ValidationException("无门槛的订单金额必须为0");
+ }
+
+ // 领取后 固定时间
+ if(StringUtils.isNotBlank(dto.getUsageType()) && dto.getUsageType().equals(CouponUsageTypeEnum.FIXED.getType()) ){
+ // 如果使用时间是固定时间的话,那么固定时间的开始时间和结束时间就不能为空
+ if(dto.getUsageStartDate()==null){
+ throw new ValidationException("固定时间开始日期不能为空");
+ }
+ if(dto.getUsageEndDate()==null){
+ throw new ValidationException("固定时间结束日期不能为空");
+ }
+ }
+
+ // 领取后 有效时间
+ if(StringUtils.isNotBlank(dto.getUsageType()) && dto.getUsageType().equals(CouponUsageTypeEnum.GET_AFTER_TIME.getType())){
+ // 如果使用时间是领取后有效时间的话,那么领取后的时间类型不能为空,且时间不能为空
+ if(StringUtils.isBlank(dto.getUsageTimeType())){
+ throw new ValidationException("领取后有效时间类型(COUPON_USAGE_TIME_TYPE)不能为空");
+ }
+
+ if(dto.getUsageTimeNum()==null){
+ throw new ValidationException("领取后有效时间整数不能为空");
+ }
+ if(dto.getUsageTimeNum()<=0){
+ throw new ValidationException("领取后有效时间整数需要大于0");
+ }
+ }
+ }
+
+}
diff --git a/src/main/java/com/mzl/flower/web/v2/coupon/CouponTemplateController.java b/src/main/java/com/mzl/flower/web/v2/coupon/CouponTemplateController.java
new file mode 100644
index 0000000..2ab7890
--- /dev/null
+++ b/src/main/java/com/mzl/flower/web/v2/coupon/CouponTemplateController.java
@@ -0,0 +1,158 @@
+package com.mzl.flower.web.v2.coupon;
+
+
+import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import com.mzl.flower.base.BaseController;
+import com.mzl.flower.base.R;
+import com.mzl.flower.base.ReturnDataDTO;
+import com.mzl.flower.config.exception.ValidationException;
+import com.mzl.flower.dto.request.coupon.CreateCouponTemplateDTO;
+import com.mzl.flower.dto.request.coupon.QueryCouponDTO;
+import com.mzl.flower.dto.response.coupon.CouponTemplateActivyVO;
+import com.mzl.flower.enums.CouponUsageTypeEnum;
+import com.mzl.flower.service.coupon.CouponTemplateService2;
+import io.swagger.annotations.ApiOperation;
+import org.apache.commons.lang3.StringUtils;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.http.ResponseEntity;
+import org.springframework.validation.annotation.Validated;
+import org.springframework.web.bind.annotation.*;
+import com.mzl.flower.entity.coupon.CouponTemplateDO;
+
+
+/**
+* @author @TaoJie
+* @since 2024-08-22
+*/
+@RestController
+@RequestMapping("/api/v2/coupon/all")
+//@Api(value = "优惠券管理-活动", tags = "优惠券管理-活动")
+@Validated
+public class CouponTemplateController extends BaseController {
+
+ @Autowired
+ CouponTemplateService2 couponTemplateService;
+
+ @PostMapping("")
+ @ApiOperation(value = "新增优惠券", notes = "新增优惠券")
+ public ResponseEntity<ReturnDataDTO> create(@Validated @RequestBody CreateCouponTemplateDTO dto) {
+
+ // 信息验证
+ valid(dto);
+
+// couponTemplateService.createCouponTemplate(dto);
+ return returnData(R.SUCCESS.getCode(), null);
+ }
+
+ @PutMapping("/{id}")
+ @ApiOperation(value = "修改", notes = "修改")
+ public ResponseEntity<ReturnDataDTO> update(@Validated @RequestBody CreateCouponTemplateDTO dto) {
+
+ CouponTemplateDO couponTemplateDO= couponTemplateService.getById(dto.getId());
+ if(null==couponTemplateDO){
+ throw new ValidationException("优惠券不存在");
+ }
+
+ // 信息验证
+ valid(dto);
+
+// couponTemplateService.updateCouponTemplate(dto);
+
+ return returnData(R.SUCCESS.getCode(), null);
+ }
+
+ @DeleteMapping("/{id}")
+ @ApiOperation(value = "删除", notes = "删除")
+ public ResponseEntity<ReturnDataDTO> delete(@PathVariable String id ) {
+
+ CouponTemplateDO couponTemplateDO= couponTemplateService.getById(id);
+ if(null==couponTemplateDO){
+ throw new ValidationException("优惠券不存在");
+ }
+ couponTemplateService.deleteCouponTemplate(id);
+ return returnData(R.SUCCESS.getCode(), null);
+ }
+
+ @GetMapping("/{id}")
+ @ApiOperation(value = "详情", notes = "详情")
+ public ResponseEntity<ReturnDataDTO> get(@PathVariable String id) {
+// CouponTemplateActivyVO couponTemplateActivyVO=couponTemplateService.getActivityCouponDetailById(id);
+ return returnData(R.SUCCESS.getCode(),null);
+ }
+
+ @GetMapping("/page")
+ @ApiOperation(value = "查询-分页", notes = "查询-分页")
+ public ResponseEntity<ReturnDataDTO<Page<CouponTemplateActivyVO>>> page(
+ Page page, QueryCouponDTO dto
+ ) {
+// couponTemplateService.getActivityPage(page,dto);
+ return returnData(R.SUCCESS.getCode(), null);
+ }
+
+ @GetMapping("/list")
+ @ApiOperation(value = "查询-全部", notes = "查询-全部")
+ public ResponseEntity<ReturnDataDTO<Page<CouponTemplateActivyVO>>> list(QueryCouponDTO dto
+ ) {
+// couponTemplateService.getActivityList(dto)
+ return returnData(R.SUCCESS.getCode(), null);
+ }
+
+
+ @PutMapping("/active/{id}")
+ @ApiOperation(value = "发布", notes = "发布")
+ public ResponseEntity<ReturnDataDTO> active(@PathVariable String id) {
+
+ CouponTemplateDO couponTemplateDO= couponTemplateService.getById(id);
+ if(null==couponTemplateDO){
+ throw new ValidationException("优惠券不存在");
+ }
+
+ couponTemplateService.activeCouponTemplate(id);
+
+ return returnData(R.SUCCESS.getCode(), null);
+ }
+
+ @PutMapping("/expire/{id}")
+ @ApiOperation(value = "下架", notes = "下架")
+ public ResponseEntity<ReturnDataDTO> expire(@PathVariable String id) {
+
+ CouponTemplateDO couponTemplateDO= couponTemplateService.getById(id);
+ if(null==couponTemplateDO){
+ throw new ValidationException("优惠券不存在");
+ }
+
+ couponTemplateService.expireCouponTemplate(id);
+
+ return returnData(R.SUCCESS.getCode(), null);
+ }
+
+
+ private void valid(CreateCouponTemplateDTO dto){
+ // 领取后 固定时间
+ if(StringUtils.isNotBlank(dto.getUsageType()) && dto.getUsageType().equals(CouponUsageTypeEnum.FIXED.getType()) ){
+ // 如果使用时间是固定时间的话,那么固定时间的开始时间和结束时间就不能为空
+ if(dto.getUsageStartDate()==null){
+ throw new ValidationException("固定时间开始日期不能为空");
+ }
+ if(dto.getUsageEndDate()==null){
+ throw new ValidationException("固定时间结束日期不能为空");
+ }
+ }
+
+ // 领取后 有效时间
+ if(StringUtils.isNotBlank(dto.getUsageType()) && dto.getUsageType().equals(CouponUsageTypeEnum.GET_AFTER_TIME.getType())){
+ // 如果使用时间是领取后有效时间的话,那么领取后的时间类型不能为空,且时间不能为空
+ if(StringUtils.isBlank(dto.getUsageTimeType())){
+ throw new ValidationException("领取后有效时间类型不能为空");
+ }
+
+ if(dto.getUsageTimeNum()==null){
+ throw new ValidationException("领取后有效时间整数不能为空");
+ }
+ if(dto.getUsageTimeNum()<=0){
+ throw new ValidationException("领取后有效时间整数需要大于0");
+ }
+ }
+ }
+
+}
diff --git a/src/main/java/com/mzl/flower/web/v2/coupon/CouponTemplateCustomerController.java b/src/main/java/com/mzl/flower/web/v2/coupon/CouponTemplateCustomerController.java
new file mode 100644
index 0000000..8e02b37
--- /dev/null
+++ b/src/main/java/com/mzl/flower/web/v2/coupon/CouponTemplateCustomerController.java
@@ -0,0 +1,15 @@
+package com.mzl.flower.web.v2.coupon;
+
+import org.springframework.web.bind.annotation.RequestMapping;
+import org.springframework.web.bind.annotation.RestController;
+
+/**
+* @author @TaoJie
+* @since 2024-08-24
+*/
+@RestController
+@RequestMapping("/v2/coupon-template-point-custom-re")
+public class CouponTemplateCustomerController {
+
+
+}
diff --git a/src/main/java/com/mzl/flower/web/v2/coupon/CouponTemplatePointController.java b/src/main/java/com/mzl/flower/web/v2/coupon/CouponTemplatePointController.java
new file mode 100644
index 0000000..5fbb65b
--- /dev/null
+++ b/src/main/java/com/mzl/flower/web/v2/coupon/CouponTemplatePointController.java
@@ -0,0 +1,215 @@
+package com.mzl.flower.web.v2.coupon;
+
+
+import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import com.mzl.flower.base.BaseController;
+import com.mzl.flower.base.R;
+import com.mzl.flower.base.ReturnDataDTO;
+import com.mzl.flower.config.exception.ValidationException;
+import com.mzl.flower.dto.request.coupon.*;
+import com.mzl.flower.dto.response.coupon.CouponTemplatePointVO;
+import com.mzl.flower.dto.response.coupon.CouponTemplateVO;
+import com.mzl.flower.entity.coupon.CouponTemplateDO;
+import com.mzl.flower.enums.CouponCategoryEnum;
+import com.mzl.flower.enums.CouponTypeEnum;
+import com.mzl.flower.enums.CouponUsageTypeEnum;
+import com.mzl.flower.service.coupon.CouponTemplateService2;
+import com.mzl.flower.utils.ConverterUtil;
+import io.swagger.annotations.Api;
+import io.swagger.annotations.ApiOperation;
+import org.apache.commons.lang3.StringUtils;
+import org.springframework.beans.BeanUtils;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.http.ResponseEntity;
+import org.springframework.validation.annotation.Validated;
+import org.springframework.web.bind.annotation.*;
+
+import java.math.BigDecimal;
+
+
+/**
+ * @author @TaoJie
+ * @since 2024-08-22
+ */
+@RestController
+@RequestMapping("/api/v2/coupon/point")
+@Api(value = "优惠券管理-积分", tags = "优惠券管理-积分")
+@Validated
+public class CouponTemplatePointController extends BaseController {
+
+ @Autowired
+ CouponTemplateService2 couponTemplateService;
+
+ @PostMapping("")
+ @ApiOperation(value = "新增", notes = "新增")
+ public ResponseEntity<ReturnDataDTO> create(@Validated @RequestBody CreateCouponTemplatePointDTO dto) {
+
+ // 信息校验
+ valid(dto);
+
+ CreateCouponTemplateBO couponTemplateBO = new CreateCouponTemplateBO();
+ BeanUtils.copyProperties(dto, couponTemplateBO);
+
+ // 设置成积分优惠券
+ couponTemplateBO.setCategory(CouponCategoryEnum.POINT.getStatus());
+ // 设置默认类型领取后有效
+ couponTemplateBO.setUsageType(CouponUsageTypeEnum.GET_AFTER_TIME.getType());
+
+ couponTemplateService.createCouponTemplate(couponTemplateBO);
+ return returnData(R.SUCCESS.getCode(), null);
+
+
+ }
+
+ @PutMapping("/{id}")
+ @ApiOperation(value = "修改", notes = "修改")
+ public ResponseEntity<ReturnDataDTO> update(@Validated @RequestBody CreateCouponTemplatePointDTO dto) {
+ // 信息校验
+ valid(dto);
+
+ CouponTemplateDO couponTemplateDO = couponTemplateService.getById(dto.getId());
+ if (null == couponTemplateDO) {
+ throw new ValidationException("优惠券不存在");
+ }
+
+ CreateCouponTemplateBO couponTemplateBO = new CreateCouponTemplateBO();
+ BeanUtils.copyProperties(dto, couponTemplateBO);
+
+ // 设置成积分优惠券
+ couponTemplateBO.setCategory(CouponCategoryEnum.POINT.getStatus());
+ // 设置默认类型
+ couponTemplateBO.setUsageType(CouponUsageTypeEnum.GET_AFTER_TIME.getType());
+
+
+ couponTemplateService.updateCouponTemplate(couponTemplateBO);
+
+ return returnData(R.SUCCESS.getCode(), null);
+ }
+
+ @DeleteMapping("/{id}")
+ @ApiOperation(value = "删除", notes = "删除")
+ public ResponseEntity<ReturnDataDTO> delete(@PathVariable String id) {
+
+ CouponTemplateDO couponTemplateDO = couponTemplateService.getById(id);
+ if (null == couponTemplateDO) {
+ throw new ValidationException("优惠券不存在");
+ }
+ couponTemplateService.deleteCouponTemplate(id);
+ return returnData(R.SUCCESS.getCode(), null);
+ }
+
+ @GetMapping("/{id}")
+ @ApiOperation(value = "详情", notes = "详情")
+ public ResponseEntity<ReturnDataDTO> get(@PathVariable String id) {
+ CouponTemplateVO couponTemplateVO = couponTemplateService.getDetailById(id);
+ return returnData(R.SUCCESS.getCode(), ConverterUtil.transObject(couponTemplateVO, CouponTemplatePointVO.class));
+ }
+
+ @GetMapping("/page")
+ @ApiOperation(value = "查询-分页", notes = "查询-分页")
+ public ResponseEntity<ReturnDataDTO<Page<CouponTemplatePointVO>>> page(Page page, QueryCouponDTO dto) {
+ // 设置只查询积分优惠券的
+ dto.setCategory(CouponCategoryEnum.POINT.getStatus());
+ Page<CouponTemplateVO> resultPage = couponTemplateService.getPage(page, dto);
+ return returnData(R.SUCCESS.getCode(), ConverterUtil.transPage(resultPage, CouponTemplatePointVO.class));
+ }
+
+ @GetMapping("/list")
+ @ApiOperation(value = "查询-全部", notes = "查询-全部")
+ public ResponseEntity<ReturnDataDTO<Page<CouponTemplateVO>>> list(QueryCouponDTO dto) {
+ // 设置只查询积分优惠券的
+ dto.setCategory(CouponCategoryEnum.POINT.getStatus());
+ return returnData(R.SUCCESS.getCode(), ConverterUtil.transList(couponTemplateService.getList(dto), CouponTemplatePointVO.class));
+ }
+
+
+ @PutMapping("/active/{id}")
+ @ApiOperation(value = "发布", notes = "发布")
+ public ResponseEntity<ReturnDataDTO> active(@PathVariable String id) {
+
+ CouponTemplateDO couponTemplateDO = couponTemplateService.getById(id);
+ if (null == couponTemplateDO) {
+ throw new ValidationException("优惠券不存在");
+ }
+
+ couponTemplateService.activeCouponTemplate(id);
+
+ return returnData(R.SUCCESS.getCode(), null);
+ }
+
+ @PutMapping("/expire/{id}")
+ @ApiOperation(value = "下架", notes = "下架")
+ public ResponseEntity<ReturnDataDTO> expire(@PathVariable String id) {
+
+ CouponTemplateDO couponTemplateDO = couponTemplateService.getById(id);
+ if (null == couponTemplateDO) {
+ throw new ValidationException("优惠券不存在");
+ }
+
+ couponTemplateService.expireCouponTemplate(id);
+
+ return returnData(R.SUCCESS.getCode(), null);
+ }
+
+ @PutMapping("/batch/expire")
+ @ApiOperation(value = "批量下架", notes = "批量下架")
+ public ResponseEntity<ReturnDataDTO> expireBatch(BatchCouponTemplateDTO dto) {
+
+
+ couponTemplateService.expireBatchCouponTemplate(dto);
+
+ return returnData(R.SUCCESS.getCode(), null);
+ }
+
+
+
+ @PutMapping("/batch/active")
+ @ApiOperation(value = "批量发布", notes = "批量发布")
+ public ResponseEntity<ReturnDataDTO> activeBatch(BatchCouponTemplateDTO dto) {
+
+ couponTemplateService.activeBatchCouponTemplate(dto);
+
+ return returnData(R.SUCCESS.getCode(), null);
+ }
+
+
+ @DeleteMapping("/batch/del")
+ @ApiOperation(value = "批量删除", notes = "批量删除")
+ public ResponseEntity<ReturnDataDTO> deleteBatch(BatchCouponTemplateDTO dto) {
+
+ couponTemplateService.deleteBatchCouponTemplate(dto);
+ return returnData(R.SUCCESS.getCode(), null);
+ }
+
+ @GetMapping("/statistics")
+ @ApiOperation(value = "积分统计", notes = "积分统计")
+ public ResponseEntity<ReturnDataDTO> statistics(QueryCouponStatisticsDTO dto) {
+ QueryCouponStatisticsBO queryCouponStatisticsBO=new QueryCouponStatisticsBO();
+ BeanUtils.copyProperties(dto,queryCouponStatisticsBO);
+ CouponTemplateVO couponTemplateVO = couponTemplateService.statisCouponTemplatePoint(queryCouponStatisticsBO);
+ return returnData(R.SUCCESS.getCode(), ConverterUtil.transObject(couponTemplateVO, CouponTemplatePointVO.class));
+ }
+
+
+ private void valid(CreateCouponTemplatePointDTO dto){
+
+ if (StringUtils.isNotBlank(dto.getCouponDiscountType())
+ && dto.getCouponDiscountType().equals(CouponTypeEnum.DISCOUNT.getType())
+ && dto.getMinOrderAmount().compareTo(dto.getCouponDiscountValue()) < 0) {
+ throw new ValidationException("订单金额不能小于折扣金额");
+ }
+ if (StringUtils.isNotBlank(dto.getCouponDiscountType())
+ && dto.getCouponDiscountType().equals(CouponTypeEnum.DISCOUNT.getType())
+ && dto.getCouponDiscountValue().compareTo(BigDecimal.ZERO) <= 0) {
+ throw new ValidationException("折扣金额必须大于0");
+ }
+
+ if (StringUtils.isNotBlank(dto.getCouponDiscountType())
+ && dto.getCouponDiscountType().equals(CouponTypeEnum.ZERO.getType())
+ && dto.getMinOrderAmount().compareTo(BigDecimal.ZERO) != 0) {
+ throw new ValidationException("无门槛的订单金额必须为0");
+ }
+
+
+ }
+}
diff --git a/src/main/java/com/mzl/flower/web/v2/coupon/CouponTemplateUserController.java b/src/main/java/com/mzl/flower/web/v2/coupon/CouponTemplateUserController.java
new file mode 100644
index 0000000..a472602
--- /dev/null
+++ b/src/main/java/com/mzl/flower/web/v2/coupon/CouponTemplateUserController.java
@@ -0,0 +1,186 @@
+package com.mzl.flower.web.v2.coupon;
+
+
+import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import com.mzl.flower.base.BaseController;
+import com.mzl.flower.base.R;
+import com.mzl.flower.base.ReturnDataDTO;
+import com.mzl.flower.config.exception.ValidationException;
+import com.mzl.flower.dto.request.coupon.CreateCouponTemplateBO;
+import com.mzl.flower.dto.request.coupon.CreateCouponTemplatePointDTO;
+import com.mzl.flower.dto.request.coupon.CreateCouponTemplateUserDTO;
+import com.mzl.flower.dto.request.coupon.QueryCouponDTO;
+import com.mzl.flower.dto.response.coupon.CouponTemplatePointVO;
+import com.mzl.flower.dto.response.coupon.CouponTemplateUserVO;
+import com.mzl.flower.dto.response.coupon.CouponTemplateVO;
+import com.mzl.flower.entity.coupon.CouponTemplateDO;
+import com.mzl.flower.enums.CouponCategoryEnum;
+import com.mzl.flower.enums.CouponGetUserTypeEnum;
+import com.mzl.flower.enums.CouponTypeEnum;
+import com.mzl.flower.enums.CouponUsageTypeEnum;
+import com.mzl.flower.service.coupon.CouponTemplateService2;
+import com.mzl.flower.utils.ConverterUtil;
+import io.swagger.annotations.Api;
+import io.swagger.annotations.ApiOperation;
+import org.springframework.beans.BeanUtils;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.http.ResponseEntity;
+import org.springframework.validation.annotation.Validated;
+import org.springframework.web.bind.annotation.*;
+
+import java.math.BigDecimal;
+import java.util.ArrayList;
+import java.util.Collections;
+import java.util.List;
+import java.util.Objects;
+import java.util.stream.Collectors;
+
+
+/**
+ * @author @TaoJie
+ * @since 2024-08-22
+ */
+@RestController
+@RequestMapping("/api/v2/coupon/user")
+@Api(value = "优惠券管理-用户", tags = "优惠券管理-用户")
+@Validated
+public class CouponTemplateUserController extends BaseController {
+
+ @Autowired
+ CouponTemplateService2 couponTemplateService;
+
+ @PostMapping("")
+ @ApiOperation(value = "新增", notes = "新增")
+ public ResponseEntity<ReturnDataDTO> create(@Validated @RequestBody CreateCouponTemplateUserDTO dto) {
+
+ if (dto.getCouponDiscountType().equals(CouponTypeEnum.DISCOUNT.getType()) && dto.getMinOrderAmount().compareTo(dto.getCouponDiscountValue()) < 0) {
+ throw new ValidationException("订单金额不能小于折扣金额");
+ }
+
+ if (dto.getCouponDiscountType().equals(CouponTypeEnum.ZERO.getType()) && dto.getMinOrderAmount().compareTo(BigDecimal.ZERO) != 0) {
+ throw new ValidationException("无门槛的订单金额必须为0");
+ }
+
+
+ CreateCouponTemplateBO couponTemplateBO = new CreateCouponTemplateBO();
+ BeanUtils.copyProperties(dto, couponTemplateBO);
+
+ // 设置成指定用户
+ couponTemplateBO.setGetUserType(CouponGetUserTypeEnum.POINT.getType());
+ // 设置成积分优惠券
+ couponTemplateBO.setCategory(CouponCategoryEnum.USER.getStatus());
+ // 设置默认类型
+ couponTemplateBO.setUsageType(CouponUsageTypeEnum.GET_AFTER_TIME.getType());
+
+ couponTemplateService.createCouponTemplate(couponTemplateBO);
+
+ return returnData(R.SUCCESS.getCode(), null);
+
+
+ }
+
+ @PutMapping("/{id}")
+ @ApiOperation(value = "修改", notes = "修改")
+ public ResponseEntity<ReturnDataDTO> update(@Validated @RequestBody CreateCouponTemplateUserDTO dto) {
+
+
+ if (dto.getCouponDiscountType().equals(CouponTypeEnum.DISCOUNT.getType()) && dto.getMinOrderAmount().compareTo(dto.getCouponDiscountValue()) < 0) {
+ throw new ValidationException("订单金额不能小于折扣金额");
+ }
+
+ if (dto.getCouponDiscountType().equals(CouponTypeEnum.ZERO.getType()) && dto.getMinOrderAmount().compareTo(BigDecimal.ZERO) != 0) {
+ throw new ValidationException("无门槛的订单金额必须为0");
+ }
+
+
+ CouponTemplateDO couponTemplateDO = couponTemplateService.getById(dto.getId());
+ if (null == couponTemplateDO) {
+ throw new ValidationException("优惠券不存在");
+ }
+
+ CreateCouponTemplateBO couponTemplateBO = new CreateCouponTemplateBO();
+ BeanUtils.copyProperties(dto, couponTemplateBO);
+
+ // 设置成指定用户
+ couponTemplateBO.setGetUserType(CouponGetUserTypeEnum.POINT.getType());
+ // 设置成积分优惠券
+ couponTemplateBO.setCategory(CouponCategoryEnum.USER.getStatus());
+ // 设置默认类型
+ couponTemplateBO.setUsageType(CouponUsageTypeEnum.GET_AFTER_TIME.getType());
+
+
+ couponTemplateService.updateCouponTemplate(couponTemplateBO);
+
+ return returnData(R.SUCCESS.getCode(), null);
+ }
+
+ @DeleteMapping("/{id}")
+ @ApiOperation(value = "删除", notes = "删除")
+ public ResponseEntity<ReturnDataDTO> delete(@PathVariable String id) {
+
+ CouponTemplateDO couponTemplateDO = couponTemplateService.getById(id);
+ if (null == couponTemplateDO) {
+ throw new ValidationException("优惠券不存在");
+ }
+ couponTemplateService.deleteCouponTemplate(id);
+ return returnData(R.SUCCESS.getCode(), null);
+ }
+
+ @GetMapping("/{id}")
+ @ApiOperation(value = "详情", notes = "详情")
+ public ResponseEntity<ReturnDataDTO> get(@PathVariable String id) {
+ CouponTemplateVO couponTemplateVO = couponTemplateService.getDetailById(id);
+ return returnData(R.SUCCESS.getCode(), ConverterUtil.transObject(couponTemplateVO, CouponTemplateUserVO.class));
+ }
+
+ @GetMapping("/page")
+ @ApiOperation(value = "查询-分页", notes = "查询-分页")
+ public ResponseEntity<ReturnDataDTO<Page<CouponTemplatePointVO>>> page(
+ Page page, QueryCouponDTO dto
+ ) {
+ // 设置只查询积分优惠券的
+ dto.setCategory(CouponCategoryEnum.USER.getStatus());
+ Page<CouponTemplateVO> resultPage = couponTemplateService.getPage(page, dto);
+ return returnData(R.SUCCESS.getCode(), ConverterUtil.transPage(resultPage, CouponTemplateUserVO.class));
+ }
+
+ @GetMapping("/list")
+ @ApiOperation(value = "查询-全部", notes = "查询-全部")
+ public ResponseEntity<ReturnDataDTO<Page<CouponTemplateVO>>> list(QueryCouponDTO dto
+ ) {
+ // 设置只查询积分优惠券的
+ dto.setCategory(CouponCategoryEnum.USER.getStatus());
+ return returnData(R.SUCCESS.getCode(), ConverterUtil.transList(couponTemplateService.getList(dto), CouponTemplateUserVO.class));
+ }
+
+
+ @PutMapping("/active/{id}")
+ @ApiOperation(value = "发布", notes = "发布")
+ public ResponseEntity<ReturnDataDTO> active(@PathVariable String id) {
+
+ CouponTemplateDO couponTemplateDO = couponTemplateService.getById(id);
+ if (null == couponTemplateDO) {
+ throw new ValidationException("优惠券不存在");
+ }
+
+ couponTemplateService.activeCouponTemplate(id);
+
+ return returnData(R.SUCCESS.getCode(), null);
+ }
+
+ @PutMapping("/expire/{id}")
+ @ApiOperation(value = "下架", notes = "下架")
+ public ResponseEntity<ReturnDataDTO> expire(@PathVariable String id) {
+
+ CouponTemplateDO couponTemplateDO = couponTemplateService.getById(id);
+ if (null == couponTemplateDO) {
+ throw new ValidationException("优惠券不存在");
+ }
+
+ couponTemplateService.expireCouponTemplate(id);
+
+ return returnData(R.SUCCESS.getCode(), null);
+ }
+
+
+}
diff --git a/src/main/java/com/mzl/flower/web/v2/coupon/CouponTemplateVipController.java b/src/main/java/com/mzl/flower/web/v2/coupon/CouponTemplateVipController.java
new file mode 100644
index 0000000..0a203aa
--- /dev/null
+++ b/src/main/java/com/mzl/flower/web/v2/coupon/CouponTemplateVipController.java
@@ -0,0 +1,142 @@
+package com.mzl.flower.web.v2.coupon;
+
+
+import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import com.mzl.flower.base.BaseController;
+import com.mzl.flower.base.R;
+import com.mzl.flower.base.ReturnDataDTO;
+import com.mzl.flower.config.exception.ValidationException;
+import com.mzl.flower.dto.request.coupon.*;
+import com.mzl.flower.dto.response.coupon.CouponTemplateVO;
+import com.mzl.flower.dto.response.coupon.CouponTemplateVipVO;
+import com.mzl.flower.entity.coupon.CouponTemplateDO;
+import com.mzl.flower.enums.CouponCategoryEnum;
+import com.mzl.flower.enums.CouponTypeEnum;
+import com.mzl.flower.service.coupon.CouponTemplateService2;
+import com.mzl.flower.utils.ConverterUtil;
+import io.swagger.annotations.Api;
+import io.swagger.annotations.ApiOperation;
+import org.apache.commons.lang3.StringUtils;
+import org.springframework.beans.BeanUtils;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.http.ResponseEntity;
+import org.springframework.validation.annotation.Validated;
+import org.springframework.web.bind.annotation.*;
+
+import java.math.BigDecimal;
+
+/**
+* @author @TaoJie
+* @since 2024-08-22
+*/
+@RestController
+@RequestMapping("/api/v2/coupon/vip")
+@Api(value = "优惠券管理-会员", tags = "优惠券管理-会员")
+@Validated
+public class CouponTemplateVipController extends BaseController {
+
+ @Autowired
+ CouponTemplateService2 couponTemplateService;
+
+ @PostMapping("")
+ @ApiOperation(value = "新增", notes = "新增")
+ public ResponseEntity<ReturnDataDTO> create(@Validated @RequestBody CreateCouponTemplateVipDTO dto) {
+
+ // 信息验证
+ valid(dto);
+
+ CreateCouponTemplateBO couponTemplateBO = new CreateCouponTemplateBO();
+ BeanUtils.copyProperties(dto, couponTemplateBO);
+
+ // 设置成积分优惠券
+ couponTemplateBO.setCategory(CouponCategoryEnum.MEMBER.getStatus());
+
+ couponTemplateService.createCouponTemplate(couponTemplateBO);
+
+ return returnData(R.SUCCESS.getCode(), null);
+ }
+
+ @PutMapping("/{id}")
+ @ApiOperation(value = "修改", notes = "修改")
+ public ResponseEntity<ReturnDataDTO> update(@Validated @RequestBody CreateCouponTemplateVipDTO dto) {
+
+ // 信息验证
+ valid(dto);
+
+ CouponTemplateDO couponTemplateDO = couponTemplateService.getById(dto.getId());
+ if (null == couponTemplateDO) {
+ throw new ValidationException("优惠券不存在");
+ }
+
+ CreateCouponTemplateBO couponTemplateBO = new CreateCouponTemplateBO();
+ BeanUtils.copyProperties(dto, couponTemplateBO);
+
+ // 设置成积分优惠券
+ couponTemplateBO.setCategory(CouponCategoryEnum.MEMBER.getStatus());
+
+ couponTemplateService.updateCouponTemplate(couponTemplateBO);
+
+ return returnData(R.SUCCESS.getCode(), null);
+ }
+
+ @DeleteMapping("/{id}")
+ @ApiOperation(value = "删除", notes = "删除")
+ public ResponseEntity<ReturnDataDTO> delete(@PathVariable String id ) {
+
+ CouponTemplateDO couponTemplateDO= couponTemplateService.getById(id);
+ if(null==couponTemplateDO){
+ throw new ValidationException("优惠券不存在");
+ }
+ couponTemplateService.deleteCouponTemplate(id);
+ return returnData(R.SUCCESS.getCode(), null);
+ }
+
+ @GetMapping("/{id}")
+ @ApiOperation(value = "详情", notes = "详情")
+ public ResponseEntity<ReturnDataDTO> get(@PathVariable String id) {
+ CouponTemplateVO couponTemplateVO = couponTemplateService.getDetailById(id);
+ return returnData(R.SUCCESS.getCode(), ConverterUtil.transObject(couponTemplateVO, CouponTemplateVipVO.class));
+ }
+
+ @GetMapping("/page")
+ @ApiOperation(value = "查询-分页", notes = "查询-分页")
+ public ResponseEntity<ReturnDataDTO<Page<CouponTemplateVipVO>>> page(
+ Page page, QueryCouponDTO dto
+ ) {
+ // 设置只查询积分优惠券的
+ dto.setCategory(CouponCategoryEnum.MEMBER.getStatus());
+ Page<CouponTemplateVO> resultPage = couponTemplateService.getPage(page, dto);
+ return returnData(R.SUCCESS.getCode(), ConverterUtil.transPage(resultPage, CouponTemplateVipVO.class));
+
+ }
+
+ @GetMapping("/list")
+ @ApiOperation(value = "查询-全部", notes = "查询-全部")
+ public ResponseEntity<ReturnDataDTO<Page<CouponTemplateVipVO>>> list(QueryCouponDTO dto
+ ) {
+ dto.setCategory(CouponCategoryEnum.MEMBER.getStatus());
+ return returnData(R.SUCCESS.getCode(), ConverterUtil.transList(couponTemplateService.getList(dto), CouponTemplateVipVO.class));
+ }
+
+
+ private void valid(CreateCouponTemplateVipDTO dto){
+
+ if (StringUtils.isNotBlank(dto.getCouponDiscountType())
+ && dto.getCouponDiscountType().equals(CouponTypeEnum.DISCOUNT.getType())
+ && dto.getMinOrderAmount().compareTo(dto.getCouponDiscountValue()) < 0) {
+ throw new ValidationException("订单金额不能小于折扣金额");
+ }
+ if (StringUtils.isNotBlank(dto.getCouponDiscountType())
+ && dto.getCouponDiscountType().equals(CouponTypeEnum.DISCOUNT.getType())
+ && dto.getCouponDiscountValue().compareTo(BigDecimal.ZERO) <= 0) {
+ throw new ValidationException("折扣金额必须大于0");
+ }
+
+ if (StringUtils.isNotBlank(dto.getCouponDiscountType())
+ && dto.getCouponDiscountType().equals(CouponTypeEnum.ZERO.getType())
+ && dto.getMinOrderAmount().compareTo(BigDecimal.ZERO) != 0) {
+ throw new ValidationException("无门槛的订单金额必须为0");
+ }
+
+ }
+}
diff --git a/src/main/resources/application.yml b/src/main/resources/application.yml
index 3620ad6..693f33e 100644
--- a/src/main/resources/application.yml
+++ b/src/main/resources/application.yml
@@ -20,7 +20,7 @@
maxRequestSize: 50MB
mybatis-plus:
- mapper-locations: classpath:/mapper/*Mapper.xml,classpath:/mapper/**/*Mapper.xml
+ mapper-locations: classpath:/mapper/*Mapper.xml,classpath:/mapper/**/*Mapper.xml,classpath:/mapper/*Mapper*.xml,classpath:/mapper/**/*Mapper*.xml
global-config:
banner: false
db-config:
diff --git a/src/main/resources/mapper/coupon/CouponRecordMapper.xml b/src/main/resources/mapper/coupon/CouponRecordMapper.xml
new file mode 100644
index 0000000..d020e58
--- /dev/null
+++ b/src/main/resources/mapper/coupon/CouponRecordMapper.xml
@@ -0,0 +1,32 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
+<mapper namespace="com.mzl.flower.mapper.coupon.CouponRecordMapper">
+
+ <!-- 通用查询映射结果 -->
+ <resultMap id="BaseResultMap" type="com.mzl.flower.entity.coupon.CouponRecordDO">
+ <id column="id" property="id" />
+ <result column="deleted" property="deleted" />
+ <result column="create_by" property="createBy" />
+ <result column="update_by" property="updateBy" />
+ <result column="create_time" property="createTime" />
+ <result column="update_time" property="updateTime" />
+ <result column="coupon_id" property="couponId" />
+ <result column="user_id" property="userId" />
+ <result column="customer_id" property="customerId" />
+ <result column="status" property="status" />
+ <result column="effective_start" property="effectiveStart" />
+ <result column="effective_end" property="effectiveEnd" />
+ <result column="order_id" property="orderId" />
+ <result column="used_time" property="usedTime" />
+ <result column="coupon_discount_value" property="couponDiscountValue" />
+ <result column="min_order_amount" property="minOrderAmount" />
+ <result column="category" property="category" />
+ <result column="coupon_code" property="couponCode" />
+ <result column="coupon_name" property="couponName" />
+
+ <result column="point" property="point" />
+ <result column="order_no" property="orderNo" />
+
+ </resultMap>
+
+</mapper>
diff --git a/src/main/resources/mapper/coupon/CouponRecordMapperCustom.xml b/src/main/resources/mapper/coupon/CouponRecordMapperCustom.xml
new file mode 100644
index 0000000..a6e6bba
--- /dev/null
+++ b/src/main/resources/mapper/coupon/CouponRecordMapperCustom.xml
@@ -0,0 +1,101 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
+<mapper namespace="com.mzl.flower.mapper.coupon.CouponRecordMapperCustom">
+
+ <!-- 通用查询映射结果 -->
+ <resultMap id="BaseResultMap" type="com.mzl.flower.entity.coupon.CouponRecordDO">
+ <id column="id" property="id" />
+ <result column="deleted" property="deleted" />
+ <result column="create_by" property="createBy" />
+ <result column="update_by" property="updateBy" />
+ <result column="create_time" property="createTime" />
+ <result column="update_time" property="updateTime" />
+ <result column="coupon_id" property="couponId" />
+ <result column="user_id" property="userId" />
+ <result column="customer_id" property="customerId" />
+ <result column="status" property="status" />
+ <result column="effective_start" property="effectiveStart" />
+ <result column="effective_end" property="effectiveEnd" />
+ <result column="order_id" property="orderId" />
+ <result column="used_time" property="usedTime" />
+ <result column="coupon_discount_value" property="couponDiscountValue" />
+ <result column="min_order_amount" property="minOrderAmount" />
+ <result column="category" property="category" />
+ <result column="coupon_code" property="couponCode" />
+ <result column="coupon_name" property="couponName" />
+ <result column="get_type" property="getType" />
+ <result column="coupon_discount_type" property="couponDiscountType" />
+ <result column="get_user_type" property="getUserType" />
+
+ <result column="point" property="point" />
+ <result column="order_no" property="orderNo" />
+
+ </resultMap>
+
+ <select id="statisCouponTemplateCount" resultType="java.lang.Integer">
+ select IFNULL(count(1),0) as cnt from t_coupon_record where deleted=false and category=#{dto.category}
+ </select>
+ <select id="statisCouponTemplateCurMonCount" resultType="java.lang.Integer">
+ select IFNULL(count(1),0) as cnt from t_coupon_record where deleted=false and category=#{dto.category} AND DATE_FORMAT(create_time, '%Y-%m') = DATE_FORMAT(CURDATE(), '%Y-%m')
+ </select>
+ <select id="statisCouponPointCurMonPointAmonut" resultType="java.lang.Integer">
+
+ </select>
+
+ <select id="getPage" resultType="com.mzl.flower.dto.response.coupon.CouponRecordVO">
+ <include refid="QuerySql"></include>
+ </select>
+ <select id="getList" resultType="com.mzl.flower.dto.response.coupon.CouponRecordVO">
+ <include refid="QuerySql"></include>
+ </select>
+
+ <sql id="QuerySql">
+ select *
+ from (
+ select r.*,
+ i.name as customerName,
+ u.tel,
+ o.order_no
+ from t_coupon_record r
+ left join t_customer_info i
+ on r.customer_id=i.id
+ left join t_user u
+ on i.user_id=u.id
+ left join t_order o
+ on r.order_id=o.id
+ ) t
+ where t.deleted=0
+ <if test="param.name != null and param.name != ''">
+ AND t.coupon_name like concat('%', #{param.name},'%')
+ </if>
+ <if test="param.couponDiscountType != null and param.couponDiscountType != ''">
+ AND t.coupon_discount_type = #{param.couponDiscountType}
+ </if>
+ <if test="param.getType != null and param.getType != ''">
+ AND t.get_type = #{param.getType}
+ </if>
+ <if test="param.getUserType != null and param.getUserType != ''">
+ AND t.get_user_type = #{param.getUserType}
+ </if>
+ <if test="param.id != null and param.id != ''">
+ AND t.id = #{param.id}
+ </if>
+ <if test="param.orderNo != null and param.orderNo != ''">
+ AND t.order_no like concat('%', #{param.orderNo},'%')
+ </if>
+ <if test="param.tel != null and param.tel != ''">
+ AND t.tel like concat('%', #{param.tel},'%')
+ </if>
+ <if test="param.status != null and param.status != ''">
+ AND t.status = #{param.status}
+ </if>
+ <if test="param.keyword != null and param.keyword != ''">
+ AND (t.customerName like concat('%', #{param.keyword},'%')
+ or t.user_id like concat('%', #{param.keyword},'%') )
+ </if>
+ order by t.create_time desc
+ </sql>
+
+
+
+</mapper>
diff --git a/src/main/resources/mapper/coupon/CouponTemplateCustomerMapper.xml b/src/main/resources/mapper/coupon/CouponTemplateCustomerMapper.xml
new file mode 100644
index 0000000..c876065
--- /dev/null
+++ b/src/main/resources/mapper/coupon/CouponTemplateCustomerMapper.xml
@@ -0,0 +1,12 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
+<mapper namespace="com.mzl.flower.mapper.coupon.CouponTemplateCustomerMapper">
+
+ <!-- 通用查询映射结果 -->
+ <resultMap id="BaseResultMap" type="com.mzl.flower.entity.coupon.CouponTemplateCustomerDO">
+ <id column="id" property="id" />
+ <result column="coupon_id" property="couponId" />
+ <result column="custom_id" property="customId" />
+ </resultMap>
+
+</mapper>
diff --git a/src/main/resources/mapper/coupon/CouponTemplateMapper.xml b/src/main/resources/mapper/coupon/CouponTemplateMapper.xml
new file mode 100644
index 0000000..78ee51d
--- /dev/null
+++ b/src/main/resources/mapper/coupon/CouponTemplateMapper.xml
@@ -0,0 +1,40 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
+<mapper namespace="com.mzl.flower.mapper.coupon.CouponTemplateMapper">
+
+ <!-- 通用查询映射结果 -->
+ <resultMap id="BaseResultMap" type="com.mzl.flower.entity.coupon.CouponTemplateDO">
+ <id column="id" property="id" />
+ <result column="create_by" property="createBy" />
+ <result column="create_time" property="createTime" />
+ <result column="update_by" property="updateBy" />
+ <result column="update_time" property="updateTime" />
+ <result column="deleted" property="deleted" />
+ <result column="coupon_code" property="couponCode" />
+ <result column="coupon_name" property="couponName" />
+ <result column="coupon_description" property="couponDescription" />
+ <result column="coupon_amount" property="couponAmount" />
+ <result column="coupon_discount_type" property="couponDiscountType" />
+ <result column="coupon_discount_value" property="couponDiscountValue" />
+ <result column="min_order_amount" property="minOrderAmount" />
+ <result column="max_discount_amount" property="maxDiscountAmount" />
+ <result column="get_type" property="getType" />
+ <result column="get_user_type" property="getUserType" />
+ <result column="get_start_date" property="getStartDate" />
+ <result column="get_end_date" property="getEndDate" />
+ <result column="get_limit" property="getLimit" />
+ <result column="usage_type" property="usageType" />
+ <result column="usage_limit" property="usageLimit" />
+ <result column="usage_per_user" property="usagePerUser" />
+ <result column="usage_start_date" property="usageStartDate" />
+ <result column="usage_end_date" property="usageEndDate" />
+ <result column="usage_time_type" property="usageTimeType" />
+ <result column="usage_time_num" property="usageTimeNum" />
+ <result column="status" property="status" />
+
+ <result column="vip_grade" property="vipGrade" />
+
+
+ </resultMap>
+
+</mapper>
diff --git a/src/main/resources/mapper/coupon/CouponTemplateMapperCustom.xml b/src/main/resources/mapper/coupon/CouponTemplateMapperCustom.xml
new file mode 100644
index 0000000..62f1f26
--- /dev/null
+++ b/src/main/resources/mapper/coupon/CouponTemplateMapperCustom.xml
@@ -0,0 +1,101 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
+<mapper namespace="com.mzl.flower.mapper.coupon.CouponTemplateMapperCustom">
+
+ <!-- 通用查询映射结果 -->
+ <resultMap id="BaseResultMap" type="com.mzl.flower.entity.coupon.CouponTemplateDO">
+ <id column="id" property="id" />
+ <result column="create_by" property="createBy" />
+ <result column="create_time" property="createTime" />
+ <result column="update_by" property="updateBy" />
+ <result column="update_time" property="updateTime" />
+ <result column="deleted" property="deleted" />
+ <result column="category" property="category" />
+ <result column="coupon_code" property="couponCode" />
+ <result column="coupon_name" property="couponName" />
+ <result column="coupon_description" property="couponDescription" />
+ <result column="coupon_amount" property="couponAmount" />
+ <result column="coupon_discount_type" property="couponDiscountType" />
+ <result column="coupon_discount_value" property="couponDiscountValue" />
+ <result column="min_order_amount" property="minOrderAmount" />
+ <result column="max_discount_amount" property="maxDiscountAmount" />
+ <result column="get_type" property="getType" />
+ <result column="get_user_type" property="getUserType" />
+ <result column="get_start_date" property="getStartDate" />
+ <result column="get_end_date" property="getEndDate" />
+ <result column="get_limit" property="getLimit" />
+ <result column="usage_type" property="usageType" />
+ <result column="usage_limit" property="usageLimit" />
+ <result column="usage_per_user" property="usagePerUser" />
+ <result column="usage_start_date" property="usageStartDate" />
+ <result column="usage_end_date" property="usageEndDate" />
+ <result column="usage_time_type" property="usageTimeType" />
+ <result column="usage_time_num" property="usageTimeNum" />
+ <result column="status" property="status" />
+ <result column="point" property="point" />
+ <result column="vip_grade" property="vipGrade" />
+
+ </resultMap>
+ <update id="activeBatchCouponTemplate">
+ update t_coupon_template set status='active',update_by=#{dto.updateBy},update_time=now() where id in
+ <foreach collection="dto.idList" item="item" open="(" separator="," close=")">
+ #{item}
+ </foreach>
+ </update>
+ <update id="expireBatchCouponTemplate">
+ update t_coupon_template set status='expired',update_by=#{dto.updateBy},update_time=now() where id in
+ <foreach collection="dto.idList" item="item" open="(" separator="," close=")">
+ #{item}
+ </foreach>
+ </update>
+
+ <update id="deleteBatchCouponTemplate">
+ update t_coupon_template set deleted=true ,update_by=#{dto.updateBy},update_time=now() where id in
+ <foreach collection="dto.idList" item="item" open="(" separator="," close=")">
+ #{item}
+ </foreach>
+ </update>
+
+ <select id="getCouponTemplatePage" resultType="com.mzl.flower.dto.response.coupon.CouponTemplateVO">
+ <include refid="QuerySql2"></include>
+ </select>
+ <select id="getList" resultType="com.mzl.flower.dto.response.coupon.CouponTemplateVO">
+ <include refid="QuerySql2"></include>
+ </select>
+
+ <sql id="QuerySql2">
+ select *
+ from (
+ select t.*,
+ create_by_user.nick_name as createByName,
+ IFNULL(get_num.cnt, 0) as getNum,
+ IFNULL(t.coupon_amount, 0) - IFNULL(get_num.cnt, 0) as unGetNum
+ from t_coupon_template t
+ left join t_user create_by_user
+ on t.create_by =create_by_user.id
+ left join (select coupon_template_id,count(1) as cnt from t_coupon_usage where deleted=0 group by coupon_template_id) get_num
+ on t.id=get_num.coupon_template_id
+ ) t
+ where t.deleted=0
+ <if test="param.name != null and param.name != ''">
+ AND t.coupon_name like concat('%', #{param.name},'%')
+ </if>
+ <if test="param.couponDiscountType != null and param.couponDiscountType != ''">
+ AND t.coupon_discount_type = #{param.couponDiscountType}
+ </if>
+ <if test="param.getType != null and param.getType != ''">
+ AND t.get_type = #{param.getType}
+ </if>
+ <if test="param.getUserType != null and param.getUserType != ''">
+ AND t.get_user_type = #{param.getUserType}
+ </if>
+ <if test="param.id != null and param.id != ''">
+ AND t.id = #{param.id}
+ </if>
+ <if test="param.category != null and param.category != ''">
+ AND t.category = #{param.category}
+ </if>
+ order by t.create_time desc
+ </sql>
+
+</mapper>
--
Gitblit v1.9.3