From 6e492d4d16efff769c2928109fb6a085fcad948d Mon Sep 17 00:00:00 2001
From: shiyunteng <shiyunteng@example.com>
Date: 星期一, 15 六月 2026 08:55:01 +0800
Subject: [PATCH] feat:付款合同编号不存在时错误提示

---
 platformx-business-finance-biz/src/main/java/com/by4cloud/platformx/business/controller/ProductController.java |   49 +++++++++++++++++++++++++++++++++++++++++++------
 1 files changed, 43 insertions(+), 6 deletions(-)

diff --git a/platformx-business-finance-biz/src/main/java/com/by4cloud/platformx/business/controller/ProductController.java b/platformx-business-finance-biz/src/main/java/com/by4cloud/platformx/business/controller/ProductController.java
index a885b85..bcea39f 100644
--- a/platformx-business-finance-biz/src/main/java/com/by4cloud/platformx/business/controller/ProductController.java
+++ b/platformx-business-finance-biz/src/main/java/com/by4cloud/platformx/business/controller/ProductController.java
@@ -1,11 +1,15 @@
 package com.by4cloud.platformx.business.controller;
 
+import cn.hutool.core.bean.BeanUtil;
+import cn.hutool.core.date.DateUtil;
 import cn.hutool.core.util.ArrayUtil;
 import cn.hutool.core.collection.CollUtil;
 import cn.hutool.core.util.StrUtil;
 import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import com.baomidou.mybatisplus.core.toolkit.Wrappers;
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import com.by4cloud.platformx.business.dto.ProductQueryDTO;
+import com.by4cloud.platformx.business.vo.ProductTreeVo;
 import com.by4cloud.platformx.common.core.util.R;
 import com.by4cloud.platformx.common.log.annotation.SysLog;
 import com.by4cloud.platformx.business.entity.Product;
@@ -21,6 +25,7 @@
 import lombok.RequiredArgsConstructor;
 import org.springframework.web.bind.annotation.*;
 
+import java.util.ArrayList;
 import java.util.List;
 import java.util.Objects;
 
@@ -54,7 +59,19 @@
         wrapper.like(StrUtil.isNotEmpty(product.getProductName()),Product::getProductName,product.getProductName());
         wrapper.like(StrUtil.isNotEmpty(product.getMainCode()),Product::getMainCode,product.getMainCode());
         wrapper.like(StrUtil.isNotEmpty(product.getErpCode()),Product::getErpCode,product.getErpCode());
-        return R.ok(productService.page(page, wrapper));
+		wrapper.orderByDesc(Product::getCreateTime);
+        Page<Product> page1 = productService.pageByScope(page, wrapper);
+        List<Product> list = page1.getRecords();
+        for(Product product1 : list){
+            Product  parent = productService.getById(product1.getParentId());
+            if(parent==null){
+                product1.setParentName("鏍圭骇浜у搧");
+            }else {
+                product1.setParentName(parent.getProductName());
+            }
+        }
+        page1.setRecords(list);
+        return R.ok(page1);
     }
 
     /**
@@ -65,10 +82,28 @@
     @Operation(summary = "鍒嗛〉鏌ヨ" , description = "鍒嗛〉鏌ヨ" )
     @GetMapping("/list" )
     @PreAuthorize("@pms.hasPermission('business_product_view')" )
-    @Inner(value = false)
     public R getProductList(@ParameterObject Product product) {
-        LambdaQueryWrapper<Product> wrapper = Wrappers.lambdaQuery();
-        return R.ok(productService.list(wrapper));
+        return R.ok(productService.getProductList(product));
+    }
+
+    /**
+     * 鍒嗛〉鏌ヨ
+     * @param queryDTO 浜у搧淇℃伅
+     * @return
+     */
+    @Operation(summary = "鍒嗛〉鏌ヨ" , description = "鍒嗛〉鏌ヨ" )
+    @GetMapping("/listByParentId" )
+    public R getProductListByParentId(@ParameterObject ProductQueryDTO queryDTO) {
+//        LambdaQueryWrapper<Product> wrapper = Wrappers.lambdaQuery();
+//        wrapper.like(StrUtil.isNotEmpty(queryDTO.getProductName()),Product::getProductName,queryDTO.getProductName());
+//        wrapper.eq(StrUtil.isNotEmpty(queryDTO.getParentId()),Product::getParentId,queryDTO.getParentId());
+//		if (StrUtil.isNotEmpty(queryDTO.getContractCategory())&&StrUtil.equals(queryDTO.getContractCategory(), "water_house")){
+//			String[] erpCodes = new String[]{"鎴跨绉熻祦","dianli","water"};
+//			wrapper.in(Product::getErpCode,erpCodes);
+//			return R.ok(BeanUtil.copyToList(productService.listByScope(wrapper), ProductTreeVo.class));
+//		}
+//        return R.ok(BeanUtil.copyToList(productService.listByScope(wrapper), ProductTreeVo.class));
+		return productService.getProductListByParentId(queryDTO);
     }
 
     /**
@@ -78,10 +113,9 @@
      */
     @Operation(summary = "灞傜骇鏌ヨ" , description = "灞傜骇鏌ヨ" )
     @GetMapping("/treeList" )
-    //@PreAuthorize("@pms.hasPermission('business_product_view')" )
     @Inner(value = false)
     public R getNewsCategoryTree(@ParameterObject Product product) {
-        return R.ok(productService.treeList(product.getParentId(), product.getProductName()));
+        return R.ok(productService.treeList());
     }
 
 
@@ -107,6 +141,9 @@
     @PostMapping
     @PreAuthorize("@pms.hasPermission('business_product_add')" )
     public R save(@RequestBody Product product) {
+		if (ArrayUtil.isNotEmpty(productService.listByScope(Wrappers.lambdaQuery(product).eq(Product::getErpCode,product.getErpCode())).toArray())){
+			return R.failed("浜у搧Erp缂栫爜宸插瓨鍦�");
+		}
         return R.ok(productService.save(product));
     }
 

--
Gitblit v1.9.1