2023-11-09 14:35:08 +07:00
|
|
|
|
using BMA.EHR.Application.Common.Interfaces;
|
|
|
|
|
|
using BMA.EHR.Application.Messaging;
|
2023-11-13 16:56:17 +07:00
|
|
|
|
using BMA.EHR.Domain.Extensions;
|
2023-11-10 14:40:53 +07:00
|
|
|
|
using BMA.EHR.Domain.Models.Leave.TimeAttendants;
|
2023-11-09 14:35:08 +07:00
|
|
|
|
using Microsoft.AspNetCore.Http;
|
2023-11-09 15:07:19 +07:00
|
|
|
|
using Microsoft.EntityFrameworkCore;
|
2023-11-09 14:35:08 +07:00
|
|
|
|
using Microsoft.Extensions.Configuration;
|
|
|
|
|
|
|
2023-11-10 14:40:53 +07:00
|
|
|
|
namespace BMA.EHR.Application.Repositories.Leaves.TimeAttendants
|
2023-11-09 14:35:08 +07:00
|
|
|
|
{
|
2023-11-13 16:56:17 +07:00
|
|
|
|
public class UserTimeStampRepository : GenericLeaveRepository<Guid, UserTimeStamp>
|
2023-11-09 14:35:08 +07:00
|
|
|
|
{
|
|
|
|
|
|
#region " Fields "
|
|
|
|
|
|
|
2023-11-13 16:56:17 +07:00
|
|
|
|
private readonly ILeaveDbContext _dbContext;
|
2023-11-09 14:35:08 +07:00
|
|
|
|
private readonly IHttpContextAccessor _httpContextAccessor;
|
|
|
|
|
|
private readonly OrganizationCommonRepository _organizationCommonRepository;
|
|
|
|
|
|
private readonly UserProfileRepository _userProfileRepository;
|
|
|
|
|
|
private readonly IConfiguration _configuration;
|
|
|
|
|
|
private readonly EmailSenderService _emailSenderService;
|
|
|
|
|
|
|
|
|
|
|
|
#endregion
|
|
|
|
|
|
|
|
|
|
|
|
#region " Constructor and Destuctor "
|
|
|
|
|
|
|
2023-11-13 16:56:17 +07:00
|
|
|
|
public UserTimeStampRepository(ILeaveDbContext dbContext,
|
2023-11-09 14:35:08 +07:00
|
|
|
|
IHttpContextAccessor httpContextAccessor,
|
|
|
|
|
|
OrganizationCommonRepository organizationCommonRepository,
|
|
|
|
|
|
UserProfileRepository userProfileRepository,
|
|
|
|
|
|
IConfiguration configuration,
|
|
|
|
|
|
EmailSenderService emailSenderService) : base(dbContext, httpContextAccessor)
|
|
|
|
|
|
{
|
|
|
|
|
|
_dbContext = dbContext;
|
|
|
|
|
|
_httpContextAccessor = httpContextAccessor;
|
|
|
|
|
|
_organizationCommonRepository = organizationCommonRepository;
|
|
|
|
|
|
_userProfileRepository = userProfileRepository;
|
|
|
|
|
|
_configuration = configuration;
|
|
|
|
|
|
_emailSenderService = emailSenderService;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
#endregion
|
|
|
|
|
|
|
|
|
|
|
|
#region " Properties "
|
|
|
|
|
|
|
|
|
|
|
|
protected Guid UserOrganizationId
|
|
|
|
|
|
{
|
|
|
|
|
|
get
|
|
|
|
|
|
{
|
|
|
|
|
|
if (UserId != null || UserId != "")
|
2024-06-20 13:37:25 +07:00
|
|
|
|
return _userProfileRepository.GetUserOCId(Guid.Parse(UserId!), AccessToken);
|
2023-11-09 14:35:08 +07:00
|
|
|
|
else
|
|
|
|
|
|
return Guid.Empty;
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
#endregion
|
2023-11-09 15:07:19 +07:00
|
|
|
|
|
|
|
|
|
|
#region " Methods "
|
|
|
|
|
|
|
2023-11-23 10:35:55 +07:00
|
|
|
|
public async Task<int> CountRecordAsync()
|
|
|
|
|
|
{
|
|
|
|
|
|
var data = await _dbContext.Set<UserTimeStamp>().CountAsync();
|
|
|
|
|
|
|
|
|
|
|
|
return data;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public async Task<UserTimeStamp?> GetTimestampByDateAsync(Guid keycloakId, DateTime date)
|
2023-11-15 14:02:21 +07:00
|
|
|
|
{
|
|
|
|
|
|
var data = await _dbContext.Set<UserTimeStamp>()
|
|
|
|
|
|
.Where(u => u.KeycloakUserId == keycloakId)
|
|
|
|
|
|
.Where(u => u.CheckIn.Date == date.Date)
|
|
|
|
|
|
.FirstOrDefaultAsync();
|
|
|
|
|
|
|
|
|
|
|
|
return data;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2026-01-30 13:35:58 +07:00
|
|
|
|
public async Task<UserTimeStamp?> GetLastRecord(Guid keycloakId, CancellationToken cancellationToken = default)
|
2023-11-09 15:07:19 +07:00
|
|
|
|
{
|
2026-01-30 13:35:58 +07:00
|
|
|
|
// กำหนด timeout เป็น 30 นาที
|
|
|
|
|
|
using var timeoutCts = new CancellationTokenSource(TimeSpan.FromMinutes(30));
|
|
|
|
|
|
using var combinedCts = CancellationTokenSource.CreateLinkedTokenSource(cancellationToken, timeoutCts.Token);
|
|
|
|
|
|
|
2023-11-10 14:40:53 +07:00
|
|
|
|
var data = await _dbContext.Set<UserTimeStamp>()
|
|
|
|
|
|
.Where(u => u.KeycloakUserId == keycloakId)
|
|
|
|
|
|
.OrderByDescending(u => u.CheckIn)
|
2026-01-30 13:35:58 +07:00
|
|
|
|
.FirstOrDefaultAsync(combinedCts.Token);
|
2023-11-10 14:40:53 +07:00
|
|
|
|
|
|
|
|
|
|
return data;
|
2023-11-09 15:07:19 +07:00
|
|
|
|
}
|
|
|
|
|
|
|
2023-11-24 14:21:33 +07:00
|
|
|
|
public async Task<List<UserTimeStamp>> GetTimeStampHistoryAsync(Guid keycloakId, int year)
|
2023-11-13 16:56:17 +07:00
|
|
|
|
{
|
|
|
|
|
|
var data = await _dbContext.Set<UserTimeStamp>()
|
|
|
|
|
|
.Where(u => u.KeycloakUserId == keycloakId)
|
2023-11-14 10:29:07 +07:00
|
|
|
|
.Where(u => u.CheckIn.Year == year)
|
2023-11-13 16:56:17 +07:00
|
|
|
|
.OrderBy(u => u.CheckIn)
|
2025-10-07 11:13:28 +07:00
|
|
|
|
|
2023-11-13 16:56:17 +07:00
|
|
|
|
.ToListAsync();
|
|
|
|
|
|
|
|
|
|
|
|
return data;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2023-11-24 14:21:33 +07:00
|
|
|
|
public async Task<List<UserTimeStamp>> GetTimeStampHistoryForAdminAsync(DateTime startDate, DateTime endDate)
|
2023-11-13 16:56:17 +07:00
|
|
|
|
{
|
|
|
|
|
|
var data = await _dbContext.Set<UserTimeStamp>()
|
2023-11-15 15:38:39 +07:00
|
|
|
|
.Where(u => u.CheckIn.Date >= startDate.Date && u.CheckIn.Date <= endDate.Date)
|
2023-11-13 16:56:17 +07:00
|
|
|
|
.OrderBy(u => u.CheckIn)
|
2025-10-07 11:13:28 +07:00
|
|
|
|
|
2023-11-13 16:56:17 +07:00
|
|
|
|
.ToListAsync();
|
|
|
|
|
|
|
|
|
|
|
|
return data;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2025-06-24 14:02:44 +07:00
|
|
|
|
public async Task<List<UserTimeStamp>> GetTimeStampHistoryForAdminRoleAsync(DateTime startDate, DateTime endDate, string role, string nodeId, int? node)
|
|
|
|
|
|
{
|
|
|
|
|
|
var data = await _dbContext.Set<UserTimeStamp>()
|
|
|
|
|
|
.Where(u => u.CheckIn.Date >= startDate.Date && u.CheckIn.Date <= endDate.Date)
|
|
|
|
|
|
.OrderBy(u => u.CheckIn)
|
|
|
|
|
|
|
|
|
|
|
|
.ToListAsync();
|
|
|
|
|
|
if (role == "OWNER")
|
|
|
|
|
|
{
|
|
|
|
|
|
node = null;
|
|
|
|
|
|
}
|
|
|
|
|
|
if (role == "OWNER" || role == "CHILD")
|
|
|
|
|
|
{
|
|
|
|
|
|
data = data
|
|
|
|
|
|
.Where(x => node == 4 ? x.Child4DnaId == Guid.Parse(nodeId!) : (node == 3 ? x.Child3DnaId == Guid.Parse(nodeId!) : (node == 2 ? x.Child2DnaId == Guid.Parse(nodeId!) : (node == 1 ? x.Child1DnaId == Guid.Parse(nodeId!) : (node == 0 ? x.RootDnaId == Guid.Parse(nodeId!) : (node == null ? true : true))))))
|
|
|
|
|
|
.ToList();
|
|
|
|
|
|
}
|
2025-12-12 01:36:06 +07:00
|
|
|
|
else if (role == "BROTHER")
|
|
|
|
|
|
{
|
|
|
|
|
|
data = data
|
|
|
|
|
|
.Where(x => node == 4 ? x.Child3DnaId == Guid.Parse(nodeId!) : (node == 3 ? x.Child2DnaId == Guid.Parse(nodeId!) : (node == 2 ? x.Child1DnaId == Guid.Parse(nodeId!) : (node == 1 || node == 0 ? x.RootDnaId == Guid.Parse(nodeId!) : (node == null ? true : true)))))
|
|
|
|
|
|
.ToList();
|
|
|
|
|
|
}
|
2025-06-24 14:02:44 +07:00
|
|
|
|
else if (role == "ROOT")
|
|
|
|
|
|
{
|
|
|
|
|
|
data = data
|
|
|
|
|
|
.Where(x => x.RootDnaId == Guid.Parse(nodeId!))
|
|
|
|
|
|
.ToList();
|
|
|
|
|
|
}
|
2025-10-07 11:13:28 +07:00
|
|
|
|
else if (role == "PARENT")
|
|
|
|
|
|
{
|
|
|
|
|
|
data = data
|
2025-10-12 16:51:51 +07:00
|
|
|
|
.Where(x => x.RootDnaId == Guid.Parse(nodeId!) && x.Child1DnaId != null)
|
2025-10-07 11:13:28 +07:00
|
|
|
|
.ToList();
|
|
|
|
|
|
}
|
2025-06-24 14:02:44 +07:00
|
|
|
|
else if (role == "NORMAL")
|
|
|
|
|
|
{
|
2025-12-06 18:03:33 +07:00
|
|
|
|
data = data.Where(x =>
|
|
|
|
|
|
node == 0 ? x.RootDnaId == Guid.Parse(nodeId!) && x.Child1DnaId == null :
|
|
|
|
|
|
node == 1 ? x.Child1DnaId == Guid.Parse(nodeId!) && x.Child2DnaId == null :
|
|
|
|
|
|
node == 2 ? x.Child2DnaId == Guid.Parse(nodeId!) && x.Child3DnaId == null :
|
|
|
|
|
|
node == 3 ? x.Child3DnaId == Guid.Parse(nodeId!) && x.Child4DnaId == null :
|
|
|
|
|
|
node == 4 ? x.Child4DnaId == Guid.Parse(nodeId!) :
|
|
|
|
|
|
true
|
|
|
|
|
|
).ToList();
|
2025-06-24 14:02:44 +07:00
|
|
|
|
}
|
|
|
|
|
|
return data;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2023-11-15 14:29:02 +07:00
|
|
|
|
public async Task<UserTimeStamp?> GetTimeStampById(Guid id)
|
|
|
|
|
|
{
|
|
|
|
|
|
var data = await _dbContext.Set<UserTimeStamp>()
|
|
|
|
|
|
.Where(u => u.Id == id)
|
|
|
|
|
|
.FirstOrDefaultAsync();
|
|
|
|
|
|
|
|
|
|
|
|
return data;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2023-11-09 15:07:19 +07:00
|
|
|
|
#endregion
|
2023-11-09 14:35:08 +07:00
|
|
|
|
}
|
|
|
|
|
|
}
|