DigitalFormReportDataModel.cs 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using InABox.Clients;
  5. using JetBrains.Annotations;
  6. namespace InABox.Core
  7. {
  8. public interface IDigitalFormReportDataModel
  9. {
  10. public DigitalFormVariable[]? Variables { get; set; }
  11. }
  12. /// <summary>
  13. /// </summary>
  14. /// <typeparam name="T">
  15. /// Should always be an EntityForm<,></typeparam>
  16. public class DigitalFormReportDataModel<T> : AutoDataModel<T>, IDigitalFormReportDataModel
  17. where T : Entity, IRemotable, IPersistent, IEntityForm, new()
  18. {
  19. private Guid? FormId { get; set; } = null;
  20. private CoreTable? FormDataTable { get; set; } = null;
  21. //private DigitalFormVariable[]? _variables = null;
  22. public DigitalFormVariable[]? Variables { get; set; }
  23. public DigitalFormReportDataModel(Filter<T> filter, Guid? formId = null) : base(filter)
  24. {
  25. FormId = formId;
  26. }
  27. public override string Name => "Digital Form Reports";
  28. protected override void CheckRequiredTables(List<string> requiredtables)
  29. {
  30. base.CheckRequiredTables(requiredtables);
  31. requiredtables.Add(TableName<T>());
  32. }
  33. private void LoadFormDataTable(Guid formID)
  34. {
  35. var formDataTable = new CoreTable();
  36. formDataTable.Columns.Add(new CoreColumn
  37. {
  38. ColumnName = "Parent.ID",
  39. DataType = typeof(Guid)
  40. });
  41. if(Variables is null)
  42. Variables = new Client<DigitalFormVariable>().Load(new Filter<DigitalFormVariable>(x => x.Form.ID).IsEqualTo(formID));
  43. foreach (var variable in Variables)
  44. foreach (var column in variable.GetVariableColumns())
  45. formDataTable.Columns.Add(column);
  46. FormDataTable = formDataTable;
  47. AddTable(typeof(CoreTable), formDataTable, true, "Form_Data");
  48. LinkTable(typeof(T), "ID", typeof(CoreTable), "Parent.ID", childalias: "Form_Data");
  49. }
  50. private void LoadFormDataIntoRow(CoreRow row, Dictionary<string, object?> data)
  51. {
  52. foreach (var key in data.Keys)
  53. {
  54. if (key.Contains('.'))
  55. {
  56. row[key] = data[key];
  57. }
  58. else
  59. {
  60. var variable = Variables.FirstOrDefault(x => string.Equals(x.Code, key));
  61. if (variable != null)
  62. row[key] = variable.ParseValue(data[key]);
  63. }
  64. }
  65. }
  66. protected override void AfterLoad(IEnumerable<string> requiredtables)
  67. {
  68. base.AfterLoad(requiredtables);
  69. if(FormDataTable == null)
  70. {
  71. LoadFormDataTable(FormId ?? ExtractValues<T, Guid>(x => (x as IDigitalFormInstance)!.Form.ID).FirstOrDefault());
  72. }
  73. var idList = ExtractValues<T, Guid>(x => x.ID);
  74. var jsonLists = ExtractValues<T, string>(x => (x as IDigitalFormInstance)!.FormData, false).ToList();
  75. var blobLists = ExtractValues<T, string?>(x => (x as IDigitalFormInstance)!.BlobData, false).ToList();
  76. for(var i = 0; i < jsonLists.Count; ++i)
  77. {
  78. var json = jsonLists[i];
  79. var blobJSON = blobLists[i];
  80. var formData = DigitalForm.DeserializeFormData(json, blobJSON);
  81. var formRow = FormDataTable!.NewRow();
  82. formRow["Parent.ID"] = idList[i];
  83. if (formData != null) LoadFormDataIntoRow(formRow, formData);
  84. FormDataTable.Rows.Add(formRow);
  85. }
  86. Load(typeof(CoreTable), FormDataTable!, requiredtables, "Form_Data");
  87. }
  88. }
  89. }