|
|
|
@ -8,7 +8,9 @@ import com.glxp.sale.admin.entity.info.CompanyEntity;
|
|
|
|
|
import com.glxp.sale.admin.entity.inout.*;
|
|
|
|
|
import com.glxp.sale.admin.entity.inventory.InvProductDetailEntity;
|
|
|
|
|
import com.glxp.sale.admin.entity.inventory.InvProductEntity;
|
|
|
|
|
import com.glxp.sale.admin.entity.inventory.InvWarehouseEntity;
|
|
|
|
|
import com.glxp.sale.admin.entity.param.SystemParamConfigEntity;
|
|
|
|
|
import com.glxp.sale.admin.entity.udid.UdiEntity;
|
|
|
|
|
import com.glxp.sale.admin.req.basic.FilterUdiInfoRequest;
|
|
|
|
|
import com.glxp.sale.admin.req.inventory.FilterInvProductDetailRequest;
|
|
|
|
|
import com.glxp.sale.admin.res.basic.BussinessTypResponse;
|
|
|
|
@ -17,10 +19,7 @@ import com.glxp.sale.admin.res.inventory.InvProductDetailJoinResponse;
|
|
|
|
|
import com.glxp.sale.admin.service.basic.*;
|
|
|
|
|
import com.glxp.sale.admin.service.info.CompanyService;
|
|
|
|
|
import com.glxp.sale.admin.service.inout.*;
|
|
|
|
|
import com.glxp.sale.admin.service.inventory.InvPreProductDetailService;
|
|
|
|
|
import com.glxp.sale.admin.service.inventory.InvPreProductService;
|
|
|
|
|
import com.glxp.sale.admin.service.inventory.InvProductDetailService;
|
|
|
|
|
import com.glxp.sale.admin.service.inventory.InvProductService;
|
|
|
|
|
import com.glxp.sale.admin.service.inventory.*;
|
|
|
|
|
import com.glxp.sale.admin.service.param.SystemParamConfigService;
|
|
|
|
|
import com.glxp.sale.admin.util.CustomUtil;
|
|
|
|
|
import com.glxp.sale.admin.util.DateUtil;
|
|
|
|
@ -78,6 +77,8 @@ public class InvProductsTrService {
|
|
|
|
|
SystemParamConfigService systemParamConfigService;
|
|
|
|
|
@Resource
|
|
|
|
|
IOOrderStatusService ioOrderStatusService;
|
|
|
|
|
@Resource
|
|
|
|
|
InvWarehouseService invWarehouseService;
|
|
|
|
|
|
|
|
|
|
@Async
|
|
|
|
|
public void genInvProducts(String orderId) {
|
|
|
|
@ -106,7 +107,8 @@ public class InvProductsTrService {
|
|
|
|
|
ErpOrderEntity erpOrderEntity = getErpOrders(warehouseEntity, erpOrderEntities);
|
|
|
|
|
if (bussinessTypeEntity.isAdvanceType()) {//预入库,则转存预入库
|
|
|
|
|
InvProductEntity invPreProductEntity =
|
|
|
|
|
invPreProductService.selectByUuid(erpOrderEntity.getGoodsid(), erpOrderEntity.getBatchNo(), warehouseEntity.getSupId());
|
|
|
|
|
invPreProductService.selectByUuid(erpOrderEntity.getGoodsid(), erpOrderEntity.getBatchNo(), warehouseEntity.getSupId()
|
|
|
|
|
, warehouseEntity.getInvStorageCode(), warehouseEntity.getInvWarehouseCode());
|
|
|
|
|
if (invPreProductEntity == null) {
|
|
|
|
|
invPreProductEntity = buildInvProduct(erpOrderEntity.getGoodsid(), erpOrderEntity, orderEntity, warehouseEntity);
|
|
|
|
|
invPreProductService.insertInvProduct(invPreProductEntity);
|
|
|
|
@ -121,7 +123,8 @@ public class InvProductsTrService {
|
|
|
|
|
invPreProductService.updateInvProduct(invPreProductEntity);
|
|
|
|
|
}
|
|
|
|
|
} else { //普通出入库
|
|
|
|
|
InvProductEntity invProductEntity = invProductService.selectByUuid(erpOrderEntity.getGoodsid(), erpOrderEntity.getBatchNo(), warehouseEntity.getSupId());
|
|
|
|
|
InvProductEntity invProductEntity = invProductService.selectByUuid(erpOrderEntity.getGoodsid(), erpOrderEntity.getBatchNo(),
|
|
|
|
|
warehouseEntity.getSupId(), warehouseEntity.getInvStorageCode(), warehouseEntity.getInvWarehouseCode());
|
|
|
|
|
if (invProductEntity == null) {
|
|
|
|
|
invProductEntity = buildInvProduct(erpOrderEntity.getGoodsid(), erpOrderEntity, orderEntity, warehouseEntity);
|
|
|
|
|
invProductEntity.setUnitFk(orderEntity.getFromCorpId());
|
|
|
|
@ -168,24 +171,29 @@ public class InvProductsTrService {
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//单据流转
|
|
|
|
|
BussinessChangeTypeEntity bussinessChangeTypeEntity = bussinessChangeTypeService.findFirstByAction(bussinessLocalTypeEntity.getLocalAction());
|
|
|
|
|
if (bussinessLocalTypeEntity.getChangeEnable() && bussinessChangeTypeEntity != null) {
|
|
|
|
|
List<BussinessChangeTypeEntity> bussinessChangeTypeEntitys = bussinessChangeTypeService.findByAction(bussinessLocalTypeEntity.getLocalAction());
|
|
|
|
|
if ((bussinessChangeTypeEntitys != null && bussinessChangeTypeEntitys.size() > 0) && bussinessLocalTypeEntity.getChangeEnable()) {
|
|
|
|
|
|
|
|
|
|
//普通出库
|
|
|
|
|
if (ConstantType.TYPE_OUT.equals(bussinessTypeEntity.getMainAction()) && !bussinessTypeEntity.isAdvanceType()) {
|
|
|
|
|
List<WarehouseEntity> datas = addOutOrder(orderEntity, mInvProductDetailEntities);//1.先计算现有库存,
|
|
|
|
|
// insetInv(bussinessTypeEntity.isAdvanceType(), mInvProductDetailEntities);//2.插入当前库存
|
|
|
|
|
List<WarehouseEntity> temps = filterMapCodes(datas);
|
|
|
|
|
buildInOrder(bussinessChangeTypeEntity, temps, orderEntity); //3.生成流转单据
|
|
|
|
|
|
|
|
|
|
//补采购入库或寄售转入单
|
|
|
|
|
// List<WarehouseEntity> datas = addOutOrder(orderEntity, mInvProductDetailEntities);//1.先计算现有库存,
|
|
|
|
|
// List<WarehouseEntity> temps = filterMapCodes(datas);
|
|
|
|
|
|
|
|
|
|
addUseOutOrder(orderEntity, mInvProductDetailEntities, bussinessChangeTypeEntitys);
|
|
|
|
|
|
|
|
|
|
} else if (ConstantType.TYPE_PUT.equals(bussinessTypeEntity.getMainAction()) && !bussinessTypeEntity.isAdvanceType())
|
|
|
|
|
//普通入库补单
|
|
|
|
|
{
|
|
|
|
|
BussinessChangeTypeEntity bussinessChangeTypeEntity = bussinessChangeTypeEntitys.get(0);
|
|
|
|
|
List<WarehouseEntity> datas = addPutOrder(orderEntity, mInvProductDetailEntities);
|
|
|
|
|
List<WarehouseEntity> temps = filterMapCodes(datas);
|
|
|
|
|
// insetInv(bussinessTypeEntity.isAdvanceType(), mInvProductDetailEntities);//2.插入当前库存
|
|
|
|
|
buildPreOutOrder(bussinessChangeTypeEntity, temps, orderEntity); //3.生成流转单据
|
|
|
|
|
} else if (ConstantType.TYPE_OUT.equals(bussinessTypeEntity.getMainAction()) && bussinessTypeEntity.isAdvanceType()) {
|
|
|
|
|
//寄售出库补单
|
|
|
|
|
BussinessChangeTypeEntity bussinessChangeTypeEntity = bussinessChangeTypeEntitys.get(0);
|
|
|
|
|
List<WarehouseEntity> datas = addPreOutOrder(orderEntity, mInvProductDetailEntities);
|
|
|
|
|
List<WarehouseEntity> temps = filterMapCodes(datas);
|
|
|
|
|
// insetInv(bussinessTypeEntity.isAdvanceType(), mInvProductDetailEntities);//2.插入当前库存
|
|
|
|
@ -199,34 +207,136 @@ public class InvProductsTrService {
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//普通出库补单
|
|
|
|
|
public List<WarehouseEntity> addOutOrder(OrderEntity orderEntity, List<InvProductDetailEntity> invProductDetailEntities) {
|
|
|
|
|
//普通出库补单-- //补采购入库或寄售转入单
|
|
|
|
|
public void addUseOutOrder(OrderEntity orderEntity, List<InvProductDetailEntity> invProductDetailEntities, List<BussinessChangeTypeEntity> bussinessChangeTypeEntities) {
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
List<WarehouseEntity> warehouseEntities = codesService.findByReceiptId(orderEntity.getId());
|
|
|
|
|
List<WarehouseEntity> inList = new ArrayList<>();
|
|
|
|
|
List<WarehouseEntity> preiInList = new ArrayList<>();
|
|
|
|
|
for (WarehouseEntity warehouseEntity : warehouseEntities) {
|
|
|
|
|
|
|
|
|
|
if (isAdavnce(warehouseEntity)) {//补寄售转入
|
|
|
|
|
|
|
|
|
|
//获取普通出入库结余数量
|
|
|
|
|
int actCount = getActCount(warehouseEntity);
|
|
|
|
|
int count = 0;
|
|
|
|
|
UdiInfoEntity udiInfoEntity = getMinDi(warehouseEntity);
|
|
|
|
|
String code = warehouseEntity.getCode();
|
|
|
|
|
if (udiInfoEntity.getDiType() == ConstantStatus.DITYPE_PACK || udiInfoEntity.getDiType() == ConstantStatus.DITYPE_SYDY
|
|
|
|
|
|| (udiInfoEntity.getSjcpbm() != null && !"".equals(udiInfoEntity.getSjcpbm()))) {
|
|
|
|
|
warehouseEntity.setNameCode(udiInfoEntity.getNameCode());
|
|
|
|
|
code = FilterUdiUtils.transGlxpNoSerStr(warehouseEntity);
|
|
|
|
|
count = actCount * warehouseEntity.getCount();
|
|
|
|
|
} else {
|
|
|
|
|
count = warehouseEntity.getCount();
|
|
|
|
|
}
|
|
|
|
|
int invCount = getCountByOrder(null, warehouseEntity.getCode(), warehouseEntity.getSupId());
|
|
|
|
|
if (invCount <= 0) {
|
|
|
|
|
invCount = getCountByOrder(null, code, warehouseEntity.getSupId());
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (invCount > 0) {
|
|
|
|
|
if (count > invCount) {
|
|
|
|
|
int lea = count - invCount;
|
|
|
|
|
warehouseEntity.setCount(lea / (getActCount(warehouseEntity)));
|
|
|
|
|
preiInList.add(warehouseEntity);
|
|
|
|
|
}
|
|
|
|
|
} else {
|
|
|
|
|
warehouseEntity.setCount(count);
|
|
|
|
|
preiInList.add(warehouseEntity);
|
|
|
|
|
}
|
|
|
|
|
InvProductDetailEntity invProductDetailEntity = filterInvByCode(invProductDetailEntities, warehouseEntity.getCode());
|
|
|
|
|
insetInvSingle(false, invProductDetailEntity);
|
|
|
|
|
warehouseEntity.setCode(code);
|
|
|
|
|
|
|
|
|
|
} else {
|
|
|
|
|
//获取普通出入库结余数量
|
|
|
|
|
int actCount = getActCount(warehouseEntity);
|
|
|
|
|
int count = 0;
|
|
|
|
|
UdiInfoEntity udiInfoEntity = getMinDi(warehouseEntity);
|
|
|
|
|
String code = warehouseEntity.getCode();
|
|
|
|
|
if (udiInfoEntity.getDiType() == ConstantStatus.DITYPE_PACK || udiInfoEntity.getDiType() == ConstantStatus.DITYPE_SYDY
|
|
|
|
|
|| (udiInfoEntity.getSjcpbm() != null && !"".equals(udiInfoEntity.getSjcpbm()))) {
|
|
|
|
|
warehouseEntity.setNameCode(udiInfoEntity.getNameCode());
|
|
|
|
|
code = FilterUdiUtils.transGlxpNoSerStr(warehouseEntity);
|
|
|
|
|
count = actCount * warehouseEntity.getCount();
|
|
|
|
|
} else {
|
|
|
|
|
count = warehouseEntity.getCount();
|
|
|
|
|
}
|
|
|
|
|
int invCount = getCountByOrder(null, warehouseEntity.getCode(), warehouseEntity.getSupId());
|
|
|
|
|
if (invCount <= 0) {
|
|
|
|
|
invCount = getCountByOrder(null, code, warehouseEntity.getSupId());
|
|
|
|
|
}
|
|
|
|
|
if (invCount > 0) {
|
|
|
|
|
if (count > invCount) {
|
|
|
|
|
int lea = count - invCount;
|
|
|
|
|
warehouseEntity.setCount(lea / getActCount(warehouseEntity));
|
|
|
|
|
inList.add(warehouseEntity);
|
|
|
|
|
}
|
|
|
|
|
} else {
|
|
|
|
|
warehouseEntity.setCount(count);
|
|
|
|
|
inList.add(warehouseEntity);
|
|
|
|
|
}
|
|
|
|
|
InvProductDetailEntity invProductDetailEntity = filterInvByCode(invProductDetailEntities, warehouseEntity.getCode());
|
|
|
|
|
insetInvSingle(false, invProductDetailEntity);
|
|
|
|
|
warehouseEntity.setCode(code);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
BussinessChangeTypeEntity advChangeTypeEntity = null;
|
|
|
|
|
BussinessChangeTypeEntity norChangeTypeEntity = null;
|
|
|
|
|
for (BussinessChangeTypeEntity bussinessChangeTypeEntity : bussinessChangeTypeEntities) {
|
|
|
|
|
if (bussinessChangeTypeEntity.getChangeType() == ConstantStatus.ORDER_CHANGE_NORMAL_ADV_IN) {
|
|
|
|
|
advChangeTypeEntity = bussinessChangeTypeEntity;
|
|
|
|
|
} else if (bussinessChangeTypeEntity.getChangeType() == ConstantStatus.ORDER_CHANGE_NORMAL_IN) {
|
|
|
|
|
norChangeTypeEntity = bussinessChangeTypeEntity;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
if (inList.size() > 0) {
|
|
|
|
|
List<WarehouseEntity> temps = filterMapCodes(inList);
|
|
|
|
|
buildInOrder(norChangeTypeEntity, temps, orderEntity); //3.生成采购入库流转单据
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (preiInList.size() > 0) {
|
|
|
|
|
List<WarehouseEntity> temps1 = filterMapCodes(preiInList);
|
|
|
|
|
buildNorPreInOrder(advChangeTypeEntity, temps1, orderEntity); //3.补寄售转入
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
public List<WarehouseEntity> addOutOrder(OrderEntity
|
|
|
|
|
orderEntity, List<InvProductDetailEntity> invProductDetailEntities) {
|
|
|
|
|
List<WarehouseEntity> warehouseEntities = codesService.findByReceiptId(orderEntity.getId());
|
|
|
|
|
List<WarehouseEntity> inList = new ArrayList<>();
|
|
|
|
|
for (WarehouseEntity warehouseEntity : warehouseEntities) {
|
|
|
|
|
//获取普通出入库结余数量
|
|
|
|
|
int actCount = getActCount(warehouseEntity);
|
|
|
|
|
int count = 0;
|
|
|
|
|
UdiInfoEntity udiInfoEntity = getMinDi(warehouseEntity);
|
|
|
|
|
String code = warehouseEntity.getCode();
|
|
|
|
|
if (udiInfoEntity.getDiType() == ConstantStatus.DITYPE_PACK || udiInfoEntity.getDiType() == ConstantStatus.DITYPE_SYDY
|
|
|
|
|
|| (udiInfoEntity.getSjcpbm() != null && !"".equals(udiInfoEntity.getSjcpbm()))) {
|
|
|
|
|
warehouseEntity.setNameCode(udiInfoEntity.getNameCode());
|
|
|
|
|
code = FilterUdiUtils.transGlxpNoSerStr(warehouseEntity);
|
|
|
|
|
// warehouseEntity.setCode(code);
|
|
|
|
|
// warehouseEntity.setCount(actCount * warehouseEntity.getCount());
|
|
|
|
|
count = actCount * warehouseEntity.getCount();
|
|
|
|
|
} else {
|
|
|
|
|
count = warehouseEntity.getCount();
|
|
|
|
|
}
|
|
|
|
|
int invCount = getCountByOrder(null, warehouseEntity.getCode(), warehouseEntity.getSupId());
|
|
|
|
|
if (invCount <= 0) {
|
|
|
|
|
invCount = getCountByOrder(null, code, warehouseEntity.getSupId());
|
|
|
|
|
}
|
|
|
|
|
if (invCount > 0) {
|
|
|
|
|
int count = actCount * warehouseEntity.getCount();
|
|
|
|
|
if (count > invCount) {
|
|
|
|
|
int lea = count - invCount;
|
|
|
|
|
warehouseEntity.setCount(lea / (getActCount(warehouseEntity)));
|
|
|
|
|
warehouseEntity.setCount(lea / actCount);
|
|
|
|
|
inList.add(warehouseEntity);
|
|
|
|
|
}
|
|
|
|
|
} else {
|
|
|
|
|
warehouseEntity.setCount(count);
|
|
|
|
|
inList.add(warehouseEntity);
|
|
|
|
|
}
|
|
|
|
|
InvProductDetailEntity invProductDetailEntity = filterInvByCode(invProductDetailEntities, warehouseEntity.getCode());
|
|
|
|
@ -237,21 +347,12 @@ public class InvProductsTrService {
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//普通入库补单
|
|
|
|
|
public List<WarehouseEntity> addPutOrder(OrderEntity orderEntity, List<InvProductDetailEntity> invProductDetailEntities) {
|
|
|
|
|
public List<WarehouseEntity> addPutOrder(OrderEntity
|
|
|
|
|
orderEntity, List<InvProductDetailEntity> invProductDetailEntities) {
|
|
|
|
|
List<WarehouseEntity> warehouseEntities = codesService.findByReceiptId(orderEntity.getId());
|
|
|
|
|
List<WarehouseEntity> preOutList = new ArrayList<>();
|
|
|
|
|
for (WarehouseEntity warehouseEntity : warehouseEntities) {
|
|
|
|
|
//获取普通出入库结余数量
|
|
|
|
|
FilterInvProductDetailRequest filterInvProductDetailRequest = new FilterInvProductDetailRequest();
|
|
|
|
|
// filterInvProductDetailRequest.setCode(warehouseEntity.getCode());
|
|
|
|
|
filterInvProductDetailRequest.setProductIdFk(warehouseEntity.getRelId());
|
|
|
|
|
filterInvProductDetailRequest.setSupId(warehouseEntity.getSupId());
|
|
|
|
|
List<InvProductDetailJoinResponse> detailJoinResponseList
|
|
|
|
|
= invPreProductDetailService.filterJoinInvProduct(filterInvProductDetailRequest);
|
|
|
|
|
UdiRelevanceEntity udiRelevanceEntity = udiRelevanceService.selectById(warehouseEntity.getRelId());
|
|
|
|
|
if ((detailJoinResponseList != null && detailJoinResponseList.size() > 0)
|
|
|
|
|
|| (udiRelevanceEntity.getIsAdavence() != null && udiRelevanceEntity.getIsAdavence())
|
|
|
|
|
) {
|
|
|
|
|
if (isAdavnce(warehouseEntity)) {
|
|
|
|
|
preOutList.add(warehouseEntity);
|
|
|
|
|
}
|
|
|
|
|
InvProductDetailEntity invProductDetailEntity = filterInvByCode(invProductDetailEntities, warehouseEntity.getCode());
|
|
|
|
@ -261,21 +362,24 @@ public class InvProductsTrService {
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//寄售出库补单
|
|
|
|
|
public List<WarehouseEntity> addPreOutOrder(OrderEntity orderEntity, List<InvProductDetailEntity> invProductDetailEntities) {
|
|
|
|
|
public List<WarehouseEntity> addPreOutOrder(OrderEntity
|
|
|
|
|
orderEntity, List<InvProductDetailEntity> invProductDetailEntities) {
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
List<WarehouseEntity> warehouseEntities = codesService.findByReceiptId(orderEntity.getId());
|
|
|
|
|
List<WarehouseEntity> prePutList = new ArrayList<>();
|
|
|
|
|
for (WarehouseEntity warehouseEntity : warehouseEntities) {
|
|
|
|
|
// int actCount = getActCount(warehouseEntity);
|
|
|
|
|
int actCount = getActCount(warehouseEntity);
|
|
|
|
|
int count = 0;
|
|
|
|
|
String code = warehouseEntity.getCode();
|
|
|
|
|
UdiInfoEntity udiInfoEntity = getMinDi(warehouseEntity);
|
|
|
|
|
if (udiInfoEntity.getDiType() == ConstantStatus.DITYPE_PACK || udiInfoEntity.getDiType() == ConstantStatus.DITYPE_SYDY
|
|
|
|
|
|| (udiInfoEntity.getSjcpbm() != null && !"".equals(udiInfoEntity.getSjcpbm()))) {
|
|
|
|
|
warehouseEntity.setNameCode(udiInfoEntity.getNameCode());
|
|
|
|
|
code = FilterUdiUtils.transGlxpNoSerStr(warehouseEntity);
|
|
|
|
|
// warehouseEntity.setCode(code);
|
|
|
|
|
// warehouseEntity.setCount(actCount * warehouseEntity.getCount());
|
|
|
|
|
count = actCount * warehouseEntity.getCount();
|
|
|
|
|
} else {
|
|
|
|
|
count = warehouseEntity.getCount();
|
|
|
|
|
}
|
|
|
|
|
//获取寄售出入库结余数量
|
|
|
|
|
int invCount = getPreCountByOrder(null, warehouseEntity.getCode(), warehouseEntity.getSupId());
|
|
|
|
@ -283,13 +387,13 @@ public class InvProductsTrService {
|
|
|
|
|
invCount = getPreCountByOrder(null, code, warehouseEntity.getSupId());
|
|
|
|
|
}
|
|
|
|
|
if (invCount > 0) {
|
|
|
|
|
int count = getActCount(warehouseEntity) * warehouseEntity.getCount();
|
|
|
|
|
if (count > invCount) {
|
|
|
|
|
int lea = count - invCount;
|
|
|
|
|
warehouseEntity.setCount(lea / (getActCount(warehouseEntity)));
|
|
|
|
|
warehouseEntity.setCount(lea / (getActCount(warehouseEntity.getCode())));
|
|
|
|
|
prePutList.add(warehouseEntity);
|
|
|
|
|
}
|
|
|
|
|
} else {
|
|
|
|
|
warehouseEntity.setCount(count);
|
|
|
|
|
prePutList.add(warehouseEntity);
|
|
|
|
|
}
|
|
|
|
|
InvProductDetailEntity invProductDetailEntity = filterInvByCode(invProductDetailEntities, warehouseEntity.getCode());
|
|
|
|
@ -320,6 +424,8 @@ public class InvProductsTrService {
|
|
|
|
|
if (preOutList == null || preOutList.size() <= 0) {
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
InvWarehouseEntity invWarehouseEntity = invWarehouseService.selectByCode(orderEntity.getLocStorageCode());
|
|
|
|
|
InvWarehouseEntity defaultWarehouseEntity = invWarehouseService.findDefault(true, true);
|
|
|
|
|
//寄售出库生成单据
|
|
|
|
|
CompanyEntity companyEntity = companyService.findCompany(Long.parseLong(Constant.SYSTEM_CUSTOMER_ID));
|
|
|
|
|
OrderEntity outOrder = new OrderEntity();
|
|
|
|
@ -338,14 +444,18 @@ public class InvProductsTrService {
|
|
|
|
|
outOrder.setErpFk(null);
|
|
|
|
|
outOrder.setCustomerId(Constant.SYSTEM_CUSTOMER_ID);
|
|
|
|
|
outOrder.setId(CustomUtil.getId());
|
|
|
|
|
outOrder.setFromCorp(companyEntity.getCompanyName());
|
|
|
|
|
outOrder.setFromCorpId(companyEntity.getUnitIdFk());
|
|
|
|
|
outOrder.setFromCorp(invWarehouseEntity.getName());
|
|
|
|
|
outOrder.setFromCorpId(invWarehouseEntity.getCode());
|
|
|
|
|
outOrder.setLocStorageCode(defaultWarehouseEntity.getCode());
|
|
|
|
|
// outOrder.setFromCorp(companyEntity.getCompanyName());
|
|
|
|
|
// outOrder.setFromCorpId(companyEntity.getUnitIdFk());
|
|
|
|
|
orderService.insertOrder(outOrder);
|
|
|
|
|
for (WarehouseEntity warehouseEntity : preOutList) {
|
|
|
|
|
warehouseEntity.setOrderId(outOrder.getId());
|
|
|
|
|
warehouseEntity.setFromCorp(orderEntity.getFromCorp());
|
|
|
|
|
warehouseEntity.setFromCorpId(orderEntity.getFromCorpId());
|
|
|
|
|
warehouseEntity.setFromCorp(invWarehouseEntity.getName());
|
|
|
|
|
warehouseEntity.setFromCorpId(invWarehouseEntity.getCode());
|
|
|
|
|
warehouseEntity.setId(null);
|
|
|
|
|
warehouseEntity.setLocStorageCode(defaultWarehouseEntity.getCode());
|
|
|
|
|
warehouseEntity.setAction(bussinessChangeTypeEntity.getScAction());
|
|
|
|
|
warehouseEntity.setMainAction(ConstantType.TYPE_OUT);
|
|
|
|
|
}
|
|
|
|
@ -402,12 +512,14 @@ public class InvProductsTrService {
|
|
|
|
|
BasicUnitMaintainEntity basicUnitMaintainEntity = basicUnitMaintainService.selectByErpId(corpName);
|
|
|
|
|
outOrder.setFromCorp(basicUnitMaintainEntity.getName());
|
|
|
|
|
outOrder.setFromCorpId(corpName);
|
|
|
|
|
outOrder.setLocStorageCode(orderEntity.getLocStorageCode());
|
|
|
|
|
orderService.insertOrder(outOrder);
|
|
|
|
|
for (WarehouseEntity warehouseEntity : temps) {
|
|
|
|
|
warehouseEntity.setOrderId(outOrder.getId());
|
|
|
|
|
warehouseEntity.setId(null);
|
|
|
|
|
warehouseEntity.setFromCorp(outOrder.getFromCorp());
|
|
|
|
|
warehouseEntity.setFromCorpId(outOrder.getFromCorpId());
|
|
|
|
|
warehouseEntity.setLocStorageCode(outOrder.getLocStorageCode());
|
|
|
|
|
warehouseEntity.setAction(bussinessChangeTypeEntity.getScAction());
|
|
|
|
|
warehouseEntity.setMainAction(ConstantType.TYPE_PUT);
|
|
|
|
|
}
|
|
|
|
@ -437,6 +549,7 @@ public class InvProductsTrService {
|
|
|
|
|
outOrder.setFromCorp(null);
|
|
|
|
|
outOrder.setCustomerId(Constant.SYSTEM_CUSTOMER_ID);
|
|
|
|
|
outOrder.setFromCorpId(null);
|
|
|
|
|
outOrder.setLocStorageCode(orderEntity.getLocStorageCode());
|
|
|
|
|
orderService.insertOrder(outOrder);
|
|
|
|
|
warehouseEntity.setOrderId(outOrder.getId());
|
|
|
|
|
warehouseEntity.setId(null);
|
|
|
|
@ -444,6 +557,7 @@ public class InvProductsTrService {
|
|
|
|
|
warehouseEntity.setMainAction(ConstantType.TYPE_PUT);
|
|
|
|
|
warehouseEntity.setFromCorp(null);
|
|
|
|
|
warehouseEntity.setFromCorpId(null);
|
|
|
|
|
warehouseEntity.setLocStorageCode(outOrder.getLocStorageCode());
|
|
|
|
|
codesTempService.insertCodesTempSingle(warehouseEntity);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
@ -459,7 +573,7 @@ public class InvProductsTrService {
|
|
|
|
|
//采购入库生成单据
|
|
|
|
|
Map<String, List<WarehouseEntity>> filterSupMaps = new HashMap<>();
|
|
|
|
|
List<WarehouseEntity> unkonwCorpList = new ArrayList<>();
|
|
|
|
|
|
|
|
|
|
// InvWarehouseEntity invWarehouseEntity = invWarehouseService.findDefault(false, true);
|
|
|
|
|
//根据库存,过滤供应商,条码分组
|
|
|
|
|
for (WarehouseEntity warehouseEntity : useInList) {
|
|
|
|
|
if (warehouseEntity.getSupId() != null) {
|
|
|
|
@ -491,6 +605,7 @@ public class InvProductsTrService {
|
|
|
|
|
BasicUnitMaintainEntity basicUnitMaintainEntity = basicUnitMaintainService.selectByErpId(corpName);
|
|
|
|
|
outOrder.setFromCorp(basicUnitMaintainEntity.getName());
|
|
|
|
|
outOrder.setFromCorpId(corpName);
|
|
|
|
|
outOrder.setLocStorageCode(orderEntity.getLocStorageCode());
|
|
|
|
|
SystemParamConfigEntity systemParamConfigEntity = systemParamConfigService.selectByParamKey("additional_auto_submit");
|
|
|
|
|
if ("1".equals(systemParamConfigEntity.getParamValue())) {
|
|
|
|
|
outOrder.setStatus(ConstantStatus.ORDER_STATUS_PROCESS);
|
|
|
|
@ -504,6 +619,7 @@ public class InvProductsTrService {
|
|
|
|
|
warehouseEntity.setId(null);
|
|
|
|
|
warehouseEntity.setFromCorp(outOrder.getFromCorp());
|
|
|
|
|
warehouseEntity.setFromCorpId(outOrder.getFromCorpId());
|
|
|
|
|
warehouseEntity.setLocStorageCode(outOrder.getLocStorageCode());
|
|
|
|
|
warehouseEntity.setAction(bussinessChangeTypeEntity.getScAction());
|
|
|
|
|
warehouseEntity.setMainAction(ConstantType.TYPE_PUT);
|
|
|
|
|
}
|
|
|
|
@ -531,6 +647,7 @@ public class InvProductsTrService {
|
|
|
|
|
outOrder.setErpFk(null);
|
|
|
|
|
outOrder.setId(CustomUtil.getId());
|
|
|
|
|
outOrder.setFromCorp(null);
|
|
|
|
|
outOrder.setLocStorageCode(orderEntity.getLocStorageCode());
|
|
|
|
|
outOrder.setFromCorpId(null);
|
|
|
|
|
orderService.insertOrder(outOrder);
|
|
|
|
|
warehouseEntity.setOrderId(outOrder.getId());
|
|
|
|
@ -539,6 +656,109 @@ public class InvProductsTrService {
|
|
|
|
|
warehouseEntity.setMainAction(ConstantType.TYPE_PUT);
|
|
|
|
|
warehouseEntity.setFromCorp(null);
|
|
|
|
|
warehouseEntity.setFromCorpId(null);
|
|
|
|
|
warehouseEntity.setLocStorageCode(outOrder.getLocStorageCode());
|
|
|
|
|
codesTempService.insertCodesTempSingle(warehouseEntity);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//生成寄售转入单据
|
|
|
|
|
public void buildNorPreInOrder(BussinessChangeTypeEntity
|
|
|
|
|
bussinessChangeTypeEntity, List<WarehouseEntity> useInList, OrderEntity orderEntity) {
|
|
|
|
|
if (useInList.size() <= 0) {
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
//采购入库生成单据
|
|
|
|
|
Map<String, List<WarehouseEntity>> filterSupMaps = new HashMap<>();
|
|
|
|
|
List<WarehouseEntity> unkonwCorpList = new ArrayList<>();
|
|
|
|
|
InvWarehouseEntity invWarehouseEntity = invWarehouseService.findDefault(true, true);
|
|
|
|
|
//根据库存,过滤供应商,条码分组
|
|
|
|
|
for (WarehouseEntity warehouseEntity : useInList) {
|
|
|
|
|
if (warehouseEntity.getSupId() != null) {
|
|
|
|
|
if (filterSupMaps.get(warehouseEntity.getSupId()) == null) {
|
|
|
|
|
List<WarehouseEntity> temps = new ArrayList<>();
|
|
|
|
|
temps.add(warehouseEntity);
|
|
|
|
|
filterSupMaps.put(warehouseEntity.getSupId(), temps);
|
|
|
|
|
} else {
|
|
|
|
|
filterSupMaps.get(warehouseEntity.getSupId()).add(warehouseEntity);
|
|
|
|
|
}
|
|
|
|
|
} else
|
|
|
|
|
unkonwCorpList.add(warehouseEntity);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//有供应商生成采购入库单据
|
|
|
|
|
for (String corpName : filterSupMaps.keySet()) {
|
|
|
|
|
List<WarehouseEntity> temps;
|
|
|
|
|
temps = filterSupMaps.get(corpName);
|
|
|
|
|
OrderEntity outOrder = new OrderEntity();
|
|
|
|
|
BeanUtils.copyProperties(orderEntity, outOrder);
|
|
|
|
|
outOrder.setActDate(DateUtil.getBeforeDay(outOrder.getActDate(), bussinessChangeTypeEntity.getBeforeTime()));
|
|
|
|
|
outOrder.setAction(bussinessChangeTypeEntity.getScAction());
|
|
|
|
|
outOrder.setMainAction(ConstantType.TYPE_PUT);
|
|
|
|
|
outOrder.setContrastStatus(ConstantStatus.ORDER_CHECK_UN);
|
|
|
|
|
outOrder.setCustomerId(Constant.SYSTEM_CUSTOMER_ID);
|
|
|
|
|
outOrder.setFromCorp(invWarehouseEntity.getName());
|
|
|
|
|
outOrder.setFromCorpId(invWarehouseEntity.getCode());
|
|
|
|
|
outOrder.setLocStorageCode(orderEntity.getLocStorageCode());
|
|
|
|
|
outOrder.setErpFk(null);
|
|
|
|
|
outOrder.setFromType(ConstantStatus.FROM_CHANGE);
|
|
|
|
|
outOrder.setId(CustomUtil.getId());
|
|
|
|
|
// BasicUnitMaintainEntity basicUnitMaintainEntity = basicUnitMaintainService.selectByErpId(corpName);
|
|
|
|
|
// outOrder.setFromCorp(basicUnitMaintainEntity.getName());
|
|
|
|
|
// outOrder.setFromCorpId(corpName);
|
|
|
|
|
SystemParamConfigEntity systemParamConfigEntity = systemParamConfigService.selectByParamKey("additional_auto_submit");
|
|
|
|
|
if ("1".equals(systemParamConfigEntity.getParamValue())) {
|
|
|
|
|
outOrder.setStatus(ConstantStatus.ORDER_STATUS_PROCESS);
|
|
|
|
|
} else {
|
|
|
|
|
outOrder.setStatus(ConstantStatus.ORDER_STATUS_ADDITIONAL);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
orderService.insertOrder(outOrder);
|
|
|
|
|
for (WarehouseEntity warehouseEntity : temps) {
|
|
|
|
|
warehouseEntity.setOrderId(outOrder.getId());
|
|
|
|
|
warehouseEntity.setId(null);
|
|
|
|
|
warehouseEntity.setFromCorp(outOrder.getFromCorp());
|
|
|
|
|
warehouseEntity.setFromCorpId(outOrder.getFromCorpId());
|
|
|
|
|
warehouseEntity.setLocStorageCode(outOrder.getLocStorageCode());
|
|
|
|
|
warehouseEntity.setAction(bussinessChangeTypeEntity.getScAction());
|
|
|
|
|
warehouseEntity.setMainAction(ConstantType.TYPE_PUT);
|
|
|
|
|
}
|
|
|
|
|
codesTempService.insertCodesTemp(temps);
|
|
|
|
|
// ioTransInoutService.transInout(outOrder.getId());
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//无供应商,一个条码生成一个错误单据,到时候利用单据合并生成同一个单据
|
|
|
|
|
for (WarehouseEntity warehouseEntity : unkonwCorpList) {
|
|
|
|
|
OrderEntity outOrder = new OrderEntity();
|
|
|
|
|
BeanUtils.copyProperties(orderEntity, outOrder);
|
|
|
|
|
outOrder.setActDate(DateUtil.getBeforeDay(outOrder.getActDate(), bussinessChangeTypeEntity.getBeforeTime()));
|
|
|
|
|
outOrder.setAction(bussinessChangeTypeEntity.getScAction());
|
|
|
|
|
outOrder.setMainAction(ConstantType.TYPE_PUT);
|
|
|
|
|
SystemParamConfigEntity systemParamConfigEntity = systemParamConfigService.selectByParamKey("additional_auto_submit");
|
|
|
|
|
if ("1".equals(systemParamConfigEntity.getParamValue())) {
|
|
|
|
|
outOrder.setStatus(ConstantStatus.ORDER_STATUS_PROCESS);
|
|
|
|
|
} else {
|
|
|
|
|
outOrder.setStatus(ConstantStatus.ORDER_STATUS_ADDITIONAL);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
outOrder.setContrastStatus(ConstantStatus.ORDER_CHECK_UN);
|
|
|
|
|
outOrder.setRemark("未选择供应商");
|
|
|
|
|
outOrder.setErpFk(null);
|
|
|
|
|
outOrder.setId(CustomUtil.getId());
|
|
|
|
|
outOrder.setFromCorp(invWarehouseEntity.getName());
|
|
|
|
|
outOrder.setFromCorpId(invWarehouseEntity.getCode());
|
|
|
|
|
outOrder.setLocStorageCode(orderEntity.getLocStorageCode());
|
|
|
|
|
orderService.insertOrder(outOrder);
|
|
|
|
|
warehouseEntity.setOrderId(outOrder.getId());
|
|
|
|
|
warehouseEntity.setId(null);
|
|
|
|
|
warehouseEntity.setAction(bussinessChangeTypeEntity.getScAction());
|
|
|
|
|
warehouseEntity.setMainAction(ConstantType.TYPE_PUT);
|
|
|
|
|
warehouseEntity.setFromCorp(outOrder.getFromCorp());
|
|
|
|
|
warehouseEntity.setFromCorpId(outOrder.getFromCorpId());
|
|
|
|
|
warehouseEntity.setLocStorageCode(outOrder.getLocStorageCode());
|
|
|
|
|
codesTempService.insertCodesTempSingle(warehouseEntity);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
@ -547,7 +767,8 @@ public class InvProductsTrService {
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//生成库存
|
|
|
|
|
private InvProductEntity buildInvProduct(String relId, ErpOrderEntity erpOrderEntity, OrderEntity orderEntity, WarehouseEntity warehouseEntity) {
|
|
|
|
|
private InvProductEntity buildInvProduct(String relId, ErpOrderEntity erpOrderEntity, OrderEntity
|
|
|
|
|
orderEntity, WarehouseEntity warehouseEntity) {
|
|
|
|
|
InvProductEntity invProductEntity = new InvProductEntity();
|
|
|
|
|
invProductEntity.setRelIdFk(relId);
|
|
|
|
|
invProductEntity.setBatchNo(erpOrderEntity.getBatchNo());
|
|
|
|
@ -560,6 +781,8 @@ public class InvProductsTrService {
|
|
|
|
|
invProductEntity.setProductsName(erpOrderEntity.getCoName());
|
|
|
|
|
invProductEntity.setYlqxzcrbarmc(erpOrderEntity.getProductCompany());
|
|
|
|
|
invProductEntity.setZczbhhzbapzbh(erpOrderEntity.getAuthCode());
|
|
|
|
|
invProductEntity.setInvStorageCode(warehouseEntity.getInvStorageCode());
|
|
|
|
|
invProductEntity.setInvWarehouseCode(warehouseEntity.getInvWarehouseCode());
|
|
|
|
|
int count = getActCount(warehouseEntity) * warehouseEntity.getCount();
|
|
|
|
|
if (orderEntity.getMainAction().equals(ConstantType.TYPE_OUT)) {
|
|
|
|
|
invProductEntity.setOutCount(count);
|
|
|
|
@ -600,6 +823,8 @@ public class InvProductsTrService {
|
|
|
|
|
invProductDetailEntity.setExpireDate(warehouseEntity.getExpireDate());
|
|
|
|
|
invProductDetailEntity.setAction(warehouseEntity.getAction());
|
|
|
|
|
invProductDetailEntity.setMainAction(orderEntity.getMainAction());
|
|
|
|
|
invProductDetailEntity.setInvStorageCode(warehouseEntity.getInvStorageCode());
|
|
|
|
|
invProductDetailEntity.setInvWarehouseCode(warehouseEntity.getWarehouseCode());
|
|
|
|
|
invProductDetailEntity.setOrderIdFk(warehouseEntity.getOrderId());
|
|
|
|
|
invProductDetailEntity.setCount(actCount * warehouseEntity.getCount());
|
|
|
|
|
if (purchaseType != null) {
|
|
|
|
@ -657,7 +882,8 @@ public class InvProductsTrService {
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
public InvProductDetailEntity filterInvByCode(List<InvProductDetailEntity> invProductDetailEntities, String code) {
|
|
|
|
|
public InvProductDetailEntity filterInvByCode(List<InvProductDetailEntity> invProductDetailEntities, String
|
|
|
|
|
code) {
|
|
|
|
|
|
|
|
|
|
for (InvProductDetailEntity invProductDetailEntity : invProductDetailEntities) {
|
|
|
|
|
if (invProductDetailEntity.getOriginCode().equals(code)) {
|
|
|
|
@ -683,6 +909,22 @@ public class InvProductsTrService {
|
|
|
|
|
return 1;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public int getActCount(String code) {
|
|
|
|
|
UdiEntity udiEntity = FilterUdiUtils.getUdi(code);
|
|
|
|
|
UdiRelevanceResponse udiInfoBean = udiRelevanceService.selectByNameCode(udiEntity.getUdi());
|
|
|
|
|
if (udiInfoBean != null) {
|
|
|
|
|
if (udiInfoBean.getIsUseDy() == 1 && udiInfoBean.getDiType() != 2) {
|
|
|
|
|
if (udiInfoBean.getBhzxxsbzsl() == 0)
|
|
|
|
|
return udiInfoBean.getZxxsbzbhsydysl();
|
|
|
|
|
else
|
|
|
|
|
return udiInfoBean.getZxxsbzbhsydysl() * udiInfoBean.getBhzxxsbzsl();
|
|
|
|
|
} else {
|
|
|
|
|
return udiInfoBean.getBhzxxsbzsl();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
return 1;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public boolean isMutiPack(WarehouseEntity warehouseEntity) {
|
|
|
|
|
UdiRelevanceResponse udiInfoBean = udiRelevanceService.selectByNameCode(warehouseEntity.getNameCode());
|
|
|
|
|
List<UdiInfoEntity> udiInfoEntities = udiInfoService.findByUuids(udiInfoBean.getUuid());
|
|
|
|
@ -696,8 +938,6 @@ public class InvProductsTrService {
|
|
|
|
|
UdiRelevanceResponse udiInfoBean = udiRelevanceService.selectByNameCode(warehouseEntity.getNameCode());
|
|
|
|
|
List<UdiInfoEntity> udiInfoEntities = udiInfoService.findByUuids(udiInfoBean.getUuid());
|
|
|
|
|
if (udiInfoBean != null) {
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
for (UdiInfoEntity udiInfoEntity : udiInfoEntities) {
|
|
|
|
|
if (udiInfoBean.getIsUseDy() == 1) {
|
|
|
|
|
if (udiInfoEntity.getDiType() == ConstantStatus.DITYPE_SYDY) {
|
|
|
|
@ -827,4 +1067,22 @@ public class InvProductsTrService {
|
|
|
|
|
return results;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//判断是否是寄售产品
|
|
|
|
|
public boolean isAdavnce(WarehouseEntity warehouseEntity) {
|
|
|
|
|
//获取普通出入库结余数量
|
|
|
|
|
FilterInvProductDetailRequest filterInvProductDetailRequest = new FilterInvProductDetailRequest();
|
|
|
|
|
// filterInvProductDetailRequest.setCode(warehouseEntity.getCode());
|
|
|
|
|
filterInvProductDetailRequest.setProductIdFk(warehouseEntity.getRelId());
|
|
|
|
|
filterInvProductDetailRequest.setSupId(warehouseEntity.getSupId());
|
|
|
|
|
List<InvProductDetailJoinResponse> detailJoinResponseList
|
|
|
|
|
= invPreProductDetailService.filterJoinInvProduct(filterInvProductDetailRequest);
|
|
|
|
|
UdiRelevanceEntity udiRelevanceEntity = udiRelevanceService.selectById(warehouseEntity.getRelId());
|
|
|
|
|
if ((detailJoinResponseList != null && detailJoinResponseList.size() > 0)
|
|
|
|
|
|| (udiRelevanceEntity.getIsAdavence() != null && udiRelevanceEntity.getIsAdavence())
|
|
|
|
|
) {
|
|
|
|
|
return true;
|
|
|
|
|
} else return false;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|