CtrlXl.cs 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130
  1. using DevExpress.XtraEditors;
  2. using XdCxRhDW.Repostory.EFContext;
  3. using XdCxRhDW.Repostory.Model;
  4. using System;
  5. using System.Collections.Generic;
  6. using System.ComponentModel;
  7. using System.Data;
  8. using System.Data.Entity;
  9. using System.Data.Entity.Migrations;
  10. using System.Drawing;
  11. using System.IO;
  12. using System.Linq;
  13. using System.Text;
  14. using System.Threading.Tasks;
  15. using System.Windows.Forms;
  16. using System.Net.Http;
  17. using ExtensionsDev;
  18. using System.Windows.Documents;
  19. using XdCxRhDW.Repostory;
  20. using XdCxRhDW.Core;
  21. using DevExpress.XtraPrinting.Native.Properties;
  22. using XdCxRhDw.Dto;
  23. using DxHelper;
  24. namespace XdCxRhDW.App.UserControl
  25. {
  26. public partial class CtrlXl : DevExpress.XtraEditors.XtraUserControl
  27. {
  28. List<XlInfo> list = new List<XlInfo>();
  29. public CtrlXl()
  30. {
  31. InitializeComponent();
  32. this.layoutControl1.UseDefault();
  33. btnOpen.UseChooseFile().UseDoubleClickToSelectAll();
  34. }
  35. private async void CtrlXl_Load(object sender, EventArgs e)
  36. {
  37. gridXl.Init<XlInfo>().UseSort().UseFilter().UseMultiSelect().UseRowNumber();
  38. gridXl.DataSource = list;
  39. await LoadData();
  40. }
  41. public async Task LoadData()
  42. {
  43. try
  44. {
  45. list.Clear();
  46. list.AddRange(await XlCache.GetAllAsync());
  47. gridView1.RefreshData();
  48. }
  49. catch (Exception ex)
  50. {
  51. Serilog.Log.Error(ex, "加载星历信息异常");
  52. DxHelper.MsgBoxHelper.ShowError("加载星历信息异常");
  53. }
  54. }
  55. private async void btnImp_Click(object sender, EventArgs e)
  56. {
  57. this.layoutControl1.Enabled = false;
  58. string baseUrl = null;
  59. using (RHDWContext db = new RHDWContext())
  60. {
  61. var res = await db.SysSetings.FirstOrDefaultAsync();
  62. if (res != null)
  63. {
  64. baseUrl = $"http://{IpHelper.GetLocalIp()}:{res.HttpPort}/api/";
  65. }
  66. }
  67. if (baseUrl == null)
  68. {
  69. MsgBoxHelper.ShowError("请在系统设置中配置Http端口");
  70. this.layoutControl1.Enabled = true;
  71. return;
  72. }
  73. var file = await HttpHelper.UploadFileAsync(btnOpen.Text, baseUrl + "File/UploadFileAsync");
  74. var result = await HttpHelper.PostRequestAsync<RecordRes>(baseUrl + "Xl/ImportTleAsync", file, 120);
  75. DxHelper.MsgBoxHelper.ShowInfo($"星历导入成功.共导入{result.data.Count}条");
  76. await LoadData();
  77. this.layoutControl1.Enabled = true;
  78. }
  79. private async void btnDel_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e)
  80. {
  81. try
  82. {
  83. if (XtraMessageBox.Show("确认删除选择的星历信息?", "确认", MessageBoxButtons.YesNo, MessageBoxIcon.Question) != DialogResult.Yes)
  84. {
  85. return;
  86. }
  87. this.Enabled = false;
  88. await Task.Run(async () =>
  89. {
  90. var ids = gridView1.GetSelectedRows();
  91. List<XlInfo> list = new List<XlInfo>();
  92. foreach (var idx in ids)
  93. {
  94. var item = gridView1.GetRow(idx) as XlInfo;
  95. list.Add(item);
  96. }
  97. var dayIds = list.Select(p => p.ID).ToList();
  98. using (RHDWContext db = new RHDWContext())
  99. {
  100. var delItems = await db.XlInfos.Where(p => dayIds.Contains(p.ID)).ToListAsync();
  101. db.XlInfos.RemoveRange(delItems);
  102. await db.SaveChangesAsync();
  103. }
  104. });
  105. gridView1.DeleteSelectedRows();
  106. }
  107. catch (Exception ex)
  108. {
  109. Serilog.Log.Error(ex, "删除选中的星历时异常");
  110. DxHelper.MsgBoxHelper.ShowError("删除选中的星历时异常");
  111. }
  112. finally
  113. {
  114. this.Enabled = true;
  115. }
  116. }
  117. private void gridView1_PopupMenuShowing(object sender, DevExpress.XtraGrid.Views.Grid.PopupMenuShowingEventArgs e)
  118. {
  119. if (gridView1.FocusedRowObject != null)
  120. popupMenu1.ShowPopup(MousePosition);
  121. }
  122. }
  123. }