JobFinancialGrid.cs 1.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Windows;
  5. using Comal.Classes;
  6. using InABox.Core;
  7. using InABox.DynamicGrid;
  8. namespace PRSDesktop
  9. {
  10. internal class JobFinancialGrid : DynamicDataGrid<JobFinancial>, IJobControl, IDataModelSource
  11. {
  12. public JobFinancialGrid()
  13. {
  14. Options.AddRange(DynamicGridOption.RecordCount, DynamicGridOption.SelectColumns, DynamicGridOption.FilterRows);
  15. }
  16. public event DataModelUpdateEvent OnUpdateDataModel;
  17. public string SectionName => "Job Financials";
  18. public DataModel DataModel(Selection selection)
  19. {
  20. var ids = ExtractValues(x => x.ID, selection).ToArray();
  21. return new BaseDataModel<JobFinancial>(new Filter<JobFinancial>(x => x.ID).InList(ids));
  22. }
  23. public Guid JobID { get; set; }
  24. protected override void DoAdd()
  25. {
  26. if (JobID.Equals(Guid.Empty) || JobID.Equals(CoreUtils.FullGuid))
  27. MessageBox.Show("Please select a Job first!");
  28. else
  29. base.DoAdd();
  30. }
  31. protected override JobFinancial CreateItem()
  32. {
  33. var result = base.CreateItem();
  34. result.Job.ID = JobID;
  35. result.Type = Data.Rows.Any() ? JobFinancialType.Variation : JobFinancialType.Contract;
  36. return result;
  37. }
  38. protected override void Reload(Filters<JobFinancial> criteria, Columns<JobFinancial> columns, ref SortOrder<JobFinancial> sort,
  39. Action<CoreTable, Exception> action)
  40. {
  41. criteria.Add(new Filter<JobFinancial>(x => x.Job.ID).IsEqualTo(JobID));
  42. base.Reload(criteria, columns, ref sort, action);
  43. }
  44. public Dictionary<string, object[]> Selected()
  45. {
  46. return new Dictionary<string, object[]>();
  47. }
  48. }
  49. }