|
@@ -3,6 +3,7 @@ package cn.rankin.productservice.service;
|
|
import cn.rankin.common.utils.api.model.APIResult;
|
|
import cn.rankin.common.utils.api.model.APIResult;
|
|
import cn.rankin.common.utils.api.page.Page;
|
|
import cn.rankin.common.utils.api.page.Page;
|
|
import cn.rankin.common.utils.enums.BaseOrderEnum;
|
|
import cn.rankin.common.utils.enums.BaseOrderEnum;
|
|
|
|
+import cn.rankin.common.utils.enums.BaseStatusEnum;
|
|
import cn.rankin.common.utils.enums.ProductTypeEnum;
|
|
import cn.rankin.common.utils.enums.ProductTypeEnum;
|
|
import cn.rankin.common.utils.util.BeanUtil;
|
|
import cn.rankin.common.utils.util.BeanUtil;
|
|
import cn.rankin.common.utils.util.JpaSortUtil;
|
|
import cn.rankin.common.utils.util.JpaSortUtil;
|
|
@@ -14,18 +15,20 @@ import cn.rankin.data.api.product.entity.*;
|
|
import cn.rankin.data.api.product.entity.Package;
|
|
import cn.rankin.data.api.product.entity.Package;
|
|
import cn.rankin.productservice.code.ProductServiceAPICode;
|
|
import cn.rankin.productservice.code.ProductServiceAPICode;
|
|
import cn.rankin.productservice.repository.MerchantProductRepository;
|
|
import cn.rankin.productservice.repository.MerchantProductRepository;
|
|
|
|
+import cn.rankin.productservice.repository.PackageProductRelationRepository;
|
|
import cn.rankin.productservice.repository.ProductRepository;
|
|
import cn.rankin.productservice.repository.ProductRepository;
|
|
|
|
+import lombok.extern.slf4j.Slf4j;
|
|
import org.springframework.beans.factory.annotation.Autowired;
|
|
import org.springframework.beans.factory.annotation.Autowired;
|
|
|
|
+import org.springframework.data.domain.Sort;
|
|
import org.springframework.stereotype.Service;
|
|
import org.springframework.stereotype.Service;
|
|
|
|
|
|
import javax.transaction.Transactional;
|
|
import javax.transaction.Transactional;
|
|
-import java.util.LinkedHashMap;
|
|
|
|
-import java.util.List;
|
|
|
|
-import java.util.Map;
|
|
|
|
|
|
+import java.util.*;
|
|
|
|
|
|
import static cn.rankin.productservice.utils.DTOConverter.convert;
|
|
import static cn.rankin.productservice.utils.DTOConverter.convert;
|
|
|
|
|
|
@Service
|
|
@Service
|
|
|
|
+@Slf4j
|
|
public class ProductService {
|
|
public class ProductService {
|
|
|
|
|
|
@Autowired
|
|
@Autowired
|
|
@@ -46,6 +49,9 @@ public class ProductService {
|
|
@Autowired
|
|
@Autowired
|
|
private TrainingService trainingService;
|
|
private TrainingService trainingService;
|
|
|
|
|
|
|
|
+ @Autowired
|
|
|
|
+ private PackageProductRelationRepository packageProductRelationRepository;
|
|
|
|
+
|
|
public APIResult<Page<Product>> search(Product product, Integer pageNo, Integer pageSize, LinkedHashMap<String, BaseOrderEnum> sort) {
|
|
public APIResult<Page<Product>> search(Product product, Integer pageNo, Integer pageSize, LinkedHashMap<String, BaseOrderEnum> sort) {
|
|
Long count = productRepository.count(product);
|
|
Long count = productRepository.count(product);
|
|
Page<Product> page = new Page<>(count, pageNo, pageSize);
|
|
Page<Product> page = new Page<>(count, pageNo, pageSize);
|
|
@@ -89,7 +95,7 @@ public class ProductService {
|
|
}
|
|
}
|
|
|
|
|
|
public Map<String, Object> getProduct(String productId) {
|
|
public Map<String, Object> getProduct(String productId) {
|
|
- Map<String, Object> result = null;
|
|
|
|
|
|
+ Map<String, Object> result = new HashMap<>();
|
|
|
|
|
|
|
|
|
|
Product product = productRepository.findByPid(productId);
|
|
Product product = productRepository.findByPid(productId);
|
|
@@ -139,6 +145,46 @@ public class ProductService {
|
|
return packageService.getPackage(productId);
|
|
return packageService.getPackage(productId);
|
|
}
|
|
}
|
|
|
|
|
|
|
|
+ /**
|
|
|
|
+ * Get Related Packge by pid
|
|
|
|
+ * @param pid
|
|
|
|
+ * @param start
|
|
|
|
+ * @param offset
|
|
|
|
+ * @param sortKey
|
|
|
|
+ * @param direction
|
|
|
|
+ * @return Plain Product, without extra fields like childrens etc.
|
|
|
|
+ */
|
|
|
|
+ public List<Product> getRelatedPackages(String pid, String merchantId, Long start, Integer offset, String sortKey, Sort.Direction direction){
|
|
|
|
+ List<PackageProductRelation> currentRelationList = packageProductRelationRepository.findByPid(pid);
|
|
|
|
+
|
|
|
|
+ //get pkgs
|
|
|
|
+ List<String> pids = new ArrayList<>();
|
|
|
|
+
|
|
|
|
+ for(PackageProductRelation rel : currentRelationList){
|
|
|
|
+ //skip pid not belong merchant
|
|
|
|
+ String pkgId = rel.getPkgId();
|
|
|
|
+ if(null == pkgId || null == merchantProductRepository.findByPidAndMerchantIdAndStatus(pkgId, merchantId, BaseStatusEnum.NORMAL)){
|
|
|
|
+ log.info("Skip, pkgId not Belong Merchant Or Not on Sale, pkgId={}, merchantId={}", pkgId, merchantId);
|
|
|
|
+ continue;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ pids.add(pkgId);
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ if (pids.isEmpty()){
|
|
|
|
+ log.info("No Related Package Find By pid, pid={}", pid);
|
|
|
|
+ return new ArrayList<>();
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ List<Product> pkgs = productRepository.findByPidsAndStatus(pids, BaseStatusEnum.NORMAL);
|
|
|
|
+
|
|
|
|
+ if (null == pkgs){
|
|
|
|
+ pkgs = new ArrayList<>();
|
|
|
|
+ }
|
|
|
|
+ return pkgs;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+
|
|
@Transactional
|
|
@Transactional
|
|
public APIResult delete(String productId) {
|
|
public APIResult delete(String productId) {
|
|
Product product = productRepository.findByPid(productId);
|
|
Product product = productRepository.findByPid(productId);
|