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.2KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196
  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. field.Value = item.Value;
  80. }
  81. }
  82. return FieldGroups;
  83. }
  84. public List<Group> GetFieldListByPropType(string propertyType)
  85. {
  86. List<Group> FieldGroups = new List<Group>();
  87. List<UserDefinedGroup> Groups;
  88. PropertyUsageType usageType = PropertyUsageType.Both;
  89. switch (propertyType.ToUpper())
  90. {
  91. case "RESIDENTIAL":
  92. usageType = PropertyUsageType.Residential;
  93. break;
  94. case "COMMERCIAL":
  95. usageType = PropertyUsageType.Commercial;
  96. break;
  97. }
  98. Groups = dBContext.UserDefinedGroups.Where(x => (x.UsageType == usageType || x.UsageType == PropertyUsageType.Both) && x.Description != "Property Overview").OrderBy(x => x.Rank).ToList();
  99. foreach (var group in Groups)
  100. {
  101. var fields = dBContext.UserDefinedFields.Where(x => x.GroupId == group.Id).ToList();
  102. if (fields.Count > 0)
  103. {
  104. var item = new Group()
  105. {
  106. Name = group.Description,
  107. Fields = new List<GroupFields>()
  108. };
  109. FieldGroups.Add(item);
  110. foreach (var field in fields)
  111. {
  112. item.Fields.Add(new GroupFields()
  113. {
  114. ID = field.Id,
  115. Name = field.FieldName,
  116. Type = field.FieldType
  117. });
  118. }
  119. }
  120. }
  121. return FieldGroups;
  122. }
  123. public void Insert(UserDefinedGroup item)
  124. {
  125. dBContext.UserDefinedGroups.Add(item);
  126. Save();
  127. }
  128. public void Insert(IEnumerable<UserDefinedGroup> items)
  129. {
  130. foreach (var item in items)
  131. {
  132. dBContext.UserDefinedGroups.Add(item);
  133. Save();
  134. }
  135. }
  136. public void Remove(UserDefinedGroup item)
  137. {
  138. dBContext.UserDefinedGroups.Remove(item);
  139. Save();
  140. }
  141. public void Remove(IEnumerable<UserDefinedGroup> items)
  142. {
  143. foreach (var item in items)
  144. {
  145. dBContext.UserDefinedGroups.Remove(item);
  146. Save();
  147. }
  148. }
  149. public void RemoveAtId(int item)
  150. {
  151. var userDefinedGroups = Get(x => x.Id == item).FirstOrDefault();
  152. if (userDefinedGroups != null)
  153. {
  154. dBContext.UserDefinedGroups.Remove(userDefinedGroups);
  155. Save();
  156. }
  157. }
  158. public void Save()
  159. {
  160. dBContext.SaveChanges();
  161. }
  162. public void Update(UserDefinedGroup item)
  163. {
  164. dBContext.Entry(item).State = EntityState.Modified;
  165. Save();
  166. }
  167. }
  168. }