CtrlTarget.cs 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126
  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.Data.Entity;
  9. using System.Drawing;
  10. using System.Linq;
  11. using System.Text;
  12. using System.Threading.Tasks;
  13. using System.Windows.Controls;
  14. using System.Windows.Documents;
  15. using System.Windows.Forms;
  16. using XdCxRhDW.App.EditForms;
  17. using XdCxRhDW.Entity;
  18. using XdCxRhDW.Repostory;
  19. namespace XdCxRhDW.App.UserControl
  20. {
  21. public partial class CtrlTarget : DevExpress.XtraEditors.XtraUserControl
  22. {
  23. readonly List<TargetInfo> list = new List<TargetInfo>();
  24. public CtrlTarget()
  25. {
  26. InitializeComponent();
  27. }
  28. private async void CtrlSat_Load(object sender, EventArgs e)
  29. {
  30. try
  31. {
  32. gridTar.UseDefault(list).UseMultiSelect().UseRowNumber()
  33. .UseAddAsync(Add).UseEditAsync<TargetInfo>(Edit).UseDeleteAsync<TargetInfo>(Del);
  34. using (RHDWContext db = new RHDWContext())
  35. {
  36. var res = db.TargetInfos.OrderBy(p => p.TargetName).OrderBy(p => p.TargetName);
  37. list.AddRange(await res.ToListAsync());
  38. }
  39. gridView1.RefreshData();
  40. }
  41. catch (Exception ex)
  42. {
  43. Serilog.Log.Error(ex, "查询目标信息异常");
  44. DxHelper.MsgBoxHelper.ShowError("查询目标信息异常");
  45. }
  46. }
  47. private async Task<TargetInfo> Add()
  48. {
  49. try
  50. {
  51. TargetEditor frm = new TargetEditor();
  52. if (frm.ShowDialog() != DialogResult.OK) return null;
  53. var addItem = frm.info;
  54. using (RHDWContext db = new RHDWContext())
  55. {
  56. db.TargetInfos.Add(addItem);
  57. await db.SaveChangesAsync();
  58. }
  59. return addItem;
  60. }
  61. catch (Exception ex)
  62. {
  63. Serilog.Log.Error(ex, "添加目标信息异常");
  64. DxHelper.MsgBoxHelper.ShowError("添加目标信息异常");
  65. return null;
  66. }
  67. }
  68. private async Task<TargetInfo> Edit(TargetInfo editItem)
  69. {
  70. try
  71. {
  72. TargetEditor frm = new TargetEditor(editItem);
  73. if (frm.ShowDialog() != DialogResult.OK) return null;
  74. editItem = frm.info;
  75. using (RHDWContext db = new RHDWContext())
  76. {
  77. var find = await db.TargetInfos.Where(p => p.ID == editItem.ID).FirstOrDefaultAsync();
  78. find.TargetName = editItem.TargetName;
  79. find.TargeColor = editItem.TargeColor;
  80. await db.SaveChangesAsync();
  81. }
  82. return editItem;
  83. }
  84. catch (Exception ex)
  85. {
  86. Serilog.Log.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. Serilog.Log.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. }
  121. }