You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
115 lines
3.6 KiB
115 lines
3.6 KiB
using System;
|
|
using System.Collections.Generic;
|
|
using System.Text;
|
|
using System.Data;
|
|
using Stone.Entity;
|
|
using Stone.DataService.Biz.BizPublic;
|
|
using Gm_WMS.DataAccess.DataService;
|
|
using Stone.DataService.Biz.Info;
|
|
|
|
namespace Stone.DataService.Biz.Bill
|
|
{
|
|
public class F_BillAsn
|
|
{
|
|
public F_BillAsn()
|
|
{
|
|
|
|
}
|
|
|
|
public DataSet BillNew(Command cmd)
|
|
{
|
|
string AsnNumber = cmd.Pars[0];
|
|
string UserName = cmd.Pars[1];
|
|
|
|
Entity_t_JIS_VDA t_JIS_VDA = new Entity_t_JIS_VDA();
|
|
|
|
DataSet dsData = t_JIS_VDA.GetData(
|
|
$"PackageNo, 0 as IsCheck, AsnNumber, IsShipingVerification,IsPrintASN",
|
|
$"[AsnNumber]='{AsnNumber}'",
|
|
$"[PackageNo] desc");
|
|
|
|
if (dsData.Tables[0].Rows.Count == 0)
|
|
{
|
|
throw new Exception($"ASN编号{AsnNumber}不存在");
|
|
}
|
|
|
|
if (dsData.Tables[0].Select("[IsPrintASN]=True").Length == 0)
|
|
throw new Exception($"{AsnNumber} 未打印");
|
|
|
|
if (dsData.Tables[0].Select("[IsShipingVerification]=False").Length == 0)
|
|
throw new Exception($"{AsnNumber} 已经完成发货校验");
|
|
|
|
|
|
return dsData;
|
|
}
|
|
|
|
public void BillSubmit(Command cmd, DataSet dsData)
|
|
{
|
|
string UserName = cmd.Pars[0];
|
|
|
|
if (dsData.Tables[0].Rows.Count == 0)
|
|
throw new Exception("提交的数据不能为空!");
|
|
|
|
string AsnNumber = dsData.Tables[0].Rows[0]["AsnNumber"].ToString();
|
|
|
|
LocalDBService db = null;
|
|
try
|
|
{
|
|
db = new LocalDBService();
|
|
db.BeginTrans();
|
|
|
|
Entity_t_JIS_VDA t_JIS_VDA = new Entity_t_JIS_VDA(db);
|
|
Entity_t_ShipingVerification t_ShipingVerification = new Entity_t_ShipingVerification(db);
|
|
|
|
DataTable dtVDA = t_JIS_VDA.GetData("", $"[AsnNumber]='{AsnNumber}'", "[PackageNo] asc").Tables[0];
|
|
if (dtVDA.Rows.Count == 0)
|
|
throw new Exception($"{AsnNumber} 在系统中不存在");
|
|
|
|
DataRow[] drs = dtVDA.Select($"[IsPackingVerification]=False");
|
|
if(drs.Length > 0)
|
|
{
|
|
string msg = "";
|
|
foreach(DataRow dr in drs)
|
|
{
|
|
msg += dr["PackageNo"].ToString() + ",";
|
|
}
|
|
if(msg != "")
|
|
{
|
|
throw new Exception($"未做装箱校验:{msg}");
|
|
}
|
|
}
|
|
|
|
if (dtVDA.Select($"[IsShipingVerification]=False").Length == 0)
|
|
throw new Exception($"{AsnNumber} 已经完成发货校验");
|
|
|
|
|
|
foreach (DataRow drData in dsData.Tables[0].Rows)
|
|
{
|
|
t_JIS_VDA.Edit(
|
|
$"[IsShipingVerification]=1",
|
|
$"[PackageNo]='{drData["PackageNo"]}'");
|
|
|
|
DataRow drNew = t_ShipingVerification.Table.NewRow();
|
|
drNew["AsnNumber"] = drData["AsnNumber"].ToString();
|
|
drNew["PackageNo"] = drData["PackageNo"].ToString();
|
|
drNew["UserName"] = UserName;
|
|
t_ShipingVerification.Add(drNew);
|
|
}
|
|
|
|
db.Commit();
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
if (db != null) db.Rollback();
|
|
throw ex;
|
|
}
|
|
finally
|
|
{
|
|
if (db != null) db.EndTrans();
|
|
}
|
|
|
|
|
|
}
|
|
|
|
}
|
|
}
|
|
|