CtrlRefTask.cs 9.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237
  1. using DevExpress.Mvvm.Native;
  2. using DevExpress.XtraBars.Customization;
  3. using DevExpress.XtraGrid.Views.Grid;
  4. using DW5S.App.EditForms;
  5. using DW5S.Entity;
  6. using DW5S.Repostory;
  7. using DW5S.ViewModel;
  8. using DxHelper;
  9. using ExtensionsDev;
  10. using Google.Protobuf.WellKnownTypes;
  11. using Microsoft.EntityFrameworkCore;
  12. using System;
  13. using System.Collections.Generic;
  14. using System.Drawing;
  15. using System.Linq;
  16. using System.Threading.Tasks;
  17. using System.Windows.Forms;
  18. using System.Linq.Expressions;
  19. using Microsoft.EntityFrameworkCore.Query;
  20. namespace DW5S.App.UserControl
  21. {
  22. public partial class CtrlRefTask : DevExpress.XtraEditors.XtraUserControl
  23. {
  24. readonly List<RefTaskViewModel> list = new List<RefTaskViewModel>();
  25. public CtrlRefTask()
  26. {
  27. InitializeComponent();
  28. }
  29. private async void CtrlRefTask_Load(object sender, EventArgs e)
  30. {
  31. try
  32. {
  33. gridRefTask.UseDefault(list).UseMultiSelect().UseRowNumber()
  34. .UseAddAsync(Add)
  35. .UseEditAsync<RefTaskViewModel>(Edit)
  36. .UseDeleteAsync<RefTaskViewModel>(Delete)
  37. .AddContentMenu<RefTaskViewModel>("一键启用", SvgHelper.CreateCycle("#2E8B57"), async data =>
  38. {
  39. try
  40. {
  41. var ids = data.Select(p => p.Id);
  42. var unitOfWork = IocContainer.UnitOfWork;
  43. var reps = unitOfWork.OfLong<RefTaskFreq>();
  44. await reps.UpdatePropAsync(p => ids.Contains(p.Id), s => s.SetProperty(b => b.Enable, true));
  45. await unitOfWork.SaveAsync();
  46. data.ForEach(d => d.Enable = true);
  47. gridView1.RefreshData();
  48. gridView1.BestFitColumns();
  49. DxHelper.MsgBoxHelper.ShowInfo("一键启用成功!");
  50. }
  51. catch (Exception ex)
  52. {
  53. IocContainer.Logger.Error(ex, "一键启用异常");
  54. DxHelper.MsgBoxHelper.ShowError("一键启用异常");
  55. }
  56. }, false)
  57. .AddContentMenu<RefTaskViewModel>("一键禁用", SvgHelper.CreateCycle("#FF0000"), async data =>
  58. {
  59. try
  60. {
  61. var ids = data.Select(p => p.Id);
  62. var unitOfWork = IocContainer.UnitOfWork;
  63. var reps = unitOfWork.OfLong<RefTaskFreq>();
  64. await reps.UpdatePropAsync(p => ids.Contains(p.Id), s => s.SetProperty(b => b.Enable, false));
  65. await unitOfWork.SaveAsync();
  66. data.ForEach(d => d.Enable = false);
  67. gridView1.RefreshData();
  68. gridView1.BestFitColumns();
  69. DxHelper.MsgBoxHelper.ShowInfo("一键禁用成功!");
  70. }
  71. catch (Exception ex)
  72. {
  73. IocContainer.Logger.Error(ex, "一键禁用异常");
  74. DxHelper.MsgBoxHelper.ShowError("一键禁用异常");
  75. }
  76. }, false);
  77. List<TxInfo> refTxList = new List<TxInfo>();
  78. var unitOfWork = IocContainer.UnitOfWork;
  79. var items = await unitOfWork.OfLong<RefTaskFreq>().AsQueryable()
  80. .Include(r => r.SampleInfo)
  81. .Include(r => r.SampleInfo.SigInfo)
  82. .Include(r => r.SampleInfo.RefTxInfo)
  83. .Include(r => r.SatInfo).OrderBy(p => p.Enable).ThenBy(p=>p.SampleInfo.SigInfo.FreqDownHz).ToListAsync();
  84. list.AddRange(items.To<List<RefTaskViewModel>>());
  85. refTxList = await unitOfWork.Of<TxInfo>().AsQueryable()
  86. .Where(t => t.TxType == EnumTxType.Ref)
  87. .OrderByDescending(p => p.UpdateTime).ToListAsync();
  88. this.txtRef.UseDefault(showClearBtn: true).SetData(refTxList.To<List<RefTxViewModel>>(), displayField: nameof(RefTxViewModel.Name)).UseDoubleClickToSelectAll();
  89. }
  90. catch (Exception ex)
  91. {
  92. IocContainer.Logger.Error(ex, "查询参考任务信息异常");
  93. DxHelper.MsgBoxHelper.ShowError("查询参考任务信息异常");
  94. }
  95. }
  96. private async Task<RefTaskViewModel> Add()
  97. {
  98. try
  99. {
  100. RefTaskFreqEditor frm = new RefTaskFreqEditor();
  101. if (frm.ShowDialog() != DialogResult.OK) return null;
  102. var addItem = frm.info;
  103. var unitOfWork = IocContainer.UnitOfWork;
  104. var addRefTaskFreq = await unitOfWork.OfLong<RefTaskFreq>().AddOrUpdateAsync(new RefTaskFreq
  105. {
  106. SampleInfoID = addItem.SampleInfoID,
  107. SatInfoID = addItem.SatInfoID,
  108. CalcCycle = addItem.CalccCycle,
  109. Snr0 = addItem.Snr,
  110. DtoCenterus = addItem.DtoCenterus,
  111. DtoRangeus = addItem.DtoRangeus,
  112. SampleLen = addItem.SampleLen,
  113. Enable = addItem.Enable,
  114. UpdateTime = DateTime.Now,
  115. });
  116. await unitOfWork.SaveAsync();
  117. addItem.Id = addRefTaskFreq.Id;
  118. return addItem;
  119. }
  120. catch (Exception ex)
  121. {
  122. IocContainer.Logger.Error(ex, "添加参考任务信息异常");
  123. DxHelper.MsgBoxHelper.ShowError("添加参考任务信息异常");
  124. return null;
  125. }
  126. }
  127. private async Task<RefTaskViewModel> Edit(RefTaskViewModel editItem)
  128. {
  129. try
  130. {
  131. RefTaskFreqEditor frm = new RefTaskFreqEditor(editItem);
  132. if (frm.ShowDialog() != DialogResult.OK) return null;
  133. editItem = frm.info;
  134. var unitOfWork = IocContainer.UnitOfWork;
  135. var edit = editItem.To<RefTaskFreq>();
  136. edit.SampleInfo = null;
  137. edit.SatInfo = null;
  138. edit.UpdateTime = DateTime.Now;
  139. await unitOfWork.OfLong<RefTaskFreq>().AddOrUpdateAsync(edit);
  140. await unitOfWork.SaveAsync();
  141. return editItem;
  142. }
  143. catch (Exception ex)
  144. {
  145. IocContainer.Logger.Error(ex, "保存参考任务信息异常");
  146. DxHelper.MsgBoxHelper.ShowError("保存参考任务信息异常");
  147. return null;
  148. }
  149. }
  150. private async Task<bool> Delete(List<RefTaskViewModel> list)
  151. {
  152. try
  153. {
  154. var unitOfWork = IocContainer.UnitOfWork;
  155. await unitOfWork.OfLong<RefTaskFreq>().DeleteAsync(list.To<List<RefTaskFreq>>());
  156. await unitOfWork.SaveAsync();
  157. return true;
  158. }
  159. catch (Exception ex)
  160. {
  161. IocContainer.Logger.Error(ex, "删除参考任务信息异常");
  162. DxHelper.MsgBoxHelper.ShowError("删除参考任务信息异常");
  163. return false;
  164. }
  165. }
  166. private async void gridView1_DoubleClick(object sender, EventArgs e)
  167. {
  168. var editItem = gridView1.GetFocusedRow() as RefTaskViewModel;
  169. if (editItem == null) return;
  170. await Edit(editItem);
  171. }
  172. private void gridView1_CustomDrawCell(object sender, DevExpress.XtraGrid.Views.Base.RowCellCustomDrawEventArgs e)
  173. {
  174. GridView view = sender as GridView;
  175. if (e.Column == view.Columns["IsEnable"])
  176. {
  177. string status = view.GetRowCellValue(e.RowHandle, view.Columns["IsEnable"]) as string;
  178. if (status == "启用")
  179. {
  180. e.Appearance.BackColor = Color.LightGreen; // 设置为绿色背景,表示活跃状态
  181. }
  182. else if (status == "禁用")
  183. {
  184. e.Appearance.BackColor = Color.LightCoral; // 设置为淡红色背景,表示非活跃状态
  185. }
  186. }
  187. }
  188. private async void btnSerach_Click(object sender, EventArgs e)
  189. {
  190. try
  191. {
  192. var reftxInfo = (txtRef.EditValue as RefTxViewModel);
  193. var unitOfWork = IocContainer.UnitOfWork;
  194. var query = unitOfWork.OfLong<RefTaskFreq>().AsQueryable();
  195. if (reftxInfo != null)
  196. {
  197. query.Where(r => r.SampleInfo.TxInfoID == reftxInfo.Id);
  198. }
  199. var items = await query
  200. .Include(r => r.SampleInfo.SigInfo)
  201. .Include(r => r.SampleInfo.RefTxInfo)
  202. .Include(r => r.SatInfo)
  203. .OrderBy(p => p.Enable).ToListAsync();
  204. list.Clear();
  205. list.AddRange(items.To<List<RefTaskViewModel>>());
  206. gridView1.RefreshData();
  207. }
  208. catch (Exception ex)
  209. {
  210. IocContainer.Logger.Error(ex, "查询参考任务信息异常");
  211. DxHelper.MsgBoxHelper.ShowError("查询参考任务信息异常");
  212. }
  213. }
  214. }
  215. }