From beeda8df0023376dbb2021148a021731dc4aedb0 Mon Sep 17 00:00:00 2001
From: jiangqs <jiangqs>
Date: 星期日, 06 八月 2023 11:29:10 +0800
Subject: [PATCH] Merge branch 'master' of ssh://sinata.cn:20202/java/HongRuiTang into master

---
 ruoyi-modules/ruoyi-order/src/main/java/com/ruoyi/order/service/impl/account/ProfitSharingServiceImpl.java |   34 ++++++++++++++++++++++++++++++++++
 1 files changed, 34 insertions(+), 0 deletions(-)

diff --git a/ruoyi-modules/ruoyi-order/src/main/java/com/ruoyi/order/service/impl/account/ProfitSharingServiceImpl.java b/ruoyi-modules/ruoyi-order/src/main/java/com/ruoyi/order/service/impl/account/ProfitSharingServiceImpl.java
index bd2bd4a..799915d 100644
--- a/ruoyi-modules/ruoyi-order/src/main/java/com/ruoyi/order/service/impl/account/ProfitSharingServiceImpl.java
+++ b/ruoyi-modules/ruoyi-order/src/main/java/com/ruoyi/order/service/impl/account/ProfitSharingServiceImpl.java
@@ -1,10 +1,17 @@
 package com.ruoyi.order.service.impl.account;
 
+import com.github.binarywang.wxpay.bean.ecommerce.ProfitSharingResult;
+import com.ruoyi.common.core.utils.uuid.IdUtils;
 import com.ruoyi.order.domain.pojo.account.ProfitSharing;
 import com.ruoyi.order.mapper.account.ProfitSharingMapper;
 import com.ruoyi.order.service.account.ProfitSharingService;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
 import org.springframework.stereotype.Service;
+
+import java.math.BigDecimal;
+import java.math.RoundingMode;
+import java.util.Date;
+import java.util.List;
 
 /**
  * <p>
@@ -17,4 +24,31 @@
 @Service
 public class ProfitSharingServiceImpl extends ServiceImpl<ProfitSharingMapper, ProfitSharing> implements ProfitSharingService {
 
+    @Override
+    public void saveProfitSharing(Long shopId, String orderId, BigDecimal orderMoney, ProfitSharingResult result) {
+        ProfitSharing profitSharing = new ProfitSharing();
+        profitSharing.setShareId(result.getOutOrderNo());
+        profitSharing.setDelFlag(0);
+        profitSharing.setShareStatus("FINISHED".equals(result.getStatus()) ? 2 : 1);
+        profitSharing.setShopId(shopId);
+        profitSharing.setOrderId(orderId);
+        profitSharing.setOrderMoney(orderMoney);
+
+        List<ProfitSharingResult.Receiver> receivers = result.getReceivers();
+        if(null != receivers && !receivers.isEmpty()){
+            ProfitSharingResult.Receiver receiver = receivers.get(0);
+            profitSharing.setReceiverAccount(receiver.getReceiverMchid());
+            BigDecimal receiverAmount = new BigDecimal(receiver.getAmount());
+            receiverAmount = receiverAmount.divide(new BigDecimal("100"), 2, RoundingMode.HALF_UP);
+            profitSharing.setReceiverAmount(receiverAmount);
+            profitSharing.setSurpMoney(orderMoney.subtract(receiverAmount));
+            profitSharing.setReceiverDescription(receiver.getDescription());
+            profitSharing.setFinishFlag(0);
+            profitSharing.setFailReason(receiver.getFailReason());
+            profitSharing.setDetailId(receiver.getDetailId());
+        }
+        profitSharing.setCreateTime(new Date());
+
+        this.saveOrUpdate(profitSharing);
+    }
 }

--
Gitblit v1.7.1