CtrlAdRes.cs 7.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191
  1. using DevExpress.CodeParser;
  2. using DevExpress.Diagram.Core.Shapes;
  3. using DevExpress.Map.Dashboard;
  4. using DW5S.DTO;
  5. using DW5S.Entity;
  6. using DW5S.Repostory;
  7. using DW5S.ViewModel;
  8. using DxHelper;
  9. using ExtensionsDev;
  10. using Microsoft.EntityFrameworkCore;
  11. using System;
  12. using System.Collections.Generic;
  13. using System.ComponentModel;
  14. using System.Data;
  15. using System.Drawing;
  16. using System.Linq;
  17. using System.Text;
  18. using System.Threading.Tasks;
  19. using System.Windows.Forms;
  20. using XdCxRhDW5S.ViewModel;
  21. namespace DW5S.App.UserControl
  22. {
  23. public partial class CtrlAdRes : DevExpress.XtraEditors.XtraUserControl
  24. {
  25. List<ADResViewModel> list = new List<ADResViewModel>();
  26. public CtrlAdRes()
  27. {
  28. InitializeComponent();
  29. this.layoutControl1.UseDefault();
  30. }
  31. private async Task<IEnumerable<SatViewModel>> GetAllSat()
  32. {
  33. var unitOfWork = IocContainer.UnitOfWork;
  34. var repsXl = unitOfWork.Of<XlInfo>() as XlRepository;
  35. var list = await repsXl.GetAllSat();
  36. return list.To<List<SatViewModel>>();
  37. }
  38. private async void CtrlAdRes_Load(object sender, EventArgs e)
  39. {
  40. try
  41. {
  42. ctrlPage.SetOnQuery(LoadPageData);
  43. txtSigStartTime.UseDefault();
  44. txtSigEndTime.UseDefault();
  45. gridAdRes.UseDefault(list, showScrollH: true).UseEmptyText("无结果").UseMultiSelect().UseRowNumber().UseDeleteAsync<AdRes>(DelAd);
  46. List<SatInfo> satList = new List<SatInfo>();
  47. var unitOfWork = IocContainer.UnitOfWork;
  48. var repsSat = unitOfWork.Of<SatInfo>();
  49. satList.AddRange(await repsSat.GetAllAsync(p => p.UpdateTime));
  50. this.txtSat.UseDefault().SetData(GetAllSat, nameof(SatViewModel.Sat)).UseDoubleClickToSelectAll();
  51. }
  52. catch (Exception ex)
  53. {
  54. string msg = "查询采集结果异常";
  55. IocContainer.Logger.Error(ex, msg);
  56. DxHelper.MsgBoxHelper.ShowError(msg);
  57. }
  58. }
  59. private async Task<bool> DelAd(List<AdRes> selectedRes)
  60. {
  61. try
  62. {
  63. var unitOfWork = IocContainer.UnitOfWork;
  64. var repsAd = unitOfWork.OfLong<AdRes>();
  65. var count = await repsAd.DeleteAsync(selectedRes);
  66. await unitOfWork.SaveAsync();
  67. ctrlPage.RefreshData();
  68. IocContainer.Logger.Information($"删除选中参估结果,共删除了{count}条参估结果记录");
  69. return true;
  70. }
  71. catch (Exception ex)
  72. {
  73. string msg = "删除采集结果异常";
  74. IocContainer.Logger.Error(ex, msg);
  75. DxHelper.MsgBoxHelper.ShowError(msg);
  76. return false;
  77. }
  78. }
  79. private void txtTimeCho_SelectedIndexChanged(object sender, EventArgs e)
  80. {
  81. switch (txtTimeCho.Text)
  82. {
  83. case "最近1小时":
  84. case "最近6小时":
  85. case "最近12小时":
  86. case "最近1天":
  87. case "最近3天":
  88. itemStart.Visibility = DevExpress.XtraLayout.Utils.LayoutVisibility.Never;
  89. itemEnd.Visibility = DevExpress.XtraLayout.Utils.LayoutVisibility.Never;
  90. break;
  91. case "自定义":
  92. itemStart.Visibility = DevExpress.XtraLayout.Utils.LayoutVisibility.Always;
  93. itemEnd.Visibility = DevExpress.XtraLayout.Utils.LayoutVisibility.Always;
  94. break;
  95. }
  96. }
  97. private void btnQuery_Click(object sender, EventArgs e)
  98. {
  99. if (txtSat.EditValue == null)
  100. {
  101. MsgBoxHelper.ShowError("请选择卫星");
  102. return;
  103. }
  104. if (txtTimeCho.SelectedText == "自定义")
  105. {
  106. if (txtSigStartTime.EditValue == null)
  107. {
  108. DxHelper.MsgBoxHelper.ShowError($"请选择信号开始时间!");
  109. return;
  110. }
  111. if (txtSigEndTime.EditValue == null)
  112. {
  113. DxHelper.MsgBoxHelper.ShowError($"请选择信号结束时间!");
  114. return;
  115. }
  116. if (txtSigStartTime.DateTime > txtSigEndTime.DateTime)
  117. {
  118. DxHelper.MsgBoxHelper.ShowError($"开始时间不能大于结束时间!");
  119. return;
  120. }
  121. if ((txtSigEndTime.DateTime - txtSigStartTime.DateTime).TotalDays > 10)
  122. {
  123. MsgBoxHelper.ShowWarning("时间跨度不能超过10天!");
  124. return;
  125. }
  126. }
  127. ctrlPage.RefreshData();
  128. }
  129. private async Task<PageData> LoadPageData(PageQueryDto arg)
  130. {
  131. var unitOfWork = IocContainer.UnitOfWork;
  132. var repsAd = unitOfWork.OfLong<AdRes>();
  133. var queryable = repsAd.AsQueryable();
  134. int? satCode = ((SatViewModel)txtSat.EditValue)?.SatCode;
  135. try
  136. {
  137. DateTime start = DateTime.MinValue;
  138. DateTime end = DateTime.MinValue;
  139. if (satCode != null)
  140. {
  141. queryable = queryable.Where(p => p.SatCode == satCode);
  142. }
  143. if (txtTimeCho.Text == "自定义")
  144. {
  145. start = txtSigStartTime.DateTime;
  146. end = txtSigEndTime.DateTime;
  147. }
  148. else
  149. {
  150. var max = queryable.OrderByDescending(p => p.SigTime).FirstOrDefault();
  151. if (max != null)
  152. {
  153. end = max.SigTime;
  154. start = end.AddHours(-Convert.ToInt32(txtTimeCho.EditValue));
  155. }
  156. }
  157. if (start != DateTime.MinValue)
  158. {
  159. queryable = queryable.Where(w => w.SigTime >= start);
  160. }
  161. if (end != DateTime.MinValue)
  162. {
  163. queryable = queryable.Where(w => w.SigTime <= end);
  164. }
  165. queryable = queryable
  166. .OrderByDescending(o => o.SigTime)
  167. .ThenBy(p => p.SatCode);
  168. }
  169. catch (TaskCanceledException) { }
  170. catch (Exception ex)
  171. {
  172. string msg = "参估结果查询异常";
  173. IocContainer.Logger.Error(ex, msg);
  174. MsgBoxHelper.ShowError(msg);
  175. }
  176. var pageData = await repsAd.GetPageData(arg, queryable);
  177. list.Clear();
  178. list.AddRange(pageData.Data.To<List<ADResViewModel>>());
  179. gridView.RefreshData();
  180. gridView.BestFitColumns();
  181. return pageData;
  182. }
  183. }
  184. }