687 lines
39 KiB
C#
Raw Normal View History

2025-05-14 12:29:38 +08:00
using Kingdee.BOS;
2025-04-18 13:42:20 +08:00
using Kingdee.BOS.App;
using Kingdee.BOS.Contracts;
using Kingdee.BOS.Core.DynamicForm;
using Kingdee.BOS.Core.DynamicForm.Operation;
2025-04-19 14:44:32 +08:00
using Kingdee.BOS.Core.DynamicForm.PlugIn;
2025-04-18 13:42:20 +08:00
using Kingdee.BOS.Core.DynamicForm.PlugIn.Args;
using Kingdee.BOS.Core.List;
using Kingdee.BOS.Core.Metadata;
using Kingdee.BOS.Core.Metadata.ConvertElement;
using Kingdee.BOS.Core.Metadata.ConvertElement.ServiceArgs;
using Kingdee.BOS.Log;
using Kingdee.BOS.Orm;
using Kingdee.BOS.Orm.DataEntity;
using Kingdee.BOS.ServiceHelper;
2025-04-19 17:25:24 +08:00
using Kingdee.BOS.Util;
2025-04-22 11:34:03 +08:00
using Pilot_KD_Parino.Common;
2025-04-18 13:42:20 +08:00
using System;
using System.ComponentModel;
using System.Data;
using System.Linq;
2025-05-14 12:29:38 +08:00
2025-04-18 13:42:20 +08:00
namespace Pilot_KD_Parino.Sal_Order
{
2025-04-19 17:25:24 +08:00
[Description("下推生成销售出库单及联动生成其他单的插件"), HotUpdate]
2025-04-19 14:44:32 +08:00
public class PushSaleOutBillPlugIn : AbstractDynamicFormPlugIn // AbstractListPlugIn
2025-04-18 13:42:20 +08:00
{
long sScrId = 0;
string sScrBillNo = "";
2025-04-19 17:25:24 +08:00
public override void AfterBarItemClick(AfterBarItemClickEventArgs e)
2025-04-18 13:42:20 +08:00
{
2025-04-19 17:25:24 +08:00
base.AfterBarItemClick(e);
2025-05-08 13:49:43 +08:00
2025-05-15 19:42:19 +08:00
{
2025-05-16 11:17:34 +08:00
//备货组织操作备货组织的发货出库单跨组织下推
if (e.BarItemKey.Equals("tbPushSalOut111", StringComparison.OrdinalIgnoreCase))
{
2025-05-15 19:42:19 +08:00
2025-05-16 11:17:34 +08:00
var FEntity = this.View.Model.DataObject;
var id = FEntity["id"];
string formid = FEntity["FFormId"].ToString();
//var detailList = (FEntity["SAL_DELIVERYNOTICEENTRY"]);
2025-05-15 19:42:19 +08:00
2025-05-16 11:17:34 +08:00
//发货通知单或者发货出库单
string getSourceSql = $@"/*dialect*/SELECT FSTABLENAME,FSBILLID FROM dbo.T_{formid}ENTRY_LK
WHERE FENTRYID IN ( SELECT FENTRYID FROM dbo.T_{formid}ENTRY WHERE FID = {id})";
var dt = DBServiceHelper.ExecuteDynamicObject(this.Context, getSourceSql);
if (dt == null || dt.Count == 0)
{
this.View.ShowMessage("没有上查关联的发货通知单");
}
int tempFid = int.Parse(dt.Select(t => t["FSBILLID"]).FirstOrDefault().ToString());
string tablename = dt.Select(t => t["FSTABLENAME"]).FirstOrDefault().ToString();
int xiaoFid = 0;
//找到采购订单
for (int kk = 0; kk < 6 && tablename.ToUpper() != "T_PUR_POORDERENTRY"; 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("没有上查关联的销售单");
//}
////共享的采购订单
//tempFid = int.Parse(dt.Select(t => t["FSBILLID"]).FirstOrDefault().ToString());
//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)
{
break;
//this.View.ShowMessage("没有上查关联的跨组织的采购订单");
}
else
{
tablename = dt.Select(t => t["FSTABLENAME"]).FirstOrDefault().ToString();
tempFid = int.Parse(dt.Select(t => t["FSBILLID"]).FirstOrDefault().ToString());
}
}
if (tablename.ToUpper() != "T_PUR_POORDERENTRY")
{
getSourceSql = $@"/*dialect*/SELECT FSTABLENAME,FSBILLID,FENTRYID FROM dbo.T_PUR_POORDERENTRY_LK
WHERE FSBILLID= {tempFid}";
dt = DBServiceHelper.ExecuteDynamicObject(this.Context, getSourceSql);
if (dt == null || dt.Count == 0)
{
throw new KDBusinessException("", "没有上查关联的跨组织的采购订单:" + tablename);
}
else
{
xiaoFid = tempFid;
//tablename = dt.Select(t => t["FSTABLENAME"]).FirstOrDefault().ToString();
//tempFid = int.Parse(dt.Select(t => t["FSBILLID"]).FirstOrDefault().ToString());
var FENTRYIDList = dt.Select(t => int.Parse(t["FENTRYID"].ToString())).ToList();
string ids = string.Join(",", FENTRYIDList);
getSourceSql = $@"/*dialect*/ SELECT FID FROM T_PUR_POORDERENTRY WHERE FENTRYID IN({ids})";
dt = DBServiceHelper.ExecuteDynamicObject(this.Context, getSourceSql);
if (dt == null || dt.Count == 0)
{
throw new KDBusinessException("", "没有上查关联的跨组织的采购订单:" + tablename);
}
else
{
tempFid = int.Parse(dt.FirstOrDefault()["FID"].ToString());
}
}
}
2025-05-16 14:16:18 +08:00
//先判断采购订单是否有采购入库单或者收料单
getSourceSql = $@"/*dialect*/SELECT FSTABLENAME,FSBILLID,FENTRYID FROM dbo.T_PUR_RECEIVEENTRY_LK
WHERE FSBILLID= {tempFid}";
dt = DBServiceHelper.ExecuteDynamicObject(this.Context, getSourceSql);
2025-05-16 11:17:34 +08:00
int stockId = 0;
2025-05-16 14:16:18 +08:00
IOperationResult result = null;
DynamicObject sheet = null;
if (dt == null || dt.Count == 0)
2025-05-16 11:17:34 +08:00
{
2025-05-16 14:16:18 +08:00
getSourceSql = $@"/*dialect*/SELECT FSTABLENAME,FSBILLID,FENTRYID FROM dbo.T_STK_INSTOCKENTRY_LK
WHERE FSBILLID= {tempFid}";
dt = DBServiceHelper.ExecuteDynamicObject(this.Context, getSourceSql);
if (dt != null || dt.Count > 0)
{
result = Invoke("PUR_PurchaseOrder", "PUR_ReceiveBill", tempFid.ToString(), "7cd93c259999489c97798063f2f7bd70", ref stockId);
}
2025-05-16 11:17:34 +08:00
}
2025-05-16 14:16:18 +08:00
if (result != null)
{
sheet = result.SuccessDataEnity.FirstOrDefault();
//string jsonsheet = JsonHelper.ToJson(sheet);
//Logger.Error("推送采购入库单",jsonsheet,null);
if (sheet != null)
{
2025-05-16 11:17:34 +08:00
2025-05-16 14:16:18 +08:00
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");
}
}
2025-05-16 11:17:34 +08:00
//找到最开始的销售订单
for (int kk = 0; kk < 6 && tablename.ToUpper() != "T_SAL_ORDERENTRY" && xiaoFid == 0; 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" && xiaoFid == 0)
{
throw new KDBusinessException("", "推送销售发货通知单失败,没有上查关联的跨组织的销售订单:" + tablename);
}
if (xiaoFid > 0)
tempFid = xiaoFid;
//getSourceSql = $@"/*dialect*/ SELECT FSALEORGID FROM T_SAL_ORDER WHERE fid ={tempFid}";
//dt = DBServiceHelper.ExecuteDynamicObject(this.Context, getSourceSql);
//string saleorgid = "";
//if (dt != null && dt.Count > 0)
//{
// saleorgid = dt.FirstOrDefault()["FSALEORGID"].ToString();
//}
//if (saleorgid != "100302" && saleorgid != "100303")
//{
getSourceSql = $@"/*dialect*/SELECT FSTABLENAME,FSBILLID,FENTRYID FROM dbo.T_SAL_DELIVERYNOTICEENTRY_LK
WHERE FSBILLID= {tempFid}";
dt = DBServiceHelper.ExecuteDynamicObject(this.Context, getSourceSql);
if (dt == null || dt.Count == 0)
{
result = Invoke("SAL_SaleOrder", "SAL_DELIVERYNOTICE", tempFid.ToString(), "193822715afc48aa9fa6d6beca7700ab", ref stockId);
sheet = result.SuccessDataEnity.FirstOrDefault();
tempFid = int.Parse(sheet["id"].ToString());
//throw new KDBusinessException("", "没有上查关联的跨组织的采购订单:" + tablename);
}
else
{
var FENTRYIDList = dt.Select(t => int.Parse(t["FENTRYID"].ToString())).ToList();
string ids = string.Join(",", FENTRYIDList);
getSourceSql = $@"/*dialect*/ SELECT FID FROM T_SAL_DELIVERYNOTICEENTRY WHERE FENTRYID IN({ids})";
dt = DBServiceHelper.ExecuteDynamicObject(this.Context, getSourceSql);
if (dt == null || dt.Count == 0)
{
throw new KDBusinessException("", "没有上查关联的跨组织的发货通知单:" + tablename);
}
else
{
tempFid = int.Parse(dt.FirstOrDefault()["FID"].ToString());
}
}
2025-05-16 14:16:18 +08:00
getSourceSql = $@"/*dialect*/SELECT FSTABLENAME,FSBILLID,FENTRYID FROM dbo.T_SAL_OUTSTOCKENTRY_LK
WHERE FSBILLID= {tempFid}";
dt = DBServiceHelper.ExecuteDynamicObject(this.Context, getSourceSql);
if (dt == null || dt.Count == 0)
{
2025-05-16 11:17:34 +08:00
result = Invoke("SAL_DELIVERYNOTICE", "SAL_OUTSTOCK", tempFid.ToString(), "ad0779a4685a43a08f08d2e42d7bf3e9", ref stockId);
2025-05-16 14:16:18 +08:00
}
2025-05-16 11:17:34 +08:00
//}
//result = Invoke("SAL_SaleOrder", "SAL_DELIVERYNOTICE", tempFid.ToString(), "193822715afc48aa9fa6d6beca7700ab", ref stockId);
//sheet = result.SuccessDataEnity.FirstOrDefault();
this.View.ShowMessage("跨组织下推订单完成");
}
}
{
////备货组织操作销售组织的销售出库单跨组织下推
////A的销售出库单-->A的发货通知单-->A的销售订单-->B的销售订单(分两种情况)-->B的销售发货通知单-->B的销售出库单
//if (e.BarItemKey.Equals("tbPushSalOut111", StringComparison.OrdinalIgnoreCase))
//{
// var FEntity = this.View.Model.DataObject;
// var id = FEntity["id"];
// string formid = FEntity["FFormId"].ToString();
// //var detailList = (FEntity["SAL_DELIVERYNOTICEENTRY"]);
// string AxiaoId = "";
// string BxiaoId = "";
// string caiGouId = ""; //采购订单ID
// string ruKuId = "";
// string AfaHuoId = "";
// string BfaHuoId = "";
// //发货通知单或者发货出库单
// string getSourceSql = $@"/*dialect*/SELECT FSTABLENAME,FSBILLID FROM dbo.T_{formid}ENTRY_LK
// WHERE FENTRYID IN ( SELECT FENTRYID FROM dbo.T_{formid}ENTRY WHERE FID = {id})";
// var dt = DBServiceHelper.ExecuteDynamicObject(this.Context, getSourceSql);
// if (dt == null || dt.Count == 0)
// {
// this.View.ShowMessage("没有上查关联的发货通知单");
// }
// int tempFid = int.Parse(dt.Select(t => t["FSBILLID"]).FirstOrDefault().ToString());
// string tablename = dt.Select(t => t["FSTABLENAME"]).FirstOrDefault().ToString();
// int xiaoFid = 0;
// AfaHuoId = tempFid.ToString();
// getSourceSql = $@"/*dialect*/SELECT FSTABLENAME,FSBILLID FROM T_SAL_DELIVERYNOTICEENTRY_LK
// WHERE FENTRYID IN ( SELECT FENTRYID FROM dbo.T_SAL_DELIVERYNOTICEENTRY WHERE FID = {id})";
// dt = DBServiceHelper.ExecuteDynamicObject(this.Context, getSourceSql);
// if (dt == null || dt.Count == 0)
// {
// //throw new KDBusinessException("", "没有找到源头销售订单:" );
// return;
// }
// tempFid = int.Parse(dt.Select(t => t["FSBILLID"]).FirstOrDefault().ToString());
// tablename = dt.Select(t => t["FSTABLENAME"]).FirstOrDefault().ToString();
// AxiaoId = tempFid.ToString();
// //销售订单找到跨组织的销售订单
// getSourceSql = $@"/*dialect*/SELECT FSTABLENAME,FSBILLID,FENTRYID FROM T_SAL_ORDERENTRY_LK
// WHERE FSBILLID = {tempFid} and FSTABLENAME='T_SAL_ORDERENTRY' ";
// dt = DBServiceHelper.ExecuteDynamicObject(this.Context, getSourceSql);
// //throw new KDBusinessException("", "1:" + getSourceSql);
// string fentryid = "";
// if (dt == null || dt.Count == 0)
// {
// //如果不是小公司的订单,是珠海派诺--珠海兴诺的订单,则按 销售订单--采购申请单--采购订单--兴诺的销售订单 逻辑找订单
// //采购申请单
// getSourceSql = $@"/*dialect*/SELECT FSTABLENAME,FSBILLID,FENTRYID FROM T_PUR_ReqEntry_LK
// WHERE FSBILLID = {tempFid} and FSTABLENAME='T_SAL_ORDERENTRY' ";
// dt = DBServiceHelper.ExecuteDynamicObject(this.Context, getSourceSql);
2025-05-15 19:42:19 +08:00
// if (dt == null || dt.Count == 0)
// {
2025-05-16 11:17:34 +08:00
// throw new KDBusinessException("", "没有找到跨组织的采购申请单:" + getSourceSql);
// return;
// }
// else
// {
// //采购申请单
// tempFid = int.Parse(dt.Select(t => t["FSBILLID"]).FirstOrDefault().ToString());
// tablename = dt.Select(t => t["FSTABLENAME"]).FirstOrDefault().ToString();
// fentryid = dt.Select(t => t["FENTRYID"]).FirstOrDefault().ToString();
// getSourceSql = $@"/*dialect*/ SELECT FID FROM T_PUR_ReqEntry WHERE FENTRYID ={fentryid}";
// dt = DBServiceHelper.ExecuteDynamicObject(this.Context, getSourceSql);
// tempFid = int.Parse(dt.FirstOrDefault()["FID"].ToString());
// getSourceSql = $@"/*dialect*/SELECT FSTABLENAME,FSBILLID,FENTRYID FROM t_PUR_POOrderEntry_LK
// WHERE FSBILLID = {tempFid} and FSTABLENAME='T_PUR_ReqEntry' ";
// dt = DBServiceHelper.ExecuteDynamicObject(this.Context, getSourceSql);
// if (dt == null || dt.Count == 0)
// {
// throw new KDBusinessException("", "没有找到跨组织的采购订单:" + getSourceSql);
// return;
// }
// else
// {
// //兴诺的采购订单
// tempFid = int.Parse(dt.Select(t => t["FSBILLID"]).FirstOrDefault().ToString());
// tablename = dt.Select(t => t["FSTABLENAME"]).FirstOrDefault().ToString();
// fentryid = dt.Select(t => t["FENTRYID"]).FirstOrDefault().ToString();
// getSourceSql = $@"/*dialect*/ SELECT FID FROM t_PUR_POOrderEntry WHERE FENTRYID ={fentryid}";
// dt = DBServiceHelper.ExecuteDynamicObject(this.Context, getSourceSql);
// tempFid = int.Parse(dt.FirstOrDefault()["FID"].ToString());
// caiGouId = tempFid.ToString();
// //兴诺的销售订单
// getSourceSql = $@"/*dialect*/SELECT FSTABLENAME,FSBILLID,FENTRYID FROM T_SAL_ORDERENTRY_LK
// WHERE FSBILLID = {tempFid} and FSTABLENAME='t_PUR_POOrderEntry' ";
// dt = DBServiceHelper.ExecuteDynamicObject(this.Context, getSourceSql);
// if (dt == null || dt.Count == 0)
// {
// throw new KDBusinessException("", "没有找到跨组织的销售订单:" + getSourceSql);
// return;
// }
// tempFid = int.Parse(dt.Select(t => t["FSBILLID"]).FirstOrDefault().ToString());
// tablename = dt.Select(t => t["FSTABLENAME"]).FirstOrDefault().ToString();
// fentryid = dt.Select(t => t["FENTRYID"]).FirstOrDefault().ToString();
// getSourceSql = $@"/*dialect*/ SELECT FID FROM T_SAL_ORDERENTRY WHERE FENTRYID ={fentryid}";
// dt = DBServiceHelper.ExecuteDynamicObject(this.Context, getSourceSql);
// tempFid = int.Parse(dt.Select(t => t["FSBILLID"]).FirstOrDefault().ToString());
// tablename = dt.Select(t => t["FSTABLENAME"]).FirstOrDefault().ToString();
// BxiaoId = tempFid.ToString();
// }
2025-05-15 19:42:19 +08:00
// }
2025-05-16 11:17:34 +08:00
// //throw new KDBusinessException("", "没有找到跨组织的销售订单:"+ getSourceSql);
// }
// else
// {
// tempFid = int.Parse(dt.Select(t => t["FSBILLID"]).FirstOrDefault().ToString());
// tablename = dt.Select(t => t["FSTABLENAME"]).FirstOrDefault().ToString();
// BxiaoId = tempFid.ToString();
2025-05-15 19:42:19 +08:00
// //找到采购订单
// for (int kk = 0; kk < 6 && tablename.ToUpper() != "T_PUR_POORDERENTRY"; kk++)
// {
2025-05-16 11:17:34 +08:00
// ////发货通知单
2025-05-15 19:42:19 +08:00
// string tempTable = dt.Select(t => t["FSTABLENAME"]).FirstOrDefault().ToString();
// getSourceSql = $@"/*dialect*/SELECT FSTABLENAME,FSBILLID FROM dbo.{tempTable}_lk
2025-05-16 11:17:34 +08:00
// WHERE FENTRYID IN ( SELECT FENTRYID FROM {tempTable} WHERE FID = {tempFid})";
2025-05-15 19:42:19 +08:00
// //dt = DBServiceHelper.ExecuteDynamicObject(this.Context, getSourceSql);
// //if (dt == null || dt.Count == 0)
// //{
// // this.View.ShowMessage("没有上查关联的销售单");
// //}
// ////共享的采购订单
// //tempFid = int.Parse(dt.Select(t => t["FSBILLID"]).FirstOrDefault().ToString());
// //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)
// {
// break;
// //this.View.ShowMessage("没有上查关联的跨组织的采购订单");
// }
// else
// {
2025-05-16 11:17:34 +08:00
2025-05-15 19:42:19 +08:00
// tablename = dt.Select(t => t["FSTABLENAME"]).FirstOrDefault().ToString();
// tempFid = int.Parse(dt.Select(t => t["FSBILLID"]).FirstOrDefault().ToString());
2025-05-16 11:17:34 +08:00
// if (tempTable == "T_PUR_POORDERENTRY")
// {
// caiGouId = tempFid.ToString();
// }
2025-05-15 19:42:19 +08:00
// }
// }
// if (tablename.ToUpper() != "T_PUR_POORDERENTRY")
// {
// getSourceSql = $@"/*dialect*/SELECT FSTABLENAME,FSBILLID,FENTRYID FROM dbo.T_PUR_POORDERENTRY_LK
2025-05-16 11:17:34 +08:00
// WHERE FSBILLID= {tempFid}";
2025-05-15 19:42:19 +08:00
// dt = DBServiceHelper.ExecuteDynamicObject(this.Context, getSourceSql);
// if (dt == null || dt.Count == 0)
// {
// throw new KDBusinessException("", "没有上查关联的跨组织的采购订单:" + tablename);
// }
// else
// {
// xiaoFid = tempFid;
// //tablename = dt.Select(t => t["FSTABLENAME"]).FirstOrDefault().ToString();
// //tempFid = int.Parse(dt.Select(t => t["FSBILLID"]).FirstOrDefault().ToString());
// var FENTRYIDList = dt.Select(t => int.Parse(t["FENTRYID"].ToString())).ToList();
// string ids = string.Join(",", FENTRYIDList);
// getSourceSql = $@"/*dialect*/ SELECT FID FROM T_PUR_POORDERENTRY WHERE FENTRYID IN({ids})";
// dt = DBServiceHelper.ExecuteDynamicObject(this.Context, getSourceSql);
// if (dt == null || dt.Count == 0)
// {
// throw new KDBusinessException("", "没有上查关联的跨组织的采购订单:" + tablename);
// }
// else
// {
// tempFid = int.Parse(dt.FirstOrDefault()["FID"].ToString());
// }
// }
// }
2025-05-16 11:17:34 +08:00
// }
// int stockId = 0;
// IOperationResult result = Invoke("PUR_PurchaseOrder", "PUR_ReceiveBill", caiGouId, "7cd93c259999489c97798063f2f7bd70", ref stockId);
2025-05-15 19:42:19 +08:00
2025-05-16 11:17:34 +08:00
// var sheet = result.SuccessDataEnity.FirstOrDefault();
// string jsonsheet = JsonHelper.ToJson(sheet);
// //Logger.Error("推送采购入库单",jsonsheet,null);
// if (sheet != null)
// {
2025-04-19 14:44:32 +08:00
2025-05-16 11:17:34 +08:00
// 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");
// }
2025-05-15 19:42:19 +08:00
2025-05-16 11:17:34 +08:00
// // 找到备货组织B的发货通知单
// getSourceSql = $@"/*dialect*/SELECT FSTABLENAME,FSBILLID,FENTRYID FROM dbo.T_SAL_DELIVERYNOTICEENTRY_LK
// WHERE FSBILLID= {BxiaoId}";
// dt = DBServiceHelper.ExecuteDynamicObject(this.Context, getSourceSql);
// if (dt == null || dt.Count == 0)
// {
// result = Invoke("SAL_SaleOrder", "SAL_DELIVERYNOTICE", BxiaoId, "193822715afc48aa9fa6d6beca7700ab", ref stockId);
// sheet = result.SuccessDataEnity.FirstOrDefault();
// tempFid = int.Parse(sheet["id"].ToString());
// BfaHuoId = tempFid.ToString();
// //throw new KDBusinessException("", "没有上查关联的跨组织的采购订单:" + tablename);
// }
// else
// {
2025-05-15 19:42:19 +08:00
2025-05-16 11:17:34 +08:00
// var FENTRYIDList = dt.Select(t => int.Parse(t["FENTRYID"].ToString())).ToList();
// string ids = string.Join(",", FENTRYIDList);
// getSourceSql = $@"/*dialect*/ SELECT FID FROM T_SAL_DELIVERYNOTICEENTRY WHERE FENTRYID IN({ids})";
2025-05-15 19:42:19 +08:00
// dt = DBServiceHelper.ExecuteDynamicObject(this.Context, getSourceSql);
2025-05-16 11:17:34 +08:00
// if (dt == null || dt.Count == 0)
2025-05-15 19:42:19 +08:00
// {
2025-05-16 11:17:34 +08:00
// throw new KDBusinessException("", "没有上查关联的跨组织的发货通知单:" + tablename);
2025-05-15 19:42:19 +08:00
// }
2025-05-16 11:17:34 +08:00
// else
2025-05-15 19:42:19 +08:00
// {
2025-05-16 11:17:34 +08:00
// tempFid = int.Parse(dt.FirstOrDefault()["FID"].ToString());
// BfaHuoId = tempFid.ToString();
2025-05-15 19:42:19 +08:00
// }
// }
2025-05-16 11:17:34 +08:00
// result = Invoke("SAL_DELIVERYNOTICE", "SAL_OUTSTOCK", BfaHuoId, "ad0779a4685a43a08f08d2e42d7bf3e9", ref stockId);
2025-05-15 19:42:19 +08:00
2025-05-16 11:17:34 +08:00
// //result = Invoke("SAL_SaleOrder", "SAL_DELIVERYNOTICE", tempFid.ToString(), "193822715afc48aa9fa6d6beca7700ab", ref stockId);
// //sheet = result.SuccessDataEnity.FirstOrDefault();
2025-05-15 19:42:19 +08:00
2025-05-08 13:49:43 +08:00
2025-05-16 11:17:34 +08:00
// this.View.ShowMessage("跨组织下推订单完成");
2025-05-08 13:49:43 +08:00
2025-05-15 19:42:19 +08:00
2025-05-16 11:17:34 +08:00
//}
2025-04-19 17:25:24 +08:00
}
2025-04-18 13:42:20 +08:00
}
2025-04-22 19:17:14 +08:00
2025-04-23 19:57:13 +08:00
private IOperationResult Invoke(string source, string target, string tempFid, string sargetBillTypeId, ref int stockId)
2025-04-18 13:42:20 +08:00
{
try
{
IOperationResult result = new OperationResult();
//获取单据转换规则
ConvertRuleElement ruleElement = ServiceHelper.GetService<IConvertService>().GetConvertRules(this.Context, source, target).FirstOrDefault();
//如下代码 直接通过查询数据库获取单据转换源单数据
ListSelectedRowCollection rows = new ListSelectedRowCollection();
int i = 0;
2025-04-22 19:17:14 +08:00
ListSelectedRow row = new ListSelectedRow(tempFid, string.Empty, i++, source);
rows.Add(row);
PushArgs pushArgs = new PushArgs(ruleElement, rows.ToArray());
pushArgs.TargetBillTypeId = sargetBillTypeId;//单据类型
//转换生成目标单
ConvertOperationResult convertResult = ServiceHelper.GetService<IConvertService>().Push(this.Context, pushArgs);
////合并转换操作结果
//result.MergeResult(convertResult);
////目标单据数据集合
DynamicObject[] destObjs = convertResult.TargetDataEntities.Select(r => r.DataEntity).ToArray();
2025-04-23 19:57:13 +08:00
2025-04-22 19:17:14 +08:00
var sdsas = JsonHelper.ToJson(destObjs);
Logger.Error("目标单据数据集合", sdsas, new Exception());
2025-04-23 19:57:13 +08:00
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();
2025-05-08 13:49:43 +08:00
2025-04-23 19:57:13 +08:00
stock0.ForEach(t =>
{
t["StockID_Id"] = temStockId;
});
2025-05-08 13:49:43 +08:00
2025-04-23 19:57:13 +08:00
//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<PUR_ReceiveEntryStockId> other3 = JsonHelper.ToObject<List<PUR_ReceiveEntryStockId>>(json1);
// var other4 = other3.Where(t => t.Name.FirstOrDefault().Value.Contains("成品仓")).ToList();
2025-05-08 13:49:43 +08:00
2025-04-23 19:57:13 +08:00
// if (other4.Count > 0)
// {
// stockId = other4.Select(t => t.Id).FirstOrDefault();
// }
// else
// {
// stockId = other3.Select(t => t.Id).FirstOrDefault();
// }
2025-05-08 13:49:43 +08:00
2025-04-23 19:57:13 +08:00
// stock0.ForEach(t =>
// {
// t["StockID_Id"] = stockId;
// });
//}
}
if (target == "SAL_DELIVERYNOTICE")//采购入库单,强制没有配置仓库的物料进成品仓库
{
//throw new KDBusinessException("","还没开发好");
//var sheet = destObjs.FirstOrDefault(); PUR_ReceiveEntry
string pur = ("SAL_DELIVERYNOTICEENTRY");
2025-05-08 13:49:43 +08:00
var stocks3 = destObjs[0];
2025-04-23 19:57:13 +08:00
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());
2025-04-22 19:17:14 +08:00
//this.View.ShowMessage("好了好了,就是这个按钮");
2025-04-23 19:57:13 +08:00
2025-04-22 19:17:14 +08:00
//return result;
////if (target == "SAL_OUTSTOCK")//销售出库
////{
//col_FEntityDetail = destObjs[0]["SAL_OUTSTOCKENTRY"] as DynamicObjectCollection;
////}
////else
////{//销售退货
//// col_FEntityDetail = destObjs[0]["SAL_RETURNSTOCKENTRY"] as DynamicObjectCollection;
////}
//#region
//long sStockOrgID = 0;
//sStockOrgID = Convert.ToInt64(destObjs[0]["StockOrgId_Id"]);
//foreach (var item in col_FEntityDetail)
//{
// //item["KeeperID_Id"] = item["OwnerID_Id"];//保管者
// string sStockSql = "select FOrgStockId from v_BusinessOrgId where FORGID= " + sStockOrgID + " ";
// sStockSql = String.Format(@"/*dialect*/" + sStockSql);
// var dt = DBServiceHelper.ExecuteDynamicObject(this.Context, sStockSql);
// //if (dt.Count > 0 && Convert.ToInt64(dt[0]["FOrgStockId"]) != 0)
// if (dt.Count > 0)
// {
// //var targetBillMeta = ServiceHelper.GetService<IMetaDataService>().Load(this.Context, target) as FormMetadata;
// //BusinessInfo info = targetBillMeta.BusinessInfo;
// //BaseDataField stockFld = info.GetField("FStockId") as BaseDataField;
// //long stockId = Convert.ToInt64(dt[0]["FOrgStockId"]);
// //IViewService viewService = ServiceHelper.GetService<IViewService>();
// //DynamicObject[] stockObjs = viewService.LoadFromCache(this.Context, new object[] { stockId }, stockFld.RefFormDynamicObjectType);
// //stockFld.RefIDDynamicProperty.SetValue(item, stockId);
// //stockFld.DynamicProperty.SetValue(item, stockObjs[0]);
// item["StockID_Id"] = Convert.ToInt64(dt[0]["FOrgStockId"]);
// }
//}
//#endregion
////目标单元数据
FormMetadata destFormMetadata = ServiceHelper.GetService<IMetaDataService>().Load(this.Context, target) as FormMetadata;
////保存目标单据
IOperationResult saveResult = ServiceHelper.GetService<ISaveService>().Save(this.Context, destFormMetadata.BusinessInfo, destObjs, OperateOption.Create());
////合并保存操作结果
//result.MergeResult(saveResult);
//根据操作结果构造返回结果
if ((saveResult.ValidationErrors != null && saveResult.ValidationErrors.Count > 0))
//|| (result.OperateResult != null && result.OperateResult.Count > 0))
2025-04-18 13:42:20 +08:00
{
2025-04-22 19:17:14 +08:00
var errorInfo = string.Join(";", saveResult.ValidationErrors.Select(x => x.Message));
//this.View.ShowErrMessage("调用下推, 导致自动保存失败 原因:" + errorInfo);
//result.IsSuccess = false;
//this.View.ShowErrMessage("调用下推, 导致自动保存失败 原因:" + saveResult.ValidationErrors[0].Message.ToString());
throw new KDBusinessException("", "未知原因导致自动保存失败原因:" + errorInfo);
}
2025-04-23 19:57:13 +08:00
result = saveResult;
2025-04-22 19:17:14 +08:00
//this.View.ShowMessage("1");
// 取到需要自动提交、审核的单据内码
object[] pkArray = (from p in destObjs select p[0]).ToArray();
//设置提交参数
IOperationResult submitResult = ServiceHelper.GetService<ISubmitService>().Submit(this.Context, destFormMetadata.BusinessInfo, pkArray, "Submit", OperateOption.Create());
// 判断提交结果,如果失败,则内部会抛出错误,回滚代码
if (submitResult.IsSuccess == false)
{
throw new KDBusinessException("", "未知原因导致自动提交失败!");
2025-04-18 13:42:20 +08:00
}
2025-04-22 19:17:14 +08:00
//设置审核参数
IOperationResult auditResult = ServiceHelper.GetService<IAuditService>().Audit(this.Context, destFormMetadata.BusinessInfo, pkArray, OperateOption.Create());
// 判断提交结果,如果失败,则内部会抛出错误,回滚代码
if (auditResult.IsSuccess == false)
{
throw new KDBusinessException("", "未知原因导致自动审核失败!");
}
//显示下推后的单据
//ShowPushResult("k0f9e182dbc5247fcabc9479ddb300fa3", convertResult, destObjs);
return result;
}
catch (Exception ex)
{
2025-04-23 19:57:13 +08:00
Logger.Error("跨组织下推订单报错", "跨组织下推订单报错 error:" + ex.Message + ex.StackTrace, ex);
2025-04-22 19:17:14 +08:00
throw ex;
}
}
2025-05-08 13:49:43 +08:00
2025-04-18 13:42:20 +08:00
}
}