package com.doumee.service.business.impl; import com.doumee.core.constants.ResponseStatus; import com.doumee.core.exception.BusinessException; import com.doumee.core.model.LoginUserInfo; import com.doumee.core.model.PageData; import com.doumee.core.model.PageWrap; import com.doumee.core.utils.Constants; import com.doumee.core.utils.DateUtil; import com.doumee.core.utils.Utils; import com.doumee.dao.business.YwElectricalLogMapper; import com.doumee.dao.business.model.YwElectricalLog; import com.doumee.service.business.YwElectricalLogService; import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper; import com.baomidou.mybatisplus.core.metadata.IPage; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.github.yulichang.wrapper.MPJLambdaWrapper; import org.apache.commons.lang3.StringUtils; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import org.springframework.util.CollectionUtils; import java.util.Date; import java.util.List; import java.util.Objects; /** * 电器类操作日志Service实现 * @author renkang * @date 2026/04/03 */ @Service public class YwElectricalLogServiceImpl implements YwElectricalLogService { @Autowired private YwElectricalLogMapper ywElectricalLogMapper; @Override public Integer create(YwElectricalLog ywElectricalLog) { if (Objects.isNull(ywElectricalLog) || StringUtils.isBlank(ywElectricalLog.getName())) { throw new BusinessException(ResponseStatus.BAD_REQUEST); } LoginUserInfo loginUserInfo = ywElectricalLog.getLoginUserInfo(); ywElectricalLog.setCreateDate(new Date()); ywElectricalLog.setCreator(loginUserInfo.getId()); ywElectricalLog.setEditDate(new Date()); ywElectricalLog.setEditor(loginUserInfo.getId()); ywElectricalLog.setIsdeleted(Constants.ZERO); ywElectricalLogMapper.insert(ywElectricalLog); return ywElectricalLog.getId(); } @Override public void deleteById(Integer id, LoginUserInfo user) { ywElectricalLogMapper.update(new UpdateWrapper() .lambda() .set(YwElectricalLog::getIsdeleted, Constants.ONE) .set(YwElectricalLog::getEditDate, DateUtil.getCurrDateTime()) .set(YwElectricalLog::getEditor, user.getId()) .eq(YwElectricalLog::getId, id) ); } @Override public void deleteByIdInBatch(List ids, LoginUserInfo user) { if (CollectionUtils.isEmpty(ids)) { return; } for (Integer id : ids) { this.deleteById(id, user); } } @Override public void updateById(YwElectricalLog ywElectricalLog) { if (Objects.isNull(ywElectricalLog) || Objects.isNull(ywElectricalLog.getId())) { throw new BusinessException(ResponseStatus.BAD_REQUEST); } LoginUserInfo loginUserInfo = ywElectricalLog.getLoginUserInfo(); ywElectricalLog.setEditDate(new Date()); ywElectricalLog.setEditor(loginUserInfo.getId()); ywElectricalLogMapper.updateById(ywElectricalLog); } @Override public YwElectricalLog findById(Integer id) { return ywElectricalLogMapper.selectOne(new QueryWrapper().lambda() .eq(YwElectricalLog::getId, id) .last(" limit 1 ")); } @Override public PageData findPage(PageWrap pageWrap) { IPage page = new Page<>(pageWrap.getPage(), pageWrap.getCapacity()); MPJLambdaWrapper queryWrapper = new MPJLambdaWrapper<>(); Utils.MP.blankToNull(pageWrap.getModel()); YwElectricalLog model = pageWrap.getModel(); queryWrapper.selectAll(YwElectricalLog.class) .and(Objects.nonNull(model) && StringUtils.isNotBlank(model.getName()), i -> i.like(YwElectricalLog::getName, model.getName())) .eq(Objects.nonNull(model) && Objects.nonNull(model.getDeviceType()), YwElectricalLog::getDeviceType, model.getDeviceType()) .eq(Objects.nonNull(model) && Objects.nonNull(model.getType()), YwElectricalLog::getType, model.getType()) .eq(Objects.nonNull(model) && Objects.nonNull(model.getSuccess()), YwElectricalLog::getSuccess, model.getSuccess()) .eq(YwElectricalLog::getIsdeleted, Constants.ZERO) .orderByDesc(YwElectricalLog::getCreateDate); IPage iPage = ywElectricalLogMapper.selectJoinPage(page, YwElectricalLog.class, queryWrapper); return PageData.from(iPage); } }