|  |  |  | 
|---|
|  |  |  | import com.doumee.service.business.BaseDataService; | 
|---|
|  |  |  | import com.doumee.service.business.GoodsService; | 
|---|
|  |  |  | import com.github.yulichang.wrapper.MPJLambdaWrapper; | 
|---|
|  |  |  | import io.swagger.v3.oas.annotations.callbacks.Callback; | 
|---|
|  |  |  | import lombok.extern.java.Log; | 
|---|
|  |  |  | import org.apache.commons.lang3.StringUtils; | 
|---|
|  |  |  | import org.apache.poi.ss.usermodel.*; | 
|---|
|  |  |  | import org.apache.poi.xssf.usermodel.XSSFWorkbook; | 
|---|
|  |  |  | 
|---|
|  |  |  | return goods.getId(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | @Transactional( rollbackFor = {Exception.class, BusinessException.class}) | 
|---|
|  |  |  | public  Integer createPlat(GoodCreatePlatRequest param){ | 
|---|
|  |  |  | LoginUserInfo user = (LoginUserInfo) SecurityUtils.getSubject().getPrincipal(); | 
|---|
|  |  |  | if(!Constants.equalsInteger(user.getType(), Constants.UserType.COMPANY.getKey())){ | 
|---|
|  |  |  | 
|---|
|  |  |  | //  如果选择平台商品和查询结果对不上,提示错误 | 
|---|
|  |  |  | 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); | 
|---|
|  |  |  | 
|---|
|  |  |  | if(!Objects.isNull(goodsParamList)&&goodsParamList.size()>0){ | 
|---|
|  |  |  | for (int i = 0; i < goodsParamList.size(); i++) { | 
|---|
|  |  |  | BaseGoodsParam bgParam = goodsParamList.get(i); | 
|---|
|  |  |  | //根据平台商品配置的平台参数信息查询企业绑定的参数信息 进行存储到 企业商品参数内 | 
|---|
|  |  |  | CateParam cateParam = cateParamMapper.selectOne(new QueryWrapper<CateParam>() | 
|---|
|  |  |  | .eq("CATEGORY_ID",goods.getCategoryId()) | 
|---|
|  |  |  | .eq("BASE_CATE_PARAM_ID",bgParam.getPramaId()) | 
|---|
|  |  |  | .eq("ISDELETED",Constants.ZERO) | 
|---|
|  |  |  | .eq("STATUS",Constants.ZERO) | 
|---|
|  |  |  | .last(" limit 1 ")); | 
|---|
|  |  |  | //                if(Objects.isNull(cateParam)){ | 
|---|
|  |  |  | //                    throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"企业分类数据同步异常请联系管理员"); | 
|---|
|  |  |  | //                } | 
|---|
|  |  |  | GoodsParam goodsParam = new GoodsParam(); | 
|---|
|  |  |  | goodsParam.setCreator(user.getId()); | 
|---|
|  |  |  | goodsParam.setCreateDate(new Date()); | 
|---|
|  |  |  | 
|---|
|  |  |  | goodsParam.setGoodsId(goods.getId()); | 
|---|
|  |  |  | goodsParam.setVal(bgParam.getVal()); | 
|---|
|  |  |  | goodsParam.setName(bgParam.getName()); | 
|---|
|  |  |  | goodsParamMapper.insert(goodsParam); | 
|---|
|  |  |  | goodsParam.setPramaId(Objects.isNull(cateParam)?null:cateParam.getId()); | 
|---|
|  |  |  | 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); | 
|---|
|  |  |  | 
|---|
|  |  |  | goods.setShortPinyin(PinYinUtil.getFirstSpell(goods.getName())); | 
|---|
|  |  |  | goodsMapper.updateById(goods); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | multifileMapper.delete(new QueryWrapper<Multifile>().eq("OBJ_ID",goods.getId())); | 
|---|
|  |  |  | multifileMapper.delete(new QueryWrapper<Multifile>().eq("OBJ_ID",goods.getId()) | 
|---|
|  |  |  | .eq("OBJ_TYPE",0).eq("COMPANY_ID",user.getCompanyId())); | 
|---|
|  |  |  | List<Multifile> multifileList = goods.getMultifileList(); | 
|---|
|  |  |  | if(!Objects.isNull(multifileList)&&multifileList.size()>Constants.ZERO){ | 
|---|
|  |  |  | for (int i = 0; i < multifileList.size(); i++) { | 
|---|
|  |  |  | 
|---|
|  |  |  | multifile.setSortnum(i+Constants.ONE); | 
|---|
|  |  |  | multifile.setObjId(goods.getId()); | 
|---|
|  |  |  | multifile.setType(Constants.ZERO); | 
|---|
|  |  |  | multifile.setCompanyId(goods.getCompanyId()); | 
|---|
|  |  |  | multifile.setObjType(Constants.ZERO); | 
|---|
|  |  |  | multifileMapper.insert(multifile); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | 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); | 
|---|
|  |  |  | }; | 
|---|
|  |  |  | //                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); | 
|---|
|  |  |  | //                }; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | 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++; | 
|---|
|  |  |  | 
|---|
|  |  |  | if (pageWrap.getModel().getStatus() != null) { | 
|---|
|  |  |  | queryWrapper.eq(Goods::getStatus, pageWrap.getModel().getStatus()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (pageWrap.getModel().getType() != null) { | 
|---|
|  |  |  | queryWrapper.eq(Goods::getType, pageWrap.getModel().getType()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (pageWrap.getModel().getCategoryId() != null) { | 
|---|
|  |  |  | queryWrapper.eq(Goods::getCategoryId, pageWrap.getModel().getCategoryId()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | + systemDictDataBiz.queryByCode(Constants.OSS, Constants.GOODS_IMG).getCode(); | 
|---|
|  |  |  | goodsIPage.getRecords().forEach(i->{ | 
|---|
|  |  |  | i.setPrefixUrl(prefixUrl); | 
|---|
|  |  |  | if(i.getType().equals(Constants.ONE)){ | 
|---|
|  |  |  | i.setBasePrice(i.getBasePrice().multiply(i.getBasePriceRate())); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | return PageData.from(goodsIPage); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | String proDir =systemDictDataBiz.queryByCode(Constants.SYSTEM,Constants.PROJECTS).getCode(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | String path = systemDictDataBiz.queryByCode(Constants.SYSTEM,Constants.GOODS_IMG_DIR).getCode() | 
|---|
|  |  |  | + proDir; | 
|---|
|  |  |  | + proDir + File.separator + user.getCompanyId(); | 
|---|
|  |  |  | if(StringUtils.isNotBlank(path)){ | 
|---|
|  |  |  | OssModel ossModel = baseDataService.initOssModel(); | 
|---|
|  |  |  | File dir =new File(path+File.separator+newModel.getRemark()+File.separator); | 
|---|
|  |  |  | 
|---|
|  |  |  | if(mulFiles==null){ | 
|---|
|  |  |  | mulFiles = new ArrayList<>(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | mulFiles.add(baseDataService.getOssImgurl(ossModel,ossModel.getGoodsFolder(),f)); | 
|---|
|  |  |  | mulFiles.add(baseDataService.getOssImgurl(ossModel,ossModel.getGoodsFolder(),mf)); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | //插入产品参数关联表 | 
|---|
|  |  |  | goodsParamMapper.insert(gp); | 
|---|
|  |  |  | //存储 cate_param_select 查询是否已存在 | 
|---|
|  |  |  | if(cateParamSelectMapper.selectCount(new QueryWrapper<CateParamSelect>() | 
|---|
|  |  |  | .eq("PARAM_ID",gp.getPramaId()).eq("NAME",gp.getName()))<=Constants.ZERO){ | 
|---|
|  |  |  | CateParamSelect cateParamSelect = new CateParamSelect(); | 
|---|
|  |  |  | cateParamSelect.setCreator(user.getId()); | 
|---|
|  |  |  | cateParamSelect.setCreateDate(new Date()); | 
|---|
|  |  |  | cateParamSelect.setName(gp.getVal()); | 
|---|
|  |  |  | cateParamSelect.setIsdeleted(Constants.ZERO); | 
|---|
|  |  |  | cateParamSelect.setStatus(Constants.ZERO); | 
|---|
|  |  |  | cateParamSelect.setParamId(gp.getPramaId()); | 
|---|
|  |  |  | cateParamSelect.setCategoryId(newModel.getCategoryId()); | 
|---|
|  |  |  | cateParamSelect.setStatus(Constants.ZERO); | 
|---|
|  |  |  | cateParamSelectMapper.insert(cateParamSelect); | 
|---|
|  |  |  | }; | 
|---|
|  |  |  | //                    if(cateParamSelectMapper.selectCount(new QueryWrapper<CateParamSelect>() | 
|---|
|  |  |  | //                            .eq("PARAM_ID",gp.getPramaId()).eq("NAME",gp.getName()))<=Constants.ZERO){ | 
|---|
|  |  |  | //                        CateParamSelect cateParamSelect = new CateParamSelect(); | 
|---|
|  |  |  | //                        cateParamSelect.setCreator(user.getId()); | 
|---|
|  |  |  | //                        cateParamSelect.setCreateDate(new Date()); | 
|---|
|  |  |  | //                        cateParamSelect.setName(gp.getVal()); | 
|---|
|  |  |  | //                        cateParamSelect.setIsdeleted(Constants.ZERO); | 
|---|
|  |  |  | //                        cateParamSelect.setStatus(Constants.ZERO); | 
|---|
|  |  |  | //                        cateParamSelect.setParamId(gp.getPramaId()); | 
|---|
|  |  |  | //                        cateParamSelect.setCategoryId(newModel.getCategoryId()); | 
|---|
|  |  |  | //                        cateParamSelect.setStatus(Constants.ZERO); | 
|---|
|  |  |  | //                        cateParamSelectMapper.insert(cateParamSelect); | 
|---|
|  |  |  | //                    }; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if(mulFiles !=null && mulFiles.size()>0){ | 
|---|
|  |  |  | 
|---|
|  |  |  | f.setCreator(newModel.getCreator()); | 
|---|
|  |  |  | f.setIsdeleted(Constants.ZERO); | 
|---|
|  |  |  | f.setSortnum(i); | 
|---|
|  |  |  | f.setCompanyId(user.getCompanyId()); | 
|---|
|  |  |  | f.setFileurl(s); | 
|---|
|  |  |  | multifileMapper.insert(f); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public void export(HttpServletRequest request, HttpServletResponse response) throws Exception { | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | LoginUserInfo loginUserInfo = (LoginUserInfo) SecurityUtils.getSubject().getPrincipal(); | 
|---|
|  |  |  | String fileName = "产品导入表"+System.currentTimeMillis()+".xlsx"; | 
|---|
|  |  |  | // 获取文件输入流 | 
|---|
|  |  |  | InputStream inputStream =  this.getClass().getClassLoader().getResourceAsStream("static/file/goodsExcelTemp.xlsx"); | 
|---|
|  |  |  | 
|---|
|  |  |  | // sheet.getPhysicalNumberOfRows()获取总的行数 | 
|---|
|  |  |  | // 循环读取每一行 | 
|---|
|  |  |  | Row row = sheet.createRow(1); | 
|---|
|  |  |  | List<Category> categoryList = categoryMapper.selectList(new QueryWrapper<Category>().eq("ISDELETED",0)); | 
|---|
|  |  |  | List<Category> categoryList = categoryMapper.selectList( | 
|---|
|  |  |  | new QueryWrapper<Category>().eq("ISDELETED",0) | 
|---|
|  |  |  | .eq("COMPANY_ID",loginUserInfo.getCompanyId()) | 
|---|
|  |  |  | ); | 
|---|
|  |  |  | categoryList.forEach(i->{ | 
|---|
|  |  |  | i.setParamList(cateParamMapper.selectList(new QueryWrapper<CateParam>().eq("ISDELETED",0).eq("CATEGORY_ID",i.getId()))); | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | 
|---|
|  |  |  | .or().like(Goods::getShortPinyin,pageWrap.getModel().getKeyword()) | 
|---|
|  |  |  | .or().like(Goods::getName,pageWrap.getModel().getKeyword()) | 
|---|
|  |  |  | ) | 
|---|
|  |  |  | .apply(!Objects.isNull(pageWrap.getModel()) && !Objects.isNull(pageWrap.getModel().getAttrFirst()), " find_in_set('"+pageWrap.getModel().getAttrFirst()+"',t.ATTR_FIRST_IDS) ") | 
|---|
|  |  |  | .apply(!Objects.isNull(pageWrap.getModel()) && !Objects.isNull(pageWrap.getModel().getAttrSecond()), " find_in_set('"+pageWrap.getModel().getAttrSecond()+"',t.ATTR_SECOD_IDS) ") | 
|---|
|  |  |  | //                .apply(!Objects.isNull(pageWrap.getModel()) && !Objects.isNull(pageWrap.getModel().getAttrFirst()), " find_in_set('"+pageWrap.getModel().getAttrFirst()+"',t.ATTR_FIRST_IDS) ") | 
|---|
|  |  |  | //                .apply(!Objects.isNull(pageWrap.getModel()) && !Objects.isNull(pageWrap.getModel().getAttrSecond()), " find_in_set('"+pageWrap.getModel().getAttrSecond()+"',t.ATTR_SECOD_IDS) ") | 
|---|
|  |  |  | .apply(!Objects.isNull(pageWrap.getModel()) && !Objects.isNull(pageWrap.getModel().getAttrFirst()), " t.id in ( SELECT  gp.GOODS_ID   FROM  cate_param_select cps  ,  goods_param gp where     gp.PRAMA_ID = cps.PARAM_ID     and gp.VAL = cps.`NAME`  " + | 
|---|
|  |  |  | " and cps.ID = '"+pageWrap.getModel().getAttrFirst()+"' ) ") | 
|---|
|  |  |  | .apply(!Objects.isNull(pageWrap.getModel()) && !Objects.isNull(pageWrap.getModel().getAttrSecond()), " t.id in ( SELECT  gp.GOODS_ID   FROM  cate_param_select cps  ,  goods_param gp where     gp.PRAMA_ID = cps.PARAM_ID     and gp.VAL = cps.`NAME`  " + | 
|---|
|  |  |  | " and cps.ID = '"+pageWrap.getModel().getAttrSecond()+"' ) ") | 
|---|
|  |  |  | .apply(!Objects.isNull(pageWrap.getModel()) && !Objects.isNull(pageWrap.getModel().getSPrice()), "  t.PRICE >=  "+pageWrap.getModel().getSPrice()+" ") | 
|---|
|  |  |  | .apply(!Objects.isNull(pageWrap.getModel()) && !Objects.isNull(pageWrap.getModel().getEPrice()), "  t.PRICE <=  "+pageWrap.getModel().getEPrice()+" "); | 
|---|
|  |  |  | queryWrapper.orderByDesc(Goods::getId); | 
|---|
|  |  |  | IPage<Goods> goodsIPage =  goodsJoinMapper.selectJoinPage(page, Goods.class, queryWrapper); | 
|---|
|  |  |  | String prefixUrl = systemDictDataBiz.queryByCode(Constants.SYSTEM, Constants.FILE_DIR).getCode() | 
|---|
|  |  |  | + systemDictDataBiz.queryByCode(Constants.SYSTEM, Constants.PROJECTS).getCode(); | 
|---|
|  |  |  | String prefixUrl = systemDictDataBiz.queryByCode(Constants.OSS, Constants.RESOURCE_PATH).getCode() | 
|---|
|  |  |  | + systemDictDataBiz.queryByCode(Constants.OSS, Constants.GOODS_IMG).getCode(); | 
|---|
|  |  |  | 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); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public List<Goods> findListForH5(GoodsRequest goodsRequest) { | 
|---|
|  |  |  | LoginUserInfo loginUserInfo = (LoginUserInfo) SecurityUtils.getSubject().getPrincipal(); | 
|---|
|  |  |  | if(!loginUserInfo.getType().equals(Constants.UserType.ZHUBO.getKey())){ | 
|---|
|  |  |  | throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"非主播用户无法使用"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | MPJLambdaWrapper<Goods> queryWrapper = new MPJLambdaWrapper<>(); | 
|---|
|  |  |  | queryWrapper.selectAll(Goods.class); | 
|---|
|  |  |  | queryWrapper.selectAs(Category::getName, Goods::getCategoryName); | 
|---|
|  |  |  | 
|---|
|  |  |  | queryWrapper.leftJoin(Brand.class, Brand::getId, Goods::getBrandId); | 
|---|
|  |  |  | queryWrapper.eq(Goods::getStatus,Constants.ZERO); | 
|---|
|  |  |  | queryWrapper.eq(Goods::getIsdeleted,Constants.ZERO); | 
|---|
|  |  |  | queryWrapper.eq(Goods::getCompanyId,loginUserInfo.getCompanyId()); | 
|---|
|  |  |  | queryWrapper.eq(!Objects.isNull(goodsRequest) && !Objects.isNull(goodsRequest.getCategoryId()), Goods::getCategoryId, goodsRequest.getCategoryId()) | 
|---|
|  |  |  | .eq(!Objects.isNull(goodsRequest) && !Objects.isNull(goodsRequest.getBrandId()), Goods::getBrandId, goodsRequest.getBrandId()) | 
|---|
|  |  |  | .and(!Objects.isNull(goodsRequest) && StringUtils.isNotBlank(goodsRequest.getKeyword()), | 
|---|
|  |  |  | 
|---|
|  |  |  | .apply(!Objects.isNull(goodsRequest) && !Objects.isNull(goodsRequest.getEPrice()), "  t.PRICE <=  "+goodsRequest.getEPrice()+" "); | 
|---|
|  |  |  | queryWrapper.orderByDesc(Goods::getId); | 
|---|
|  |  |  | List<Goods> goodsList = goodsJoinMapper.selectJoinList(Goods.class,queryWrapper); | 
|---|
|  |  |  | String prefixUrl = systemDictDataBiz.queryByCode(Constants.SYSTEM, Constants.FILE_DIR).getCode() | 
|---|
|  |  |  | + systemDictDataBiz.queryByCode(Constants.SYSTEM, Constants.PROJECTS).getCode(); | 
|---|
|  |  |  | String prefixUrl = systemDictDataBiz.queryByCode(Constants.OSS, Constants.RESOURCE_PATH).getCode() | 
|---|
|  |  |  | + systemDictDataBiz.queryByCode(Constants.OSS, Constants.GOODS_IMG).getCode(); | 
|---|
|  |  |  | 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; | 
|---|
|  |  |  | } | 
|---|