From 0c78c7aaeaa5a427bc8a5c5faf3cd6bbb589c2da Mon Sep 17 00:00:00 2001
From: yujian <yujian@123.com>
Date: 星期二, 08 十月 2019 12:08:38 +0800
Subject: [PATCH] map 改造

---
 fanli/src/main/java/com/yeshi/fanli/util/jd/JDUtil.java |  139 ++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 138 insertions(+), 1 deletions(-)

diff --git a/fanli/src/main/java/com/yeshi/fanli/util/jd/JDUtil.java b/fanli/src/main/java/com/yeshi/fanli/util/jd/JDUtil.java
index 9ec8560..87870ae 100644
--- a/fanli/src/main/java/com/yeshi/fanli/util/jd/JDUtil.java
+++ b/fanli/src/main/java/com/yeshi/fanli/util/jd/JDUtil.java
@@ -26,6 +26,7 @@
 import org.yeshi.utils.BigDecimalUtil;
 import org.yeshi.utils.HttpUtil;
 
+import com.yeshi.fanli.dto.GoodsClassDTO;
 import com.yeshi.fanli.dto.jd.JDCommissionInfo;
 import com.yeshi.fanli.dto.jd.JDCouponInfo;
 import com.yeshi.fanli.dto.jd.JDPingouInfo;
@@ -33,7 +34,6 @@
 import com.yeshi.fanli.dto.jd.JDSearchResult;
 import com.yeshi.fanli.dto.jd.JDShopInfo;
 import com.yeshi.fanli.entity.jd.JDGoods;
-import com.yeshi.fanli.entity.taobao.TaoBaoGoodsBrief;
 import com.yeshi.fanli.tag.PageEntity;
 import com.yeshi.fanli.util.MoneyBigDecimalUtil;
 import com.yeshi.fanli.util.StringUtil;
@@ -390,6 +390,57 @@
 		return BigDecimalUtil.getWithNoZera(MoneyBigDecimalUtil.mul(money, new BigDecimal("0.9")));
 	}
 
+	
+	/**
+	 * 鍟嗗搧浣i噾璁$畻
+	 * 
+	 * @param goods
+	 * @param rate
+	 * @return
+	 */
+	public static BigDecimal getGoodsFanLiMoneyPlus(JDGoods goods, BigDecimal rate) {
+		BigDecimal money = new BigDecimal(0);
+		BigDecimal commissionPlus = goods.getCommissionPlus();
+		if (commissionPlus == null) {
+			return money;
+		}
+		
+		
+
+		BigDecimal price = null;
+		JDPingouInfo pinGouInfo = goods.getPinGouInfo();
+		if (pinGouInfo == null) {
+			price = goods.getPrice();
+		} else {
+			price = pinGouInfo.getPingouPrice();
+		}
+
+		JDCouponInfo couponInfo = goods.getCouponInfo();
+		if (couponInfo == null) {
+			money = MoneyBigDecimalUtil.mul(MoneyBigDecimalUtil
+					.mul(MoneyBigDecimalUtil.mul(price, commissionPlus), new BigDecimal("0.01")),
+					MoneyBigDecimalUtil.div(rate, new BigDecimal(100)));
+		} else {
+			BigDecimal quota = couponInfo.getQuota();
+			BigDecimal discount = couponInfo.getDiscount();
+			if (quota.compareTo(price) <= 0 && price.compareTo(discount) > 0) {
+
+				BigDecimal finalPrice = price.subtract(discount);
+				money = MoneyBigDecimalUtil.mul(MoneyBigDecimalUtil.mul(
+						MoneyBigDecimalUtil.mul(finalPrice, commissionPlus),
+						new BigDecimal("0.01")), MoneyBigDecimalUtil.div(rate, new BigDecimal(100)));
+
+			} else {// 涓嶈兘鐢ㄥ埜
+				money = MoneyBigDecimalUtil.mul(
+						MoneyBigDecimalUtil.mul(MoneyBigDecimalUtil.mul(price,commissionPlus),
+								new BigDecimal("0.01")),
+						MoneyBigDecimalUtil.div(rate, new BigDecimal(100)));
+			}
+		}
+		// 杩斿埄姣斾緥涓哄師鏉ョ殑90%
+		return BigDecimalUtil.getWithNoZera(MoneyBigDecimalUtil.mul(money, new BigDecimal("0.9")));
+	}
+	
 	/**
 	 * 璁$畻鍟嗗搧鍒稿悗浠凤紝娌℃湁鍒稿垯杩斿洖鍘熶环
 	 * 
@@ -628,5 +679,91 @@
 		}
 		return jdGoods;
 	}
+	
+	
+	/**
+	 * 鑾峰彇绫荤洰
+	 * @param level 绛夌骇
+	 * @param parentId 涓婄骇id
+	 * @return
+	 */
+	public static List<GoodsClassDTO> getCategoryList(int level, int parentId) {
+		try {
+			// 璇锋眰鍦板潃
+			String requestUrl = "https://union.jd.com/api/help/getCategoryList?level=%s&parentId=%s";
+			// 鎵ц璇锋眰
+			String result = HttpUtil.get(String.format(requestUrl, level, parentId));
 
+			if (!StringUtil.isNullOrEmpty(result)) {
+				JSONObject json = JSONObject.fromObject(result);
+				JSONArray jsonArray = json.getJSONArray("data");
+				if (jsonArray != null && jsonArray.size() > 0) {
+					List<GoodsClassDTO> list = new ArrayList<GoodsClassDTO>();
+					for (int i=0;i <jsonArray.size() ;i ++ ) {
+						Object object = jsonArray.get(i);
+						if (object == null)
+							continue;
+						JSONObject jsonClass = JSONObject.fromObject(object);
+						
+						GoodsClassDTO goodsClass = new GoodsClassDTO();
+						goodsClass.setId(jsonClass.optString("id"));
+						goodsClass.setName(jsonClass.optString("categoryName"));
+						list.add(goodsClass);
+					}
+					return list;
+				}
+			}
+		} catch (Exception e) {
+			e.printStackTrace();
+		}
+		return null;
+	}
+
+	/**
+	 * 鑾峰彇绫荤洰
+	 * @param level 绛夌骇
+	 * @param parentId 涓婄骇id
+	 * @return
+	 */
+	public static List<GoodsClassDTO> getCategoryCommiPlus(int level, int parentId) {
+		try {
+			// 璇锋眰鍦板潃
+			String requestUrl = "https://union.jd.com/api/help/getCategoryCommiPlus?level=%s&parentId=%s";
+			// 鎵ц璇锋眰
+			String result = HttpUtil.get(String.format(requestUrl, level, parentId));
+
+			if (!StringUtil.isNullOrEmpty(result)) {
+				JSONObject json = JSONObject.fromObject(result);
+				JSONArray jsonArray = json.getJSONArray("data");
+				if (jsonArray != null && jsonArray.size() > 0) {
+					List<GoodsClassDTO> list = new ArrayList<GoodsClassDTO>();
+					for (int i=0;i <jsonArray.size() ;i ++ ) {
+						Object object = jsonArray.get(i);
+						if (object == null)
+							continue;
+						JSONObject jsonClass = JSONObject.fromObject(object);
+						
+						GoodsClassDTO goodsClass = new GoodsClassDTO();
+						goodsClass.setId(jsonClass.optString("id"));
+						goodsClass.setName(jsonClass.optString("name"));
+						
+						String selfMobileComm = jsonClass.optString("selfMobileComm");
+						if (!StringUtil.isNullOrEmpty(selfMobileComm)) 
+							goodsClass.setSelfComm(new BigDecimal(selfMobileComm));
+						
+						String popMobileComm = jsonClass.optString("popMobileComm");
+						if (!StringUtil.isNullOrEmpty(popMobileComm)) 
+							goodsClass.setPopComm(new BigDecimal(popMobileComm));
+						
+						list.add(goodsClass);
+					}
+					return list;
+				}
+			}
+		} catch (Exception e) {
+			e.printStackTrace();
+		}
+		return null;
+	}
+	
 }

--
Gitblit v1.8.0