From 91c2b2c831f7ab60957161314010330f61e65d6f Mon Sep 17 00:00:00 2001 From: yuyubo <1870149533@qq.com> Date: Wed, 23 Apr 2025 19:57:13 +0800 Subject: [PATCH] 22 --- Pilot_KD_Parino/Pilot_KD_Parino.csproj | 1 + .../Sal_Order/PushSaleOutBillPlugIn.cs | 157 ++++++++++++++++-- 2 files changed, 147 insertions(+), 11 deletions(-) diff --git a/Pilot_KD_Parino/Pilot_KD_Parino.csproj b/Pilot_KD_Parino/Pilot_KD_Parino.csproj index 722ccf9..5c71130 100644 --- a/Pilot_KD_Parino/Pilot_KD_Parino.csproj +++ b/Pilot_KD_Parino/Pilot_KD_Parino.csproj @@ -333,6 +333,7 @@ + diff --git a/Pilot_KD_Parino/Sal_Order/PushSaleOutBillPlugIn.cs b/Pilot_KD_Parino/Sal_Order/PushSaleOutBillPlugIn.cs index 1fb67a4..f88c278 100644 --- a/Pilot_KD_Parino/Sal_Order/PushSaleOutBillPlugIn.cs +++ b/Pilot_KD_Parino/Sal_Order/PushSaleOutBillPlugIn.cs @@ -1,4 +1,6 @@ -using Kingdee.BOS; +using DevExpress.Xpo.DB.Helpers; +using FarPoint.Excel; +using Kingdee.BOS; using Kingdee.BOS.App; using Kingdee.BOS.App.Data; using Kingdee.BOS.Contracts; @@ -54,6 +56,7 @@ namespace Pilot_KD_Parino.Sal_Order } int tempFid = int.Parse(dt.Select(t => t["FSBILLID"]).FirstOrDefault().ToString()); string tablename = dt.Select(t => t["FSTABLENAME"]).FirstOrDefault().ToString(); + //找到采购订单 for (int kk = 0; kk < 6 && tablename.ToUpper() != "T_PUR_POORDERENTRY"; kk++) { ////发货通知单 @@ -89,13 +92,61 @@ namespace Pilot_KD_Parino.Sal_Order } if (tablename.ToUpper() != "T_PUR_POORDERENTRY") { - this.View.ShowMessage("没有上查关联的跨组织的采购订单 " + tablename); - return; + + throw new KDBusinessException("", "没有上查关联的跨组织的采购订单:" + tablename); + } - IOperationResult result = Invoke("PUR_PurchaseOrder", "PUR_ReceiveBill", tempFid.ToString(), "7cd93c259999489c97798063f2f7bd70"); + + int stockId = 0; + IOperationResult result = Invoke("PUR_PurchaseOrder", "PUR_ReceiveBill", tempFid.ToString(), "7cd93c259999489c97798063f2f7bd70", ref stockId); + + var sheet = result.SuccessDataEnity.FirstOrDefault(); + string jsonsheet = JsonHelper.ToJson(sheet); + //Logger.Error("推送采购入库单",jsonsheet,null); + if (sheet != null) + { + + result = Invoke("PUR_ReceiveBill", "STK_InStock", sheet["id"].ToString(), "a1ff32276cd9469dad3bf2494366fa4f", ref stockId); + //sheet = result.SuccessDataEnity.FirstOrDefault(); + //result = Invoke("PUR_ReceiveBill", "STK_InStock", sheet["id"].ToString(), "a1ff32276cd9469dad3bf2494366fa4f"); + } + //找到最开始的销售订单 + for (int kk = 0; kk < 6 && tablename.ToUpper() != "T_SAL_ORDERENTRY"; kk++) + { + ////发货通知单 + tempFid = int.Parse(dt.Select(t => t["FSBILLID"]).FirstOrDefault().ToString()); + string tempTable = dt.Select(t => t["FSTABLENAME"]).FirstOrDefault().ToString(); + getSourceSql = $@"/*dialect*/SELECT FSTABLENAME,FSBILLID FROM dbo.{tempTable}_lk + WHERE FENTRYID IN ( SELECT FENTRYID FROM {tempTable} WHERE FID = {tempFid})"; + dt = DBServiceHelper.ExecuteDynamicObject(this.Context, getSourceSql); + if (dt == null || dt.Count == 0) + { + + this.View.ShowMessage("没有上查关联的跨组织的采购订单"); + return; + } + else + { + tablename = dt.Select(t => t["FSTABLENAME"]).FirstOrDefault().ToString(); + + } + tempFid = int.Parse(dt.Select(t => t["FSBILLID"]).FirstOrDefault().ToString()); + } + if (tablename.ToUpper() != "T_SAL_ORDERENTRY") + { + + throw new KDBusinessException("", "推送销售发货通知单失败,没有上查关联的跨组织的销售订单:" + tablename); + + } + + result = Invoke("SAL_SaleOrder", "SAL_DELIVERYNOTICE", tempFid.ToString(), "193822715afc48aa9fa6d6beca7700ab", ref stockId); + sheet = result.SuccessDataEnity.FirstOrDefault(); + result = Invoke("SAL_DELIVERYNOTICE", "SAL_OUTSTOCK", sheet["id"].ToString(), "ad0779a4685a43a08f08d2e42d7bf3e9", ref stockId); + + this.View.ShowMessage("跨组织下推订单完成"); //this.View.ShowMessage("就是这个按钮"+ id); @@ -129,7 +180,7 @@ namespace Pilot_KD_Parino.Sal_Order } - private IOperationResult Invoke(string source, string target, string tempFid, string sargetBillTypeId) + private IOperationResult Invoke(string source, string target, string tempFid, string sargetBillTypeId, ref int stockId) { try { @@ -153,13 +204,97 @@ namespace Pilot_KD_Parino.Sal_Order ////目标单据数据集合 DynamicObject[] destObjs = convertResult.TargetDataEntities.Select(r => r.DataEntity).ToArray(); - //根据实际情况,处理目标单据数据 - //destObjs[0]["Date"] = Convert.ToDateTime(sDate); - DynamicObjectCollection col_FEntityDetail; + var sdsas = JsonHelper.ToJson(destObjs); Logger.Error("目标单据数据集合", sdsas, new Exception()); + int temStockId = stockId; + if (target == "PUR_ReceiveBill")//收料通知单,强制没有配置仓库的物料进成品仓库 + { + //var sheet = destObjs.FirstOrDefault(); PUR_ReceiveEntry + string pur = ("PUR_ReceiveEntry"); + var stocks3 = destObjs[0]; + + if (temStockId == 0) + { + string sql2 = $@"/*dialect*/ SELECT FUseOrgId,fname, a.FSTOCKID,FForbidStatus,FDocumentStatus FROM T_BD_STOCK a + LEFT JOIN T_BD_STOCK_L b ON a.FSTOCKID=b.FSTOCKID + WHERE fname like '%成品仓%' AND FForbidStatus='A' AND FDocumentStatus='C' AND FUseOrgId={stocks3["StockOrgId_Id"]}"; + var stockList = DBServiceHelper.ExecuteDynamicObject(this.Context, sql2, null, null, CommandType.Text, null); + if (stockList == null || stockList.Count == 0) + { + throw new KDBusinessException("", "所涉及的跨组织单位没有配置成品仓"); + } + + + temStockId = stockList.Select(t => int.Parse(t["FSTOCKID"].ToString())).FirstOrDefault(); + stockId = temStockId; + } + var stocks333 = stocks3[pur]; + var stocks = stocks333 as DynamicObjectCollection; + var stock0 = stocks.ToList(); + + stock0.ForEach(t => + { + t["StockID_Id"] = temStockId; + }); + + + + //if (stock0.Count > 0) + //{ + // var others= stocks.Where(t => int.Parse(t["StockID_Id"].ToString()) != 0).ToList(); + // if (others.Count == 0) + // { + // throw new KDBusinessException("", "上查关联的跨组织的采购订单明细全部没有配置仓库" ); + // } + // var other2 = others.Select(t => t["StockId"]).ToList(); + // var json1 = JsonHelper.ToJson(other2); + // List other3 = JsonHelper.ToObject>(json1); + // var other4 = other3.Where(t => t.Name.FirstOrDefault().Value.Contains("成品仓")).ToList(); + + // if (other4.Count > 0) + // { + // stockId = other4.Select(t => t.Id).FirstOrDefault(); + // } + // else + // { + // stockId = other3.Select(t => t.Id).FirstOrDefault(); + // } + + + // stock0.ForEach(t => + // { + // t["StockID_Id"] = stockId; + // }); + //} + } + + + if (target == "SAL_DELIVERYNOTICE")//采购入库单,强制没有配置仓库的物料进成品仓库 + { + //throw new KDBusinessException("","还没开发好"); + //var sheet = destObjs.FirstOrDefault(); PUR_ReceiveEntry + string pur = ("SAL_DELIVERYNOTICEENTRY"); + var stocks3 = destObjs[0]; + var stocks333 = stocks3[pur]; + var stocks = stocks333 as DynamicObjectCollection; + var stock0 = stocks.ToList(); + stock0.ForEach(t => + { + t["StockID_Id"] = temStockId; + }); + + + + } + + //根据实际情况,处理目标单据数据 + //destObjs[0]["Date"] = Convert.ToDateTime(sDate); + //DynamicObjectCollection col_FEntityDetail; + //var sdsas = JsonHelper.ToJson(destObjs); + //Logger.Error("目标单据数据集合", sdsas, new Exception()); //this.View.ShowMessage("好了好了,就是这个按钮"); - + //return result; ////if (target == "SAL_OUTSTOCK")//销售出库 ////{ @@ -217,7 +352,7 @@ namespace Pilot_KD_Parino.Sal_Order //this.View.ShowErrMessage("调用下推, 导致自动保存失败 原因:" + saveResult.ValidationErrors[0].Message.ToString()); throw new KDBusinessException("", "未知原因导致自动保存失败原因:" + errorInfo); } - + result = saveResult; //this.View.ShowMessage("1"); // 取到需要自动提交、审核的单据内码 object[] pkArray = (from p in destObjs select p[0]).ToArray(); @@ -242,7 +377,7 @@ namespace Pilot_KD_Parino.Sal_Order } catch (Exception ex) { - Logger.Error("同步报关信息时", "同步报关信息时 error:" + ex.Message + ex.StackTrace, ex); + Logger.Error("跨组织下推订单报错", "跨组织下推订单报错 error:" + ex.Message + ex.StackTrace, ex); throw ex; }