cuijian
2023-08-19 bdd0875d4b13a3f1ef472f64d4b6a95e0ef64b22
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
package org.jeecg.modules.eam.service.impl;
 
import org.jeecg.modules.eam.entity.EquipmentDisposal;
import org.jeecg.modules.eam.entity.EquipmentScrap;
import org.jeecg.modules.eam.entity.EquipmentScrapDetail;
import org.jeecg.modules.eam.mapper.EquipmentScrapDetailMapper;
import org.jeecg.modules.eam.mapper.EquipmentScrapMapper;
import org.jeecg.modules.eam.service.IEquipmentScrapService;
import org.springframework.stereotype.Service;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.transaction.annotation.Transactional;
 
import java.io.Serializable;
import java.util.List;
import java.util.Collection;
 
/**
 * @Description: 设备报废
 * @Author: jeecg-boot
 * @Date: 2023-05-06
 * @Version: V1.0
 */
@Service
public class EquipmentScrapServiceImpl extends ServiceImpl<EquipmentScrapMapper, EquipmentScrap> implements IEquipmentScrapService {
 
    @Autowired
    private EquipmentScrapMapper equipmentScrapMapper;
    @Autowired
    private EquipmentScrapDetailMapper equipmentScrapDetailMapper;
 
    @Override
    @Transactional(rollbackFor = Exception.class)
    public void saveMain(EquipmentScrap equipmentScrap, List<EquipmentScrapDetail> equipmentScrapDetailList) {
        equipmentScrap.setAuditStatus("notSubmitted");
//        equipmentScrap.setChangeMethod("scrap");
        equipmentScrapMapper.insert(equipmentScrap);
        if (equipmentScrapDetailList != null && equipmentScrapDetailList.size() > 0) {
            for (EquipmentScrapDetail entity : equipmentScrapDetailList) {
                //外键设置
                entity.setEquipmentChangeId(equipmentScrap.getId());
                equipmentScrapDetailMapper.insert(entity);
            }
        }
    }
 
    @Override
    @Transactional(rollbackFor = Exception.class)
    public void updateMain(EquipmentScrap equipmentScrap, List<EquipmentScrapDetail> equipmentScrapDetailList) {
        equipmentScrapMapper.updateById(equipmentScrap);
 
        //1.先删除子表数据
        equipmentScrapDetailMapper.deleteByMainId(equipmentScrap.getId());
 
        //2.子表数据重新插入
        if (equipmentScrapDetailList != null && equipmentScrapDetailList.size() > 0) {
            for (EquipmentScrapDetail entity : equipmentScrapDetailList) {
                //外键设置
                entity.setEquipmentChangeId(equipmentScrap.getId());
                equipmentScrapDetailMapper.insert(entity);
            }
        }
    }
 
    @Override
    @Transactional(rollbackFor = Exception.class)
    public void delMain(String id) {
        equipmentScrapDetailMapper.deleteByMainId(id);
        equipmentScrapMapper.deleteById(id);
    }
 
    @Override
    @Transactional(rollbackFor = Exception.class)
    public void delBatchMain(Collection<? extends Serializable> idList) {
        for (Serializable id : idList) {
            equipmentScrapDetailMapper.deleteByMainId(id.toString());
            equipmentScrapMapper.deleteById(id);
        }
    }
 
    @Override
    public void submit(String id) {
        EquipmentScrap equipmentScrap = super.getById(id);
        equipmentScrap.setAuditStatus("pendingApproval");
        super.updateById(equipmentScrap);
    }
 
    @Override
    public void revocation(String id) {
        EquipmentScrap equipmentScrap = super.getById(id);
//            设置撤回后的状态为初始状态 待提交=notSubmitted
//            TODO  需要明确什么状态下不允许撤回
        equipmentScrap.setAuditStatus("notSubmitted");
        super.updateById(equipmentScrap);
    }
 
}