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 queryPageList(EimsEquStatuBo bo, PageQuery pageQuery) { // 使用自定义SQL实现设备状态与设备表的模糊关联分页查询 Page page = pageQuery.build(); List list = baseMapper.selectEquStatuPage(bo, pageQuery); page.setRecords(list); return TableDataInfo.build(page); } /** * 查询符合条件的设备状态记录列表 * * @param bo 查询条件 * @return 设备状态记录列表 */ @Override public List queryList(EimsEquStatuBo bo) { LambdaQueryWrapper lqw = buildQueryWrapper(bo); return baseMapper.selectVoList(lqw); } private LambdaQueryWrapper buildQueryWrapper(EimsEquStatuBo bo) { Map params = bo.getParams(); LambdaQueryWrapper 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 ids, Boolean isValid) { if(isValid){ //TODO 做一些业务上的校验,判断是否需要校验 } return baseMapper.deleteByIds(ids) > 0; } }