DynamicDashboardDataQueryGrid.cs 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191
  1. using InABox.Core;
  2. using InABox.DynamicGrid;
  3. using System;
  4. using System.Collections.Generic;
  5. using System.Linq;
  6. using System.Text;
  7. using System.Threading.Tasks;
  8. namespace InABox.Wpf.Dashboard.Editor;
  9. internal class DynamicDashboardDataQueryEditItem : BaseObject
  10. {
  11. // Having to do custom OnPropertyChanged stuff because Fody isn't allowed in this project.
  12. private Type? _type;
  13. [ComboLookupEditor(typeof(TypeLookupGenerator))]
  14. [EditorSequence(1)]
  15. public Type? Type
  16. {
  17. get => _type;
  18. set
  19. {
  20. var oldValue = _type;
  21. _type = value;
  22. OnPropertyChanged(nameof(Type), oldValue, value);
  23. }
  24. }
  25. [EditorSequence(2)]
  26. public string Name { get; set; } = "";
  27. [FilterEditor]
  28. [EditorSequence(3)]
  29. public string Filter { get; set; } = "";
  30. [ColumnsEditor]
  31. [EditorSequence(4)]
  32. public string Columns { get; set; } = "";
  33. [SortOrderEditor]
  34. [EditorSequence(5)]
  35. public string SortOrder { get; set; } = "";
  36. public DynamicDashboardDataQueryEditItem()
  37. {
  38. }
  39. public DynamicDashboardDataQueryEditItem(IDynamicDashboardDataQuery query)
  40. {
  41. Name = query.Key;
  42. Type = query.Type;
  43. Filter = Serialization.Serialize(query.Filter);
  44. Columns = Serialization.Serialize(query.Columns);
  45. SortOrder = Serialization.Serialize(query.SortOrder);
  46. }
  47. private class TypeLookupGenerator : LookupGenerator<DynamicDashboardDataQueryEditItem>
  48. {
  49. public TypeLookupGenerator(DynamicDashboardDataQueryEditItem[]? items) : base(items)
  50. {
  51. }
  52. protected override void DoGenerateLookups()
  53. {
  54. foreach(var entity in CoreUtils.Entities.Where(x => x.IsSubclassOf(typeof(Entity)) && x.HasInterface<IRemotable>()).OrderBy(x => x.Name))
  55. {
  56. AddValue(entity, entity.Name);
  57. }
  58. }
  59. }
  60. protected override void DoPropertyChanged(string name, object? before, object? after)
  61. {
  62. base.DoPropertyChanged(name, before, after);
  63. if(name == nameof(Type))
  64. {
  65. Filter = "";
  66. Columns = "";
  67. SortOrder = "";
  68. if (Type is not null && (Name.IsNullOrWhiteSpace() || Name == (before as Type)?.Name))
  69. {
  70. Name = Type.Name;
  71. }
  72. }
  73. }
  74. public IDynamicDashboardDataQuery? ToQuery()
  75. {
  76. if(Type is not null)
  77. {
  78. var query = (Activator.CreateInstance(typeof(DynamicDashboardDataQuery<>).MakeGenericType(Type)) as IDynamicDashboardDataQuery)!;
  79. query.Key = Name;
  80. query.Filter = Serialization.Deserialize(typeof(Filter<>).MakeGenericType(Type), Filter) as IFilter;
  81. query.Columns = (Serialization.Deserialize(typeof(Columns<>).MakeGenericType(Type), Columns) as IColumns)
  82. ?? Core.Columns.None(Type);
  83. query.SortOrder = Serialization.Deserialize(typeof(SortOrder<>).MakeGenericType(Type), SortOrder) as ISortOrder;
  84. return query;
  85. }
  86. else
  87. {
  88. return null;
  89. }
  90. }
  91. }
  92. internal class DynamicDashboardDataQueryGrid : DynamicItemsListGrid<DynamicDashboardDataQueryEditItem>
  93. {
  94. protected override void Init()
  95. {
  96. base.Init();
  97. ActionColumns.Add(new DynamicTextColumn(GetText)
  98. {
  99. HeaderText = "Table"
  100. });
  101. HiddenColumns.Add(x => x.Type);
  102. }
  103. private object? GetText(CoreRow? row)
  104. {
  105. return row?.Get<DynamicDashboardDataQueryEditItem, Type?>(x => x.Type)?.Name ?? "";
  106. }
  107. protected override void DoValidate(DynamicDashboardDataQueryEditItem[] items, List<string> errors)
  108. {
  109. base.DoValidate(items, errors);
  110. foreach(var item in items)
  111. {
  112. if(Items.Any(x => x != item && x.Name == item.Name))
  113. {
  114. errors.Add($"Duplicate key '{item.Name}'");
  115. }
  116. }
  117. }
  118. protected override void DoReconfigure(DynamicGridOptions options)
  119. {
  120. base.DoReconfigure(options);
  121. options.AddRows = true;
  122. options.EditRows = true;
  123. options.DeleteRows = true;
  124. }
  125. private readonly Column<DynamicDashboardDataQueryEditItem> FilterColumn = new(x => x.Filter);
  126. private readonly Column<DynamicDashboardDataQueryEditItem> ColumnsColumn = new(x => x.Columns);
  127. private readonly Column<DynamicDashboardDataQueryEditItem> SortOrderColumn = new(x => x.SortOrder);
  128. private readonly Column<DynamicDashboardDataQueryEditItem> TypeColumn = new(x => x.Type);
  129. protected override void CustomiseEditor(IDynamicEditorForm form, DynamicDashboardDataQueryEditItem[] items, DynamicGridColumn column, BaseEditor editor)
  130. {
  131. base.CustomiseEditor(form, items, column, editor);
  132. var item = items.First();
  133. if(FilterColumn.IsEqualTo(column.ColumnName) && editor is FilterEditor filterEditor)
  134. {
  135. filterEditor.Type = item.Type;
  136. }
  137. else if(ColumnsColumn.IsEqualTo(column.ColumnName) && editor is ColumnsEditor columnsEditor)
  138. {
  139. columnsEditor.Type = item.Type;
  140. }
  141. else if(SortOrderColumn.IsEqualTo(column.ColumnName) && editor is SortOrderEditor sortEditor)
  142. {
  143. sortEditor.Type = item.Type;
  144. }
  145. }
  146. protected override Dictionary<string, object?> EditorValueChanged(IDynamicEditorForm editor, DynamicDashboardDataQueryEditItem[] items, string name, object value)
  147. {
  148. var changed = base.EditorValueChanged(editor, items, name, value);
  149. if (TypeColumn.IsEqualTo(name))
  150. {
  151. if(value is Type type)
  152. {
  153. if(editor.TryFindEditor<FilterEditorControl>(FilterColumn.Property, out var filterEditor))
  154. {
  155. filterEditor.FilterType = type;
  156. }
  157. if(editor.TryFindEditor<ColumnsEditorControl>(ColumnsColumn.Property, out var columnsEditor))
  158. {
  159. columnsEditor.ColumnsType = type;
  160. }
  161. }
  162. }
  163. return changed;
  164. }
  165. }