|
|
|
@ -154,10 +154,10 @@ public class OdsProcureOutOrderServiceImpl implements IOdsProcureOutOrderService
|
|
|
|
|
@Override
|
|
|
|
|
@DS("#header.poolName")
|
|
|
|
|
public List<OdsProcureOutOrder> selectOdsProcureOutOrderListZC(OdsProcureOutOrder odsProcureOutOrder) {
|
|
|
|
|
odsProcureOutOrder.setUserDefined3("X");
|
|
|
|
|
List<OdsProcureOutOrder> orderList = odsProcureOutOrderMapper.selectOdsProcureOutOrderListZC(odsProcureOutOrder);
|
|
|
|
|
for (OdsProcureOutOrder order:
|
|
|
|
|
orderList) {
|
|
|
|
|
if (order.getUserDefined4().length()>10){
|
|
|
|
|
String tem= odsProcureOutOrderMapper.selectMesReportWorkConsume(order);
|
|
|
|
|
if(tem==null){
|
|
|
|
|
order.setBGNumber(new BigDecimal("0"));
|
|
|
|
@ -165,13 +165,6 @@ public class OdsProcureOutOrderServiceImpl implements IOdsProcureOutOrderService
|
|
|
|
|
order.setBGNumber(new BigDecimal(tem));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}else {
|
|
|
|
|
//这个反冲的
|
|
|
|
|
List<OdsProcureOutOrder> odsProcureOutOrderList=odsProcureOutOrderMapper.selectMesReportWorkConsumeFC(order.getUserDefined4(),order.getMaterialCode());
|
|
|
|
|
if (odsProcureOutOrderList.size()>0){
|
|
|
|
|
order.setBGNumber( odsProcureOutOrderList.get(0).getPlanNumber());
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return orderList;
|
|
|
|
@ -310,6 +303,7 @@ public class OdsProcureOutOrderServiceImpl implements IOdsProcureOutOrderService
|
|
|
|
|
// factoryCode工厂号
|
|
|
|
|
// createBy操作人
|
|
|
|
|
// "produceCode":
|
|
|
|
|
String ID="";
|
|
|
|
|
if(orderList.size()>0){
|
|
|
|
|
String factoryCode = orderList.get(0).getFactoryCode();
|
|
|
|
|
DynamicDataSourceContextHolder.push("ds_" + factoryCode);
|
|
|
|
@ -346,6 +340,7 @@ public class OdsProcureOutOrderServiceImpl implements IOdsProcureOutOrderService
|
|
|
|
|
odsProcureOutOrder1.setMaterialCode(materialCode);
|
|
|
|
|
List<OdsProcureOutOrder> odsProcureOutOrders = odsProcureOutOrderMapper.selectWmsOdsProcureOutOrderSpecial(odsProcureOutOrder1);
|
|
|
|
|
//包材出库单----会有特殊的那种二次过账的单子--就看前端会不会传对应的标识卡了
|
|
|
|
|
ID=odsProcureOutOrders.get(0).getID();
|
|
|
|
|
OdsProcureOutOrder order1= odsProcureOutOrders.get(0);
|
|
|
|
|
order.setUserDefined4(order1.getUserDefined4());
|
|
|
|
|
//出库明细
|
|
|
|
@ -358,7 +353,7 @@ public class OdsProcureOutOrderServiceImpl implements IOdsProcureOutOrderService
|
|
|
|
|
if (tem.compareTo(realityNumber)>= 0) {
|
|
|
|
|
order1.setOrderStatus("3");//3是满足出库数量
|
|
|
|
|
} else {
|
|
|
|
|
order1.setOrderStatus("2");
|
|
|
|
|
order1.setOrderStatus("2");//进行
|
|
|
|
|
}
|
|
|
|
|
order1.setOutNumber(tem);//这样的话,就可以用已经过账的数量来计算要过账的数量,用出库数量减去已经过账的数量,就是要过账的数量,只要不为0,就可以进行
|
|
|
|
|
|
|
|
|
@ -380,13 +375,13 @@ public class OdsProcureOutOrderServiceImpl implements IOdsProcureOutOrderService
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
OdsProcureOutOrder order=new OdsProcureOutOrder();
|
|
|
|
|
|
|
|
|
|
order.setID(ID);
|
|
|
|
|
List<OdsProcureOutOrder> orderList1 = odsProcureOutOrderMapper.selectWmsOdsProcureOutOrderByOrderStatusSpecial(order);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (orderList1.size()>0){
|
|
|
|
|
OutboundPostingzcSAPGYTS(orderList1);
|
|
|
|
|
}
|
|
|
|
|
// if (orderList1.size()>0){
|
|
|
|
|
// OutboundPostingzcSAPGYTS(orderList1);
|
|
|
|
|
// }
|
|
|
|
|
if (gzList.size()>0) {
|
|
|
|
|
for (OdsProcureOutOrder order1:
|
|
|
|
|
gzList) {
|
|
|
|
@ -451,9 +446,26 @@ public class OdsProcureOutOrderServiceImpl implements IOdsProcureOutOrderService
|
|
|
|
|
return results;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Override
|
|
|
|
|
public List<OdsProcureOutOrder> selectOdsProcureOutOrderListZCTC(OdsProcureOutOrder odsProcureOutOrder) {
|
|
|
|
|
odsProcureOutOrder.setUserDefined3("X");
|
|
|
|
|
List<OdsProcureOutOrder> orderList = odsProcureOutOrderMapper.selectOdsProcureOutOrderListZCTW(odsProcureOutOrder);
|
|
|
|
|
for (OdsProcureOutOrder order:
|
|
|
|
|
orderList) {
|
|
|
|
|
String tem= odsProcureOutOrderMapper.selectMesReportWorkConsume(order);
|
|
|
|
|
if(tem==null){
|
|
|
|
|
order.setBGNumber(new BigDecimal("0"));
|
|
|
|
|
}else {
|
|
|
|
|
order.setBGNumber(new BigDecimal(tem));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return orderList;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public void OutboundPostingzcSAPGYTS(List<OdsProcureOutOrder> orderList) {
|
|
|
|
|
//先根据出库单获取
|
|
|
|
|
//
|
|
|
|
|
// -- and wms_ods_procure_out_order.Order_Status='3'
|
|
|
|
|
//我把过账状态-- and wms_ods_procure_out_order.User_Defined10!='2'去掉了
|
|
|
|
|
List<OdsProcureOutOrder> orderList1 = odsProcureOutOrderMapper.selectWmsOdsProcureOutOrderSpecialByIDs(orderList);
|
|
|
|
@ -462,7 +474,9 @@ public class OdsProcureOutOrderServiceImpl implements IOdsProcureOutOrderService
|
|
|
|
|
if ("成本中心".equals(orderList1.get(0).getUserDefined6())){//区分出来内部订单
|
|
|
|
|
Map paramMap=new HashMap<>();
|
|
|
|
|
List<Map> mapList = new ArrayList<>();
|
|
|
|
|
paramMap.put("GL_ACCOUNT", order.getUserDefined2());//总帐科目编号
|
|
|
|
|
paramMap.put("COSTCENTER", order.getUserDefined3());//成本中心
|
|
|
|
|
paramMap.put("GR_RCPT", order.getUserDefined4());//收货方/运达方
|
|
|
|
|
paramMap.put("PLANT", order.getSiteCode());//工厂
|
|
|
|
|
paramMap.put("LGORT", order.getLocCode());//库存地点
|
|
|
|
|
paramMap.put("MATNR", order.getMaterialCode());//物料号
|
|
|
|
@ -483,14 +497,24 @@ public class OdsProcureOutOrderServiceImpl implements IOdsProcureOutOrderService
|
|
|
|
|
Map map = new HashMap();
|
|
|
|
|
map = (Map) result2.getData();
|
|
|
|
|
String userDefined9 = (String) map.get("MATERIALDOCUMENT");
|
|
|
|
|
order.setUserDefined9(userDefined9);
|
|
|
|
|
order.setUserDefined10("2");//成功
|
|
|
|
|
//order.setUserDefined9(userDefined9);
|
|
|
|
|
// order.setUserDefined10("2");//成功
|
|
|
|
|
// for (OdsProcureOutOrder order2:
|
|
|
|
|
// orderList2 ) {
|
|
|
|
|
// BigDecimal sapNumber= order1.getSapNumber();
|
|
|
|
|
// order1.setSapNumber(sapNumber.add(order1.getOutNumber()));//成功..这个是否的outNumber是用已出库减去已经过账的数量
|
|
|
|
|
// odsProcureOutOrderMapper.updateWMSOdsProcureOutOrdersapById(order1);
|
|
|
|
|
order1.setID(order.getID());
|
|
|
|
|
order1.setSapNumber(order.getOutNumber());//成功..这个是否的outNumber是用已出库减去已经过账的数量
|
|
|
|
|
order1.setUserDefined10("2");//1是未过账,2是成功,3是失败
|
|
|
|
|
order1.setUserDefined9(userDefined9);//凭证
|
|
|
|
|
order1.setUserDefined11(msg);//信息
|
|
|
|
|
odsProcureOutOrderMapper.updateWMSOdsProcureOutOrdersapSpecialById(order1);
|
|
|
|
|
// }
|
|
|
|
|
}else {
|
|
|
|
|
order1.setID(order.getID());
|
|
|
|
|
// order1.setSapNumber(order.getOutNumber());//成功..这个是否的outNumber是用已出库减去已经过账的数量
|
|
|
|
|
order1.setUserDefined10("3");//1是未过账,2是成功,3是失败
|
|
|
|
|
// order1.setUserDefined9(userDefined9);//凭证
|
|
|
|
|
order1.setUserDefined11(msg);//信息
|
|
|
|
|
odsProcureOutOrderMapper.updateWMSOdsProcureOutOrdersapSpecialTWById(order1);
|
|
|
|
|
}
|
|
|
|
|
//这个地方需要对
|
|
|
|
|
}else {
|
|
|
|
@ -508,6 +532,7 @@ public class OdsProcureOutOrderServiceImpl implements IOdsProcureOutOrderService
|
|
|
|
|
paramMap.put("EXPIRYDATE", order.getUserDefined5());//货架寿命到期日
|
|
|
|
|
mapList.add(paramMap);
|
|
|
|
|
// R result2 = remoteSapService.sapProductOutboundCostTWO(mapList);
|
|
|
|
|
R result2 = remoteSapService.sapProductOutboundCostTW(mapList);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|