package com.doumee.service.business.impl; 
 | 
  
 | 
import com.doumee.service.business.third.model.PageData; 
 | 
import com.doumee.service.business.third.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.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<RoomRecord> deleteWrapper = new UpdateWrapper<>(roomRecord); 
 | 
        roomRecordMapper.delete(deleteWrapper); 
 | 
    } 
 | 
  
 | 
    @Override 
 | 
    public void deleteByIdInBatch(List<Integer> ids) { 
 | 
        if (CollectionUtils.isEmpty(ids)) { 
 | 
            return; 
 | 
        } 
 | 
        roomRecordMapper.deleteBatchIds(ids); 
 | 
    } 
 | 
  
 | 
    @Override 
 | 
    public void updateById(RoomRecord roomRecord) { 
 | 
        roomRecordMapper.updateById(roomRecord); 
 | 
    } 
 | 
  
 | 
    @Override 
 | 
    public void updateByIdInBatch(List<RoomRecord> 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<RoomRecord> wrapper = new QueryWrapper<>(roomRecord); 
 | 
        return roomRecordMapper.selectOne(wrapper); 
 | 
    } 
 | 
  
 | 
    @Override 
 | 
    public List<RoomRecord> findList(RoomRecord roomRecord) { 
 | 
        QueryWrapper<RoomRecord> wrapper = new QueryWrapper<>(roomRecord); 
 | 
        return roomRecordMapper.selectList(wrapper); 
 | 
    } 
 | 
   
 | 
    @Override 
 | 
    public PageData<RoomRecord> findPage(PageWrap<RoomRecord> pageWrap) { 
 | 
        IPage<RoomRecord> page = new Page<>(pageWrap.getPage(), pageWrap.getCapacity()); 
 | 
  
 | 
        MPJLambdaWrapper<RoomRecord> 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<RoomRecord> wrapper = new QueryWrapper<>(roomRecord); 
 | 
        return roomRecordMapper.selectCount(wrapper); 
 | 
    } 
 | 
} 
 |