From 9b7a45a3985f18da4784fbb742f8aa236c951d5c Mon Sep 17 00:00:00 2001
From: huanghongfa <huanghongfa123456>
Date: 星期三, 21 四月 2021 10:07:02 +0800
Subject: [PATCH] bug修复

---
 springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/service/impl/ComShopGoodsServiceImpl.java |   84 ++++++++++++++++++++++-------------------
 1 files changed, 45 insertions(+), 39 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 5d38b84..6433941 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,29 +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.PageShopStoreVO;
-import com.panzhihua.service_community.dao.ComShopGoodsAttrDAO;
-import com.panzhihua.common.model.dtos.shop.PageComShopGoodsDTO;
-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;
@@ -64,9 +52,15 @@
         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.getGoodsDescribe());
         int goodsId = this.baseMapper.insert(shopGoodsDO);
         if (goodsId > 0) {
             ArrayList<ComShopGoodsAttrDO> goodsAttrDOS = Lists.newArrayList();
@@ -81,9 +75,14 @@
                 shopGoodsAttrDO.setStoreId(goodDO.getStoreId());
                 shopGoodsAttrDO.setGoodsName(goodDO.getName());
                 //如果没有规格加默认
-                shopGoodsAttrDO.setGoodsAttr(goodsAttr.getGoodsAttr());
+                if(StringUtils.isNotEmpty(goodsAttr.getGoodsAttr())){
+                    shopGoodsAttrDO.setGoodsAttr("默认");
+                }else{
+                    shopGoodsAttrDO.setGoodsAttr(goodsAttr.getGoodsAttr());
+                }
                 shopGoodsAttrDO.setIsDefault(1);
                 shopGoodsAttrDO.setPrice(goodsAttr.getAttrPrice());
+                shopGoodsAttrDO.setAttrPic(images[0]);
                 goodsAttrDOS.add(shopGoodsAttrDO);
             });
             if (goodsAttrDOS.size() > 0) {
@@ -97,23 +96,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);
     }
 
@@ -136,15 +132,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);
@@ -187,9 +184,18 @@
      * @return 商品列表
      */
     @Override
-    public R pageShopGoods(ComShopGoodsDTO comShopGoodsDTO) {
-        Page page = new Page<>(comShopGoodsDTO.getPageNum(), comShopGoodsDTO.getPageSize());
-        return R.ok(this.baseMapper.pageShopGoodByApps(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);
     }
 
     /**

--
Gitblit v1.7.1