CtrlStation.cs 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147
  1. using DevExpress.Office.Utils;
  2. using DW5S.App.EditForms;
  3. using DW5S.Entity;
  4. using DW5S.Repostory;
  5. using DW5S.ViewModel;
  6. using Microsoft.EntityFrameworkCore;
  7. using System;
  8. using System.Collections.Generic;
  9. using System.Data;
  10. using System.Linq;
  11. using System.Threading.Tasks;
  12. using System.Windows.Forms;
  13. using XdCxRhDW5S.ViewModel;
  14. using static System.Runtime.InteropServices.JavaScript.JSType;
  15. namespace DW5S.App.UserControl
  16. {
  17. public partial class CtrlStation : DevExpress.XtraEditors.XtraUserControl
  18. {
  19. List<AdCardViewModel> list = new List<AdCardViewModel>();
  20. public CtrlStation()
  21. {
  22. InitializeComponent();
  23. gridStation.UseDefault(list).UseEmptyText("请添加采集通道").UseMultiSelect().UseRowNumber();
  24. gridStation
  25. .UseBoolColumn(nameof(AdChannelViewModel.Enable), "启用", "禁用", AdChannelgView)
  26. .UseLookUpEditColumn(nameof(AdChannelViewModel.SatInfoID), displayField: nameof(SatViewModel.Sat), AdChannelgView)
  27. .UseLookUpEditColumn(nameof(AdChannelViewModel.TxInfoID), displayField: nameof(RecTxViewModel.Name), AdChannelgView);
  28. }
  29. private async void CtrlStation_Load(object sender, EventArgs e)
  30. {
  31. try
  32. {
  33. var sats = await GetSats();
  34. var ants = await GetAnts();
  35. gridStation.UpdateLookUpEditDataSource(nameof(AdChannelViewModel.SatInfoID), sats, AdChannelgView);
  36. gridStation.UpdateLookUpEditDataSource(nameof(AdChannelViewModel.TxInfoID), ants, AdChannelgView);
  37. gridStation.UseAddAsync(Add)
  38. .UseEditAsync<AdCardViewModel>(Edit)
  39. .UseDeleteAsync<AdCardViewModel>(Delete);
  40. var unitOfWork = IocContainer.UnitOfWork;
  41. var adCards = await unitOfWork.Of<AdCard>().AsQueryable()
  42. .Include(p => p.AdChannels)
  43. .OrderByDescending(p => p.Name).ToListAsync();
  44. list.AddRange(adCards.To<List<AdCardViewModel>>());
  45. }
  46. catch (Exception ex)
  47. {
  48. string msg = "查询采集信息异常";
  49. IocContainer.Logger.Error(ex, msg);
  50. DxHelper.MsgBoxHelper.ShowError(msg);
  51. }
  52. }
  53. private async Task<List<RecTxViewModel>> GetAnts()
  54. {
  55. var unitOfWork = IocContainer.UnitOfWork;
  56. var repsRecTx = unitOfWork.Of<TxInfo>();
  57. var items = await repsRecTx.FindAsync(f => f.Enable == true, p => p.Name);
  58. var ss = items.To<List<RecTxViewModel>>();
  59. return ss;
  60. }
  61. private async Task<List<SatViewModel>> GetSats()
  62. {
  63. var unitOfWork = IocContainer.UnitOfWork;
  64. var reps = unitOfWork.Of<SatInfo>();
  65. var res = await reps.GetAllAsync();
  66. return res.OrderBy(s => s.SatName).To<List<SatViewModel>>();
  67. }
  68. private async Task<AdCardViewModel> Add()
  69. {
  70. try
  71. {
  72. StationEditor frm = new StationEditor();
  73. if (frm.ShowDialog() != DialogResult.OK) return null;
  74. var addItem = frm.info.To<AdCard>();
  75. addItem.ServerStatus = EnumServerStatus.OffLine;
  76. var adChannels = frm.AdChItems.To<List<AdChannel>>();
  77. addItem.AdChannels = adChannels;
  78. var unitOfWork = IocContainer.UnitOfWork;
  79. var repsStation = unitOfWork.Of<AdCard>();
  80. var res = await repsStation.AddOrUpdateAsync(addItem);
  81. await unitOfWork.SaveAsync();
  82. var adCard = res.To<AdCardViewModel>();
  83. return adCard;
  84. }
  85. catch (Exception ex)
  86. {
  87. string msg = "添加采集信息异常";
  88. IocContainer.Logger.Error(ex, msg);
  89. DxHelper.MsgBoxHelper.ShowError(msg);
  90. return null;
  91. }
  92. }
  93. private async Task<AdCardViewModel> Edit(AdCardViewModel editItem)
  94. {
  95. try
  96. {
  97. StationEditor frm = new StationEditor(editItem);
  98. if (frm.ShowDialog() != DialogResult.OK) return null;
  99. editItem = frm.info;
  100. var unitOfWork = IocContainer.UnitOfWork;
  101. var repsStation = unitOfWork.Of<AdCard>();
  102. await repsStation.AddOrUpdateAsync(editItem.To<AdCard>());
  103. await unitOfWork.SaveAsync();
  104. return editItem;
  105. }
  106. catch (Exception ex)
  107. {
  108. string msg = "保存采集信息异常";
  109. IocContainer.Logger.Error(ex, msg);
  110. DxHelper.MsgBoxHelper.ShowError(msg);
  111. return null;
  112. }
  113. }
  114. private async Task<bool> Delete(List<AdCardViewModel> list)
  115. {
  116. try
  117. {
  118. var unitOfWork = IocContainer.UnitOfWork;
  119. var repsCxTx = unitOfWork.Of<AdCard>();
  120. await repsCxTx.DeleteAsync(list.To<List<AdCard>>());
  121. await unitOfWork.SaveAsync();
  122. return true;
  123. }
  124. catch (Exception ex)
  125. {
  126. string msg = "删除采集信息异常";
  127. IocContainer.Logger.Error(ex, msg);
  128. DxHelper.MsgBoxHelper.ShowError(msg);
  129. return false;
  130. }
  131. }
  132. private async void gridView1_DoubleClick(object sender, EventArgs e)
  133. {
  134. var editItem = Adgview.GetFocusedRow() as AdCardViewModel;
  135. if (editItem == null) return;
  136. await Edit(editItem);
  137. }
  138. }
  139. }