Commit d85b632c by 肖洋洋
parents b9155a67 1253dd21
...@@ -8,14 +8,12 @@ import org.springframework.web.bind.annotation.*; ...@@ -8,14 +8,12 @@ import org.springframework.web.bind.annotation.*;
import orthopedics.controller.error.ErrorEnum; import orthopedics.controller.error.ErrorEnum;
import orthopedics.controller.v1.TransactionController; import orthopedics.controller.v1.TransactionController;
import orthopedics.model.*; import orthopedics.model.*;
import orthopedics.service.InvCountService; import orthopedics.service.*;
import orthopedics.service.InventoryServer;
import orthopedics.service.TransactionServer;
import orthopedics.service.UserServer;
import orthopedics.util.Result; import orthopedics.util.Result;
import orthopedics.util.StatusCode; import orthopedics.util.StatusCode;
import orthopedics.vo.InvCountHeaderPage; import orthopedics.vo.InvCountHeaderPage;
import java.math.BigDecimal;
import java.time.LocalDateTime; import java.time.LocalDateTime;
import java.util.HashMap; import java.util.HashMap;
import java.util.List; import java.util.List;
...@@ -95,6 +93,10 @@ public class CheckController { ...@@ -95,6 +93,10 @@ public class CheckController {
return userServer.checkAccessToken(accessToken); return userServer.checkAccessToken(accessToken);
} }
@Autowired
private InvTransacationCostService invTransacationCostService;
//封装json数据 //封装json数据
private JSONObject getJson(InvCountHeaderPage invCountHeaderPage, InvCountLine invCountLine){ private JSONObject getJson(InvCountHeaderPage invCountHeaderPage, InvCountLine invCountLine){
JSONObject jsonObject = new JSONObject(); JSONObject jsonObject = new JSONObject();
...@@ -114,6 +116,13 @@ public class CheckController { ...@@ -114,6 +116,13 @@ public class CheckController {
quantity = -invCountLine.getDifferentQuantity(); quantity = -invCountLine.getDifferentQuantity();
} }
Double unit_price = Double.valueOf(invItem.getPurchasePrice());
InvTransactionCost lastTranCost = invTransacationCostService.findCostByInvIdAndItemId(inventory.getId(),invCountLine.getItemId());
if(lastTranCost != null){
unit_price = lastTranCost.getLastCost();
}
BigDecimal b = new BigDecimal(unit_price*quantity);
Double price = b.setScale(4, BigDecimal.ROUND_HALF_UP).doubleValue();
JSONObject tempData = new JSONObject(); JSONObject tempData = new JSONObject();
tempData.put("inv_code",inventory.getInvCode()); tempData.put("inv_code",inventory.getInvCode());
tempData.put("subinv_code",subinventory.getSubinvCode()); tempData.put("subinv_code",subinventory.getSubinvCode());
...@@ -122,7 +131,7 @@ public class CheckController { ...@@ -122,7 +131,7 @@ public class CheckController {
tempData.put("tx_type_code",txTypeCode); tempData.put("tx_type_code",txTypeCode);
tempData.put("tx_date",LocalDateTime.now()); tempData.put("tx_date",LocalDateTime.now());
tempData.put("tx_quantity",quantity); tempData.put("tx_quantity",quantity);
tempData.put("tx_price",invItem.getPurchasePrice()); tempData.put("tx_price",price);
tempData.put("source_code","INVENTORY");//来源与库存 tempData.put("source_code","INVENTORY");//来源与库存
tempData.put("source_header_id",invCountHeaderPage.getId()); tempData.put("source_header_id",invCountHeaderPage.getId());
tempData.put("source_line_id",invCountLine.getId()); tempData.put("source_line_id",invCountLine.getId());
......
...@@ -47,7 +47,7 @@ public class InvItemChangeController { ...@@ -47,7 +47,7 @@ public class InvItemChangeController {
//对比价格是否有变化 //对比价格是否有变化
if (LastInvItemChange.getPurchasePrice().equals(invItemChange.getPurchasePrice())) { if (LastInvItemChange.getPurchasePrice().equals(invItemChange.getPurchasePrice())) {
//无则不做任何操作 //无则不做任何操作
return new Result(false,StatusCode.ERROR,ErrorEnum.DataHaveNotChange.getErrorMsg()); return new Result(true,StatusCode.OK,ErrorEnum.DataHaveNotChange.getErrorMsg());
} else { } else {
//先将版本号转化为数字+1,再转化成String //先将版本号转化为数字+1,再转化成String
String editVersion = String.valueOf(Integer.parseInt(LastInvItemChange.getEditVersions()) + 1); String editVersion = String.valueOf(Integer.parseInt(LastInvItemChange.getEditVersions()) + 1);
......
...@@ -336,6 +336,7 @@ public class PurOrderHeaderController { ...@@ -336,6 +336,7 @@ public class PurOrderHeaderController {
} }
RcvReceiptHeader rcvReceiptHeader=new RcvReceiptHeader(); RcvReceiptHeader rcvReceiptHeader=new RcvReceiptHeader();
rcvReceiptHeader.setId(UuidUtil.get32UUIDString()); rcvReceiptHeader.setId(UuidUtil.get32UUIDString());
rcvReceiptHeader.setCreateBy(sysAccessToken.getUserName()); rcvReceiptHeader.setCreateBy(sysAccessToken.getUserName());
...@@ -396,7 +397,7 @@ public class PurOrderHeaderController { ...@@ -396,7 +397,7 @@ public class PurOrderHeaderController {
}catch (Exception e){ }catch (Exception e){
return new Result(false, StatusCode.ERROR,"数量类型错误"); return new Result(false, StatusCode.ERROR,"数量类型错误");
} }
rcvReceiptLine.setAttribute3(purOrderLine.getFixedPrice());
rcvReceiptLine.setShippedQuantity(i); rcvReceiptLine.setShippedQuantity(i);
rcvReceiptLine.setReceivedQuantity(i); rcvReceiptLine.setReceivedQuantity(i);
rcvReceiptLine.setUnitCode(purOrderLine.getUnitCode()); rcvReceiptLine.setUnitCode(purOrderLine.getUnitCode());
......
...@@ -13,6 +13,7 @@ import orthopedics.util.StatusCode; ...@@ -13,6 +13,7 @@ import orthopedics.util.StatusCode;
import orthopedics.util.UuidUtil; import orthopedics.util.UuidUtil;
import orthopedics.vo.RcvReceiptHeaderPage; import orthopedics.vo.RcvReceiptHeaderPage;
import java.math.BigDecimal;
import java.text.SimpleDateFormat; import java.text.SimpleDateFormat;
import java.time.LocalDateTime; import java.time.LocalDateTime;
import java.time.ZoneId; import java.time.ZoneId;
...@@ -146,7 +147,8 @@ public class RcvReceiptController { ...@@ -146,7 +147,8 @@ public class RcvReceiptController {
//获取当前时间 //获取当前时间
LocalDateTime updateTime = LocalDateTime.now(); LocalDateTime updateTime = LocalDateTime.now();
//验收入库判断操作 //验收入库判断操作
for(RcvReceiptHeaderPage rcvRecHeaderPage:rcvReceiptHeaderPageList){ for(RcvReceiptHeaderPage rcvPage:rcvReceiptHeaderPageList){
RcvReceiptHeaderPage rcvRecHeaderPage = rcvReceiptHeaderService.findRcvReceiptHeaderPage(rcvPage.getId());
String lineStatus = null; String lineStatus = null;
//调用验收通过 //调用验收通过
if ("accept".equals(status)) { if ("accept".equals(status)) {
...@@ -217,9 +219,12 @@ public class RcvReceiptController { ...@@ -217,9 +219,12 @@ public class RcvReceiptController {
jsonObject.put("tx_type_code",receiptType); jsonObject.put("tx_type_code",receiptType);
jsonObject.put("tx_date",LocalDateTime.now()); jsonObject.put("tx_date",LocalDateTime.now());
jsonObject.put("tx_quantity",quantity); jsonObject.put("tx_quantity",quantity);
jsonObject.put("tx_price",invItem.getPurchasePrice());
jsonObject.put("source_header_id",id); jsonObject.put("source_header_id",id);
jsonObject.put("source_line_id",rcvReceiptLine.getId()); jsonObject.put("source_line_id",rcvReceiptLine.getId());
BigDecimal b = new BigDecimal(Double.valueOf(rcvReceiptLine.getAttribute3()) * quantity);
Double tx_amount = b.setScale(4, BigDecimal.ROUND_HALF_UP).doubleValue();
jsonObject.put("tx_amount",tx_amount);
jsonObject.put("tx_price",tx_amount);
JSONObject data = new JSONObject(); JSONObject data = new JSONObject();
data.put("data",jsonObject); data.put("data",jsonObject);
return data; return data;
......
...@@ -8,6 +8,7 @@ import org.springframework.web.bind.annotation.*; ...@@ -8,6 +8,7 @@ import org.springframework.web.bind.annotation.*;
import orthopedics.controller.error.ErrorEnum; import orthopedics.controller.error.ErrorEnum;
import orthopedics.controller.v1.TransactionController; import orthopedics.controller.v1.TransactionController;
import orthopedics.model.*; import orthopedics.model.*;
import orthopedics.service.InvTransacationCostService;
import orthopedics.service.InventoryServer; import orthopedics.service.InventoryServer;
import orthopedics.service.TransferService; import orthopedics.service.TransferService;
import orthopedics.service.UserServer; import orthopedics.service.UserServer;
...@@ -16,7 +17,11 @@ import orthopedics.util.StatusCode; ...@@ -16,7 +17,11 @@ import orthopedics.util.StatusCode;
import orthopedics.util.StringUtil; import orthopedics.util.StringUtil;
import orthopedics.vo.WarTransferPage; import orthopedics.vo.WarTransferPage;
import java.math.BigDecimal;
import java.time.LocalDateTime; import java.time.LocalDateTime;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
@RestController @RestController
@RequestMapping("/bookcity/transfer") @RequestMapping("/bookcity/transfer")
...@@ -30,7 +35,8 @@ public class TransferController { ...@@ -30,7 +35,8 @@ public class TransferController {
private UserServer userServer; private UserServer userServer;
@Autowired @Autowired
private InventoryServer inventoryServer; private InventoryServer inventoryServer;
@Autowired
private InvTransacationCostService invTransacationCostService;
/** /**
*描述:库存调拨的审核接口,将状态从新建new修改为已审核approval, *描述:库存调拨的审核接口,将状态从新建new修改为已审核approval,
* 调用库存转移接口,生成两条出入库事务处理类型为“跨库在途调拨-发放”“跨库在途调拨-接收” * 调用库存转移接口,生成两条出入库事务处理类型为“跨库在途调拨-发放”“跨库在途调拨-接收”
...@@ -85,6 +91,9 @@ public class TransferController { ...@@ -85,6 +91,9 @@ public class TransferController {
if(warTransferLine.getQuantity() == null || "".equals(warTransferLine.getQuantity())){ if(warTransferLine.getQuantity() == null || "".equals(warTransferLine.getQuantity())){
return new Result(false,StatusCode.ERROR,"调拨单号为:"+warTransferPage.getOrderNumber()+"的调拨单行的调出数量需填入"); return new Result(false,StatusCode.ERROR,"调拨单号为:"+warTransferPage.getOrderNumber()+"的调拨单行的调出数量需填入");
} }
if("0".equals(warTransferLine.getQuantity())){
return new Result(false,StatusCode.ERROR,"调拨单号为:"+warTransferPage.getOrderNumber()+"的调拨单行的调出数量不能为0");
}
JSONObject json = getJson(warTransferPage,warTransferLine); JSONObject json = getJson(warTransferPage,warTransferLine);
transactionController.invItemeTransfer(token,json); transactionController.invItemeTransfer(token,json);
} }
...@@ -158,6 +167,7 @@ public class TransferController { ...@@ -158,6 +167,7 @@ public class TransferController {
checkLocatorCode(inInvId,inSubinvId,inLocatorCode); checkLocatorCode(inInvId,inSubinvId,inLocatorCode);
String inLocatorId = getLocatorCode(inInvId,inSubInvCode,inLocatorCode); String inLocatorId = getLocatorCode(inInvId,inSubInvCode,inLocatorCode);
transferService.updateInvTranAtSure(inSubinvId,inLocatorId,headerId,lineId,inInvId); transferService.updateInvTranAtSure(inSubinvId,inLocatorId,headerId,lineId,inInvId);
invTransacationCostService.updateInvTranCostAtSure(inSubinvId,inLocatorId,headerId,lineId,inInvId);
InvTransaction invTransaction = transferService.findInvTranAtSure(headerId,lineId,inInvId,inSubinvId,inLocatorId); InvTransaction invTransaction = transferService.findInvTranAtSure(headerId,lineId,inInvId,inSubinvId,inLocatorId);
if(invTransaction == null){ if(invTransaction == null){
return new Result(false,StatusCode.ERROR,"调拨单号为"+orderNum+"对应的库存现有量数据不存在,请检查!"); return new Result(false,StatusCode.ERROR,"调拨单号为"+orderNum+"对应的库存现有量数据不存在,请检查!");
...@@ -166,19 +176,21 @@ public class TransferController { ...@@ -166,19 +176,21 @@ public class TransferController {
if(warTransferLine.getFinalQty() == null || "".equals(warTransferLine.getFinalQty())){ if(warTransferLine.getFinalQty() == null || "".equals(warTransferLine.getFinalQty())){
return new Result(false,StatusCode.ERROR,"调拨单号为"+orderNum+"的调拨单行的二次确认数量需填入!"); return new Result(false,StatusCode.ERROR,"调拨单号为"+orderNum+"的调拨单行的二次确认数量需填入!");
} }
if(!warTransferLine.getQuantity().equals(warTransferLine.getFinalQty())){
//修改调拨的库存事务处理数量
transferService.updateInvTranQuantity(warTransferLine.getFinalQty(),headerId,lineId,inInvId,inSubinvId,inLocatorId);//修改调入数量
InvTransaction outInvTran = transferService.findOutInvTran(headerId,lineId); InvTransaction outInvTran = transferService.findOutInvTran(headerId,lineId);
InvTransaction inInvTran = transferService.findInInvTran(headerId,lineId); InvTransaction inInvTran = transferService.findInInvTran(headerId,lineId);
if(!warTransferLine.getQuantity().equals(warTransferLine.getFinalQty()) || !warTransferLine.getUnitPrice().equals(outInvTran.getTxPrice())) {
//修改调拨的库存事务处理数量或金额
transferService.updateInvTranQuantity(warTransferLine.getFinalQty(),inInvTran.getId(),warTransferLine.getUnitPrice());//修改调入数量或金额
if(outInvTran == null || inInvTran == null){ if(outInvTran == null || inInvTran == null){
return new Result(false,StatusCode.ERROR,"调拨单号为"+orderNum+"对应的库存现有量数据不存在,请检查!"); return new Result(false,StatusCode.ERROR,"调拨单号为"+orderNum+"对应的库存现有量数据不存在,请检查!");
} }
transferService.updateInvTranQuantity("-"+warTransferLine.getFinalQty(),headerId,lineId,outInvTran.getInvId(),outInvTran.getSubinvId(),outInvTran.getLocatorId());//修改调出数量 transferService.updateInvTranQuantity("-"+warTransferLine.getFinalQty(),outInvTran.getId(),warTransferLine.getUnitPrice());//修改调出数量
Integer quantity = Integer.valueOf(warTransferLine.getQuantity()) - Integer.valueOf(warTransferLine.getFinalQty()); Integer quantity = Integer.valueOf(warTransferLine.getQuantity()) - Integer.valueOf(warTransferLine.getFinalQty());
transferService.updateInvItemOnHandByLastTxId(quantity,outInvTran.getId()); transferService.updateInvItemOnHandByLastTxId(quantity,outInvTran.getId());
Integer quantityOut = -quantity; Integer quantityOut = -quantity;
transferService.updateInvItemOnHandByOriginTxId(quantityOut,inInvTran.getId()); transferService.updateInvItemOnHandByOriginTxId(quantityOut,inInvTran.getId());
//修改成本表的计算
updateInvTranCost(headerId,lineId,warTransferLine.getFinalQty(),warTransferLine.getUnitPrice());
} }
transferService.updateInvItemOnhandAtSure(inSubinvId,inLocatorId,invTransaction.getId()); transferService.updateInvItemOnhandAtSure(inSubinvId,inLocatorId,invTransaction.getId());
} }
...@@ -189,6 +201,7 @@ public class TransferController { ...@@ -189,6 +201,7 @@ public class TransferController {
if(uCount == 0){ if(uCount == 0){
return new Result(false,StatusCode.ERROR,"调拨单号为:"+warTransferPage.getOrderNumber()+"确认失败!"); return new Result(false,StatusCode.ERROR,"调拨单号为:"+warTransferPage.getOrderNumber()+"确认失败!");
} }
invTransacationCostService.updateInvTransactionCost(warTransferPage.getId(),warTransferLine.getId());
} }
} }
int count = transferService.updateTransferStatus(null,"completed",updateBy,updateTime,id); int count = transferService.updateTransferStatus(null,"completed",updateBy,updateTime,id);
...@@ -222,6 +235,7 @@ public class TransferController { ...@@ -222,6 +235,7 @@ public class TransferController {
jsonObject.put("destination_locator_code",inLocatorCode); jsonObject.put("destination_locator_code",inLocatorCode);
jsonObject.put("item_code",warTransferLine.getItemCode()); jsonObject.put("item_code",warTransferLine.getItemCode());
jsonObject.put("tx_type_code",warTransfer.getOrderType()); jsonObject.put("tx_type_code",warTransfer.getOrderType());
jsonObject.put("tx_amount",warTransferLine.getUnitPrice());
jsonObject.put("tx_price",warTransferLine.getUnitPrice()); jsonObject.put("tx_price",warTransferLine.getUnitPrice());
jsonObject.put("tx_date",LocalDateTime.now()); jsonObject.put("tx_date",LocalDateTime.now());
jsonObject.put("source_code","INVENTORY");//来源于库存 jsonObject.put("source_code","INVENTORY");//来源于库存
...@@ -254,4 +268,39 @@ public class TransferController { ...@@ -254,4 +268,39 @@ public class TransferController {
} }
return invLocatorId; return invLocatorId;
} }
//修改成本表的记录
private void updateInvTranCost(String headerId,String lineId,String quantity,String price){
List<InvTransactionCost> costList = invTransacationCostService.findInvTranCostBySource(headerId, lineId);
if(costList.size() != 0){
for(InvTransactionCost invTransactionCost:costList){
if(invTransactionCost.getTxQuantity() > 0){
Integer tx_quantity = Integer.valueOf(quantity);
Double tx_price = Double.valueOf(price);
Map<String,Object> map = getCost(tx_quantity,tx_price,invTransactionCost.getFirstQuantity(),invTransactionCost.getFirstAmount());
invTransacationCostService.updateInvTranCost(tx_quantity,tx_price,(Double) map.get("lastAmount"),(Integer) map.get("lastQuantity"),(Double)map.get("lastCost"),invTransactionCost.getId());
}
if(invTransactionCost.getTxQuantity() < 0){
Integer tx_quantity = Integer.valueOf("-"+quantity);
Double tx_price = Double.valueOf("-"+price);
Map<String,Object> map = getCost(tx_quantity,tx_price,invTransactionCost.getFirstQuantity(),invTransactionCost.getFirstAmount());
invTransacationCostService.updateInvTranCost(tx_quantity,tx_price,(Double) map.get("lastAmount"),(Integer) map.get("lastQuantity"),(Double)map.get("lastCost"),invTransactionCost.getId());
}
}
}
}
//成本计算公式
private Map<String,Object> getCost(Integer tx_quantity,Double tx_amount,Integer first_quantity,Double first_amount){
Map<String,Object> map = new HashMap<>();
BigDecimal b = new BigDecimal(first_amount + tx_amount);
Double lastAmount = b.setScale(4, BigDecimal.ROUND_HALF_UP).doubleValue();
Integer lastQuantity = first_quantity+ tx_quantity;
BigDecimal c = new BigDecimal(lastAmount/lastQuantity);
Double lastCost = c.setScale(4, BigDecimal.ROUND_HALF_UP).doubleValue();
map.put("lastAmount",lastAmount);
map.put("lastQuantity",lastQuantity);
map.put("lastCost",lastCost);
return map;
}
} }
package orthopedics.controller.bookcity; package orthopedics.controller.bookcity;
import com.alibaba.fastjson.JSONObject; import com.alibaba.fastjson.JSONObject;
import org.apache.commons.codec.language.DoubleMetaphone;
import org.springframework.beans.BeanUtils; import org.springframework.beans.BeanUtils;
import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.util.StringUtils; import org.springframework.util.StringUtils;
...@@ -17,6 +18,7 @@ import orthopedics.util.UuidUtil; ...@@ -17,6 +18,7 @@ import orthopedics.util.UuidUtil;
import orthopedics.vo.RcvReceiptHeaderPage; import orthopedics.vo.RcvReceiptHeaderPage;
import orthopedics.vo.WshShipmentHeaderPage; import orthopedics.vo.WshShipmentHeaderPage;
import java.math.BigDecimal;
import java.time.LocalDateTime; import java.time.LocalDateTime;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.HashMap; import java.util.HashMap;
...@@ -225,9 +227,14 @@ public class WshShipmentController { ...@@ -225,9 +227,14 @@ public class WshShipmentController {
//获取当前时间 //获取当前时间
LocalDateTime updateTime = LocalDateTime.now(); LocalDateTime updateTime = LocalDateTime.now();
//提交出库 //提交出库
for(WshShipmentHeaderPage wshShipmentHeaderPage:wshShipmentHeaderPageList){ for(WshShipmentHeaderPage wshShipPage:wshShipmentHeaderPageList){
WshShipmentHeaderPage wshShipmentHeaderPage = shipServer.findWshShipById(wshShipPage.getId());
for(WshShipmentLine wshShipmentLine:wshShipmentHeaderPage.getWshShipmentLineList()){ for(WshShipmentLine wshShipmentLine:wshShipmentHeaderPage.getWshShipmentLineList()){
JSONObject jsonObject = getJson(wshShipmentHeaderPage.getShipmentNumber(),wshShipmentHeaderPage.getId(),wshShipmentLine); String tx_amount = null;
if("PURCHASE_RETURN".equals(wshShipmentHeaderPage.getShipmentType())){
tx_amount = "-"+wshShipmentLine.getAttribute3();
}
JSONObject jsonObject = getJson(tx_amount,wshShipmentHeaderPage.getShipmentNumber(),wshShipmentHeaderPage.getId(),wshShipmentLine);
transactionController.invItemInOut(token,jsonObject); transactionController.invItemInOut(token,jsonObject);
} }
//修改状态为已交货DELIVERED //修改状态为已交货DELIVERED
...@@ -240,7 +247,7 @@ public class WshShipmentController { ...@@ -240,7 +247,7 @@ public class WshShipmentController {
return new Result(true,StatusCode.OK,"出库成功!"); return new Result(true,StatusCode.OK,"出库成功!");
} }
public JSONObject getJson(String number,String id,WshShipmentLine wshShipmentLine){ public JSONObject getJson(String tx_amount,String number,String id,WshShipmentLine wshShipmentLine){
JSONObject jsonObject = new JSONObject(); JSONObject jsonObject = new JSONObject();
InvItem invItem = invItemService.findInvItemById(wshShipmentLine.getItemId()); InvItem invItem = invItemService.findInvItemById(wshShipmentLine.getItemId());
if(invItem == null){ if(invItem == null){
...@@ -249,17 +256,6 @@ public class WshShipmentController { ...@@ -249,17 +256,6 @@ public class WshShipmentController {
if(invItem.getItemCode() == null || "".equals(invItem.getItemCode())){ if(invItem.getItemCode() == null || "".equals(invItem.getItemCode())){
throw ErrorEnum.Error.createException("发运单号为:"+number+",行号为:"+wshShipmentLine.getLineNumber()+"的商品信息:商品代码不完整!"); throw ErrorEnum.Error.createException("发运单号为:"+number+",行号为:"+wshShipmentLine.getLineNumber()+"的商品信息:商品代码不完整!");
} }
String price = null;
if(!"".equals(wshShipmentLine.getAttribute1()) && wshShipmentLine.getAttribute1() != null){
price = wshShipmentLine.getAttribute1();
}else{
if(invItem.getPurchasePrice() == null || "".equals(invItem.getPurchasePrice())){
throw ErrorEnum.Error.createException("发运单号为:"+number+",行号为:"+wshShipmentLine.getLineNumber()+"的商品信息:商品没有价格!");
}
else{
price = invItem.getPurchasePrice();
}
}
Inventory inventory = inventoryServer.selectInventoryById(wshShipmentLine.getInvId()); Inventory inventory = inventoryServer.selectInventoryById(wshShipmentLine.getInvId());
if(inventory == null){ if(inventory == null){
throw ErrorEnum.Error.createException("发运单号为:"+number+",行号为:"+wshShipmentLine.getLineNumber()+"的库存不存在!"); throw ErrorEnum.Error.createException("发运单号为:"+number+",行号为:"+wshShipmentLine.getLineNumber()+"的库存不存在!");
...@@ -289,9 +285,10 @@ public class WshShipmentController { ...@@ -289,9 +285,10 @@ public class WshShipmentController {
jsonObject.put("tx_type_code","SALE_ISSUE"); jsonObject.put("tx_type_code","SALE_ISSUE");
jsonObject.put("tx_date",LocalDateTime.now()); jsonObject.put("tx_date",LocalDateTime.now());
jsonObject.put("tx_quantity",wshShipmentLine.getQuantity()); jsonObject.put("tx_quantity",wshShipmentLine.getQuantity());
jsonObject.put("tx_price",price); jsonObject.put("tx_price",wshShipmentLine.getAttribute3());
jsonObject.put("source_header_id",id); jsonObject.put("source_header_id",id);
jsonObject.put("source_line_id",wshShipmentLine.getId()); jsonObject.put("source_line_id",wshShipmentLine.getId());
jsonObject.put("tx_amount",tx_amount);
JSONObject data = new JSONObject(); JSONObject data = new JSONObject();
data.put("data",jsonObject); data.put("data",jsonObject);
return data; return data;
......
...@@ -131,8 +131,8 @@ public class TransactionController { ...@@ -131,8 +131,8 @@ public class TransactionController {
BigDecimal sourcePrice = null; BigDecimal sourcePrice = null;
BigDecimal destinationPrice = null; BigDecimal destinationPrice = null;
if (StringUtil.notEmpty(price)) { if (StringUtil.notEmpty(price)) {
destinationPrice = new BigDecimal(price); destinationPrice = new BigDecimal(price).setScale(2, BigDecimal.ROUND_HALF_UP);
sourcePrice = new BigDecimal(price); sourcePrice = new BigDecimal(price).setScale(2, BigDecimal.ROUND_HALF_UP);
} else { } else {
InvTransactionAction invTransactionAction = transactionServer.selectActionById(invTransactionType.getTxActionId()); InvTransactionAction invTransactionAction = transactionServer.selectActionById(invTransactionType.getTxActionId());
destinationPrice = BigDecimal.ZERO; destinationPrice = BigDecimal.ZERO;
...@@ -204,6 +204,7 @@ public class TransactionController { ...@@ -204,6 +204,7 @@ public class TransactionController {
sourceInvTransaction.setSummaryFlag("N"); sourceInvTransaction.setSummaryFlag("N");
//创建转移源的事务记录 //创建转移源的事务记录
transactionServer.createTransaction(sourceInvTransaction); transactionServer.createTransaction(sourceInvTransaction);
insertInvTransactionCost(sourceInvTransaction,data.getDouble("-"+"tx_amount"));
InvTransaction destinationInvTransaction = new InvTransaction(); InvTransaction destinationInvTransaction = new InvTransaction();
BeanUtils.copyProperties(sourceInvTransaction, destinationInvTransaction); BeanUtils.copyProperties(sourceInvTransaction, destinationInvTransaction);
...@@ -229,6 +230,7 @@ public class TransactionController { ...@@ -229,6 +230,7 @@ public class TransactionController {
destinationInvTransaction.setCosignmentEndDate(consignmentEndDate); destinationInvTransaction.setCosignmentEndDate(consignmentEndDate);
//创建转移目标的事务记录 //创建转移目标的事务记录
transactionServer.createTransaction(destinationInvTransaction); transactionServer.createTransaction(destinationInvTransaction);
insertInvTransactionCost(destinationInvTransaction,data.getDouble("tx_amount"));
InvItemOnhand sourceInvItemOnhand = new InvItemOnhand(); InvItemOnhand sourceInvItemOnhand = new InvItemOnhand();
...@@ -411,8 +413,6 @@ public class TransactionController { ...@@ -411,8 +413,6 @@ public class TransactionController {
outInvItemOnhand.setLastTxId(invTransaction.getId()); outInvItemOnhand.setLastTxId(invTransaction.getId());
transactionServer.outItemOnhand(outInvItemOnhand); transactionServer.outItemOnhand(outInvItemOnhand);
}else if ("RECEIPT_INTO_STORE".equals(invTransactionAction.getTxActionCode())){ }else if ("RECEIPT_INTO_STORE".equals(invTransactionAction.getTxActionCode())){
logger.info("------入库-------"); logger.info("------入库-------");
LocalDateTime consignmentStartDate = TimeUtil.fromDateToLocalDateTime(data.getString("consignment_start_date")); LocalDateTime consignmentStartDate = TimeUtil.fromDateToLocalDateTime(data.getString("consignment_start_date"));
...@@ -445,6 +445,8 @@ public class TransactionController { ...@@ -445,6 +445,8 @@ public class TransactionController {
} }
transactionServer.createTransaction(invTransaction); transactionServer.createTransaction(invTransaction);
//入库成本记录表
insertInvTransactionCost(invTransaction,data.getDouble("tx_amount"));
Map<String, Object> reponseResult = new HashMap<>(); Map<String, Object> reponseResult = new HashMap<>();
ErrorEnum.SUCCESS.putIntoMap(reponseResult); ErrorEnum.SUCCESS.putIntoMap(reponseResult);
return JSON.toJSONString(reponseResult); return JSON.toJSONString(reponseResult);
...@@ -749,4 +751,49 @@ public class TransactionController { ...@@ -749,4 +751,49 @@ public class TransactionController {
} }
return locatorCode; return locatorCode;
} }
@Autowired
private InvTransacationCostService invTransacationCostService;
//入库成本记录表
private void insertInvTransactionCost(InvTransaction invTransaction,Double tx_amount){
InvTransactionCost invTransactionCost = new InvTransactionCost();
BeanUtils.copyProperties(invTransaction,invTransactionCost);
invTransactionCost.setId(UuidUtil.get32UUIDString());
InvTransactionCost lastTranCost = invTransacationCostService.findCostByInvIdAndItemId(invTransaction.getInvId(),invTransaction.getItemId());
Integer firstQuantity = 0;
Double firstCost = 0.0;
Double firstAmount = 0.0;
if(lastTranCost != null){
firstQuantity = lastTranCost.getLastQuantity();
firstCost = lastTranCost.getLastCost();
firstAmount = lastTranCost.getLastAmount();
}
invTransactionCost.setFirstCost(firstCost);
invTransactionCost.setFirstQuantity(firstQuantity);
invTransactionCost.setFirstAmount(firstAmount);
Integer txQuantity = invTransaction.getTxQuantity();
if("".equals(tx_amount) || tx_amount == null){
BigDecimal a = new BigDecimal(txQuantity*firstCost);
tx_amount = a.setScale(4, BigDecimal.ROUND_HALF_UP).doubleValue();
}
invTransactionCost.setTxAmount(tx_amount);
BigDecimal b = new BigDecimal(firstAmount + tx_amount);
Double lastAmount = b.setScale(4, BigDecimal.ROUND_HALF_UP).doubleValue();
Integer lastQuantity = firstQuantity + txQuantity;
invTransactionCost.setLastAmount(lastAmount);
invTransactionCost.setLastQuantity(lastQuantity);
Double lastCost = 0.00;
if(!(Math.abs(lastAmount)<0.00001) && !"0".equals(lastQuantity)){
BigDecimal c = new BigDecimal(lastAmount / lastQuantity);
lastCost = c.setScale(4, BigDecimal.ROUND_HALF_UP).doubleValue();
}
if(lastCost < 0){
lastCost = firstCost;
invTransactionCost.setRemark("无法计算成本,沿用期初成本");
}
invTransactionCost.setLastCost(lastCost);
invTransactionCost.setStatus("1");
invTransacationCostService.insertInvTransactionCost(invTransactionCost);
}
} }
package orthopedics.dao;
import java.util.List;
import org.apache.ibatis.annotations.*;
import orthopedics.model.InvTransactionCost;
import org.apache.ibatis.annotations.Param;
import javax.crypto.interfaces.DHPublicKey;
/**
* @author ice
*/
public interface InvTransactionCostMapper{
@Select("SELECT * FROM inv_transaction_cost")
@Results(id = "invtransactioncost", value ={
@Result(property = "id", column = "id"),
@Result(property = "createBy", column = "create_by"),
@Result(property = "createTime", column = "create_time"),
@Result(property = "updateBy", column = "update_by"),
@Result(property = "updateTime", column = "update_time"),
@Result(property = "attributeCategory", column = "attribute_category"),
@Result(property = "attribute1", column = "attribute1"),
@Result(property = "attribute2", column = "attribute2"),
@Result(property = "attribute3", column = "attribute3"),
@Result(property = "attribute4", column = "attribute4"),
@Result(property = "attribute5", column = "attribute5"),
@Result(property = "attribute6", column = "attribute6"),
@Result(property = "attribute7", column = "attribute7"),
@Result(property = "attribute8", column = "attribute8"),
@Result(property = "attribute9", column = "attribute9"),
@Result(property = "attribute10", column = "attribute10"),
@Result(property = "txTypeId", column = "tx_type_id"),
@Result(property = "txSourceTypeId", column = "tx_source_type_id"),
@Result(property = "txActionId", column = "tx_action_id"),
@Result(property = "txDate", column = "tx_date"),
@Result(property = "txUnit", column = "tx_unit"),
@Result(property = "sourceHeaderId", column = "source_header_id"),
@Result(property = "sourceLineId", column = "source_line_id"),
@Result(property = "invId", column = "inv_id"),
@Result(property = "subinvId", column = "subinv_id"),
@Result(property = "locatorId", column = "locator_id"),
@Result(property = "itemId", column = "item_id"),
@Result(property = "firstCost", column = "first_cost"),
@Result(property = "firstQuantity", column = "first_quantity"),
@Result(property = "firstAmount", column = "first_amount"),
@Result(property = "txQuantity", column = "tx_quantity"),
@Result(property = "txAmount", column = "tx_amount"),
@Result(property = "lastQuantity", column = "last_quantity"),
@Result(property = "lastAmount", column = "last_amount"),
@Result(property = "lastCost", column = "last_cost"),
@Result(property = "status", column = "status"),
@Result(property = "remark", column = "remark"),
})
public List<InvTransactionCost> select();
@Insert("<script>" +
"INSERT INTO inv_transaction_cost(id,create_by,create_time,update_by,update_time,attribute_category,attribute1,attribute2,attribute3,attribute4,attribute5,attribute6,attribute7,attribute8,attribute9,attribute10,tx_type_id,tx_source_type_id,tx_action_id,tx_date,tx_unit,source_header_id,source_line_id,inv_id,subinv_id,locator_id,item_id,first_cost,first_quantity,first_amount,tx_quantity,tx_amount,last_quantity,last_amount,last_cost,status,remark) VALUES" +
"<foreach collection='invtransactioncosts' item='item' index='index' separator=','>" +
"(#{item.id},#{item.createBy},#{item.createTime},#{item.updateBy},#{item.updateTime},#{item.attributeCategory},#{item.attribute1},#{item.attribute2},#{item.attribute3},#{item.attribute4},#{item.attribute5},#{item.attribute6},#{item.attribute7},#{item.attribute8},#{item.attribute9},#{item.attribute10},#{item.txTypeId},#{item.txSourceTypeId},#{item.txActionId},#{item.txDate},#{item.txUnit},#{item.sourceHeaderId},#{item.sourceLineId},#{item.invId},#{item.subinvId},#{item.locatorId},#{item.itemId},#{item.firstCost},#{item.firstQuantity},#{item.firstAmount},#{item.txQuantity},#{item.txAmount},#{item.lastQuantity},#{item.lastAmount},#{item.lastCost},#{item.status},#{item.remark})" +
"</foreach>" +
"</script>")
Integer insertBatch(@Param("invtransactioncosts")List<InvTransactionCost> InvTransactionCostList);
@Insert(
"INSERT INTO inv_transaction_cost(id,create_by,create_time,update_by,update_time,attribute_category,attribute1,attribute2,attribute3,attribute4,attribute5,attribute6,attribute7,attribute8,attribute9,attribute10,tx_type_id,tx_source_type_id,tx_action_id,tx_date,tx_unit,source_header_id,source_line_id,inv_id,subinv_id,locator_id,item_id,first_cost,first_quantity,first_amount,tx_quantity,tx_amount,last_quantity,last_amount,last_cost,status,remark) VALUES" +
"(#{id},#{createBy},#{createTime},#{updateBy},#{updateTime},#{attributeCategory},#{attribute1},#{attribute2},#{attribute3},#{attribute4},#{attribute5},#{attribute6},#{attribute7},#{attribute8},#{attribute9},#{attribute10},#{txTypeId},#{txSourceTypeId},#{txActionId},#{txDate},#{txUnit},#{sourceHeaderId},#{sourceLineId},#{invId},#{subinvId},#{locatorId},#{itemId},#{firstCost},#{firstQuantity},#{firstAmount},#{txQuantity},#{txAmount},#{lastQuantity},#{lastAmount},#{lastCost},#{status},#{remark})"
)
Integer insert(InvTransactionCost InvTransactionCost);
@Select("select * from inv_transaction_cost where inv_id = #{invId} and item_id =#{itemId} ORDER BY tx_date desc LIMIT 1")
@ResultMap("invtransactioncost")
InvTransactionCost selectCostByInvIdAndItemId(@Param("invId")String invId,@Param("itemId")String itemId);
@Update("UPDATE inv_transaction_cost set tx_quantity=#{tx_quantity},tx_amount=#{tx_amount},last_amount=#{last_amount},last_quantity=#{last_quantity},last_cost=#{last_cost} where id=#{id}")
Integer updateInvTranCost(@Param("tx_quantity")Integer tx_quantity, @Param("tx_amount")Double tx_amount, @Param("last_amount")Double last_amount, @Param("last_quantity")Integer last_quantity, @Param("last_cost")Double last_cost,@Param("id")String id);
@Select("select * from inv_transaction_cost where source_header_id = #{headerId} and source_line_id = #{lineId}")
@ResultMap("invtransactioncost")
List<InvTransactionCost> selectInvTranCostBySource(@Param("headerId")String headerId,@Param("lineId")String lineId);
//调拨确认时修改跨库为跨库直接调拨
@Update("UPDATE inv_transaction_cost SET tx_action_id = '2c9f8d286bf8b3de016bfa1012a7008t' WHERE source_header_id = #{headerId} AND source_line_id = #{lineId}")
Integer updateInvTransactionCost(@Param("headerId")String headerId,@Param("lineId")String lineId);
//调拨确认时增加调入库区货架
@Update("UPDATE inv_transaction_cost SET subinv_id=#{subinvId},locator_id=#{locatorId} WHERE source_header_id = #{headerId} AND source_line_id = #{lineId} and inv_id=#{invId} and tx_quantity > 0")
Integer updateInvTranCostAtSure(@Param("subinvId")String subinvId,@Param("locatorId")String locatorId,@Param("headerId")String headerId,@Param("lineId")String lineId,@Param("invId")String invId);
}
\ No newline at end of file
...@@ -90,12 +90,16 @@ public interface InvTransactionMapper{ ...@@ -90,12 +90,16 @@ public interface InvTransactionMapper{
@ResultMap("invtransaction") @ResultMap("invtransaction")
List<InvTransaction> findInvTranAtSure(@Param("headerId")String headerId,@Param("lineId")String lineId,@Param("invId")String invId,@Param("subinvId")String subinvId,@Param("locatorId")String locatorId); List<InvTransaction> findInvTranAtSure(@Param("headerId")String headerId,@Param("lineId")String lineId,@Param("invId")String invId,@Param("subinvId")String subinvId,@Param("locatorId")String locatorId);
// //二次数量不一致时需修改
// @Update({"<script>" +
// "update inv_transaction SET tx_quantity = #{quantity} where source_header_id = #{headerId} AND source_line_id = #{lineId} and inv_id=#{invId} and subinv_id= #{subinvId} and source_code ='INVENTORY'" +
// "<if test = 'locatorId != null '>and locator_id = #{locatorId}</if>" +
// "</script>"})
// Integer updateInvTranQuantity(@Param("quantity")String quantity,@Param("headerId")String headerId,@Param("lineId")String lineId,@Param("invId")String invId,@Param("subinvId")String subinvId,@Param("locatorId")String locatorId);
//二次数量不一致时需修改 //二次数量不一致时需修改
@Update({"<script>" + @Update("update inv_transaction SET tx_quantity = #{quantity},tx_price = #{price} where id = #{id} and source_code ='INVENTORY'")
"update inv_transaction SET tx_quantity = #{quantity} where source_header_id = #{headerId} AND source_line_id = #{lineId} and inv_id=#{invId} and subinv_id= #{subinvId} and source_code ='INVENTORY'" + Integer updateInvTranQuantity(@Param("quantity")String quantity,@Param("id")String id,@Param("price")String price);
"<if test = 'locatorId != null '>and locator_id = #{locatorId}</if>" +
"</script>"})
Integer updateInvTranQuantity(@Param("quantity")String quantity,@Param("headerId")String headerId,@Param("lineId")String lineId,@Param("invId")String invId,@Param("subinvId")String subinvId,@Param("locatorId")String locatorId);
//查询库存调拨的出库信息 //查询库存调拨的出库信息
@Select("select * from inv_transaction where source_header_id = #{headerId} AND source_line_id = #{lineId} and tx_quantity < 0 and source_code ='INVENTORY'") @Select("select * from inv_transaction where source_header_id = #{headerId} AND source_line_id = #{lineId} and tx_quantity < 0 and source_code ='INVENTORY'")
......
...@@ -45,6 +45,7 @@ public interface RcvReceiptLineMapper{ ...@@ -45,6 +45,7 @@ public interface RcvReceiptLineMapper{
@Result(property = "sourceHeaderNumber", column = "source_header_number"), @Result(property = "sourceHeaderNumber", column = "source_header_number"),
@Result(property = "sourceLineId", column = "source_line_id"), @Result(property = "sourceLineId", column = "source_line_id"),
@Result(property = "sourceLineNumber", column = "source_line_number"), @Result(property = "sourceLineNumber", column = "source_line_number"),
@Result(property = "invId", column = "inv_id"),
}) })
public List<RcvReceiptLine> select(); public List<RcvReceiptLine> select();
......
...@@ -90,4 +90,8 @@ public interface WshShipmentHeaderMapper{ ...@@ -90,4 +90,8 @@ public interface WshShipmentHeaderMapper{
@Update("update wsh_shipment_header set update_by = #{updateBy},update_time = #{updateTime},header_status = #{status} where id = #{id}") @Update("update wsh_shipment_header set update_by = #{updateBy},update_time = #{updateTime},header_status = #{status} where id = #{id}")
boolean updateWshHeaderStatus(@Param("updateBy")String updateBy, @Param("updateTime")LocalDateTime updateTime,@Param("status")String status,@Param("id")String id); boolean updateWshHeaderStatus(@Param("updateBy")String updateBy, @Param("updateTime")LocalDateTime updateTime,@Param("status")String status,@Param("id")String id);
@Select("select * from wsh_shipment_header where id = #{id}")
@ResultMap("wshshipmentheader")
WshShipmentHeader selectWshShipHeaderById(@Param("id")String id);
} }
\ No newline at end of file
...@@ -98,4 +98,8 @@ public interface WshShipmentLineMapper{ ...@@ -98,4 +98,8 @@ public interface WshShipmentLineMapper{
@Update("update wsh_shipment_line set update_by = #{updateBy},update_time = #{updateTime},line_status = #{status} where wsh_shipment_header_id = #{id}") @Update("update wsh_shipment_line set update_by = #{updateBy},update_time = #{updateTime},line_status = #{status} where wsh_shipment_header_id = #{id}")
boolean updateLineStatus(@Param("updateBy")String updateBy, @Param("updateTime") LocalDateTime updateTime,@Param("status")String status,@Param("id")String id); boolean updateLineStatus(@Param("updateBy")String updateBy, @Param("updateTime") LocalDateTime updateTime,@Param("status")String status,@Param("id")String id);
@Select("select * from wsh_shipment_line where wsh_shipment_header_id = #{id}")
@ResultMap("wshshipmentline")
List<WshShipmentLine> selectWshShipLineByHeaderId(@Param("id")String id);
} }
\ No newline at end of file
package orthopedics.service;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import orthopedics.dao.InvTransactionCostMapper;
import orthopedics.model.InvTransactionCost;
import java.util.List;
@Service
public class InvTransacationCostService {
@Autowired
private InvTransactionCostMapper invTransactionCostMapper;
public InvTransactionCost findCostByInvIdAndItemId(String invId,String itemId){
return invTransactionCostMapper.selectCostByInvIdAndItemId(invId,itemId);
}
public Integer insertInvTransactionCost(InvTransactionCost invTransactionCost){
return invTransactionCostMapper.insert(invTransactionCost);
}
public Integer updateInvTranCost(Integer tx_quantity,Double tx_amount,Double last_amount,Integer last_quantity,Double last_cost,String id){
return invTransactionCostMapper.updateInvTranCost(tx_quantity,tx_amount,last_amount,last_quantity,last_cost,id);
}
public List<InvTransactionCost> findInvTranCostBySource(String headerId,String lineId){
return invTransactionCostMapper.selectInvTranCostBySource(headerId, lineId);
}
public Integer updateInvTransactionCost(String headerId,String lineId){
return invTransactionCostMapper.updateInvTransactionCost(headerId, lineId);
}
public Integer updateInvTranCostAtSure(String subinvId,String locatorId,String headerId,String lineId,String invId){
return invTransactionCostMapper.updateInvTranCostAtSure(subinvId, locatorId, headerId, lineId, invId);
}
}
...@@ -6,6 +6,7 @@ import java.util.List; ...@@ -6,6 +6,7 @@ import java.util.List;
import java.util.Map; import java.util.Map;
import org.springframework.beans.BeanUtils;
import orthopedics.dao.CstItemCostMapper; import orthopedics.dao.CstItemCostMapper;
import orthopedics.dao.FunctionMapper; import orthopedics.dao.FunctionMapper;
import orthopedics.dao.WshShipmentHeaderMapper; import orthopedics.dao.WshShipmentHeaderMapper;
...@@ -25,6 +26,7 @@ import org.springframework.beans.factory.annotation.Autowired; ...@@ -25,6 +26,7 @@ import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service; import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional; import org.springframework.transaction.annotation.Transactional;
import org.springframework.util.CollectionUtils; import org.springframework.util.CollectionUtils;
import orthopedics.vo.WshShipmentHeaderPage;
/** /**
* @author: su.yongpeng * @author: su.yongpeng
...@@ -175,4 +177,13 @@ public class ShipServer { ...@@ -175,4 +177,13 @@ public class ShipServer {
public boolean updateWshLineStatus(String updateBy,LocalDateTime updateTime,String status,String id){ public boolean updateWshLineStatus(String updateBy,LocalDateTime updateTime,String status,String id){
return wshShipmentLineMapper.updateLineStatus(updateBy, updateTime, status, id); return wshShipmentLineMapper.updateLineStatus(updateBy, updateTime, status, id);
} }
public WshShipmentHeaderPage findWshShipById(String id){
WshShipmentHeaderPage wshShipmentHeaderPage = new WshShipmentHeaderPage();
WshShipmentHeader wshShipmentHeader = wshShipmentHeaderMapper.selectWshShipHeaderById(id);
BeanUtils.copyProperties(wshShipmentHeader,wshShipmentHeaderPage);
List<WshShipmentLine> wshShipmentLineList = wshShipmentLineMapper.selectWshShipLineByHeaderId(id);
wshShipmentHeaderPage.setWshShipmentLineList(wshShipmentLineList);
return wshShipmentHeaderPage;
}
} }
...@@ -60,8 +60,8 @@ public class TransferService { ...@@ -60,8 +60,8 @@ public class TransferService {
return invItemOnhandMapper.updateInvItemOnhandAtSure(subinvId, locatorId, id); return invItemOnhandMapper.updateInvItemOnhandAtSure(subinvId, locatorId, id);
} }
public int updateInvTranQuantity(String quantity,String headerId,String lineId,String invId,String subinvId,String locatorId){ public int updateInvTranQuantity(String quantity,String id,String price){
return invTransactionMapper.updateInvTranQuantity(quantity, headerId, lineId, invId, subinvId, locatorId); return invTransactionMapper.updateInvTranQuantity(quantity,id,price);
} }
public InvTransaction findInInvTran(String headerId,String lineId){ public InvTransaction findInInvTran(String headerId,String lineId){
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or sign in to comment