Authored by caoyan

UFO比价

... ... @@ -53,5 +53,8 @@ public class ChannelSkuCompareRspBo {
private String statusStr;
private Integer status;
private String channelUrl;
private String imageUrl;
}
... ...
... ... @@ -18,7 +18,7 @@
<properties>
<project-name>ufo-platform</project-name>
<spring.version>4.3.8.RELEASE</spring.version>
<ufo.model.version>1.0-SNAPSHOT</ufo.model.version>
<ufo.model.version>2.0-SNAPSHOT</ufo.model.version>
<inboxclient.version>1.0.0-SNAPSHOT</inboxclient.version>
</properties>
... ...
... ... @@ -18,10 +18,12 @@ import com.alibaba.fastjson.JSONObject;
import com.yoho.core.common.utils.DateUtil;
import com.yoho.error.exception.ServiceException;
import com.yoho.ufo.dal.ChannelSkuCompareMapper;
import com.yoho.ufo.dal.GoodsMapper;
import com.yoho.ufo.dal.ProductMapper;
import com.yoho.ufo.dal.StorageMapper;
import com.yoho.ufo.dal.StoragePriceMapper;
import com.yoho.ufo.dal.UfoSizeMapper;
import com.yoho.ufo.dal.model.Goods;
import com.yoho.ufo.dal.model.Product;
import com.yoho.ufo.dal.model.Storage;
import com.yoho.ufo.dal.model.StoragePrice;
... ... @@ -32,6 +34,9 @@ import com.yoho.ufo.model.commoditybasicrole.size.Size;
import com.yoho.ufo.service.IBusinessExportService;
import com.yoho.ufo.service.IChannelSkuCompareService;
import com.yoho.ufo.service.model.PageResponseBO;
import com.yoho.ufo.util.CollectionUtil;
import com.yoho.ufo.util.ImagesConstant;
import com.yoho.ufo.util.ImagesHelper;
/**
* @author caoyan
... ... @@ -56,6 +61,9 @@ public class ChannelSkuCompareServiceImpl implements IChannelSkuCompareService,
@Autowired
private StoragePriceMapper storagePriceMapper;
@Autowired
private GoodsMapper goodsMapper;
@Override
public PageResponseBO<ChannelSkuCompareRspBo> queryList(ChannelSkuCompareReq req) {
LOGGER.info("queryList in. req is {}", req);
... ... @@ -90,11 +98,16 @@ public class ChannelSkuCompareServiceImpl implements IChannelSkuCompareService,
List<Storage> storageList = storageMapper.selectByIds(skuList);
Map<Integer, Storage> storageMap = storageList.stream().collect(Collectors.toMap(Storage::getId, s->s));
//查询商品图片
List<Integer> goodsIdList = CollectionUtil.map(storageList, Storage::getGoodsId);
List<Goods> goodsList = goodsMapper.selectByIds(goodsIdList);
Map<Integer, String> goodsIdImageMap = goodsList.stream().collect(Collectors.toMap(Goods::getId, Goods::getColorImage));
//计算UFO当前价,可售sku最低价
List<StoragePrice> storagePriceList = storagePriceMapper.selectMinPriceByStorageIdList(skuList);
Map<Integer, BigDecimal> storageMinPriceMap = storagePriceList.stream().collect(Collectors.toMap(StoragePrice::getStorageId, StoragePrice::getPrice));
List<ChannelSkuCompareRspBo> respList = convertToResp(cscList, productMap, sizeIdNameMap, storageMap, storageMinPriceMap);
List<ChannelSkuCompareRspBo> respList = convertToResp(cscList, productMap, sizeIdNameMap, storageMap, storageMinPriceMap, goodsIdImageMap);
PageResponseBO<ChannelSkuCompareRspBo> result=new PageResponseBO<>();
result.setList(respList);
... ... @@ -183,7 +196,8 @@ public class ChannelSkuCompareServiceImpl implements IChannelSkuCompareService,
private List<ChannelSkuCompareRspBo> convertToResp(List<ChannelSkuCompare> cscList, Map<Integer, Product> productMap,
Map<Integer, String> sizeIdNameMap, Map<Integer, Storage> storageMap, Map<Integer, BigDecimal> storageMinPriceMap){
Map<Integer, String> sizeIdNameMap, Map<Integer, Storage> storageMap, Map<Integer, BigDecimal> storageMinPriceMap,
Map<Integer, String> goodsIdImageMap){
List<ChannelSkuCompareRspBo> boList = Lists.newArrayList();
for(ChannelSkuCompare csc : cscList) {
ChannelSkuCompareRspBo bo = new ChannelSkuCompareRspBo();
... ... @@ -210,6 +224,8 @@ public class ChannelSkuCompareServiceImpl implements IChannelSkuCompareService,
}
bo.setStatus(csc.getStatus());
bo.setStatusStr(bo.getStatus().intValue()==0 ? "正常" : "异常");
String imageUrl = goodsIdImageMap.get(storageMap.get(csc.getSku()).getGoodsId());
bo.setImageUrl(ImagesHelper.getImageAbsoluteUrl(imageUrl, ImagesConstant.BUCKET_GOODS_IMG));
boList.add(bo);
}
... ...