二楼入库工位处理系统.cs 4.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  1. using Microsoft.OpenApi.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.BCR;
  8. using WCS.Entity.Protocol.Station;
  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(MainWorld))]
  20. [Description("二楼入库工位处理系统")]
  21. public class 二楼入库工位处理系统 : DeviceSystem<Station>
  22. {
  23. protected override bool ParallelDo => false;
  24. protected override bool SaveLogsToFile => true;
  25. private List<BCR> BCRS = new List<BCR>();
  26. public 二楼入库工位处理系统()
  27. {
  28. BCRS = Device.All.Where(v => v.HasProtocol<IBCR81>()).Select(v => new BCR(v, World)).ToList();
  29. }
  30. public override void Do(Station obj)
  31. {
  32. obj.入库站点是否被禁止();
  33. obj.入库站点是否满足执行条件();
  34. WCS_TaskInfo task = null; //处理完成的任务
  35. SqlSugarHelper.Do(_db =>
  36. {
  37. var db = _db.Default;
  38. WCS_TaskInfo taskInfo = null; //需要处理的任务
  39. #region 初始化空轮入库任务检索
  40. //判断当前站台是否有多条待执行状态的初始化空轮入库任务
  41. if (db.Queryable<WCS_TaskInfo>().Count(v => v.Type == TaskType.EmptyInit && v.Status == TaskStatus.WaitingToExecute && v.SrmStation == obj.Entity.Code) > 1)
  42. {
  43. throw new KnownException($"{obj.Entity.Code}站台存在多个空轮初始化入库任务,请取消RFID不是站台实物的任务", LogLevelEnum.Mid);
  44. }
  45. taskInfo = db.Queryable<WCS_TaskInfo>().First(v => v.Type == TaskType.EmptyInit && v.Status == TaskStatus.WaitingToExecute && v.SrmStation == obj.Entity.Code);
  46. #endregion 初始化空轮入库任务检索
  47. #region 非空轮初始化入库任务
  48. if (task == null)
  49. {
  50. taskInfo = db.Queryable<WCS_TaskInfo>().First(v => v.ID == obj.Data.TaskNumber && v.Type == TaskType.EnterDepot);
  51. if (taskInfo == null) throw new KnownException($"未找到任务[{obj.Data.TaskNumber}],或该任务不是入库任务", LogLevelEnum.Mid);
  52. if (taskInfo.Status != Entity.TaskStatus.AGVExecution)
  53. {
  54. if (!db.Queryable<WCS_TaskDtl>().SplitTable(v => v.Take(2)).Any(v => v.ParentTaskCode == taskInfo.ID && v.Desc.Contains("等待分配货位后堆垛机进行取货")))
  55. {
  56. throw new KnownException($"任务:{task.ID}不是AGV执行状态,请检查异常原因", LogLevelEnum.High);
  57. }
  58. }
  59. }
  60. #endregion 非空轮初始化入库任务
  61. if (obj.Entity.Code == "1025")//获取称重
  62. {
  63. var dev91 = Device.All.Where(v => v.Code == obj.Entity.Code).Select(v => new Device<IStation91>(v, this.World)).FirstOrDefault();
  64. taskInfo.Weight = dev91.Data.Weight;
  65. if (taskInfo.Weight <= 100) throw new KnownException($"称重结果错误:{taskInfo.Weight}", LogLevelEnum.Mid);
  66. //上抛重量
  67. try { WmsApi.WcsUploadInfo(taskInfo.ID, (decimal)taskInfo.Weight, taskInfo.BarCode); } catch (Exception ex) { World.Log(ex.Message, LogLevelEnum.Mid); }
  68. }
  69. taskInfo.Status = TaskStatus.ConveyorExecution;
  70. db.Updateable(taskInfo).ExecuteCommand();
  71. taskInfo.AddWCS_TASK_DTL(_db, obj.Entity.Code, "SRM", $"状态更新为{TaskStatus.ConveyorExecution.GetDisplayName()},等待分配货位后堆垛机进行取货");
  72. task = taskInfo;
  73. });
  74. if (task == null) throw new KnownException("数据更新错误", LogLevelEnum.High);
  75. obj.Data.TaskNumber = task.ID;
  76. }
  77. public override bool Select(Device dev)
  78. {
  79. return dev.HasFlag(DeviceFlags.二楼入库口);
  80. }
  81. }
  82. }