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

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174
  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.Property;
  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).ToList();
  20. }
  21. public List<UserDefinedGroup> GetAll()
  22. {
  23. return dBContext.UserDefinedGroups.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> GetFieldListByPropType(string propertyType)
  66. {
  67. List<Group> FieldGroups = new List<Group>();
  68. List<UserDefinedGroup> Groups;
  69. PropertyUsageType usageType = PropertyUsageType.Both;
  70. switch (propertyType.ToUpper())
  71. {
  72. case "RESIDENTIAL":
  73. usageType = PropertyUsageType.Residential;
  74. break;
  75. case "COMMERCIAL":
  76. usageType = PropertyUsageType.Commercial;
  77. break;
  78. }
  79. Groups = dBContext.UserDefinedGroups.Where(x => (x.UsageType == usageType || x.UsageType == PropertyUsageType.Both) && x.Description != "Property Overview").OrderBy(x => x.Rank).ToList();
  80. foreach (var group in Groups)
  81. {
  82. var fields = dBContext.UserDefinedFields.Where(x => x.GroupId == group.Id).ToList();
  83. if (fields.Count > 0)
  84. {
  85. var item = new Group()
  86. {
  87. Name = group.Description,
  88. Fields = new List<GroupFields>()
  89. };
  90. FieldGroups.Add(item);
  91. foreach (var field in fields)
  92. {
  93. item.Fields.Add(new GroupFields()
  94. {
  95. ID = field.Id,
  96. Name = field.FieldName,
  97. Type = field.FieldType
  98. });
  99. }
  100. }
  101. }
  102. return FieldGroups;
  103. }
  104. public void Insert(UserDefinedGroup item)
  105. {
  106. dBContext.UserDefinedGroups.Add(item);
  107. Save();
  108. }
  109. public void Insert(IEnumerable<UserDefinedGroup> items)
  110. {
  111. foreach (var item in items)
  112. {
  113. dBContext.UserDefinedGroups.Add(item);
  114. Save();
  115. }
  116. }
  117. public void Remove(UserDefinedGroup item)
  118. {
  119. dBContext.UserDefinedGroups.Remove(item);
  120. Save();
  121. }
  122. public void Remove(IEnumerable<UserDefinedGroup> items)
  123. {
  124. foreach (var item in items)
  125. {
  126. dBContext.UserDefinedGroups.Remove(item);
  127. Save();
  128. }
  129. }
  130. public void RemoveAtId(int item)
  131. {
  132. var userDefinedGroups = Get(x => x.Id == item).FirstOrDefault();
  133. if (userDefinedGroups != null)
  134. {
  135. dBContext.UserDefinedGroups.Remove(userDefinedGroups);
  136. Save();
  137. }
  138. }
  139. public void Save()
  140. {
  141. dBContext.SaveChanges();
  142. }
  143. public void Update(UserDefinedGroup item)
  144. {
  145. dBContext.Entry(item).State = EntityState.Modified;
  146. Save();
  147. }
  148. }
  149. }