| package doumeemes.service.business.impl; | 
|   | 
| import doumeemes.core.constants.ResponseStatus; | 
| import doumeemes.core.exception.BusinessException; | 
| import doumeemes.core.model.LoginUserInfo; | 
| import doumeemes.core.model.PageData; | 
| import doumeemes.core.model.PageWrap; | 
| import doumeemes.core.utils.Constants; | 
| import doumeemes.core.utils.Utils; | 
| import doumeemes.dao.business.SalesorderMapper; | 
| import doumeemes.dao.business.model.Salesorder; | 
| import doumeemes.service.business.SalesorderService; | 
| 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.apache.shiro.SecurityUtils; | 
| import org.springframework.beans.factory.annotation.Autowired; | 
| import org.springframework.stereotype.Service; | 
| import org.springframework.util.CollectionUtils; | 
|   | 
| import java.util.List; | 
|   | 
| /** | 
|  * 订单类-销售订单信息表Service实现 | 
|  * @author 江蹄蹄 | 
|  * @date 2022/07/27 11:14 | 
|  */ | 
| @Service | 
| public class SalesorderServiceImpl implements SalesorderService { | 
|   | 
|     @Autowired | 
|     private SalesorderMapper salesorderMapper; | 
|   | 
|     @Override | 
|     public Integer create(Salesorder salesorder) { | 
|         salesorderMapper.insert(salesorder); | 
|         return salesorder.getId(); | 
|     } | 
|   | 
|     @Override | 
|     public void deleteById(Integer id) { | 
|         salesorderMapper.deleteById(id); | 
|     } | 
|   | 
|     @Override | 
|     public void delete(Salesorder salesorder) { | 
|         UpdateWrapper<Salesorder> deleteWrapper = new UpdateWrapper<>(salesorder); | 
|         salesorderMapper.delete(deleteWrapper); | 
|     } | 
|   | 
|     @Override | 
|     public void deleteByIdInBatch(List<Integer> ids) { | 
|         if (CollectionUtils.isEmpty(ids)) { | 
|             return; | 
|         } | 
|         salesorderMapper.deleteBatchIds(ids); | 
|     } | 
|   | 
|     @Override | 
|     public void updateById(Salesorder salesorder) { | 
|         salesorderMapper.updateById(salesorder); | 
|     } | 
|   | 
|     @Override | 
|     public void updateByIdInBatch(List<Salesorder> salesorders) { | 
|         if (CollectionUtils.isEmpty(salesorders)) { | 
|             return; | 
|         } | 
|         for (Salesorder salesorder: salesorders) { | 
|             this.updateById(salesorder); | 
|         } | 
|     } | 
|   | 
|     @Override | 
|     public Salesorder findById(Integer id) { | 
|         return salesorderMapper.selectById(id); | 
|     } | 
|   | 
|     @Override | 
|     public Salesorder findOne(Salesorder salesorder) { | 
|         QueryWrapper<Salesorder> wrapper = new QueryWrapper<>(salesorder); | 
|         return salesorderMapper.selectOne(wrapper); | 
|     } | 
|   | 
|     @Override | 
|     public List<Salesorder> findList(Salesorder salesorder) { | 
|         LoginUserInfo user = (LoginUserInfo) SecurityUtils.getSubject().getPrincipal(); | 
|         if(!Constants.equalsInteger(user.getType(),Constants.USERTYPE.COM)){ | 
|             throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(), "对不起,您无权限进行该操作!"); | 
|         } | 
|         salesorder.setRootDepartId(user.getRootDepartment().getId()); | 
|         salesorder.setDeleted(Constants.ZERO); | 
|         salesorder.setDepartId(user.getCurComDepartment().getId()); | 
|         return salesorderMapper.selectList(salesorder); | 
|     } | 
|    | 
|     @Override | 
|     public PageData<Salesorder> findPage(PageWrap<Salesorder> pageWrap) { | 
|         IPage<Salesorder> page = new Page<>(pageWrap.getPage(), pageWrap.getCapacity()); | 
|         QueryWrapper<Salesorder> queryWrapper = new QueryWrapper<>(); | 
|         Utils.MP.blankToNull(pageWrap.getModel()); | 
|         if (pageWrap.getModel().getId() != null) { | 
|             queryWrapper.lambda().eq(Salesorder::getId, pageWrap.getModel().getId()); | 
|         } | 
|         if (pageWrap.getModel().getDeleted() != null) { | 
|             queryWrapper.lambda().eq(Salesorder::getDeleted, pageWrap.getModel().getDeleted()); | 
|         } | 
|         if (pageWrap.getModel().getCreateUser() != null) { | 
|             queryWrapper.lambda().eq(Salesorder::getCreateUser, pageWrap.getModel().getCreateUser()); | 
|         } | 
|         if (pageWrap.getModel().getCreateTime() != null) { | 
|             queryWrapper.lambda().ge(Salesorder::getCreateTime, Utils.Date.getStart(pageWrap.getModel().getCreateTime())); | 
|             queryWrapper.lambda().le(Salesorder::getCreateTime, Utils.Date.getEnd(pageWrap.getModel().getCreateTime())); | 
|         } | 
|         if (pageWrap.getModel().getUpdateUser() != null) { | 
|             queryWrapper.lambda().eq(Salesorder::getUpdateUser, pageWrap.getModel().getUpdateUser()); | 
|         } | 
|         if (pageWrap.getModel().getUpdateTime() != null) { | 
|             queryWrapper.lambda().ge(Salesorder::getUpdateTime, Utils.Date.getStart(pageWrap.getModel().getUpdateTime())); | 
|             queryWrapper.lambda().le(Salesorder::getUpdateTime, Utils.Date.getEnd(pageWrap.getModel().getUpdateTime())); | 
|         } | 
|         if (pageWrap.getModel().getRemark() != null) { | 
|             queryWrapper.lambda().eq(Salesorder::getRemark, pageWrap.getModel().getRemark()); | 
|         } | 
|         if (pageWrap.getModel().getRootDepartId() != null) { | 
|             queryWrapper.lambda().eq(Salesorder::getRootDepartId, pageWrap.getModel().getRootDepartId()); | 
|         } | 
|         if (pageWrap.getModel().getDepartId() != null) { | 
|             queryWrapper.lambda().eq(Salesorder::getDepartId, pageWrap.getModel().getDepartId()); | 
|         } | 
|         if (pageWrap.getModel().getCustomerId() != null) { | 
|             queryWrapper.lambda().eq(Salesorder::getCustomerId, pageWrap.getModel().getCustomerId()); | 
|         } | 
|         if (pageWrap.getModel().getCode() != null) { | 
|             queryWrapper.lambda().eq(Salesorder::getCode, pageWrap.getModel().getCode()); | 
|         } | 
|         if (pageWrap.getModel().getCustomerCate() != null) { | 
|             queryWrapper.lambda().eq(Salesorder::getCustomerCate, pageWrap.getModel().getCustomerCate()); | 
|         } | 
|         if (pageWrap.getModel().getArea() != null) { | 
|             queryWrapper.lambda().eq(Salesorder::getArea, pageWrap.getModel().getArea()); | 
|         } | 
|         if (pageWrap.getModel().getSaleUserId() != null) { | 
|             queryWrapper.lambda().eq(Salesorder::getSaleUserId, pageWrap.getModel().getSaleUserId()); | 
|         } | 
|         if (pageWrap.getModel().getOrigin() != null) { | 
|             queryWrapper.lambda().eq(Salesorder::getOrigin, pageWrap.getModel().getOrigin()); | 
|         } | 
|         if (pageWrap.getModel().getType() != null) { | 
|             queryWrapper.lambda().eq(Salesorder::getType, pageWrap.getModel().getType()); | 
|         } | 
|         if (pageWrap.getModel().getOrderDate() != null) { | 
|             queryWrapper.lambda().ge(Salesorder::getOrderDate, Utils.Date.getStart(pageWrap.getModel().getOrderDate())); | 
|             queryWrapper.lambda().le(Salesorder::getOrderDate, Utils.Date.getEnd(pageWrap.getModel().getOrderDate())); | 
|         } | 
|         if (pageWrap.getModel().getAmount() != null) { | 
|             queryWrapper.lambda().eq(Salesorder::getAmount, pageWrap.getModel().getAmount()); | 
|         } | 
|         if (pageWrap.getModel().getUrgent() != null) { | 
|             queryWrapper.lambda().eq(Salesorder::getUrgent, pageWrap.getModel().getUrgent()); | 
|         } | 
|         if (pageWrap.getModel().getOriginOrderId() != null) { | 
|             queryWrapper.lambda().eq(Salesorder::getOriginOrderId, pageWrap.getModel().getOriginOrderId()); | 
|         } | 
|         if (pageWrap.getModel().getStatus() != null) { | 
|             queryWrapper.lambda().eq(Salesorder::getStatus, pageWrap.getModel().getStatus()); | 
|         } | 
|         for(PageWrap.SortData sortData: pageWrap.getSorts()) { | 
|             if (sortData.getDirection().equalsIgnoreCase(PageWrap.DESC)) { | 
|                 queryWrapper.orderByDesc(sortData.getProperty()); | 
|             } else { | 
|                 queryWrapper.orderByAsc(sortData.getProperty()); | 
|             } | 
|         } | 
|         return PageData.from(salesorderMapper.selectPage(page, queryWrapper)); | 
|     } | 
|   | 
|     @Override | 
|     public long count(Salesorder salesorder) { | 
|         QueryWrapper<Salesorder> wrapper = new QueryWrapper<>(salesorder); | 
|         return salesorderMapper.selectCount(wrapper); | 
|     } | 
| } |