CtrlRefTask.cs 9.2 KB

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