一楼叠盘机入库.cs 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112
  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.Protocol.BCR;
  8. using WCS.WorkEngineering.Protocol.Station;
  9. using WCS.WorkEngineering.WebApi.Controllers;
  10. using WCS.WorkEngineering.WebApi.Models.WMS.Request;
  11. using WCS.WorkEngineering.Worlds;
  12. namespace WCS.WorkEngineering.Systems
  13. {
  14. /// <summary>
  15. /// 一楼叠盘机入库
  16. /// </summary>
  17. [BelongTo(typeof(MainWorld))]
  18. [Description("一楼叠盘机入库")]
  19. public class 一楼叠盘机入库 : DeviceSystem<Device<IStation520, IStation521, IStation523, IStation91, IBCR81>>
  20. {
  21. protected override bool ParallelDo => true;
  22. protected override bool SaveLogsToFile => true;
  23. public override void Do(Device<IStation520, IStation521, IStation523, IStation91, IBCR81> obj)
  24. {
  25. obj.入库站点是否被禁止();
  26. obj.入库站点是否满足执行条件();
  27. WCS_TaskInfo task = null;//处理完成的任务
  28. try
  29. {
  30. var device = "";
  31. var barcode = "";
  32. switch (obj.Entity.Code)
  33. {
  34. case "2527":
  35. device = "SRM1";
  36. barcode = "TPA";
  37. break;
  38. case "2528":
  39. device = "SRM1";
  40. barcode = "TPA";
  41. break;
  42. case "2727":
  43. device = "SRM2";
  44. barcode = "TPA";
  45. break;
  46. case "2728":
  47. device = "SRM2";
  48. barcode = "TPA";
  49. break;
  50. };
  51. SqlSugarHelper.Do(_db =>
  52. {
  53. var db = _db.Default;
  54. //验证是否有对应的任务
  55. if (!db.Queryable<WCS_TaskInfo>().Any(v => v.BarCode == barcode))
  56. {
  57. var res = WmsApi.OneFloorWorkerBuildEmptyPalletsStock(new OneFloorWorkerBuildEmptyPalletsStockRequest()
  58. {
  59. PalletCode = barcode,
  60. StartLoc = obj.Entity.Code,
  61. Height = 2
  62. });
  63. if (res.ResCode == WebApi.Models.WMS.Response.ResponseStatusCodeEnum.Sucess) return;
  64. }
  65. //找到对应的任务
  66. task = db.Queryable<WCS_TaskInfo>().First(v => v.BarCode == barcode);
  67. if (task.Status == Entity.TaskStatus.WaitingToExecute)
  68. {
  69. var tunnel = obj.Entity.Targets.Where(v => v.HasFlag(Extensions.DeviceFlags.巷道)).FirstOrDefault();
  70. //开始对任务进行处理
  71. task.Status = Entity.TaskStatus.ConveyorExecution;
  72. task.StartTime = DateTime.Now;
  73. task.SrmStation = task.AddrFrom;
  74. task.LastInteractionPoint = obj.Entity.Code;
  75. task.Tunnel = tunnel.Code;
  76. task.Height = 2;
  77. task.AddWCS_TASK_DTL(_db, obj.Entity.Code, "开始执行入库任务");
  78. db.Updateable(task).ExecuteCommand();
  79. task.updateRedisHash();
  80. }
  81. else return;
  82. });
  83. }
  84. catch (Exception ex)
  85. {
  86. throw new KnownException(ex.Message, LogLevelEnum.High);
  87. }
  88. if (task == null) return;
  89. World.Log($"任务处理:开始-DB520[{obj.Data.TaskNumber}]-[{obj.Data.VoucherNo}]-DB521[{obj.Data2.TaskNumber}]-[{obj.Data2.VoucherNo}]");
  90. obj.Data.TaskNumber = task.ID;
  91. obj.Data.VoucherNo++;
  92. World.Log($"任务处理:结束-DB520[{obj.Data.TaskNumber}]-[{obj.Data.VoucherNo}]-DB521[{obj.Data2.TaskNumber}]-[{obj.Data2.VoucherNo}]");
  93. }
  94. public override bool Select(Device dev)
  95. {
  96. return dev.HasFlag(Extensions.DeviceFlags.一楼叠盘机);
  97. }
  98. }
  99. }