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 8.2KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249
  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. Rank = field.Rank
  121. });
  122. }
  123. }
  124. }
  125. return FieldGroups;
  126. }
  127. public void Insert(UserDefinedGroup item)
  128. {
  129. dBContext.UserDefinedGroups.Add(item);
  130. Save();
  131. }
  132. public void Insert(IEnumerable<UserDefinedGroup> items)
  133. {
  134. foreach (var item in items)
  135. {
  136. dBContext.UserDefinedGroups.Add(item);
  137. Save();
  138. }
  139. }
  140. public void Remove(UserDefinedGroup item)
  141. {
  142. dBContext.UserDefinedGroups.Remove(item);
  143. Save();
  144. }
  145. public void Remove(IEnumerable<UserDefinedGroup> items)
  146. {
  147. foreach (var item in items)
  148. {
  149. dBContext.UserDefinedGroups.Remove(item);
  150. Save();
  151. }
  152. }
  153. public void RemoveAtId(int item)
  154. {
  155. var userDefinedGroups = Get(x => x.Id == item).FirstOrDefault();
  156. if (userDefinedGroups != null)
  157. {
  158. dBContext.UserDefinedGroups.Remove(userDefinedGroups);
  159. Save();
  160. }
  161. }
  162. public void Save()
  163. {
  164. dBContext.SaveChanges();
  165. }
  166. public void Update(UserDefinedGroup item)
  167. {
  168. dBContext.Entry(item).State = EntityState.Modified;
  169. Save();
  170. }
  171. public int NewId()
  172. {
  173. // Not sure if properties need it
  174. return 0;
  175. }
  176. public List<Group> GetSavedList(int PropertyId)
  177. {
  178. if (PropertyId == 0)
  179. return null;
  180. var prop = dBContext.Properties.Include("PropertyType").Where(p => p.Id == PropertyId).FirstOrDefault();
  181. var all = GetFieldListByPropType(prop.PropertyType.PropertyUsageType);
  182. var groups = (from g in dBContext.UserDefinedGroups
  183. where g.UsageType == prop.PropertyType.UsageType
  184. || g.UsageType == PropertyUsageType.Both
  185. orderby g.Rank
  186. select g).ToList();
  187. foreach (UserDefinedGroup uGroup in groups)
  188. {
  189. var groupFields = (from f in dBContext.PropertyUserFields
  190. join uf in dBContext.UserDefinedFields on f.UserDefinedFieldId equals uf.Id
  191. join g in dBContext.UserDefinedGroups on uf.GroupId equals g.Id
  192. where f.PropertyId == PropertyId
  193. && g.Id == uGroup.Id
  194. orderby g.Rank, uf.Rank
  195. select new { uf.FieldName, f.Value, f.Description }).ToList();
  196. foreach (var val in groupFields)
  197. {
  198. foreach (var iGroup in all)
  199. {
  200. foreach (var field in iGroup.Fields)
  201. {
  202. if (field.Name == val.FieldName)
  203. {
  204. field.Value = val.Value;
  205. }
  206. }
  207. }
  208. }
  209. }
  210. return all;
  211. }
  212. }
  213. }