From bbe0a2fd03063316e50cf141986bda984599bbda Mon Sep 17 00:00:00 2001
From: 935090232@qq.com <ak473600000>
Date: Tue, 22 Feb 2022 23:41:42 +0800
Subject: [PATCH] Merge branch 'developer'

---
 zq-erp/src/main/java/com/matrix/system/shopXcx/mqTask/SalesOrderTask.java |   52 +++++++++++++++++++++++++++++++---------------------
 1 files changed, 31 insertions(+), 21 deletions(-)

diff --git a/zq-erp/src/main/java/com/matrix/system/shopXcx/mqTask/SalesOrderTask.java b/zq-erp/src/main/java/com/matrix/system/shopXcx/mqTask/SalesOrderTask.java
index 43ec960..3383a03 100644
--- a/zq-erp/src/main/java/com/matrix/system/shopXcx/mqTask/SalesOrderTask.java
+++ b/zq-erp/src/main/java/com/matrix/system/shopXcx/mqTask/SalesOrderTask.java
@@ -4,11 +4,9 @@
 import cn.hutool.core.util.ObjectUtil;
 import cn.hutool.core.util.StrUtil;
 import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
-import com.matrix.biz.bean.BizUser;
-import com.matrix.biz.service.BizUserService;
+import com.matrix.component.asyncmessage.MessageHandler;
 import com.matrix.core.constance.MatrixConstance;
 import com.matrix.core.tools.LogUtil;
-import com.matrix.core.tools.StringUtils;
 import com.matrix.system.common.bean.BusParameterSettings;
 import com.matrix.system.common.dao.BusParameterSettingsDao;
 import com.matrix.system.fenxiao.constant.FenxiaoSettingConstant;
@@ -16,12 +14,14 @@
 import com.matrix.system.fenxiao.dao.ShopSalesmanOrderDao;
 import com.matrix.system.fenxiao.entity.ShopSalesmanGrade;
 import com.matrix.system.fenxiao.entity.ShopSalesmanOrder;
+import com.matrix.system.hive.bean.SysVipInfo;
 import com.matrix.system.hive.dao.SysOrderDao;
 import com.matrix.system.hive.dao.SysOrderItemDao;
 import com.matrix.system.hive.dao.SysVipInfoDao;
 import com.matrix.system.hive.service.CodeService;
 import com.matrix.system.hive.service.ShoppingGoodsService;
 import com.matrix.system.hive.service.SysOrderService;
+import com.matrix.system.hive.service.SysVipInfoService;
 import com.matrix.system.shopXcx.bean.ShopOrder;
 import com.matrix.system.shopXcx.bean.ShopOrderDetails;
 import com.matrix.system.shopXcx.bean.ShopProduct;
@@ -38,12 +38,13 @@
 import java.io.IOException;
 import java.util.Date;
 import java.util.List;
+import java.util.Map;
 
 /**
  * 分销订单创建
  */
 @Component
-public class SalesOrderTask implements DeliverCallback {
+public class SalesOrderTask implements MessageHandler {
 
 
     @Autowired
@@ -52,7 +53,7 @@
     ShopOrderDetailsDao shopOrderDetailsDao;
 
     @Autowired
-    BizUserService bizUserService;
+    SysVipInfoService sysVipInfoService;
 
 
     @Autowired
@@ -90,11 +91,20 @@
     private ShopSalesmanGradeDao shopSalesmanGradeDao;
 
 
+    @Override
+    public String getName() {
+        return "分销订单创建事件";
+    }
 
     @Override
-    public void handle(String consumerTag, Delivery message) throws IOException {
+    public String getRouteKey() {
+        return AsyncMessageRouting.CREATE_ORDER;
+    }
 
-        String orderId = new String(message.getBody(), "UTF-8");
+    @Override
+    public void handle(Map<String,Object> param){
+
+        String orderId = (String) param.get("orderId");
         LogUtil.debug("收到分销订单任务orderId={}", orderId);
         //获取订单信息
         ShopOrder order = shopOrderDao.selectById(Integer.valueOf(orderId));
@@ -113,8 +123,8 @@
     @Transactional
     void handleExtensionOrder(ShopOrder order) {
         //判读客户是否存在上级,存在则产生上级的收益
-        BizUser bizUser = bizUserService.findByOpenId(order.getUserId());
-        LogUtil.debug("处理分销订单userOpid={}",bizUser.getOpenId());
+        SysVipInfo sysVipInfo = sysVipInfoService.findById(order.getUserId());
+        LogUtil.debug("处理分销订单userOpid={}",sysVipInfo.getOpenId());
         //判断是否重复生成
         QueryWrapper queryWrapper=new QueryWrapper();
         queryWrapper.eq("order_id",order.getId());
@@ -140,14 +150,14 @@
                 }
             }
             //自购返佣
-            Integer isSales = bizUser.getIsSales();
-            if(BizUser.IS_SALES == isSales){
+            Integer isSales = sysVipInfo.getIsSales();
+            if(SysVipInfo.IS_SALES == isSales){
                 for (ShopOrderDetails item:order.getDetails() ){
                     if(item.getShopProduct().getAbleSales()==ShopProduct.ABLE_SALES){
                         //分销规则是否开启自购返佣
-                        BusParameterSettings zgfy = parameterSettingsDao.selectCompanyParamByCode(FenxiaoSettingConstant.FX_ZGFY, bizUser.getCompanyId());
+                        BusParameterSettings zgfy = parameterSettingsDao.selectCompanyParamByCode(FenxiaoSettingConstant.FX_ZGFY, sysVipInfo.getCompanyId());
                         //按分销等级计算
-                        ShopSalesmanGrade shopSalesmanGrade = shopSalesmanGradeDao.selectById(bizUser.getSalesmanGrade());
+                        ShopSalesmanGrade shopSalesmanGrade = shopSalesmanGradeDao.selectById(sysVipInfo.getSalesmanGrade());
                         if(ObjectUtil.isNotEmpty(zgfy)) {
                             //获取商品的自购返佣价格,如果没有设置,在去获取当前推广人的等级的自购返佣比例
                             if(StrUtil.isNotEmpty(zgfy.getParamValue()) &&
@@ -175,19 +185,19 @@
             }
 
             //存在上级
-            if(StringUtils.isNotBlank(bizUser.getParentOpenId())) {
-            	BizUser salesMan=bizUserService.findByOpenId(bizUser.getParentOpenId());
+            if(sysVipInfo.getRecommendId()!=null) {
+            	SysVipInfo salesMan=sysVipInfoService.findById(sysVipInfo.getRecommendId());
                 Double salesAmount=0D;
                 Double invitationAmount=0D;
-            	BizUser invitationMan=null;
+            	SysVipInfo invitationMan=null;
             	ShopSalesmanOrder invitationOrder=null;
-            	boolean hasInvitationMan=StringUtils.isNotBlank(salesMan.getParentOpenId());
+            	boolean hasInvitationMan=salesMan.getRecommendId()!=null;
             	//判断推广员是否还存在上级,存在则计算邀请收益
             	if(hasInvitationMan){
-            		invitationMan=bizUserService.findByOpenId(salesMan.getParentOpenId());
+            		invitationMan=sysVipInfoService.findById(salesMan.getRecommendId());
             		invitationOrder=new ShopSalesmanOrder();
             		BeanUtils.copyProperties(salesmanOrder,invitationOrder);
-            		invitationOrder.setSalesUserId(invitationMan.getOpenId());
+            		invitationOrder.setSalesUserId(invitationMan.getId());
             		invitationOrder.setRevenueType(ShopSalesmanOrder.REVENUE_TYPE_INVITATION);
             	}
             	//收益计算
@@ -222,7 +232,7 @@
                     zk=order.getOrderMoney().doubleValue()/orderTotal;
                     salesAmount=salesAmount*zk;
                     salesmanOrder.setAmount(salesAmount);
-                    salesmanOrder.setSalesUserId(bizUser.getParentOpenId());
+                    salesmanOrder.setSalesUserId(sysVipInfo.getRecommendId());
                     shopSalesmanOrderDao.insert(salesmanOrder);
                 }
                 //邀请提成记录
@@ -233,7 +243,7 @@
                     shopSalesmanOrderDao.insert(invitationOrder);
                 } 
             }else{
-                LogUtil.debug("不存在父级userOpid={}",bizUser.getOpenId());
+                LogUtil.debug("不存在父级userOpid={}",sysVipInfo.getOpenId());
             }
         }else{
             LogUtil.debug("重复订单id={}",order.getId());

--
Gitblit v1.9.1