From 88b54772dbcf5ecab1e2316e4e4626ac901b8908 Mon Sep 17 00:00:00 2001
From: yujian <yujian>
Date: 星期二, 22 一月 2019 15:58:24 +0800
Subject: [PATCH] 邀请码添加返回状态

---
 fanli/src/main/java/com/yeshi/fanli/service/impl/hongbao/HongBaoV2ServiceImpl.java |  712 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++-
 1 files changed, 698 insertions(+), 14 deletions(-)

diff --git a/fanli/src/main/java/com/yeshi/fanli/service/impl/hongbao/HongBaoV2ServiceImpl.java b/fanli/src/main/java/com/yeshi/fanli/service/impl/hongbao/HongBaoV2ServiceImpl.java
index 1fd6c27..51df0e4 100644
--- a/fanli/src/main/java/com/yeshi/fanli/service/impl/hongbao/HongBaoV2ServiceImpl.java
+++ b/fanli/src/main/java/com/yeshi/fanli/service/impl/hongbao/HongBaoV2ServiceImpl.java
@@ -1,10 +1,16 @@
 package com.yeshi.fanli.service.impl.hongbao;
 
 import java.math.BigDecimal;
+import java.util.Calendar;
 import java.util.Collections;
 import java.util.Comparator;
 import java.util.Date;
+import java.util.HashMap;
+import java.util.HashSet;
+import java.util.Iterator;
 import java.util.List;
+import java.util.Map;
+import java.util.Set;
 
 import javax.annotation.Resource;
 
@@ -12,6 +18,7 @@
 import org.springframework.transaction.annotation.Transactional;
 
 import com.yeshi.fanli.dao.mybatis.HongBaoV2Mapper;
+import com.yeshi.fanli.dao.mybatis.PidOrderMapper;
 import com.yeshi.fanli.dao.mybatis.hongbao.HongBaoMapper;
 import com.yeshi.fanli.dao.mybatis.order.CommonOrderGoodsMapper;
 import com.yeshi.fanli.dao.mybatis.order.CommonOrderMapper;
@@ -19,14 +26,32 @@
 import com.yeshi.fanli.dao.mybatis.order.OrderItemMapper;
 import com.yeshi.fanli.dao.mybatis.order.OrderMapper;
 import com.yeshi.fanli.dao.mybatis.taobao.TaoBaoOrderMapper;
+import com.yeshi.fanli.dao.mybatis.taobao.TaoBaoWeiQuanOrderMapper;
+import com.yeshi.fanli.dto.HongBaoDTO;
+import com.yeshi.fanli.entity.bus.msg.MsgOrderDetail;
 import com.yeshi.fanli.entity.bus.user.HongBao;
 import com.yeshi.fanli.entity.bus.user.HongBaoV2;
+import com.yeshi.fanli.entity.bus.user.UserInfo;
 import com.yeshi.fanli.entity.order.CommonOrder;
 import com.yeshi.fanli.entity.order.CommonOrderGoods;
 import com.yeshi.fanli.entity.order.HongBaoOrder;
+import com.yeshi.fanli.entity.taobao.PidOrder;
 import com.yeshi.fanli.entity.taobao.TaoBaoOrder;
+import com.yeshi.fanli.entity.taobao.TaoBaoWeiQuanOrder;
+import com.yeshi.fanli.exception.HongBaoException;
+import com.yeshi.fanli.exception.share.UserShareGoodsRecordException;
+import com.yeshi.fanli.log.LogHelper;
+import com.yeshi.fanli.service.inter.hongbao.HongBaoManageService;
 import com.yeshi.fanli.service.inter.hongbao.HongBaoV2Service;
+import com.yeshi.fanli.service.inter.hongbao.ThreeSaleSerivce;
+import com.yeshi.fanli.service.inter.msg.UserOrderMsgNotificationService;
+import com.yeshi.fanli.service.inter.order.CommonOrderService;
+import com.yeshi.fanli.service.inter.user.UserInfoService;
+import com.yeshi.fanli.service.inter.user.UserNotificationService;
+import com.yeshi.fanli.service.inter.user.UserShareGoodsGroupService;
 import com.yeshi.fanli.util.Constant;
+import com.yeshi.fanli.util.MoneyBigDecimalUtil;
+import com.yeshi.fanli.util.TimeUtil;
 import com.yeshi.fanli.util.taobao.TaoBaoOrderUtil;
 
 @Service
@@ -55,6 +80,33 @@
 
 	@Resource
 	private OrderMapper orderMapper;
+
+	@Resource
+	private CommonOrderService commonOrderService;
+
+	@Resource
+	private UserInfoService userInfoService;
+
+	@Resource
+	private TaoBaoWeiQuanOrderMapper taoBaoWeiQuanOrderMapper;
+
+	@Resource
+	private UserShareGoodsGroupService userShareGoodsGroupService;
+
+	@Resource
+	private PidOrderMapper pidOrderMapper;
+
+	@Resource
+	private HongBaoManageService hongBaoManageService;
+
+	@Resource
+	private ThreeSaleSerivce threeSaleSerivce;
+
+	@Resource
+	private UserNotificationService userNotificationService;
+
+	@Resource
+	private UserOrderMsgNotificationService userOrderMsgNotificationService;
 
 	@Override
 	public int insert(HongBaoV2 record) {
@@ -99,12 +151,22 @@
 		if (hb.getParent() != null)
 			v2.setParent(new HongBaoV2(hb.getParent().getId()));
 
-		if (hb.getPreGettime() == null || hb.getPreGettime() == 0)
-			v2.setPreGetTime(null);
-		else
-			v2.setPreGetTime(new Date(hb.getPreGettime()));
+		if (hb.getType() == HongBao.TYPE_SHARE_GOODS) {
+			if (hb.getBalanceTime() != null)
+				v2.setPreGetTime(new Date(hb.getPreGettime()));
+			else
+				v2.setPreGetTime(null);
+		} else {
+			if (hb.getPreGettime() == null || hb.getPreGettime() == 0)
+				v2.setPreGetTime(null);
+			else
+				v2.setPreGetTime(new Date(hb.getPreGettime()));
+		}
 
 		v2.setState(hb.getState());
+		if (hb.getState() == 1 && hb.getBalanceTime() != null) {
+			v2.setState(HongBaoV2.STATE_KELINGQU);
+		}
 		v2.setType(type);
 		v2.setUpdateTime(new Date(hb.getCreatetime()));
 		v2.setUrank(hb.getUrank());
@@ -126,12 +188,10 @@
 			if (hb.getOrder() != null) {
 				orderId = hb.getOrder().getOrderId();
 				// 鏌ヨ鍚屼竴璁㈠崟鍙风殑闈炲瓙绾㈠寘
-
 			} else
 				orderId = hb.getOrderId();
 
 			int count = commonOrderMapper.countByOrderNOAndOrderType(orderId, Constant.SOURCE_TYPE_TAOBAO);
-			
 
 			// 宸茬粡鎻掑叆璁㈠崟
 			if (count > 0)
@@ -174,20 +234,46 @@
 
 				if (list.size() <= 0)
 					return;
+				if (list.get(0).getType() == 20)
+					for (HongBao hb1 : list) {
+						PidOrder pidOrder = pidOrderMapper.getPidOrderByHongBaoId(hb1.getId());
+						if (pidOrder != null)
+							hb1.setAuctionId(pidOrder.getAuctionId());
+
+					}
+
 				List<TaoBaoOrder> orderList = taoBaoOrderMapper.selectTaoBaoOrderByOrderId(orderId);
-				if (orderList == null || orderList.size() != list.size()) {
+
+				if (orderList == null || orderList.size() < list.size()) {
 					System.out.println("绾㈠寘鏁颁笌璁㈠崟鏁颁笉瀵瑰簲");
 					return;
 				}
 
+				// 鍔犲叆鎺掑簭鍊�
+				for (int i = 0; i < orderList.size(); i++) {
+					orderList.get(i).setOrderBy(i + 1);
+				}
+
 				// 鎸夌収auctionId,payMoney鎺掑簭
 				Comparator<HongBao> cm = new Comparator<HongBao>() {
-
 					@Override
 					public int compare(HongBao o1, HongBao o2) {
-						return o1.getAuctionId() == o2.getAuctionId()
-								? (o1.getPayMoney().subtract(o2.getPayMoney()).compareTo(new BigDecimal(0)))
-								: (int) (o1.getAuctionId() - o2.getAuctionId());
+						if (o1.getAuctionId().longValue() < o2.getAuctionId().longValue())
+							return -3;
+						else if (o1.getAuctionId().longValue() > o2.getAuctionId().longValue()) {
+							return 3;
+						} else {
+							if (o1.getState() - o2.getState() > 0)
+								return 2;
+							else if (o1.getState() - o2.getState() < 0)
+								return -2;
+							else {
+								if (o1.getPayMoney().compareTo(o2.getPayMoney()) >= 0)
+									return 1;
+								else
+									return -1;
+							}
+						}
 					}
 				};
 
@@ -197,13 +283,24 @@
 
 					@Override
 					public int compare(TaoBaoOrder o1, TaoBaoOrder o2) {
-						return o1.getAuctionId() == o2.getAuctionId()
-								? (o1.getPayment().subtract(o2.getPayment()).compareTo(new BigDecimal(0)))
-								: (int) (o1.getAuctionId() - o2.getAuctionId());
+
+						if (o1.getAuctionId().longValue() < o2.getAuctionId().longValue())
+							return -3;
+						else if (o1.getAuctionId().longValue() > o2.getAuctionId().longValue()) {
+							return 3;
+						} else {
+							if (o1.getPayment().compareTo(o2.getPayment()) < 0)
+								return 2;
+							else
+								return -2;
+						}
 					}
 				};
 
 				Collections.sort(orderList, cmOrder);
+
+				for (TaoBaoOrder t : orderList)
+					System.out.println(t.getAuctionId());
 
 				for (int i = 0; i < list.size(); i++) {
 					CommonOrder commonOrder = TaoBaoOrderUtil.convert(orderList.get(i));
@@ -220,6 +317,13 @@
 					commonOrder.setCommonOrderGoods(goods);
 
 					commonOrder.setUserInfo(list.get(i).getUserInfo());
+					commonOrder.setCreateTime(new Date(list.get(i).getCreatetime()));
+
+					// TODO 缁存潈鍒ゆ柇
+					List<TaoBaoWeiQuanOrder> weiQuanList = taoBaoWeiQuanOrderMapper.selectListByOrderIdAndState(orderId,
+							"缁存潈鎴愬姛");
+					if (weiQuanList != null && weiQuanList.size() > 0)
+						commonOrder.setState(CommonOrder.STATE_WQ);
 
 					commonOrderMapper.insertSelective(commonOrder);
 
@@ -258,4 +362,584 @@
 
 	}
 
+	@Transactional
+	@Override
+	public void addHongBao(List<CommonOrder> commonOrderList, int type) throws HongBaoException {
+		Set<Integer> stateSet = new HashSet<>();// 璁㈠崟鐘舵�丼et
+		if (commonOrderList != null && commonOrderList.size() > 0) {
+			Map<Integer, HongBaoOrder> notificationMap = new HashMap<>();
+			int goodsCount = 0;
+			boolean hasAdd = false;
+			for (CommonOrder commonOrder : commonOrderList) {
+				stateSet.add(commonOrder.getState());
+				goodsCount += commonOrder.getCount();
+				if (commonOrder == null || commonOrder.getId() == null || commonOrder.getUserInfo() == null)
+					throw new HongBaoException(1, "璁㈠崟淇℃伅涓嶅畬鏁�");
+				HongBaoOrder hongBaoOrder = hongBaoOrderMapper.selectByCommonOrderId(commonOrder.getId());
+				if (hongBaoOrder == null) {
+					saveHongBao(commonOrder, type, notificationMap);
+					hasAdd = true;
+				} else {
+					updateHongBao(hongBaoOrder, commonOrder, type, notificationMap);
+				}
+			}
+			/**
+			 * 閫氱煡鐢ㄦ埛鐨勮繑鍒╂儏鍐�
+			 */
+			int state = getOrderState(stateSet);
+			if (hasAdd) {
+				Iterator<Integer> its = notificationMap.keySet().iterator();
+				while (its.hasNext()) {
+
+					Integer t = its.next();
+					HongBaoV2 notify = notificationMap.get(t).getHongBaoV2();
+					CommonOrder commonOrder = notificationMap.get(t).getCommonOrder();
+					String orderId = commonOrderList.get(0).getOrderNo();
+					Long uid = notify.getUserInfo().getId();
+					BigDecimal money = notify.getMoney();
+					switch (t) {
+					case HongBaoV2.TYPE_ZIGOU:
+						userNotificationService.orderFanliStatisticed(uid, orderId, goodsCount, MsgOrderDetail.STATE_FK,
+								null, money);
+						userOrderMsgNotificationService.orderFanLiStatistic(uid, orderId, commonOrder.getPayment(),
+								money, goodsCount, state);
+						break;
+					case HongBaoV2.TYPE_SHARE_GOODS:
+						userNotificationService.orderShareStatisticed(uid, orderId, goodsCount, MsgOrderDetail.STATE_FK,
+								null, money);
+						userOrderMsgNotificationService.orderShareStatistic(uid, orderId, commonOrder.getPayment(),
+								money, goodsCount, state);
+						break;
+					case HongBaoV2.TYPE_YIJI:
+						userNotificationService.orderInviteStatisticed(uid, orderId, goodsCount,
+								MsgOrderDetail.STATE_FK, null, money);
+						userOrderMsgNotificationService.orderInviteStatistic(uid, orderId, commonOrder.getPayment(),
+								money, goodsCount, state);
+						break;
+					case HongBaoV2.TYPE_ERJI:
+						userNotificationService.orderInviteStatisticed(uid, orderId, goodsCount,
+								MsgOrderDetail.STATE_FK, null, money);
+						userOrderMsgNotificationService.orderInviteStatistic(uid, orderId, commonOrder.getPayment(),
+								money, goodsCount, state);
+						break;
+					}
+				}
+			}
+
+			// 娣诲姞鏂扮増鏈�氱煡
+
+			if (!hasAdd) {
+				Iterator<Integer> its = notificationMap.keySet().iterator();
+				while (its.hasNext()) {
+					Integer t = its.next();
+					HongBaoV2 notify = notificationMap.get(t).getHongBaoV2();
+					CommonOrder commonOrder = notificationMap.get(t).getCommonOrder();
+					String orderId = commonOrderList.get(0).getOrderNo();
+					Long uid = notify.getUserInfo().getId();
+					BigDecimal money = notify.getMoney();
+					switch (t) {
+					case HongBaoV2.TYPE_ZIGOU:
+						userOrderMsgNotificationService.orderFanLiStateChanged(uid, orderId, commonOrder.getPayment(),
+								money, state);
+						break;
+					case HongBaoV2.TYPE_SHARE_GOODS:
+						userOrderMsgNotificationService.orderShareStateChanged(uid, orderId, commonOrder.getPayment(),
+								money, state);
+						break;
+					case HongBaoV2.TYPE_YIJI:
+						userOrderMsgNotificationService.orderInviteStateChanged(uid, orderId, commonOrder.getPayment(),
+								money, state);
+						break;
+					case HongBaoV2.TYPE_ERJI:
+						userOrderMsgNotificationService.orderInviteStateChanged(uid, orderId, commonOrder.getPayment(),
+								money, state);
+						break;
+					}
+				}
+			}
+		}
+
+	}
+
+	private int getOrderState(Set<Integer> states) {
+		if (states.size() == 1)
+			return states.iterator().next();
+		Iterator<Integer> its = states.iterator();
+		while (its.hasNext()) {
+			int tempState = its.next();
+			if (tempState == CommonOrder.STATE_FK)
+				return CommonOrder.STATE_FK;
+			else if (tempState == CommonOrder.STATE_JS)
+				return CommonOrder.STATE_JS;
+		}
+		return CommonOrder.STATE_SX;
+	}
+
+	@Transactional
+	private void updateHongBao(HongBaoOrder hongBaoOrder, CommonOrder commonOrder, int type,
+			Map<Integer, HongBaoOrder> notificationMap) throws HongBaoException {
+		System.out.println(commonOrder.getOrderNo());
+		HongBaoV2 oldHongBao = hongBaoV2Mapper.selectByPrimaryKey(hongBaoOrder.getHongBaoV2().getId());
+		if (oldHongBao == null)
+			throw new HongBaoException(10, "绾㈠寘瀵硅薄涓嶅瓨鍦�");
+		// 宸茬粡澶辨晥鎴栬�呭凡缁忛鍙栫殑绾㈠寘涓嶅仛澶勭悊
+		if (oldHongBao.getState() == HongBaoV2.STATE_SHIXIAO || oldHongBao.getState() == HongBaoV2.STATE_YILINGQU)
+			return;
+
+		if (type == HongBaoV2.TYPE_ZIGOU) {// 鑾峰彇鑷喘鐨勮繑鍒╂瘮渚�
+			BigDecimal fanliRate = hongBaoManageService.getFanLiRate(commonOrder.getCreateTime().getTime());
+			HongBaoV2 hongBao = new HongBaoV2(hongBaoOrder.getHongBaoV2().getId());
+			hongBao.setUpdateTime(new Date());
+			// 鏇存敼鐘舵�佷笌璧勯噾
+			if (commonOrder.getState() == CommonOrder.STATE_FK) {
+				hongBao.setState(HongBaoV2.STATE_BUKELINGQU);
+				hongBao.setMoney(
+						MoneyBigDecimalUtil.mul(commonOrder.getEstimate(), fanliRate.divide(new BigDecimal(100))));
+			} else if (commonOrder.getState() == CommonOrder.STATE_JS) {
+				hongBao.setState(HongBaoV2.STATE_KELINGQU);
+				hongBao.setMoney(
+						MoneyBigDecimalUtil.mul(commonOrder.geteIncome(), fanliRate.divide(new BigDecimal(100))));
+				hongBao.setPreGetTime(new Date(commonOrder.getSettleTime().getTime() + 1000 * 60 * 60 * 24 * 15L));
+			} else if (commonOrder.getState() == CommonOrder.STATE_SX) {
+				hongBao.setState(HongBaoV2.STATE_SHIXIAO);
+				hongBao.setMoney(new BigDecimal(0));
+			}
+			hongBaoV2Mapper.updateByPrimaryKeySelective(hongBao);
+
+			// 鍔犲叆閫氱煡
+			if (notificationMap.get(type) == null) {
+				HongBaoV2 tempHongBao = new HongBaoV2(oldHongBao.getId());
+				tempHongBao.setUserInfo(oldHongBao.getUserInfo());
+				tempHongBao.setMoney(hongBao.getMoney());
+				CommonOrder tempCommonOrder = new CommonOrder(commonOrder.getId());
+				tempCommonOrder.setPayment(commonOrder.getPayment());
+				notificationMap.put(type, new HongBaoOrder(tempCommonOrder, tempHongBao));
+			} else {
+				// 澧炲姞浠樻閲戦涓庤祫閲�
+				HongBaoOrder tempHongBaoOrder = notificationMap.get(type);
+				tempHongBaoOrder.getCommonOrder()
+						.setPayment(tempHongBaoOrder.getCommonOrder().getPayment().add(commonOrder.getPayment()));
+				tempHongBaoOrder.getHongBaoV2()
+						.setMoney(tempHongBaoOrder.getHongBaoV2().getMoney().add(hongBao.getMoney()));
+				notificationMap.put(type, tempHongBaoOrder);
+			}
+
+			// 鑾峰彇瀛愮孩鍖�
+			List<HongBaoV2> children = hongBaoV2Mapper.listChildrenById(hongBao.getId());
+			if (children != null)
+				for (HongBaoV2 child : children) {
+					HongBaoV2 childUpdate = new HongBaoV2(child.getId());
+					childUpdate.setState(hongBao.getState());
+					childUpdate.setUpdateTime(new Date());
+					BigDecimal rate = null;
+					if (child.getType() == HongBaoV2.TYPE_YIJI) {// 涓�绾у垎浜禋
+						rate = hongBaoManageService.getFirstInviteRate(child.getUrank(),
+								commonOrder.getCreateTime().getTime());
+					} else if (child.getType() == HongBaoV2.TYPE_ERJI) {// 浜岀骇鍒嗕韩璧�
+						rate = hongBaoManageService.getSecondInviteRate(child.getUrank(),
+								commonOrder.getCreateTime().getTime());
+					}
+
+					// 浠ュ疄闄呮敹鍏ヤ负鍑嗚绠楅浼版敹鐩�
+					if (hongBao.getState() == HongBaoV2.STATE_KELINGQU) {
+						childUpdate.setMoney(
+								MoneyBigDecimalUtil.mul(hongBao.getMoney(), rate.divide(new BigDecimal(100))));
+						Calendar calendar = Calendar.getInstance();
+						calendar.setTime(commonOrder.getSettleTime());
+						calendar.add(Calendar.MONTH, 1);
+						childUpdate.setPreGetTime(new Date(TimeUtil.convertToTimeTemp(
+								calendar.get(Calendar.YEAR) + "-" + (calendar.get(Calendar.MONTH) + 1) + "-25",
+								"yyyy-M-dd")));
+					} else if (hongBao.getState() == HongBaoV2.STATE_BUKELINGQU) {
+						childUpdate.setMoney(
+								MoneyBigDecimalUtil.mul(hongBao.getMoney(), rate.divide(new BigDecimal(100))));
+					}
+					hongBaoV2Mapper.updateByPrimaryKeySelective(childUpdate);
+
+					// 鍔犲叆閫氱煡
+					if (notificationMap.get(type) == null) {
+						HongBaoV2 tempHongBao = new HongBaoV2(child.getId());
+						tempHongBao.setUserInfo(child.getUserInfo());
+						tempHongBao.setMoney(child.getMoney());
+						CommonOrder tempCommonOrder = new CommonOrder(commonOrder.getId());
+						tempCommonOrder.setPayment(commonOrder.getPayment());
+						notificationMap.put(type, new HongBaoOrder(tempCommonOrder, tempHongBao));
+					} else {
+						// 澧炲姞浠樻閲戦涓庤祫閲�
+						HongBaoOrder tempHongBaoOrder = notificationMap.get(type);
+						tempHongBaoOrder.getCommonOrder().setPayment(
+								tempHongBaoOrder.getCommonOrder().getPayment().add(commonOrder.getPayment()));
+						tempHongBaoOrder.getHongBaoV2()
+								.setMoney(tempHongBaoOrder.getHongBaoV2().getMoney().add(child.getMoney()));
+						notificationMap.put(type, tempHongBaoOrder);
+					}
+
+				}
+
+		} else if (type == HongBaoV2.TYPE_SHARE_GOODS) {
+			BigDecimal fanliRate = hongBaoManageService.getFanLiRate(commonOrder.getCreateTime().getTime());
+			HongBaoV2 hongBao = new HongBaoV2(hongBaoOrder.getHongBaoV2().getId());
+			hongBao.setUpdateTime(new Date());
+			// 鏇存敼鐘舵�佷笌璧勯噾
+			if (commonOrder.getState() == CommonOrder.STATE_FK) {
+				hongBao.setState(HongBaoV2.STATE_BUKELINGQU);
+				hongBao.setMoney(
+						MoneyBigDecimalUtil.mul(commonOrder.getEstimate(), fanliRate.divide(new BigDecimal(100))));
+			} else if (commonOrder.getState() == CommonOrder.STATE_JS) {
+				hongBao.setState(HongBaoV2.STATE_KELINGQU);
+				hongBao.setMoney(
+						MoneyBigDecimalUtil.mul(commonOrder.geteIncome(), fanliRate.divide(new BigDecimal(100))));
+				Calendar calendar = Calendar.getInstance();
+				calendar.setTime(commonOrder.getSettleTime());
+				calendar.add(Calendar.MONTH, 1);
+				hongBao.setPreGetTime(new Date(TimeUtil.convertToTimeTemp(
+						calendar.get(Calendar.YEAR) + "-" + (calendar.get(Calendar.MONTH) + 1) + "-25", "yyyy-M-dd")));
+			} else if (commonOrder.getState() == CommonOrder.STATE_SX) {
+				hongBao.setState(HongBaoV2.STATE_SHIXIAO);
+				hongBao.setMoney(new BigDecimal(0));
+			}
+			hongBaoV2Mapper.updateByPrimaryKeySelective(hongBao);
+			// 閫氱煡
+			if (notificationMap.get(type) == null) {
+				HongBaoV2 tempHongBao = new HongBaoV2(hongBao.getId());
+				tempHongBao.setUserInfo(hongBao.getUserInfo());
+				tempHongBao.setMoney(hongBao.getMoney());
+				CommonOrder tempCommonOrder = new CommonOrder(commonOrder.getId());
+				tempCommonOrder.setPayment(commonOrder.getPayment());
+				notificationMap.put(type, new HongBaoOrder(tempCommonOrder, tempHongBao));
+			} else {
+				// 澧炲姞浠樻閲戦涓庤祫閲�
+				HongBaoOrder tempHongBaoOrder = notificationMap.get(type);
+				tempHongBaoOrder.getCommonOrder()
+						.setPayment(tempHongBaoOrder.getCommonOrder().getPayment().add(commonOrder.getPayment()));
+				tempHongBaoOrder.getHongBaoV2()
+						.setMoney(tempHongBaoOrder.getHongBaoV2().getMoney().add(hongBao.getMoney()));
+				notificationMap.put(type, tempHongBaoOrder);
+			}
+
+			// 鑾峰彇瀛愮孩鍖�
+			List<HongBaoV2> children = hongBaoV2Mapper.listChildrenById(hongBao.getId());
+			if (children != null)
+				for (HongBaoV2 child : children) {
+					HongBaoV2 childUpdate = new HongBaoV2(child.getId());
+					// 缁熶竴璁剧疆鐘舵��
+					childUpdate.setState(hongBao.getState());
+					childUpdate.setUpdateTime(new Date());
+					BigDecimal rate = null;
+					if (child.getType() == HongBaoV2.TYPE_SHARE_YIJI) {// 涓�绾у垎浜禋
+						rate = hongBaoManageService.getFirstShareRate(child.getUrank(),
+								commonOrder.getCreateTime().getTime());
+					} else if (child.getType() == HongBaoV2.TYPE_SHARE_ERJI) {// 浜岀骇鍒嗕韩璧�
+						rate = hongBaoManageService.getSecondShareRate(child.getUrank(),
+								commonOrder.getCreateTime().getTime());
+					}
+
+					// 浠ュ疄闄呮敹鍏ヤ负鍑嗚绠楅浼版敹鐩�
+					if (CommonOrder.STATE_JS == commonOrder.getState()) {
+						childUpdate.setMoney(
+								MoneyBigDecimalUtil.mul(hongBao.getMoney(), rate.divide(new BigDecimal(100))));
+						Calendar calendar = Calendar.getInstance();
+						calendar.setTime(commonOrder.getSettleTime());
+						calendar.add(Calendar.MONTH, 1);
+						childUpdate.setPreGetTime(new Date(TimeUtil.convertToTimeTemp(
+								calendar.get(Calendar.YEAR) + "-" + (calendar.get(Calendar.MONTH) + 1) + "-25",
+								"yyyy-M-dd")));
+					} else if (CommonOrder.STATE_FK == commonOrder.getState()) {
+						if (commonOrder.getOrderNo().equalsIgnoreCase("314134177659155087"))
+							System.out.println("");
+
+						childUpdate.setMoney(
+								MoneyBigDecimalUtil.mul(hongBao.getMoney(), rate.divide(new BigDecimal(100))));
+					}
+					hongBaoV2Mapper.updateByPrimaryKeySelective(childUpdate);
+				}
+		} else
+			throw new HongBaoException(2, "type閿欒");
+	}
+
+	@Transactional
+	private void saveHongBao(CommonOrder commonOrder, int type, Map<Integer, HongBaoOrder> notificationMap)
+			throws HongBaoException {
+		if (type == HongBaoV2.TYPE_ZIGOU) {// 鑾峰彇鑷喘鐨勮繑鍒╂瘮渚�
+			BigDecimal fanliRate = hongBaoManageService.getFanLiRate(commonOrder.getCreateTime().getTime());
+			HongBaoV2 hongBao = new HongBaoV2();
+			hongBao.setUserInfo(commonOrder.getUserInfo());
+			hongBao.setCreateTime(new Date());
+			hongBao.setType(HongBaoV2.TYPE_ZIGOU);
+			hongBao.setVersion(2);
+			if (commonOrder.getState() == CommonOrder.STATE_FK) {
+				hongBao.setState(HongBaoV2.STATE_BUKELINGQU);
+				hongBao.setMoney(
+						MoneyBigDecimalUtil.mul(commonOrder.getEstimate(), fanliRate.divide(new BigDecimal(100))));
+			} else if (commonOrder.getState() == CommonOrder.STATE_JS) {
+				hongBao.setState(HongBaoV2.STATE_KELINGQU);
+				hongBao.setMoney(
+						MoneyBigDecimalUtil.mul(commonOrder.geteIncome(), fanliRate.divide(new BigDecimal(100))));
+				hongBao.setPreGetTime(new Date(commonOrder.getSettleTime().getTime() + 1000 * 60 * 60 * 24 * 15L));
+			} else if (commonOrder.getState() == CommonOrder.STATE_SX) {
+				hongBao.setState(HongBaoV2.STATE_SHIXIAO);
+				hongBao.setMoney(new BigDecimal(0));
+			} else {
+				throw new HongBaoException(3, "缁存潈璁㈠崟涓嶈兘鍒涘缓绾㈠寘");
+			}
+			UserInfo user = userInfoService.getUserById(commonOrder.getUserInfo().getId());
+			hongBao.setUrank(user.getRank());
+			hongBaoV2Mapper.insertSelective(hongBao);
+			// 娣诲姞绾㈠寘涓庤鍗曠殑鏄犲皠
+			HongBaoOrder hongBaoOrder = new HongBaoOrder();
+			hongBaoOrder.setCommonOrder(commonOrder);
+			hongBaoOrder.setCreateTime(new Date());
+			hongBaoOrder.setHongBaoV2(hongBao);
+			hongBaoOrderMapper.insertSelective(hongBaoOrder);
+			// 鍔犲叆閫氱煡
+			if (notificationMap.get(type) == null) {
+				HongBaoV2 tempHongBao = new HongBaoV2(hongBao.getId());
+				tempHongBao.setUserInfo(hongBao.getUserInfo());
+				tempHongBao.setMoney(hongBao.getMoney());
+				CommonOrder tempCommonOrder = new CommonOrder(commonOrder.getId());
+				tempCommonOrder.setPayment(commonOrder.getPayment());
+				notificationMap.put(type, new HongBaoOrder(tempCommonOrder, tempHongBao));
+			} else {
+				// 澧炲姞浠樻閲戦涓庤祫閲�
+				HongBaoOrder tempHongBaoOrder = notificationMap.get(type);
+				tempHongBaoOrder.getCommonOrder()
+						.setPayment(tempHongBaoOrder.getCommonOrder().getPayment().add(commonOrder.getPayment()));
+				tempHongBaoOrder.getHongBaoV2()
+						.setMoney(tempHongBaoOrder.getHongBaoV2().getMoney().add(hongBao.getMoney()));
+				notificationMap.put(type, tempHongBaoOrder);
+			}
+
+			UserInfo boss = threeSaleSerivce.getBoss(user.getId());
+			if (boss != null && hongBao.getState() != HongBaoV2.STATE_SHIXIAO) {// 1绾OSS瀛樺湪涓旂孩鍖呮湭澶辨晥
+
+				// 鎻掑叆涓�绾у瓙绾㈠寘
+				BigDecimal firstRate = hongBaoManageService
+						.getFirstInviteRate(boss.getRank() == null ? 0 : boss.getRank());
+				if (firstRate.compareTo(new BigDecimal(0)) <= 0)
+					return;
+				HongBaoV2 firstHongbao = new HongBaoV2();
+				firstHongbao.setUserInfo(boss);
+				firstHongbao.setUrank(boss.getRank());
+				firstHongbao.setParent(hongBao);
+				firstHongbao.setCreateTime(new Date());
+				firstHongbao.setType(HongBaoV2.TYPE_YIJI);
+				firstHongbao.setVersion(2);
+				firstHongbao.setState(hongBao.getState());
+
+				if (hongBao.getState() == HongBaoV2.STATE_KELINGQU) {
+					firstHongbao.setMoney(
+							MoneyBigDecimalUtil.mul(hongBao.getMoney(), firstRate.divide(new BigDecimal(100))));
+					Calendar calendar = Calendar.getInstance();
+					calendar.setTime(commonOrder.getSettleTime());
+					calendar.add(Calendar.MONTH, 1);
+					firstHongbao.setPreGetTime(new Date(TimeUtil.convertToTimeTemp(
+							calendar.get(Calendar.YEAR) + "-" + (calendar.get(Calendar.MONTH) + 1) + "-25",
+							"yyyy-M-dd")));
+				} else if (hongBao.getState() == HongBaoV2.STATE_BUKELINGQU) {
+					firstHongbao.setMoney(
+							MoneyBigDecimalUtil.mul(hongBao.getMoney(), firstRate.divide(new BigDecimal(100))));
+				}
+				hongBaoV2Mapper.insertSelective(firstHongbao);
+				// 鐢ㄦ埛閫氱煡
+				if (notificationMap.get(HongBaoV2.TYPE_YIJI) == null) {
+					HongBaoV2 tempHongBao = new HongBaoV2(firstHongbao.getId());
+					tempHongBao.setUserInfo(firstHongbao.getUserInfo());
+					tempHongBao.setMoney(firstHongbao.getMoney());
+					CommonOrder tempCommonOrder = new CommonOrder(commonOrder.getId());
+					tempCommonOrder.setPayment(commonOrder.getPayment());
+					notificationMap.put(HongBaoV2.TYPE_YIJI, new HongBaoOrder(tempCommonOrder, tempHongBao));
+				} else {
+					// 澧炲姞浠樻閲戦涓庤祫閲�
+					HongBaoOrder tempHongBaoOrder = notificationMap.get(HongBaoV2.TYPE_YIJI);
+					tempHongBaoOrder.getCommonOrder()
+							.setPayment(tempHongBaoOrder.getCommonOrder().getPayment().add(commonOrder.getPayment()));
+					tempHongBaoOrder.getHongBaoV2()
+							.setMoney(tempHongBaoOrder.getHongBaoV2().getMoney().add(firstHongbao.getMoney()));
+					notificationMap.put(HongBaoV2.TYPE_YIJI, tempHongBaoOrder);
+				}
+
+				// 鎻掑叆浜岀骇瀛愮孩鍖�
+				boss = threeSaleSerivce.getBoss(boss.getId());
+				if (boss != null) {// 浜岀骇BOSS瀛樺湪
+					BigDecimal secondRate = hongBaoManageService
+							.getSecondInviteRate(boss.getRank() == null ? 0 : boss.getRank());
+					if (secondRate.compareTo(new BigDecimal(0)) <= 0)
+						return;
+					HongBaoV2 secondHongbao = new HongBaoV2();
+					secondHongbao.setUserInfo(boss);
+					secondHongbao.setUrank(boss.getRank());
+					secondHongbao.setParent(hongBao);
+					secondHongbao.setCreateTime(new Date());
+					secondHongbao.setType(HongBaoV2.TYPE_ERJI);
+					secondHongbao.setVersion(2);
+					secondHongbao.setState(hongBao.getState());
+					if (hongBao.getState() == HongBaoV2.STATE_KELINGQU) {
+						secondHongbao.setMoney(
+								MoneyBigDecimalUtil.mul(hongBao.getMoney(), secondRate.divide(new BigDecimal(100))));
+						Calendar calendar = Calendar.getInstance();
+						calendar.setTime(commonOrder.getSettleTime());
+						calendar.add(Calendar.MONTH, 1);
+						secondHongbao.setPreGetTime(new Date(TimeUtil.convertToTimeTemp(
+								calendar.get(Calendar.YEAR) + "-" + (calendar.get(Calendar.MONTH) + 1) + "-25",
+								"yyyy-M-dd")));
+					} else if (hongBao.getState() == HongBaoV2.STATE_BUKELINGQU) {
+						secondHongbao.setMoney(
+								MoneyBigDecimalUtil.mul(hongBao.getMoney(), secondRate.divide(new BigDecimal(100))));
+					}
+					hongBaoV2Mapper.insertSelective(secondHongbao);
+
+					// 鐢ㄦ埛閫氱煡
+					if (notificationMap.get(HongBaoV2.TYPE_ERJI) == null) {
+						HongBaoV2 tempHongBao = new HongBaoV2(secondHongbao.getId());
+						tempHongBao.setUserInfo(secondHongbao.getUserInfo());
+						tempHongBao.setMoney(secondHongbao.getMoney());
+						CommonOrder tempCommonOrder = new CommonOrder(commonOrder.getId());
+						tempCommonOrder.setPayment(commonOrder.getPayment());
+						notificationMap.put(HongBaoV2.TYPE_ERJI, new HongBaoOrder(tempCommonOrder, tempHongBao));
+					} else {
+						// 澧炲姞浠樻閲戦涓庤祫閲�
+						HongBaoOrder tempHongBaoOrder = notificationMap.get(HongBaoV2.TYPE_ERJI);
+						tempHongBaoOrder.getCommonOrder().setPayment(
+								tempHongBaoOrder.getCommonOrder().getPayment().add(commonOrder.getPayment()));
+						tempHongBaoOrder.getHongBaoV2()
+								.setMoney(tempHongBaoOrder.getHongBaoV2().getMoney().add(secondHongbao.getMoney()));
+						notificationMap.put(HongBaoV2.TYPE_ERJI, tempHongBaoOrder);
+					}
+				}
+
+			}
+
+		} else if (type == HongBaoV2.TYPE_SHARE_GOODS) {
+			// 鍒嗕韩璧氫笉鍔犲叆澶辨晥鐨勮鍗�
+			if (commonOrder.getState() == CommonOrder.STATE_SX || commonOrder.getState() == CommonOrder.STATE_WQ)
+				return;
+			// 鍒嗕韩璧�
+			BigDecimal shareRate = hongBaoManageService.getShareRate(commonOrder.getCreateTime().getTime());
+			HongBaoV2 hongBao = new HongBaoV2();
+			hongBao.setCreateTime(new Date());
+			hongBao.setType(HongBaoV2.TYPE_SHARE_GOODS);
+			hongBao.setVersion(2);
+			if (commonOrder.getState() == CommonOrder.STATE_FK) {
+				hongBao.setState(HongBaoV2.STATE_BUKELINGQU);
+				hongBao.setMoney(
+						MoneyBigDecimalUtil.mul(commonOrder.getEstimate(), shareRate.divide(new BigDecimal(100))));
+			} else if (commonOrder.getState() == CommonOrder.STATE_JS) {
+				hongBao.setState(HongBaoV2.STATE_KELINGQU);
+				hongBao.setMoney(
+						MoneyBigDecimalUtil.mul(commonOrder.geteIncome(), shareRate.divide(new BigDecimal(100))));
+				Calendar calendar = Calendar.getInstance();
+				calendar.setTime(commonOrder.getSettleTime());
+				calendar.add(Calendar.MONTH, 1);
+				hongBao.setPreGetTime(new Date(TimeUtil.convertToTimeTemp(
+						calendar.get(Calendar.YEAR) + "-" + (calendar.get(Calendar.MONTH) + 1) + "-25", "yyyy-M-dd")));
+			}
+			UserInfo user = userInfoService.getUserById(commonOrder.getUserInfo().getId());
+			hongBao.setUrank(user.getRank());
+			hongBao.setUserInfo(user);
+			hongBaoV2Mapper.insertSelective(hongBao);
+			// 鎻掑叆绾㈠寘涓庤鍗曟槧灏�
+			HongBaoOrder hongBaoOrder = new HongBaoOrder();
+			hongBaoOrder.setCommonOrder(commonOrder);
+			hongBaoOrder.setCreateTime(new Date());
+			hongBaoOrder.setHongBaoV2(hongBao);
+			hongBaoOrderMapper.insertSelective(hongBaoOrder);
+
+			if (notificationMap.get(type) == null) {
+				HongBaoV2 tempHongBao = new HongBaoV2(hongBao.getId());
+				tempHongBao.setUserInfo(hongBao.getUserInfo());
+				tempHongBao.setMoney(hongBao.getMoney());
+				CommonOrder tempCommonOrder = new CommonOrder(commonOrder.getId());
+				tempCommonOrder.setPayment(commonOrder.getPayment());
+				notificationMap.put(type, new HongBaoOrder(tempCommonOrder, tempHongBao));
+			} else {
+				// 澧炲姞浠樻閲戦涓庤祫閲�
+				HongBaoOrder tempHongBaoOrder = notificationMap.get(type);
+				tempHongBaoOrder.getCommonOrder()
+						.setPayment(tempHongBaoOrder.getCommonOrder().getPayment().add(commonOrder.getPayment()));
+				tempHongBaoOrder.getHongBaoV2()
+						.setMoney(tempHongBaoOrder.getHongBaoV2().getMoney().add(hongBao.getMoney()));
+				notificationMap.put(type, tempHongBaoOrder);
+			}
+
+			// 淇敼缁熻鏁版嵁
+			Long goodsId = commonOrder.getCommonOrderGoods().getId();
+			// 鏌ヨ鍟嗗搧
+			CommonOrderGoods goods = commonOrderGoodsMapper.selectByPrimaryKey(goodsId);
+
+			HongBao hb = new HongBao();
+			if (goods != null)
+				hb.setAuctionId(Long.parseLong(goods.getGoodsId()));
+			hb.setUserInfo(hongBao.getUserInfo());
+			hb.setMoney(hongBao.getMoney());
+
+			try {
+				userShareGoodsGroupService.updateOrderRecord(hb);
+			} catch (UserShareGoodsRecordException e) {
+				try {
+					LogHelper.errorDetailInfo(e);
+				} catch (Exception e1) {
+					e1.printStackTrace();
+				}
+			}
+
+		} else
+			throw new HongBaoException(2, "type閿欒");
+	}
+
+	@Override
+	public List<HongBaoDTO> listJiangJinByUid(Long uid, int page, int pageSize) {
+		return hongBaoV2Mapper.listJiangJinByUid(uid, (page - 1) * pageSize, pageSize);
+	}
+
+	@Override
+	public long countJiangJinByUid(Long uid) {
+		Long count = hongBaoV2Mapper.countJiangJinByUid(uid);
+		return count == null ? 0 : count;
+	}
+
+	@Override
+	public BigDecimal getTotalTiChengMoney(Long uid) {
+
+		return hongBaoV2Mapper.getTotalTiChengMoney(uid);
+	}
+
+	@Override
+	public int getTotalTiChengCount(Long uid) {
+		return hongBaoV2Mapper.getTotalTiChengCount(uid);
+	}
+
+	@Override
+	public BigDecimal getUnGetTiChengMoney(Long uid) {
+		return hongBaoV2Mapper.getUnGetTiChengMoney(uid);
+	}
+
+	@Override
+	public BigDecimal getTotalFanLiMoney(Long uid) {
+		BigDecimal money = hongBaoV2Mapper.getTotalFanLiMoney(uid);
+		return money == null ? new BigDecimal(0) : money;
+	}
+
+	@Override
+	public BigDecimal getUnRecievedFanLiMoney(Long uid) {
+		BigDecimal money = hongBaoV2Mapper.getUnRecievedFanLiMoney(uid);
+		return money == null ? new BigDecimal(0) : money;
+	}
+
+	@Override
+	public BigDecimal getUnRecievedMoneyWithCreateTime(Long uid, Date minDate, Date maxDate) {
+		BigDecimal money = hongBaoV2Mapper.getUnRecievedMoneyWithCreateTime(uid, minDate, maxDate);
+		if (money == null)
+			return new BigDecimal(0);
+		else
+			return money;
+	}
+
+	@Override
+	public BigDecimal getUnRecievedMoneyWithPreGetTime(Long uid, Date minDate, Date maxDate) {
+		BigDecimal money = hongBaoV2Mapper.getUnRecievedMoneyWithPreGetTime(uid, minDate, maxDate);
+		if (money == null)
+			return new BigDecimal(0);
+		else
+			return money;
+	}
 }

--
Gitblit v1.8.0