package com.pz.system.service.impl; import cn.hutool.core.bean.BeanUtil; import com.baomidou.mybatisplus.core.toolkit.StringUtils; import com.pz.common.core.page.TableDataInfo; import com.pz.common.core.domain.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.springframework.stereotype.Service; import com.pz.system.domain.bo.DbmyOrderBo; import com.pz.system.domain.vo.DbmyOrderVo; import com.pz.system.domain.DbmyOrder; import com.pz.system.mapper.DbmyOrderMapper; import com.pz.system.service.IDbmyOrderService; import java.util.List; import java.util.Map; import java.util.Collection; /** * 代办买药订单Service业务层处理 * * @author ruoyi * @date 2023-09-11 */ @RequiredArgsConstructor @Service public class DbmyOrderServiceImpl implements IDbmyOrderService { private final DbmyOrderMapper baseMapper; /** * 查询代办买药订单 */ @Override public DbmyOrderVo queryById(Integer id){ return baseMapper.selectVoById(id); } /** * 查询代办买药订单列表 */ @Override public TableDataInfo<DbmyOrderVo> queryPageList(DbmyOrderBo bo, PageQuery pageQuery) { Page<DbmyOrderVo> result = baseMapper.findDbmyOrderVoPage(pageQuery.build(), bo); return TableDataInfo.build(result); } /** * 查询代办买药订单列表 */ @Override public List<DbmyOrderVo> queryList(DbmyOrderBo bo) { LambdaQueryWrapper<DbmyOrder> lqw = buildQueryWrapper(bo); return baseMapper.selectVoList(lqw); } private LambdaQueryWrapper<DbmyOrder> buildQueryWrapper(DbmyOrderBo bo) { Map<String, Object> params = bo.getParams(); LambdaQueryWrapper<DbmyOrder> lqw = Wrappers.lambdaQuery(); lqw.eq(bo.getOrderId() != null, DbmyOrder::getOrderId, bo.getOrderId()); lqw.like(StringUtils.isNotBlank(bo.getYpName()), DbmyOrder::getYpName, bo.getYpName()); lqw.eq(StringUtils.isNotBlank(bo.getYdAddress()), DbmyOrder::getYdAddress, bo.getYdAddress()); lqw.eq(bo.getIsCf() != null, DbmyOrder::getIsCf, bo.getIsCf()); lqw.eq(StringUtils.isNotBlank(bo.getPrescriptionAttachment()), DbmyOrder::getPrescriptionAttachment, bo.getPrescriptionAttachment()); lqw.eq(bo.getWay() != null, DbmyOrder::getWay, bo.getWay()); lqw.eq(StringUtils.isNotBlank(bo.getRecipient()), DbmyOrder::getRecipient, bo.getRecipient()); lqw.eq(StringUtils.isNotBlank(bo.getAdress()), DbmyOrder::getAdress, bo.getAdress()); lqw.eq(StringUtils.isNotBlank(bo.getAddressInfo()), DbmyOrder::getAddressInfo, bo.getAddressInfo()); lqw.eq(StringUtils.isNotBlank(bo.getPhone()), DbmyOrder::getPhone, bo.getPhone()); lqw.eq(bo.getIsRefrigerate() != null, DbmyOrder::getIsRefrigerate, bo.getIsRefrigerate()); lqw.eq(bo.getStatus() != null, DbmyOrder::getStatus, bo.getStatus()); lqw.eq(bo.getOverTime() != null, DbmyOrder::getOverTime, bo.getOverTime()); lqw.eq(StringUtils.isNotBlank(bo.getVoucher()), DbmyOrder::getVoucher, bo.getVoucher()); lqw.eq(StringUtils.isNotBlank(bo.getPzShr()), DbmyOrder::getPzShr, bo.getPzShr()); lqw.eq(StringUtils.isNotBlank(bo.getPzAddress()), DbmyOrder::getPzAddress, bo.getPzAddress()); lqw.eq(StringUtils.isNotBlank(bo.getPzShPhone()), DbmyOrder::getPzShPhone, bo.getPzShPhone()); lqw.eq(StringUtils.isNotBlank(bo.getPzShRemake()), DbmyOrder::getPzShRemake, bo.getPzShRemake()); return lqw; } /** * 新增代办买药订单 */ @Override public Boolean insertByBo(DbmyOrderBo bo) { DbmyOrder add = BeanUtil.toBean(bo, DbmyOrder.class); validEntityBeforeSave(add); boolean flag = baseMapper.insert(add) > 0; if (flag) { bo.setId(add.getId()); } return flag; } /** * 修改代办买药订单 */ @Override public Boolean updateByBo(DbmyOrderBo bo) { DbmyOrder update = BeanUtil.toBean(bo, DbmyOrder.class); validEntityBeforeSave(update); return baseMapper.updateById(update) > 0; } /** * 保存前的数据校验 */ private void validEntityBeforeSave(DbmyOrder entity){ //TODO 做一些数据校验,如唯一约束 } /** * 批量删除代办买药订单 */ @Override public Boolean deleteWithValidByIds(Collection<Integer> ids, Boolean isValid) { if(isValid){ //TODO 做一些业务上的校验,判断是否需要校验 } return baseMapper.deleteBatchIds(ids) > 0; } }