大连融科 WMS
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.

364 lines
13 KiB

using System;
using System.Collections.Generic;
using System.Text;
using System.ServiceModel;
using System.Data;
using System.Collections;
using System.Linq;
using SiaSun.LMS.Model;
using SiaSun.LMS.Common;
using System.Reflection;
namespace SiaSun.LMS.Implement
{
[ServiceBehavior(IncludeExceptionDetailInFaults = true, InstanceContextMode = InstanceContextMode.Single, ConcurrencyMode = ConcurrencyMode.Multiple, MaxItemsInObjectGraph = int.MaxValue)]
public partial class S_ManageService : S_BaseService, SiaSun.LMS.Interface.I_ManageService
{
public S_ManageService()
{
}
public bool ManageCreate(string sManageType, string sMethodName, object[] lsObj, out string sResult)
{
sResult = string.Empty;
return false;
}
#region MANAGE_TYPE
public IList<SiaSun.LMS.Model.MANAGE_TYPE_PARAM> ManageTypeParamGetList(int MANAGE_TYPE_ID)
{
return this._P_MANAGE_TYPE_PARAM.GetList(MANAGE_TYPE_ID);
}
#endregion
#region MANAGE
/// <summary>任务-调用
/// 任务-调用
/// </summary>
/// <param name="sManageType">任务类型</param>
/// <param name="sMethod">方法</param>
/// <param name="lsObj">参数</param>
/// <param name="sResult">返回结果</param>
/// <returns></returns>
public bool InvokeManageService(string sManageType, string sMethodName, object[] lsObj, out string sResult)
{
bool bResult = true;
sResult = string.Empty;
string sClassFullName = string.Format("SiaSun.LMS.Implement.Manage.{0}", sManageType);
List<object> oPara = lsObj.ToList<object>();
oPara.Add(sResult);
Type t = this.GetType();
Assembly complierAssembly = t.Assembly;
object complierInstance = complierAssembly.CreateInstance(sClassFullName);
Type type = complierInstance.GetType();
object[] obj = oPara.ToArray();
object oResult = null;
//创建反射的所有公用方法
MethodInfo[] lsMethodInfo = type.GetMethods();
bool bFind = false;
foreach (MethodInfo methodInfo in lsMethodInfo)
{
if (methodInfo.Name.Equals(sMethodName) && oPara.Count.Equals(methodInfo.GetParameters().Length))
{
oResult = methodInfo.Invoke(complierInstance, obj);
bFind = true;
break;
}
}
if (!bFind)
{
bResult = false;
sResult = string.Format("未找到{0}类型的{1}方法", sClassFullName, sMethodName);
}
else
{
bResult = Convert.ToBoolean(oResult);
sResult = obj[oPara.Count - 1].ToString();
}
//bResult = new SiaSun.LMS.Implement.Manage.ManageBase().Invoke(sClassFullName, sMethod, lsObj.ToList<object>(), out sResult);
return bResult;
}
#endregion
#region CONTROL
/// <summary>作业-动作
/// 作业-动作
/// </summary>
/// <param name="WAREHOUSE">库房编码</param>
/// <param name="sResult"></param>
/// <returns></returns>
public void ControlTranslate(string WAREHOUSE)
{
string sResult = string.Empty;
IList<SiaSun.LMS.Model.FLOW_PARA> lsFLOW_PARA = this._S_FlowService.FlowGetParameters("FLOW_MANAGE");
string[] aFLOW_PARA = new string[lsFLOW_PARA.Count];
SiaSun.LMS.Model.MANAGE_ACTION_EXCUTE mt = new SiaSun.LMS.Model.MANAGE_ACTION_EXCUTE();
DataTable dt = this.GetList(string.Format("SELECT * FROM V_FLOW_CONTROL_ACTION ", WAREHOUSE));
foreach (DataRow dr in dt.Rows)
{
int i = 0;
foreach (SiaSun.LMS.Model.FLOW_PARA mFLOW_PARA in lsFLOW_PARA)
{
aFLOW_PARA[i] = dr[mFLOW_PARA.FLOW_PARA_CODE].ToString();
i++;
}
mt.MANAGE_ID = Convert.ToInt32(dr["MANAGE_ID"]);
mt.ACTION_EVENT = dr["FLOW_ACTION_EVENT"].ToString();
mt.ACTION_EVENT = string.Format(mt.ACTION_EVENT, aFLOW_PARA);
bool bResult = true;//= new SiaSun.LMS.Implement.S_FlowService().ManageEventExecute(mt, out sResult);
SiaSun.LMS.Model.IO_CONTROL mIO_CONTROL = this._P_IO_CONTROL.GetModel(Convert.ToInt32(dr["CONTROL_ID"]));
if (!bResult)
{
if (sResult.Contains("牺牲"))
{
this._log.Error(string.Format("处理任务异常: {0}", sResult));
continue;
}
SiaSun.LMS.Model.MANAGE_MAIN mMANAGE_MAIN = this._P_MANAGE_MAIN.GetModel(mt.MANAGE_ID);
mMANAGE_MAIN.MANAGE_STATUS = Enum.MANAGE_STATUS.Error.ToString();
mMANAGE_MAIN.MANAGE_REMARK = sResult + string.Format("【控制任务状态-{0}】", mIO_CONTROL.CONTROL_STATUS.ToString());
this._P_MANAGE_MAIN.Update(mMANAGE_MAIN);
}
if (bResult)
{
if (null != mIO_CONTROL)
{
mIO_CONTROL.PRE_CONTROL_STATUS = Convert.ToString(dr["CONTROL_STATUS"]);
this._P_IO_CONTROL.Update(mIO_CONTROL);
}
}
}
}
#endregion
public bool RecordCreate(int MANAGE_ID, out string sResult)
{
bool bResult = true;
sResult = string.Empty;
SiaSun.LMS.Model.MANAGE_MAIN mMANAGE_MAIN = this._P_MANAGE_MAIN.GetModel(MANAGE_ID);
if (null == mMANAGE_MAIN)
{
bResult = false;
sResult = string.Format("任务号{0}不存在", MANAGE_ID);
return bResult;
}
SiaSun.LMS.Model.RECORD_MAIN mRECORD_MAIN = new Model.RECORD_MAIN();
SiaSun.LMS.Model.RECORD_LIST mRECORD_LIST = null;
SiaSun.LMS.Model.RECORD_DETAIL mRECORD_DETAIL = null;
SiaSun.LMS.Model.PLAN_LIST mPLAN_LIST = null;
SiaSun.LMS.Model.PLAN_MAIN mPLAN_MAIN = this._P_PLAN_MAIN.GetModel(mMANAGE_MAIN.PLAN_ID);
SiaSun.LMS.Model.WH_CELL mSTART_WH_CELL = this._P_WH_CELL.GetModel(mMANAGE_MAIN.START_CELL_ID);
SiaSun.LMS.Model.WH_CELL mEND_WH_CELL = this._P_WH_CELL.GetModel(mMANAGE_MAIN.END_CELL_ID);
try
{
if (mPLAN_MAIN != null)
{
mRECORD_MAIN.PLAN_CODE = mPLAN_MAIN.PLAN_CODE;
mRECORD_MAIN.PLAN_TYPE_CODE = mPLAN_MAIN.PLAN_TYPE_CODE;
}
mRECORD_MAIN.MANAGE_TYPE_CODE = mMANAGE_MAIN.MANAGE_TYPE_CODE;
mRECORD_MAIN.STOCK_BARCODE = mMANAGE_MAIN.STOCK_BARCODE;
if (mSTART_WH_CELL != null)
mRECORD_MAIN.START_POSITION = mSTART_WH_CELL.CELL_CODE;
if (mEND_WH_CELL != null)
mRECORD_MAIN.END_POSITION = mEND_WH_CELL.CELL_CODE;
mRECORD_MAIN.RECORD_OPERATOR = mMANAGE_MAIN.MANAGE_OPERATOR;
mRECORD_MAIN.MANAGE_BEGIN_TIME = mMANAGE_MAIN.MANAGE_BEGIN_TIME;
mRECORD_MAIN.MANAGE_END_TIME = mMANAGE_MAIN.MANAGE_END_TIME;
mRECORD_MAIN.RECORD_REMARK = mMANAGE_MAIN.MANAGE_REMARK;
this._P_RECORD_MAIN.Add(mRECORD_MAIN);
foreach (SiaSun.LMS.Model.MANAGE_LIST mMANAGE_LIST in this._P_MANAGE_LIST.GetListManageID(MANAGE_ID))
{
mRECORD_LIST = new Model.RECORD_LIST();
mRECORD_LIST.RECORD_ID = mRECORD_MAIN.RECORD_ID;
mRECORD_LIST.PLAN_LIST_ID = mMANAGE_LIST.PLAN_LIST_ID;
mRECORD_LIST.RECORD_LIST_QUANTITY = mMANAGE_LIST.MANAGE_LIST_QUANTITY;
mRECORD_LIST.GOODS_ID = mMANAGE_LIST.GOODS_ID;
mRECORD_LIST.RECORD_LIST_REMARK = mMANAGE_LIST.MANAGE_LIST_REMARK;
bResult = this._S_GoodsService.GoodsPropertySetValue(mMANAGE_LIST.GOODS_ID, mRECORD_LIST, mMANAGE_LIST, out sResult);
if (!bResult)
{
return bResult;
}
mRECORD_LIST.BOX_BARCODE = mMANAGE_LIST.BOX_BARCODE;
this._P_RECORD_LIST.Add(mRECORD_LIST);
//是否为空 是否有明细
SiaSun.LMS.Model.PLAN_LIST nPLAN_LIST = new PLAN_LIST();
if (mPLAN_MAIN != null)
{
mPLAN_LIST = this._P_PLAN_LIST.GetModel(mMANAGE_LIST.PLAN_LIST_ID);
if (mPLAN_LIST != null)
{
mPLAN_LIST.PLAN_LIST_FINISHED_QUANTITY += mMANAGE_LIST.MANAGE_LIST_QUANTITY;
this._P_PLAN_LIST.Update(mPLAN_LIST);
}
#region//判断计划是否可以完成
DataTable update_plan = this.GetList(string.Format(@"select * from plan_list where plan_id = {0}", mPLAN_MAIN.PLAN_ID));
int j = 0;
for (int i = 0; i < update_plan.Rows.Count; i++)
{
if (Convert.ToInt32(update_plan.Rows[i]["PLAN_LIST_FINISHED_QUANTITY"]) >= Convert.ToInt32(update_plan.Rows[i]["PLAN_LIST_QUANTITY"]))
{
j++;
}
}
if (j == update_plan.Rows.Count)
{
mPLAN_MAIN.PLAN_STATUS = "Complete";
mPLAN_MAIN.PLAN_END_TIME = SiaSun.LMS.Common.StringUtil.GetDateTime();
this._P_PLAN_MAIN.Update(mPLAN_MAIN);
}
#endregion
if (mPLAN_MAIN.PLAN_TYPE_CODE == "PlanIn")
{
nPLAN_LIST.GOODS_PROPERTY3 = mEND_WH_CELL.CELL_CODE;//货位编码
}
else
{
nPLAN_LIST.GOODS_PROPERTY3 = mSTART_WH_CELL.CELL_CODE;
}
nPLAN_LIST.GOODS_PROPERTY1 = mPLAN_MAIN.PLAN_FROM_DEPT;//货物编码
nPLAN_LIST.GOODS_PROPERTY2 = Convert.ToString(mMANAGE_LIST.MANAGE_LIST_QUANTITY);
nPLAN_LIST.GOODS_PROPERTY3 = mEND_WH_CELL.CELL_CODE;//货位编码
nPLAN_LIST.GOODS_PROPERTY4 = "1";//标志位
nPLAN_LIST.GOODS_PROPERTY5 = mPLAN_MAIN.PLAN_CODE;//计划单号
nPLAN_LIST.GOODS_PROPERTY6 = string.Empty;
this._P_PLAN_LIST.Add(nPLAN_LIST);
}
IList<SiaSun.LMS.Model.MANAGE_DETAIL> lsMANAGE_DETAIL = this._P_MANAGE_DETAIL.GetListManageListID(mMANAGE_LIST.MANAGE_LIST_ID);
foreach (SiaSun.LMS.Model.MANAGE_DETAIL mMANAGE_DETAIL in lsMANAGE_DETAIL)
{
mRECORD_DETAIL = new Model.RECORD_DETAIL();
mRECORD_DETAIL.RECORD_LIST_ID = mRECORD_LIST.RECORD_LIST_ID;
mRECORD_DETAIL.BOX_BARCODE = mMANAGE_DETAIL.BOX_BARCODE;
mRECORD_DETAIL.GOODS_BARCODE = mMANAGE_DETAIL.GOODS_BARCODE;
mRECORD_DETAIL.RECORD_DETAIL_REMARK = mMANAGE_DETAIL.MANAGE_DETAIL_REMARK;
this._P_RECORD_DETAIL.Add(mRECORD_DETAIL);
}
}
this._P_IO_CONTROL.DeleteManageID(MANAGE_ID);
this._P_MANAGE_DETAIL.DeleteManageID(MANAGE_ID);
this._P_MANAGE_LIST.DeleteManageID(MANAGE_ID);
this._P_MANAGE_MAIN.Delete(MANAGE_ID);
}
catch (Exception ex)
{
bResult = false;
sResult = ex.Message;
}
return bResult;
}
public bool ManageInAndroid(MANAGE_MAIN mm, List<MANAGE_LIST> lManageList, out string sResult)
{
return this.Invoke("ManageIn", "ManageCreate", new object[] { mm, lManageList, true, true, true, false }, out sResult); ;
}
public bool ManageOutAndroid(MANAGE_MAIN mm, List<MANAGE_LIST> lManageList, out string sResult)
{
return this.Invoke("ManageOut", "ManageCreate", new object[] { mm, lManageList, true, true, true }, out sResult); ;
}
}
}