From ad7151b14f2721b0fa40a903c6e65a2c511dd4c5 Mon Sep 17 00:00:00 2001
From: XiaoRuby <3114200645@qq.com>
Date: 星期四, 27 七月 2023 15:08:13 +0800
Subject: [PATCH] LIMS管理系统框架-开发7-27第二次标准库完成修改

---
 standard-server/src/main/java/com/yuanchu/limslaboratory/service/impl/ProductServiceImpl.java |   89 ++++++++++++++++----------------------------
 1 files changed, 32 insertions(+), 57 deletions(-)

diff --git a/standard-server/src/main/java/com/yuanchu/limslaboratory/service/impl/ProductServiceImpl.java b/standard-server/src/main/java/com/yuanchu/limslaboratory/service/impl/ProductServiceImpl.java
index 3d20a4c..6cbc593 100644
--- a/standard-server/src/main/java/com/yuanchu/limslaboratory/service/impl/ProductServiceImpl.java
+++ b/standard-server/src/main/java/com/yuanchu/limslaboratory/service/impl/ProductServiceImpl.java
@@ -1,10 +1,14 @@
 package com.yuanchu.limslaboratory.service.impl;
 
 import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
+import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper;
+import com.baomidou.mybatisplus.core.metadata.IPage;
+import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
 import com.yuanchu.limslaboratory.pojo.Product;
 import com.yuanchu.limslaboratory.mapper.ProductMapper;
 import com.yuanchu.limslaboratory.service.ProductService;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
+import com.yuanchu.limslaboratory.utils.MyUtil;
 import org.springframework.beans.factory.annotation.Autowired;
 import com.yuanchu.limslaboratory.service.UserService;
 import org.springframework.stereotype.Service;
@@ -14,6 +18,7 @@
 import java.util.ArrayList;
 import java.util.List;
 import java.util.Map;
+import java.util.Objects;
 
 /**
  * <p>
@@ -30,70 +35,40 @@
     private ProductMapper productMapper;
 
     @Override
-    public List<Product> selectProductByMaterialId(String materialId) {
-        return productMapper.selectProductByMaterialId(materialId);
-    }
-
-    @Autowired
-    private UserService userService;
-
-    @Override
-    public Integer addProductInformation(Product product) {
-        return productMapper.insert(product);
+    public void deleteProductInformation(List<Integer> SpecificationsId) {
+        for (Integer materialId : SpecificationsId){
+            LambdaUpdateWrapper<Product> wrapper = new LambdaUpdateWrapper<>();
+            wrapper.eq(Product::getSpecifications_id, materialId);
+            wrapper.set(Product::getState, 0);
+            productMapper.update(new Product(), wrapper);
+        }
     }
 
     @Override
-    public List<Map<String, Object>> getListProductInformation(Integer materialId) {
-        LambdaQueryWrapper<Product> wrapper = new LambdaQueryWrapper<>();
-        wrapper.eq(Product::getMaterialId, materialId);
-        wrapper.select(Product::getId, Product::getName, Product::getFather);
-        wrapper.groupBy(Product::getFather);
-        List<Map<String, Object>> products = productMapper.selectMaps(wrapper);
-        for (Map<String, Object> product:products){
-            if (!ObjectUtils.isEmpty(product.get("father"))){
-                product.remove("name");
-                product.remove("id");
-                LambdaQueryWrapper<Product> wrapper1 = new LambdaQueryWrapper<>();
-                wrapper1.eq(Product::getFather, product.get("father"));
-                wrapper1.select(Product::getId, Product::getName);
-                List<Map<String, Object>> maps = productMapper.selectMaps(wrapper1);
-                product.put("sonProduct", maps);
+    public IPage<Map<String, Object>> pageProductInformation(String productCodeOrName, Page<Objects> page) {
+        IPage<Map<String, Object>> iPage = productMapper.pageProductInformation(productCodeOrName, page);
+        List<Map<String, Object>> maps = iPage.getRecords();
+        MyUtil.PrintLog(maps.toString());
+        maps.forEach(map -> {
+            int num = Integer.parseInt(map.get("num").toString());
+            boolean children = false;
+            if (num > 1){
+                children = true;
+            } else {
+                Map<String, Object> product = productMapper.selectOneChildren(map.get("father"));
+                map.putAll(product);
             }
-        }
-        for (Map<String, Object> product:products){
-            System.out.println(product);
-        }
-        return products;
+            map.put("children", children);
+            map.remove("num");
+        });
+        return iPage;
     }
 
     @Override
-    public Map<String, Object> getProductInformation(Integer productId) {
-        Map<String, Object> productMap = productMapper.getProductInformation(productId);
-        String userName = userService.selectByUserId((Integer) productMap.get("user_id"));
-        productMap.remove("user_id");
-        productMap.put("userName", userName);
-        return productMap;
-    }
-
-    @Override
-    public Integer deleteProductInformation(Integer productId) {
+    public List<Map<String, Object>> pageFatherNameProductInformation(String fatherName) {
         LambdaQueryWrapper<Product> wrapper = new LambdaQueryWrapper<>();
-        wrapper.eq(Product::getId, productId);
-        return productMapper.delete(wrapper);
-    }
-
-    @Override
-    public void deleteProductEqMaterialId(List<String> materialListId) {
-        for (String materialId : materialListId){
-            LambdaQueryWrapper<Product> wrapper = new LambdaQueryWrapper<>();
-            wrapper.eq(Product::getMaterialId, materialId);
-            wrapper.select(Product::getId);
-            List<Product> products = productMapper.selectList(wrapper);
-            List<Integer> productDeleteId = new ArrayList<>();
-            for (Product product : products){
-                productDeleteId.add(product.getId());
-            }
-            productMapper.deleteBatchIds(productDeleteId);
-        }
+        wrapper.eq(Product::getFather, fatherName);
+        wrapper.select(Product::getId, Product::getName, Product::getUnit, Product::getRequired, Product::getInternal);
+        return productMapper.selectMaps(wrapper);
     }
 }

--
Gitblit v1.9.3