From 970ed0f8df6a19e4e3dae062c4e2e2232a0b97d0 Mon Sep 17 00:00:00 2001
From: huanghongfa <huanghongfa123456>
Date: 星期三, 21 四月 2021 11:06:45 +0800
Subject: [PATCH] 删除商家bug修复

---
 springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/service/impl/ComShopGoodsServiceImpl.java |  145 ++++++++++++++++++++++++++---------------------
 1 files changed, 80 insertions(+), 65 deletions(-)

diff --git a/springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/service/impl/ComShopGoodsServiceImpl.java b/springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/service/impl/ComShopGoodsServiceImpl.java
index fee1058..0b7e793 100644
--- a/springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/service/impl/ComShopGoodsServiceImpl.java
+++ b/springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/service/impl/ComShopGoodsServiceImpl.java
@@ -1,12 +1,9 @@
 package com.panzhihua.service_community.service.impl;
 
-import java.math.BigDecimal;
-
 import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
 import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import com.baomidou.mybatisplus.core.metadata.IPage;
-import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
 import com.google.common.collect.Lists;
 import com.panzhihua.common.exceptions.ServiceException;
@@ -16,30 +13,20 @@
 import com.panzhihua.common.model.vos.shop.AddShopGoodsAttrVO;
 import com.panzhihua.common.model.vos.shop.PageShopGoodsVO;
 import com.panzhihua.common.model.vos.shop.AddShopGoodsVO;
+import com.panzhihua.common.utlis.StringUtils;
 import com.panzhihua.service_community.dao.ComShopGoodsAttrDAO;
 import com.panzhihua.common.model.vos.shop.ComShopGoodsAttrVO;
 import com.panzhihua.common.model.vos.shop.ComShopGoodsVO;
-import com.panzhihua.common.model.vos.shop.ComShopStoreVO;
-import com.panzhihua.service_community.dao.ComShopGoodsAttrDAO;
-import com.panzhihua.common.model.dtos.shop.PageComShopGoodsDTO;
-import com.panzhihua.common.model.vos.shop.ComShopStoreVO;
-import com.panzhihua.common.model.vos.shop.ShopGoodsVO;
+import com.panzhihua.common.model.vos.shop.PageShopStoreVO;
 import com.panzhihua.service_community.dao.ComShopGoodsDAO;
 import com.panzhihua.service_community.model.dos.ComShopGoodsAttrDO;
 import com.panzhihua.service_community.dao.ComShopStoreDAO;
-import com.panzhihua.service_community.model.dos.ComShopGoodsAttrDO;
 import com.panzhihua.service_community.model.dos.ComShopGoodsDO;
 import com.panzhihua.service_community.model.dos.ComShopStoreDO;
 import com.panzhihua.service_community.service.ComShopGoodsService;
 import lombok.extern.slf4j.Slf4j;
 import org.springframework.beans.BeanUtils;
 import org.springframework.stereotype.Service;
-
-import javax.annotation.Resource;
-import java.util.ArrayList;
-import java.util.Arrays;
-import java.util.List;
-import java.util.stream.Collectors;
 
 import javax.annotation.Resource;
 import java.util.ArrayList;
@@ -65,15 +52,20 @@
         if (addShopGoodsVO == null) {
             return R.ok("500", "数据为空!");
         }
+        String[] images = addShopGoodsVO.getGoodsPic().split(",");
         ComShopGoodsDO shopGoodsDO = new ComShopGoodsDO();
         BeanUtils.copyProperties(addShopGoodsVO, shopGoodsDO);
+        if (images.length > 1) {
+            shopGoodsDO.setGoodsPic(images[0]);
+        }
+        shopGoodsDO.setImages(addShopGoodsVO.getGoodsPic());
         shopGoodsDO.setSale(0);
+        shopGoodsDO.setDetails(addShopGoodsVO.getDetails());
         int goodsId = this.baseMapper.insert(shopGoodsDO);
         if (goodsId > 0) {
             ArrayList<ComShopGoodsAttrDO> goodsAttrDOS = Lists.newArrayList();
-            addShopGoodsVO.getGoodsAttrVOList().forEach(goodsAttr -> {
-                ComShopGoodsDO goodDO = this.baseMapper.selectById(shopGoodsDO.getId());
-                //维护商品规格表
+            ComShopGoodsDO goodDO = this.baseMapper.selectById(shopGoodsDO.getId());
+            addShopGoodsVO.getGoodsAttrVOList().forEach(goodsAttr -> {//维护商品规格表
                 if (goodDO == null) {
                     throw new ServiceException("商家id不存在!");
                 }
@@ -81,12 +73,23 @@
                 shopGoodsAttrDO.setGoodsId(shopGoodsDO.getId());
                 shopGoodsAttrDO.setStoreId(goodDO.getStoreId());
                 shopGoodsAttrDO.setGoodsName(goodDO.getName());
-                //如果没有规格加默认
                 shopGoodsAttrDO.setGoodsAttr(goodsAttr.getGoodsAttr());
                 shopGoodsAttrDO.setIsDefault(1);
                 shopGoodsAttrDO.setPrice(goodsAttr.getAttrPrice());
+                shopGoodsAttrDO.setAttrPic(images[0]);
                 goodsAttrDOS.add(shopGoodsAttrDO);
             });
+            if (addShopGoodsVO.getGoodsAttrVOList().size() < 1) {//如果没有规格参数加默认
+                ComShopGoodsAttrDO shopGoodsAttrDO = new ComShopGoodsAttrDO();
+                shopGoodsAttrDO.setGoodsId(shopGoodsDO.getId());
+                shopGoodsAttrDO.setStoreId(goodDO.getStoreId());
+                shopGoodsAttrDO.setGoodsName(goodDO.getName());
+                shopGoodsAttrDO.setGoodsAttr("默认");
+                shopGoodsAttrDO.setIsDefault(1);
+                shopGoodsAttrDO.setPrice(goodDO.getPrice());
+                shopGoodsAttrDO.setAttrPic(images[0]);
+                goodsAttrService.save(shopGoodsAttrDO);
+            }
             if (goodsAttrDOS.size() > 0) {
                 goodsAttrService.saveBatch(goodsAttrDOS);
             }
@@ -98,23 +101,20 @@
     public R pageGoodsList(PageComShopGoodsDTO pageComShopGoodsDTO) {
         Page page = new Page<>(pageComShopGoodsDTO.getPageNum(), pageComShopGoodsDTO.getPageSize());
         IPage<PageShopGoodsVO> comShopStoreVOIPage = this.baseMapper.pageShopGoods(page, pageComShopGoodsDTO);
-        List<PageShopGoodsVO> shopGoodsVOS = comShopStoreVOIPage.getRecords();
-        List<Long> goodsIds = shopGoodsVOS.stream().map(PageShopGoodsVO::getId).collect(Collectors.toList());
-        LambdaQueryWrapper<ComShopGoodsAttrDO> in = new LambdaQueryWrapper<ComShopGoodsAttrDO>().in(ComShopGoodsAttrDO::getGoodsId, goodsIds);
-        //分页查询商品规格,组装数据
-        List<ComShopGoodsAttrDO> goodsAttrDOS = goodsAttrService.getBaseMapper().selectList(in);
-        comShopStoreVOIPage.getRecords().forEach(vo -> {
-            List<ComShopGoodsAttrDO> goodsAttrDOs = goodsAttrDOS.stream().filter(goodsAttr -> goodsAttr.getGoodsId().equals(vo.getId())).collect(Collectors.toList());
-            ArrayList<AddShopGoodsAttrVO> goodsAttrVOList = Lists.newArrayList();
-            for (ComShopGoodsAttrDO oneGoodsAttrDO :goodsAttrDOs) {
-                AddShopGoodsAttrVO goodsAttrVO = new AddShopGoodsAttrVO();
-                goodsAttrVO.setGoodsAttrId(oneGoodsAttrDO.getId());
-                goodsAttrVO.setGoodsAttr(oneGoodsAttrDO.getGoodsAttr());
-                goodsAttrVO.setAttrPrice(oneGoodsAttrDO.getPrice());
-                goodsAttrVOList.add(goodsAttrVO);
-            }
-            vo.setGoodsAttts(goodsAttrVOList);
-        });
+        if (!comShopStoreVOIPage.getRecords().isEmpty()) {
+            comShopStoreVOIPage.getRecords().forEach(shopGoods -> {
+                List<ComShopGoodsAttrDO> goodsAttrDOs = shopGoodsAttrDAO.selectList(new QueryWrapper<ComShopGoodsAttrDO>().lambda().eq(ComShopGoodsAttrDO::getGoodsId, shopGoods.getId()));
+                ArrayList<AddShopGoodsAttrVO> goodsAttrVOList = Lists.newArrayList();
+                for (ComShopGoodsAttrDO oneGoodsAttrDO : goodsAttrDOs) {
+                    AddShopGoodsAttrVO goodsAttrVO = new AddShopGoodsAttrVO();
+                    goodsAttrVO.setGoodsAttrId(oneGoodsAttrDO.getId());
+                    goodsAttrVO.setGoodsAttr(oneGoodsAttrDO.getGoodsAttr());
+                    goodsAttrVO.setAttrPrice(oneGoodsAttrDO.getPrice());
+                    goodsAttrVOList.add(goodsAttrVO);
+                }
+                shopGoods.setGoodsAttts(goodsAttrVOList);
+            });
+        }
         return R.ok(comShopStoreVOIPage);
     }
 
@@ -137,15 +137,16 @@
             }
             //先删除
             ComShopGoodsAttrDO goodsAttrDO = goodsAttrService.getBaseMapper().selectById(goodsAttr.getGoodsAttrId());
-            if (goodsAttrDO == null) {
-                throw new ServiceException("规格为空,请检查规格Id");
-            }
             ComShopGoodsAttrDO shopGoodsAttrDO = new ComShopGoodsAttrDO();
             shopGoodsAttrDO.setGoodsId(id);
             shopGoodsAttrDO.setStoreId(shopGoodsDO.getStoreId());
             shopGoodsAttrDO.setGoodsName(shopGoodsDO.getName());
-            //如果没有规格加默认
-            shopGoodsAttrDO.setGoodsAttr(goodsAttr.getGoodsAttr());
+            if (goodsAttrDO == null) {
+                //如果没有规格加默认
+                shopGoodsAttrDO.setGoodsAttr(goodsAttr.getGoodsAttr());
+            } else {
+                shopGoodsAttrDO.setGoodsAttr("默认");
+            }
             shopGoodsAttrDO.setIsDefault(1);
             shopGoodsAttrDO.setPrice(goodsAttr.getAttrPrice());
             goodsAttrDOS.add(shopGoodsAttrDO);
@@ -161,68 +162,82 @@
 
     @Override
     public R deleteShopGoods(Long[] id) {
-        ComShopGoodsDO storeDO = new ComShopGoodsDO();
-        storeDO.setDeleteStatus(2);
-        LambdaQueryWrapper<ComShopGoodsDO> query = new LambdaQueryWrapper<ComShopGoodsDO>().eq(ComShopGoodsDO::getId, id);
-        int update = this.baseMapper.update(storeDO, query);
-        return update > 0 ? R.ok() : R.fail();
+        LambdaQueryWrapper<ComShopGoodsDO> query = new LambdaQueryWrapper<ComShopGoodsDO>().in(ComShopGoodsDO::getId, id);
+        List<ComShopGoodsDO> comShopGoodsDOS = this.baseMapper.selectList(query);
+        for (ComShopGoodsDO one : comShopGoodsDOS) {
+            one.setDeleteStatus(2);
+            this.baseMapper.updateById(one);
+        }
+        return R.ok();
     }
 
     @Override
     public R changeStatus(Long id, Integer status) {
         ComShopGoodsDO shopGoodsDO = this.baseMapper.selectById(id);
-        if(shopGoodsDO==null){
+        if (shopGoodsDO == null) {
             return R.fail("id有误!");
         }
         shopGoodsDO.setStatus(status);
         this.baseMapper.updateById(shopGoodsDO);
         return R.ok();
     }
+
     /**
      * 分页查询商品列表
-     * @param comShopGoodsDTO   请求参数
-     * @return  商品列表
+     *
+     * @param comShopGoodsDTO 请求参数
+     * @return 商品列表
      */
     @Override
-    public R pageShopGoods(ComShopGoodsDTO comShopGoodsDTO){
-        Page page = new Page<>(comShopGoodsDTO.getPageNum(),comShopGoodsDTO.getPageSize());
-        return R.ok(this.baseMapper.pageShopGoods(page,comShopGoodsDTO));
+    public R pageShopGoods(ComShopGoodsDTO comShopGoodsDTO) {
+        Page page = new Page<>(comShopGoodsDTO.getPageNum(), comShopGoodsDTO.getPageSize());
+        IPage<ComShopGoodsVO> goodsVOIPage = this.baseMapper.pageShopGoodByApps(page, comShopGoodsDTO);
+        if (!goodsVOIPage.getRecords().isEmpty()) {
+            goodsVOIPage.getRecords().forEach(goodsVo -> {
+                List<ComShopGoodsAttrVO> goodsAttrList = shopGoodsAttrDAO.getGoodsAttr(goodsVo.getId());
+                if (!goodsAttrList.isEmpty()) {
+                    goodsVo.setGoodsAttrList(goodsAttrList);
+                }
+            });
+        }
+        return R.ok(goodsVOIPage);
     }
 
     /**
      * 根据商品id查询商品信息
-     * @param goodsId   商品id
-     * @return  商品信息
+     *
+     * @param goodsId 商品id
+     * @return 商品信息
      */
     @Override
-    public R shopGoodsDetail(Long goodsId){
+    public R shopGoodsDetail(Long goodsId) {
 
         //根据id查询商品信息
         ComShopGoodsDO goodsDO = this.baseMapper.selectById(goodsId);
-        if(goodsDO == null || goodsDO.getDeleteStatus().equals(ComShopGoodsDO.deleteStatus.yes)){
-            return R.fail(403,"商品不存在");
+        if (goodsDO == null || goodsDO.getDeleteStatus().equals(ComShopGoodsDO.deleteStatus.yes)) {
+            return R.fail(403, "商品不存在");
         }
-        if(!goodsDO.getStatus().equals(ComShopGoodsDO.status.sell)){
-            return R.fail(405,"商品已下架");
+        if (!goodsDO.getStatus().equals(ComShopGoodsDO.status.sell)) {
+            return R.fail(405, "商品已下架");
         }
 
         //根据商品id查询商品规格信息
         List<ComShopGoodsAttrVO> goodsAttrList = new ArrayList<>();
-        List<ComShopGoodsAttrDO> goodsAttrDOS = shopGoodsAttrDAO.selectList(new QueryWrapper<ComShopGoodsAttrDO>().eq("goods_id",goodsId));
-        goodsAttrDOS.forEach(attrDO->{
+        List<ComShopGoodsAttrDO> goodsAttrDOS = shopGoodsAttrDAO.selectList(new QueryWrapper<ComShopGoodsAttrDO>().eq("goods_id", goodsId));
+        goodsAttrDOS.forEach(attrDO -> {
             ComShopGoodsAttrVO goodsAttrVO = new ComShopGoodsAttrVO();
-            BeanUtils.copyProperties(attrDO,goodsAttrVO);
+            BeanUtils.copyProperties(attrDO, goodsAttrVO);
             goodsAttrList.add(goodsAttrVO);
         });
 
         //查询商品店铺信息
         ComShopStoreDO shopStoreDO = shopStoreDAO.selectById(goodsDO.getStoreId());
-        ComShopStoreVO shopStoreVO = new ComShopStoreVO();
-        BeanUtils.copyProperties(shopStoreDO,shopStoreVO);
+        PageShopStoreVO shopStoreVO = new PageShopStoreVO();
+        BeanUtils.copyProperties(shopStoreDO, shopStoreVO);
 
         //设置值
         ComShopGoodsVO shopGoods = new ComShopGoodsVO();
-        BeanUtils.copyProperties(goodsDO,shopGoods);
+        BeanUtils.copyProperties(goodsDO, shopGoods);
         shopGoods.setGoodsAttrList(goodsAttrList);
         shopGoods.setShopStoreVO(shopStoreVO);
         return R.ok(shopGoods);

--
Gitblit v1.7.1