TaskBookBehavior_63005.cs 2.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677
  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_63005 : BaseTaskBookBehaviorV2
  14. {
  15. LocationPropertyManager locationManager = new LocationPropertyManager();
  16. public TaskBookBehavior_63005() : base(63005, "库位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. int dotCount = data.ScanMessage.Count(d => d == ',');
  40. if (dotCount != 4)
  41. {
  42. Log(taskDetailInfo, stepInfo, $"扫码数据格式检查失败 {data.ScanMessage}");
  43. return false;
  44. }
  45. string[] barcodeArr = data.ScanMessage.Split(',');
  46. var locationData = locationManager.GetById(stepInfo.WareHouseID);
  47. if (locationData == null)
  48. {
  49. Log(taskDetailInfo, stepInfo, $"查询库位数据失败 {stepInfo.WareHouseID}");
  50. return false;
  51. }
  52. locationData.MaterialBarcode = barcodeArr[0];
  53. locationData.MaterialId = barcodeArr[1];
  54. locationData.BatchNumber = barcodeArr[2];
  55. locationData.MaterialNumber = barcodeArr[3];
  56. bool result = locationManager.Update(locationData);
  57. Log(taskDetailInfo, stepInfo, $"更新库位AGV扫码{result.ToChineseString()} {data.ScanMessage}");
  58. return result;
  59. }
  60. catch (Exception ex)
  61. {
  62. LogException(ex);
  63. }
  64. return false;
  65. }
  66. }
  67. }