CtrlRefTask.cs 8.7 KB

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