OrderRequestRepository.cs 1.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445
  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.BusinessTripExpenses)
  22. .Include(x => x.ServiceCertificate)
  23. .FirstOrDefaultAsync(x => x.Id == id);
  24. }
  25. public async Task<Tuple<IQueryable<OrderRequest>, int>> GetAllWithChildrenAsync()
  26. {
  27. var query = dbSet.Include(x => x.OrderType).Include(x=> x.LeaveType).AsQueryable();
  28. var total = await query.CountAsync();
  29. return new Tuple<IQueryable<OrderRequest>, int>(query, total);
  30. }
  31. public async Task<Tuple<IQueryable<OrderRequest>, int>> GetAllUserOrdersAsync(string userId, long contractId)
  32. {
  33. var query = dbSet.Include(x => x.OrderType).Include(x => x.LeaveType).Where(a=> a.RequestingEmployeeId == userId && a.ContractId == contractId).AsQueryable();
  34. var total = await query.CountAsync();
  35. return new Tuple<IQueryable<OrderRequest>, int>(query, total);
  36. }
  37. }
  38. }