二楼出库工位处理系统.cs 2.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748
  1. using ServiceCenter.Logs;
  2. using ServiceCenter.SqlSugars;
  3. using System.ComponentModel;
  4. using WCS.Core;
  5. using WCS.Entity;
  6. using WCS.WorkEngineering.Extensions;
  7. using WCS.WorkEngineering.WebApi.Controllers;
  8. using WCS.WorkEngineering.Worlds;
  9. using DeviceFlags = WCS.WorkEngineering.Extensions.DeviceFlags;
  10. namespace WCS.WorkEngineering.Systems
  11. {
  12. /// <summary>
  13. /// 二楼出库工位处理系统
  14. /// </summary>
  15. [BelongTo(typeof(MainWorld))]
  16. [Description("二楼出库工位处理系统")]
  17. public class 二楼出库工位处理系统 : DeviceSystem<Station>
  18. {
  19. protected override bool ParallelDo => true;
  20. protected override bool SaveLogsToFile => true;
  21. public override void Do(Station obj)
  22. {
  23. if (!obj.Data3.Status.HasFlag(Entity.Protocol.Station.StatusEunm.PH_Status)) throw new KnownException("无光电", LogLevelEnum.Low);
  24. SqlSugarHelper.Do(db =>
  25. {
  26. var task = db.Default.Queryable<WCS_TaskInfo>().First(v => v.ID == obj.Data.TaskNumber && v.Status == Entity.TaskStatus.ConveyorExecution) ?? throw new KnownException("无可执行任务", LogLevelEnum.Mid);
  27. var agv = db.Default.Queryable<WCS_AgvTaskInfo>().SplitTable(v => v.Take(2)).First(v => v.ID == task.AgvTaskID && v.Status == AGVTaskStatus.NewBuild) ?? throw new KnownException("未找到对应的AGV任务", LogLevelEnum.Mid);
  28. var res = IwmsApi.满轮出库(task.MatCode, task.AddrTo, task.ID.ToString(), task.BarCode, task.InvBarCode, task.IsSurplus, task.IsRework, task.IsFast, task.Grade);
  29. agv.Status = AGVTaskStatus.Confirm;
  30. agv.AgvID = res.data;
  31. agv.Station = obj.Entity.Code;
  32. db.Default.Updateable(agv).SplitTable().ExecuteCommand();
  33. task.Status = Entity.TaskStatus.AGVExecution;
  34. db.Default.Updateable(task).ExecuteCommand();
  35. task.AddWCS_TASK_DTL(db, obj.Entity.Code, "AGV", "任务已下发AGV");
  36. });
  37. }
  38. public override bool Select(Device dev)
  39. {
  40. //return dev.Code == "1026";
  41. return dev.HasFlag(DeviceFlags.二楼出库口);
  42. }
  43. }
  44. }