package com.doumee.service.business.impl; import com.doumee.core.model.PageData; import com.doumee.core.model.PageWrap; import com.doumee.core.utils.Utils; import com.doumee.dao.business.RoomRecordMapper; import com.doumee.dao.business.join.RoomRecordJoinMapper; import com.doumee.dao.business.model.Bookings; import com.doumee.dao.business.model.Devices; import com.doumee.dao.business.model.RoomRecord; import com.doumee.dao.business.model.Rooms; import com.doumee.dao.system.model.SystemUser; import com.doumee.service.business.RoomRecordService; 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.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import org.springframework.util.CollectionUtils; import java.util.List; /** * 会议室开门记录表Service实现 * @author 江蹄蹄 * @date 2023/05/05 18:25 */ @Service public class RoomRecordServiceImpl implements RoomRecordService { @Autowired private RoomRecordMapper roomRecordMapper; @Autowired private RoomRecordJoinMapper roomRecordJoinMapper; @Override public Integer create(RoomRecord roomRecord) { roomRecordMapper.insert(roomRecord); return roomRecord.getId(); } @Override public void deleteById(Integer id) { roomRecordMapper.deleteById(id); } @Override public void delete(RoomRecord roomRecord) { UpdateWrapper deleteWrapper = new UpdateWrapper<>(roomRecord); roomRecordMapper.delete(deleteWrapper); } @Override public void deleteByIdInBatch(List ids) { if (CollectionUtils.isEmpty(ids)) { return; } roomRecordMapper.deleteBatchIds(ids); } @Override public void updateById(RoomRecord roomRecord) { roomRecordMapper.updateById(roomRecord); } @Override public void updateByIdInBatch(List roomRecords) { if (CollectionUtils.isEmpty(roomRecords)) { return; } for (RoomRecord roomRecord: roomRecords) { this.updateById(roomRecord); } } @Override public RoomRecord findById(Integer id) { return roomRecordMapper.selectById(id); } @Override public RoomRecord findOne(RoomRecord roomRecord) { QueryWrapper wrapper = new QueryWrapper<>(roomRecord); return roomRecordMapper.selectOne(wrapper); } @Override public List findList(RoomRecord roomRecord) { QueryWrapper wrapper = new QueryWrapper<>(roomRecord); return roomRecordMapper.selectList(wrapper); } @Override public PageData findPage(PageWrap pageWrap) { IPage page = new Page<>(pageWrap.getPage(), pageWrap.getCapacity()); MPJLambdaWrapper queryWrapper = new MPJLambdaWrapper<>(); Utils.MP.blankToNull(pageWrap.getModel()); queryWrapper.selectAll(RoomRecord.class) .selectAs(Rooms::getName,RoomRecord::getRoomName) .selectAs(SystemUser::getRealname,RoomRecord::getUserName) .selectAs(Bookings::getName,RoomRecord::getMeeting) .leftJoin(Rooms.class,Rooms::getId,RoomRecord::getRoomId) .leftJoin(Bookings.class,Bookings::getId,RoomRecord::getObjId) .leftJoin(SystemUser.class,SystemUser::getId,RoomRecord::getUserId); queryWrapper.like(pageWrap.getModel().getUserName() != null,SystemUser::getRealname, pageWrap.getModel().getUserName()); queryWrapper.like(pageWrap.getModel().getRoomId() != null,Rooms::getId, pageWrap.getModel().getRoomId()); queryWrapper.like(pageWrap.getModel().getMeeting() != null,Bookings::getName, pageWrap.getModel().getMeeting()); queryWrapper.like(pageWrap.getModel().getObjType() != null,RoomRecord::getObjType, pageWrap.getModel().getObjType()); if (pageWrap.getModel().getStartDate() != null) { queryWrapper.ge(RoomRecord::getCreateDate, pageWrap.getModel().getStartDate()); } if (pageWrap.getModel().getEndDate() != null) { queryWrapper.le(RoomRecord::getCreateDate, pageWrap.getModel().getEndDate()); } queryWrapper.orderByDesc(RoomRecord::getCreateDate); return PageData.from(roomRecordJoinMapper.selectJoinPage(page, RoomRecord.class,queryWrapper)); } @Override public long count(RoomRecord roomRecord) { QueryWrapper wrapper = new QueryWrapper<>(roomRecord); return roomRecordMapper.selectCount(wrapper); } }