using Microsoft.AspNetCore.Identity; using Microsoft.AspNetCore.WebUtilities; using Microsoft.EntityFrameworkCore; using Microsoft.Extensions.Configuration; using MTWorkHR.Application.Identity; using MTWorkHR.Application.Mapper; using MTWorkHR.Application.Models; using MTWorkHR.Core.Global; using MTWorkHR.Core.IRepositories; using MTWorkHR.Core.UnitOfWork; using MTWorkHR.Infrastructure.Entities; using MTWorkHR.Application.Services.Interfaces; using MTWorkHR.Core.Email; using MTWorkHR.Core.Entities; using System.Linq.Dynamic.Core; using System.Linq; namespace MTWorkHR.Application.Services { public class AttendanceService : BaseService, IAttendanceService { private readonly IUnitOfWork _unitOfWork; private readonly GlobalInfo _globalInfo; public AttendanceService(IUnitOfWork unitOfWork, GlobalInfo globalInfo) :base(unitOfWork) { _unitOfWork = unitOfWork; _globalInfo = globalInfo; } public async Task> GetAll(AttendancePagingInputDto PagingInputDto) { var res = await _unitOfWork.Attendance.GetAllWithChildrenAsync(); var query = res.Item1; if (_globalInfo.UserType != UserTypeEnum.Business) { query = query.Where(m => m.UserId == _globalInfo.UserId); } if (PagingInputDto.Filter != null) { var filter = PagingInputDto.Filter; query = query.Where(u => u.LeaveReason!.Contains(filter) || u.UserName!.Contains(filter)); } if (PagingInputDto.SearchDate != null) { query = query.Where(u => u.AttendanceDate.Date == PagingInputDto.SearchDate.Value.Date); } if (PagingInputDto.UserId != null) { query = query.Where(u => u.UserId == PagingInputDto.UserId); } //var dayGroupByUser = query.GroupBy(m => new { m.UserId, m.UserName, AttendanceDate = m.AttendanceDate.Date }).Select // (g => new Attendance // { // UserId = g.Key.UserId, // UserName = g.Key.UserName, // AttendanceDate = g.Key.AttendanceDate, // TotalHours = g.Sum(s => (s.CheckInTime.HasValue && s.CheckOutTime.HasValue) ? (s.CheckOutTime.Value - s.CheckInTime.Value).TotalHours : 0) // }); var order = query.OrderBy(PagingInputDto.OrderByField + " " + PagingInputDto.OrderType); var page = order.Skip((PagingInputDto.PageNumber * PagingInputDto.PageSize) - PagingInputDto.PageSize).Take(PagingInputDto.PageSize); var total = await query.CountAsync(); var list = MapperObject.Mapper .Map>(await page.ToListAsync()); //var dayGroupByUser = list.GroupBy(m => new { m.UserId,m.WeekDay, m.UserName, AttendanceDate = m.AttendanceDate.Date }).Select // (g => new AttendanceDto { // UserId = g.Key.UserId, UserName=g.Key.UserName, // WeekDay= g.Key.WeekDay, // AttendanceDate = g.Key.AttendanceDate, // TotalHours = g.Sum(s=> s.TotalHours) // }).ToList(); var response = new PagingResultDto { Result = list , //Result = ! string.IsNullOrEmpty( PagingInputDto.UserId ) ? list : dayGroupByUser, Total = total }; return response; } public override async Task Create(AttendanceDto input) { var oldEntity = await _unitOfWork.Attendance.GetAttendanceByUserId(input.UserId, input.AttendanceDate); if (oldEntity is null) { var entitiy = MapperObject.Mapper.Map(input); if (entitiy is null) throw new AppException(ExceptionEnum.MapperIssue); var newEntity = await _unitOfWork.Attendance.AddAsync(entitiy); var Success = await _unitOfWork.CompleteAsync(); var response = Mapper.MapperObject.Mapper.Map(newEntity); return response; } else { var response = Mapper.MapperObject.Mapper.Map(oldEntity); return response; } } public override async Task Update(AttendanceDto input) { Attendance? entity = null; if (input.Id > 0) entity = await _unitOfWork.Attendance.GetByIdAsync(input.Id); else entity = await _unitOfWork.Attendance.GetAttendanceByUserId(input.UserId, input.AttendanceDate); if (entity is null) throw new AppException(ExceptionEnum.RecordNotExist); entity.CheckOutTime = input.CheckOutTime; entity.LeaveType = input.LeaveType; entity.LeaveReason = input.LeaveReason; await _unitOfWork.CompleteAsync(); var response = Mapper.MapperObject.Mapper.Map(entity); return response; } } }