DigitalFormReportDataModel.cs 3.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using InABox.Clients;
  5. namespace InABox.Core
  6. {
  7. /// <summary>
  8. /// </summary>
  9. /// <typeparam name="T">
  10. /// Should always be an EntityForm<,></typeparam>
  11. public class DigitalFormReportDataModel<T> : AutoDataModel<T>
  12. where T : Entity, IRemotable, IPersistent, new()
  13. {
  14. private Guid? FormId { get; set; } = null;
  15. private CoreTable? FormDataTable { get; set; } = null;
  16. private DigitalFormVariable[] Variables = null;
  17. public DigitalFormReportDataModel(Filter<T> filter, Guid? formId = null) : base(filter)
  18. {
  19. FormId = formId;
  20. }
  21. public override string Name => "Digital Form Reports";
  22. protected override void CheckRequiredTables(List<string> requiredtables)
  23. {
  24. base.CheckRequiredTables(requiredtables);
  25. requiredtables.Add(TableName<T>());
  26. }
  27. private void LoadFormDataTable(Guid formID)
  28. {
  29. var formDataTable = new CoreTable();
  30. formDataTable.Columns.Add(new CoreColumn
  31. {
  32. ColumnName = "Parent.ID",
  33. DataType = typeof(Guid)
  34. });
  35. var variables = new Client<DigitalFormVariable>().Load(new Filter<DigitalFormVariable>(x => x.Form.ID).IsEqualTo(formID));
  36. foreach (var variable in variables)
  37. formDataTable.Columns.Add(
  38. new CoreColumn
  39. {
  40. ColumnName = variable.Code,
  41. DataType = DigitalFormVariable.DataType(variable.FieldType())
  42. }
  43. );
  44. FormDataTable = formDataTable;
  45. Variables = variables;
  46. AddTable(typeof(CoreTable), formDataTable, true, "Form_Data");
  47. LinkTable(typeof(T), "ID", typeof(CoreTable), "Parent.ID", childalias: "Form_Data");
  48. }
  49. protected override void AfterLoad(IEnumerable<string> requiredtables)
  50. {
  51. base.AfterLoad(requiredtables);
  52. if(FormDataTable == null)
  53. {
  54. LoadFormDataTable(FormId ?? ExtractValues<T, Guid>(x => (x as IDigitalFormInstance).Form.ID).FirstOrDefault());
  55. }
  56. var idList = ExtractValues<T, Guid>(x => x.ID);
  57. var jsonLists = ExtractValues<T, string>(x => (x as IDigitalFormInstance).FormData);
  58. var formDatas = jsonLists.Select(x => Serialization.Deserialize<Dictionary<string, object>>(x));
  59. foreach (var (i, formData) in formDatas.Select((x, i) => new Tuple<int, Dictionary<string, object>>(i, x)))
  60. {
  61. var formRow = FormDataTable.NewRow();
  62. formRow["Parent.ID"] = idList[i];
  63. if(formData != null)
  64. {
  65. foreach (var key in formData.Keys)
  66. {
  67. var variable = Variables.FirstOrDefault(x => string.Equals(x.Code, key));
  68. if (variable != null)
  69. formRow[key] = variable.ParseValue(formData[key]);
  70. }
  71. }
  72. FormDataTable.Rows.Add(formRow);
  73. }
  74. Load(typeof(CoreTable), FormDataTable, requiredtables, "Form_Data");
  75. }
  76. }
  77. }