From 392b42c4891cf2e6beda57ab32c51598f290f4b7 Mon Sep 17 00:00:00 2001
From: mitao <2763622819@qq.com>
Date: 星期五, 14 三月 2025 20:56:27 +0800
Subject: [PATCH] bug修改

---
 ruoyi-modules/ruoyi-promotion/src/main/java/com/ruoyi/promotion/controller/management/MgtCouponController.java |  119 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 119 insertions(+), 0 deletions(-)

diff --git a/ruoyi-modules/ruoyi-promotion/src/main/java/com/ruoyi/promotion/controller/management/MgtCouponController.java b/ruoyi-modules/ruoyi-promotion/src/main/java/com/ruoyi/promotion/controller/management/MgtCouponController.java
index ea7dd90..74b2292 100644
--- a/ruoyi-modules/ruoyi-promotion/src/main/java/com/ruoyi/promotion/controller/management/MgtCouponController.java
+++ b/ruoyi-modules/ruoyi-promotion/src/main/java/com/ruoyi/promotion/controller/management/MgtCouponController.java
@@ -1,6 +1,31 @@
 package com.ruoyi.promotion.controller.management;
 
 
+import com.alibaba.excel.EasyExcel;
+import com.alibaba.excel.util.DateUtils;
+import com.ruoyi.common.core.domain.R;
+import com.ruoyi.common.core.utils.page.PageDTO;
+import com.ruoyi.promotion.controller.management.dto.MgtCouponDTO;
+import com.ruoyi.promotion.controller.management.dto.MgtCouponQuery;
+import com.ruoyi.promotion.controller.management.dto.MgtCouponReceiveQuery;
+import com.ruoyi.promotion.controller.management.dto.MgtCouponUpdDTO;
+import com.ruoyi.promotion.controller.management.vo.CouponReceiveDetailVO;
+import com.ruoyi.promotion.controller.management.vo.MgtCouponVO;
+import com.ruoyi.promotion.service.ICouponService;
+import com.ruoyi.system.api.validate.InsertGroup;
+import com.ruoyi.system.api.validate.UpdateGroup;
+import io.swagger.annotations.Api;
+import io.swagger.annotations.ApiOperation;
+import java.io.IOException;
+import java.net.URLEncoder;
+import java.util.Date;
+import java.util.List;
+import javax.servlet.http.HttpServletResponse;
+import lombok.RequiredArgsConstructor;
+import org.springframework.validation.annotation.Validated;
+import org.springframework.web.bind.annotation.PostMapping;
+import org.springframework.web.bind.annotation.PutMapping;
+import org.springframework.web.bind.annotation.RequestBody;
 import org.springframework.web.bind.annotation.RequestMapping;
 import org.springframework.web.bind.annotation.RestController;
 
@@ -14,6 +39,100 @@
  */
 @RestController
 @RequestMapping("/mgt/coupon")
+@RequiredArgsConstructor
+@Api(value = "管理后台-优惠券管理相关接口", tags = "管理后台-优惠券管理相关接口")
 public class MgtCouponController {
 
+    private final ICouponService couponService;
+    private final HttpServletResponse response;
+
+    /**
+     * 获取优惠券列表的分页数据
+     *
+     * @param query 管理后台-优惠券查询对象
+     * @return PageDTO<MgtCouponVO>
+     */
+    @ApiOperation(value = "获取优惠券列表的分页数据", notes = "优惠券列表的分页数据")
+    @PostMapping("/page")
+    public R<PageDTO<MgtCouponVO>> getCouponPage(@Validated @RequestBody MgtCouponQuery query) {
+        return R.ok(couponService.getCouponPage(query));
+    }
+
+    /**
+     * 添加优惠券
+     *
+     * @param dto 管理后台-优惠券数据传输对象
+     */
+    @ApiOperation("添加优惠券")
+    @PostMapping("/add")
+    public R<?> saveCoupon(@Validated(InsertGroup.class) @RequestBody MgtCouponDTO dto) {
+        couponService.saveCoupon(dto);
+        return R.ok();
+    }
+
+    /**
+     * 编辑优惠券
+     *
+     * @param dto 管理后台-优惠券数据传输对象
+     */
+    @ApiOperation("编辑优惠券")
+    @PutMapping("/update")
+    public R<?> updateCoupon(@Validated(UpdateGroup.class) @RequestBody MgtCouponDTO dto) {
+        couponService.updateCoupon(dto);
+        return R.ok();
+    }
+
+    /**
+     * 上架/下架
+     *
+     * @param dto 管理后台-优惠券上架下架数据传输对象
+     */
+    @ApiOperation("上架/下架")
+    @PutMapping("/upd-status")
+    public R<?> updStatus(@Validated @RequestBody MgtCouponUpdDTO dto) {
+        couponService.updStatus(dto);
+        return R.ok();
+    }
+
+    /**
+     * 领取详情
+     *
+     * @param query 管理后台-优惠券领取详情查询对象
+     * @return PageDTO<CouponReceiveDetailVO>
+     */
+    @ApiOperation("领取详情")
+    @PostMapping("/receive-detail")
+    public R<PageDTO<CouponReceiveDetailVO>> getReceiveDetail(
+            @Validated @RequestBody MgtCouponReceiveQuery query) {
+        return R.ok(couponService.getReceiveDetail(query));
+    }
+
+    /**
+     * 导出优惠券领取详情
+     *
+     * @param query 管理后台-优惠券领取详情查询对象
+     */
+    @ApiOperation("领取详情-导出")
+    @PostMapping("/receive-detail/export")
+    public void exportReceiveDetail(@RequestBody MgtCouponReceiveQuery query) {
+        List<CouponReceiveDetailVO> couponReceiveDetailVOList = couponService.getCouponReceiveDetailList(
+                query);
+        response.setContentType(
+                "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet");
+        response.setCharacterEncoding("utf-8");
+        // 这里URLEncoder.encode可以防止中文乱码 当然和easyexcel没有关系
+        try {
+            String fileName = URLEncoder.encode(
+                            "优惠券领取明细" + DateUtils.format(new Date(), "yyyyMMddHHmmss"), "UTF-8")
+                    .replaceAll("\\+", "%20");
+            response.setHeader("Content-disposition",
+                    "attachment;filename*=utf-8''" + fileName + ".xlsx");
+            EasyExcel.write(response.getOutputStream(), CouponReceiveDetailVO.class)
+                    .sheet("优惠券领取明细")
+                    .doWrite(couponReceiveDetailVOList);
+        } catch (IOException e) {
+            throw new RuntimeException(e);
+        }
+    }
 }
+    

--
Gitblit v1.7.1