From d8a687741273d121586b83745280c57f7e9d3297 Mon Sep 17 00:00:00 2001 From: XiaoRuby <3114200645@qq.com> Date: 星期一, 07 八月 2023 17:51:28 +0800 Subject: [PATCH] Merge branch 'master' of https://gitee.com/yuanchu_code/lims-management-system --- standard-server/src/main/java/com/yuanchu/limslaboratory/service/impl/ProductServiceImpl.java | 79 +++++++++++++++++++++++++++++++++++++++ 1 files changed, 79 insertions(+), 0 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 new file mode 100644 index 0000000..b82da28 --- /dev/null +++ b/standard-server/src/main/java/com/yuanchu/limslaboratory/service/impl/ProductServiceImpl.java @@ -0,0 +1,79 @@ +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; +import org.springframework.util.ObjectUtils; + +import javax.annotation.Resource; +import java.util.ArrayList; +import java.util.List; +import java.util.Map; +import java.util.Objects; + +/** + * <p> + * 鏈嶅姟瀹炵幇绫� + * </p> + * + * @author 姹熻嫃榈烽洀缃戠粶绉戞妧鏈夐檺鍏徃 + * @since 2023-07-17 + */ +@Service +public class ProductServiceImpl extends ServiceImpl<ProductMapper, Product> implements ProductService { + + @Resource + private ProductMapper productMapper; + + @Override + 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 IPage<Map<String, Object>> pageProductInformation(String productCodeOrName, Integer specificationsId, Page<Objects> page) { + IPage<Map<String, Object>> iPage = productMapper.pageProductInformation(productCodeOrName, specificationsId, page); + List<Map<String, Object>> maps = iPage.getRecords(); + 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); + } + map.put("children", children); + map.remove("num"); + }); + return iPage; + } + + @Override + public List<Map<String, Object>> pageFatherNameProductInformation(String fatherName) { + LambdaQueryWrapper<Product> wrapper = new LambdaQueryWrapper<>(); + wrapper.eq(Product::getFather, fatherName); + wrapper.select(Product::getId, Product::getName, Product::getUnit, Product::getRequired, Product::getInternal); + return productMapper.selectMaps(wrapper); + } + + //閫氳繃椤圭洰鍚嶆煡璇㈤」鐩殑璇曢獙鏂规硶 + @Override + public List<Map> selectInstrumentByProname(String name) { + return productMapper.selectInstrumentByProname(name); + } +} -- Gitblit v1.9.3