OrderRequestRepository.cs 2.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758
  1. using Microsoft.EntityFrameworkCore;
  2. using MTWorkHR.Core.Entities;
  3. using MTWorkHR.Core.IDto;
  4. using MTWorkHR.Core.IRepositories;
  5. using MTWorkHR.Infrastructure.Entities;
  6. using MTWorkHR.Infrastructure.DBContext;
  7. using MTWorkHR.Core.Entities.User;
  8. namespace MTWorkHR.Infrastructure.Repositories
  9. {
  10. public class OrderRequestRepository : Repository<OrderRequest>, IOrderRequestRepository
  11. {
  12. private readonly DbSet<OrderRequest> dbSet;
  13. public OrderRequestRepository(HRDataContext context) : base(context)
  14. {
  15. dbSet = context.Set<OrderRequest>();
  16. }
  17. public async Task<OrderRequest> GetByIdWithAllChildren(long id)
  18. {
  19. return await dbSet
  20. .Include(x => x.OrderType)
  21. .Include(x=> x.LeaveType)
  22. .Include(x => x.BusinessTripExpenses).ThenInclude(x=> x.Attachments)
  23. .Include(x => x.ServiceCertificate)
  24. .Include(x => x.OrderAttachments)
  25. .Include(x => x.OverTimeDays).ThenInclude(x=> x.OverTimeAttachment)
  26. .AsNoTracking()
  27. .FirstOrDefaultAsync(x => x.Id == id);
  28. }
  29. public async Task<OrderRequest> GetByIdWithTypes(long id)
  30. {
  31. return await dbSet
  32. .Include(x => x.OrderType)
  33. .Include(x => x.LeaveType)
  34. .AsNoTracking()
  35. .FirstOrDefaultAsync(x => x.Id == id);
  36. }
  37. public async Task<Tuple<IQueryable<OrderRequest>, int>> GetAllWithChildrenAsync()
  38. {
  39. var query = dbSet.Include(x => x.OrderType).Include(x=> x.LeaveType).AsNoTracking().AsQueryable();
  40. var total = await query.CountAsync();
  41. return new Tuple<IQueryable<OrderRequest>, int>(query, total);
  42. }
  43. public async Task<Tuple<IQueryable<OrderRequest>, int>> GetAllUserOrdersAsync(string userId, long contractId)
  44. {
  45. var query = dbSet.Include(x => x.OrderType).Include(x => x.LeaveType).Where(a=> a.RequestingEmployeeId == userId && a.ContractId == contractId).AsNoTracking().AsQueryable();
  46. var total = await query.CountAsync();
  47. return new Tuple<IQueryable<OrderRequest>, int>(query, total);
  48. }
  49. }
  50. }