Fixiaobai
2023-09-06 8abe275e36823f1065300af45e1f7a9a68f549a7
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
package com.yuanchu.limslaboratory.service.impl;
 
import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper;
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
import com.yuanchu.limslaboratory.pojo.Product;
import com.yuanchu.limslaboratory.mapper.ProductMapper;
import com.yuanchu.limslaboratory.pojo.dto.StandardProductAddDto;
import com.yuanchu.limslaboratory.service.ProductService;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import com.yuanchu.limslaboratory.utils.MyUtil;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
 
import javax.annotation.Resource;
import java.util.Date;
import java.util.List;
import java.util.Map;
 
 
/**
 * <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 List<Integer> chooseVersion(Integer specificationsId) {
        return productMapper.chooseVersion(specificationsId);
    }
 
    //展示该型号下的检验项目要求
    @Override
    @Transactional(rollbackFor = Exception.class)
    public List<Map<String, Object>> pageProductInformation(Integer specificationsId, Integer version) {
        return productMapper.pageProductInformation(specificationsId, version);
    }
 
    //填写标准值与内控值,鼠标移开保存
    @Override
    public Integer write(Integer id, String required, String internal) {
        Product product = new Product();
        product.setId(id);
        product.setRequired(required);
        product.setInternal(internal);
        MyUtil.PrintLog(product.toString());
        return productMapper.updateById(product);
    }
 
    @Override
    public void deleteList(String ids) {
        productMapper.deleteList(ids);
    }
 
    //添加同一个型号的其他版本
    @Override
    public Integer addVersion(Integer specificationsId, Integer version) {
        List<Product> productList = productMapper.selectList(Wrappers.<Product>query()
                .eq("specifications_id", specificationsId)
                .eq("version", version));
        for (Product product : productList) {
            product.setId(null);
            product.setVersion(productMapper.chooseVersion(specificationsId).get(0) + 1);
            product.setSpecifications_id(specificationsId);
        }
        saveBatch(productList);
        return productList.get(0).getVersion();
    }
 
    //查询该型号下的所有试验项目(父类)
    @Override
    public List<Map<String, Object>> chooseProject(Integer modelId) {
        return productMapper.chooseProject(modelId);
    }
 
    @Override
    public String addProduct(StandardProductAddDto dto) {
        int i = productMapper.addProduct(new Product(
                dto.getName(), dto.getFather(),
                dto.getUnit(), new Date(), new Date(),
                Integer.parseInt(dto.getVersion()), dto.getSpecificationId()));
        if(i>0) return "添加成功!";
        return "添加失败";
    }
 
 
}