Вы не можете выбрать более 25 тем Темы должны начинаться с буквы или цифры, могут содержать дефисы(-) и должны содержать не более 35 символов.

CategoryService.cs 10KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260
  1. using Diligent.WebAPI.Contracts.DTOs.Categories;
  2. namespace Diligent.WebAPI.Business.Services
  3. {
  4. public class CategoryService : ICategoryService
  5. {
  6. private readonly DatabaseContext _context;
  7. private readonly IMapper _mapper;
  8. private readonly UserManager<User> _userManager;
  9. private readonly IUserService _userService;
  10. public CategoryService(DatabaseContext context, IMapper mapper, UserManager<User> userManager, IUserService userService)
  11. {
  12. _context = context;
  13. _mapper = mapper;
  14. _userManager = userManager;
  15. _userService = userService;
  16. }
  17. public async Task<CategoriesParentChild> GetRootCategories(int userId,int parentCategoryId)
  18. {
  19. var user = await _userManager.FindByIdAsync(userId.ToString());
  20. var role = (await _userManager.GetRolesAsync(user))[0];
  21. if(parentCategoryId != -1 && role != "SuperAdmin")
  22. {
  23. var categories = await _context.UserCategories.Where(x => x.UserId == userId && x.CategoryId == parentCategoryId).ToListAsync();
  24. if (categories.Count == 0) return null;
  25. }
  26. if (role == "SuperAdmin")
  27. if (parentCategoryId == -1)
  28. {
  29. return new CategoriesParentChild
  30. {
  31. Categories = _mapper.Map<List<CategoriesNamesResponse>>
  32. (await _context.Categories.Where(k => k.ParentCategory == null).ToListAsync()),
  33. ChildParentRelations = await GetByParentChild(parentCategoryId)
  34. };
  35. }
  36. else
  37. {
  38. return new CategoriesParentChild
  39. {
  40. Categories = await GetChildCategories(parentCategoryId, userId, role),
  41. ChildParentRelations = await GetByParentChild(parentCategoryId)
  42. };
  43. }
  44. var userCategories = new List<UserCategories>();
  45. if(parentCategoryId == -1)
  46. userCategories = await _context.UserCategories
  47. .Where(k => k.UserId == userId && k.Category.ParentCategory == null)
  48. .Include(t => t.Category)
  49. .ToListAsync();
  50. else
  51. return new CategoriesParentChild
  52. {
  53. Categories = await GetChildCategories(parentCategoryId, userId, role),
  54. ChildParentRelations = await GetByParentChild(parentCategoryId)
  55. };
  56. return new CategoriesParentChild
  57. {
  58. Categories = GetCategoriesFromUserCategories(userCategories),
  59. ChildParentRelations = await GetByParentChild(parentCategoryId)
  60. };
  61. }
  62. public async Task<Category> GetCategoryEntityById(int? id) =>
  63. await _context.Categories.Where(x => x.Id == id).FirstOrDefaultAsync();
  64. public async Task<List<IsGrantedCategory>> GetCategories(int userId)
  65. {
  66. var grantedCategories = await _context.UserCategories.Where(k => k.UserId == userId).ToListAsync();
  67. var allCategories = await _context.Categories.ToListAsync();
  68. var result = new List<IsGrantedCategory>();
  69. for (int i = 0; i < allCategories.Count; i++)
  70. {
  71. var newCategory = new IsGrantedCategory
  72. {
  73. Id = allCategories[i].Id,
  74. Name = allCategories[i].Name,
  75. };
  76. bool isGranted = false;
  77. for (int j = 0; j < grantedCategories.Count; j++)
  78. {
  79. if(grantedCategories[j].CategoryId == allCategories[i].Id && userId == grantedCategories[j].UserId)
  80. {
  81. isGranted = true;
  82. break;
  83. }
  84. }
  85. newCategory.IsChecked = isGranted;
  86. result.Add(newCategory);
  87. isGranted = false;
  88. }
  89. return result;
  90. }
  91. public async Task<List<TreeViewCategoryResponse>> GetAllCategories(int userId)
  92. {
  93. var user = await _userManager.FindByIdAsync(userId.ToString());
  94. var role = (await _userManager.GetRolesAsync(user))[0];
  95. List<Category> categories = new();
  96. if(role == "SuperAdmin")
  97. {
  98. categories = await _context.Categories.Include(k => k.ParentCategory).ToListAsync();
  99. }
  100. else
  101. {
  102. categories = await getCategoriesUserCanSee(user.Id);
  103. }
  104. List<TreeViewCategoryResponse> response = new();
  105. foreach (var category in categories)
  106. {
  107. TreeViewCategoryResponse treeViewCategory = new();
  108. if(category.ParentCategory == null)
  109. {
  110. treeViewCategory.Id = category.Id;
  111. treeViewCategory.Name = category.Name;
  112. treeViewCategory.TreeViewCategories = GetTreeCategoryItem(categories, category.Id);
  113. response.Add(treeViewCategory);
  114. }
  115. }
  116. return response;
  117. }
  118. private List<CategoriesNamesResponse> GetCategoriesFromUserCategories(List<UserCategories> userCategories)
  119. {
  120. var res = new List<CategoriesNamesResponse>();
  121. for (int i = 0; i < userCategories.Count; i++)
  122. {
  123. res.Add(_mapper.Map<CategoriesNamesResponse>(userCategories[i].Category));
  124. }
  125. return res;
  126. }
  127. private async Task<List<CategoriesNamesResponse>> GetByParentChild(int categoryId)
  128. {
  129. var categories = await _context.Categories.Include(x => x.ParentCategory).ToListAsync();
  130. var categoryById = categories.Where(x => x.Id == categoryId).FirstOrDefault();
  131. List<CategoriesNamesResponse> dto = new();
  132. while (true)
  133. {
  134. if (categoryById == null) break;
  135. dto.Add(new CategoriesNamesResponse
  136. {
  137. Id = categoryById.Id,
  138. Name = categoryById.Name
  139. });
  140. categoryById = categoryById.ParentCategory;
  141. }
  142. dto.Reverse();
  143. return dto;
  144. }
  145. private async Task<List<CategoriesNamesResponse>> GetChildCategories(int parentCategoryId, int userId, string role)
  146. {
  147. if (role == "SuperAdmin")
  148. return _mapper.Map<List<CategoriesNamesResponse>>(
  149. await _context.Categories
  150. .Where(k => k.ParentCategory != null && k.ParentCategory.Id == parentCategoryId)
  151. .ToListAsync());
  152. var userCategories = await _context.UserCategories
  153. .Where(k => k.UserId == userId && k.Category != null && k.Category.ParentCategory != null && k.Category.ParentCategory.Id == parentCategoryId)
  154. .Include(t => t.Category)
  155. .ToListAsync();
  156. return GetCategoriesFromUserCategories(userCategories);
  157. }
  158. private async Task<List<Category>> getCategoriesUserCanSee(int userId)
  159. {
  160. var k = await _context.UserCategories.Include(c => c.Category).ThenInclude(p => p.ParentCategory).Where(t => t.UserId == userId).ToListAsync();
  161. List<Category> t = new();
  162. foreach (var m in k)
  163. {
  164. Category category = m.Category;
  165. while (true)
  166. {
  167. bool s = false;
  168. for (int i = 0; i < k.Count; i++)
  169. {
  170. if (category.Id == k[i].CategoryId)
  171. {
  172. s = true;
  173. break;
  174. }
  175. }
  176. if (s && category.ParentCategory is null)
  177. {
  178. t.Add(m.Category);
  179. break;
  180. }
  181. else if (!s && category.ParentCategory is null)
  182. {
  183. break;
  184. }
  185. else if (s == true)
  186. {
  187. category = category.ParentCategory;
  188. continue;
  189. }
  190. else
  191. {
  192. break;
  193. }
  194. }
  195. }
  196. return t;
  197. }
  198. private List<TreeViewCategoryResponse> GetTreeCategoryItem(List<Category> items, int id)
  199. {
  200. List<TreeViewCategoryResponse> response = new();
  201. foreach (var item in items)
  202. {
  203. if(item.ParentCategory != null && item.ParentCategory.Id == id)
  204. {
  205. TreeViewCategoryResponse treeViewCategory = new();
  206. treeViewCategory.Id = item.Id;
  207. treeViewCategory.Name = item.Name;
  208. treeViewCategory.TreeViewCategories = GetTreeCategoryItem(items, item.Id);
  209. response.Add(treeViewCategory);
  210. }
  211. }
  212. return response;
  213. }
  214. public async Task CreateAsync(CreateCategoryDto createCategoryDto, int userId)
  215. {
  216. Category category = null;
  217. if(createCategoryDto.ParentId != null)
  218. {
  219. category = await _context.Categories.Where(x => x.Id == createCategoryDto.ParentId).FirstOrDefaultAsync();
  220. }
  221. var newCategory = new Category { Name = createCategoryDto.Name, ParentCategory = category };
  222. await _context.Categories.AddAsync(newCategory);
  223. await _context.SaveChangesAsync();
  224. await _userService.GrantCategoryToUserAsync(new GrantUserCategoryRequestDto {
  225. UserId = userId, Categories = new List<GrantCategoryToUserRequestDto> {
  226. new GrantCategoryToUserRequestDto { Id = newCategory.Id, IsChecked = true }
  227. }
  228. });
  229. }
  230. }
  231. }