From 89797724de8d01ce53bb39004940d00981602882 Mon Sep 17 00:00:00 2001
From: java110 <928255095@qq.com>
Date: 星期二, 27 十月 2020 18:37:09 +0800
Subject: [PATCH] 优化代码
---
service-goods/src/main/java/com/java110/goods/bmo/product/impl/GetProductBMOImpl.java | 134 ++++++++++++++++++++++++++++++++++++++++++++
1 files changed, 133 insertions(+), 1 deletions(-)
diff --git a/service-goods/src/main/java/com/java110/goods/bmo/product/impl/GetProductBMOImpl.java b/service-goods/src/main/java/com/java110/goods/bmo/product/impl/GetProductBMOImpl.java
index 873515b..89f679f 100644
--- a/service-goods/src/main/java/com/java110/goods/bmo/product/impl/GetProductBMOImpl.java
+++ b/service-goods/src/main/java/com/java110/goods/bmo/product/impl/GetProductBMOImpl.java
@@ -1,8 +1,16 @@
package com.java110.goods.bmo.product.impl;
+import com.java110.dto.file.FileRelDto;
import com.java110.dto.product.ProductDto;
+import com.java110.dto.product.ProductSpecDetailDto;
+import com.java110.dto.productDetail.ProductDetailDto;
+import com.java110.dto.productSpecValue.ProductSpecValueDto;
import com.java110.goods.bmo.product.IGetProductBMO;
+import com.java110.intf.common.IFileRelInnerServiceSMO;
+import com.java110.intf.goods.IProductDetailInnerServiceSMO;
import com.java110.intf.goods.IProductInnerServiceSMO;
+import com.java110.intf.goods.IProductSpecDetailInnerServiceSMO;
+import com.java110.intf.goods.IProductSpecValueInnerServiceSMO;
import com.java110.vo.ResultVo;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.http.HttpStatus;
@@ -18,18 +26,31 @@
@Autowired
private IProductInnerServiceSMO productInnerServiceSMOImpl;
+ @Autowired
+ private IFileRelInnerServiceSMO fileRelInnerServiceSMOImpl;
+
+ @Autowired
+ private IProductDetailInnerServiceSMO productDetailInnerServiceSMOImpl;
+
+ @Autowired
+ private IProductSpecValueInnerServiceSMO productSpecValueInnerServiceSMOImpl;
+
+ @Autowired
+ private IProductSpecDetailInnerServiceSMO productSpecDetailInnerServiceSMOImpl;
+
/**
* @param productDto
* @return 璁㈠崟鏈嶅姟鑳藉鎺ュ彈鐨勬姤鏂�
*/
public ResponseEntity<String> get(ProductDto productDto) {
-
int count = productInnerServiceSMOImpl.queryProductsCount(productDto);
List<ProductDto> productDtos = null;
if (count > 0) {
productDtos = productInnerServiceSMOImpl.queryProducts(productDto);
+
+ freshProductDtos(productDtos, productDto);
} else {
productDtos = new ArrayList<>();
}
@@ -41,4 +62,115 @@
return responseEntity;
}
+ private void freshProductDtos(List<ProductDto> productDtos, ProductDto productDto) {
+
+ if (productDtos == null || productDtos.size() < 1) {
+ return;
+ }
+
+ //杈撳叆
+ List<String> productIds = new ArrayList<>();
+
+ for (ProductDto tmpProductDto : productDtos) {
+ productIds.add(tmpProductDto.getProductId());
+ }
+
+ FileRelDto fileRelDto = new FileRelDto();
+ fileRelDto.setObjIds(productIds.toArray(new String[productIds.size()]));
+ fileRelDto.setRelTypeCd(FileRelDto.REL_TYPE_CD_GOODS_COVER);
+ List<FileRelDto> fileRelDtos = fileRelInnerServiceSMOImpl.queryFileRels(fileRelDto);
+
+ //鍒峰叆鍥剧墖淇℃伅
+ List<String> photoVos = null;
+ String url = null;
+ for (ProductDto tmpProductDto : productDtos) {
+ for (FileRelDto tmpFileRelDto : fileRelDtos) {
+ if (tmpProductDto.getProductId().equals(tmpFileRelDto.getObjId())) {
+ url = "/callComponent/download/getFile/file?fileId=" + tmpFileRelDto.getFileRealName() + "&communityId=-1";
+ tmpProductDto.setCoverPhoto(url);
+ }
+ }
+ }
+
+ //鍒峰叆搴撳瓨鍜岄攢閲�
+ ProductSpecValueDto productSpecValueDto = new ProductSpecValueDto();
+ productSpecValueDto.setStoreId(productDtos.get(0).getStoreId());
+ productSpecValueDto.setProductIds(productIds.toArray(new String[productIds.size()]));
+ List<ProductSpecValueDto> productSpecValueDtos = productSpecValueInnerServiceSMOImpl.queryProductStockAndSales(productSpecValueDto);
+ for (ProductDto tmpProduct : productDtos) {
+ for (ProductSpecValueDto tmpProdSpecValue : productSpecValueDtos) {
+ if (tmpProdSpecValue.getProductId().equals(tmpProduct.getProductId())) {
+ tmpProduct.setSales(tmpProdSpecValue.getSales());
+ tmpProduct.setStock(tmpProdSpecValue.getStock());
+ }
+ }
+ }
+
+ // 鏌ヨ瑙勬牸
+ if (productDtos.size() > 1) {
+ return;
+ }
+
+ //杈撳叆杞挱鍥�
+ fileRelDto = new FileRelDto();
+ fileRelDto.setObjId(productDtos.get(0).getProductId());
+ fileRelDto.setRelTypeCd(FileRelDto.REL_TYPE_CD_GOODS_CAROUSEL_FIGURE);
+ fileRelDtos = fileRelInnerServiceSMOImpl.queryFileRels(fileRelDto);
+ List<String> photos = new ArrayList<>();
+ for (ProductDto tmpProductDto : productDtos) {
+ for (FileRelDto tmpFileRelDto : fileRelDtos) {
+ if (tmpProductDto.getProductId().equals(tmpFileRelDto.getObjId())) {
+ url = "/callComponent/download/getFile/file?fileId=" + tmpFileRelDto.getFileRealName() + "&communityId=-1";
+ photos.add(url);
+ }
+ }
+ tmpProductDto.setCarouselFigurePhotos(photos);
+ }
+
+ freshProductSpecValue(productDtos);
+
+ ProductDetailDto productDetailDto = new ProductDetailDto();
+ productDetailDto.setProductId(productDtos.get(0).getProductId());
+ productDetailDto.setStoreId(productDtos.get(0).getStoreId());
+ List<ProductDetailDto> productDetailDtos = productDetailInnerServiceSMOImpl.queryProductDetails(productDetailDto);
+
+ if (productDetailDtos == null || productDetailDtos.size() < 1) {
+ return;
+ }
+
+ productDtos.get(0).setContent(productDetailDtos.get(0).getContent());
+ }
+
+ private void freshProductSpecValue(List<ProductDto> productDtos) {
+ ProductSpecValueDto productSpecValueDto = new ProductSpecValueDto();
+ productSpecValueDto.setProductId(productDtos.get(0).getProductId());
+ productSpecValueDto.setStoreId(productDtos.get(0).getStoreId());
+ List<ProductSpecValueDto> productSpecValueDtos = productSpecValueInnerServiceSMOImpl.queryProductSpecValues(productSpecValueDto);
+
+ if (productSpecValueDtos == null || productSpecValueDtos.size() < 1) {
+ return;
+ }
+ productDtos.get(0).setProductSpecValues(productSpecValueDtos);
+
+ List<String> specIds = new ArrayList<>();
+ for (ProductSpecValueDto productSpecValue : productSpecValueDtos) {
+ specIds.add(productSpecValue.getSpecId());
+ }
+
+ ProductSpecDetailDto productSpecDetailDto = new ProductSpecDetailDto();
+ productSpecDetailDto.setSpecIds(specIds.toArray(new String[specIds.size()]));
+ productSpecDetailDto.setStoreId(productDtos.get(0).getStoreId());
+ List<ProductSpecDetailDto> productSpecDetailDtos = productSpecDetailInnerServiceSMOImpl.queryProductSpecDetails(productSpecDetailDto);
+ List<ProductSpecDetailDto> tmpProductSpecDetailDtos = null;
+ for (ProductSpecValueDto productSpecValue : productSpecValueDtos) {
+ tmpProductSpecDetailDtos = new ArrayList<>();
+ for (ProductSpecDetailDto tmpProductSpecDetailDto : productSpecDetailDtos) {
+ if (productSpecValue.getSpecId().equals(tmpProductSpecDetailDto.getSpecId())) {
+ tmpProductSpecDetailDtos.add(tmpProductSpecDetailDto);
+ }
+ }
+ productSpecValue.setProductSpecDetails(tmpProductSpecDetailDtos);
+ }
+ }
+
}
--
Gitblit v1.8.0