满轮主线预写入目标地址.cs 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116
  1. using Castle.Core.Internal;
  2. using Newtonsoft.Json;
  3. using ServiceCenter.Extensions;
  4. using ServiceCenter.Logs;
  5. using ServiceCenter.Redis;
  6. using ServiceCenter.SqlSugars;
  7. using System.ComponentModel;
  8. using WCS.Core;
  9. using WCS.Entity;
  10. using WCS.Entity.Protocol.BCR;
  11. using WCS.Entity.Protocol.Station;
  12. using WCS.WorkEngineering.Extensions;
  13. using WCS.WorkEngineering.Worlds;
  14. using TaskStatus = WCS.Entity.TaskStatus;
  15. namespace WCS.WorkEngineering.Systems
  16. {
  17. /// <summary>
  18. /// 满轮主线预写入目标地址
  19. /// </summary>
  20. [BelongTo(typeof(SortingMainLineWorld))]
  21. [Description("满轮主线预写入目标地址")]
  22. public class 满轮主线预写入目标地址 : DeviceSystem<Device<IStation523, IBCR83, IStation525>>
  23. {
  24. protected override bool ParallelDo => true;
  25. protected override bool SaveLogsToFile => true;
  26. public override void Do(Device<IStation523, IBCR83, IStation525> obj)
  27. {
  28. //待处理条码组
  29. var pendingBcrList = obj.Data2.GetBcrCodeList().Where(x => !x.IsNullOrEmpty());
  30. //缓存条码组
  31. var cacheBcrList = obj.Data3.GetBcrCodeList();
  32. var codes = pendingBcrList.Where(x => !cacheBcrList.Contains(x));
  33. World.Log($"扫码器:{JsonConvert.SerializeObject(pendingBcrList)}");
  34. World.Log($"缓存信息:{JsonConvert.SerializeObject(cacheBcrList)}");
  35. //循环处理所有缓存条码组中没有的条码
  36. foreach (var bcrCode in codes)
  37. {
  38. //取出预分配地址,并计算相关信息
  39. var key = $"AllocationWarehouseSort:{bcrCode}";
  40. var value = RedisHub.WMS.Get(key);
  41. if (value == null)
  42. {
  43. World.Log($"{bcrCode}:找不到分库记录", LogLevelEnum.High);
  44. continue;
  45. }
  46. var mainlineDiversion = JsonConvert.DeserializeObject<MainlineDiversion>(value);
  47. var srmCode = mainlineDiversion.WarehouseCode.WarehouseToSrm();
  48. var next = DevicePath.GetPath(obj.Entity.Code, srmCode).Points[1].Code;
  49. //开始检查任务信息
  50. var db = new SqlSugarHelper();
  51. var task = db.Default.Queryable<WCS_TaskInfo>().Single(x => x.BarCode == bcrCode && x.ID == mainlineDiversion.TaskId && x.Status == TaskStatus.NewBuild);
  52. if (task == null)
  53. {
  54. World.Log($"{bcrCode}-{mainlineDiversion}:找不到匹配任务", LogLevelEnum.High);
  55. continue;
  56. }
  57. try
  58. {
  59. db.Connect.BeginTran();
  60. task.Status = TaskStatus.WaitingToExecute;
  61. task.EditWho = "WCS";
  62. task.StartTime = DateTime.Now;
  63. task.EditTime = DateTime.Now;
  64. db.Default.Updateable(task).ExecuteCommand();
  65. task.AddWCS_TASK_DTL(db.Default, obj.Entity.Code, next.ToString(), "任务完成预分流");
  66. db.Connect.CommitTran();
  67. }
  68. catch (Exception e)
  69. {
  70. db.Connect.RollbackTran();
  71. World.Log($"{bcrCode}-{mainlineDiversion}:----{e.Message}", LogLevelEnum.High);
  72. continue;
  73. }
  74. //开始赋值
  75. obj.Data3.GetType().GetProperty($"BcrCode{obj.Data3.NextIndex}").SetValue(obj.Data3, bcrCode);
  76. obj.Data3.GetType().GetProperty($"TaskNumber{obj.Data3.NextIndex}").SetValue(obj.Data3, task.ID);
  77. obj.Data3.GetType().GetProperty($"GoodsEnd{obj.Data3.NextIndex}").SetValue(obj.Data3, next.ToShort());
  78. if (obj.Data3.NextIndex >= 49)
  79. {
  80. obj.Data3.NextIndex = 0;
  81. }
  82. else
  83. {
  84. obj.Data3.NextIndex++;
  85. }
  86. }
  87. }
  88. public override bool Select(Device dev)
  89. {
  90. return dev.Code is "18" or "118";
  91. }
  92. }
  93. /// <summary>
  94. /// 主线分流
  95. /// </summary>
  96. public class MainlineDiversion
  97. {
  98. /// <summary>
  99. /// 任务号
  100. /// </summary>
  101. public int TaskId { get; set; }
  102. /// <summary>
  103. /// 仓库号
  104. /// </summary>
  105. public string WarehouseCode { get; set; }
  106. }
  107. }