|  |  | 
 |  |  | package com.zy.asrs.task.handler; | 
 |  |  |  | 
 |  |  | import com.baomidou.mybatisplus.mapper.EntityWrapper; | 
 |  |  | import com.zy.asrs.entity.*; | 
 |  |  | import com.core.common.Cools; | 
 |  |  | import com.zy.asrs.entity.LocDetl; | 
 |  |  | import com.zy.asrs.entity.LocMast; | 
 |  |  | import com.zy.asrs.entity.WrkDetl; | 
 |  |  | import com.zy.asrs.entity.WrkMast; | 
 |  |  | import com.zy.asrs.service.*; | 
 |  |  | import com.zy.asrs.task.AbstractHandler; | 
 |  |  | import com.zy.asrs.task.core.ReturnT; | 
 |  |  | import com.zy.asrs.utils.VersionUtils; | 
 |  |  | import lombok.extern.slf4j.Slf4j; | 
 |  |  | import org.springframework.beans.factory.annotation.Autowired; | 
 |  |  | import org.springframework.stereotype.Service; | 
 |  |  | import org.springframework.transaction.annotation.Transactional; | 
 |  |  | 
 |  |  | /** | 
 |  |  |  * Created by vincent on 2020/7/4 | 
 |  |  |  */ | 
 |  |  | @Slf4j | 
 |  |  | @Service | 
 |  |  | @Transactional | 
 |  |  | public class WorkMastHandler extends AbstractHandler<String> { | 
 |  |  | 
 |  |  |             if (null == locMast) { | 
 |  |  |                 exceptionHandle("工作档[workNo={0}]库位号错误[locNo={1}]", wrkMast.getWrkNo(), wrkMast.getLocNo()); | 
 |  |  |             } | 
 |  |  |             assert locMast != null; | 
 |  |  |             switch (wrkMast.getIoType()) { | 
 |  |  |                 // 空板入库 | 
 |  |  |                 case 10: | 
 |  |  |                     // 修改库位状态=D | 
 |  |  |                     if (locMast.getLocSts().equals("S") || locMast.getLocSts().equals("Q")) { | 
 |  |  |                         if (!Cools.isEmpty(wrkMast.getBarcode())) { | 
 |  |  |                             locMast.setBarcode(wrkMast.getBarcode()); | 
 |  |  |                         } | 
 |  |  |                         locMast.setLocSts("D"); | 
 |  |  |                         locMast.setIoTime(now); | 
 |  |  |                         locMast.setModiTime(now); | 
 |  |  | 
 |  |  |                     } | 
 |  |  |                     // 遍历工作明细,更新库存明细和入库通知档 | 
 |  |  |                     for (WrkDetl wrkDetl : wrkDetls) { | 
 |  |  |                         LocDetl locDetl = locDetlService.selectOne(new EntityWrapper<LocDetl>().eq("loc_no", wrkMast.getLocNo()).eq("matnr", wrkDetl.getMatnr())); | 
 |  |  |  | 
 |  |  |                         LocDetl locDetl = locDetlService.selectItem(locMast.getLocNo(), wrkDetl.getMatnr(), wrkDetl.getBatch()); | 
 |  |  |                         if (null != locDetl) { | 
 |  |  |                             boolean res = locDetlService.updateAnfme(wrkDetl.getAnfme(), wrkMast.getLocNo(), wrkDetl.getMatnr()); | 
 |  |  |                             if (!res) { | 
 |  |  |                             if (!locDetlService.updateAnfme(wrkDetl.getAnfme(), wrkMast.getLocNo(), wrkDetl.getMatnr(), wrkDetl.getBatch())) { | 
 |  |  |                                 exceptionHandle("全板入库 ===>> 更新库存明细失败;[workNo={0}],[locNo={1}]", wrkMast.getWrkNo(), wrkMast.getLocNo()); | 
 |  |  |                             } | 
 |  |  |                         } else { | 
 |  |  |                             locDetl = new LocDetl(); | 
 |  |  |                             locDetl.sync(wrkDetl); | 
 |  |  |                             locDetl.setLocNo(wrkMast.getLocNo()); // 库位号 | 
 |  |  |                             VersionUtils.setLocDetl(locDetl, wrkDetl); // 版本控制 | 
 |  |  |                             locDetl.setAnfme(wrkDetl.getAnfme()); // 数量 | 
 |  |  |                             locDetl.setZpallet(wrkDetl.getZpallet()); // 托盘条码 | 
 |  |  |                             locDetl.setModiTime(now); | 
 |  |  |                             locDetl.setAppeTime(now); | 
 |  |  |                             if (!locDetlService.insert(locDetl)) { | 
 |  |  |                                 exceptionHandle("全板入库 ===>> 添加库存明细失败;[workNo={0}],[locNo={1}]", wrkMast.getWrkNo(), wrkMast.getLocNo()); | 
 |  |  |                             } | 
 |  |  |                         } | 
 |  |  |  | 
 |  |  |                         // 更新入库通知档 ioStatus ===>> Y | 
 |  |  |                         try { | 
 |  |  |                             WaitPakin setParam = new WaitPakin(); | 
 |  |  |                             setParam.setIoStatus("Y"); | 
 |  |  |                             boolean updateRes = waitPakinService.update(setParam | 
 |  |  |                                     , new EntityWrapper<WaitPakin>().eq("zpallet", wrkDetl.getZpallet()) | 
 |  |  |                                             .eq("matnr", wrkDetl.getMatnr()) | 
 |  |  |                                             .eq("anfme", wrkDetl.getAnfme())); | 
 |  |  |                             if (!updateRes && updateRes) { | 
 |  |  |                                 exceptionHandle("全板入库 ===>> 更新入库通知档失败;[workNo={0}]", wrkMast.getWrkNo()); | 
 |  |  |                             } | 
 |  |  | //                            Wrapper<WaitPakin> wrapper = new EntityWrapper<WaitPakin>() | 
 |  |  | //                                    .eq("zpallet", wrkDetl.getZpallet()) | 
 |  |  | //                                    .eq("matnr", wrkDetl.getMatnr()) | 
 |  |  | //                                    .eq("anfme", wrkDetl.getAnfme()); | 
 |  |  | //                            if (Cools.isEmpty(wrkDetl.getBatch())) { | 
 |  |  | //                                wrapper.eq("batch", wrkDetl.getBatch()); | 
 |  |  | //                            } else { | 
 |  |  | //                                wrapper.isNull("batch").or().eq("batch", ""); | 
 |  |  | //                            } | 
 |  |  | //                            WaitPakin setParam = new WaitPakin(); | 
 |  |  | //                            setParam.setIoStatus("Y"); | 
 |  |  | //                            setParam.setModiTime(now); | 
 |  |  | //                            waitPakinService.update(setParam, wrapper); | 
 |  |  |                         } catch (Exception ignore){} | 
 |  |  |  | 
 |  |  |                     } | 
 |  |  | 
 |  |  |                     if (wrkDetls53.isEmpty()) { | 
 |  |  |                         exceptionHandle("拣料入库 ===>> 工作明细档为空;[workNo={0}]", wrkMast.getWrkNo()); | 
 |  |  |                     } | 
 |  |  |                     for (WrkDetl wrkDetl:wrkDetls53) { | 
 |  |  |                         // 修改库存明细数量,如果工作明细数量为0时,删除库存明细 | 
 |  |  |                         LocDetl locDetl = locDetlService.selectOne(new EntityWrapper<LocDetl>().eq("loc_no", locMast.getLocNo()).eq("matnr", wrkDetl.getMatnr())); | 
 |  |  |                     for (WrkDetl wrkDetl : wrkDetls53) { | 
 |  |  |  | 
 |  |  |                         LocDetl locDetl = locDetlService.selectItem(locMast.getLocNo(), wrkDetl.getMatnr(), wrkDetl.getBatch()); | 
 |  |  |                         if (null != locDetl) { | 
 |  |  |                             if (!locDetlService.updateAnfme(locDetl.getAnfme() - wrkDetl.getAnfme(), locMast.getLocNo(), wrkDetl.getMatnr())) { | 
 |  |  |                             if (!locDetlService.updateAnfme(locDetl.getAnfme() - wrkDetl.getAnfme(), locMast.getLocNo(), wrkDetl.getMatnr(), wrkDetl.getBatch())) { | 
 |  |  |                                 exceptionHandle("拣料入库 ===>> 修改库存明细数量失败;[workNo={0}],[locNo={1}]", wrkMast.getWrkNo(), wrkMast.getLocNo()); | 
 |  |  |                             } | 
 |  |  |                             // todo:luxiaotao 3)修改出库通知档 status ==> Y | 
 |  |  |                         } | 
 |  |  |                     } | 
 |  |  |                     // 修改库位状态 Q ====>> F | 
 |  |  | 
 |  |  |                     } | 
 |  |  |                     // 修改库存明细数量,如无库存,曾新增 | 
 |  |  |                     for (WrkDetl wrkDetl:wrkDetls54) { | 
 |  |  |                         LocDetl locDetl = locDetlService.selectOne(new EntityWrapper<LocDetl>().eq("loc_no", locMast.getLocNo()).eq("matnr", wrkDetl.getMatnr())); | 
 |  |  |  | 
 |  |  |                         LocDetl locDetl = locDetlService.selectItem(locMast.getLocNo(), wrkDetl.getMatnr(), wrkDetl.getBatch()); | 
 |  |  |                         if (null != locDetl) { | 
 |  |  |                             if (!locDetlService.updateAnfme(wrkDetl.getAnfme(), locMast.getLocNo(), wrkDetl.getMatnr())) { | 
 |  |  |                             if (!locDetlService.updateAnfme(wrkDetl.getAnfme(), locMast.getLocNo(), wrkDetl.getMatnr(), wrkDetl.getBatch())) { | 
 |  |  |                                 exceptionHandle("并板入库 ===>> 修改库存明细数量失败;[workNo={0}],[matnr={1}]", wrkMast.getWrkNo(), wrkDetl.getMatnr()); | 
 |  |  |                             } | 
 |  |  |                         } else { | 
 |  |  |                             locDetl = new LocDetl(); | 
 |  |  |                             locDetl.sync(wrkDetl); | 
 |  |  |                             locDetl.setLocNo(wrkMast.getLocNo()); // 库位号 | 
 |  |  |                             VersionUtils.setLocDetl(locDetl, wrkDetl); // 版本控制 | 
 |  |  |                             locDetl.setAnfme(wrkDetl.getAnfme()); // 数量 | 
 |  |  |                             locDetl.setZpallet(wrkDetl.getZpallet()); // 托盘条码 | 
 |  |  |                             locDetl.setModiTime(now); | 
 |  |  |                             locDetl.setAppeTime(now); | 
 |  |  |                             if (!locDetlService.insert(locDetl)) { | 
 |  |  |                                 exceptionHandle("并板入库 ===>> 新增库存明细失败;[workNo={0}],[matnr={1}]", wrkMast.getWrkNo(), wrkDetl.getMatnr()); | 
 |  |  |                             } | 
 |  |  |                         } | 
 |  |  |                         // todo:luxiaotao 3)修改出库通知档 status ==> Y | 
 |  |  |                     } | 
 |  |  |                     // 修改库位状态 Q ====>> F | 
 |  |  |                     if (locMast.getLocSts().equals("Q")) { | 
 |  |  | 
 |  |  |                     if (wrkDetls57.isEmpty()) { | 
 |  |  |                         exceptionHandle("盘点入库 ===>> 工作明细档为空;[workNo={0}]", wrkMast.getWrkNo()); | 
 |  |  |                     } | 
 |  |  |                     // todo:luxiaotao 3)修改盘点通知档 status ==> Y | 
 |  |  |                     // 修改库位状态 Q ====>> F | 
 |  |  |                     if (locMast.getLocSts().equals("Q")) { | 
 |  |  |                         locMast.setLocSts("F"); | 
 |  |  |                         locMast.setLocSts(wrkMast.getFullPlt().equals("Y")?"F":"D"); | 
 |  |  |                         locMast.setBarcode(wrkMast.getBarcode()); | 
 |  |  |                         locMast.setIoTime(now); | 
 |  |  |                         locMast.setModiTime(now); | 
 |  |  | 
 |  |  |                             exceptionHandle("库位移转 ===>> 转移库存明细数据失败;[源库位={0}],[目标库位={1}]", wrkMast.getSourceLocNo(), wrkMast.getLocNo()); | 
 |  |  |                         } | 
 |  |  |                     } | 
 |  |  |                     // todo:luxiaotao 3)修改盘点通知档 status ==> Y | 
 |  |  |                     // 修改源库位状态 ==> O | 
 |  |  |                     LocMast sourceLoc = locMastService.selectById(wrkMast.getSourceLocNo()); | 
 |  |  |                     if (null != sourceLoc) { | 
 |  |  | 
 |  |  |                 exceptionHandle("更新入库完成状态失败;[workNo={0}]", wrkMast.getWrkNo()); | 
 |  |  |             } | 
 |  |  |         } catch (Exception e) { | 
 |  |  |             log.error("fail", e); | 
 |  |  |             e.printStackTrace(); | 
 |  |  |             TransactionAspectSupport.currentTransactionStatus().setRollbackOnly(); | 
 |  |  |             return FAIL.setMsg(e.getMessage()); | 
 |  |  | 
 |  |  |             if (null == locMast) { | 
 |  |  |                 exceptionHandle("工作档[workNo={0}]库位号错误[locNo={1}]", wrkMast.getWrkNo(), wrkMast.getLocNo()); | 
 |  |  |             } | 
 |  |  |             assert locMast != null; | 
 |  |  |             switch (wrkMast.getIoType()) { | 
 |  |  |                 // 全板出库 | 
 |  |  |                 case 101: | 
 |  |  |                     // 出库确认信号位 | 
 |  |  |                     if (Cools.isEmpty(wrkMast.getInvWh()) || wrkMast.getInvWh().equals("N")) { | 
 |  |  |                         return SUCCESS; | 
 |  |  |                     } | 
 |  |  |                     // 根据工作号,查询工作明细档 | 
 |  |  |                     List<WrkDetl> wrkDetls101 = wrkDetlService.selectList(new EntityWrapper<WrkDetl>().eq("wrk_no", wrkMast.getWrkNo())); | 
 |  |  |                     if (wrkDetls101.isEmpty()) { | 
 |  |  | 
 |  |  |                 exceptionHandle("更新出库完成状态失败;[workNo={0}]", wrkMast.getWrkNo()); | 
 |  |  |             } | 
 |  |  |         } catch (Exception e) { | 
 |  |  |             log.error("fail", e); | 
 |  |  |             e.printStackTrace(); | 
 |  |  |             TransactionAspectSupport.currentTransactionStatus().setRollbackOnly(); | 
 |  |  |             return FAIL.setMsg(e.getMessage()); |