质检报告推送qms优化,备注字段改为从收货单子表获取
This commit is contained in:
parent
393be18782
commit
d68f368111
|
|
@ -81,16 +81,16 @@ public class QCRptDataPushtoQmsAction implements ICommonAction {
|
|||
boolean needSkip = false; // 标记是否需要跳过当前ArriveVO
|
||||
|
||||
// 检查当前到货单的所有明细,只要有一个明细的vbdef23为Y/y,就跳过整个到货单
|
||||
if (bvos != null && bvos.length > 0) {
|
||||
for (ArriveItemVO itemVO : bvos) {
|
||||
// 获取vbdef23字段值,处理null情况
|
||||
String vbdef23 = (String) itemVO.getAttributeValue("vbdef23");
|
||||
if (vbdef23 != null && "Y".equalsIgnoreCase(vbdef23)) {
|
||||
needSkip = true;
|
||||
break; // 只要有一个明细符合,直接跳出明细循环
|
||||
}
|
||||
}
|
||||
}
|
||||
// if (bvos != null && bvos.length > 0) {
|
||||
// for (ArriveItemVO itemVO : bvos) {
|
||||
// // 获取vbdef32字段值,处理null情况
|
||||
// String vbdef32 = (String) itemVO.getAttributeValue("vbdef32");
|
||||
// if (vbdef32 != null && "Y".equalsIgnoreCase(vbdef32)) {
|
||||
// needSkip = true;
|
||||
// break; // 只要有一个明细符合,直接跳出明细循环
|
||||
// }
|
||||
// }
|
||||
// }
|
||||
|
||||
// 不需要跳过的,加入有效列表
|
||||
if (!needSkip) {
|
||||
|
|
@ -166,22 +166,29 @@ public class QCRptDataPushtoQmsAction implements ICommonAction {
|
|||
itemObj.put("wlxhgg", materialtype + materialspec); // 物料型号规格
|
||||
itemObj.put("sjsl", reportHeaderVO.getNapplynum().toString()); // 送检数量(设计单位),按设计计量单位统计的送检数量
|
||||
itemObj.put("jldw", cunitname); // 计量单位
|
||||
itemObj.put("bz", reportItemVO.getVbdef1()); // 明细备注,用于填写该送检物料的补充说明
|
||||
itemObj.put("bz", getBz(bvo,reportItemVO.getCfirstbid())); // 明细备注,用于填写该送检物料的补充说明
|
||||
itemObj.put("bipzyid", pkReportbill); // 质检报告ID
|
||||
itemObj.put("bipqdid", reportItemVO.getPk_reportbill_b()); // 质检报告明细ID
|
||||
contentArray.add(itemObj);
|
||||
}
|
||||
singleObj.put("Content", contentArray);
|
||||
// pushData(singleObj);
|
||||
// update.add(hvo.getPk_arriveorder());
|
||||
// updateArrveOrder(hvo.getPk_arriveorder());
|
||||
pushData(singleObj);
|
||||
update.add(hvo.getPk_arriveorder());
|
||||
updateArrveOrder(hvo.getPk_arriveorder());
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
private Object getBz(ArriveItemVO[] bvo, String cfirstbid) {
|
||||
for (ArriveItemVO arriveItemVO : bvo) {
|
||||
if(arriveItemVO.getPk_arriveorder_b().equals(cfirstbid)) {
|
||||
return arriveItemVO.getVmemob();
|
||||
}
|
||||
}
|
||||
return null;
|
||||
}
|
||||
private void updateArrveOrder(String pkArriveorder) throws DAOException {
|
||||
BaseDAO dao = new BaseDAO();
|
||||
String sql = "update po_arriveorder_b set vbdef23='Y' where pk_arriveorder='"
|
||||
String sql = "update po_arriveorder_b set vbdef32='Y' where pk_arriveorder='"
|
||||
+ pkArriveorder + "'";
|
||||
dao.executeUpdate(sql);
|
||||
}
|
||||
|
|
@ -215,87 +222,6 @@ public class QCRptDataPushtoQmsAction implements ICommonAction {
|
|||
return cghth;
|
||||
}
|
||||
|
||||
private void buildSyncData1(ReportVO[] useVOs) throws BusinessException {
|
||||
for (ReportVO vo : useVOs) {
|
||||
ReportHeaderVO hvo = vo.getHVO();
|
||||
ReportItemVO[] bvo = vo.getBVO();
|
||||
// 判断物料的业务单元是否是箱变公司,不是则跳过
|
||||
String pkOrg = hvo.getPk_org();
|
||||
String orgCode = MyHelper.transferField(OrgVO.getDefaultTableName(), OrgVO.CODE, OrgVO.PK_ORG, pkOrg);
|
||||
if (checkIfOrg(orgCode, configParams)) {
|
||||
continue;
|
||||
}
|
||||
// 查询供应商信息
|
||||
String pk_supplier_v = hvo.getPk_supplier_v();
|
||||
SupplierVersionVO supplierVersionVO = new SupplierVersionVO();
|
||||
if (pk_supplier_v != null && !pk_supplier_v.isEmpty() && !"~".equals(pk_supplier_v)) {
|
||||
ISupplierBaseInfoQryService baseQryService = NCLocator.getInstance().lookup(ISupplierBaseInfoQryService.class);
|
||||
supplierVersionVO = baseQryService.querySupplierVersionByVID(pk_supplier_v);
|
||||
}
|
||||
// 查询人员信息
|
||||
String pkApplyer = hvo.getPk_applyer();
|
||||
String applyerName = MyHelper.getStrValByCondition(PsndocVO.getDefaultTableName(), PsndocVO.NAME,
|
||||
PsndocVO.PK_PSNDOC + " = '" + pkApplyer + "'");
|
||||
String bz = "", cghth = "";
|
||||
if (bvo != null && bvo.length > 0) {
|
||||
bz = bvo[0].getVbdef1(); // BOM备注
|
||||
cghth = bvo[0].getVbdef2(); // 采购单号
|
||||
}
|
||||
// 组装数据
|
||||
JSONObject singleObj = new JSONObject();
|
||||
long cts = System.currentTimeMillis();
|
||||
singleObj.put("batchid", cts);
|
||||
singleObj.put("csdh", hvo.getVapplybillcode());// 送检单号,采购送检单的唯一标识编号
|
||||
singleObj.put("sjrq", hvo.getDapplydate().toString());// 送检日期,格式建议为 yyyy-MM-dd
|
||||
singleObj.put("wlgysid", supplierVersionVO.getCode());// 供应商编码
|
||||
singleObj.put("wlgysmc", supplierVersionVO.getName());// 供应商名称
|
||||
singleObj.put("sjr", applyerName);// 送检人,负责提交送检单的人员姓名
|
||||
singleObj.put("cghth", cghth);// 采购合同号,关联对应的采购合同
|
||||
singleObj.put("bz", hvo.getVmemo());// 摘要备注,用于填写送检单的补充说明信息
|
||||
|
||||
String pkMaterial = hvo.getPk_material();
|
||||
Map<String, Object> materialMap = MyHelper.getMapValByCondition(MaterialVO.getDefaultTableName(), "code,name,materialspec,materialtype",
|
||||
"pk_material = '" + pkMaterial + "'");
|
||||
String cunitid = hvo.getCunitid();// 主单位
|
||||
String cunitname = MyHelper.getStrValByCondition(MeasdocVO.getDefaultTableName(), MeasdocVO.NAME,
|
||||
MeasdocVO.PK_MEASDOC + " = '" + cunitid + "'");
|
||||
// 处理Content数组
|
||||
JSONArray contentArray = new JSONArray();
|
||||
JSONObject itemObj = new JSONObject();
|
||||
itemObj.put("wlbh", materialMap.getOrDefault("code", "")); // 物料编码
|
||||
itemObj.put("wlmc", materialMap.getOrDefault("name", "")); // 物料名称
|
||||
String materialtype = skipNull(materialMap.get("materialtype"));
|
||||
String materialspec = skipNull(materialMap.get("materialspec"));
|
||||
itemObj.put("wlxhgg", materialtype + materialspec); // 物料型号规格
|
||||
itemObj.put("sjsl", hvo.getNapplynum().toString()); // 送检数量(设计单位),按设计计量单位统计的送检数量
|
||||
itemObj.put("jldw", cunitname); // 计量单位
|
||||
itemObj.put("bz", bz); // 明细备注,用于填写该送检物料的补充说明
|
||||
contentArray.add(itemObj);
|
||||
|
||||
singleObj.put("Content", contentArray);
|
||||
/* {
|
||||
"batchid": "10002",
|
||||
"csdh": "SJ202405001",
|
||||
"sjrq": "2024-05-20",
|
||||
"wlgysid": "GY001",
|
||||
"wlgysmc": "XX 金属材料有限公司",
|
||||
"sjr": "张三",
|
||||
"cghth": "HT202405003",
|
||||
"bz": "紧急送检,需优先检测",
|
||||
"Content": [
|
||||
{
|
||||
"wlbh": "ACC26711",
|
||||
"wlmc": "铜排",
|
||||
"wlxhgg": "15558190831",
|
||||
"jldw": "米",
|
||||
"sjsl": "50",
|
||||
"bz": "无特殊要求"
|
||||
}
|
||||
]
|
||||
}*/
|
||||
pushData(singleObj);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* 推送同步数据
|
||||
|
|
|
|||
|
|
@ -4,6 +4,8 @@ import com.alibaba.fastjson.JSON;
|
|||
import com.alibaba.fastjson.JSONArray;
|
||||
import com.alibaba.fastjson.JSONObject;
|
||||
import com.alibaba.fastjson.serializer.SerializerFeature;
|
||||
import nc.bs.dao.BaseDAO;
|
||||
import nc.bs.dao.DAOException;
|
||||
import nc.bs.framework.common.NCLocator;
|
||||
import nc.bs.logging.Log;
|
||||
import nc.bs.trade.business.HYPubBO;
|
||||
|
|
@ -169,15 +171,30 @@ public class SyncDeleteQcQmsRule implements IRule<ReportVO> {
|
|||
}
|
||||
|
||||
itemObj.put("jldw", cunitname); // 计量单位
|
||||
itemObj.put("bz", reportItemVO.getVbdef1()); // 明细备注
|
||||
itemObj.put("bz", getBz(bvo,reportItemVO.getCfirstbid())); // Ã÷ϸ±¸×¢ ËÍ»õµ¥±¸×¢
|
||||
itemObj.put("bipzyid", pkReportbill); // 质检报告ID
|
||||
itemObj.put("bipqdid", reportItemVO.getPk_reportbill_b()); // 质检报告明细ID
|
||||
contentArray.add(itemObj);
|
||||
}
|
||||
singleObj.put("Content", contentArray);
|
||||
pushData(singleObj);
|
||||
updateArrveOrder(hvo.getPk_arriveorder());
|
||||
}
|
||||
}
|
||||
private void updateArrveOrder(String pkArriveorder) throws DAOException {
|
||||
BaseDAO dao = new BaseDAO();
|
||||
String sql = "update po_arriveorder_b set vbdef32='Y' where pk_arriveorder='"
|
||||
+ pkArriveorder + "'";
|
||||
dao.executeUpdate(sql);
|
||||
}
|
||||
private Object getBz(ArriveItemVO[] bvo, String cfirstbid) {
|
||||
for (ArriveItemVO arriveItemVO : bvo) {
|
||||
if(arriveItemVO.getPk_arriveorder_b().equals(cfirstbid)) {
|
||||
return arriveItemVO.getVmemob();
|
||||
}
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
// 以下方法与原逻辑一致,未做修改
|
||||
private String getCghthVal(ArriveHeaderVO hvo, ArriveItemVO[] bvo) throws BusinessException {
|
||||
|
|
|
|||
|
|
@ -4,6 +4,8 @@ import com.alibaba.fastjson.JSON;
|
|||
import com.alibaba.fastjson.JSONArray;
|
||||
import com.alibaba.fastjson.JSONObject;
|
||||
import com.alibaba.fastjson.serializer.SerializerFeature;
|
||||
import nc.bs.dao.BaseDAO;
|
||||
import nc.bs.dao.DAOException;
|
||||
import nc.bs.framework.common.NCLocator;
|
||||
import nc.bs.logging.Log;
|
||||
import nc.bs.trade.business.HYPubBO;
|
||||
|
|
@ -139,15 +141,30 @@ public class SyncQcQmsRule implements IRule<ReportVO> {
|
|||
itemObj.put("wlxhgg", materialtype + materialspec); // 物料型号规格
|
||||
itemObj.put("sjsl", reportHeaderVO.getNapplynum().toString()); // 送检数量(设计单位),按设计计量单位统计的送检数量
|
||||
itemObj.put("jldw", cunitname); // 计量单位
|
||||
itemObj.put("bz", reportItemVO.getVbdef1()); // 明细备注,用于填写该送检物料的补充说明
|
||||
itemObj.put("bz", getBz(bvo,reportItemVO.getCfirstbid())); // Ã÷ϸ±¸×¢£¬ËÍ»õµ¥±¸×¢
|
||||
itemObj.put("bipzyid", pkReportbill); // 质检报告ID
|
||||
itemObj.put("bipqdid", reportItemVO.getPk_reportbill_b()); // 质检报告明细ID
|
||||
contentArray.add(itemObj);
|
||||
}
|
||||
singleObj.put("Content", contentArray);
|
||||
pushData(singleObj);
|
||||
updateArrveOrder(hvo.getPk_arriveorder());
|
||||
}
|
||||
}
|
||||
private void updateArrveOrder(String pkArriveorder) throws DAOException {
|
||||
BaseDAO dao = new BaseDAO();
|
||||
String sql = "update po_arriveorder_b set vbdef32='Y' where pk_arriveorder='"
|
||||
+ pkArriveorder + "'";
|
||||
dao.executeUpdate(sql);
|
||||
}
|
||||
private Object getBz(ArriveItemVO[] bvo, String cfirstbid) {
|
||||
for (ArriveItemVO arriveItemVO : bvo) {
|
||||
if(arriveItemVO.getPk_arriveorder_b().equals(cfirstbid)) {
|
||||
return arriveItemVO.getVmemob();
|
||||
}
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
private String getCghthVal(ArriveHeaderVO hvo, ArriveItemVO[] bvo) throws BusinessException {
|
||||
String cghth = "";
|
||||
|
|
@ -178,87 +195,6 @@ public class SyncQcQmsRule implements IRule<ReportVO> {
|
|||
return cghth;
|
||||
}
|
||||
|
||||
private void buildSyncData1(ReportVO[] useVOs) throws BusinessException {
|
||||
for (ReportVO vo : useVOs) {
|
||||
ReportHeaderVO hvo = vo.getHVO();
|
||||
ReportItemVO[] bvo = vo.getBVO();
|
||||
// 判断物料的业务单元是否是箱变公司,不是则跳过
|
||||
String pkOrg = hvo.getPk_org();
|
||||
String orgCode = MyHelper.transferField(OrgVO.getDefaultTableName(), OrgVO.CODE, OrgVO.PK_ORG, pkOrg);
|
||||
if (checkIfOrg(orgCode, configParams)) {
|
||||
continue;
|
||||
}
|
||||
// 查询供应商信息
|
||||
String pk_supplier_v = hvo.getPk_supplier_v();
|
||||
SupplierVersionVO supplierVersionVO = new SupplierVersionVO();
|
||||
if (pk_supplier_v != null && !pk_supplier_v.isEmpty() && !"~".equals(pk_supplier_v)) {
|
||||
ISupplierBaseInfoQryService baseQryService = NCLocator.getInstance().lookup(ISupplierBaseInfoQryService.class);
|
||||
supplierVersionVO = baseQryService.querySupplierVersionByVID(pk_supplier_v);
|
||||
}
|
||||
// 查询人员信息
|
||||
String pkApplyer = hvo.getPk_applyer();
|
||||
String applyerName = MyHelper.getStrValByCondition(PsndocVO.getDefaultTableName(), PsndocVO.NAME,
|
||||
PsndocVO.PK_PSNDOC + " = '" + pkApplyer + "'");
|
||||
String bz = "", cghth = "";
|
||||
if (bvo != null && bvo.length > 0) {
|
||||
bz = bvo[0].getVbdef1(); // BOM备注
|
||||
cghth = bvo[0].getVbdef2(); // 采购单号
|
||||
}
|
||||
// 组装数据
|
||||
JSONObject singleObj = new JSONObject();
|
||||
long cts = System.currentTimeMillis();
|
||||
singleObj.put("batchid", cts);
|
||||
singleObj.put("csdh", hvo.getVapplybillcode());// 送检单号,采购送检单的唯一标识编号
|
||||
singleObj.put("sjrq", hvo.getDapplydate().toString());// 送检日期,格式建议为 yyyy-MM-dd
|
||||
singleObj.put("wlgysid", supplierVersionVO.getCode());// 供应商编码
|
||||
singleObj.put("wlgysmc", supplierVersionVO.getName());// 供应商名称
|
||||
singleObj.put("sjr", applyerName);// 送检人,负责提交送检单的人员姓名
|
||||
singleObj.put("cghth", cghth);// 采购合同号,关联对应的采购合同
|
||||
singleObj.put("bz", hvo.getVmemo());// 摘要备注,用于填写送检单的补充说明信息
|
||||
|
||||
String pkMaterial = hvo.getPk_material();
|
||||
Map<String, Object> materialMap = MyHelper.getMapValByCondition(MaterialVO.getDefaultTableName(), "code,name,materialspec,materialtype",
|
||||
"pk_material = '" + pkMaterial + "'");
|
||||
String cunitid = hvo.getCunitid();// 主单位
|
||||
String cunitname = MyHelper.getStrValByCondition(MeasdocVO.getDefaultTableName(), MeasdocVO.NAME,
|
||||
MeasdocVO.PK_MEASDOC + " = '" + cunitid + "'");
|
||||
// 处理Content数组
|
||||
JSONArray contentArray = new JSONArray();
|
||||
JSONObject itemObj = new JSONObject();
|
||||
itemObj.put("wlbh", materialMap.getOrDefault("code", "")); // 物料编码
|
||||
itemObj.put("wlmc", materialMap.getOrDefault("name", "")); // 物料名称
|
||||
String materialtype = skipNull(materialMap.get("materialtype"));
|
||||
String materialspec = skipNull(materialMap.get("materialspec"));
|
||||
itemObj.put("wlxhgg", materialtype + materialspec); // 物料型号规格
|
||||
itemObj.put("sjsl", hvo.getNapplynum().toString()); // 送检数量(设计单位),按设计计量单位统计的送检数量
|
||||
itemObj.put("jldw", cunitname); // 计量单位
|
||||
itemObj.put("bz", bz); // 明细备注,用于填写该送检物料的补充说明
|
||||
contentArray.add(itemObj);
|
||||
|
||||
singleObj.put("Content", contentArray);
|
||||
/* {
|
||||
"batchid": "10002",
|
||||
"csdh": "SJ202405001",
|
||||
"sjrq": "2024-05-20",
|
||||
"wlgysid": "GY001",
|
||||
"wlgysmc": "XX 金属材料有限公司",
|
||||
"sjr": "张三",
|
||||
"cghth": "HT202405003",
|
||||
"bz": "紧急送检,需优先检测",
|
||||
"Content": [
|
||||
{
|
||||
"wlbh": "ACC26711",
|
||||
"wlmc": "铜排",
|
||||
"wlxhgg": "15558190831",
|
||||
"jldw": "米",
|
||||
"sjsl": "50",
|
||||
"bz": "无特殊要求"
|
||||
}
|
||||
]
|
||||
}*/
|
||||
pushData(singleObj);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* 推送同步数据
|
||||
|
|
|
|||
Loading…
Reference in New Issue