环形库分流点.cs 2.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758
  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.WorkEngineering.Extensions;
  8. using WCS.WorkEngineering.Protocol.Station;
  9. using WCS.WorkEngineering.Worlds;
  10. namespace WCS.WorkEngineering.Systems
  11. {
  12. /// <summary>
  13. /// 分流点
  14. /// </summary>
  15. [BelongTo(typeof(MainWorld))]
  16. [Description("环形库分流点")]
  17. public class 环形库分流点 : DeviceSystem<Device<IStation520, IStation521, IStation523, IStation91>>
  18. {
  19. protected override bool ParallelDo => true;
  20. protected override bool SaveLogsToFile => true;
  21. public override void Do(Device<IStation520, IStation521, IStation523, IStation91> obj)
  22. {
  23. if (obj.Data.VoucherNo != obj.Data2.VoucherNo) throw new KnownException($"凭证号不一致,DB520:{obj.Data.VoucherNo}-DB521:{obj.Data2.VoucherNo}", LogLevelEnum.High);
  24. if (obj.Data3.Status.HasFlag(StationStatus.Run)) throw new KnownException("设备运行中", LogLevelEnum.Low);
  25. if (!obj.Data3.Status.HasFlag(StationStatus.OT_Status)) throw new KnownException("站台货物信息与实际占用不一致", LogLevelEnum.Low);
  26. if (obj.Data2.Request != 1) throw new KnownException("无请求", LogLevelEnum.Mid);
  27. if (obj.Data2.TaskNumber == 1)
  28. {
  29. obj.Data.TaskNumber = 591;
  30. obj.Data.GoodsStart = obj.Entity.Code.ToShort();
  31. obj.Data.GoodsEnd = 591;
  32. obj.Data.VoucherNo++;
  33. World.Log($"执行记录:任务号[{591}]");
  34. }
  35. SqlSugarHelper.Do(_db =>
  36. {
  37. var db = _db.Default;
  38. var taskInfo = db.Queryable<WCS_TaskInfo>().First(v => v.ID == obj.Data2.TaskNumber) ?? throw new KnownException("未找到对应的WCS任务", LogLevelEnum.Mid);
  39. });
  40. obj.Data.TaskNumber = obj.Data2.TaskNumber;
  41. obj.Data.GoodsStart = obj.Entity.Code.ToShort();
  42. obj.Data.GoodsEnd = 455;
  43. obj.Data.VoucherNo++;
  44. World.Log($"执行记录:任务号[{obj.Data2.TaskNumber}]");
  45. }
  46. public override bool Select(Device dev)
  47. {
  48. return dev.HasFlag(Extensions.DeviceFlags.环形库分流点);
  49. }
  50. }
  51. }