桁架码垛工位任务结束处理.cs 6.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122
  1. using ServiceCenter.Extensions;
  2. using ServiceCenter.Logs;
  3. using ServiceCenter.SqlSugars;
  4. using System.ComponentModel;
  5. using WCS.Core;
  6. using WCS.Entity;
  7. using WCS.Entity.Protocol.Station;
  8. using WCS.Entity.Protocol.Truss;
  9. using WCS.WorkEngineering.Extensions;
  10. using WCS.WorkEngineering.WebApi.Controllers;
  11. using WCS.WorkEngineering.Worlds;
  12. using DeviceFlags = WCS.WorkEngineering.Extensions.DeviceFlags;
  13. using TaskStatus = WCS.Entity.TaskStatus;
  14. namespace WCS.WorkEngineering.Systems
  15. {
  16. /// <summary>
  17. /// 码垛工位处理
  18. /// </summary>
  19. [BelongTo(typeof(SortingPalletizingWorld))]
  20. [Description("码垛工位任务结束处理09")]
  21. public class 桁架码垛工位任务结束处理 : DeviceSystem<Device<IStation520, IStation521, IStation523, ITruss530, ITruss531>>
  22. {
  23. protected override bool ParallelDo => true;
  24. public override void Do(Device<IStation520, IStation521, IStation523, ITruss530, ITruss531> obj)
  25. {
  26. if (!obj.Data5.CmdType.HasFlag(TrussCmdType.End) && !obj.Data4.CmdType.HasFlag(TrussCmdType.End1 | TrussCmdType.Two) && obj.Data4.CmdType != 0) obj.Data4.CmdType = 0;
  27. if (!obj.Data3.Status.HasFlag(StationStatus.PH_Status)) return;
  28. if (!obj.Data5.CmdType.HasFlag(TrussCmdType.End)) return;
  29. if (!obj.Data5.CmdType.HasFlag(TrussCmdType.End1))
  30. {
  31. if (obj.Data5.MaxQuantity != obj.Data5.Quantity || obj.Data5.Quantity == 0 || obj.Data5.MaxQuantity == 0) return;
  32. }
  33. WCS_TaskInfo task = null;
  34. //找到对应的码垛数据
  35. SqlSugarHelper.Do(_db =>
  36. {
  37. var db = _db.Default;
  38. var palletizing = db.Queryable<WCS_Palletizing>().Single(x => x.PalletizingStation == obj.Entity.Code && !x.Finish);
  39. var TaskNoList = obj.Data5.GetTaskNoList().Where(x => x > 0).ToList();
  40. var taskList = db.Queryable<WCS_TaskInfo>().Where(x => TaskNoList.Contains(x.ID)).ToList();
  41. var taskCodes = taskList.Select(x => x.BarCode).ToList();
  42. if (!obj.Data5.CmdType.HasFlag(TrussCmdType.End1))
  43. {
  44. if (TaskNoList.Count == 0)
  45. {
  46. var taskAny = db.Queryable<WCS_TaskInfo>().NoLock().Single(x => x.Type == TaskType.EnterDepot && x.Status == TaskStatus.ConveyorExecution && x.BusType == "码垛入库" && x.AddrFrom == obj.Entity.Code);
  47. //针对断电写入信号失败的情况
  48. if (taskAny != null && obj.Data.TaskNumber != taskAny.ID)
  49. {
  50. obj.Data.TaskNumber = taskAny.ID;
  51. obj.Data.GoodsStart = obj.Entity.Code.ToShort();
  52. obj.Data.GoodsEnd = taskAny.AddrNext.ToShort();
  53. obj.Data4.CmdType = TrussCmdType.End;
  54. }
  55. return;
  56. }
  57. if (taskList.Count != TaskNoList.Count)
  58. {
  59. var taskIn = db.Queryable<WCS_TaskInfo>().NoLock().Single(x => x.BarCode == palletizing.PalleCode && x.Type == TaskType.EnterDepot && x.Status < TaskStatus.Finish);
  60. if (taskIn == null)
  61. {
  62. WmsApi.ForceFinishBingPallet(palletizing.PalleCode, taskCodes, taskList.FirstOrDefault().WarehouseCode, obj.Entity.Code);
  63. return;
  64. }
  65. }
  66. //throw new KnownException($"任务数量不一致!,请检查托盘任务信息", LogLevelEnum.Mid);
  67. }
  68. var taskInfo = db.Queryable<WCS_TaskInfo>().Single(x => x.BarCode == palletizing.PalleCode && x.Type == TaskType.EnterDepot && x.Status < TaskStatus.Finish);
  69. if (taskInfo == null)
  70. {
  71. if (obj.Data5.CmdType.HasFlag(TrussCmdType.Two)) WmsApi.SecondaryBingPallet(palletizing.PalleCode, taskCodes, taskList.FirstOrDefault().WarehouseCode, obj.Entity.Code);
  72. else if (obj.Data5.CmdType.HasFlag(TrussCmdType.End1)) WmsApi.ForceFinishBingPallet(palletizing.PalleCode, taskCodes, taskList.FirstOrDefault().WarehouseCode, obj.Entity.Code);
  73. else WmsApi.FinishBingPallet(palletizing.PalleCode, taskCodes, taskList.FirstOrDefault().WarehouseCode, obj.Entity.Code);
  74. return;
  75. }
  76. if (taskInfo.Status != TaskStatus.WaitingToExecute)
  77. {
  78. if (taskInfo.Status == TaskStatus.NewBuild) throw new KnownException($"等待入库任务{taskInfo.ID}初始化完成", LogLevelEnum.Low);
  79. return;
  80. }
  81. foreach (var x in taskList)
  82. {
  83. x.Status = TaskStatus.Finish;
  84. x.EndTime = DateTime.Now;
  85. db.UpdateableRowLock(x).UpdateColumns(x => new { x.Status, x.EndTime }).ExecuteCommand();
  86. x.AddWCS_TASK_DTL(db, obj.Entity.Code, "任务结束");
  87. }
  88. palletizing.Finish = true;
  89. palletizing.isItHalf = obj.Data5.CmdType.HasFlag(TrussCmdType.Two);
  90. if (palletizing.isItHalf)
  91. {
  92. palletizing.TaskId = taskInfo.ID; //如果是半托入库,需要把绑定的任务切换成入库任务
  93. }
  94. db.UpdateableRowLock(palletizing).UpdateColumns(x => new { x.Finish, x.isItHalf, x.TaskId }).ExecuteCommand();
  95. taskInfo.Status = TaskStatus.ConveyorExecution;
  96. db.UpdateableRowLock(taskInfo).UpdateColumns(x => new { x.Status }).ExecuteCommand();
  97. taskInfo.AddWCS_TASK_DTL(db, obj.Entity.Code, $"桁架码垛结束处理完成");
  98. task = taskInfo;
  99. });
  100. if (task == null) return;
  101. obj.Data.TaskNumber = task.ID;
  102. obj.Data.GoodsStart = obj.Entity.Code.ToShort();
  103. obj.Data.GoodsEnd = task.AddrNext.ToShort();
  104. obj.Data4.CmdType = TrussCmdType.End;
  105. }
  106. public override bool Select(Device dev)
  107. {
  108. var devCodes = new List<string>() { "1670", "1671", "1715", "1716", "1685", "1686" };
  109. return dev.HasFlag(DeviceFlags.桁架码垛位) || devCodes.Contains(dev.Code);
  110. }
  111. }
  112. }