Add Holiday and WeekEnd Function

This commit is contained in:
Suphonchai Phoonsawat 2024-01-22 09:07:18 +07:00
parent 89d4d677de
commit 3b4a641525
2 changed files with 26 additions and 2 deletions

View file

@ -26,6 +26,17 @@ namespace BMA.EHR.Application.Repositories.MetaData
#region " Methods "
public async Task<List<DateTime>> GetHolidayAsync(DateTime startDate, DateTime endDate, string category = "NORMAL")
{
var data = await _dbContext.Set<Holiday>().AsQueryable()
.Where(x => x.Category == category)
.Where(x => x.HolidayDate.Date >= startDate && x.HolidayDate.Date <= endDate)
.Select(x => x.HolidayDate.Date)
.ToListAsync();
return data;
}
public async Task<int> GetHolidayCountAsync(DateTime startDate, DateTime endDate, string category = "NORMAL")
{
var data = await _dbContext.Set<Holiday>().AsQueryable()
@ -36,6 +47,21 @@ namespace BMA.EHR.Application.Repositories.MetaData
return data;
}
public List<DateTime> GetWeekEnd(DateTime startDate, DateTime endDate, string category = "NORMAL")
{
var dates = new List<DateTime>();
for (DateTime i = startDate; i <= endDate; i = i.AddDays(1))
{
dates.Add(i);
}
if (category == "NORMAL")
return dates.Where(d => d.DayOfWeek == DayOfWeek.Saturday || d.DayOfWeek == DayOfWeek.Sunday).ToList();
else
return dates.Where(d => d.DayOfWeek == DayOfWeek.Sunday).ToList();
}
public int GetWeekEndCount(DateTime startDate, DateTime endDate, string category = "NORMAL")
{
var dates = new List<DateTime>();