CtrlRefCgRes.cs 7.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211
  1. using DW5S.DTO;
  2. using DW5S.Entity;
  3. using DW5S.Repostory;
  4. using DW5S.ViewModel;
  5. using DxHelper;
  6. using ExtensionsDev;
  7. using Microsoft.EntityFrameworkCore;
  8. using System;
  9. using System.Collections.Generic;
  10. using System.Diagnostics;
  11. using System.IO;
  12. using System.Linq;
  13. using System.Threading.Tasks;
  14. using XdCxRhDW5S.ViewModel;
  15. namespace DW5S.App.UserControl
  16. {
  17. public partial class CtrlRefCgRes : DevExpress.XtraEditors.XtraUserControl
  18. {
  19. List<RefCgResViewModel> list = new List<RefCgResViewModel>();
  20. public CtrlRefCgRes()
  21. {
  22. InitializeComponent();
  23. this.layoutControl1.UseDefault();
  24. this.ctrlPage1.Compact = false;
  25. this.ctrlPage1.AlignRight = true;
  26. this.ctrlPage1.ShowGoto = true;
  27. }
  28. private async void CtrlRefCgRes_Load(object sender, EventArgs e)
  29. {
  30. try
  31. {
  32. ctrlPage1.SetOnQuery(LoadPageData);
  33. txtStartTime.UseDefault();
  34. txtEndTime.UseDefault();
  35. gridCg.UseDefault(list).UseMultiSelect().UseRowNumber().UseDeleteAsync<RefCgResViewModel>(DelCg);
  36. List<SatInfo> satList = new List<SatInfo>();
  37. var unitOfWork = IocContainer.UnitOfWork;
  38. var repsSat = unitOfWork.Of<SatInfo>();
  39. satList.AddRange(await repsSat.GetAllAsync(p => p.UpdateTime));
  40. this.txtSat.UseDefault(showClearBtn: true).SetData(satList.To<List<SatViewModel>>(), displayField: nameof(SatViewModel.Sat)).UseDoubleClickToSelectAll();
  41. }
  42. catch (Exception ex)
  43. {
  44. IocContainer.Logger.Error(ex, "查询参考参估结果异常");
  45. DxHelper.MsgBoxHelper.ShowError("查询参考参估结果异常");
  46. }
  47. }
  48. private async Task<bool> DelCg(List<RefCgResViewModel> selectedRes)
  49. {
  50. try
  51. {
  52. var unitOfWork = IocContainer.UnitOfWork;
  53. var repsCg = unitOfWork.OfLong<RefCgRes>();
  54. var count = await repsCg.DeleteAsync(selectedRes.To<List<RefCgRes>>());
  55. await unitOfWork.SaveAsync();
  56. ctrlPage1.RefreshData();
  57. IocContainer.Logger.Information($"删除选中参考参估结果,共删除了{count}条参考参估结果记录");
  58. return true;
  59. }
  60. catch (Exception ex)
  61. {
  62. IocContainer.Logger.Error(ex, "删除参考参估结果异常");
  63. DxHelper.MsgBoxHelper.ShowError("删除参考参估结果异常");
  64. return false;
  65. }
  66. }
  67. private void txtTimeCho_SelectedIndexChanged(object sender, EventArgs e)
  68. {
  69. switch (txtTimeCho.Text)
  70. {
  71. case "最近1小时":
  72. case "最近6小时":
  73. case "最近12小时":
  74. case "最近1天":
  75. case "最近3天":
  76. itemStart.Visibility = DevExpress.XtraLayout.Utils.LayoutVisibility.Never;
  77. itemEnd.Visibility = DevExpress.XtraLayout.Utils.LayoutVisibility.Never;
  78. break;
  79. case "自定义":
  80. itemStart.Visibility = DevExpress.XtraLayout.Utils.LayoutVisibility.Always;
  81. itemEnd.Visibility = DevExpress.XtraLayout.Utils.LayoutVisibility.Always;
  82. break;
  83. }
  84. }
  85. private void btnSearch_Click(object sender, EventArgs e)
  86. {
  87. if (txtTimeCho.SelectedText == "自定义")
  88. {
  89. if (txtStartTime.EditValue == null)
  90. {
  91. DxHelper.MsgBoxHelper.ShowError($"请选择信号开始时间!");
  92. return;
  93. }
  94. if (txtEndTime.EditValue == null)
  95. {
  96. DxHelper.MsgBoxHelper.ShowError($"请选择信号结束时间!");
  97. return;
  98. }
  99. if (txtStartTime.DateTime > txtEndTime.DateTime)
  100. {
  101. DxHelper.MsgBoxHelper.ShowError($"开始时间不能大于结束时间!");
  102. return;
  103. }
  104. if ((txtEndTime.DateTime - txtStartTime.DateTime).TotalDays > 10)
  105. {
  106. MsgBoxHelper.ShowWarning("时间跨度不能超过10天!");
  107. return;
  108. }
  109. }
  110. ctrlPage1.RefreshData();
  111. }
  112. private async Task<PageData> LoadPageData(PageQueryDto arg)
  113. {
  114. int? satId = ((SatViewModel)txtSat.EditValue)?.Id;
  115. var unitOfWork = IocContainer.UnitOfWork;
  116. var repsCg = unitOfWork.OfLong<RefCgRes>();
  117. var queryable = repsCg.AsQueryable();
  118. try
  119. {
  120. DateTime start = DateTime.MinValue;
  121. DateTime end = DateTime.MinValue;
  122. if (satId!=null)
  123. {
  124. queryable = queryable.Where(p => p.SatInfoID == satId);
  125. }
  126. if (txtTimeCho.Text == "自定义")
  127. {
  128. start = txtStartTime.DateTime;
  129. end = txtEndTime.DateTime;
  130. }
  131. else
  132. {
  133. var max = queryable.OrderByDescending(p => p.FileTime).FirstOrDefault();
  134. if (max != null)
  135. {
  136. end = max.FileTime;
  137. start = end.AddHours(-(int)txtTimeCho.EditValue);
  138. }
  139. }
  140. if (start != DateTime.MinValue)
  141. {
  142. queryable = queryable.Where(w => w.FileTime >= start);
  143. }
  144. if (end != DateTime.MinValue)
  145. {
  146. queryable = queryable.Where(w => w.FileTime <= end);
  147. }
  148. queryable = queryable
  149. .Include(w => w.SatInfo)
  150. .Include(w => w.RefTxInfo)
  151. .OrderByDescending(o => o.FileTime)
  152. .ThenBy(p => p.SatInfo.SatCode);
  153. }
  154. catch (Exception ex)
  155. {
  156. IocContainer.Logger.Error(ex, "参考参估结果查询异常");
  157. MsgBoxHelper.ShowError("参考参估结果查询异常");
  158. }
  159. var pageData = await repsCg.GetPageData(arg, queryable);
  160. list.Clear();
  161. list.AddRange(pageData.Data.To<List<RefCgResViewModel>>());
  162. gridView1.RefreshData();
  163. gridView1.BestFitColumns();
  164. return pageData;
  165. }
  166. private void btnDraw_Click(object sender, EventArgs e)
  167. {
  168. try
  169. {
  170. var exeFile = AppConfigHelper.Get("CgDrawExe");
  171. if (string.IsNullOrWhiteSpace(exeFile))
  172. {
  173. MsgBoxHelper.ShowError("请在平台配置文件中设置绘图程序路径CgDrawExe");
  174. return;
  175. }
  176. if (!File.Exists(exeFile))
  177. {
  178. MsgBoxHelper.ShowError($"找不到绘图程序[{exeFile}]");
  179. return;
  180. }
  181. FileInfo f = new FileInfo(exeFile);
  182. var dir = Path.GetDirectoryName(f.FullName);
  183. List<CgRes> data = gridView1.DataController.GetAllFilteredAndSortedRows().OfType<CgRes>().ToList();
  184. var file = data.ToCsvFile($"{dir}\\CgDraw{DateTime.Now:yyyyMMddHHmmss}.csv");
  185. Process.Start(new ProcessStartInfo()
  186. {
  187. FileName = f.FullName,
  188. Arguments = file,
  189. });
  190. }
  191. catch (Exception ex)
  192. {
  193. IocContainer.Logger.Error(ex, "参考参估绘图异常");
  194. }
  195. }
  196. }
  197. }