From d53c16a12e612a95dc8f6fb248e3669cbc441eb4 Mon Sep 17 00:00:00 2001
From: Pu Zhibing <393733352@qq.com>
Date: 星期二, 17 十二月 2024 16:48:41 +0800
Subject: [PATCH] 新增加商品特价接口

---
 ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/controller/GoodsBargainPriceController.java |   94 ++++++++++++++++++++++++++++++++++++----------
 1 files changed, 73 insertions(+), 21 deletions(-)

diff --git a/ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/controller/GoodsBargainPriceController.java b/ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/controller/GoodsBargainPriceController.java
index 72a84a9..952197d 100644
--- a/ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/controller/GoodsBargainPriceController.java
+++ b/ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/controller/GoodsBargainPriceController.java
@@ -3,20 +3,22 @@
 
 import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import com.ruoyi.account.api.feignClient.AppUserClient;
+import com.ruoyi.account.api.model.AppUser;
 import com.ruoyi.common.core.domain.R;
 import com.ruoyi.common.core.utils.StringUtils;
+import com.ruoyi.common.core.web.controller.BaseController;
+import com.ruoyi.common.core.web.page.TableDataInfo;
 import com.ruoyi.common.security.service.TokenService;
-import com.ruoyi.other.api.domain.Goods;
-import com.ruoyi.other.api.domain.GoodsBargainPrice;
-import com.ruoyi.other.api.domain.GoodsBargainPriceDetail;
+import com.ruoyi.other.api.domain.*;
 import com.ruoyi.other.api.vo.GetGoodsBargainPrice;
-import com.ruoyi.other.service.GoodsBargainPriceDetailService;
-import com.ruoyi.other.service.GoodsBargainPriceService;
-import com.ruoyi.other.service.GoodsService;
+import com.ruoyi.other.service.*;
+import com.ruoyi.other.vo.AddGoodsBargainPriceVo;
+import com.ruoyi.other.vo.GoodsBargainPriceInfo;
+import com.ruoyi.other.vo.ShopGoodsList;
+import com.ruoyi.other.vo.ShopGoodsListVo;
 import com.ruoyi.system.api.model.LoginUser;
-import io.swagger.annotations.Api;
-import io.swagger.annotations.ApiOperation;
-import io.swagger.annotations.ApiParam;
+import io.swagger.annotations.*;
 import io.swagger.models.auth.In;
 import org.springframework.transaction.annotation.Transactional;
 import org.springframework.util.CollectionUtils;
@@ -24,6 +26,7 @@
 
 import javax.annotation.Resource;
 import java.util.List;
+import java.util.stream.Collectors;
 
 import static com.alibaba.nacos.shaded.org.checkerframework.checker.units.UnitsTools.g;
 
@@ -52,12 +55,19 @@
     @Resource
     private GoodsService goodsService;
 
+    @Resource
+    private GoodsCategoryService goodsCategoryService;
+
+    @Resource
+    private AppUserClient appUserClient;
+
+    @Resource
+    private ShopService shopService;
+
 
     /**
      * 根据商品id和会员等级获取门店特价
      *
-     * @param goodsBargainPrice
-     * @return
      */
     @PostMapping("/getGoodsBargainPrice")
     public R<GoodsBargainPriceDetail> getGoodsBargainPrice(@RequestBody GetGoodsBargainPrice goodsBargainPrice) {
@@ -80,7 +90,7 @@
      * 新增
      */
     @PostMapping("/add")
-    @ApiOperation(value = "新增", tags = {"后台管理-门店特殊售价"})
+    @ApiOperation(value = "新增", tags = {"管理后台-商品管理-门店特殊售价"})
     @Transactional(rollbackFor = Exception.class)
     public R<Void> add(@RequestBody GoodsBargainPrice goodsBargainPrice) {
         LoginUser loginUserApplet = tokenService.getLoginUserApplet();
@@ -106,7 +116,7 @@
      * 删除
      */
     @DeleteMapping("/delete")
-    @ApiOperation(value = "删除", tags = {"后台管理-门店特殊售价"})
+    @ApiOperation(value = "删除", tags = {"管理后台-商品管理-门店特殊售价-"})
     public R<Void> delete(@ApiParam("id") @RequestParam("id") Integer id) {
         goodsBargainPriceService.removeById(id);
         goodsBargainPriceDetailService.remove(new LambdaQueryWrapper<GoodsBargainPriceDetail>()
@@ -118,7 +128,7 @@
      * 修改
      */
     @PutMapping("/edit")
-    @ApiOperation(value = "修改", tags = {"后台管理-门店特殊售价"})
+    @ApiOperation(value = "修改", tags = {"管理后台-商品管理-门店特殊售价"})
     @Transactional(rollbackFor = Exception.class)
     public R<Void> edit(@RequestBody GoodsBargainPrice goodsBargainPrice) {
         goodsBargainPriceService.updateById(goodsBargainPrice);
@@ -132,7 +142,7 @@
      * 详情
      */
     @GetMapping("/detail")
-    @ApiOperation(value = "详情", tags = {"后台管理-门店特殊售价"})
+    @ApiOperation(value = "详情", tags = {"管理后台-商品管理-门店特殊售价"})
     public R<GoodsBargainPrice> detail(@ApiParam("id") @RequestParam("id") Integer id) {
         GoodsBargainPrice goodsBargainPrice = goodsBargainPriceService.getById(id);
         List<GoodsBargainPriceDetail> goodsBargainPriceDetailList = goodsBargainPriceDetailService.list(new LambdaQueryWrapper<GoodsBargainPriceDetail>()
@@ -145,7 +155,7 @@
      * 列表
      */
     @GetMapping("/list")
-    @ApiOperation(value = "列表", tags = {"后台管理-门店特殊售价"})
+    @ApiOperation(value = "列表", tags = {"管理后台-商品管理-门店特殊售价"})
     public R<Page<GoodsBargainPrice>> list(@ApiParam("页码") @RequestParam(value = "pageNum", required = false) Integer pageNum,
                                            @ApiParam("每页数量") @RequestParam(value = "pageSize", required = false) Integer pageSize,
                                            @ApiParam("商品id") @RequestParam(value = "goodsId", required = false) Integer goodsId,
@@ -155,19 +165,61 @@
                                            @ApiParam("审核状态") @RequestParam(value = "auditStatus", required = false) Integer auditStatus) {
 
 
-        List<Integer> goodsIds = goodsService.listObjs(new LambdaQueryWrapper<Goods>()
-                .select(Goods::getId)
+        List<Goods> goodsList = goodsService.list(new LambdaQueryWrapper<Goods>()
                 .eq(StringUtils.isNotEmpty(goodsName), Goods::getName, goodsName)
                 .eq(goodsType != null, Goods::getType, goodsType)
                 .eq(categoryId != null, Goods::getGoodsCategoryId, categoryId));
+        List<Integer> goodsIds = goodsList.stream().map(Goods::getId).collect(Collectors.toList());
+        if (goodsId != null){
+            goodsIds.add(goodsId);
+        }
 
-        goodsIds.add(goodsId);
         Page<GoodsBargainPrice> page = goodsBargainPriceService.page(Page.of(pageNum, pageSize), new LambdaQueryWrapper<GoodsBargainPrice>()
                 .eq(!CollectionUtils.isEmpty(goodsIds), GoodsBargainPrice::getGoodsId, goodsId)
                 .eq(auditStatus != null, GoodsBargainPrice::getAuditStatus, auditStatus));
+
+        page.getRecords().forEach(goodsBargainPrice -> goodsList.stream()
+                .filter(goods -> goods.getId().equals(goodsBargainPrice.getGoodsId()))
+                .findFirst().ifPresent(g -> {
+                    GoodsCategory goodsCategory = goodsCategoryService.getById(g.getGoodsCategoryId());
+                    Integer shopId = goodsBargainPrice.getShopId();
+                    Shop shop = shopService.getById(shopId);
+                    R<AppUser> r = appUserClient.getAppUserByPhone1(shop.getPhone());
+                    if (R.isError(r)){
+                        throw new RuntimeException("获取店长信息失败");
+                    }
+                    goodsBargainPrice.setOwnerName(r.getData().getName());
+                    goodsBargainPrice.setOwnerPhone(shop.getPhone());
+                    goodsBargainPrice.setShopName(shop.getName());
+                    goodsBargainPrice.setGoodsName(g.getName());
+                    goodsBargainPrice.setCategoryName(goodsCategory.getName());
+                }));
+
         return R.ok(page);
     }
-
-
+    
+    
+    
+    
+    @ResponseBody
+    @GetMapping("/getGoodsBargainPriceInfo/{id}")
+    @ApiOperation(value = "获取商品特殊售价详情", tags = {"门店后台-商品管理"})
+    @ApiImplicitParams({
+            @ApiImplicitParam(value = "商品id", name = "id", required = true, dataType = "int"),
+    })
+    public R<GoodsBargainPriceInfo> getGoodsBargainPriceInfo(@PathVariable("id") Integer id){
+        GoodsBargainPriceInfo goodsBargainPriceInfo = goodsBargainPriceService.getGoodsBargainPriceInfo(id);
+        return R.ok(goodsBargainPriceInfo);
+    }
+    
+    
+    
+    
+    @ResponseBody
+    @GetMapping("/addGoodsBargainPrice/{id}")
+    @ApiOperation(value = "保存商品特殊售价", tags = {"门店后台-商品管理"})
+    public R addGoodsBargainPrice(@RequestBody AddGoodsBargainPriceVo vo){
+        return goodsBargainPriceService.addGoodsBargainPrice(vo);
+    }
 }
 

--
Gitblit v1.7.1