SpreadsheetTemplateGrid.cs 3.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Windows.Media.Imaging;
  5. using Comal.Classes;
  6. using InABox.Clients;
  7. using InABox.Core;
  8. using InABox.DynamicGrid;
  9. using InABox.DynamicGrid.Spreadsheet;
  10. using InABox.WPF;
  11. using net.sf.mpxj.phoenix.schema.phoenix4;
  12. namespace PRSDesktop.Components.Spreadsheet
  13. {
  14. public class SpreadsheetTemplateGrid : DynamicDataGrid<SpreadsheetTemplate>
  15. {
  16. public Type AppliesTo { get; set; }
  17. protected override void Init()
  18. {
  19. base.Init();
  20. ActionColumns.Add(new DynamicImageColumn(EditImage, EditSpreadsheet) { Position = DynamicActionColumnPosition.Start });
  21. }
  22. protected override void DoReconfigure(FluentList<DynamicGridOption> options)
  23. {
  24. base.DoReconfigure(options);
  25. options.BeginUpdate().Clear().Add(DynamicGridOption.AddRows)
  26. .Add(DynamicGridOption.EditRows)
  27. .Add(DynamicGridOption.DeleteRows)
  28. .Add(DynamicGridOption.RecordCount)
  29. .EndUpdate();
  30. }
  31. protected override void Reload(Filters<SpreadsheetTemplate> criteria, Columns<SpreadsheetTemplate> columns, ref SortOrder<SpreadsheetTemplate>? sort, Action<CoreTable?, Exception?> action)
  32. {
  33. criteria.Add(new Filter<SpreadsheetTemplate>(c => c.AppliesTo).IsEqualTo(AppliesTo.EntityName().Split(".").Last()));
  34. base.Reload(criteria, columns, ref sort, action);
  35. }
  36. protected override SpreadsheetTemplate CreateItem()
  37. {
  38. var result = base.CreateItem();
  39. result.AppliesTo = AppliesTo.EntityName().Split(".").Last();
  40. return result;
  41. }
  42. private BitmapImage EditImage(CoreRow? arg)
  43. {
  44. return PRSDesktop.Resources.pencil.AsBitmapImage();
  45. }
  46. private bool EditSpreadsheet(CoreRow? row)
  47. {
  48. var spreadsheet = LoadItem(row);
  49. var window = new SpreadsheetWindow(spreadsheet);
  50. window.OnSave += SaveSpreadsheet;
  51. window.ShowDialog();
  52. Refresh(false, true);
  53. return false;
  54. }
  55. protected override void DoDoubleClick(object sender)
  56. {
  57. if (SelectedRows.Any())
  58. EditSpreadsheet(SelectedRows.First());
  59. else
  60. base.DoDoubleClick(sender);
  61. }
  62. private void SaveSpreadsheet(object sender, SpreadsheetSaveArgs args)
  63. {
  64. SpreadsheetTemplate? sheet = args.Spreadsheet as SpreadsheetTemplate;
  65. if (sheet == null)
  66. return;
  67. if (args.SaveAs || Guid.Equals(sheet.ID,Guid.Empty))
  68. {
  69. sheet.ID = Guid.Empty;
  70. sheet.CommitChanges();
  71. sheet.Data = args.Data;
  72. EditItems(new SpreadsheetTemplate[] { sheet });
  73. }
  74. else
  75. {
  76. sheet.Data = args.Data;
  77. new Client<SpreadsheetTemplate>().Save(args.Spreadsheet as SpreadsheetTemplate, "Saved by PRS Spreadsheet");
  78. }
  79. }
  80. }
  81. }