CtrlADTask.cs 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106
  1. using DevExpress.Mvvm.Native;
  2. using DW5S.Entity;
  3. using DW5S.Repostory;
  4. using DW5S.ViewModel;
  5. using ExtensionsDev;
  6. using Microsoft.EntityFrameworkCore;
  7. using System;
  8. using System.Collections.Generic;
  9. using System.Linq;
  10. using System.Threading.Tasks;
  11. using XdCxRhDW5S.ViewModel;
  12. namespace DW5S.App.UserControl
  13. {
  14. public partial class CtrlADTask : DevExpress.XtraEditors.XtraUserControl
  15. {
  16. readonly List<ADTaskViewModel> list = new List<ADTaskViewModel>();
  17. public CtrlADTask()
  18. {
  19. InitializeComponent();
  20. }
  21. private async void CtrlRefTask_Load(object sender, EventArgs e)
  22. {
  23. try
  24. {
  25. gridRefTask.UseDefault(list).UseMultiSelect().UseRowNumber()
  26. .HideColumn(nameof(ADTaskViewModel.Id));
  27. var sigList = await GetSigInfos();
  28. this.txtSig.UseDefault(showClearBtn: true).SetData(sigList, displayField: nameof(SigViewModel.FreqDownDis)).UseDoubleClickToSelectAll();
  29. var taskList = await Query();
  30. list.AddRange(taskList);
  31. gridView1.RefreshData();
  32. gridView1.BestFitColumns();
  33. }
  34. catch (Exception ex)
  35. {
  36. IocContainer.Logger.Error(ex, "查询采集任务信息异常");
  37. DxHelper.MsgBoxHelper.ShowError("查询采集任务信息异常");
  38. }
  39. }
  40. private async Task<List<SigViewModel>> GetSigInfos()
  41. {
  42. var unitOfWork = IocContainer.UnitOfWork;
  43. var sigInfos = await unitOfWork.Of<SigInfo>().GetAllAsync(p => p.FreqUpHz);
  44. var sigList = sigInfos.OrderBy(i => i.SigType).OrderBy(i => i.FreqDownHz).To<List<SigViewModel>>();
  45. return sigList;
  46. }
  47. private async Task<List<SatViewModel>> GetSats()
  48. {
  49. var unitOfWork = IocContainer.UnitOfWork;
  50. var reps = unitOfWork.Of<SatInfo>();
  51. var res = await reps.GetAllAsync();
  52. return res.OrderBy(s => s.SatName).To<List<SatViewModel>>();
  53. }
  54. private async Task<List<ADTaskViewModel>> Query(SigViewModel sigView = null)
  55. {
  56. List<ADTaskViewModel> taskList = new List<ADTaskViewModel>();
  57. var unitOfWork = IocContainer.UnitOfWork;
  58. var adCards = await unitOfWork.Of<AdCard>().AsQueryable().Where(p => p.Enable == true)
  59. .Include(p => p.AdChannels)
  60. .OrderByDescending(p => p.Name).ToListAsync();
  61. var chItems = adCards.SelectMany(a => a.AdChannels).Where(s => s.Enable == true).ToList();
  62. var sigList = await GetSigInfos();
  63. var sats = await GetSats();
  64. var chsats = sats.Where(s => chItems.Any(c => c.SatInfoID == s.Id));
  65. foreach (var sigItem in sigList)
  66. {
  67. if (sigView != null && sigView.Id == sigItem.Id)
  68. {
  69. continue;
  70. }
  71. var adTask = sigItem.To<ADTaskViewModel>();
  72. adTask.SatViews = chsats.ToList();
  73. taskList.Add(adTask);
  74. }
  75. return taskList;
  76. }
  77. private async void btnSerach_Click(object sender, EventArgs e)
  78. {
  79. try
  80. {
  81. var sigView = (txtSig.EditValue as SigViewModel);
  82. var taskList = await Query(sigView);
  83. list.Clear();
  84. list.AddRange(taskList);
  85. gridView1.RefreshData();
  86. }
  87. catch (Exception ex)
  88. {
  89. IocContainer.Logger.Error(ex, "查询采集任务信息异常");
  90. DxHelper.MsgBoxHelper.ShowError("查询采集任务信息异常");
  91. }
  92. }
  93. }
  94. }