98 lines
3.8 KiB
C#
98 lines
3.8 KiB
C#
|
|
using System;
|
|||
|
|
using System.ComponentModel;
|
|||
|
|
using System.Collections.Generic;
|
|||
|
|
using System.Linq;
|
|||
|
|
using System.Text;
|
|||
|
|
using Kingdee.BOS;
|
|||
|
|
using Kingdee.BOS.Core.Bill.PlugIn;
|
|||
|
|
using Kingdee.BOS.Core.Bill.PlugIn.Args;
|
|||
|
|
using Kingdee.BOS.Core.DynamicForm.PlugIn.Args;
|
|||
|
|
using Kingdee.BOS.Core.Metadata;
|
|||
|
|
using Kingdee.BOS.Core.Metadata.EntityElement;
|
|||
|
|
using Kingdee.BOS.Core.SqlBuilder;
|
|||
|
|
using Kingdee.BOS.Orm.DataEntity;
|
|||
|
|
using Kingdee.BOS.ServiceHelper;
|
|||
|
|
using Kingdee.BOS.Util;
|
|||
|
|
using Kingdee.BOS.Core.DynamicForm;
|
|||
|
|
using Kingdee.BOS.Core.DynamicForm.PlugIn;
|
|||
|
|
using System.Data;
|
|||
|
|
using System.Collections;
|
|||
|
|
using System.Windows.Forms;
|
|||
|
|
namespace aoyuPlugIn
|
|||
|
|
{
|
|||
|
|
[Description("销售订单验证库存数")]
|
|||
|
|
public class jb_xsdd_yzkcs : AbstractBillPlugIn
|
|||
|
|
{
|
|||
|
|
public override void BeforeSave(BeforeSaveEventArgs e)
|
|||
|
|
{
|
|||
|
|
|
|||
|
|
base.BeforeSave(e);
|
|||
|
|
|
|||
|
|
|
|||
|
|
////取表体最大行数
|
|||
|
|
//string FEntity_nm = "T_SAL_ORDERENTRY";
|
|||
|
|
//int tol = this.Model.GetEntryRowCount(FEntity_nm);
|
|||
|
|
//计算评审天数
|
|||
|
|
//销售组 FSaleGroupId,FSALEGROUPID
|
|||
|
|
DynamicObject obxsz = this.View.Model.GetValue("FSaleGroupId") as DynamicObject;
|
|||
|
|
string xsz = obxsz["Name"].ToString();
|
|||
|
|
try
|
|||
|
|
{
|
|||
|
|
//FSaleOrderEntry
|
|||
|
|
string ORM_NM = "SaleOrderEntry";//你的单据体ORM实体名
|
|||
|
|
DynamicObject obj = this.Model.DataObject;
|
|||
|
|
DynamicObjectCollection rows = obj[ORM_NM] as DynamicObjectCollection;
|
|||
|
|
int k = 0;
|
|||
|
|
ComboBox cmb = new ComboBox();DataTable tb = new DataTable();
|
|||
|
|
tb.Columns.Add("wlno");tb.Columns.Add("fqty");
|
|||
|
|
try {
|
|||
|
|
foreach (var r in rows)
|
|||
|
|
{
|
|||
|
|
DynamicObject obwl = this.View.Model.GetValue("FMaterialId", k) as DynamicObject;
|
|||
|
|
string wlno = obwl["Number"].ToString();
|
|||
|
|
|
|||
|
|
if (cmb.Items.Contains(wlno) == false)
|
|||
|
|
{
|
|||
|
|
cmb.Items.Add(wlno);
|
|||
|
|
DataRow nr = tb.NewRow();
|
|||
|
|
nr[0] = wlno;
|
|||
|
|
string dds = this.View.Model.GetValue("FQty", k).ToString();
|
|||
|
|
nr[1] = dds;
|
|||
|
|
tb.Rows.Add(nr);
|
|||
|
|
}
|
|||
|
|
else
|
|||
|
|
{
|
|||
|
|
DataRow[] nr = tb.Select("wlno='" + wlno + "'");
|
|||
|
|
nr[0]["fqty"] = (Convert.ToDouble(nr[0]["fqty"].ToString()) + Convert.ToDouble(this.View.Model.GetValue("FQty",k).ToString())).ToString();
|
|||
|
|
}
|
|||
|
|
k++;
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
catch(Exception ex) { MessageBox.Show(ex.Message); }
|
|||
|
|
k = 0;
|
|||
|
|
foreach (DataRow r in tb.Rows)
|
|||
|
|
{
|
|||
|
|
string wlno = r["wlno"].ToString();
|
|||
|
|
Double fqty = Convert.ToDouble( r["fqty"].ToString());
|
|||
|
|
|
|||
|
|
var sSql = String.Format("EXEC jb_get_kchz " + xsz + "," + wlno);
|
|||
|
|
var dr = DBServiceHelper.ExecuteDynamicObject(this.Context, sSql);
|
|||
|
|
Double cys =Convert.ToDouble(dr[0]["cys"].ToString());
|
|||
|
|
if (fqty > cys)
|
|||
|
|
{
|
|||
|
|
this.View.ShowMessage("物料编码:" + wlno + "的订单数" + fqty.ToString() + "大于库存管理报表中的差异数" + cys.ToString() + ",不能保存");
|
|||
|
|
|
|||
|
|
//e.Cancel = true;
|
|||
|
|
}
|
|||
|
|
k++;
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
catch (Exception ex) { this.View.ShowMessage("验证数据时发生错误为:" + ex.Message);
|
|||
|
|
e.Cancel = true;
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
}
|
|||
|
|
}
|