From f29c8786807015d78b9be8a33397f69478d92a76 Mon Sep 17 00:00:00 2001
From: liding <756868258@qq.com>
Date: 星期六, 12 七月 2025 16:52:27 +0800
Subject: [PATCH] 1.设备优化 2.配煤计算器

---
 main-business/src/main/java/com/ruoyi/business/service/impl/ProductionMasterServiceImpl.java |   36 +++++++++++++++++++++++++++++++++---
 1 files changed, 33 insertions(+), 3 deletions(-)

diff --git a/main-business/src/main/java/com/ruoyi/business/service/impl/ProductionMasterServiceImpl.java b/main-business/src/main/java/com/ruoyi/business/service/impl/ProductionMasterServiceImpl.java
index 4157611..eef4183 100644
--- a/main-business/src/main/java/com/ruoyi/business/service/impl/ProductionMasterServiceImpl.java
+++ b/main-business/src/main/java/com/ruoyi/business/service/impl/ProductionMasterServiceImpl.java
@@ -19,7 +19,9 @@
 import org.springframework.transaction.annotation.Transactional;
 
 import java.math.BigDecimal;
+import java.math.RoundingMode;
 import java.time.LocalDate;
+import java.time.format.DateTimeFormatter;
 import java.util.*;
 import java.util.stream.Collectors;
 
@@ -282,13 +284,41 @@
      * 灏嗗姞宸ヤ骇鐢熺殑浜у搧璁板綍鍒板緟鍏ュ簱琛�
      */
     private void insertPendingInventory(List<Production> list) {
+        LocalDate currentDate = LocalDate.now();
+        DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd");
+        String formattedDate = currentDate.format(formatter);
+        final int SCALE = 2;
+        final RoundingMode ROUNDING_MODE = RoundingMode.HALF_UP;
+        final BigDecimal TAX_RATE = new BigDecimal("1.13");
+
         for (Production p : list) {
             PendingInventory pending = new PendingInventory();
             pending.setCoalId(p.getCoalId());
             pending.setInventoryQuantity(p.getProductionQuantity());
-            pending.setSupplierName("鐢熶骇鍔犲伐鍏ュ簱");
-            pending.setTotalPriceIncludingTax(p.getTotalCost());
-            pending.setPriceIncludingTax(p.getPurchasePrice());
+            pending.setUnit("t");
+            pending.setSupplierName(formattedDate + " - " + "鐢熶骇鍔犲伐鍏ュ簱");
+
+            // 闈炵┖澶勭悊
+            BigDecimal totalCost = p.getTotalCost() == null ? BigDecimal.ZERO : p.getTotalCost();
+            BigDecimal productionQuantity = p.getProductionQuantity() == null ? BigDecimal.ZERO : p.getProductionQuantity();
+
+            // 鍚◣鎬讳环
+            BigDecimal totalPriceIncludingTax = totalCost.multiply(productionQuantity)
+                    .setScale(SCALE, ROUNDING_MODE);
+            pending.setTotalPriceIncludingTax(totalPriceIncludingTax);
+
+            // 鍚◣鍗曚环
+            pending.setPriceIncludingTax(totalCost.setScale(SCALE, ROUNDING_MODE));
+
+            // 涓嶅惈绋庡崟浠凤紙鐩存帴淇濈暀2浣嶅皬鏁帮級
+            BigDecimal priceExcludingTax = totalCost.divide(TAX_RATE, SCALE, ROUNDING_MODE);
+            pending.setPriceExcludingTax(priceExcludingTax);
+
+            // 涓嶅惈绋庢�讳环
+            BigDecimal totalPriceExcludingTax = priceExcludingTax.multiply(productionQuantity)
+                    .setScale(SCALE, ROUNDING_MODE);
+            pending.setTotalPriceExcludingTax(totalPriceExcludingTax);
+
             pending.setRegistrantId(p.getProducerId());
             pending.setRegistrationDate(LocalDate.now());
             pendingInventoryMapper.insert(pending);

--
Gitblit v1.9.3