CtrlTarget.cs 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134
  1. using DevExpress.Utils.About;
  2. using DevExpress.Utils.Html;
  3. using DevExpress.XtraEditors;
  4. using System;
  5. using System.Collections.Generic;
  6. using System.ComponentModel;
  7. using System.Data;
  8. using System.Drawing;
  9. using System.Linq;
  10. using System.Text;
  11. using System.Threading.Tasks;
  12. using System.Windows.Controls;
  13. using System.Windows.Documents;
  14. using System.Windows.Forms;
  15. using DW5S.App.EditForms;
  16. using DW5S.Entity;
  17. using DW5S.Repostory;
  18. namespace DW5S.App.UserControl
  19. {
  20. public partial class CtrlTarget : DevExpress.XtraEditors.XtraUserControl
  21. {
  22. readonly List<TargetInfo> list = new List<TargetInfo>();
  23. public CtrlTarget()
  24. {
  25. InitializeComponent();
  26. }
  27. private async void CtrlSat_Load(object sender, EventArgs e)
  28. {
  29. try
  30. {
  31. gridTar.UseDefault(list).UseMultiSelect().UseRowNumber()
  32. .UseAddAsync(Add).UseEditAsync<TargetInfo>(Edit).UseDeleteAsync<TargetInfo>(Del);
  33. using (RHDWContext db = new RHDWContext())
  34. {
  35. var res = db.TargetInfos.OrderBy(p => p.TargetName).OrderBy(p => p.TargetName);
  36. list.AddRange(await res.ToListAsync());
  37. }
  38. gridView1.RefreshData();
  39. }
  40. catch (Exception ex)
  41. {
  42. DW5S.Framework.LogHelper.Error("查询目标信息异常", ex);
  43. DxHelper.MsgBoxHelper.ShowError("查询目标信息异常");
  44. }
  45. }
  46. private async Task<TargetInfo> Add()
  47. {
  48. try
  49. {
  50. TargetEditor frm = new TargetEditor();
  51. if (frm.ShowDialog() != DialogResult.OK) return null;
  52. var addItem = frm.info;
  53. using (RHDWContext db = new RHDWContext())
  54. {
  55. db.TargetInfos.Add(addItem);
  56. await db.SaveChangesAsync();
  57. }
  58. return addItem;
  59. }
  60. catch (Exception ex)
  61. {
  62. DW5S.Framework.LogHelper.Error("添加目标信息异常", ex);
  63. DxHelper.MsgBoxHelper.ShowError("添加目标信息异常");
  64. return null;
  65. }
  66. }
  67. private async Task<TargetInfo> Edit(TargetInfo editItem)
  68. {
  69. try
  70. {
  71. TargetEditor frm = new TargetEditor(editItem);
  72. if (frm.ShowDialog() != DialogResult.OK) return null;
  73. editItem = frm.info;
  74. using (RHDWContext db = new RHDWContext())
  75. {
  76. var find = await db.TargetInfos.Where(p => p.ID == editItem.ID).FirstOrDefaultAsync();
  77. find.TargetName = editItem.TargetName;
  78. find.TargeColor = editItem.TargeColor;
  79. find.UpdateTime = DateTime.Now;
  80. await db.SaveChangesAsync();
  81. }
  82. return editItem;
  83. }
  84. catch (Exception ex)
  85. {
  86. DW5S.Framework.LogHelper.Error("保存目标信息异常", ex);
  87. DxHelper.MsgBoxHelper.ShowError("保存目标信息异常");
  88. return null;
  89. }
  90. }
  91. private async Task<bool> Del(List<TargetInfo> list)
  92. {
  93. try
  94. {
  95. var ids = list.Select(p => p.ID);
  96. using (RHDWContext db = new RHDWContext())
  97. {
  98. var delItems = await db.TargetInfos.Where(p => ids.Contains(p.ID)).ToListAsync();
  99. db.TargetInfos.RemoveRange(delItems);
  100. await db.SaveChangesAsync();
  101. }
  102. return true;
  103. }
  104. catch (Exception ex)
  105. {
  106. DW5S.Framework.LogHelper.Error("删除目标信息异常", ex);
  107. DxHelper.MsgBoxHelper.ShowError("删除目标信息异常");
  108. return false;
  109. }
  110. }
  111. private void gridView1_RowCellStyle(object sender, DevExpress.XtraGrid.Views.Grid.RowCellStyleEventArgs e)
  112. {
  113. if (e.CellValue == null) return;
  114. if (e.Column.FieldName == nameof(TargetInfo.TargeColor))
  115. {
  116. var clolrRes = ColorTranslator.FromHtml(e.CellValue.ToString());
  117. e.Appearance.BackColor = clolrRes;
  118. }
  119. }
  120. private async void gridView1_DoubleClick(object sender, EventArgs e)
  121. {
  122. var editItem = gridView1.GetFocusedRow() as TargetInfo;
  123. if (editItem == null) return;
  124. await Edit(editItem);
  125. }
  126. }
  127. }