合流入库.cs 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  1. using DBHelper;
  2. using System;
  3. using System.Collections.Generic;
  4. using System.Linq;
  5. using System.Text;
  6. using System.Threading.Tasks;
  7. using WCS.Core;
  8. using WCS.Entity;
  9. using WCS.Entity.Protocol;
  10. using WCS.Service.Extensions;
  11. using WCS.Service.Helpers;
  12. using WCS.Service.Log;
  13. namespace WCS.Service.Works.Station
  14. {
  15. [WorkTitle(typeof(ProductHandler), "合流入库")]
  16. internal class 合流入库 : DeviceWork<Device<IStation520, IStation521, IStation523>>
  17. {
  18. protected override void Do(Device<IStation520, IStation521, IStation523> dev)
  19. {
  20. if (Ltc.Do(dev, v => v.Data2.VoucherNo != v.Data.VoucherNo)) throw new WarnException($"等待任务执行--凭证号不一致");
  21. if (Ltc.Do(dev, v => v.Data3.Status.HasFlag(StationStatus.运行状态位))) throw new WarnException($"设备运行中");
  22. if (Ltc.Do(dev, v => v.Data2.Status.HasFlag(IstationStatus.光电状态) == false)) return;
  23. if (Ltc.Do(dev, v => v.Data2.Tasknum < 10000)) return;
  24. if (Ltc.Do(dev, v => v.Data2.Request != IstationRequest.请求分配目标地址)) return;
  25. if (dev.Entity.CODE == "3163")
  26. {
  27. InfoLog.INFO_INFO($"已扫码等待分配目标地址,[{dev.Entity.CODE}写入信息:当前任务号[{dev.Data2.Tasknum}]-凭证号[{dev.Data2.VoucherNo}]");
  28. }
  29. var bcr = dev.Entity.BCR();
  30. var barcode = bcr.Content.Trim('\r');
  31. if (barcode == "")
  32. {
  33. InfoLog.INFO_WarnDb($"{dev.Entity.CODE}--扫码失败,内容为空", dev.Entity.CODE, WCS_EXCEPTIONTYPE.设备异常);
  34. return;
  35. };
  36. var res = WMS.GetSingleOrDouble(barcode,dev.Entity.CODE);
  37. if (res == null) throw new WarnException($"{dev.Entity.CODE}: WMS未返回结果");
  38. DB.Do(db =>
  39. {
  40. var task = db.Default.Set<WCS_TASK>().FirstOrDefault(v => v.ID == dev.Data2.Tasknum);
  41. if(task == null) throw new Exception($"任务号不存在");
  42. dev.Data.Tasknum = dev.Data2.Tasknum;
  43. dev.Data.Goodsnum = res.Root.ToShort();
  44. if (dev.Entity.CODE == "3163")
  45. {
  46. dev.Data.Goodsend = Device.Find(task.ADDRNEXT).GetPath("SRM").CODE.ToShort();
  47. }
  48. dev.Data.VoucherNo++;
  49. if (dev.Entity.CODE == "3163")
  50. {
  51. InfoLog.INFO_INFO($"[{dev.Entity.CODE}]写入信息:[{dev.Data2.Tasknum}]-[{dev.Data.VoucherNo}]");
  52. }
  53. });
  54. }
  55. protected override bool SelectDevice(WCS_DEVICE dev)
  56. {
  57. return new string[] { "3047","3163" }.Contains(dev.CODE);
  58. }
  59. }
  60. }