MesWorkspace.cs 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193
  1. using LocalhostMES.Core;
  2. using LocalhostMES.DataBase;
  3. using LocalhostMES.Models;
  4. using Prism.Mvvm;
  5. using System;
  6. using System.Collections.Generic;
  7. using System.Collections.ObjectModel;
  8. using System.Linq;
  9. using System.Threading.Tasks;
  10. using System.Windows;
  11. using System.Windows.Media;
  12. namespace LocalhostMES.ViewModels.Services
  13. {
  14. public sealed class MesWorkspace : BindableBase, IMesWorkspace
  15. {
  16. private LogHelper.LogChangHandler _logHandler;
  17. private bool _initialized;
  18. private string _statusLine;
  19. private Brush _statusForeground = Brushes.Green;
  20. private int _selectedTabIndex = 0;
  21. private string _crossPageSn;
  22. public Management MesManagement => Management.GetManagement();
  23. public ObservableCollection<WorkOrderInfo> WorkOrders { get; } = new ObservableCollection<WorkOrderInfo>();
  24. public ObservableCollection<string> Logs { get; } = new ObservableCollection<string>();
  25. public string StatusLine
  26. {
  27. get => _statusLine;
  28. private set => SetProperty(ref _statusLine, value);
  29. }
  30. public Brush StatusForeground
  31. {
  32. get => _statusForeground;
  33. private set => SetProperty(ref _statusForeground, value);
  34. }
  35. public int SelectedTabIndex
  36. {
  37. get => _selectedTabIndex;
  38. set => SetProperty(ref _selectedTabIndex, value);
  39. }
  40. public string CrossPageSn
  41. {
  42. get => _crossPageSn;
  43. set => SetProperty(ref _crossPageSn, value);
  44. }
  45. public void Initialize()
  46. {
  47. if (_initialized)
  48. {
  49. return;
  50. }
  51. _initialized = true;
  52. DatabaseHelper.CreataDataTable();
  53. ReloadWorkOrders();
  54. EnsureOrderNotifyClient();
  55. _logHandler = msg =>
  56. {
  57. Application.Current?.Dispatcher.Invoke(() =>
  58. {
  59. Logs.Add($"[{DateTime.Now:HH:mm:ss}] {msg}\n");
  60. });
  61. };
  62. LogHelper.logChangHandler += _logHandler;
  63. }
  64. public void Shutdown()
  65. {
  66. if (MesManagement.WorkOrderNotifyTcpClient != null)
  67. {
  68. MesManagement.WorkOrderNotifyTcpClient.MessageReceived -= OnOrderNotifyMessage;
  69. MesManagement.WorkOrderNotifyTcpClient.LogReceived -= OnOrderNotifyLog;
  70. MesManagement.WorkOrderNotifyTcpClient.Dispose();
  71. MesManagement.WorkOrderNotifyTcpClient = null;
  72. }
  73. if (_logHandler != null)
  74. {
  75. LogHelper.logChangHandler -= _logHandler;
  76. _logHandler = null;
  77. }
  78. }
  79. public void ReloadWorkOrders()
  80. {
  81. WorkOrders.Clear();
  82. foreach (var w in DatabaseHelper.SelectWorkOrderInfo())
  83. {
  84. WorkOrders.Add(w);
  85. }
  86. }
  87. public void ShowStatus(string message, bool isError)
  88. {
  89. Application.Current?.Dispatcher.Invoke(() =>
  90. {
  91. StatusLine = message;
  92. StatusForeground = isError ? Brushes.Red : Brushes.Green;
  93. });
  94. }
  95. private void EnsureOrderNotifyClient()
  96. {
  97. if (MesManagement.WorkOrderNotifyTcpClient != null)
  98. {
  99. return;
  100. }
  101. var client = new WorkOrderNotifyTcpClient("127.0.0.1", 9000);
  102. client.MessageReceived += OnOrderNotifyMessage;
  103. client.LogReceived += OnOrderNotifyLog;
  104. MesManagement.WorkOrderNotifyTcpClient = client;
  105. Task.Run(async () =>
  106. {
  107. try
  108. {
  109. await client.ConnectAsync();
  110. }
  111. catch (Exception ex)
  112. {
  113. ShowStatus($"TCP客户端连接失败: {ex.Message}", true);
  114. }
  115. });
  116. }
  117. private void OnOrderNotifyLog(string message)
  118. {
  119. Application.Current?.Dispatcher.Invoke(() =>
  120. {
  121. Logs.Add($"[{DateTime.Now:HH:mm:ss}] {message}\n");
  122. });
  123. }
  124. private async void OnOrderNotifyMessage(string message)
  125. {
  126. if (string.IsNullOrWhiteSpace(message))
  127. {
  128. return;
  129. }
  130. if (!message.StartsWith("OrderRef|", StringComparison.OrdinalIgnoreCase))
  131. {
  132. return;
  133. }
  134. try
  135. {
  136. var httpHelper = MesManagement.ApiClient;
  137. if (httpHelper == null)
  138. {
  139. ShowStatus("未配置API客户端,无法自动刷新工单", true);
  140. return;
  141. }
  142. ApiResponse<List<WorkOrderInfo>> apiResponse = await httpHelper.GetWorkOrdersAsync();
  143. if (!apiResponse.success)
  144. {
  145. return;
  146. }
  147. if (apiResponse.data == null || apiResponse.data.Count == 0)
  148. {
  149. return;
  150. }
  151. MesManagement.GetOrderInfo = apiResponse.data;
  152. foreach (var item in apiResponse.data.Where(it => !string.IsNullOrWhiteSpace(it.WorkOrderNo)))
  153. {
  154. if (!DatabaseHelper.UpdateWorkOrderInfo(item))
  155. {
  156. DatabaseHelper.InsertWorkOrderInfo(item);
  157. }
  158. }
  159. ReloadWorkOrders();
  160. ShowStatus($"收到{message},工单已自动刷新", false);
  161. }
  162. catch
  163. {
  164. }
  165. }
  166. }
  167. }