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

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081
  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. if (task.ProdLine == 1)
  28. {
  29. //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);
  30. var res = IwmsApi.满轮出库(task.MatCode, task.AddrTo, task.ID.ToString(), task.BarCode, task.InvBarCode, task.IsSurplus, task.IsRework, task.IsFast, task.Grade, task.WorkBench, task.AddWho, true);
  31. var agv = new WCS_AgvTaskInfo()
  32. {
  33. ID = db.GetAGVTaskId(),
  34. TaskType = AGVTaskType.CallMaterial,
  35. Status = AGVTaskStatus.Confirm,
  36. Station = obj.Entity.Code,
  37. Position = obj.Entity.Code,
  38. AddWho = "WCS",
  39. AgvID = res.data,
  40. };
  41. db.Default.Insertable(agv).SplitTable().ExecuteCommand();
  42. //agv.Status = AGVTaskStatus.Confirm;
  43. //agv.AgvID = res.data;
  44. //agv.Station = obj.Entity.Code;
  45. //agv.Position = obj.Entity.Code;
  46. //db.Default.Updateable(agv).SplitTable(x => x.Take(2)).ExecuteCommand();
  47. task.AgvTaskID = agv.ID;
  48. task.Status = Entity.TaskStatus.AGVExecution;
  49. db.Default.Updateable(task).ExecuteCommand();
  50. task.AddWCS_TASK_DTL(db, obj.Entity.Code, "AGV", $"任务已下发AGV,AGVID:{agv.AgvID}");
  51. }
  52. else
  53. {
  54. 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);
  55. var res = IwmsApi.满轮出库(task.MatCode, task.AddrTo, task.ID.ToString(), task.BarCode, task.InvBarCode, task.IsSurplus, task.IsRework, task.IsFast, task.Grade, task.WorkBench, task.AddWho);
  56. agv.Status = AGVTaskStatus.Confirm;
  57. agv.AgvID = res.data;
  58. agv.Station = obj.Entity.Code;
  59. agv.Position = obj.Entity.Code;
  60. db.Default.Updateable(agv).SplitTable(x => x.Take(2)).ExecuteCommand();
  61. task.Status = Entity.TaskStatus.AGVExecution;
  62. db.Default.Updateable(task).ExecuteCommand();
  63. task.AddWCS_TASK_DTL(db, obj.Entity.Code, "AGV", $"任务已下发AGV,AGVID:{agv.AgvID}");
  64. }
  65. });
  66. }
  67. public override bool Select(Device dev)
  68. {
  69. //return dev.Code == "1026";
  70. return dev.HasFlag(DeviceFlags.二楼出库口);
  71. }
  72. }
  73. }