using BMA.EHR.Application.Common.Interfaces; using BMA.EHR.Application.Messaging; using BMA.EHR.Domain.Models.Leave.TimeAttendants; using Microsoft.AspNetCore.Http; using Microsoft.EntityFrameworkCore; using Microsoft.Extensions.Configuration; namespace BMA.EHR.Application.Repositories.Leaves.TimeAttendants { public class ProcessUserTimeStampRepository : GenericLeaveRepository { #region " Fields " private readonly ILeaveDbContext _dbContext; 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 " public ProcessUserTimeStampRepository(ILeaveDbContext dbContext, 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 != "") return _userProfileRepository.GetUserOCId(Guid.Parse(UserId!)); else return Guid.Empty; } } #endregion #region " Methods " public bool IsEditRequest(Guid userId, DateTime checkDate) { try { var data = _dbContext.Set().AsQueryable() .FirstOrDefault(x => x.KeycloakUserId == userId && x.CheckDate.Date == checkDate.Date); return !(data == null); } catch { throw; } } public async Task Copy() { var userTimeStamps = await _dbContext.Set().ToListAsync(); foreach (var u in userTimeStamps) { var p = new ProcessUserTimeStamp { KeycloakUserId = u.KeycloakUserId, CheckIn = u.CheckIn, CheckInLat = u.CheckInLat, CheckInLon = u.CheckInLon, CheckInPOI = u.CheckInPOI, CheckInImageUrl = u.CheckInImageUrl, IsLocationCheckIn = u.IsLocationCheckIn, CheckInLocationName = u.CheckInLocationName, CheckInRemark = u.CheckInRemark, CheckOut = u.CheckOut, CheckOutLat = u.CheckOutLat, CheckOutLon = u.CheckOutLon, CheckOutPOI = u.CheckOutPOI, CheckOutImageUrl = u.CheckOutImageUrl, IsLocationCheckOut = u.IsLocationCheckOut, CheckOutLocationName = u.CheckOutLocationName, CheckOutRemark = u.CheckOutRemark, }; _dbContext.Set().Add(p); } await _dbContext.SaveChangesAsync(); } public async Task CountRecordAsync() { var data = await _dbContext.Set().CountAsync(); return data; } public async Task GetTimestampByDateAsync(Guid keycloakId, DateTime date) { var data = await _dbContext.Set() .Where(u => u.KeycloakUserId == keycloakId) .Where(u => u.CheckIn.Date == date.Date) .FirstOrDefaultAsync(); return data; } public async Task GetLastRecord(Guid keycloakId) { var data = await _dbContext.Set() .Where(u => u.KeycloakUserId == keycloakId) .OrderByDescending(u => u.CheckIn) .FirstOrDefaultAsync(); return data; } public async Task> GetTimeStampHistoryAsync(Guid keycloakId, int year, int page = 1, int pageSize = 10, string keyword = "") { var data = await _dbContext.Set() .Where(u => u.KeycloakUserId == keycloakId) .Where(u => u.CheckIn.Year == year) .OrderByDescending(u => u.CheckIn.Date) .Skip((page - 1) * pageSize) .Take(pageSize) .ToListAsync(); return data; } public async Task GetTimeStampHistoryForAdminCountAsync(DateTime startDate, DateTime endDate) { var data = await _dbContext.Set() .Where(u => u.CheckIn.Date >= startDate.Date && u.CheckIn.Date <= endDate.Date) .ToListAsync(); return data.Count; } public async Task> GetTimeStampHistoryByRangeForUserAsync(Guid userId, DateTime startDate, DateTime endDate) { var data = await _dbContext.Set() .Where(x => x.KeycloakUserId == userId) .Where(u => u.CheckIn.Date >= startDate.Date && u.CheckIn.Date <= endDate.Date) .ToListAsync(); return data; } public async Task> GetTimeStampHistoryForAdminAsync(DateTime startDate, DateTime endDate) { var data = await _dbContext.Set() .Where(u => u.CheckIn.Date >= startDate.Date && u.CheckIn.Date <= endDate.Date) .OrderBy(u => u.CheckIn) .ToListAsync(); return data; } public async Task GetTimeStampById(Guid id) { var data = await _dbContext.Set() .Where(u => u.Id == id) .FirstOrDefaultAsync(); return data; } #endregion } }