车间能级提升-智能设备管理系统
baoshiwei
2025-06-24 f571cf0182abd65176fb1512c5cb5ddaea49c4a3
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
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
package org.dromara.eims.service.impl;
 
import org.dromara.common.core.domain.model.LoginUser;
import org.dromara.common.core.utils.DateUtils;
import org.dromara.common.core.utils.MapstructUtils;
import org.dromara.common.core.utils.StringUtils;
import org.dromara.common.mybatis.core.page.TableDataInfo;
import org.dromara.common.mybatis.core.page.PageQuery;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
import lombok.RequiredArgsConstructor;
import org.dromara.common.satoken.utils.LoginHelper;
import org.dromara.eims.domain.EimsEqu;
import org.springframework.stereotype.Service;
import org.dromara.eims.domain.bo.EimsEquStatuBo;
import org.dromara.eims.domain.vo.EimsEquStatuVo;
import org.dromara.eims.domain.EimsEquStatu;
import org.dromara.eims.mapper.EimsEquStatuMapper;
import org.dromara.eims.service.IEimsEquStatuService;
import org.dromara.eims.service.IEimsEquService;
import org.dromara.eims.domain.bo.EimsEquBo;
import org.springframework.transaction.annotation.Transactional;
 
import java.util.List;
import java.util.Map;
import java.util.Collection;
 
/**
 * 设备状态记录Service业务层处理
 *
 * @author zhuguifei
 * @date 2025-01-14
 */
@RequiredArgsConstructor
@Service
public class EimsEquStatuServiceImpl implements IEimsEquStatuService {
 
    private final EimsEquStatuMapper baseMapper;
    private final IEimsEquService equService;
 
    /**
     * 查询设备状态记录
     *
     * @param equStatuId 主键
     * @return 设备状态记录
     */
    @Override
    public EimsEquStatuVo queryById(Long equStatuId){
        return baseMapper.selectVoById(equStatuId);
    }
 
    /**
     * 分页查询设备状态记录列表
     *
     * @param bo        查询条件
     * @param pageQuery 分页参数
     * @return 设备状态记录分页列表
     */
    @Override
    public TableDataInfo<EimsEquStatuVo> queryPageList(EimsEquStatuBo bo, PageQuery pageQuery) {
        // 使用自定义SQL实现设备状态与设备表的模糊关联分页查询
        Page<EimsEquStatuVo> page = pageQuery.build();
        List<EimsEquStatuVo> list = baseMapper.selectEquStatuPage(bo, pageQuery);
        page.setRecords(list);
        return TableDataInfo.build(page);
    }
 
    /**
     * 查询符合条件的设备状态记录列表
     *
     * @param bo 查询条件
     * @return 设备状态记录列表
     */
    @Override
    public List<EimsEquStatuVo> queryList(EimsEquStatuBo bo) {
        LambdaQueryWrapper<EimsEquStatu> lqw = buildQueryWrapper(bo);
        return baseMapper.selectVoList(lqw);
    }
 
    private LambdaQueryWrapper<EimsEquStatu> buildQueryWrapper(EimsEquStatuBo bo) {
        Map<String, Object> params = bo.getParams();
        LambdaQueryWrapper<EimsEquStatu> lqw = Wrappers.lambdaQuery();
        lqw.eq(bo.getEquId() != null, EimsEquStatu::getEquId, bo.getEquId());
        lqw.eq(StringUtils.isNotBlank(bo.getBeforeChange()), EimsEquStatu::getBeforeChange, bo.getBeforeChange());
        lqw.eq(StringUtils.isNotBlank(bo.getAfterChange()), EimsEquStatu::getAfterChange, bo.getAfterChange());
        lqw.eq(bo.getChangeUser() != null, EimsEquStatu::getChangeUser, bo.getChangeUser());
        lqw.between(params.get("beginTime") != null && params.get("endTime") != null,
            EimsEquStatu::getChangeDate, params.get("beginTime"), params.get("endTime"));
        return lqw;
    }
 
    /**
     * 新增设备状态记录
     *
     * @param bo 设备状态记录
     * @return 是否新增成功
     */
    @Override
    public Boolean insertByBo(EimsEquStatuBo bo) {
        // 获取登录用户
        LoginUser loginUser = LoginHelper.getLoginUser();
        EimsEquStatu add = MapstructUtils.convert(bo, EimsEquStatu.class);
        add.setChangeUser(loginUser.getUserId());
        add.setChangeDate(DateUtils.getNowDate());
        validEntityBeforeSave(add);
        boolean flag = baseMapper.insert(add) > 0;
        if (flag) {
            bo.setEquStatuId(add.getEquStatuId());
        }
        return flag;
    }
 
    /**
     * 修改设备状态记录
     *
     * @param bo 设备状态记录
     * @return 是否修改成功
     */
    @Override
    @Transactional(rollbackFor = Exception.class)
    public Boolean updateByBo(EimsEquStatuBo bo) {
        EimsEquStatu update = MapstructUtils.convert(bo, EimsEquStatu.class);
        validEntityBeforeSave(update);
        boolean result = baseMapper.updateById(update) > 0;
        // 同意时同步设备状态
        if ("1".equals(String.valueOf(bo.getOrderStatus()))) {
            EimsEquStatuVo vo = baseMapper.selectVoById(bo.getEquStatuId());
            EimsEquBo equBo = new EimsEquBo();
            equBo.setEquId(vo.getEquId());
            equBo.setStatus(vo.getAfterChange());
            equService.updateByBo(equBo);
        }
        return result;
    }
 
    /**
     * 保存前的数据校验
     */
    private void validEntityBeforeSave(EimsEquStatu entity){
        //TODO 做一些数据校验,如唯一约束
    }
 
    /**
     * 校验并批量删除设备状态记录信息
     *
     * @param ids     待删除的主键集合
     * @param isValid 是否进行有效性校验
     * @return 是否删除成功
     */
    @Override
    public Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid) {
        if(isValid){
            //TODO 做一些业务上的校验,判断是否需要校验
        }
        return baseMapper.deleteByIds(ids) > 0;
    }
}