TaskBookBehavior_63004.cs 2.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465
  1. using DbCommon.BusinessCore.BaseCore;
  2. using ProjectManagementSystem.Common.Core;
  3. using ProjectManagementSystem.Common.Extenions;
  4. using ProjectManagementSystem.Common.Logger;
  5. using ProjectManagementSystem.Common.Models.Crms;
  6. using System;
  7. using System.Collections.Generic;
  8. using System.Linq;
  9. using System.Text;
  10. using System.Threading.Tasks;
  11. namespace ProjectManagementSystem.Common.TaskBookEvent
  12. {
  13. public class TaskBookBehavior_63004 : BaseTaskBookBehaviorV2
  14. {
  15. LocationPropertyManager locationManager = new LocationPropertyManager();
  16. public TaskBookBehavior_63004() : base(63004, "库位AGV扫码")
  17. {
  18. }
  19. public override bool TaskBookOperator(TaskData taskDetailInfo, StepData stepInfo)
  20. {
  21. try
  22. {
  23. int id = taskDetailInfo.Carrier;
  24. if (!DeviceControl.Instance.Communication.InfoVcuDictionary.TryGetValue(id, out var data))
  25. {
  26. Log(taskDetailInfo, stepInfo, "获取VCU扫码数据失败");
  27. return false;
  28. }
  29. if (!data.DataValid)
  30. {
  31. Log(taskDetailInfo, stepInfo, "获取VCU扫码数据超时");
  32. return false;
  33. }
  34. if (string.IsNullOrEmpty(data.ScanMessage))
  35. {
  36. Log(taskDetailInfo, stepInfo, "获取VCU扫码数据为空");
  37. return false;
  38. }
  39. var locationData = locationManager.GetById(stepInfo.WareHouseID);
  40. if (locationData == null)
  41. {
  42. Log(taskDetailInfo, stepInfo, $"查询库位数据失败 {stepInfo.WareHouseID}");
  43. return false;
  44. }
  45. locationData.MaterialId = data.ScanMessage;
  46. bool result = locationManager.Update(locationData);
  47. Log(taskDetailInfo, stepInfo, $"更新库位AGV扫码{result.ToChineseString()} {data.ScanMessage}");
  48. return result;
  49. }
  50. catch (Exception ex)
  51. {
  52. LogException(ex);
  53. }
  54. return false;
  55. }
  56. }
  57. }