From e163a27328c805ffec7c894259430f76f0881d00 Mon Sep 17 00:00:00 2001 From: Rodney Chen <rodney.chen@hotmail.com> Date: 星期四, 03 四月 2025 23:12:23 +0800 Subject: [PATCH] 更新收货单提交按行提交已完成清点的行,上架增加IQC审核的判断 --- Tiger.Business.WMS/ERP/U9C_WMS.cs | 38 ++++++++++++++++++++++---------------- 1 files changed, 22 insertions(+), 16 deletions(-) diff --git a/Tiger.Business.WMS/ERP/U9C_WMS.cs b/Tiger.Business.WMS/ERP/U9C_WMS.cs index 73fa43c..28f4a1d 100644 --- a/Tiger.Business.WMS/ERP/U9C_WMS.cs +++ b/Tiger.Business.WMS/ERP/U9C_WMS.cs @@ -9,6 +9,7 @@ using Tiger.IBusiness; using SqlSugar; using System.Data.Entity.Core.Common.CommandTrees.ExpressionBuilder; +using Tiger.Model.Entitys.MES.U9C; namespace Tiger.Business.WMS { @@ -129,9 +130,10 @@ ID = dtl.LineID.ToString(), ITEM_CODE = dtl.ItemCode, QTY_PACKING = dtl.PackQty.ToDouble(), - QTY = dtl.POQtyTU.ToDouble(), + QTY = dtl.ShipQtyTU.ToDouble(), + PO_QTY = dtl.POQtyTU, SUPP_CODE = dtl.SupplierCode, - SUPP_LOTNO = dtl.SupplierLot, + SUPP_LOTNO = dtl.LotMater, LOTNO = dtl.LotMater, AUTH_ORG = orgs.FirstOrDefault(q => q.ID == dtl.Org.ToString())?.ORG_CODE, CREATE_TIME = dtl.ModifiedOn,//--鏃堕棿涓嶆洿鏂� @@ -145,10 +147,12 @@ foreach (var asn in asns) { var snlist = db.Queryable<mes_MaterialBarCode>().Where(x => x.Segment1 == asn.ORDER_NO || x.Segment2 == asn.ORDER_NO).ToList(); + foreach (var sn in snlist) { var barcode = new Barcode(sn.Code); var dtl = dtls.First(q => q.LINE_NO == barcode.OrderLine); + var asnDtl = list.First(q => q.DocLineNo.ToString() == barcode.OrderLine); BIZ_U9_ASN_SN info = new() { AUTH_ORG = asn.AUTH_ORG, @@ -176,7 +180,7 @@ AUTH_ORG = asn.AUTH_ORG, STATUS = WMS_ITEM.STATUSs.Incoming.GetValue(), QTY = sn.WhQty, - PROD_DATE = barcode.ProdDate ?? DateTime.Now, + PROD_DATE = barcode.ProdDate ?? BarcodeAnalysis.GetDateTime(asnDtl.SupplierLot) ??DateTime.Now, UNIT = barcode.Unit, TRANS_CODE = nameof(BIZ_U9_ASN), TRANS_NO = info.ORDER_NO, @@ -223,7 +227,7 @@ .WhereColumns(t => new { t.ORDER_NO, t.GHOST_ROW }) .ToStorage(); y.AsInsertable.ExecuteCommand(); - y.AsUpdateable.IgnoreColumns(x => x.ID).UpdateColumns(q => new { q.ORDER_NO, q.SUPP_CODE, q.SUPP_NAME, q.DELIVERY_DATE, q.PLANARRIVED_DATE, q.ORDER_DATE, q.CREATE_USER, q.UPDATE_TIME, q.AUTH_ORG, q.UPDATE_USER, }).ExecuteCommand(); + y.AsUpdateable.IgnoreColumns(x => x.ID).UpdateColumns(q => new { q.ORDER_NO, q.SUPP_CODE, q.SUPP_NAME, q.DELIVERY_DATE,q.PLANARRIVED_DATE, q.ORDER_DATE, q.CREATE_USER, q.UPDATE_TIME, q.AUTH_ORG, q.UPDATE_USER, }).ExecuteCommand(); }); } if (dtls.Any()) @@ -234,7 +238,7 @@ .WhereColumns(t => new { t.ORDER_NO, t.ID, t.GHOST_ROW }) .ToStorage(); y.AsInsertable.ExecuteCommand(); - y.AsUpdateable.UpdateColumns(q => new { q.ORDER_NO, q.LINE_NO, q.SUPP_CODE, q.ID, q.ITEM_CODE, q.QTY_PACKING, q.QTY, q.SUPP_LOTNO, q.LOTNO, q.AUTH_ORG, q.CREATE_USER, q.UPDATE_TIME, q.UPDATE_USER, }).ExecuteCommand(); + y.AsUpdateable.UpdateColumns(q => new { q.ORDER_NO, q.LINE_NO, q.SUPP_CODE, q.ID, q.ITEM_CODE, q.QTY_PACKING, q.QTY,q.PO_QTY, q.SUPP_LOTNO, q.LOTNO, q.AUTH_ORG, q.CREATE_USER, q.UPDATE_TIME, q.UPDATE_USER, }).ExecuteCommand(); }); } if (sns.Any()) @@ -328,16 +332,18 @@ { BIZ_U9_RECEIPT_DTL info = new() { - STATUS = BIZ_U9_RETURN.STATUSs.Imported.GetValue(), //鐘舵�� + STATUS = BIZ_U9_RMA.STATUSs.Imported.GetValue(), //鐘舵�� ORDER_NO = item.DocNo, //鍗曟嵁鍙� LINE_NO = item.DocLineNo.ToString(), //鍗曟嵁琛屽彿 ITEM_CODE = item.ItemCode, //鐗╂枡缂栫爜 - QTY = item.RtnFillQtyTU.ToDouble(), // mes鍗曟嵁鏁伴噺 --U9閫�琛ユ暟閲� + QTY = item.EyeballingQtyTU.ToDouble(), // mes鍗曟嵁鏁伴噺 --U9閫�琛ユ暟閲� AUTH_ORG = orgs.FirstOrDefault(q => q.ID == item.Org.ToString())?.ORG_CODE, //鐢熶骇鍗曞厓鎺堟潈鏍囪瘑瀛楃 CREATE_TIME = item.ModifiedOn,//--鏃堕棿涓嶆洿鏂� CREATE_USER = UserCode, - UPDATE_TIME = item.ModifiedOn, - UPDATE_USER = UserCode + UPDATE_TIME = item.ModifiedOn, + UPDATE_USER = UserCode, + ERP_STATUS_CODE = item.Status.ToString(), + ERP_STATUS_NAME = item.StatusName, }; resultDt.Add(info); } @@ -363,7 +369,7 @@ .WhereColumns(t => new { t.ORDER_NO, t.LINE_NO, t.GHOST_ROW }) .ToStorage(); y.AsInsertable.ExecuteCommand(); - y.AsUpdateable.UpdateColumns(q => new { q.STATUS, q.ORDER_NO, q.LINE_NO, q.ITEM_CODE, q.QTY, q.AUTH_ORG, q.CREATE_USER, q.UPDATE_USER, q.UPDATE_TIME }).ExecuteCommand(); + y.AsUpdateable.UpdateColumns(q => new { q.STATUS, q.ORDER_NO, q.LINE_NO, q.ITEM_CODE, q.QTY, q.AUTH_ORG, q.ERP_STATUS_CODE, q.ERP_STATUS_NAME, q.CREATE_USER, q.CREATE_TIME, q.UPDATE_USER, q.UPDATE_TIME }).ExecuteCommand(); }); } Logger.Scheduler.Info($"鏀惰揣鍗曡〃澶翠俊鎭瓨鍏ユ暟鎹簱锛屾�绘暟锛歔{resultDt.Count}]"); @@ -387,13 +393,13 @@ string UserCode = "U9C_In_GetReturn"; var list = db.Queryable<mes_ReturnedDocInfo>().Where(x => x.SplitFlag == 0 && x.ReceivementType == 1 && x.ModifiedOn > input.startTime.ToDateTime() && x.ModifiedOn < input.endTime.ToDateTime()).ToList(); var orgs = Biz.Db.Queryable<SYS_ORGANIZATION>().ToList(); - List<BIZ_U9_RETURN> result = new(); - List<BIZ_U9_RETURN_DTL> resultDt = new(); + List<BIZ_U9_RMA> result = new(); + List<BIZ_U9_RMA_DTL> resultDt = new(); if (list != null && list.Count > 0) { result = list .GroupBy(x => new { x.DocNo }) - .Select(x => new BIZ_U9_RETURN + .Select(x => new BIZ_U9_RMA { STATUS = BIZ_U9_RECEIPT.STATUSs.Init.GetValue(), //鐘舵�� ORDER_NO = x.Key.DocNo, //鍗曞彿 @@ -413,9 +419,9 @@ Logger.Scheduler.Info($"閫�璐у崟琛ㄥご淇℃伅瀛樺叆瀹炰綋涓紝鎬绘暟锛歔{result.Count}]"); foreach (var item in list) { - BIZ_U9_RETURN_DTL info = new() + BIZ_U9_RMA_DTL info = new() { - STATUS = BIZ_U9_RETURN.STATUSs.Imported.GetValue(), //鐘舵�� + STATUS = BIZ_U9_RMA.STATUSs.Imported.GetValue(), //鐘舵�� ORDER_NO = item.DocNo, //鍗曟嵁鍙� LINE_NO = item.DocLineNo.ToString(), //鍗曟嵁琛屽彿 ITEM_CODE = item.ItemCode, //鐗╂枡缂栫爜 @@ -617,7 +623,7 @@ { ORDER_NO = item.DocNo, //鍗曟嵁鍙� LINE_NO = item.DocLineNo.ToString(), //鍗曟嵁琛屽彿 - STATUS = BIZ_U9_RETURN.STATUSs.Imported.GetValue(), //鐘舵�� + STATUS = BIZ_U9_RMA.STATUSs.Imported.GetValue(), //鐘舵�� ITEM_CODE = item.ItemCode, //鐗╂枡缂栫爜 UNIT =item.StoreUOM,// UNIT 鍗曚綅 QTY = item.StoreUOMQty,//QTY 鍗曟嵁鏁伴噺 -- Gitblit v1.9.3