出库任务处理.cs 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687
  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 => false;
  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. if (obj.Data2.Request != 1)
  36. {
  37. if (obj.Data2.GoodsEnd != "8269".ToShort())
  38. {
  39. throw new KnownException("无请求", LogLevelEnum.Mid);
  40. }
  41. }
  42. if (obj.Data2.TaskNumber <= 0)
  43. return;
  44. if (obj.Data2.GoodsEnd != obj.Entity.Code.ToShort()) return;
  45. SqlSugarHelper.Do(db =>
  46. {
  47. //找到对应任务
  48. var taskInfo = db.Default.Queryable<WCS_TaskInfo>().First(v => v.ID == obj.Data2.TaskNumber);
  49. if (taskInfo == null) throw new KnownException($"未找到对应WCS任务{obj.Data2.TaskNumber}", LogLevelEnum.High);
  50. if (taskInfo.AddrTo == obj.Entity.Code && taskInfo.Type == TaskType.OutDepot && taskInfo.AddrTo != "8278")
  51. {
  52. taskInfo.Status = Entity.TaskStatus.Finish;
  53. taskInfo.EditTime = DateTime.Now;
  54. taskInfo.EedTime = DateTime.Now;
  55. db.Default.Updateable(taskInfo).ExecuteCommand();
  56. taskInfo.AddWCS_TASK_DTL(db, obj.Entity.Code, taskInfo.AddrNext, $"出库任务完成");
  57. WmsApi.CompleteTask(taskInfo.ID);
  58. taskInfo.CompleteOrCancelTasks(db);
  59. if ( (obj.Entity.Code == "8263" || obj.Entity.Code == "8257"))
  60. {
  61. obj.Data.TaskNumber = taskInfo.ID;
  62. obj.Data.GoodsStart = Convert.ToInt16(obj.Entity.Code);
  63. obj.Data.GoodsEnd = 8262;
  64. obj.Data.VoucherNo++;
  65. World.Log($"出库位置{obj.Entity.Code}任务{obj.Data2.TaskNumber}完成,写入PLC凭证号{obj.Data.VoucherNo+1}", LogLevelEnum.Mid);
  66. return;
  67. }
  68. else if(obj.Entity.Code == "8269" || obj.Entity.Code == "8278")
  69. {
  70. obj.Data.TaskNumber = 0;
  71. obj.Data.VoucherNo++;
  72. World.Log($"出库位置{obj.Entity.Code}任务{obj.Data2.TaskNumber}完成,写入PLC凭证号{obj.Data.VoucherNo+1}", LogLevelEnum.Mid);
  73. return;
  74. }
  75. }
  76. });
  77. }
  78. public override bool Select(Device dev)
  79. {
  80. return dev.HasFlag(DeviceFlags.出货口);
  81. }
  82. }
  83. }