UserTaskRepository.cs 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849
  1. using Microsoft.EntityFrameworkCore;
  2. using MTWorkHR.Core.Entities;
  3. using MTWorkHR.Core.IDto;
  4. using MTWorkHR.Infrastructure.Entities;
  5. using MTWorkHR.Infrastructure.DBContext;
  6. using MTWorkHR.Core.IRepositories;
  7. namespace MTWorkHR.Infrastructure.Repositories
  8. {
  9. public class UserTaskRepository : Repository<UserTask>, IUserTaskRepository
  10. {
  11. private readonly DbSet<UserTask> dbSet;
  12. public UserTaskRepository(HRDataContext context) : base(context)
  13. {
  14. dbSet = context.Set<UserTask>();
  15. }
  16. public async Task<UserTask> GetByIdWithAllChildren(long id)
  17. {
  18. return await dbSet
  19. .Include(x => x.TaskAttachments).ThenInclude(a => a.AttachmentType)
  20. .Include(x => x.UserTaskHistories)
  21. .Include(x => x.TaskStatus)
  22. .Include(x => x.Project)
  23. .FirstOrDefaultAsync(x => x.Id == id);
  24. }
  25. public async Task<UserTask> GetByUserIdWithAllChildren(string userId)
  26. {
  27. return await dbSet
  28. .Include(x => x.TaskAttachments).ThenInclude(a => a.AttachmentType)
  29. .Include(x => x.UserTaskHistories)
  30. .Include(x => x.TaskStatus)
  31. .Include(x => x.Project)
  32. .FirstOrDefaultAsync(x => x.AssignedUserId == userId);
  33. }
  34. public async Task<Tuple<IQueryable<UserTask>, int>> GetAllWithChildrenAsync()
  35. {
  36. var query = dbSet.Include(x => x.Project).AsQueryable();
  37. var total = await query.CountAsync();
  38. return new Tuple<IQueryable<UserTask>, int>(query, total);
  39. }
  40. }
  41. }