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

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384
  1. using ServiceCenter.Logs;
  2. using ServiceCenter.SqlSugars;
  3. using System.ComponentModel;
  4. using WCS.Core;
  5. using WCS.Entity;
  6. using WCS.Entity.Protocol.BCR;
  7. using WCS.Entity.Protocol.Station;
  8. using WCS.WorkEngineering.Extensions;
  9. using WCS.WorkEngineering.WebApi.Controllers;
  10. using WCS.WorkEngineering.Worlds;
  11. using DeviceFlags = WCS.WorkEngineering.Extensions.DeviceFlags;
  12. using TaskStatus = WCS.Entity.TaskStatus;
  13. namespace WCS.WorkEngineering.Systems
  14. {
  15. /// <summary>
  16. /// 二楼入库工位处理系统
  17. /// </summary>
  18. [BelongTo(typeof(MainWorld))]
  19. [Description("二楼入库工位处理系统")]
  20. public class 二楼入库工位处理系统 : DeviceSystem<Station>
  21. {
  22. protected override bool ParallelDo => false;
  23. protected override bool SaveLogsToFile => true;
  24. private List<BCR> BCRS = new List<BCR>();
  25. public 二楼入库工位处理系统()
  26. {
  27. BCRS = Device.All.Where(v => v.HasProtocol<IBCR81>()).Select(v => new BCR(v, World)).ToList();
  28. }
  29. public override void Do(Station obj)
  30. {
  31. obj.StorageStationIsForbid();
  32. //判断凭证号是否一致
  33. if (obj.Data.VoucherNo != obj.Data2.VoucherNo) throw new KnownException($"凭证号不一致,DB520:{obj.Data.VoucherNo}-DB521{obj.Data2.VoucherNo}", LogLevelEnum.High);
  34. //设备是否停止运行
  35. if (obj.Data3.Status.HasFlag(StatusEunm.Run)) throw new KnownException("设备运行中", LogLevelEnum.Low);
  36. if (!obj.Data3.Status.HasFlag(StatusEunm.PH_Status)) throw new KnownException("没有光电", LogLevelEnum.Low);
  37. if (obj.Data2.TaskNumber != 0) throw new KnownException("有任务", LogLevelEnum.Low);
  38. if (obj.Data2.Request != 1) throw new KnownException("没有请求", LogLevelEnum.Low);
  39. WCS_TaskInfo task = null;
  40. SqlSugarHelper.Do(db =>
  41. {
  42. if (obj.Entity.Code == "1025" || obj.Entity.Code == "1023")
  43. {
  44. var taskInfos = db.Default.Queryable<WCS_TaskInfo>().Where(v => v.Type == TaskType.EmptyInit && v.Status == TaskStatus.WaitingToExecute);
  45. var taskInfo = taskInfos.First(v => v.SrmStation == obj.Entity.Code) ?? throw new KnownException($"未找到对应的任务", LogLevelEnum.Mid);
  46. if (taskInfo != null)
  47. {
  48. task = taskInfo;
  49. if (task.Type != TaskType.EmptyInit && task.Status != Entity.TaskStatus.WaitingToExecute) throw new KnownException($"任务:{task.ID}不是待执行状态,请检查异常原因", LogLevelEnum.High);
  50. }
  51. }
  52. if (task == null) return;
  53. if (task.Status == Entity.TaskStatus.ConveyorExecution) return;
  54. if (obj.Entity.Code == "1025")
  55. {
  56. //获取称重
  57. var dev91 = Device.All.Where(v => v.Code == obj.Entity.Code).Select(v => new Device<IStation91>(v, this.World)).FirstOrDefault();
  58. task.Weight = dev91.Data.Weight;
  59. WmsApi.WcsUploadInfo(task.ID, (decimal)task.Weight, task.BarCode);
  60. }
  61. task.Status = Entity.TaskStatus.ConveyorExecution;
  62. db.Default.Updateable(task).ExecuteCommand();
  63. task.AddWCS_TASK_DTL(db, obj.Entity.Code, "SRM", $"状态更新为{Entity.TaskStatus.ConveyorExecution},等待分配货位后堆垛机进行取货");
  64. });
  65. if (task == null) throw new KnownException("数据更新错误", LogLevelEnum.High);
  66. obj.Data.TaskNumber = task.ID;
  67. }
  68. public override bool Select(Device dev)
  69. {
  70. //return dev.Code == "1025";
  71. return dev.HasFlag(DeviceFlags.二楼入库口);
  72. }
  73. }
  74. }