From d1cab4b2f2690d1331f12f0d9de78bbbf926f390 Mon Sep 17 00:00:00 2001
From: 无关风月 <443237572@qq.com>
Date: 星期四, 16 一月 2025 14:27:51 +0800
Subject: [PATCH] Merge branch 'master' of http://120.76.84.145:10101/gitblit/r/java/qijisheng

---
 ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/controller/GoodsController.java |   64 +++++++++++++++++++++++++++++---
 1 files changed, 58 insertions(+), 6 deletions(-)

diff --git a/ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/controller/GoodsController.java b/ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/controller/GoodsController.java
index 2e72477..b4b019b 100644
--- a/ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/controller/GoodsController.java
+++ b/ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/controller/GoodsController.java
@@ -10,10 +10,12 @@
 import com.ruoyi.common.core.web.controller.BaseController;
 import com.ruoyi.common.core.web.page.PageInfo;
 import com.ruoyi.common.core.web.page.TableDataInfo;
+import com.ruoyi.common.redis.annotation.DistributedLock;
 import com.ruoyi.other.api.domain.Goods;
 import com.ruoyi.other.api.domain.VipSetting;
 import com.ruoyi.other.api.feignClient.VipSettingClient;
 import com.ruoyi.other.service.GoodsService;
+import com.ruoyi.other.service.VipSettingService;
 import com.ruoyi.other.vo.GoodsVO;
 import io.swagger.annotations.*;
 import org.springframework.web.bind.annotation.*;
@@ -37,6 +39,8 @@
     private GoodsService goodsService;
     @Resource
     private VipSettingClient settingClient;
+    @Resource
+    private VipSettingService vipSettingService;
 
     /**
      * 添加商品
@@ -44,6 +48,9 @@
     @PostMapping("/addGoods")
     @ApiOperation(value = "发布商品", tags = {"管理后台-商品管理"})
     public R<Void> addGoods(@RequestBody Goods goods) {
+        if(goods.getPurchaseLimit()==null){
+            goods.setPurchaseLimit(-1);
+        }
         goodsService.addGoods(goods);
         return R.ok();
     }
@@ -74,6 +81,9 @@
     @PutMapping("/manageGoodsUpdate")
     @ApiOperation(value = "商品修改", tags = {"管理后台-商品管理"})
     public R<Void> manageGoodsUpdate(@RequestBody Goods goods){
+        if(goods.getPurchaseLimit()==null){
+            goods.setPurchaseLimit(-1);
+        }
         goodsService.updateManageGoods(goods);
         if (goods.getType()==2){
             goods.setAppointStore(2);
@@ -123,6 +133,10 @@
     @DeleteMapping("/manageGoodsDelete/{goodsId}")
     @ApiOperation(value = "商品删除", tags = {"管理后台-商品管理"})
     public R<Void> manageGoodsDelete(@PathVariable("goodsId") Long goodsId){
+        long count = vipSettingService.count(new LambdaQueryWrapper<VipSetting>().last(" where FIND_IN_SET(" + goodsId + ", good_ids)"));
+        if(0 < count){
+            return R.fail("商品已被会员配置使用,不能删除");
+        }
         goodsService.removeById(goodsId);
         return R.ok();
     }
@@ -165,11 +179,14 @@
      */
     @GetMapping("/goodsDetail/{goodsId}")
     @ApiOperation(value = "商品详情", tags = {"小程序-商城-首页"})
-    public R<GoodsVO> goodsDetail(@PathVariable("goodsId") Long goodsId, String longitude, String latitude){
-        return R.ok(goodsService.goodsDetail(goodsId, longitude, latitude));
+    public R<GoodsVO> goodsDetail(@PathVariable("goodsId") Long goodsId,
+                                  Integer shopId,
+                                  String longitude,
+                                  String latitude) {
+        return R.ok(goodsService.goodsDetail(goodsId, shopId, longitude, latitude));
     }
-    
-    
+
+
     /**
      * 根据类型(1=服务商品,2=单品商品)获取商品数据
      * @param type
@@ -181,8 +198,8 @@
         List<Goods> list = goodsService.list(new LambdaQueryWrapper<Goods>().eq(Goods::getType, type).eq(Goods::getDelFlag, 0).eq(Goods::getStatus, 2));
         return R.ok(list);
     }
-    
-    
+
+
     /**
      * 根据id获取商品信息
      * @param id
@@ -202,5 +219,40 @@
         return R.ok(goods);
     }
 
+
+    /**
+     * 编辑商品
+     * @param goods
+     * @return
+     */
+    @PostMapping("/editGoodsList")
+    public R editGoodsList(@RequestBody List<Goods> goods){
+        goodsService.updateBatchById(goods);
+        return R.ok();
+    }
+
+
+    /**
+     * 商品销量增加
+     */
+    @PutMapping("/editGoodsNum")
+    @DistributedLock(lockNamePre = "#goods_lock", lockNamePost = "#goodsId")
+    public R<Void> editGoodsNum(@RequestParam("goodsId") Integer goodsId, @RequestParam("num") Integer num){
+        Goods goods = goodsService.getById(goodsId);
+        goods.setSaleNum(goods.getSaleNum() + num);
+        goodsService.updateById(goods);
+        return R.ok();
+    }
+
+
+    /**
+     * 获取所有商品
+     * @return
+     */
+    @PostMapping("/getAllGoods")
+    public R<List<Goods>> getAllGoods(){
+        List<Goods> list = goodsService.list(new LambdaQueryWrapper<Goods>().eq(Goods::getDelFlag, 0).eq(Goods::getStatus, 2));
+        return R.ok(list);
+    }
 }
 

--
Gitblit v1.7.1