|  |  |  | 
|---|
|  |  |  | //  如果选择平台商品和查询结果对不上,提示错误 | 
|---|
|  |  |  | throw  new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"对不起,请正确选择平台商品!"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | List<Multifile> multifileList = new ArrayList<>(); | 
|---|
|  |  |  | List<GoodsParam> goodsParamList = new ArrayList<>(); | 
|---|
|  |  |  | for(BaseGoods model : goodsList){ | 
|---|
|  |  |  | //遍历平台商品信息,进行商品信息同步 | 
|---|
|  |  |  | Goods goods = initGoodsPlatParam(user,model,param); | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | goodsMapper.insert(goods); | 
|---|
|  |  |  | //开始处理附件 | 
|---|
|  |  |  | dealPlatMultifule(goods.getId(),user,model); | 
|---|
|  |  |  | dealPlatMultifule(goods.getId(),user,model,multifileList); | 
|---|
|  |  |  | //开始处理参数配置 | 
|---|
|  |  |  | dealPlatGoodsParam(model,goods,user); | 
|---|
|  |  |  | dealPlatGoodsParam(model,goods,user,goodsParamList); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if(multifileList.size()>0){ | 
|---|
|  |  |  | multifileMapper.insertBatch(multifileList); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if(goodsParamList.size()>0){ | 
|---|
|  |  |  | goodsParamMapper.insertBatch(goodsParamList); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | return 1; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | private void dealPlatGoodsParam(BaseGoods model, Goods goods, LoginUserInfo user) { | 
|---|
|  |  |  | private void dealPlatGoodsParam(BaseGoods model, Goods goods, LoginUserInfo user,List<GoodsParam> paramList) { | 
|---|
|  |  |  | BaseGoodsParam baseGoodsParam = new BaseGoodsParam(); | 
|---|
|  |  |  | baseGoodsParam.setGoodsId(model.getId()); | 
|---|
|  |  |  | baseGoodsParam.setIsdeleted(Constants.ZERO); | 
|---|
|  |  |  | 
|---|
|  |  |  | goodsParam.setVal(bgParam.getVal()); | 
|---|
|  |  |  | goodsParam.setName(bgParam.getName()); | 
|---|
|  |  |  | goodsParam.setPramaId(Objects.isNull(cateParam)?null:cateParam.getId()); | 
|---|
|  |  |  | goodsParamMapper.insert(goodsParam); | 
|---|
|  |  |  | paramList.add(goodsParam); | 
|---|
|  |  |  | //                goodsParamMapper.insert(goodsParam); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | Goods goods = new Goods(); | 
|---|
|  |  |  | goods.setIsdeleted(Constants.ZERO); | 
|---|
|  |  |  | goods.setGoodsId(model.getId()); | 
|---|
|  |  |  | goods.setCompanyId(user.getCompanyId()); | 
|---|
|  |  |  | if(goodsMapper.selectCount(new QueryWrapper<>(goods))>0){ | 
|---|
|  |  |  | //如果已经同步过,跳过此次同步 | 
|---|
|  |  |  | return  null; | 
|---|
|  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | *  开始处理平台商品关联附件,复制一套到企业商品上 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | private void dealPlatMultifule(Integer id, LoginUserInfo user, BaseGoods model) { | 
|---|
|  |  |  | private void dealPlatMultifule(Integer id, LoginUserInfo user, BaseGoods model,List<Multifile> fileList ) { | 
|---|
|  |  |  | Multifile f = new Multifile(); | 
|---|
|  |  |  | f.setObjId(model.getId()); | 
|---|
|  |  |  | f.setIsdeleted(Constants.ZERO); | 
|---|
|  |  |  | 
|---|
|  |  |  | multifile.setName(multifile.getName()); | 
|---|
|  |  |  | multifile.setSortnum(multifile.getSortnum()); | 
|---|
|  |  |  | multifile.setCompanyId(user.getCompanyId()); | 
|---|
|  |  |  | multifileMapper.insert(multifile); | 
|---|
|  |  |  | fileList.add(multifile); | 
|---|
|  |  |  | //                multifileMapper.insert(multifile); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | if(Constants.equalsInteger(Constants.ONE, param.getType())){ | 
|---|
|  |  |  | for(PlatGoodsParam p: param.getGoodsParamList()){ | 
|---|
|  |  |  | if(Constants.equalsInteger(model.getId(),p.getGoodsId())){ | 
|---|
|  |  |  | return p.getPrice(); | 
|---|
|  |  |  | return p.getPrice().setScale(0,BigDecimal.ROUND_CEILING); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //如果没有配置入手价,安装加价系数来计算 | 
|---|
|  |  |  | if(model.getCateRatePrice()==null){ | 
|---|
|  |  |  | model.setCateRatePrice(systemDictDataBiz.getGoodsPriceRate()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //返回 | 
|---|
|  |  |  | return Constants.formatBigdecimal(model.getPrice()).multiply(model.getCateRatePrice()).multiply(param.getRate()); | 
|---|
|  |  |  | //        if(model.getCateRatePrice()==null){ | 
|---|
|  |  |  | //            model.setCateRatePrice(systemDictDataBiz.getGoodsPriceRate()); | 
|---|
|  |  |  | //        } | 
|---|
|  |  |  | //返回 .multiply(model.getCateRatePrice()) | 
|---|
|  |  |  | return (Constants.formatBigdecimal(model.getPrice()).multiply(param.getRate())).setScale(0,BigDecimal.ROUND_CEILING); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | multifile.setObjId(goods.getId()); | 
|---|
|  |  |  | multifile.setType(Constants.ZERO); | 
|---|
|  |  |  | multifile.setObjType(Constants.ZERO); | 
|---|
|  |  |  | multifile.setCompanyId(goods.getCompanyId()); | 
|---|
|  |  |  | multifileMapper.insert(multifile); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | goodsParam.setSortnum(i+Constants.ONE); | 
|---|
|  |  |  | goodsParam.setGoodsId(goods.getId()); | 
|---|
|  |  |  | goodsParamMapper.insert(goodsParam); | 
|---|
|  |  |  | //存储 cate_param_select 查询是否已存在 | 
|---|
|  |  |  | //                if(cateParamSelectMapper.selectCount(new QueryWrapper<CateParamSelect>() | 
|---|
|  |  |  | //                        .eq("PARAM_ID",goodsParam.getPramaId()).eq("NAME",goodsParam.getName()))<=Constants.ZERO){ | 
|---|
|  |  |  | //                    CateParamSelect cateParamSelect = new CateParamSelect(); | 
|---|
|  |  |  | //                    cateParamSelect.setCreator(user.getId()); | 
|---|
|  |  |  | //                    cateParamSelect.setCreateDate(new Date()); | 
|---|
|  |  |  | //                    cateParamSelect.setName(goodsParam.getVal()); | 
|---|
|  |  |  | //                    cateParamSelect.setIsdeleted(Constants.ZERO); | 
|---|
|  |  |  | //                    cateParamSelect.setStatus(Constants.ZERO); | 
|---|
|  |  |  | //                    cateParamSelect.setParamId(goodsParam.getPramaId()); | 
|---|
|  |  |  | //                    cateParamSelect.setCategoryId(goods.getCategoryId()); | 
|---|
|  |  |  | //                    cateParamSelect.setStatus(Constants.ZERO); | 
|---|
|  |  |  | //                    cateParamSelectMapper.insert(cateParamSelect); | 
|---|
|  |  |  | //                }; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return goods.getId(); | 
|---|
|  |  |  | 
|---|
|  |  |  | }else{ | 
|---|
|  |  |  | throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"当前登录用户类别错误,无法进行该操作"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if(goodsMapper.selectCount(new QueryWrapper<Goods>().eq("COMPANY_ID",user.getCompanyId()).eq("ISDELETED",Constants.ZERO).ne("id",goods.getId()).eq("name",goods.getName()))>0){ | 
|---|
|  |  |  | if(goodsMapper.selectCount(new QueryWrapper<Goods>().eq("COMPANY_ID",user.getCompanyId()) | 
|---|
|  |  |  | .eq("ISDELETED",Constants.ZERO).ne("id",goods.getId()).eq("name",goods.getName()))>0){ | 
|---|
|  |  |  | throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"【"+goods.getName()+"】已存在"); | 
|---|
|  |  |  | }; | 
|---|
|  |  |  | goods.setStatus(Constants.ZERO); | 
|---|
|  |  |  | 
|---|
|  |  |  | multifile.setSortnum(i+Constants.ONE); | 
|---|
|  |  |  | multifile.setObjId(goods.getId()); | 
|---|
|  |  |  | multifile.setType(Constants.ZERO); | 
|---|
|  |  |  | multifile.setCompanyId(goods.getCompanyId()); | 
|---|
|  |  |  | multifile.setObjType(Constants.ZERO); | 
|---|
|  |  |  | multifileMapper.insert(multifile); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | throw new BusinessException(ResponseStatus.DATA_EMPTY); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //拉式商品 且 上架时,需要限制 平台商品是否已下架 | 
|---|
|  |  |  | if(dbGoods.getType().equals(Constants.goodsType.PULL)&&goods.getStatus().equals(Constants.ZERO)){ | 
|---|
|  |  |  | if(dbGoods.getType().equals(Constants.goodsType.PULL.getValue())&&goods.getStatus().equals(Constants.ZERO)){ | 
|---|
|  |  |  | BaseGoods baseGoods = baseGoodsMapper.selectById(dbGoods.getGoodsId()); | 
|---|
|  |  |  | if(Objects.isNull(baseGoods)){ | 
|---|
|  |  |  | throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"未查询到平台商品信息"); | 
|---|
|  |  |  | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //拉式商品 且 上架时,需要限制 平台商品是否已下架 | 
|---|
|  |  |  | if(dbGoods.getType().equals(Constants.goodsType.PULL)&&batchDisableDTO.getStatus().equals(Constants.ZERO)){ | 
|---|
|  |  |  | if(dbGoods.getType().equals(Constants.goodsType.PULL.getValue())&&batchDisableDTO.getStatus().equals(Constants.ZERO)){ | 
|---|
|  |  |  | BaseGoods baseGoods = baseGoodsMapper.selectById(dbGoods.getGoodsId()); | 
|---|
|  |  |  | if(Objects.isNull(baseGoods)||!baseGoods.getStatus().equals(Constants.ZERO)){ | 
|---|
|  |  |  | errNum++; | 
|---|
|  |  |  | 
|---|
|  |  |  | goodsIPage.getRecords().forEach(i->{ | 
|---|
|  |  |  | i.setPrefixUrl(prefixUrl); | 
|---|
|  |  |  | i.setMultifileList(multifileMapper.selectList(new QueryWrapper<Multifile>().eq("OBJ_ID",i.getId()).orderByAsc(" SORTNUM "))); | 
|---|
|  |  |  | i.setGoodsParamList(goodsParamMapper.selectList(new QueryWrapper<GoodsParam>().eq("GOODS_ID",i.getId()).orderByAsc(" SORTNUM "))); | 
|---|
|  |  |  | i.setGoodsParamList(goodsParamMapper.selectList(new QueryWrapper<GoodsParam>() | 
|---|
|  |  |  | .eq("GOODS_ID",i.getId()) | 
|---|
|  |  |  | .orderByAsc(" SORTNUM "))); | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | return PageData.from(goodsIPage); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | goodsList.forEach(i->{ | 
|---|
|  |  |  | i.setPrefixUrl(prefixUrl); | 
|---|
|  |  |  | i.setMultifileList(multifileMapper.selectList(new QueryWrapper<Multifile>().eq("OBJ_ID",i.getId()).orderByAsc(" SORTNUM "))); | 
|---|
|  |  |  | i.setGoodsParamList(goodsParamMapper.selectList(new QueryWrapper<GoodsParam>().eq("GOODS_ID",i.getId()).orderByAsc(" SORTNUM "))); | 
|---|
|  |  |  | i.setGoodsParamList(goodsParamMapper.selectList( | 
|---|
|  |  |  | new QueryWrapper<GoodsParam>().eq("GOODS_ID",i.getId()) | 
|---|
|  |  |  | .apply(" name in ( select cp.NAME from cate_param cp where cp.CATEGORY_ID = "+i.getCategoryId()+" and cp.ISSHOW = 1 and cp.ISDELETED = 0 and cp.STATUS = 0 ) ") | 
|---|
|  |  |  | .orderByAsc(" SORTNUM "))); | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | return goodsList; | 
|---|
|  |  |  | } | 
|---|