From 143d1c57f32e0bd34977491101c1feecc0ffc2df Mon Sep 17 00:00:00 2001
From: Cui Zhi Feng <7426394+wuxixiaocui@user.noreply.gitee.com>
Date: 星期一, 02 九月 2024 15:07:49 +0800
Subject: [PATCH] 积分商品批量删除和上下架

---
 src/main/resources/script/db-v2.sql                               |    2 ++
 src/main/java/com/mzl/flower/web/point/PointGoodsController.java  |   12 ++++++------
 src/main/java/com/mzl/flower/service/point/PointGoodsService.java |   32 ++++++++++++++++++++++----------
 3 files changed, 30 insertions(+), 16 deletions(-)

diff --git a/src/main/java/com/mzl/flower/service/point/PointGoodsService.java b/src/main/java/com/mzl/flower/service/point/PointGoodsService.java
index d7cca87..4c2ab59 100644
--- a/src/main/java/com/mzl/flower/service/point/PointGoodsService.java
+++ b/src/main/java/com/mzl/flower/service/point/PointGoodsService.java
@@ -71,8 +71,14 @@
         return p.getId();
     }
 
-    public void deletePointGoods(Long id){
-        pointGoodsMapper.deleteById(id);
+    public void deletePointGoods(String idStr){
+        List<String> ids = splitParam(idStr);
+        if (ids != null && ids.size() > 0) {
+            for(String idd : ids) {
+                Long id = Long.parseLong(idd);
+                pointGoodsMapper.deleteById(id);
+            }
+        }
     }
 
     public Page<PointGoodsListDTO> selectGoodsList(Page page, PointGoodsQueryDTO dto){
@@ -94,15 +100,21 @@
         return dto;
     }
 
-    public void updateStatus(Long id, String status){
-        PointGoods p = pointGoodsMapper.selectById(id);
-        if(p == null){
-            throw new ValidationException("商品未找到");
-        }
+    public void updateStatus(String idStr, String status){
+        List<String> ids = splitParam(idStr);
+        if(ids != null && ids.size() > 0) {
+            for(String idd : ids) {
+                Long id = Long.parseLong(idd);
+                PointGoods p = pointGoodsMapper.selectById(id);
+                if (p == null) {
+                    continue;
+                }
 
-        p.setStatus(status);
-        p.update(SecurityUtils.getUserId());
-        pointGoodsMapper.updateById(p);
+                p.setStatus(status);
+                p.update(SecurityUtils.getUserId());
+                pointGoodsMapper.updateById(p);
+            }
+        }
     }
 
     public synchronized void exchangeGoods(ExchangeGoodsDTO dto) {
diff --git a/src/main/java/com/mzl/flower/web/point/PointGoodsController.java b/src/main/java/com/mzl/flower/web/point/PointGoodsController.java
index 97614f8..5368dbd 100644
--- a/src/main/java/com/mzl/flower/web/point/PointGoodsController.java
+++ b/src/main/java/com/mzl/flower/web/point/PointGoodsController.java
@@ -61,9 +61,9 @@
     @GetMapping("/list/delete")
     @ApiOperation(value = "商品删除")
     @ApiImplicitParams({
-            @ApiImplicitParam(name = "id", value = "商品id", required = true, dataType = "Long", paramType = "query")
+            @ApiImplicitParam(name = "id", value = "商品id", required = true, dataType = "String", paramType = "query")
     })
-    public ResponseEntity<ReturnDataDTO<?>> deletePointGoods(Long id) {
+    public ResponseEntity<ReturnDataDTO<?>> deletePointGoods(String id) {
         pointGoodsService.deletePointGoods(id);
         return returnData(R.SUCCESS.getCode(), null);
     }
@@ -71,9 +71,9 @@
     @GetMapping("/list/on")
     @ApiOperation(value = "商品上架")
     @ApiImplicitParams({
-            @ApiImplicitParam(name = "id", value = "商品id", required = true, dataType = "Long", paramType = "query")
+            @ApiImplicitParam(name = "id", value = "商品id", required = true, dataType = "String", paramType = "query")
     })
-    public ResponseEntity<ReturnDataDTO<?>> upGoods(Long id) {
+    public ResponseEntity<ReturnDataDTO<?>> upGoods(String id) {
         pointGoodsService.updateStatus(id, Constants.POINT_GOODS_STATUS.A.name());
         return returnData(R.SUCCESS.getCode(), null);
     }
@@ -81,9 +81,9 @@
     @GetMapping("/list/off")
     @ApiOperation(value = "商品下架")
     @ApiImplicitParams({
-            @ApiImplicitParam(name = "id", value = "商品id", required = true, dataType = "Long", paramType = "query")
+            @ApiImplicitParam(name = "id", value = "商品id", required = true, dataType = "String", paramType = "query")
     })
-    public ResponseEntity<ReturnDataDTO<?>> offGoods(Long id) {
+    public ResponseEntity<ReturnDataDTO<?>> offGoods(String id) {
         pointGoodsService.updateStatus(id, Constants.POINT_GOODS_STATUS.I.name());
         return returnData(R.SUCCESS.getCode(), null);
     }
diff --git a/src/main/resources/script/db-v2.sql b/src/main/resources/script/db-v2.sql
index c8c0f76..12c75ef 100644
--- a/src/main/resources/script/db-v2.sql
+++ b/src/main/resources/script/db-v2.sql
@@ -13,6 +13,8 @@
 ALTER TABLE `t_order_item` ADD `original_price` DECIMAL(11,2)  COMMENT '优惠前售价/扎';
 ALTER TABLE `t_order_item` ADD `real_price` DECIMAL(11,2)  COMMENT '真实成交价格/每扎';
 
+INSERT INTO t_code_value(ID,TYPE_CODE,VALUE,LABEL,DESCRIPTION,SEQ,STATUS) VALUES ('POINT_GOODS_STATUS_A','POINT_GOODS_STATUS','A','上架','上架',1,'A');
+INSERT INTO t_code_value(ID,TYPE_CODE,VALUE,LABEL,DESCRIPTION,SEQ,STATUS) VALUES ('POINT_GOODS_STATUS_I','POINT_GOODS_STATUS','I','下架','下架',2,'A');
 
 
 

--
Gitblit v1.9.3