From 24a8d17e007545f7426c48352109aa1a9c6587ee Mon Sep 17 00:00:00 2001
From: admin <weikou2014>
Date: 星期三, 06 五月 2020 12:02:09 +0800
Subject: [PATCH] IOS上线隐藏我的界面的banner与超级会员升级信息

---
 fanli/src/main/java/com/yeshi/fanli/service/impl/order/HongBaoV2ServiceImpl.java |  126 ++++++++++++++++++++---------------------
 1 files changed, 61 insertions(+), 65 deletions(-)

diff --git a/fanli/src/main/java/com/yeshi/fanli/service/impl/order/HongBaoV2ServiceImpl.java b/fanli/src/main/java/com/yeshi/fanli/service/impl/order/HongBaoV2ServiceImpl.java
index 71c0172..7303b65 100644
--- a/fanli/src/main/java/com/yeshi/fanli/service/impl/order/HongBaoV2ServiceImpl.java
+++ b/fanli/src/main/java/com/yeshi/fanli/service/impl/order/HongBaoV2ServiceImpl.java
@@ -26,14 +26,17 @@
 import com.yeshi.fanli.dao.mybatis.taobao.TaoBaoWeiQuanOrderMapper;
 import com.yeshi.fanli.dto.HongBao;
 import com.yeshi.fanli.dto.HongBaoDTO;
+import com.yeshi.fanli.dto.order.HongBaoAddResult;
 import com.yeshi.fanli.entity.bus.user.HongBaoV2;
 import com.yeshi.fanli.entity.bus.user.ThreeSale;
 import com.yeshi.fanli.entity.bus.user.UserExtraTaoBaoInfo;
 import com.yeshi.fanli.entity.bus.user.UserInfo;
+import com.yeshi.fanli.entity.bus.user.vip.UserLevelEnum;
 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.order.ShareGoodsActivityOrder;
+import com.yeshi.fanli.entity.system.ConfigKeyEnum;
 import com.yeshi.fanli.entity.taobao.TaoBaoOrder;
 import com.yeshi.fanli.exception.order.HongBaoException;
 import com.yeshi.fanli.exception.order.ShareGoodsActivityOrderException;
@@ -52,7 +55,6 @@
 import com.yeshi.fanli.service.inter.user.UserSystemCouponService;
 import com.yeshi.fanli.service.inter.user.invite.ThreeSaleSerivce;
 import com.yeshi.fanli.service.inter.user.tb.UserExtraTaoBaoInfoService;
-import com.yeshi.fanli.service.inter.user.vip.UserVIPInfoService;
 import com.yeshi.fanli.util.Constant;
 import com.yeshi.fanli.util.MoneyBigDecimalUtil;
 import com.yeshi.fanli.util.StringUtil;
@@ -147,13 +149,15 @@
 		return hongBaoV2Mapper.selectByPrimaryKey(id);
 	}
 
-	@Transactional
+	@Transactional(rollbackFor = Exception.class)
 	@Override
-	public int addHongBao(List<CommonOrder> commonOrderList, int type) throws HongBaoException, UserAccountException {
+	public HongBaoAddResult addHongBao(List<CommonOrder> commonOrderList, int type)
+			throws HongBaoException, UserAccountException {
 		Set<Integer> stateSet = new HashSet<>();// 璁㈠崟鐘舵�丼et
 		if (commonOrderList != null && commonOrderList.size() > 0) {
 			int orderType = commonOrderList.get(0).getSourceType();
 
+			boolean miandan = false;
 			Map<Integer, HongBaoOrder> notificationMap = new HashMap<>();
 			int goodsCount = 0;
 			boolean hasAdd = false;
@@ -165,7 +169,7 @@
 					throw new HongBaoException(1, "璁㈠崟淇℃伅涓嶅畬鏁�");
 				HongBaoOrder hongBaoOrder = hongBaoOrderMapper.selectByCommonOrderId(commonOrder.getId());
 				if (hongBaoOrder == null) {
-					saveHongBao(commonOrder, type, notificationMap);
+					miandan = saveHongBao(commonOrder, type, notificationMap);
 					hasAdd = true;
 				} else {
 					boolean update = updateHongBao(hongBaoOrder, commonOrder, type, notificationMap);
@@ -190,77 +194,52 @@
 					switch (t) {
 					case HongBaoV2.TYPE_ZIGOU:
 						userOrderMsgNotificationService.orderFanLiStatistic(uid, orderId, orderType,
-								commonOrder.getPayment(), money, goodsCount, state);
+								commonOrder.getPayment(), money, goodsCount, commonOrder.getState(),
+								commonOrder.getThirdCreateTime());
+
 						break;
 					case HongBaoV2.TYPE_SHARE_GOODS:
 
 						userOrderMsgNotificationService.orderShareStatistic(uid, orderId, orderType,
-								commonOrder.getPayment(), money, goodsCount, state);
+								commonOrder.getPayment(), money, goodsCount, commonOrder.getState(),
+								commonOrder.getThirdCreateTime());
+
 						break;
 					case HongBaoV2.TYPE_YIJI:
-
 						userOrderMsgNotificationService.orderInviteStatistic(uid, orderId, orderType,
-								commonOrder.getPayment(), money, goodsCount, state);
+								commonOrder.getPayment(), money, new BigDecimal(0), goodsCount, commonOrder.getState(),
+								commonOrder.getThirdCreateTime());
 						break;
 					case HongBaoV2.TYPE_ERJI:
-
 						userOrderMsgNotificationService.orderInviteStatistic(uid, orderId, orderType,
-								commonOrder.getPayment(), money, goodsCount, state);
+								commonOrder.getPayment(), money, new BigDecimal(0), goodsCount, commonOrder.getState(),
+								commonOrder.getThirdCreateTime());
 						break;
 
 					case HongBaoV2.TYPE_SHARE_YIJI:
-						userOrderMsgNotificationService.orderShareFirstLevelStatistic(uid, orderId, orderType,
-								commonOrder.getPayment(), money, goodsCount, state, notify.getBeizhu());
-						break;
-					}
-				}
-			}
+						userOrderMsgNotificationService.orderInviteStatistic(uid, orderId, orderType,
+								commonOrder.getPayment(), money, new BigDecimal(0), goodsCount, commonOrder.getState(),
+								commonOrder.getThirdCreateTime());
 
-			// 娣诲姞鏂扮増鏈�氱煡
-
-			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, orderType,
-								commonOrder.getPayment(), money, state);
+					case HongBaoV2.TYPE_SHARE_ERJI:
+						userOrderMsgNotificationService.orderInviteStatistic(uid, orderId, orderType,
+								commonOrder.getPayment(), money, new BigDecimal(0), goodsCount, commonOrder.getState(),
+								commonOrder.getThirdCreateTime());
 						break;
-					case HongBaoV2.TYPE_SHARE_GOODS:
-						userOrderMsgNotificationService.orderShareStateChanged(uid, orderId, orderType,
-								commonOrder.getPayment(), money, state);
-						break;
-					case HongBaoV2.TYPE_YIJI:
-						userOrderMsgNotificationService.orderInviteStateChanged(uid, orderId, orderType,
-								commonOrder.getPayment(), money, state);
-						break;
-					case HongBaoV2.TYPE_ERJI:
-						userOrderMsgNotificationService.orderInviteStateChanged(uid, orderId, orderType,
-								commonOrder.getPayment(), money, state);
-						break;
-					case HongBaoV2.TYPE_SHARE_YIJI:
-						userOrderMsgNotificationService.orderShareFirstLevelStateChanged(uid, orderId, orderType,
-								commonOrder.getPayment(), money, state);
 					}
 				}
 			}
 
 			int resultCode = 0;
 			if (hasAdd && hasUpdate)
-				return 12;
+				return new HongBaoAddResult(HongBaoAddResult.CODE_ADD_AND_UPDATE, miandan);
 			else if (hasAdd)
-				return 1;
+				return new HongBaoAddResult(HongBaoAddResult.CODE_ADD, miandan);
 			else if (hasUpdate)
-				return 2;
-			return resultCode;
+				return new HongBaoAddResult(HongBaoAddResult.CODE_UPDATE, miandan);
+			return new HongBaoAddResult(resultCode, miandan);
 		}
-		return 0;
+		return new HongBaoAddResult(0, false);
 	}
 
 	private int getOrderState(Set<Integer> states) {
@@ -277,7 +256,7 @@
 		return CommonOrder.STATE_SX;
 	}
 
-	@Transactional
+	@Transactional(rollbackFor = Exception.class)
 	private boolean updateHongBao(HongBaoOrder hongBaoOrder, CommonOrder commonOrder, int type,
 			Map<Integer, HongBaoOrder> notificationMap) throws HongBaoException, UserAccountException {
 		System.out.println(commonOrder.getOrderNo());
@@ -290,7 +269,8 @@
 			return false;
 
 		if (type == HongBaoV2.TYPE_ZIGOU) {// 鑾峰彇鑷喘鐨勮繑鍒╂瘮渚�
-			BigDecimal fanliRate = hongBaoManageService.getFanLiRate(commonOrder.getCreateTime().getTime());
+			BigDecimal fanliRate = hongBaoManageService.getFanLiRate(UserLevelEnum.daRen,
+					commonOrder.getCreateTime().getTime());
 			// 鍏嶅崟澶勭悊
 			boolean mianDan = false;
 			List<CommonOrder> orderList = commonOrderService.listBySourceTypeAndOrderId(Constant.SOURCE_TYPE_TAOBAO,
@@ -544,7 +524,8 @@
 					&& commonOrder.getSourcePosition().equalsIgnoreCase(TaoBaoConstant.TAOBAO_TLJ_RELATION_PID_DEFAULT))
 				fanliRate = hongBaoManageService.getTLJShareRate(commonOrder.getCreateTime().getTime());
 			else
-				fanliRate = hongBaoManageService.getShareRate(commonOrder.getCreateTime().getTime());
+				fanliRate = hongBaoManageService.getShareRate(UserLevelEnum.daRen,
+						commonOrder.getCreateTime().getTime());
 
 			List<ShareGoodsActivityOrder> list = shareGoodsActivityOrderService
 					.listByOrderIdAndUid(commonOrder.getUserInfo().getId(), commonOrder.getOrderNo());
@@ -664,11 +645,12 @@
 		return true;
 	}
 
-	@Transactional
-	private void saveHongBao(CommonOrder commonOrder, int type, Map<Integer, HongBaoOrder> notificationMap)
+	@Transactional(rollbackFor = Exception.class)
+	private boolean saveHongBao(CommonOrder commonOrder, int type, Map<Integer, HongBaoOrder> notificationMap)
 			throws HongBaoException, UserAccountException {
 		if (type == HongBaoV2.TYPE_ZIGOU) {// 鑾峰彇鑷喘鐨勮繑鍒╂瘮渚�
-			BigDecimal fanliRate = hongBaoManageService.getFanLiRate(commonOrder.getCreateTime().getTime());
+			BigDecimal fanliRate = hongBaoManageService.getFanLiRate(UserLevelEnum.daRen,
+					commonOrder.getCreateTime().getTime());
 			// 鏌ヨ鏄惁鏈夊厤鍗曡鍒�
 			BigDecimal mianDanMoney = null;
 			if (commonOrder.getState() == CommonOrder.STATE_JS || commonOrder.getState() == CommonOrder.STATE_FK) {
@@ -769,7 +751,7 @@
 				BigDecimal firstRate = hongBaoManageService
 						.getFirstInviteRate(boss.getRank() == null ? 0 : boss.getRank());
 				if (firstRate.compareTo(new BigDecimal(0)) <= 0)
-					return;
+					return mianDanMoney != null;
 				HongBaoV2 firstHongbao = new HongBaoV2();
 				firstHongbao.setUserInfo(boss);
 				firstHongbao.setUrank(boss.getRank());
@@ -795,7 +777,7 @@
 				}
 				// 杩斿埄涓�0鐨勪笉閫氱煡
 				if (firstHongbao.getMoney() == null || firstHongbao.getMoney().compareTo(new BigDecimal(0)) <= 0)
-					return;
+					return mianDanMoney != null;
 
 				hongBaoV2Mapper.insertSelective(firstHongbao);
 				// 鐢ㄦ埛閫氱煡
@@ -822,7 +804,7 @@
 					BigDecimal secondRate = hongBaoManageService
 							.getSecondInviteRate(boss.getRank() == null ? 0 : boss.getRank());
 					if (secondRate.compareTo(new BigDecimal(0)) <= 0)
-						return;
+						return mianDanMoney != null;
 					HongBaoV2 secondHongbao = new HongBaoV2();
 					secondHongbao.setUserInfo(boss);
 					secondHongbao.setUrank(boss.getRank());
@@ -848,7 +830,7 @@
 
 					// 杩斿埄涓�0鐨勪笉缁熻
 					if (secondHongbao.getMoney() == null || secondHongbao.getMoney().compareTo(new BigDecimal(0)) <= 0)
-						return;
+						return mianDanMoney != null;
 
 					hongBaoV2Mapper.insertSelective(secondHongbao);
 
@@ -872,21 +854,22 @@
 				}
 
 			}
-
+			return mianDanMoney != null;
 		} else if (type == HongBaoV2.TYPE_SHARE_GOODS) {
 			// 鍒嗕韩璧氫笉鍔犲叆澶辨晥鐨勮鍗�
 			if (commonOrder.getState() == CommonOrder.STATE_SX || commonOrder.getState() == CommonOrder.STATE_WQ)
-				return;
+				return false;
 			// 鍒嗕韩璧�
 			BigDecimal shareRate = null;
 			if (commonOrder.getSourceType() == Constant.SOURCE_TYPE_TAOBAO
 					&& commonOrder.getSourcePosition().equalsIgnoreCase(TaoBaoConstant.TAOBAO_TLJ_RELATION_PID_DEFAULT))// 鏉ヨ嚜浜庢窐绀奸噾鐨勫垎浜�
 				shareRate = hongBaoManageService.getTLJShareRate(commonOrder.getCreateTime().getTime());
 			else
-				shareRate = hongBaoManageService.getShareRate(commonOrder.getCreateTime().getTime());
+				shareRate = hongBaoManageService.getShareRate(UserLevelEnum.daRen,
+						commonOrder.getCreateTime().getTime());
 
 			// 鍒ゆ柇璁㈠崟鍒嗕韩娲诲姩鏄惁寮�鍚�
-			if ("1".equalsIgnoreCase(configService.get("share_goods_activity_open"))) {
+			if ("1".equalsIgnoreCase(configService.get(ConfigKeyEnum.shareGoodsActivityOpen.getKey()))) {
 				// 娌℃湁璁㈠崟锛屽苟涓旀槸娓犻亾ID鏉ョ殑锛屽苟涓�
 				UserExtraTaoBaoInfo taoBaoExtraInfo = userExtraTaoBaoInfoService
 						.getByUid(commonOrder.getUserInfo().getId());
@@ -1041,6 +1024,8 @@
 			}
 		} else
 			throw new HongBaoException(2, "type閿欒");
+
+		return false;
 	}
 
 	@Override
@@ -1178,4 +1163,15 @@
 		return hongBaoV2Mapper.listByIds(idList);
 	}
 
+	@Override
+	public List<HongBaoDTO> listByOrderTradeId(String tradeId) {
+		return hongBaoV2Mapper.listByOrderTradeId(tradeId);
+	}
+
+	@Override
+	public Integer getDirectBossUrankByPid(Long pid) {
+		return hongBaoV2Mapper.getDirectBossUrankByPid(pid);
+	}
+
+	
 }

--
Gitblit v1.8.0