出库任务处理.cs 3.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091
  1. using ServiceCenter.Extensions;
  2. using ServiceCenter.Logs;
  3. using ServiceCenter.SqlSugars;
  4. using System;
  5. using System.Collections.Generic;
  6. using System.ComponentModel;
  7. using System.Linq;
  8. using System.Text;
  9. using System.Threading.Tasks;
  10. using WCS.Core;
  11. using WCS.Entity;
  12. using WCS.WorkEngineering.Extensions;
  13. using WCS.WorkEngineering.Protocol.Station;
  14. using WCS.WorkEngineering.WebApi.Controllers;
  15. using WCS.WorkEngineering.Worlds;
  16. using DeviceFlags = WCS.WorkEngineering.Extensions.DeviceFlags;
  17. namespace WCS.WorkEngineering.Systems
  18. {
  19. /// <summary>
  20. /// 出库任务处理
  21. /// </summary>
  22. [BelongTo(typeof(MainWorld))]
  23. [Description("出库任务处理")]
  24. public class 出库任务处理 : DeviceSystem<Device<IStation520, IStation521, IStation523>>
  25. {
  26. protected override bool ParallelDo => true;
  27. protected override bool SaveLogsToFile => true;
  28. List<Station> devs = new List<Station>();
  29. public 出库任务处理()
  30. {
  31. devs = Device.All.Where(v => v.HasFlag(DeviceFlags.出货口)).Select(v => new Station(v, this.World)).ToList();
  32. }
  33. public override void Do(Device<IStation520, IStation521, IStation523> obj)
  34. {
  35. WCS_TaskInfo task = null;
  36. if (obj.Data2.TaskNumber <= 0)
  37. return;
  38. if (!obj.Data3.Status.HasFlag(StationStatus.PH_Status) || !obj.Data3.Status.HasFlag(StationStatus.OT_Status))
  39. return;
  40. if (obj.Data2.GoodsEnd != obj.Entity.Code.ToShort()) return;
  41. if (obj.Data2.Request == 0)
  42. {
  43. SqlSugarHelper.Do(db =>
  44. {
  45. //找到对应任务
  46. var taskInfo = db.Default.Queryable<WCS_TaskInfo>().First(v => v.ID == obj.Data2.TaskNumber);
  47. if (taskInfo == null) throw new KnownException($"未找到对应WCS任务{obj.Data2.TaskNumber}", LogLevelEnum.High);
  48. if (taskInfo.AddrTo == obj.Entity.Code && taskInfo.Type == TaskType.OutDepot)
  49. {
  50. taskInfo.Status = Entity.TaskStatus.Finish;
  51. taskInfo.EditTime = DateTime.Now;
  52. taskInfo.EedTime = DateTime.Now;
  53. db.Default.Updateable(taskInfo).ExecuteCommand();
  54. taskInfo.AddWCS_TASK_DTL(db, obj.Entity.Code, taskInfo.AddrNext, $"出库任务完成");
  55. task = taskInfo;
  56. taskInfo.CompleteOrCancelTasks(db);
  57. WmsApi.CompleteTask(task.ID);
  58. obj.Data.TaskNumber = 0;
  59. obj.Data.VoucherNo++;
  60. }
  61. });
  62. }
  63. else
  64. {
  65. SqlSugarHelper.Do(db =>
  66. {
  67. //找到对应任务
  68. var taskInfo = db.Default.Queryable<WCS_TaskInfo>().First(v => v.ID == obj.Data2.TaskNumber);
  69. if (taskInfo != null) throw new KnownException($"WCS任务{obj.Data2.TaskNumber}未完成,请联系相关人员查明原因", LogLevelEnum.High);
  70. //出货口货取走后去叠盘机叠盘
  71. obj.Data.TaskNumber = obj.Entity.Code.ToShort();
  72. if (obj.Entity.Code == "8263" || obj.Entity.Code == "8269")
  73. {
  74. obj.Data.GoodsEnd = 8262;
  75. }
  76. obj.Data.VoucherNo++;
  77. });
  78. }
  79. }
  80. public override bool Select(Device dev)
  81. {
  82. return dev.HasFlag(DeviceFlags.出货口);
  83. }
  84. }
  85. }