From 160ed62b3eca5e6b57efd945c95fb5a719bea785 Mon Sep 17 00:00:00 2001
From: liusheng <337615773@qq.com>
Date: 星期二, 06 六月 2023 11:35:37 +0800
Subject: [PATCH] 根据税后求税前金额

---
 ruoyi-project/src/main/java/com/ruoyi/project/service/impl/ServiceFunddetailServiceImpl.java |   62 +++++++++++++++++++++++++++---
 1 files changed, 55 insertions(+), 7 deletions(-)

diff --git a/ruoyi-project/src/main/java/com/ruoyi/project/service/impl/ServiceFunddetailServiceImpl.java b/ruoyi-project/src/main/java/com/ruoyi/project/service/impl/ServiceFunddetailServiceImpl.java
index 32b0637..f7add24 100644
--- a/ruoyi-project/src/main/java/com/ruoyi/project/service/impl/ServiceFunddetailServiceImpl.java
+++ b/ruoyi-project/src/main/java/com/ruoyi/project/service/impl/ServiceFunddetailServiceImpl.java
@@ -9,6 +9,7 @@
 import com.ruoyi.common.tax.TaxtUtils;
 import com.ruoyi.project.domain.*;
 import com.ruoyi.project.domain.vo.TaxMoneyVO;
+import com.ruoyi.project.domain.vo.TaxedMoneyVO;
 import com.ruoyi.project.mapper.ServiceFundMapper;
 import org.apache.commons.collections4.CollectionUtils;
 import org.springframework.beans.factory.annotation.Autowired;
@@ -93,24 +94,71 @@
         return dataBybeneficiaryNo;
     }
 
+    /**
+     * 鏍规嵁鍙楃泭浜虹紪鍙疯幏鍙栫◣璐归噾棰�
+     *
+     * @param taxMoneyVo
+     * @return
+     */
     @Override
     public Double getTaxBeforeByBeneFiciaryNo(TaxMoneyVO taxMoneyVo) {
+        Double sum = 0.00;
+        Double totalScore = 0.00;
         List<ServiceFunddetail> taxationByBeneFiciaryNo = serviceFunddetailMapper.getTaxBeforeByBeneFiciaryNo(taxMoneyVo);
-        if (CollectionUtils.isEmpty(taxationByBeneFiciaryNo) && taxMoneyVo.getMoney() == 0) {
-            //閮戒负0浜嗭紝灏辨病鏈夊繀瑕佸啀璁$畻浜�
-            return 0.00;
+        if (CollectionUtils.isNotEmpty(taxationByBeneFiciaryNo)) {
+            //璁$畻鐢宠閲戦鎬诲拰锛屼笉鍖呮嫭褰撳墠浼犺繘鏉ョ殑
+            sum = taxationByBeneFiciaryNo.stream().mapToDouble(ServiceFunddetail::getAmount).sum();
+            //涓嶅姞鏈钖叕鐨勪釜绋�
+            totalScore = taxationByBeneFiciaryNo.stream().mapToDouble(ServiceFunddetail::getTaxamount).sum();
         }
-        double sum = taxationByBeneFiciaryNo.stream().mapToDouble(ServiceFunddetail::getAmount).sum();
+
         sum = sum + new Double(taxMoneyVo.getMoney());
-        //鍔犱笂鏈钖叕鐨勪釜绋�
+        //鍔犱笂鏈钖叕鐨勬�讳釜绋�
         String taxation = TaxtUtils.getTaxation(new BigDecimal(sum));
-        //涓嶅姞鏈钖叕鐨勪釜绋�
-        Double totalScore = taxationByBeneFiciaryNo.stream().mapToDouble(ServiceFunddetail::getTaxamount).sum();
 
         Double tax = Double.valueOf(taxation) - totalScore;
         return tax;
     }
 
+    /**
+     * 鏍规嵁绋庡悗宸ヨ祫锛岀畻鍑虹◣鍓嶅伐璧�
+     *
+     * @param money
+     * @return
+     */
+    @Override
+    public TaxedMoneyVO getTaxBeforeByAfterMoney(TaxMoneyVO taxMoneyVo) {
+        TaxedMoneyVO taxedMoneyVO = new TaxedMoneyVO();
+        Double sum = 0.00;
+        Double totalScore = 0.00;
+        List<ServiceFunddetail> taxationByBeneFiciaryNo = serviceFunddetailMapper.getTaxBeforeByBeneFiciaryNo(taxMoneyVo);
+        if (CollectionUtils.isNotEmpty(taxationByBeneFiciaryNo)) {
+            //璁$畻鍑虹◣鍚庢�婚噾棰濓紙涓嶅寘鍚湰娆★級
+            sum = taxationByBeneFiciaryNo.stream().mapToDouble(ServiceFunddetail::getTaxedamount).sum();
+            //姹傚嚭涔嬪墠鐨勬�荤殑涓◣
+            totalScore = taxationByBeneFiciaryNo.stream().mapToDouble(ServiceFunddetail::getTaxamount).sum();
+        }
+        //璁$畻鍑烘�荤殑绋庡悗钖叕锛堝寘鍚湰娆★級
+        sum = sum + taxMoneyVo.getMoney();
+        //绋庡墠鎬婚噾棰�
+        String taxationBefore = TaxtUtils.getTaxationBefore(new BigDecimal(sum));
+        //鎬讳釜绋�
+        BigDecimal tax = new BigDecimal(taxationBefore).subtract(new BigDecimal(sum));
+
+        //鏈鐨勭◣鍓嶉噾棰�
+        String nowTaxMoney = TaxtUtils.getTaxationBefore(new BigDecimal(taxMoneyVo.getMoney()));
+        //鏈鐨勭◣璐�
+        BigDecimal subtract = new BigDecimal(nowTaxMoney).subtract(new BigDecimal(taxMoneyVo.getMoney()));
+
+        taxedMoneyVO.setAllTax(tax.toString());
+        taxedMoneyVO.setAllTaxbeforeMoney(taxationBefore);
+        taxedMoneyVO.setAllAaxAfterMoney(sum.toString());
+        taxedMoneyVO.setNowTaxBeforeMoney(nowTaxMoney);
+        taxedMoneyVO.setNowTax(subtract.toString());
+
+        return taxedMoneyVO;
+    }
+
 
     @Override
     public List<ServiceFunddetail> getAllDetailsByFDIDLW(Long id) {

--
Gitblit v1.9.3