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.PlatformQueueMapper; import com.doumee.dao.business.model.PlatformQueue; import com.doumee.service.business.PlatformQueueService; 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 org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import org.springframework.util.CollectionUtils; import java.util.List; /** * 月台_叫号排队信息表Service实现 * @author 江蹄蹄 * @date 2024/06/28 10:03 */ @Service public class PlatformQueueServiceImpl implements PlatformQueueService { @Autowired private PlatformQueueMapper platformQueueMapper; @Override public Integer create(PlatformQueue platformQueue) { platformQueueMapper.insert(platformQueue); return platformQueue.getId(); } @Override public void deleteById(Integer id) { platformQueueMapper.deleteById(id); } @Override public void delete(PlatformQueue platformQueue) { UpdateWrapper deleteWrapper = new UpdateWrapper<>(platformQueue); platformQueueMapper.delete(deleteWrapper); } @Override public void deleteByIdInBatch(List ids) { if (CollectionUtils.isEmpty(ids)) { return; } platformQueueMapper.deleteBatchIds(ids); } @Override public void updateById(PlatformQueue platformQueue) { platformQueueMapper.updateById(platformQueue); } @Override public void updateByIdInBatch(List platformQueues) { if (CollectionUtils.isEmpty(platformQueues)) { return; } for (PlatformQueue platformQueue: platformQueues) { this.updateById(platformQueue); } } @Override public PlatformQueue findById(Integer id) { return platformQueueMapper.selectById(id); } @Override public PlatformQueue findOne(PlatformQueue platformQueue) { QueryWrapper wrapper = new QueryWrapper<>(platformQueue); return platformQueueMapper.selectOne(wrapper); } @Override public List findList(PlatformQueue platformQueue) { QueryWrapper wrapper = new QueryWrapper<>(platformQueue); return platformQueueMapper.selectList(wrapper); } @Override public PageData findPage(PageWrap pageWrap) { IPage page = new Page<>(pageWrap.getPage(), pageWrap.getCapacity()); QueryWrapper queryWrapper = new QueryWrapper<>(); Utils.MP.blankToNull(pageWrap.getModel()); queryWrapper.lambda() .eq(pageWrap.getModel().getId() != null, PlatformQueue::getId, pageWrap.getModel().getId()) .eq(pageWrap.getModel().getCreator() != null, PlatformQueue::getCreator, pageWrap.getModel().getCreator()) .ge(pageWrap.getModel().getCreateDate() != null, PlatformQueue::getCreateDate, Utils.Date.getStart(pageWrap.getModel().getCreateDate())) .le(pageWrap.getModel().getCreateDate() != null, PlatformQueue::getCreateDate, Utils.Date.getEnd(pageWrap.getModel().getCreateDate())) .eq(pageWrap.getModel().getEditor() != null, PlatformQueue::getEditor, pageWrap.getModel().getEditor()) .ge(pageWrap.getModel().getEditDate() != null, PlatformQueue::getEditDate, Utils.Date.getStart(pageWrap.getModel().getEditDate())) .le(pageWrap.getModel().getEditDate() != null, PlatformQueue::getEditDate, Utils.Date.getEnd(pageWrap.getModel().getEditDate())) .eq(pageWrap.getModel().getIsdeleted() != null, PlatformQueue::getIsdeleted, pageWrap.getModel().getIsdeleted()) .eq(pageWrap.getModel().getRemark() != null, PlatformQueue::getRemark, pageWrap.getModel().getRemark()) .eq(pageWrap.getModel().getJobId() != null, PlatformQueue::getJobId, pageWrap.getModel().getJobId()) .eq(pageWrap.getModel().getContent() != null, PlatformQueue::getContent, pageWrap.getModel().getContent()) .eq(pageWrap.getModel().getStatus() != null, PlatformQueue::getStatus, pageWrap.getModel().getStatus()) .eq(pageWrap.getModel().getObjType() != null, PlatformQueue::getObjType, pageWrap.getModel().getObjType()) .eq(pageWrap.getModel().getObjId() != null, PlatformQueue::getObjId, pageWrap.getModel().getObjId()) .eq(pageWrap.getModel().getCarCode() != null, PlatformQueue::getCarCode, pageWrap.getModel().getCarCode()) .eq(pageWrap.getModel().getPlatformId() != null, PlatformQueue::getPlatformId, pageWrap.getModel().getPlatformId()) .eq(pageWrap.getModel().getPlatformName() != null, PlatformQueue::getPlatformName, pageWrap.getModel().getPlatformName()) .eq(pageWrap.getModel().getDriverPhone() != null, PlatformQueue::getDriverPhone, pageWrap.getModel().getDriverPhone()) .eq(pageWrap.getModel().getDriverName() != null, PlatformQueue::getDriverName, pageWrap.getModel().getDriverName()) .eq(pageWrap.getModel().getDriverId() != null, PlatformQueue::getDriverId, pageWrap.getModel().getDriverId()) .eq(pageWrap.getModel().getOrderCode() != null, PlatformQueue::getOrderCode, pageWrap.getModel().getOrderCode()) ; for(PageWrap.SortData sortData: pageWrap.getSorts()) { if (sortData.getDirection().equalsIgnoreCase(PageWrap.DESC)) { queryWrapper.orderByDesc(sortData.getProperty()); } else { queryWrapper.orderByAsc(sortData.getProperty()); } } return PageData.from(platformQueueMapper.selectPage(page, queryWrapper)); } @Override public long count(PlatformQueue platformQueue) { QueryWrapper wrapper = new QueryWrapper<>(platformQueue); return platformQueueMapper.selectCount(wrapper); } }