using HH.WCS.JuShi.api;
using HH.WCS.JuShi.core;
using HH.WCS.JuShi.dispatch;
using HH.WCS.JuShi.LISTA.process;
using HH.WCS.JuShi.util;
using HH.WCS.JuShi.wms;
using HH.WCS.JuShi;
using Newtonsoft.Json;
using NLog.Fluent;
using SqlSugar;
using Swashbuckle.Swagger;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Security.Cryptography;
using static HH.WCS.JuShi.LISTA.process.HttpModel;
using static System.Runtime.CompilerServices.RuntimeHelpers;
using HH.WCS.JuShi.device;
using Org.BouncyCastle.Utilities;
using Opc.Ua;
using System.Collections;
using System.Xml.Linq;
using System.Threading;
using static HH.WCS.JuShi.dispatch.NDC;
using static HH.WCS.JuShi.util.Settings;
namespace HH.WCS.JuShi.process
{
internal class TaskProcess
{
#region 任务相关
//--------------------------------------------------任务相关--------------------------------------------------
///
/// 取货卸货完成,缓存位状态更新
///
///
///
internal static void CacheBitUpdate(WCSTask mst, bool load)
{
//var trayCarryCount = mst.N_CNTR_COUNT > 0 ? mst.N_CNTR_COUNT : 1;
if (load)
{
Console.WriteLine($"任务{mst.S_CODE} 货位{mst.S_START_LOC}取货完成,起点解绑容器{mst.S_CNTR_CODE}");
LogHelper.Info($"任务{mst.S_CODE} 货位{mst.S_START_LOC}取货完成,起点解绑容器{mst.S_CNTR_CODE}");
LocationHelper.UnBindingLoc(mst.S_START_LOC, mst.S_CNTR_CODE.Split(',').ToList());
}
else
{
Console.WriteLine($"任务{mst.S_CODE} 货位{mst.S_END_LOC}卸货完成,终点绑定容器{mst.S_CNTR_CODE}");
LogHelper.Info($"任务{mst.S_CODE} 货位{mst.S_END_LOC}卸货完成,终点绑定容器{mst.S_CNTR_CODE}");
LocationHelper.BindingLoc(mst.S_END_LOC, mst.S_CNTR_CODE.Split(',').ToList());
}
}
///
/// 任务取消,缓存位状态更新
///
///
internal static void CacheBitCancelUpdate(WCSTask mst)
{
//任务取消,取货完成前的,起点的loadingCount和终点unLoadingCount都清除,取货完成的只处理终点
if (WCSHelper.CheckActionRecordExist(mst.S_CODE, 4))
{
//根据客户现场要求,如果取货完成任务失败人工拉到终点,我们就当卸货完成处理;如果是人工拉走到其它区域,我们就解锁终点,删除托盘。
//终点绑定
CacheBitUpdate(mst, false);
LocationHelper.UnLockLoc(mst.S_END_LOC);
}
else
{
//起点终点解锁
LocationHelper.UnLockLoc(mst.S_START_LOC);
LocationHelper.UnLockLoc(mst.S_END_LOC);
}
}
///
/// 任务拦截
///
///
///
internal static bool Intercept(WCSTask mst)
{
var result = false;
// if (mst.S_TYPE == "自动转运") {
//判断人工卸货区开关
// result = true;
// }
return result;
}
///
/// 任务状态更新处理
///
///
///
internal static void OperateStatus(WCSTask mst, int state)
{
if (state == 4)//取货完成
{
CacheBitUpdate(mst, true);
//拆托机安全交互
ctjSafe(mst);
}
if (state == 6)//卸货完成
{
CacheBitUpdate(mst, false);
//rgv安全交互
rgvSafe(mst);
//拆托机安全交互
ctjSafe(mst);
}
if (state == 7)
{
CacheBitCancelUpdate(mst);
}
}
//rgv安全交互
private static void rgvSafe(WCSTask mst)
{
//rgv安全交互 根据终点货位找到是哪个rgv
var reservoir = Settings.ReservoirAreas.Where(a => a.areaName == "RGV库区").FirstOrDefault();
if (mst.S_END_AREA.Equals(reservoir.areaCode))
{
var safeInteractions = Settings.SafeInteractions.Where(a => a.location == mst.S_END_LOC).FirstOrDefault();
var safelists = JsonConvert.DeserializeObject>(DeviceProcess.rgvSafeInteraction);
if (safelists.Any())
{
var safelist = safelists.Where(s => s.ip == safeInteractions.ip).First();
LogHelper.Info($"RGV安全交互参数{safelist}");
//不等于 2卸货完成确认信号 就接着发
if (safelist.data != "2")
{
string datastr = "3F00102030400D0A";
// 返回信号
switch (safeInteractions.pointCode)
{
case "RGV1":
datastr = datastr.Replace("10", "11");
break;
case "RGV2":
datastr = datastr.Replace("20", "21");
break;
case "RGV3":
datastr = datastr.Replace("30", "31");
break;
case "RGV4":
datastr = datastr.Replace("40", "41");
break;
}
LogHelper.Info($"RGV安全交互发送信号{safelist.ip},{datastr}");
PlcHelper.SendHex(safelist.ip, datastr);
//休眠3秒再调
Thread.Sleep(3000);
rgvSafe(mst);
}
else
{
LogHelper.Info($"RGV安全交互发送信号{safelist.ip},3F00102030400D0A");
//无状态信号
PlcHelper.SendHex(safelist.ip, "3F00102030400D0A");
}
}
}
}
//拆托机安全交互
private static void ctjSafe(WCSTask mst)
{
PlcDeviceTable plcDeviceTable = null;
//找到线体 根据线体找内存里的状态
var rkreservoirs = Settings.ConveyorLinesInfos.Where(s => s.location == mst.S_END_LOC).FirstOrDefault();
var ckreservoirs = Settings.ConveyorLinesInfos.Where(s => s.location == mst.S_START_LOC).FirstOrDefault();
if (rkreservoirs != null)
{
plcDeviceTable = S7Helper.plcDeviceTables.Find(a => a.DeviceNo == rkreservoirs.code);
}
else if (ckreservoirs != null)
{
plcDeviceTable = S7Helper.plcDeviceTables.Find(a => a.DeviceNo == ckreservoirs.code);
}
LogHelper.Info($"拆托机安全交互写入参数{plcDeviceTable}");
if (plcDeviceTable != null)
{
//s7写入
double addr = 0; //偏移量
string deviceNo = null;//拆托机号
if (plcDeviceTable.DeviceNo == 1003)
{
addr = 90.1;
deviceNo = "1";
}
else if (plcDeviceTable.DeviceNo == 1006)
{
addr = 180.1;
deviceNo = "2";
}
else if (plcDeviceTable.DeviceNo == 1001)
{
addr = 30.0;
deviceNo = "1";
}
else if (plcDeviceTable.DeviceNo == 1004)
{
addr = 120.0;
deviceNo = "2";
}
LogHelper.Info($"拆托机安全交互写入{deviceNo},{addr}");
S7Helper.WriteDouble(deviceNo, 9, addr, 1);
}
}
private static object locLocker = new object();
///
/// 堆叠库区出入库任务申请
///
///
///
///
///
///
///
///
///
internal static bool ApplyTN_Task(Location ls, ref List cntrs, string area, string itemCode, string itemBatch, string taskType, bool insStock = true)
{
var result = false;
lock (locLocker)
{
try
{
if (insStock)
{
Console.WriteLine($"MoboxHelperCreateTask: {area}-{itemCode}-{itemBatch}-{taskType}");
var endTN_Location = GetLocation4In(area, itemCode, itemBatch, 3);
if (endTN_Location != null)
{
var endLayer = endTN_Location.N_CURRENT_NUM == 0 ? 1 : 2;
var taskNo = DateTime.Now.Ticks.ToString();
result = TaskProcess.CreateTransport(ls.S_CODE, endTN_Location.S_CODE, taskType, cntrs, 1, endLayer, 3, 70);
}
else
{
Console.WriteLine($"MoboxHelperCreateTask: 未找到终点货位");
}
}
else
{
var startTN_Location = GetLocation4Out(area, itemCode, itemBatch, 3);
if (startTN_Location != null)
{
var startLayer = startTN_Location.N_CURRENT_NUM <= 3 ? 1 : 2;
var taskNo = DateTime.Now.Ticks.ToString();
var carryCount = startTN_Location.N_CURRENT_NUM > 3 ? startTN_Location.N_CURRENT_NUM - 3 : startTN_Location.N_CURRENT_NUM;
//出库要从起点获取托盘
var cntrList = LocationHelper.GetLocCntr(startTN_Location.S_CODE);
if (cntrList.Count == startTN_Location.N_CURRENT_NUM)
{
cntrs = cntrList.OrderByDescending(a => a.T_CREATE).Take(carryCount).Select(a => a.S_CNTR_CODE.Trim()).ToList();
result = TaskProcess.CreateTransport(startTN_Location.S_CODE, ls.S_CODE, taskType, cntrs, startLayer, 1, carryCount, 65);
}
else
{
Console.WriteLine($"起点托盘数量和货位容器表不符合,请检查【货位表】和【货位容器表】");
}
}
}
}
catch (Exception ex)
{
Console.WriteLine("MoboxHelperCreateTask:" + ex.Message);
LogHelper.Error("MoboxHelperCreateTask:" + ex.Message, ex);
}
}
return result;
}
private static Location GetLocation4Out(string area, string itemCode, string itemBatch, int v)
{
throw new NotImplementedException();
}
private static Location GetLocation4In(string area, string itemCode, string itemBatch, int v)
{
throw new NotImplementedException();
}
///
/// 普通货架区的出入库申请
///
///
///
///
///
///
///
///
internal static bool ApplyNormalTN_Task(Location ls, ref List cntrs, string area, string taskType, string itemCode, bool insStock = true)
{
var result = false;
lock (locLocker)
{
try
{
if (insStock)
{
Console.WriteLine($"MoboxHelperCreateTask: {area}-{taskType}");
var endTN_Location = new Location();
if (endTN_Location != null)
{
var taskNo = DateTime.Now.Ticks.ToString();
result = TaskProcess.CreateTransport(ls.S_CODE, endTN_Location.S_CODE, taskType, cntrs, 70);
}
else
{
Console.WriteLine($"MoboxHelperCreateTask: 未找到终点货位");
}
}
else
{
var startTN_Location = new Location();
if (startTN_Location != null)
{
//出库要从起点获取托盘
var cntrList = LocationHelper.GetLocCntr(startTN_Location.S_CODE);
if (cntrList.Count == startTN_Location.N_CURRENT_NUM)
{
result = TaskProcess.CreateTransport(startTN_Location.S_CODE, ls.S_CODE, taskType, new List { cntrList[0].S_CNTR_CODE }, 65);
}
else
{
Console.WriteLine($"起点托盘数量和货位容器表不符合,请检查【货位表】和【货位容器表】");
}
}
}
}
catch (Exception ex)
{
Console.WriteLine("MoboxHelperCreateTask:" + ex.Message);
LogHelper.Error("MoboxHelperCreateTask:" + ex.Message, ex);
}
}
return result;
}
///
/// 推送任务
///
///
internal static bool SendTask(WCSTask mst)
{
var result = false;
var start = "0"; var end = "0";
var taskType = mst.S_TYPE.Trim();
// if (mst.N_B_STATE == 0) {
if (mst.N_SCHEDULE_TYPE == 1)
{
start = LocationHelper.GetAgvSite(mst.S_START_LOC);
end = LocationHelper.GetAgvSite(mst.S_END_LOC);
Console.WriteLine($"SendTask {mst.S_CODE}");
Console.WriteLine("start=" + start);
Console.WriteLine("end= " + end);
var dic = new Dictionary();
dic.Add("Pri", mst.N_PRIORITY.ToString());
dic.Add("From", start.ToString());
dic.Add("To", end.ToString());
dic.Add("No", mst.S_CODE.Trim());// dic.Add("Ext1", "1"); dic.Add("Ext2", "CALLADDAGV"); dic.Add("N_CNTR_COUNT", "");
var res = NDC.AddNewOrder(5, dic);
if (res != null && (res.Res.ErrCode == 0 || res.Res.ErrCode == 50009))
{
//推送成功,修改任务优先级
mst.N_B_STATE = 1;
WCSHelper.UpdateStatus(mst);
result = true;
}
}
return result;
}
///
/// 国自推送任务
///
///
internal static bool SendGZTask(WCSTask mst)
{
var result = false;
var taskState = mst.N_B_STATE;
if (taskState == 0)
{
Console.WriteLine($"任务mst {JsonConvert.SerializeObject(mst)}");
LogHelper.Info($"任务mst {JsonConvert.SerializeObject(mst)}", "任务");
var startLoc = LocationHelper.GetLoc(mst.S_START_LOC);
var endLoc = LocationHelper.GetLoc(mst.S_END_LOC);
if (startLoc != null && endLoc != null)
{
string src = $"\"src\":\"{startLoc.S_AGV_SITE}\",";
string dst = $"\"dst\":\"{endLoc.S_AGV_SITE}\"";
string parmeS = "{";
string parmeD = "}";
string parme = parmeS + src + dst + parmeD;
int res = 0;
LogHelper.Info($"推送任务参数{parme}", "任务");
res = GZRobot.CreateOrder(mst.S_CODE, mst.N_PRIORITY, parme);
#region
//if (mst.S_TYPE == "呼叫空托" || mst.S_TYPE == "按钮盒调用空托" || mst.S_TYPE == "拆托")
//{
// PlcDeviceTable plcDeviceTable = null;
// //找到线体 根据线体找内存里的状态
// var reservoirs1 = Settings.ConveyorLinesInfos.Where(s => s.location == startLoc.S_CODE).FirstOrDefault();
// plcDeviceTable = S7Helper.plcDeviceTables.Find(a => a.DeviceNo == reservoirs1.code);
// if (plcDeviceTable != null)
// {
// if (mst.S_TYPE == "呼叫空托" || mst.S_TYPE == "按钮盒调用空托")
// {
// LogHelper.Info($"呼叫空托状态参数{JsonConvert.SerializeObject(plcDeviceTable)}", "任务");
// //0-脱机状态,1-待机状态,2-运行中 待机且有托盘且请求取框才走
// if (plcDeviceTable.workMode == 1 && plcDeviceTable.lightAction == 1 && plcDeviceTable.requestTake)
// {
// LogHelper.Info($"推送任务参数{parme}", "任务");
// res = GZRobot.CreateOrder(mst.S_CODE, mst.N_PRIORITY, parme);
// }
// }
// else if (mst.S_TYPE == "拆托")
// {
// LogHelper.Info($"拆托状态参数{JsonConvert.SerializeObject(plcDeviceTable)}", "任务");
// //0-脱机状态,1-待机状态,2-运行中 待机且无托盘且允许放框才走
// if (plcDeviceTable.workMode == 1 && plcDeviceTable.lightAction == 0 && plcDeviceTable.requestPut)
// {
// LogHelper.Info($"推送任务参数{parme}", "任务");
// res = GZRobot.CreateOrder(mst.S_CODE, mst.N_PRIORITY, parme);
// }
// }
// }
//}
//else
//{
// LogHelper.Info($"推送任务参数{parme}", "任务");
// res = GZRobot.CreateOrder(mst.S_CODE, mst.N_PRIORITY, parme);
//}
#endregion
if (res > 0)
{
//更新任务状态
mst.N_B_STATE = 1;
mst.S_EQ_TASK_CODE = res.ToString();
WCSHelper.UpdateStatus(mst);
WCSHelper.UpdateEQNo(mst);
////推送成功,修改任务状态
//TaskHelper.UpdateStatus(mst, "已推送");
////推送成功,修改国自ID
//TaskHelper.UpdateGzId(mst, res);
LogHelper.Info($"任务mst {mst.S_CODE}推送成功", "任务");
result = true;
}
}
}
else { result = true; }
return result;
}
///
/// 创建搬运任务
///
///
///
///
///
///
///
///
///
///
public static bool CreateTransport(string start, string end, string taskType, string cntrs, int startLayer, int endLayer, int trayCarryCount = 1, int priority = 1)
{
var result = false;
var trayCodes = cntrs;
var taskNo = DateTime.Now.Ticks.ToString();
var res = WCSHelper.CreateTask(taskNo, start.Trim(), end.Trim(), taskType, priority, trayCodes, trayCarryCount, startLayer, endLayer);
if (res)
{
result = true;
//任务创建成功,起点货位出库锁定,终点货位入库锁定
LocationHelper.LockLoc(start, 2);
LocationHelper.LockLoc(end, 1);
}
return result;
}
///
/// 创建搬运任务
///
///
///
///
///
///
///
///
///
///
public static bool CreateTransport(string start, string end, string taskType, List cntrs, int startLayer, int endLayer, int trayCarryCount = 1, int priority = 1)
{
var result = false;
var trayCodes = string.Join(",", cntrs);
var taskNo = DateTime.Now.Ticks.ToString();
var res = WCSHelper.CreateTask(taskNo, start.Trim(), end.Trim(), taskType, priority, trayCodes, trayCarryCount, startLayer, endLayer);
if (res)
{
result = true;
//任务创建成功,起点货位出库锁定,终点货位入库锁定
LocationHelper.LockLoc(start, 2);
LocationHelper.LockLoc(end, 1);
}
return result;
}
public static bool CreateTransport(string start, string end, string taskType, List cntrs, int priority = 1)
{
var result = false;
//批次号存托盘号,1~3个托盘
var trayCodes = string.Join(",", cntrs);
var taskNo = DateTime.Now.Ticks.ToString();
var res = WCSHelper.CreateTask(taskNo, start.Trim(), end.Trim(), taskType, priority, trayCodes, 1, 1, 1);
if (res)
{
result = true;
LocationHelper.LockLoc(start, 2);
LocationHelper.LockLoc(end, 1);
}
return result;
}
internal static Result cancelTask1(cancleTaskParme model)
{
var result = new Result();
LogHelper.Info("cancelTask1取消任务信息:" + JsonConvert.SerializeObject(model), "API");
if (model == null)
{
result.success = false;
result.errMsg = "参数为null";
result.errCode = 1;
return result;
}
var task = WCSHelper.GetTask(model.taskNo);
if (task != null)
{
if (task.S_B_STATE.Trim() == "未执行")
{
//未执行直接修改状态为取消
TaskProcess.OperateStatus(task, 7);
WCSHelper.UpdateStatus(task, "取消");
result.success = true;
result.errMsg = "取消任务成功";
result.errCode = 0;
}
else if (task.S_B_STATE.Trim() != "取消" && task.S_B_STATE.Trim() != "完成")
{
if (GZRobot.CancelOrder(int.Parse(task.S_EQ_TASK_CODE)))
{
TaskProcess.OperateStatus(task, 7);
WCSHelper.Fail(task);
result.success = true;
result.errMsg = "国自取消任务成功";
result.errCode = 0;
}
else
{
result.success = false;
result.errMsg = "国自取消任务失败";
result.errCode = 1;
}
}
else
{
result.success = false;
result.errMsg = "任务已经结束";
result.errCode = 1;
}
}
else
{
result.success = false;
result.errMsg = "任务不存在";
result.errCode = 1;
}
LogHelper.Info("cancelTask1取消任务返回结果:" + JsonConvert.SerializeObject(result), "API");
return result;
}
///
/// 创建入库任务
///
///
///
internal static Result CreateInWork(moboxParam model)
{
var result = new Result() { success = true, errMsg = "入库任务生成成功!" };
var db = new SqlHelper().GetInstance();
var loc = db.Queryable().Where(a => a.S_CODE == model.S_LOC_CODE).First();
if (loc == null || loc.S_LOCK_STATE.Trim() != "无")
{
return new Result { success = false, errMsg = $"{model.S_LOC_CODE}库位已被锁定!" };
}
if (string.IsNullOrEmpty(model.S_LOC_CODE))
{
return new Result { success = false, errMsg = "入库未传起点货位!" };
}
var end = Settings.LocAreas.Where(s => s.startBit.Split(',').ToList().Contains(model.S_LOC_CODE)).FirstOrDefault();
if (end == null)
{
return new Result { success = false, errMsg = "起点未找到对应的终点库区!" };
}
Location InLoc = TaskProcess.InWorkTransport(end.endArea);
if (InLoc == null)
{
return new Result { success = false, errMsg = $"终点库区{end.endArea}未找到空货位!" };
}
//if (model.S_TASK_TYPE == "成品入库")
//{
// var locs = db.Queryable().Where(a => a.S_CODE == "KZB-A").First();
// if (locs == null || locs.S_LOCK_STATE.Trim() != "无")
// {
// return new Result { success = false, errMsg = $"KZB-A货位在锁定中!" };
// }
// var locTray = db.Queryable().Where(a => a.S_LOC_CODE == "KZB-A").OrderByDescending(s=>s.T_CREATE).First();
// if (locTray != null)
// {
// var resl = TaskProcess.CreateTransport("KZB-A", "CP", "基坑空托转运", locTray.S_CNTR_CODE.Split(',').ToList(), locs.N_CURRENT_NUM, 1,1,15);
// if (!resl)
// {
// return new Result { success = false, errMsg = "空托出库任务生成失败!" };
// }
// }
//}
string trayCode = ContainerHelper.GenerateCntrNo();
var res = TaskProcess.CreateTransport(model.S_LOC_CODE, InLoc.S_CODE, model.S_TASK_TYPE, trayCode.Split(',').ToList(), 1, 1);
if (!res)
{
return new Result { success = false, errMsg = "入库任务生成失败!" };
}
ContainerHelper.BindLocCntrs(model.S_LOC_CODE, trayCode, model.S_ITEM_CODE, model.S_ITEM_NAME, model.S_CK == "是" ? 1 : 0);
return result;
}
///
/// 创建出库任务
///
///
///
internal static Result CreateOutWork(moboxParam model)
{
var result = new Result() { success = true, errMsg = "出库任务生成成功!" };
var db = new SqlHelper().GetInstance();
var loc = db.Queryable().Where(a => a.S_CODE == model.S_LOC_CODE).First();
if (loc == null || loc.S_LOCK_STATE.Trim() != "无")
{
return new Result { success = false, errMsg = $"{model.S_LOC_CODE}库位已被锁定!" };
}
if (string.IsNullOrEmpty(model.S_LOC_CODE))
{
return new Result { success = false, errMsg = "出库未传终点货位!" };
}
var start = Settings.LocAreas.Where(s => s.endBit != null && s.endBit.Split(',').ToList().Contains(model.S_LOC_CODE)).FirstOrDefault();
if (start == null)
{
return new Result { success = false, errMsg = "终点未找到对应的起点库区!" };
}
Location OutLoc = TaskProcess.OutWorkTransport(start.startArea, model.S_ITEM_CODE);
if (OutLoc == null)
{
return new Result { success = false, errMsg = $"起点库区{start.startArea}未找到对应的满货位!" };
}
var locCntrRel = db.Queryable().Where(a => a.S_LOC_CODE == OutLoc.S_CODE).First();
var res = TaskProcess.CreateTransport(OutLoc.S_CODE, model.S_LOC_CODE, model.S_TASK_TYPE, locCntrRel.S_CNTR_CODE.Split(',').ToList(), 1, 1);
if (!res)
{
return new Result { success = false, errMsg = "出库任务生成失败!" };
}
return result;
}
///
/// 创建空托转运任务
///
///
///
internal static Result EmptyTrayTransport(moboxParam model)
{
var result = new Result() { success = true, errMsg = "空托转运任务生成成功!" };
var db = new SqlHelper().GetInstance();
var loc = db.Queryable().Where(a => a.S_CODE == model.S_START_LOC).First();
if (loc == null || loc.S_LOCK_STATE.Trim() != "无")
{
return new Result { success = false, errMsg = $"{model.S_START_LOC}库位已被锁定!" };
}
if (string.IsNullOrEmpty(model.S_START_LOC))
{
return new Result { success = false, errMsg = "空托转运未传起点货位!" };
}
Location InLoc = TaskProcess.InWorkTransport(model.S_END_AREA);
if (InLoc == null)
{
return new Result { success = false, errMsg = $"终点库区{model.S_END_AREA}未找到空货位!" };
}
//string trayCode = ContainerHelper.GenerateCntrNo();
var locCntr = db.Queryable().Where(a => a.S_LOC_CODE == model.S_START_LOC).ToList();
if (!locCntr.Any())
{
return new Result { success = false, errMsg = $"{model.S_START_LOC}货位未找到托盘!" };
}
var res = TaskProcess.CreateTransport(model.S_START_LOC, InLoc.S_CODE, model.S_TASK_TYPE, locCntr.Select(s => s.S_CNTR_CODE).ToList(), loc.N_CURRENT_NUM, InLoc.N_CURRENT_NUM + 1);
if (!res)
{
return new Result { success = false, errMsg = "空托转运任务生成失败!" };
}
//ContainerHelper.BindLocCntrs(model.S_LOC_CODE, trayCode, model.S_ITEM_CODE, model.S_ITEM_NAME);
return result;
return result;
}
#endregion
///
/// 入库货位
///
/// 库区
///
public static Location InWorkTransport(string area)
{
Location result = null;
var db = new SqlHelper