package com.zy.asrs.service.impl; import com.baomidou.mybatisplus.mapper.EntityWrapper; import com.baomidou.mybatisplus.plugins.Page; import com.baomidou.mybatisplus.service.impl.ServiceImpl; import com.core.exception.CoolException; import com.zy.asrs.entity.*; import com.zy.asrs.entity.param.LocDetlAdjustParam; import com.zy.asrs.entity.result.StockVo; import com.zy.asrs.mapper.ManLocDetlMapper; import com.zy.asrs.service.ManLocDetlService; import com.zy.asrs.service.MatService; import com.zy.asrs.service.NodeService; import com.zy.asrs.utils.SaasUtils; import com.zy.system.entity.User; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; import java.util.*; @Service("manLocDetlService") public class ManLocDetlServiceImpl extends ServiceImpl implements ManLocDetlService { @Autowired private MatService matService; @Autowired private NodeService nodeService; @Override public Page getPage(Page page) { Map condition = page.getCondition(); List manLocDetls = baseMapper.listByPage(condition); page.setRecords(manLocDetls); page.setTotal(baseMapper.listByPageCount(page.getCondition())); return page; } @Override public Page getStockOut(Page page) { page.setRecords(baseMapper.getStockOutPage(page.getCondition())); page.setTotal(baseMapper.getStockOutPageCount(page.getCondition())); return page; } @Override public boolean updateAnfme(Double anfme, String locNo, String matnr, String batch) { if (anfme <= 0) { return this.baseMapper.deleteItem(locNo, matnr, batch) > 0; } else { return baseMapper.updateAnfme(anfme, locNo, matnr, batch) > 0; } } @Override public boolean updateLocNo(String newLocNo, String oldLocNo) { return baseMapper.updateLocNo(newLocNo, oldLocNo) > 0; } @Override public List getSameDetlToday(String matnr, Integer start, Integer end) { return this.baseMapper.selectSameDetlToday(matnr, start, end); } @Override public Page getStockStatis(Page page) { page.setRecords(baseMapper.getStockStatis(page.getCondition())); page.setTotal(baseMapper.getStockStatisCount(page.getCondition())); return page; } @Override public Double getSumAnfme(String matnr) { return this.baseMapper.selectSumAnfmeByMatnr(matnr); } @Override public List selectPakoutByRule(String matnr) { return this.baseMapper.selectPakoutByRule(matnr); } @Override public List getAsrsLocDetl(String matnr) { return this.baseMapper.getAsrsLocDetl(matnr); } @Override public Integer countLocNoNum(String locNo) { return this.baseMapper.countLocNoNum(locNo); } @Override public List queryStock(String matnr,String batch) { return this.baseMapper.queryStock(matnr,batch); } @Override public Double queryStockAnfme(String matnr, String batch) { return this.baseMapper.queryStockAnfme(matnr, batch); } @Override public List queryStockTotal() { return this.baseMapper.queryStockTotal(); } /** * 获取库存总数 * * @return */ @Override public Integer sum() { return this.baseMapper.sum(); } @Override public List unreason() { return this.baseMapper.unreason(); } @Override public ManLocDetl selectItem(String locNo, String matnr, String batch) { return this.baseMapper.selectItem(locNo, matnr, batch); } @Override public Double getLocDetlSumQty(String locNo) { return this.baseMapper.selectLocDetlSumQty(locNo); } @Override public Page getOutPage(Page manLocDetlPage) { Map condition = manLocDetlPage.getCondition(); List manLocDetls = baseMapper.listByOutPage(condition); manLocDetlPage.setRecords(manLocDetls); manLocDetlPage.setTotal(baseMapper.listByOutPageCount(manLocDetlPage.getCondition())); return manLocDetlPage; } @Transactional @Override public void adjustLocDetl(LocDetlAdjustParam param, Long userId, User user) { Date now = new Date(); for (LocDetlAdjustParam.LocDetlAdjust locDetlAdjust : param.getList()) { ManLocDetl manLocDetl = this.baseMapper.selectItem(param.getLocNo(), locDetlAdjust.getMatnr(), locDetlAdjust.getBatch()); this.baseMapper.delete(new EntityWrapper() .eq("loc_no", param.getLocNo()).eq("matnr",locDetlAdjust.getMatnr())); Mat mat = matService.selectOne(new EntityWrapper() .eq("matnr", locDetlAdjust.getMatnr())); if (mat == null) { throw new CoolException("无法找到需要调整的物料,请联系管理员"); } Node node = nodeService.selectOne(new EntityWrapper() .eq("uuid", param.getLocNo())); if (node == null) { throw new CoolException("无法找到需要调整的库位,请联系管理员"); } manLocDetl.setAnfme(locDetlAdjust.getCount()); manLocDetl.setUpdateBy(userId); manLocDetl.setModiTime(now); SaasUtils.insertLog(3,manLocDetl.getLocNo(), manLocDetl.getMatnr(),manLocDetl.getAnfme(),user.getUsername(), null,null,null,null, null,null); this.baseMapper.insert(manLocDetl); } } @Override public Page selectAllPage(Page param) { Map condition = param.getCondition(); List manLocDetls = baseMapper.selectAllPage(condition); param.setRecords(manLocDetls); param.setTotal(baseMapper.selectAllPageSize(condition)); return param; } @Override public ManLocDetl selectInventory(String LocNo, String Matnr, String batch) { return baseMapper.selectInventory(LocNo,Matnr,batch); } @Override public int deleteDatailed(String locNo, String matnr, String batch) { return baseMapper.deleteDatailed(locNo,matnr,batch); } @Override public int increase(Double anfme,String locNo, String matnr, String batch,Double weight) { return baseMapper.increase(anfme,locNo,matnr,batch,weight); } @Override public List selectAllWarning() { return baseMapper.selectAllWarning(); } @Override public List selectByLocNo(String locNo) { return this.baseMapper.selectByLocNo(locNo); } @Override public int updateStockFreeze(String matnr, String locNo, Integer stockFreeze) { return this.baseMapper.updateStockFreeze(matnr, locNo, stockFreeze); } }