API
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

UserDefinedGroupRepository.cs 6.4KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205
  1. using Microsoft.EntityFrameworkCore;
  2. using System;
  3. using System.Collections.Generic;
  4. using System.Linq;
  5. using UnivateProperties_API.Containers.Property;
  6. using UnivateProperties_API.Context;
  7. using UnivateProperties_API.Model.Properties;
  8. namespace UnivateProperties_API.Repository.Properties
  9. {
  10. public class UserDefinedGroupRepository : IUserDefinedGroupRepository
  11. {
  12. private readonly DataContext dBContext;
  13. public UserDefinedGroupRepository(DataContext _dBContext)
  14. {
  15. dBContext = _dBContext;
  16. }
  17. public List<UserDefinedGroup> Get(Func<UserDefinedGroup, bool> where)
  18. {
  19. return dBContext.UserDefinedGroups.Where(where).OrderBy(x => x.Rank).ToList();
  20. }
  21. public List<UserDefinedGroup> GetAll()
  22. {
  23. return dBContext.UserDefinedGroups.OrderBy(x => x.Rank).ToList();
  24. }
  25. public UserDefinedGroup GetDetailed(Func<UserDefinedGroup, bool> first)
  26. {
  27. return dBContext.UserDefinedGroups.FirstOrDefault(first);
  28. }
  29. public List<UserDefinedGroup> GetDetailedAll()
  30. {
  31. return dBContext.UserDefinedGroups.ToList();
  32. }
  33. public List<Group> GetFieldList(string name)
  34. {
  35. List<Group> FieldGroups = new List<Group>();
  36. List<UserDefinedGroup> Groups;
  37. if (name == "Property Overview")
  38. Groups = dBContext.UserDefinedGroups.Where(x => x.Description == "Property Overview").OrderBy(x => x.Rank).ToList();
  39. else
  40. Groups = dBContext.UserDefinedGroups.Where(x => x.Description != "Property Overview").OrderBy(x => x.Rank).ToList();
  41. foreach (var group in Groups)
  42. {
  43. var fields = dBContext.UserDefinedFields.Where(x => x.GroupId == group.Id).ToList();
  44. if (fields.Count > 0)
  45. {
  46. var item = new Group()
  47. {
  48. Name = group.Description,
  49. Fields = new List<GroupFields>()
  50. };
  51. FieldGroups.Add(item);
  52. foreach (var field in fields)
  53. {
  54. item.Fields.Add(new GroupFields()
  55. {
  56. ID = field.Id,
  57. Name = field.FieldName,
  58. Type = field.FieldType
  59. });
  60. }
  61. }
  62. }
  63. return FieldGroups;
  64. }
  65. public List<Group> GetFieldList(string propertyType, string name, int propertyID)
  66. {
  67. List<Group> FieldGroups = GetFieldList(name);
  68. if (name == "Property Overview")
  69. FieldGroups = GetFieldList(name);
  70. else
  71. FieldGroups = GetFieldListByPropType(propertyType);
  72. var savedValues = dBContext.PropertyUserFields.Where(x => x.PropertyId == propertyID).ToList();
  73. foreach (Group group in FieldGroups)
  74. {
  75. foreach(GroupFields field in group.Fields)
  76. {
  77. var item = savedValues.Find(x => x.UserDefinedFieldId == field.ID);
  78. if (item != null)
  79. {
  80. field.Value = item.Value ?? "";
  81. field.ItemID = item.Id;
  82. }
  83. }
  84. }
  85. return FieldGroups;
  86. }
  87. public List<Group> GetFieldListByPropType(string propertyType)
  88. {
  89. List<Group> FieldGroups = new List<Group>();
  90. List<UserDefinedGroup> Groups;
  91. PropertyUsageType usageType = PropertyUsageType.Both;
  92. switch (propertyType.ToUpper())
  93. {
  94. case "RESIDENTIAL":
  95. usageType = PropertyUsageType.Residential;
  96. break;
  97. case "COMMERCIAL":
  98. usageType = PropertyUsageType.Commercial;
  99. break;
  100. }
  101. Groups = dBContext.UserDefinedGroups.Where(x => (x.UsageType == usageType || x.UsageType == PropertyUsageType.Both) && x.Description != "Property Overview").OrderBy(x => x.Rank).ToList();
  102. foreach (var group in Groups)
  103. {
  104. var fields = dBContext.UserDefinedFields.Where(x => x.GroupId == group.Id).ToList();
  105. if (fields.Count > 0)
  106. {
  107. var item = new Group()
  108. {
  109. Name = group.Description,
  110. Fields = new List<GroupFields>()
  111. };
  112. FieldGroups.Add(item);
  113. foreach (var field in fields)
  114. {
  115. item.Fields.Add(new GroupFields()
  116. {
  117. ID = field.Id,
  118. Name = field.FieldName,
  119. Type = field.FieldType
  120. });
  121. }
  122. }
  123. }
  124. return FieldGroups;
  125. }
  126. public void Insert(UserDefinedGroup item)
  127. {
  128. dBContext.UserDefinedGroups.Add(item);
  129. Save();
  130. }
  131. public void Insert(IEnumerable<UserDefinedGroup> items)
  132. {
  133. foreach (var item in items)
  134. {
  135. dBContext.UserDefinedGroups.Add(item);
  136. Save();
  137. }
  138. }
  139. public void Remove(UserDefinedGroup item)
  140. {
  141. dBContext.UserDefinedGroups.Remove(item);
  142. Save();
  143. }
  144. public void Remove(IEnumerable<UserDefinedGroup> items)
  145. {
  146. foreach (var item in items)
  147. {
  148. dBContext.UserDefinedGroups.Remove(item);
  149. Save();
  150. }
  151. }
  152. public void RemoveAtId(int item)
  153. {
  154. var userDefinedGroups = Get(x => x.Id == item).FirstOrDefault();
  155. if (userDefinedGroups != null)
  156. {
  157. dBContext.UserDefinedGroups.Remove(userDefinedGroups);
  158. Save();
  159. }
  160. }
  161. public void Save()
  162. {
  163. dBContext.SaveChanges();
  164. }
  165. public void Update(UserDefinedGroup item)
  166. {
  167. dBContext.Entry(item).State = EntityState.Modified;
  168. Save();
  169. }
  170. public int NewId()
  171. {
  172. // Not sure if properties need it
  173. return 0;
  174. }
  175. }
  176. }