StatisticsViewModel.cs 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Collections.ObjectModel;
  4. using System.Data;
  5. using System.Linq;
  6. using System.Windows;
  7. using Aitex.Core.RT.Log;
  8. using MECF.Framework.Common.CommonData;
  9. using MECF.Framework.Common.DataCenter;
  10. using MECF.Framework.Common.OperationCenter;
  11. using OpenSEMI.ClientBase;
  12. using SciChart.Core.Extensions;
  13. using Virgo_DUI.Client.Models.Sys;
  14. namespace Virgo_DUI.Client.Models.History.Statistics
  15. {
  16. public class StatsDataListItem:NotifiableItem
  17. {
  18. public string Name { get; set; }
  19. public string Value { get; set; }
  20. public string Description { get; set; }
  21. public string Total { get; set; }
  22. public string LastUpdateTime { get; set; }
  23. public string LastResetTime { get; set; }
  24. public string LastResetTotalTime { get; set; }
  25. public string AlarmValue { get; set; }
  26. public string AlarmValueSetPoint { get; set; }
  27. public bool AlarmEnable { get; set; }
  28. public bool AlarmTextSaved { get; set; }
  29. public bool IsVisible { get; set; }
  30. }
  31. public class StatisticsViewModel : UiViewModelBase
  32. {
  33. public ObservableCollection<StatsDataListItem> StatData { get; set; }
  34. protected override void OnInitialize()
  35. {
  36. StatData = new ObservableCollection<StatsDataListItem>();
  37. base.OnInitialize();
  38. }
  39. protected override void OnActivate()
  40. {
  41. base.OnActivate();
  42. }
  43. protected override void OnDeactivate(bool close)
  44. {
  45. base.OnDeactivate(close);
  46. }
  47. protected override void Poll()
  48. {
  49. try
  50. {
  51. string sql = $"SELECT * FROM \"stats_data\" order by \"name\" ASC;";
  52. DataTable dbData = QueryDataClient.Instance.Service.QueryData(sql);
  53. Application.Current.Dispatcher.BeginInvoke(new Action(() =>
  54. {
  55. if (dbData == null || dbData.Rows.Count == 0)
  56. return;
  57. string[] clearedNameList = Array.ConvertAll<StatsDataListItem, string>(StatData.ToArray(), x => x.Name);
  58. List<string> removableList = new List<string>();
  59. if (clearedNameList.Length > 0)
  60. removableList = clearedNameList.ToList();
  61. for (int i = 0; i < dbData.Rows.Count; i++)
  62. {
  63. if (!dbData.Rows[i]["is_visible"].Equals(DBNull.Value) && !Convert.ToBoolean(dbData.Rows[i]["is_visible"].ToString()))
  64. continue;
  65. string name = dbData.Rows[i]["name"].ToString();
  66. removableList.RemoveIfContains(name);
  67. StatsDataListItem item = StatData.FirstOrDefault(x => x.Name == name);
  68. if (item == null)
  69. {
  70. item = new StatsDataListItem();
  71. item.Name = dbData.Rows[i]["name"].ToString();
  72. item.AlarmEnable = false;
  73. item.IsVisible = true;
  74. item.AlarmTextSaved = true;
  75. item.AlarmValueSetPoint = dbData.Rows[i]["alarm_value"].ToString();
  76. StatData.Add(item);
  77. }
  78. item.Description = dbData.Rows[i]["description"].ToString();
  79. item.Value = dbData.Rows[i]["value"].ToString();
  80. item.Total = dbData.Rows[i]["total"].ToString();
  81. if (!dbData.Rows[i]["enable_alarm"].Equals(DBNull.Value))
  82. item.AlarmEnable = Convert.ToBoolean(dbData.Rows[i]["enable_alarm"].ToString());
  83. item.AlarmValue = dbData.Rows[i]["alarm_value"].ToString();
  84. if (!dbData.Rows[i]["last_update_time"].Equals(DBNull.Value))
  85. item.LastUpdateTime = ((DateTime)dbData.Rows[i]["last_update_time"]).ToString("yyyy-MM-dd HH:mm:ss.fff");
  86. if (!dbData.Rows[i]["last_reset_time"].Equals(DBNull.Value))
  87. item.LastResetTime = ((DateTime)dbData.Rows[i]["last_reset_time"]).ToString("yyyy-MM-dd HH:mm:ss.fff");
  88. if (!dbData.Rows[i]["last_total_reset_time"].Equals(DBNull.Value))
  89. item.LastResetTotalTime = ((DateTime)dbData.Rows[i]["last_total_reset_time"]).ToString("yyyy-MM-dd HH:mm:ss.fff");
  90. item.InvokePropertyChanged(nameof(item.AlarmValue));
  91. item.InvokePropertyChanged(nameof(item.Value));
  92. item.InvokePropertyChanged(nameof(item.Total));
  93. item.InvokePropertyChanged(nameof(item.LastUpdateTime));
  94. item.InvokePropertyChanged(nameof(item.LastResetTime));
  95. item.InvokePropertyChanged(nameof(item.LastResetTotalTime));
  96. }
  97. foreach (var name in removableList)
  98. {
  99. StatsDataListItem item = StatData.FirstOrDefault(x => x.Name == name);
  100. if (item != null)
  101. StatData.Remove(item);
  102. }
  103. }));
  104. }
  105. catch (Exception e)
  106. {
  107. LOG.Write(e);
  108. }
  109. }
  110. public void ResetValue(StatsDataListItem item)
  111. {
  112. InvokeClient.Instance.Service.DoOperation("System.Stats.ResetValue", item.Name);
  113. }
  114. public void ResetEnableAlarm(StatsDataListItem item)
  115. {
  116. InvokeClient.Instance.Service.DoOperation("System.Stats.EnableAlarm", item.Name, item.AlarmEnable);
  117. }
  118. public void SetAlarmValue(StatsDataListItem item)
  119. {
  120. if (string.IsNullOrEmpty(item.AlarmValueSetPoint) ||
  121. !int.TryParse(item.AlarmValueSetPoint, out int setValue))
  122. {
  123. DialogBox.ShowWarning("Alarm value not valid");
  124. return;
  125. }
  126. InvokeClient.Instance.Service.DoOperation("System.Stats.SetAlarmValue", item.Name, setValue);
  127. item.AlarmTextSaved = true;
  128. item.InvokePropertyChanged(nameof(item.AlarmTextSaved));
  129. }
  130. public void ResetTotalValue(StatsDataListItem item)
  131. {
  132. InvokeClient.Instance.Service.DoOperation("System.Stats.ResetTotalValue", item.Name);
  133. }
  134. }
  135. }