From 7e7db2fa55a9a3af46d4fd8ede0dee147f101d64 Mon Sep 17 00:00:00 2001
From: yujian <yujian@163.com>
Date: 星期六, 09 五月 2020 21:41:27 +0800
Subject: [PATCH] 2.1需求

---
 fanli/src/main/java/com/yeshi/fanli/controller/client/v2/UserOrderControllerV2.java |   56 +++++++++++++++++++++++++++++++++++---------------------
 1 files changed, 35 insertions(+), 21 deletions(-)

diff --git a/fanli/src/main/java/com/yeshi/fanli/controller/client/v2/UserOrderControllerV2.java b/fanli/src/main/java/com/yeshi/fanli/controller/client/v2/UserOrderControllerV2.java
index 783f355..c0061fb 100644
--- a/fanli/src/main/java/com/yeshi/fanli/controller/client/v2/UserOrderControllerV2.java
+++ b/fanli/src/main/java/com/yeshi/fanli/controller/client/v2/UserOrderControllerV2.java
@@ -18,6 +18,7 @@
 import org.yeshi.utils.JsonUtil;
 import org.yeshi.utils.NumberUtil;
 
+import com.yeshi.fanli.dto.order.UserTeamLevel;
 import com.yeshi.fanli.entity.accept.AcceptData;
 import com.yeshi.fanli.entity.bus.user.HongBaoV2;
 import com.yeshi.fanli.entity.bus.user.UserInfo;
@@ -39,6 +40,7 @@
 import com.yeshi.fanli.service.inter.order.CommonOrderService;
 import com.yeshi.fanli.service.inter.order.ESOrderService;
 import com.yeshi.fanli.service.inter.order.HongBaoOrderService;
+import com.yeshi.fanli.service.inter.order.HongBaoV2Service;
 import com.yeshi.fanli.service.inter.order.OrderHongBaoMapService;
 import com.yeshi.fanli.service.inter.order.OrderHongBaoMoneyComputeService;
 import com.yeshi.fanli.service.inter.order.tb.TaoBaoWeiQuanOrderService;
@@ -97,6 +99,9 @@
 	@Resource
 	private UserVIPInfoService userVIPInfoService;
 
+	@Resource
+	private HongBaoV2Service hongBaoV2Service;
+	
 	@Resource
 	private HongBaoOrderService hongBaoOrderService;
 
@@ -454,24 +459,9 @@
 		data.put("selfMoney", selfMoney.setScale(2, BigDecimal.ROUND_DOWN).toString());
 		data.put("shareMoney", shareMoney.setScale(2, BigDecimal.ROUND_DOWN).toString());
 		
-		
 		BigDecimal teamMoney = new BigDecimal(0);
-		if (!VersionUtil.greaterThan_2_1(acceptData.getPlatform(), acceptData.getVersion())) {
-			teamMoney = hongBaoV2CountService.getRewardMoneyToCount(uid, dateType, 3, null);
-		} else {
-			BigDecimal bonus = null;
-			BigDecimal dividend = null;  // TODO 鍒嗙孩缁熻
-			if (dateType == 4) { // 宸插埌璐�
-				dividend = new BigDecimal(0);
-				bonus = hongBaoV2CountService.geBonusByuid(uid, dateType, 3, 2);
-			} else { // 鏈け鏁�
-				bonus = hongBaoV2CountService.geBonusByuid(uid, dateType, 3, 4);
-			}
-			
-			dividend = new BigDecimal(0);
-			// 鎬诲洟闃熷鍔�
-			teamMoney = bonus.add(dividend);
-		}
+		teamMoney = hongBaoV2CountService.getRewardMoneyToCount(uid, dateType, 3, null);
+
 		data.put("inviteMoney", teamMoney.setScale(2, BigDecimal.ROUND_DOWN).toString());
 		out.print(JsonUtil.loadTrueResult(data));
 	}
@@ -565,15 +555,20 @@
 			}
 		}
 		
-		
+		// 绾㈠寘鑾峰緱鑰�
 		HongBaoV2 hongBaoV2 = hoList.get(0).getHongBaoV2();
 		UserLevelEnum userLevel = UserLevelUtil.getByOrderRank(hongBaoV2.getUrank());
 		if (userLevel == null)
 			userLevel = UserLevelEnum.daRen;
 		UserLevelEnum upperLevel =  UserLevelEnum.superVIP;
 			
+		// 璁㈠崟璐拱鑰�
 		CommonOrder commonOrder1 = hoList.get(0).getCommonOrder();
 		Date downTime = commonOrder1.getThirdCreateTime();
+		UserLevelEnum buyer = UserLevelUtil.getByOrderRank(commonOrder1.getUrank());
+		if (buyer == null) {
+			buyer = UserLevelEnum.daRen;
+		}
 		
 		BigDecimal upperTotalMoney = new BigDecimal(0);
 		List<GoodsRebateVO> voList = new ArrayList<>();
@@ -592,7 +587,10 @@
 			
 			// 瀹炰粯娆�
 			BigDecimal payment = hongBaoOrder.getCommonOrder().getPayment();
-			if (hongBaoOrder.getCommonOrder().getSettlement() != null)
+			// 鑻ュ凡缁撶畻 -鏄剧ず缁撶畻閲戦
+			Integer orderState = hongBaoOrder.getCommonOrder().getState();
+			if (hongBaoOrder.getCommonOrder().getSettlement() != null 
+					&& (orderState == CommonOrder.STATE_JS || orderState == CommonOrder.STATE_WQ))
 				payment = hongBaoOrder.getCommonOrder().getSettlement();
 			if (payment == null)
 				payment = new BigDecimal(0);
@@ -602,6 +600,7 @@
 			// 鍩虹浣i噾
 			BigDecimal commission = orderHongBaoMoneyComputeService.computeBaseFanliMoney(commonOrder);
 			goodsVO.setCommision("楼" +commission.setScale(2, BigDecimal.ROUND_DOWN));
+		
 			// 骞冲彴琛ヨ创  = 杩斿埄 - 鍩虹浣i噾
 			goodsVO.setSubsidy("楼" + fanli.subtract(commission).setScale(2, BigDecimal.ROUND_DOWN));
 			//  杈句汉琛ヨ创
@@ -621,13 +620,28 @@
 			} else if (type == 2) {
 				upperTotalMoney = upperTotalMoney.add(orderHongBaoMoneyComputeService.computeShareMoney(commonOrder, upperLevel));
 			} else if (type == 3) {
-				upperTotalMoney = upperTotalMoney.add(hongBao);
+				List<UserTeamLevel> bossLevelList = new ArrayList<>();
+				if (hongBaoV2.getType() == HongBaoV2.TYPE_YIJI || hongBaoV2.getType() == HongBaoV2.TYPE_SHARE_YIJI) {
+					bossLevelList.add(new UserTeamLevel(null, UserLevelEnum.superVIP));
+					upperTotalMoney = upperTotalMoney.add(orderHongBaoMoneyComputeService.computeFirstInviteMoney(commonOrder,
+							buyer, bossLevelList));
+				} else {
+					Integer bRank = hongBaoV2Service.getDirectBossUrankByPid(hongBaoOrder.getHongBaoV2().getParent().getId());
+					UserLevelEnum directBoss = UserLevelUtil.getByOrderRank(bRank);
+					if (directBoss == null) {
+						directBoss = UserLevelEnum.daRen;
+					}
+					bossLevelList.add(new UserTeamLevel(null, directBoss));
+					bossLevelList.add(new UserTeamLevel(null, UserLevelEnum.superVIP));
+					upperTotalMoney = upperTotalMoney.add(orderHongBaoMoneyComputeService.computeSecondInviteMoney(commonOrder,
+							buyer, bossLevelList));
+				}
 			}
 		}
 		
+		
 		orderRebateVO.setFanLiDesc(predictDesc + typeName);
 		orderRebateVO.setFanLi("楼" + hongBao.setScale(2, BigDecimal.ROUND_DOWN));
-		
 		orderRebateVO.setType(type);
 		orderRebateVO.setStateDesc(stateDesc);
 		orderRebateVO.setListGoods(voList);

--
Gitblit v1.8.0