CtrlRefTask.cs 9.5 KB

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