From 2495a8e1f71b6a0908a423765aaafd9ae0140d0c Mon Sep 17 00:00:00 2001
From: huminmin <mac@MacBook-Pro.local>
Date: 星期三, 11 三月 2026 15:21:53 +0800
Subject: [PATCH] 生成生产订单与生产计划关联表

---
 src/main/java/com/ruoyi/productionPlan/service/impl/ProductionPlanServiceImpl.java |   73 ++++++++++++++++++++++++++++++------
 1 files changed, 61 insertions(+), 12 deletions(-)

diff --git a/src/main/java/com/ruoyi/productionPlan/service/impl/ProductionPlanServiceImpl.java b/src/main/java/com/ruoyi/productionPlan/service/impl/ProductionPlanServiceImpl.java
index 31fa45c..cb916e9 100644
--- a/src/main/java/com/ruoyi/productionPlan/service/impl/ProductionPlanServiceImpl.java
+++ b/src/main/java/com/ruoyi/productionPlan/service/impl/ProductionPlanServiceImpl.java
@@ -5,9 +5,11 @@
 import com.alibaba.fastjson2.JSONObject;
 import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import com.baomidou.mybatisplus.core.metadata.IPage;
+import com.baomidou.mybatisplus.core.toolkit.Wrappers;
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
 import com.ruoyi.common.exception.ServiceException;
+import com.ruoyi.common.exception.base.BaseException;
 import com.ruoyi.common.utils.StringUtils;
 import com.ruoyi.common.utils.bean.BeanUtils;
 import com.ruoyi.common.utils.http.HttpUtils;
@@ -18,7 +20,9 @@
 import com.ruoyi.productionPlan.dto.ProductionPlanDto;
 import com.ruoyi.productionPlan.dto.ProductionPlanImportDto;
 import com.ruoyi.productionPlan.dto.ProductionPlanSummaryDto;
+import com.ruoyi.productionPlan.mapper.ProductOrderPlanMapper;
 import com.ruoyi.productionPlan.mapper.ProductionPlanMapper;
+import com.ruoyi.productionPlan.pojo.ProductOrderPlan;
 import com.ruoyi.productionPlan.pojo.ProductionPlan;
 import com.ruoyi.productionPlan.service.ProductionPlanService;
 import lombok.extern.slf4j.Slf4j;
@@ -30,10 +34,7 @@
 import javax.servlet.http.HttpServletResponse;
 import java.math.BigDecimal;
 import java.nio.charset.StandardCharsets;
-import java.time.Instant;
-import java.time.LocalDateTime;
-import java.time.OffsetDateTime;
-import java.time.ZoneId;
+import java.time.*;
 import java.time.format.DateTimeFormatter;
 import java.time.format.DateTimeParseException;
 import java.util.*;
@@ -64,6 +65,9 @@
 
     @Autowired
     private ProductOrderService productOrderService;
+
+    @Autowired
+    private ProductOrderPlanMapper productOrderPlanMapper;
 
     /**
      * 鍚屾閿侊紝纭繚鎵嬪姩鍜屽畾鏃朵换鍔′笉鍚屾椂鎵ц
@@ -107,15 +111,13 @@
         //  鏍¢獙鏄惁瀛樺湪涓嶅悓鐨勪骇鍝佸悕绉�
         String firstProductName = plans.get(0).getProductName();
         if (plans.stream().anyMatch(p -> !p.getProductName().equals(firstProductName))) {
-            log.warn("鍚堝苟澶辫触锛屽瓨鍦ㄤ笉鍚岀殑浜у搧鍚嶇О");
-            return false;
+            throw new BaseException("鍚堝苟澶辫触锛屽瓨鍦ㄤ笉鍚岀殑浜у搧鍚嶇О");
         }
 
         // 鏍¢獙鏄惁瀛樺湪涓嶅悓鐨勪骇鍝佽鏍�
         String firstProductSpec = plans.get(0).getProductSpec();
         if (plans.stream().anyMatch(p -> !p.getProductSpec().equals(firstProductSpec))) {
-            log.warn("鍚堝苟澶辫触锛屽瓨鍦ㄤ笉鍚岀殑浜у搧瑙勬牸");
-            return false;
+            throw new BaseException("鍚堝苟澶辫触锛屽瓨鍦ㄤ笉鍚岀殑浜у搧瑙勬牸");
         }
 
 
@@ -126,6 +128,7 @@
                 .reduce(BigDecimal.ZERO, BigDecimal::add);
         // 鍒ゆ柇涓嬪彂鏁伴噺鏄惁澶т簬绛変簬鏂规暟
         if (productionPlanDto.getTotalAssignedQuantity().compareTo(totalVolume) > 0) {
+
             log.warn("鎿嶄綔澶辫触锛屼笅鍙戞暟閲忎笉鑳藉ぇ浜庢柟鏁�");
             return false;
         }
@@ -141,6 +144,7 @@
             if (assignedVolume.add(volume).compareTo(productionPlanDto.getTotalAssignedQuantity()) >= 0) {
                 // 鏈�鍚庝竴涓鍒掞紝鍒嗛厤鍓╀綑鏂规暟
                 plan.setAssignedQuantity(productionPlanDto.getTotalAssignedQuantity().subtract(assignedVolume));
+                productionPlanMapper.updateById(plan);
                 break;
             }
 
@@ -152,11 +156,16 @@
 
         // 鍒涘缓鐢熶骇璁㈠崟
         ProductOrder productOrder = new ProductOrder();
-        String combineIds = StringUtils.join(productionPlanDto.getIds(), ",");
-        productOrder.setCombineProductionPlanIds(combineIds);
         productOrder.setQuantity(productionPlanDto.getTotalAssignedQuantity());
         productOrder.setPlanCompleteTime(productionPlanDto.getPlanCompleteTime());
         productOrderService.addProductOrder(productOrder);
+
+        for (Long planId : productionPlanDto.getIds()) {
+            ProductOrderPlan productOrderPlan = new ProductOrderPlan();
+            productOrderPlan.setProductOrderId(productOrder.getId());
+            productOrderPlan.setProductionPlanId(planId);
+            productOrderPlanMapper.insert(productOrderPlan);
+        }
         return true;
     }
 
@@ -166,6 +175,33 @@
         productionPlanDto.setDataSourceType(PRODUCTION_FORECAST.getCode());
         productionPlanMapper.insert(productionPlanDto);
         return true;
+    }
+
+    @Override
+    @Transactional(rollbackFor = Exception.class)
+    public boolean update(ProductionPlanDto productionPlanDto) {
+        // 鏌ヨ鏄惁鏈夊叧鑱旇鍗�
+        boolean hasProductOrderPlan = productOrderPlanMapper.selectList(Wrappers.<ProductOrderPlan>lambdaQuery().eq(ProductOrderPlan::getProductionPlanId, productionPlanDto.getId())).stream().anyMatch(p -> p.getProductOrderId() != null);
+        if (hasProductOrderPlan) {
+            //  濡傛灉鍏宠仈锛屾柟鏁板彧鑳介�掑
+            ProductionPlan currentPlan = productionPlanMapper.selectById(productionPlanDto.getId());
+            if (productionPlanDto.getVolume().compareTo(currentPlan.getVolume()) < 0) {
+                throw new BaseException("鏂规暟涓嶈兘閫掑噺");
+            }
+        }
+
+        return productionPlanMapper.updateById(productionPlanDto) > 0;
+    }
+
+    @Override
+    @Transactional(rollbackFor = Exception.class)
+    public boolean delete(List<Long> ids) {
+        // 濡傛灉鏈夊叧鑱旇鍗曪紝鍒欎笉鑳藉垹闄�
+        if (productOrderPlanMapper.selectList(Wrappers.<ProductOrderPlan>lambdaQuery().in(ProductOrderPlan::getProductionPlanId, ids)).stream().anyMatch(p -> p.getProductOrderId() != null)) {
+            throw new BaseException("鍒犻櫎澶辫触锛屽瓨鍦ㄥ叧鑱旇鍗�");
+        }
+
+        return productionPlanMapper.deleteBatchIds(ids) > 0;
     }
 
     /**
@@ -337,8 +373,20 @@
                     try {
                         long start = Long.parseLong(dateArr.getString(0));
                         long end = Long.parseLong(dateArr.getString(1));
-                        plan.setStartDate(Instant.ofEpochMilli(start).atZone(ZoneId.systemDefault()).toLocalDateTime());
-                        plan.setEndDate(Instant.ofEpochMilli(end).atZone(ZoneId.systemDefault()).toLocalDateTime());
+
+                        Date startDate = Date.from(Instant.ofEpochMilli(start)
+                                .atZone(ZoneId.systemDefault())
+                                .toLocalDate()
+                                .atStartOfDay(ZoneId.systemDefault())
+                                .toInstant());
+                        Date endDate = Date.from(Instant.ofEpochMilli(end)
+                                .atZone(ZoneId.systemDefault())
+                                .toLocalDate()
+                                .atStartOfDay(ZoneId.systemDefault())
+                                .toInstant());
+
+                        plan.setStartDate(startDate);
+                        plan.setEndDate(endDate);
                     } catch (Exception e) {
                         log.warn("瑙f瀽鏃ユ湡澶辫触: {}", dateArr);
                     }
@@ -454,6 +502,7 @@
         for (ProductionPlanImportDto dto : list) {
             entity = new ProductionPlan();
             BeanUtils.copyProperties(dto, entity);
+            entity.setAssignedQuantity(BigDecimal.ZERO);
             entity.setCreateTime(LocalDateTime.now());
             entity.setUpdateTime(LocalDateTime.now());
             entity.setDataSourceType(2);

--
Gitblit v1.9.3