StatisticsViewModel.cs 6.7 KB

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