CtrlXl.cs 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162
  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. string file = null;
  74. try
  75. {
  76. file = await HttpHelper.UploadFileAsync(btnOpen.Text, baseUrl + "File/UploadFileAsync");
  77. }
  78. catch (TaskCanceledException)
  79. {
  80. layoutControl1.Enabled = true;
  81. Serilog.Log.Warning($"文件[{btnOpen.Text}]上传超时");
  82. DxHelper.MsgBoxHelper.ShowInfo($"文件[{btnOpen.Text}]上传超时");
  83. return;
  84. }
  85. catch (Exception ex)
  86. {
  87. layoutControl1.Enabled = true;
  88. Serilog.Log.Error(ex, $"文件[{btnOpen.Text}]上传异常");
  89. DxHelper.MsgBoxHelper.ShowError($"文件[{btnOpen.Text}]上传异常");
  90. return;
  91. }
  92. try
  93. {
  94. var result = await HttpHelper.PostRequestAsync<RecordRes>(baseUrl + "Xl/ImportTleAsync", file, 120);
  95. DxHelper.MsgBoxHelper.ShowInfo($"星历导入成功.共导入{result.data.Count}条");
  96. await LoadData();
  97. }
  98. catch (TaskCanceledException)
  99. {
  100. Serilog.Log.Warning($"星历导入超时");
  101. DxHelper.MsgBoxHelper.ShowInfo($"星历导入超时");
  102. return;
  103. }
  104. catch (Exception ex)
  105. {
  106. Serilog.Log.Error(ex,"星历导入异常");
  107. }
  108. this.layoutControl1.Enabled = true;
  109. }
  110. private async void btnDel_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e)
  111. {
  112. try
  113. {
  114. if (XtraMessageBox.Show("确认删除选择的星历信息?", "确认", MessageBoxButtons.YesNo, MessageBoxIcon.Question) != DialogResult.Yes)
  115. {
  116. return;
  117. }
  118. this.Enabled = false;
  119. await Task.Run(async () =>
  120. {
  121. var ids = gridView1.GetSelectedRows();
  122. List<XlInfo> list = new List<XlInfo>();
  123. foreach (var idx in ids)
  124. {
  125. var item = gridView1.GetRow(idx) as XlInfo;
  126. list.Add(item);
  127. }
  128. var dayIds = list.Select(p => p.ID).ToList();
  129. using (RHDWContext db = new RHDWContext())
  130. {
  131. var delItems = await db.XlInfos.Where(p => dayIds.Contains(p.ID)).ToListAsync();
  132. db.XlInfos.RemoveRange(delItems);
  133. await db.SaveChangesAsync();
  134. }
  135. });
  136. gridView1.DeleteSelectedRows();
  137. }
  138. catch (Exception ex)
  139. {
  140. Serilog.Log.Error(ex, "删除选中的星历时异常");
  141. DxHelper.MsgBoxHelper.ShowError("删除选中的星历时异常");
  142. }
  143. finally
  144. {
  145. this.Enabled = true;
  146. }
  147. }
  148. private void gridView1_PopupMenuShowing(object sender, DevExpress.XtraGrid.Views.Grid.PopupMenuShowingEventArgs e)
  149. {
  150. if (gridView1.FocusedRowObject != null)
  151. popupMenu1.ShowPopup(MousePosition);
  152. }
  153. }
  154. }