|
@@ -9,6 +9,7 @@ using WCS.WorkEngineering.Extensions;
|
|
|
using WCS.WorkEngineering.WebApi.Controllers;
|
|
|
using WCS.WorkEngineering.Worlds;
|
|
|
using DeviceFlags = WCS.WorkEngineering.Extensions.DeviceFlags;
|
|
|
+using TaskStatus = WCS.Entity.TaskStatus;
|
|
|
|
|
|
namespace WCS.WorkEngineering.Systems
|
|
|
{
|
|
@@ -41,30 +42,52 @@ namespace WCS.WorkEngineering.Systems
|
|
|
SqlSugarHelper.Do(_db =>
|
|
|
{
|
|
|
var db = _db.Default;
|
|
|
- //获取RFID
|
|
|
- var barcode = BCRS.GetBCRCode(obj.Entity.Code);
|
|
|
- //跟据RFID获取对应的任务
|
|
|
- var taskInfo = db.Queryable<WCS_TaskInfo>().First(v => v.BarCode == barcode) ?? throw new KnownException($"未找到RFID:{barcode}对应WCS任务", LogLevelEnum.Mid);
|
|
|
- if (taskInfo.Status != Entity.TaskStatus.AGVExecution)
|
|
|
+ WCS_TaskInfo taskInfo = null;
|
|
|
+ //判断是否有空轮初始化任务
|
|
|
+ if (db.Queryable<WCS_TaskInfo>().Count(v => v.Type == TaskType.EmptyInit && v.Status == TaskStatus.WaitingToExecute && v.SrmStation == obj.Entity.Code) > 1)
|
|
|
{
|
|
|
- if (db.Queryable<WCS_TaskDtl>().SplitTable(v => v.Take(2)).Any(v => v.ParentTaskCode == taskInfo.ID && v.Desc.Contains("等待分配货位后堆垛机进行取货"))) return;
|
|
|
- else throw new KnownException($"任务:{taskInfo.ID}不是AGV执行状态,请检查异常原因", LogLevelEnum.High);
|
|
|
+ throw new KnownException($"{obj.Entity.Code}站台存在多个空轮初始化入库任务,请取消RFID不是站台实物的任务", LogLevelEnum.Mid);
|
|
|
}
|
|
|
+ taskInfo = db.Queryable<WCS_TaskInfo>().First(v => v.Type == TaskType.EmptyInit && v.Status == TaskStatus.WaitingToExecute && v.SrmStation == obj.Entity.Code);
|
|
|
|
|
|
- if (!obj.Data3.Status.HasFlag(StatusEunm.ManualStorage)) //不是手动入库
|
|
|
+ string barcode = "";
|
|
|
+ //manlun
|
|
|
+ if (taskInfo == null)
|
|
|
{
|
|
|
- //判断AGV任务目标地址是否是当前地址
|
|
|
- var agv = db.Queryable<WCS_AgvTaskInfo>().SplitTable(v => v.Take(2)).First(v => v.ID == taskInfo.AgvTaskID) ?? throw new KnownException($"任务{taskInfo.ID}未找到对应AGV任务", LogLevelEnum.Mid);
|
|
|
- if (taskInfo.AddrNext != obj.Entity.Code) throw new KnownException($"任务{taskInfo.ID}不是货架上的任务,请检查RFID是否正确", LogLevelEnum.Mid);
|
|
|
- if (agv.Position != obj.Entity.Code) throw new KnownException($"任务{taskInfo.ID}对应AGV任务目标地址不是当前站台", LogLevelEnum.Mid);
|
|
|
- }
|
|
|
+ //获取RFID
|
|
|
+ barcode = BCRS.GetBCRCode(obj.Entity.Code);
|
|
|
+ //跟据RFID获取对应的任务
|
|
|
+ taskInfo = db.Queryable<WCS_TaskInfo>().First(v => v.BarCode == barcode) ?? throw new KnownException($"未找到RFID:{barcode}对应WCS任务", LogLevelEnum.Mid);
|
|
|
+ if (taskInfo.Status != Entity.TaskStatus.AGVExecution)
|
|
|
+ {
|
|
|
+ if (db.Queryable<WCS_TaskDtl>().SplitTable(v => v.Take(2)).Any(v => v.ParentTaskCode == taskInfo.ID && v.Desc.Contains("等待分配货位后堆垛机进行取货"))) return;
|
|
|
+ else throw new KnownException($"任务:{taskInfo.ID}不是AGV执行状态,请检查异常原因", LogLevelEnum.High);
|
|
|
+ }
|
|
|
|
|
|
- //获取称重
|
|
|
- var dev91 = Device.All.Where(v => v.Code == obj.Entity.Code).Select(v => new Device<IStation91>(v, this.World)).FirstOrDefault();
|
|
|
- taskInfo.Weight = dev91.Data.Weight;
|
|
|
- if (taskInfo.Weight < 200) throw new KnownException($"称重结果错误:{taskInfo.Weight}", LogLevelEnum.Mid);
|
|
|
- //上抛重量
|
|
|
- try { WmsApi.WcsUploadInfo(taskInfo.ID, (decimal)taskInfo.Weight, taskInfo.BarCode); } catch (Exception ex) { World.Log(ex.Message, LogLevelEnum.Mid); }
|
|
|
+ if (!obj.Data3.Status.HasFlag(StatusEunm.ManualStorage)) //不是手动入库
|
|
|
+ {
|
|
|
+ //判断AGV任务目标地址是否是当前地址
|
|
|
+ var agv = db.Queryable<WCS_AgvTaskInfo>().SplitTable(v => v.Take(2)).First(v => v.ID == taskInfo.AgvTaskID) ?? throw new KnownException($"任务{taskInfo.ID}未找到对应AGV任务", LogLevelEnum.Mid);
|
|
|
+ if (taskInfo.AddrNext != obj.Entity.Code) throw new KnownException($"任务{taskInfo.ID}不是货架上的任务,请检查RFID是否正确", LogLevelEnum.Mid);
|
|
|
+ if (agv.Position != obj.Entity.Code) throw new KnownException($"任务{taskInfo.ID}对应AGV任务目标地址不是当前站台", LogLevelEnum.Mid);
|
|
|
+ }
|
|
|
+ //获取称重
|
|
|
+ var dev91 = Device.All.Where(v => v.Code == obj.Entity.Code).Select(v => new Device<IStation91>(v, this.World)).FirstOrDefault();
|
|
|
+ taskInfo.Weight = dev91.Data.Weight;
|
|
|
+ if (taskInfo.Weight < 200) throw new KnownException($"称重结果错误:{taskInfo.Weight}", LogLevelEnum.Mid);
|
|
|
+ //上抛重量
|
|
|
+ try { WmsApi.WcsUploadInfo(taskInfo.ID, (decimal)taskInfo.Weight, taskInfo.BarCode); } catch (Exception ex) { World.Log(ex.Message, LogLevelEnum.Mid); }
|
|
|
+ }
|
|
|
+ else//空轮初始化任务
|
|
|
+ {
|
|
|
+ //获取称重
|
|
|
+ var dev91 = Device.All.Where(v => v.Code == obj.Entity.Code).Select(v => new Device<IStation91>(v, this.World)).FirstOrDefault();
|
|
|
+ taskInfo.Weight = dev91.Data.Weight;
|
|
|
+ if (taskInfo.Weight < 140) throw new KnownException($"称重结果错误:{taskInfo.Weight}", LogLevelEnum.Mid);
|
|
|
+ //上抛重量
|
|
|
+ try { WmsApi.WcsUploadInfo(taskInfo.ID, (decimal)taskInfo.Weight, taskInfo.BarCode); } catch (Exception ex) { World.Log(ex.Message, LogLevelEnum.Mid); }
|
|
|
+ }
|
|
|
+
|
|
|
|
|
|
taskInfo.Status = Entity.TaskStatus.ConveyorExecution;
|
|
|
db.Updateable(taskInfo).ExecuteCommand();
|