选煤厂生产管理平台后台代码
dongyukun
2024-12-10 b643c158bc05f2a7f95bb9fed15a1451691eaef4
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 com.iailab.module.pms.coalquality.modules.detection.service.impl;
 
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.iailab.framework.common.pojo.PageResult;
import com.iailab.framework.common.service.impl.BaseServiceImpl;
import com.iailab.framework.common.util.object.BeanUtils;
import com.iailab.iems.common.utils.ConvertUtils;
import com.iailab.iems.common.utils.SerialNumUtils;
import com.iailab.module.pms.coalquality.modules.detection.dao.QualityDetectionDao;
import com.iailab.module.pms.coalquality.modules.detection.dto.QualityDetectionDTO;
import com.iailab.module.pms.coalquality.modules.detection.entity.QualityDetectionEntity;
import com.iailab.module.pms.coalquality.modules.detection.service.QualityDetectionService;
import com.iailab.module.pms.coalquality.modules.detection.vo.DetectionPageReqVO;
import org.apache.commons.lang3.StringUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
import org.springframework.util.CollectionUtils;
 
import java.util.Arrays;
import java.util.Date;
import java.util.HashMap;
import java.util.Map;
 
/**
 * 煤质检测
 *
 * @author PanZhibao
 * @Description
 * @createTime 2023年02月07日 13:15:00
 */
@Service
public class QualityDetectionServiceImpl extends BaseServiceImpl<QualityDetectionDao, QualityDetectionEntity>
        implements QualityDetectionService {
 
    @Autowired
    private SerialNumUtils serialNumUtils;
 
    private Map<String, String> prefixMap = new HashMap<>();
 
    private String BUSINESS_CODE = "QualityDetection";
 
    @Override
    public PageResult<QualityDetectionDTO> page(DetectionPageReqVO reqVO) {
        PageResult<QualityDetectionEntity> page = baseDao.selectPage(reqVO);
 
        return BeanUtils.toBean(page, QualityDetectionDTO.class);
    }
 
 
    @Override
    public QualityDetectionDTO get(String id) {
        QualityDetectionEntity entity = baseDao.selectById(id);
 
        return ConvertUtils.sourceToTarget(entity, QualityDetectionDTO.class);
    }
 
    @Override
    public void save(QualityDetectionDTO dto) {
        if (CollectionUtils.isEmpty(prefixMap)) {
            prefixMap.put("ym", "10");
            prefixMap.put("cpm", "20");
            prefixMap.put("spm", "30");
        }
        QualityDetectionEntity entity = ConvertUtils.sourceToTarget(dto, QualityDetectionEntity.class);
        entity.setCode(prefixMap.get(dto.getType()) + serialNumUtils.getByBusinessDate(BUSINESS_CODE + dto.getType(), dto.getRq(), 4));
        entity.setCreateDate(new Date());
//        entity.setCreator(SecurityUser.getUserId().toString());
        insert(entity);
    }
 
    @Override
    public void update(QualityDetectionDTO dto) {
        QualityDetectionEntity entity = ConvertUtils.sourceToTarget(dto, QualityDetectionEntity.class);
        entity.setUpdateDate(new Date());
//        entity.setUpdater(SecurityUser.getUserId().toString());
        updateById(entity);
    }
 
    @Override
    @Transactional(rollbackFor = Exception.class)
    public void delete(String[] ids) {
        baseDao.deleteByIds(Arrays.asList(ids));
    }
 
    @Override
    public Long cheack(QualityDetectionDTO dto) {
        String id = dto.getId();
        String code = dto.getCode();
 
        QueryWrapper<QualityDetectionEntity> queryWrapper = new QueryWrapper<>();
        queryWrapper.ne(StringUtils.isNotBlank(id), "id", id);
        queryWrapper.and(wrapper -> wrapper.eq("code", code));
        return baseDao.selectCount(queryWrapper);
    }
 
}