From 744594ef1a2f530fc3e86ea9dc48b62247f79420 Mon Sep 17 00:00:00 2001
From: admin <weikou2014>
Date: 星期二, 19 五月 2020 17:13:23 +0800
Subject: [PATCH] 饿了么绘图,添加口碑

---
 fanli/src/main/java/com/yeshi/fanli/util/rocketmq/consumer/order/OrderDividentsMessageListener.java |  104 +++++++++++++++++++++++++++++-----------------------
 1 files changed, 58 insertions(+), 46 deletions(-)

diff --git a/fanli/src/main/java/com/yeshi/fanli/util/rocketmq/consumer/order/OrderDividentsMessageListener.java b/fanli/src/main/java/com/yeshi/fanli/util/rocketmq/consumer/order/OrderDividentsMessageListener.java
index 3086e42..09d35b4 100644
--- a/fanli/src/main/java/com/yeshi/fanli/util/rocketmq/consumer/order/OrderDividentsMessageListener.java
+++ b/fanli/src/main/java/com/yeshi/fanli/util/rocketmq/consumer/order/OrderDividentsMessageListener.java
@@ -1,8 +1,6 @@
 package com.yeshi.fanli.util.rocketmq.consumer.order;
 
-import java.math.BigDecimal;
-import java.util.Calendar;
-import java.util.Date;
+import java.util.ArrayList;
 import java.util.List;
 
 import javax.annotation.Resource;
@@ -16,20 +14,25 @@
 import com.google.gson.Gson;
 import com.yeshi.fanli.dto.mq.order.OrderTopicTagEnum;
 import com.yeshi.fanli.dto.mq.order.body.OrderConfirmMQMsg;
+import com.yeshi.fanli.dto.mq.order.body.OrderMQMsg;
+import com.yeshi.fanli.dto.mq.order.body.OrderWeiQuanMQMsg;
 import com.yeshi.fanli.dto.mq.user.UserTopicTagEnum;
 import com.yeshi.fanli.dto.mq.user.body.UserForbiddenMQMsg;
+import com.yeshi.fanli.dto.order.UserTeamLevel;
+import com.yeshi.fanli.entity.bus.user.ThreeSale;
+import com.yeshi.fanli.entity.bus.user.vip.UserLevelEnum;
 import com.yeshi.fanli.entity.order.CommonOrder;
-import com.yeshi.fanli.entity.order.dividents.TeamDividentsSourceOrder;
-import com.yeshi.fanli.entity.taobao.TaoBaoWeiQuanOrder;
 import com.yeshi.fanli.exception.ParamsException;
 import com.yeshi.fanli.exception.money.TeamDividentsDebtException;
 import com.yeshi.fanli.exception.order.dividents.TeamDividentsSourceOrderException;
 import com.yeshi.fanli.log.LogHelper;
 import com.yeshi.fanli.service.inter.order.CommonOrderService;
-import com.yeshi.fanli.service.inter.order.dividents.TeamDividentsSourceOrderService;
+import com.yeshi.fanli.service.inter.user.invite.ThreeSaleSerivce;
 import com.yeshi.fanli.service.manger.order.TeamDividentsManager;
+import com.yeshi.fanli.service.manger.order.TeamDividentsSourceManager;
+import com.yeshi.fanli.service.manger.user.UserLevelManager;
 import com.yeshi.fanli.util.Constant;
-import com.yeshi.fanli.util.TimeUtil;
+import com.yeshi.fanli.util.order.CommonOrderUtil;
 import com.yeshi.fanli.util.rocketmq.MQTopicName;
 
 /**
@@ -41,13 +44,19 @@
 public class OrderDividentsMessageListener implements MessageListener {
 
 	@Resource
-	private TeamDividentsSourceOrderService teamDividentsSourceOrderService;
-
-	@Resource
 	private CommonOrderService commonOrderService;
 
 	@Resource
 	private TeamDividentsManager teamDividentsManager;
+
+	@Resource
+	private TeamDividentsSourceManager teamDividentsSourceManager;
+
+	@Resource
+	private ThreeSaleSerivce threeSaleSerivce;
+
+	@Resource
+	private UserLevelManager userLevelManager;
 
 	public OrderDividentsMessageListener() {
 
@@ -64,52 +73,55 @@
 				// 鏌ヨ涓婄骇绾㈠寘
 				UserForbiddenMQMsg dto = new Gson().fromJson(new String(message.getBody()), UserForbiddenMQMsg.class);
 				if (dto != null) {
-					teamDividentsSourceOrderService.invalidOrderByUid(dto.getUid(), "鐢ㄦ埛琚皝绂�");
+					teamDividentsSourceManager.invalidBySourceUid(dto.getUid(), "鐢ㄦ埛琚皝绂�");
 					return Action.CommitMessage;
 				}
 			}
 		} else if (MQTopicName.TOPIC_ORDER.name().equalsIgnoreCase(message.getTopic())) {
-			// 璁㈠崟纭鏀惰揣
-			if (tag.equalsIgnoreCase(OrderTopicTagEnum.orderConfirm.name())) {
-				// 鎻掑叆鍒嗙孩
-				OrderConfirmMQMsg dto = new Gson().fromJson(new String(message.getBody()), OrderConfirmMQMsg.class);
-				List<CommonOrder> commonOrderList = commonOrderService.listBySourceTypeAndOrderId(dto.getSourceType(),
-						dto.getOrderNo());
-				BigDecimal eincome = new BigDecimal(0);
-				Date settleTime = null;
-				for (CommonOrder order : commonOrderList) {
-					if (order.getState() == CommonOrder.STATE_JS)
-						eincome = eincome.add(order.geteIncome());
-					if (settleTime == null)
-						settleTime = order.getSettleTime();
-				}
+			if (tag.equalsIgnoreCase(OrderTopicTagEnum.orderStatistic.name())) {
 
-				Calendar calendar = Calendar.getInstance();
-				calendar.setTime(settleTime);
-				calendar.add(Calendar.MONTH, 1);
-				Date preSendTime = new Date(TimeUtil.convertToTimeTemp(
-						calendar.get(Calendar.YEAR) + "-" + (calendar.get(Calendar.MONTH) + 1) + "-25", "yyyy-M-dd"));
-
-				TeamDividentsSourceOrder sourceOrder = new TeamDividentsSourceOrder();
-				sourceOrder.setMoney(eincome);
-				sourceOrder.setOrderNo(dto.getOrderNo());
-				sourceOrder.setPreSendTime(preSendTime);
-				sourceOrder.setSourceType(dto.getSourceType());
-				sourceOrder.setState(TeamDividentsSourceOrder.STATE_CAN_SEND);
-				sourceOrder.setUid(dto.getSourceUid());
-				try {
-					teamDividentsSourceOrderService.addTeamDividentsSourceOrder(sourceOrder);
+				OrderMQMsg dto = new Gson().fromJson(new String(message.getBody()), OrderMQMsg.class);
+				if (dto == null || dto.getStaticticDate().getTime() < Constant.NEW_ORDER_FANLI_RULE_TIME)
 					return Action.CommitMessage;
-				} catch (ParamsException e) {
-					e.printStackTrace();
-				} catch (TeamDividentsSourceOrderException e) {
-					e.printStackTrace();
+
+				if (dto.isMiandan())// 鍏嶅崟鐨勫晢鍝佷笉鍙備笌鍒嗙孩
+					return Action.CommitMessage;
+
+				if (dto.getHandleType() == OrderMQMsg.HANDLE_TYPE_ADD) {
+					List<CommonOrder> commonOrderList = commonOrderService.listBySourceTypeAndOrderId(dto.getType(),
+							dto.getOrderId());
+
+					int state = CommonOrderUtil.getState(commonOrderList);
+					if (commonOrderList.size() > 0 && state != CommonOrder.STATE_SX) {
+						List<UserTeamLevel> bossList = new ArrayList<>();
+						List<ThreeSale> threeSalesList = threeSaleSerivce.getMyBossDeepList(dto.getUid(), 100);
+						if (threeSalesList != null)
+							for (ThreeSale ts : threeSalesList) {
+								UserLevelEnum level = userLevelManager.getUserLevel(ts.getBoss().getId());
+								bossList.add(new UserTeamLevel(ts.getBoss().getId(), level));
+							}
+						try {
+							teamDividentsSourceManager.addSource(commonOrderList, bossList);
+							return Action.CommitMessage;
+						} catch (TeamDividentsSourceOrderException e) {
+							if (e.getCode() == TeamDividentsSourceOrderException.CODE_EXIST) {
+								return Action.CommitMessage;
+							}
+						} catch (ParamsException e) {
+							e.printStackTrace();
+						}
+					}
+				} else {
+					teamDividentsSourceManager.updateOrderMoney(dto.getOrderId(), dto.getType());
 				}
 
+			} else if (tag.equalsIgnoreCase(OrderTopicTagEnum.orderConfirm.name())) {// 璁㈠崟纭鏀惰揣
+				OrderConfirmMQMsg dto = new Gson().fromJson(new String(message.getBody()), OrderConfirmMQMsg.class);
+				teamDividentsSourceManager.orderSettle(dto.getOrderNo(), dto.getSourceType());
 			} else if (tag.equalsIgnoreCase(OrderTopicTagEnum.taoBaoOrderWeiQuan.name())) {
-				TaoBaoWeiQuanOrder dto = new Gson().fromJson(new String(message.getBody()), TaoBaoWeiQuanOrder.class);
+				OrderWeiQuanMQMsg dto = new Gson().fromJson(new String(message.getBody()), OrderWeiQuanMQMsg.class);
 				try {
-					teamDividentsManager.weiQuan(dto.getOrderId(), Constant.SOURCE_TYPE_TAOBAO);
+					teamDividentsManager.weiQuan(dto.getOrderNo(), dto.getSourceType());
 					return Action.CommitMessage;
 				} catch (TeamDividentsDebtException e) {
 					e.printStackTrace();

--
Gitblit v1.8.0