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 |  176 ++++++++++++++++++++++++++++++++--------------------------
 1 files changed, 98 insertions(+), 78 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 13585aa..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,67 +123,88 @@
     @Transactional
     void handleExtensionOrder(ShopOrder order) {
         //判读客户是否存在上级,存在则产生上级的收益
-        BizUser bizUser = bizUserService.findByOpenId(order.getUserId());
-        if(StringUtils.isNotBlank(bizUser.getParentOpenId())){//存在上级
-
-            LogUtil.debug("处理分销订单userOpid={}",bizUser.getOpenId());
-            //判断是否重复生成
-            QueryWrapper queryWrapper=new QueryWrapper();
-            queryWrapper.eq("order_id",order.getId());
-            Integer orderCount = shopSalesmanOrderDao.selectCount(queryWrapper);
-            if(orderCount==0){
-                ShopSalesmanOrder salesmanOrder=new ShopSalesmanOrder();
-                salesmanOrder.setCompanyId(order.getCompanyId());
-                salesmanOrder.setCreateBy(MatrixConstance.SYSTEM_USER);
-                salesmanOrder.setUpdateBy(MatrixConstance.SYSTEM_USER);
-                salesmanOrder.setCreateTime(new Date());
-                salesmanOrder.setUpdateTime(new Date());
-                salesmanOrder.setOrderId(Long.parseLong(order.getId()+""));
-                salesmanOrder.setUserId(order.getUserId());
-                salesmanOrder.setSalesUserId(bizUser.getParentOpenId());
-                salesmanOrder.setRevenueType(ShopSalesmanOrder.REVENUE_TYPE_SALES);
-                salesmanOrder.setOrderStatus(ShopSalesmanOrder.STATUS_DJS);
-                Double salesAmount=0D;
-                Double selfAmount=0D;
-                Double invitationAmount=0D;
-                Double orderTotal=0D;
-                Double zk=1D;
-
-                BizUser salesMan=bizUserService.findByOpenId(bizUser.getParentOpenId());
-                BizUser invitationMan=null;
-                ShopSalesmanOrder invitationOrder=null;
-                boolean hasInvitationMan=StringUtils.isNotBlank(salesMan.getParentOpenId());
-                
-                //判断推广员是否还存在上级,存在则计算邀请收益
-                if(hasInvitationMan){
-                    invitationMan=bizUserService.findByOpenId(salesMan.getParentOpenId());
-                    invitationOrder=new ShopSalesmanOrder();
-                    BeanUtils.copyProperties(salesmanOrder,invitationOrder);
-                    invitationOrder.setSalesUserId(invitationMan.getOpenId());
-                    invitationOrder.setRevenueType(ShopSalesmanOrder.REVENUE_TYPE_INVITATION);
+        SysVipInfo sysVipInfo = sysVipInfoService.findById(order.getUserId());
+        LogUtil.debug("处理分销订单userOpid={}",sysVipInfo.getOpenId());
+        //判断是否重复生成
+        QueryWrapper queryWrapper=new QueryWrapper();
+        queryWrapper.eq("order_id",order.getId());
+        Integer orderCount = shopSalesmanOrderDao.selectCount(queryWrapper);
+        if(orderCount==0){
+            ShopSalesmanOrder salesmanOrder=new ShopSalesmanOrder();
+            salesmanOrder.setCompanyId(order.getCompanyId());
+            salesmanOrder.setCreateBy(MatrixConstance.SYSTEM_USER);
+            salesmanOrder.setUpdateBy(MatrixConstance.SYSTEM_USER);
+            salesmanOrder.setCreateTime(new Date());
+            salesmanOrder.setUpdateTime(new Date());
+            salesmanOrder.setOrderId(Long.parseLong(order.getId()+""));
+            salesmanOrder.setUserId(order.getUserId());
+            salesmanOrder.setRevenueType(ShopSalesmanOrder.REVENUE_TYPE_SALES);
+            salesmanOrder.setOrderStatus(ShopSalesmanOrder.STATUS_DJS);
+        	Double selfAmount=0D;
+            Double zk=1D;
+            //分销订单总额
+            Double orderTotal=0D;
+            for (ShopOrderDetails item:order.getDetails() ){
+                if(item.getShopProduct().getAbleSales()==ShopProduct.ABLE_SALES){
+                	orderTotal+=item.getTotalPrice().doubleValue();
                 }
-
-                //收益计算
+            }
+            //自购返佣
+            Integer isSales = sysVipInfo.getIsSales();
+            if(SysVipInfo.IS_SALES == isSales){
                 for (ShopOrderDetails item:order.getDetails() ){
-                    if(StringUtils.isNotBlank(item.getShopProduct().getAttrValues())
-                            && item.getShopProduct().getAbleSales()==ShopProduct.ABLE_SALES){
+                    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(salesMan.getSalesmanGrade());
+                        ShopSalesmanGrade shopSalesmanGrade = shopSalesmanGradeDao.selectById(sysVipInfo.getSalesmanGrade());
                         if(ObjectUtil.isNotEmpty(zgfy)) {
                             //获取商品的自购返佣价格,如果没有设置,在去获取当前推广人的等级的自购返佣比例
-                        	if(StrUtil.isNotEmpty(zgfy.getParamValue()) && 
-                        			FenxiaoSettingConstant.FX_ZGFY_YES.equals(zgfy.getParamValue())) {
-                        		if(item.getShopSku().getSelfPrice() == null
+                            if(StrUtil.isNotEmpty(zgfy.getParamValue()) &&
+                                    FenxiaoSettingConstant.FX_ZGFY_YES.equals(zgfy.getParamValue())) {
+                                if(item.getShopSku().getSelfPrice() == null
                                         ||item.getShopSku().getSealesPrice().doubleValue() == 0){
                                     selfAmount+=item.getTotalPrice().doubleValue()*(shopSalesmanGrade.getSelfCommission()/100);
-                        		}else {
-                        			//按产品设置的自购返佣金额计算
-                        			selfAmount+=item.getShopSku().getSelfPrice().doubleValue()*item.getCount();
-                        		}
-                        	}
+                                }else {
+                                    //按产品设置的自购返佣金额计算
+                                    selfAmount+=item.getShopSku().getSelfPrice().doubleValue()*item.getCount();
+                                }
+                            }
                         }
+                    }
+                }
+                //自购返佣记录
+                if(selfAmount > 0) {
+                    //整体的优惠金额折算成折扣,* 佣金
+                    zk=order.getOrderMoney().doubleValue()/orderTotal;
+                    selfAmount=selfAmount*zk;
+                    salesmanOrder.setAmount(selfAmount);
+                    salesmanOrder.setSalesUserId(order.getUserId());
+                    shopSalesmanOrderDao.insert(salesmanOrder);
+                }
+            }
+
+            //存在上级
+            if(sysVipInfo.getRecommendId()!=null) {
+            	SysVipInfo salesMan=sysVipInfoService.findById(sysVipInfo.getRecommendId());
+                Double salesAmount=0D;
+                Double invitationAmount=0D;
+            	SysVipInfo invitationMan=null;
+            	ShopSalesmanOrder invitationOrder=null;
+            	boolean hasInvitationMan=salesMan.getRecommendId()!=null;
+            	//判断推广员是否还存在上级,存在则计算邀请收益
+            	if(hasInvitationMan){
+            		invitationMan=sysVipInfoService.findById(salesMan.getRecommendId());
+            		invitationOrder=new ShopSalesmanOrder();
+            		BeanUtils.copyProperties(salesmanOrder,invitationOrder);
+            		invitationOrder.setSalesUserId(invitationMan.getId());
+            		invitationOrder.setRevenueType(ShopSalesmanOrder.REVENUE_TYPE_INVITATION);
+            	}
+            	//收益计算
+                for (ShopOrderDetails item:order.getDetails() ){
+                    if(item.getShopProduct().getAbleSales()==ShopProduct.ABLE_SALES){
+                        //按分销等级计算
+                        ShopSalesmanGrade shopSalesmanGrade = shopSalesmanGradeDao.selectById(salesMan.getSalesmanGrade());
                         //推广提成,按分销等级计算或者按产品设置的推广金额计算
                         if(item.getShopSku().getSealesPrice()==null
                                 ||item.getShopSku().getSealesPrice().doubleValue()==0){
@@ -193,25 +224,16 @@
                             	invitationAmount+=item.getShopSku().getInvitationPrice().doubleValue()*item.getCount();
                             }
                         }
-                        
-                        orderTotal+=item.getTotalPrice().doubleValue();
                     }
-                }
-                //自购返佣记录
-                if(selfAmount > 0) {
-                	//整体的优惠金额折算成折扣,* 佣金
-                    zk=order.getOrderMoney().doubleValue()/orderTotal;
-                    selfAmount=selfAmount*zk;
-                    salesmanOrder.setAmount(selfAmount);
-                    shopSalesmanOrderDao.insert(salesmanOrder);
                 }
                 //推广提成记录
                 if(salesAmount>0){
-	                //整体的优惠金额折算成折扣,* 佣金
-	                zk=order.getOrderMoney().doubleValue()/orderTotal;
-	                salesAmount=salesAmount*zk;
-	                salesmanOrder.setAmount(salesAmount);
-	                shopSalesmanOrderDao.insert(salesmanOrder);
+                    //整体的优惠金额折算成折扣,* 佣金
+                    zk=order.getOrderMoney().doubleValue()/orderTotal;
+                    salesAmount=salesAmount*zk;
+                    salesmanOrder.setAmount(salesAmount);
+                    salesmanOrder.setSalesUserId(sysVipInfo.getRecommendId());
+                    shopSalesmanOrderDao.insert(salesmanOrder);
                 }
                 //邀请提成记录
                 if(invitationAmount > 0) {
@@ -221,12 +243,10 @@
                     shopSalesmanOrderDao.insert(invitationOrder);
                 } 
             }else{
-                LogUtil.debug("重复订单id={}",order.getId());
+                LogUtil.debug("不存在父级userOpid={}",sysVipInfo.getOpenId());
             }
         }else{
-            LogUtil.debug("不存在父级userOpid={}",bizUser.getOpenId());
+            LogUtil.debug("重复订单id={}",order.getId());
         }
-
-
     }
 }

--
Gitblit v1.9.1