From d2f14f6bb44c6dd19cc0816a033452b6de56184b Mon Sep 17 00:00:00 2001
From: Rodney Chen <rodney.chen@hotmail.com>
Date: 星期日, 06 四月 2025 18:09:45 +0800
Subject: [PATCH] 增加备料任务调用U9接口方法

---
 Tiger.Business.WMS/ERP/U9C_WMS.cs |   24 +++++++++++++++---------
 1 files changed, 15 insertions(+), 9 deletions(-)

diff --git a/Tiger.Business.WMS/ERP/U9C_WMS.cs b/Tiger.Business.WMS/ERP/U9C_WMS.cs
index fe547b9..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())
@@ -332,12 +336,14 @@
                         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}]");

--
Gitblit v1.9.3