API
您最多选择25个主题 主题必须以字母或数字开头,可以包含连字符 (-),并且长度不得超过35个字符

UnitConfigurationRepository.cs 4.1KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141
  1. using Microsoft.EntityFrameworkCore;
  2. using System;
  3. using System.Collections.Generic;
  4. using System.Linq;
  5. using UnivateProperties_API.Containers.Timeshare;
  6. using UnivateProperties_API.Context;
  7. using UnivateProperties_API.Model.Timeshare;
  8. namespace UnivateProperties_API.Repository.Timeshare
  9. {
  10. public class UnitConfigurationRepository : IRepository<UnitConfiguration>
  11. {
  12. private readonly DataContext _dbContext;
  13. public UnitConfigurationRepository(DataContext dbContext)
  14. {
  15. _dbContext = dbContext;
  16. }
  17. public List<UnitConfiguration> Get(Func<UnitConfiguration, bool> where)
  18. {
  19. return _dbContext.UnitConfigurations.Where(where).ToList();
  20. }
  21. public List<UnitConfigurationType> GetTypes(Func<UnitConfigurationType, bool> where)
  22. {
  23. return _dbContext.UnitConfigurationTypes.Where(where).ToList();
  24. }
  25. public List<UnitConfiguration> GetAll()
  26. {
  27. return _dbContext.UnitConfigurations.ToList();
  28. }
  29. public UnitConfiguration GetDetailed(Func<UnitConfiguration, bool> first)
  30. {
  31. var item = _dbContext.UnitConfigurations.FirstOrDefault(first);
  32. item.Types = GetTypes(t => t.UnitConfigurationId == item.Id);
  33. return item;
  34. }
  35. public List<UnitConfigurationDto> GetMyDetailed()
  36. {
  37. var list = new List<UnitConfigurationDto>();
  38. UnitConfigurationDto dto = new UnitConfigurationDto();
  39. foreach (var item in GetAll())
  40. {
  41. dto = new UnitConfigurationDto()
  42. {
  43. Id = item.Id,
  44. Code = item.Code,
  45. Bedrooms = item.Bedrooms,
  46. Adults = item.Adults,
  47. Children = item.Children
  48. };
  49. dto.Types = new List<string>();
  50. foreach (var subItem in GetTypes(t => t.UnitConfigurationId == item.Id))
  51. {
  52. dto.Types.Add(subItem.Description);
  53. }
  54. list.Add(dto);
  55. }
  56. return list;
  57. }
  58. public List<UnitConfiguration> GetDetailedAll()
  59. {
  60. var list = new List<UnitConfiguration>();
  61. foreach(var item in GetAll())
  62. {
  63. item.Types = GetTypes(t => t.UnitConfigurationId == item.Id);
  64. list.Add(item);
  65. }
  66. return list;
  67. }
  68. public void Insert(UnitConfiguration item)
  69. {
  70. _dbContext.Add(item);
  71. Save();
  72. }
  73. public void InsertType(UnitConfigurationType type)
  74. {
  75. _dbContext.Add(type);
  76. Save();
  77. }
  78. public void Insert(IEnumerable<UnitConfiguration> items)
  79. {
  80. foreach (var item in items)
  81. {
  82. _dbContext.Add(item);
  83. }
  84. Save();
  85. }
  86. public void Remove(UnitConfiguration item)
  87. {
  88. var i = _dbContext.UnitConfigurations.Find(item);
  89. _dbContext.UnitConfigurations.Remove(i);
  90. Save();
  91. }
  92. public void RemoveType(UnitConfigurationType item)
  93. {
  94. var i = _dbContext.UnitConfigurationTypes.Find(item);
  95. _dbContext.UnitConfigurationTypes.Remove(i);
  96. Save();
  97. }
  98. public void Remove(IEnumerable<UnitConfiguration> items)
  99. {
  100. foreach (var item in items)
  101. {
  102. var i = _dbContext.UnitConfigurations.Find(item);
  103. _dbContext.UnitConfigurations.Remove(i);
  104. }
  105. Save();
  106. }
  107. public void RemoveAtId(int item)
  108. {
  109. var i = _dbContext.UnitConfigurations.Find(item);
  110. _dbContext.UnitConfigurations.Remove(i);
  111. Save();
  112. }
  113. public void Save()
  114. {
  115. _dbContext.SaveChanges();
  116. }
  117. public void Update(UnitConfiguration item)
  118. {
  119. _dbContext.Entry(item).State = EntityState.Modified;
  120. Save();
  121. }
  122. }
  123. }