From 573c491b4a1ba60e12a5678a01c1546c0077c1ee Mon Sep 17 00:00:00 2001
From: admin <weikou2014>
Date: 星期二, 30 七月 2019 09:07:42 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/master'

---
 fanli/src/main/java/com/yeshi/fanli/controller/client/v1/SearchController.java |   79 ++++++++++++++++++++++++++++++++++-----
 1 files changed, 68 insertions(+), 11 deletions(-)

diff --git a/fanli/src/main/java/com/yeshi/fanli/controller/client/v1/SearchController.java b/fanli/src/main/java/com/yeshi/fanli/controller/client/v1/SearchController.java
index 4b37c91..257ec87 100644
--- a/fanli/src/main/java/com/yeshi/fanli/controller/client/v1/SearchController.java
+++ b/fanli/src/main/java/com/yeshi/fanli/controller/client/v1/SearchController.java
@@ -4,10 +4,8 @@
 import java.math.BigDecimal;
 import java.util.ArrayList;
 import java.util.Collections;
-import java.util.HashMap;
 import java.util.HashSet;
 import java.util.List;
-import java.util.Map;
 import java.util.Set;
 
 import javax.annotation.Resource;
@@ -17,10 +15,12 @@
 import org.springframework.web.bind.annotation.RequestMapping;
 import org.springframework.web.bind.annotation.RequestMethod;
 import org.yeshi.utils.JsonUtil;
+import org.yeshi.utils.taobao.TaoBaoAuthUtil;
 import org.yeshi.utils.taobao.TbImgUtil;
 
 import com.google.gson.Gson;
 import com.google.gson.GsonBuilder;
+import com.yeshi.fanli.dto.dataoke.DaTaoKeGoodsResult;
 import com.yeshi.fanli.entity.accept.AcceptData;
 import com.yeshi.fanli.entity.bus.lable.QualityFactory;
 import com.yeshi.fanli.entity.bus.recommend.Honest;
@@ -36,12 +36,14 @@
 import com.yeshi.fanli.entity.taobao.TaoBaoSearchResult;
 import com.yeshi.fanli.entity.taobao.TaoBaoUnionConfig;
 import com.yeshi.fanli.entity.taobao.dataoke.DaTaoKeDetail;
+import com.yeshi.fanli.entity.taobao.dataoke.DaTaoKeDetailV2;
 import com.yeshi.fanli.service.inter.config.BusinessSystemService;
 import com.yeshi.fanli.service.inter.config.ConfigService;
 import com.yeshi.fanli.service.inter.config.SuperHotSearchService;
 import com.yeshi.fanli.service.inter.hongbao.HongBaoManageService;
 import com.yeshi.fanli.service.inter.lable.QualityGoodsService;
 import com.yeshi.fanli.service.inter.lable.TaoKeGoodsService;
+import com.yeshi.fanli.service.inter.taobao.TaoBaoShopService;
 import com.yeshi.fanli.service.inter.taobao.TaoBaoUnionConfigService;
 import com.yeshi.fanli.service.inter.taobao.dataoke.DaTaoKeGoodsDetailService;
 import com.yeshi.fanli.service.inter.user.HistorySearchService;
@@ -50,8 +52,10 @@
 import com.yeshi.fanli.util.StringUtil;
 import com.yeshi.fanli.util.ThreadUtil;
 import com.yeshi.fanli.util.cache.TaoBaoGoodsCacheUtil;
+import com.yeshi.fanli.util.dataoke.DaTaoKeApiUtil;
 import com.yeshi.fanli.util.taobao.SearchFilterUtil;
 import com.yeshi.fanli.util.taobao.TaoBaoUtil;
+import com.yeshi.fanli.vo.brand.TaoBaoShopVO;
 
 import net.sf.ehcache.Element;
 import net.sf.json.JSONArray;
@@ -87,6 +91,9 @@
 
 	@Resource
 	private TaoBaoGoodsCacheUtil taoBaoGoodsCacheUtil;
+
+	@Resource
+	private TaoBaoShopService taoBaoShopService;
 
 	@Resource
 	private DaTaoKeGoodsDetailService daTaoKeGoodsDetailService;
@@ -412,15 +419,20 @@
 
 		historySearchService.addHistorySearch(kw, bid);
 
-		BusinessSystem system = businessSystemService.getBusinessSystemCache(acceptData.getPlatform(),
-				acceptData.getPackages());
-		if (system == null) {
-			out.print(JsonUtil.loadFalseResult("绯荤粺涓嶅瓨鍦�"));
-			return;
-		}
+		// BusinessSystem system =
+		// businessSystemService.getBusinessSystemCache(acceptData.getPlatform(),
+		// acceptData.getPackages());
+		// if (system == null) {
+		// out.print(JsonUtil.loadFalseResult("绯荤粺涓嶅瓨鍦�"));
+		// return;
+		// }
 
 		if (!StringUtil.isNullOrEmpty(kw) && (kw.startsWith("http://") || kw.startsWith("https://"))) {
-			out.print(JsonUtil.loadFalseResult("鏃犳硶鎼滅储閾炬帴"));
+			JSONObject data = new JSONObject();
+			data.put("result", new JSONArray());
+			data.put("count", 0);
+			data.put("nav", new JSONArray());
+			out.print(JsonUtil.loadTrueResult(data));
 			return;
 		}
 
@@ -456,7 +468,9 @@
 			data = searchGoods(kw, page, filter, order, startprice, endprice);
 		} else {
 			// 鎺ㄨ崘锛氱簿閫夊簱
-			data = searchQualityGoods(kw, page, filter, order, startprice, endprice);
+			// data = searchQualityGoods(kw, page, filter, order, startprice,
+			// endprice);
+			data = searchDaTaoKeGoods(kw, page, filter, order, startprice, endprice);
 		}
 
 		// 鑾峰彇鎺ㄨ崘璇�
@@ -466,6 +480,12 @@
 			listRecommendWords = TaoBaoUtil.getSuguestSearch(kw);
 			if (listRecommendWords == null || listRecommendWords.size() == 0) {
 				listRecommendWords = new ArrayList<String>();
+			}
+
+			List<TaoBaoShopVO> listShop =taoBaoShopService.getShopByKey(kw);
+			if (listShop != null && listShop.size() > 0 && listShop.get(0).getListGoods() != null
+					&& listShop.get(0).getListGoods().size() > 2) {
+				data.put("shop", JsonUtil.getApiCommonGson().toJson(listShop.get(0)));
 			}
 		}
 
@@ -661,7 +681,7 @@
 			if (daTaoKeList != null && daTaoKeList.size() > 0) {
 				Collections.reverse(daTaoKeList);
 				for (DaTaoKeDetail detail : daTaoKeList) {
-					taoBaoGoodsBriefs.add(0,TaoBaoUtil.convert(detail));
+					taoBaoGoodsBriefs.add(0, TaoBaoUtil.convert(detail));
 				}
 			}
 		} catch (Exception e) {
@@ -930,6 +950,43 @@
 		return data;
 	}
 
+	private JSONObject searchDaTaoKeGoods(String key, int page, String filter, String order, String startprice,
+			String endprice) {
+		page = page + 1;
+		int sort = DaTaoKeApiUtil.SORT_DEFAULT;
+		if ("5".equalsIgnoreCase(order)) {
+			sort = DaTaoKeApiUtil.SORT_COMMISSION;
+		} else if ("1".equalsIgnoreCase(order)) {
+			sort = DaTaoKeApiUtil.SORT_SALES;
+		} else if ("2".equalsIgnoreCase(order)) {
+			sort = DaTaoKeApiUtil.SORT_PRICE_HIGH_TO_LOW;
+		} else if ("3".equalsIgnoreCase(order)) {
+			sort = DaTaoKeApiUtil.SORT_PRICE_LOW_TO_HIGH;
+		}
+
+		List<TaoBaoGoodsBriefExtra> listExtra = new ArrayList<TaoBaoGoodsBriefExtra>();
+		BigDecimal proportion = manageService.getFanLiRate();
+
+		DaTaoKeGoodsResult result = DaTaoKeApiUtil.search(key, null, null, null, page, 20, sort);
+		if (result != null && result.getGoodsList() != null)
+			for (DaTaoKeDetailV2 goods : result.getGoodsList()) {
+				listExtra.add(
+						TaoBaoUtil.getTaoBaoGoodsBriefExtra(TaoBaoUtil.convert(goods), proportion.toString(), null));
+			}
+
+		List<TaoBaoSearchNav> navList = new ArrayList<>();
+		Gson gson = new GsonBuilder().create();
+		Gson gson2 = JsonUtil.getConvertBigDecimalToStringSubZeroBuilder(new GsonBuilder())
+				.excludeFieldsWithoutExposeAnnotation().create();
+
+		JSONObject data = new JSONObject();
+		data.put("nav", gson.toJson(navList));
+		data.put("result", gson2.toJson(listExtra));
+		data.put("count", result.getTotalCount());
+
+		return data;
+	}
+
 	/**
 	 * 璁剧疆鏌ヨ浣i噾姣斾緥鑼冨洿
 	 * 

--
Gitblit v1.8.0