From 474ddd0b76f343b09038e6f60e2826684d5eecd2 Mon Sep 17 00:00:00 2001
From: buhuazhen <hua100783@gmail.com>
Date: 星期五, 08 五月 2026 13:32:57 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/dev_浪潮_pro' into dev_浪潮_pro

---
 src/main/java/com/ruoyi/basic/service/impl/ProductServiceImpl.java |   20 +++++++++++++++++---
 1 files changed, 17 insertions(+), 3 deletions(-)

diff --git a/src/main/java/com/ruoyi/basic/service/impl/ProductServiceImpl.java b/src/main/java/com/ruoyi/basic/service/impl/ProductServiceImpl.java
index b93e14a..3667bb6 100644
--- a/src/main/java/com/ruoyi/basic/service/impl/ProductServiceImpl.java
+++ b/src/main/java/com/ruoyi/basic/service/impl/ProductServiceImpl.java
@@ -1,6 +1,9 @@
 package com.ruoyi.basic.service.impl;
 
 import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
+import com.baomidou.mybatisplus.core.metadata.IPage;
+import com.baomidou.mybatisplus.core.toolkit.ObjectUtils;
+import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
 import com.ruoyi.basic.dto.ProductDto;
 import com.ruoyi.basic.dto.ProductTreeDto;
@@ -9,12 +12,10 @@
 import com.ruoyi.basic.pojo.Product;
 import com.ruoyi.basic.pojo.ProductModel;
 import com.ruoyi.basic.service.IProductService;
+import com.ruoyi.basic.vo.ProductModelVo;
 import com.ruoyi.common.utils.bean.BeanUtils;
-import com.ruoyi.common.utils.poi.ExcelUtil;
-import com.ruoyi.framework.web.domain.AjaxResult;
 import lombok.AllArgsConstructor;
 import org.springframework.stereotype.Service;
-import org.springframework.web.multipart.MultipartFile;
 
 import java.util.ArrayList;
 import java.util.Arrays;
@@ -38,6 +39,12 @@
         if (productDto.getProductName() != null && !productDto.getProductName().isEmpty()) {
             queryWrapper.like(Product::getProductName, productDto.getProductName());
         }
+        // 娴疆鐢ㄤ簬鍖哄垎鎴愬搧鍜岀墿鏂�
+        if (productDto.getProductType() != null && !productDto.getProductType().isEmpty()) {
+            if (productDto.getProductType().equals("鎴愬搧")){
+                queryWrapper.eq(Product::getProductName, productDto.getProductType());
+            }else queryWrapper.ne(Product::getProductName, "鎴愬搧");
+        }
 
         // 鏌ヨ鏍硅妭鐐瑰垪琛�
         List<Product> rootProducts = productMapper.selectList(queryWrapper);
@@ -52,6 +59,10 @@
         return tree;
     }
 
+    @Override
+    public IPage<ProductModelVo> listPageProductModel(Page<ProductModelVo> page, ProductModel productModel) {
+        return productModelMapper.listPageProductModel(page, productModel);
+    }
 
 
     // 閫掑綊鏋勫缓瀛愯妭鐐�
@@ -83,6 +94,9 @@
 
     @Override
     public int addOrEditProduct(ProductDto productDto) {
+        if (ObjectUtils.isEmpty(productDto.getParentId())) {
+            throw new IllegalArgumentException("璇烽�夋嫨鐖惰妭鐐�");
+        }
         if (productDto.getId() == null) {
             // 鏂板浜у搧閫昏緫
             if (productDto.getParentId() == null) {

--
Gitblit v1.9.3