From f4c288c55d08c04cd026508b358beebfcdce5fc2 Mon Sep 17 00:00:00 2001
From: liding <756868258@qq.com>
Date: 星期五, 22 五月 2026 09:29:09 +0800
Subject: [PATCH] feat(product): 添加产品型号向下复制功能并优化生产报工重量计算 - 在ProductController中新增downCopy接口实现产品型号批量复制功能 - 将ProductionProductMainDto中的bomInputQty字段重命名为inputWeight - 在ProductionProductMainServiceImpl中添加JSON解析逻辑支持从otherData中提取投入重量 - 新增resolveInputWeight、findParameterValue、findFieldValue等工具方法处理复杂参数解析 - 为ProductModelDto添加targetProductId字段用于指定复制目标 - 修复销售台账按调度员ID和姓名分组的SQL查询问题 - 优化库存服务中剩余数量计算的空值处理逻辑 - 完善生产投料数量为空时的默认值处理机制

---
 src/main/java/com/ruoyi/production/controller/ProductOrderController.java |   41 +++++++++++++----------------------------
 1 files changed, 13 insertions(+), 28 deletions(-)

diff --git a/src/main/java/com/ruoyi/production/controller/ProductOrderController.java b/src/main/java/com/ruoyi/production/controller/ProductOrderController.java
index 4beb89f..baebd18 100644
--- a/src/main/java/com/ruoyi/production/controller/ProductOrderController.java
+++ b/src/main/java/com/ruoyi/production/controller/ProductOrderController.java
@@ -1,13 +1,11 @@
 package com.ruoyi.production.controller;
 
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
-import com.ruoyi.basic.pojo.Customer;
 import com.ruoyi.common.utils.poi.ExcelUtil;
 import com.ruoyi.framework.aspectj.lang.annotation.Log;
 import com.ruoyi.framework.aspectj.lang.enums.BusinessType;
 import com.ruoyi.framework.web.domain.R;
 import com.ruoyi.production.dto.ProductOrderDto;
-import com.ruoyi.production.pojo.ProcessRoute;
 import com.ruoyi.production.pojo.ProductOrder;
 import com.ruoyi.production.service.ProductOrderService;
 import io.swagger.annotations.Api;
@@ -16,10 +14,9 @@
 import org.springframework.web.bind.annotation.*;
 
 import javax.servlet.http.HttpServletResponse;
-import java.math.BigDecimal;
 import java.util.List;
 
-@RequestMapping("productOrder")
+@RequestMapping("/productOrder")
 @RestController
 @Api(tags = "鐢熶骇璁㈠崟")
 public class ProductOrderController {
@@ -29,7 +26,7 @@
 
 
     @ApiOperation("鍒嗛〉鏌ヨ")
-    @GetMapping("page")
+    @GetMapping("/page")
     public R page(ProductOrderDto productOrder, Page page) {
         return R.ok(productOrderService.pageProductOrder(page, productOrder));
     }
@@ -53,29 +50,6 @@
     @PostMapping("/export")
     public void export(HttpServletResponse response, ProductOrderDto productOrderDto) {
         List<ProductOrderDto> list = productOrderService.pageProductOrder(new Page<>(1, -1), productOrderDto).getRecords();
-
-        if (list != null && !list.isEmpty()) {
-            list.forEach(item -> {
-                // 鍒ょ┖
-                if (item.getQuantity() == null || item.getCompleteQuantity() == null) {
-                    item.setCompletionStatus(BigDecimal.ZERO);
-                    return;
-                }
-
-                // 鍒ら浂
-                if (item.getQuantity().compareTo(BigDecimal.ZERO) == 0) {
-                    item.setCompletionStatus(BigDecimal.ZERO);
-                    return;
-                }
-                BigDecimal progress = item.getCompleteQuantity()
-                        .divide(item.getQuantity(), 4, BigDecimal.ROUND_HALF_UP)
-                        .multiply(new BigDecimal(100))
-                        .setScale(2, BigDecimal.ROUND_HALF_UP);
-
-                item.setCompletionStatus(progress);
-            });
-        }
-
         ExcelUtil<ProductOrderDto> util = new ExcelUtil<>(ProductOrderDto.class);
         util.exportExcel(response, list, "鐢熶骇璁㈠崟鏁版嵁");
     }
@@ -87,4 +61,15 @@
     }
 
 
+    @ApiOperation("鏂板鐢熶骇璁㈠崟")
+    @PostMapping("/addProductOrder")
+    public R addProductOrder(@RequestBody ProductOrderDto productOrderDto) {
+        return R.ok(productOrderService.addProductOrder(productOrderDto));
+    }
+
+    @ApiOperation("鍒犻櫎鐢熶骇璁㈠崟")
+    @DeleteMapping("/{ids}")
+    public R delete(@PathVariable("ids") Long[] ids) {
+        return R.ok(productOrderService.delete(ids));
+    }
 }

--
Gitblit v1.9.3