AttendanceService.cs 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231
  1. using Microsoft.AspNetCore.Identity;
  2. using Microsoft.AspNetCore.WebUtilities;
  3. using Microsoft.EntityFrameworkCore;
  4. using Microsoft.Extensions.Configuration;
  5. using MTWorkHR.Application.Identity;
  6. using MTWorkHR.Application.Mapper;
  7. using MTWorkHR.Application.Models;
  8. using MTWorkHR.Core.Global;
  9. using MTWorkHR.Core.IRepositories;
  10. using MTWorkHR.Core.UnitOfWork;
  11. using MTWorkHR.Infrastructure.Entities;
  12. using MTWorkHR.Application.Services.Interfaces;
  13. using MTWorkHR.Core.Email;
  14. using MTWorkHR.Core.Entities;
  15. using System.Linq.Dynamic.Core;
  16. using System.Linq;
  17. using Microsoft.AspNetCore.Http;
  18. using MTWorkHR.Core.Entities.Base;
  19. namespace MTWorkHR.Application.Services
  20. {
  21. public class AttendanceService : BaseService<Attendance, AttendanceDto, AttendanceDto>, IAttendanceService
  22. {
  23. private readonly IUnitOfWork _unitOfWork;
  24. private readonly GlobalInfo _globalInfo;
  25. private readonly IUserService _userService;
  26. public AttendanceService(IUnitOfWork unitOfWork, GlobalInfo globalInfo, IUserService userService) :base(unitOfWork)
  27. {
  28. _unitOfWork = unitOfWork;
  29. _globalInfo = globalInfo;
  30. _userService = userService;
  31. }
  32. public async Task<PagingResultDto<AttendanceDto>> GetAll(AttendancePagingInputDto PagingInputDto)
  33. {
  34. var res = await _unitOfWork.Attendance.GetAllWithChildrenAsync();
  35. var query = res.Item1;
  36. if (_globalInfo.UserType != UserTypeEnum.Business)
  37. {
  38. query = query.Where(m => m.UserId == _globalInfo.UserId);
  39. }
  40. if (PagingInputDto.Filter != null)
  41. {
  42. var filter = PagingInputDto.Filter;
  43. query = query.Where(u => u.LeaveReason!.Contains(filter) || u.UserName!.Contains(filter));
  44. }
  45. if (PagingInputDto.SearchDate != null)
  46. {
  47. query = query.Where(u => u.AttendanceDate.Date == PagingInputDto.SearchDate.Value.Date);
  48. }
  49. if (PagingInputDto.UserId != null)
  50. {
  51. query = query.Where(u => u.UserId == PagingInputDto.UserId);
  52. }
  53. var order = query.OrderBy(PagingInputDto.OrderByField + " " + PagingInputDto.OrderType);
  54. var page = order.Skip((PagingInputDto.PageNumber * PagingInputDto.PageSize) - PagingInputDto.PageSize).Take(PagingInputDto.PageSize);
  55. var total = await query.CountAsync();
  56. var list = MapperObject.Mapper
  57. .Map<IList<AttendanceDto>>(await page.ToListAsync());
  58. // var employeesListx = list.Select(a => a.UserId).Distinct();
  59. var employeesList = await _userService.GetAllCompanyEmployees();
  60. Dictionary<string, UserBasicInfoDto> employeeDictList = new Dictionary<string, UserBasicInfoDto>();
  61. List<AttendanceDto> attendanceResult = new List<AttendanceDto>();
  62. if (string.IsNullOrEmpty(PagingInputDto.UserId))
  63. {
  64. if (PagingInputDto.UserName != null)
  65. {
  66. //employeesList = employeesList.Where(u => u.FirstName.Contains(PagingInputDto.UserName) || u.LastName.Contains(PagingInputDto.UserName) ||
  67. //u.UserName.Contains(PagingInputDto.UserName) || u.Email.Contains(PagingInputDto.UserName)
  68. //).ToList();
  69. var filter = PagingInputDto.UserName;
  70. var filters = filter.Split(" ");
  71. var firstNameFilter = filters[0];
  72. var lastNameFilter = filters.Length > 1 ? filters[1] : "";
  73. employeesList = employeesList.Where(u =>
  74. u.UserName.Contains(filter) || u.Email.Contains(filter) || u.FavoriteName.Contains(filter) || u.FirstName.Contains(filter) || u.LastName.Contains(filter) ||
  75. u.FirstName.Contains(firstNameFilter) && (string.IsNullOrEmpty(lastNameFilter) || u.LastName.Contains(lastNameFilter)) ||
  76. u.LastName.Contains(lastNameFilter) && (string.IsNullOrEmpty(firstNameFilter) || u.FirstName.Contains(firstNameFilter))
  77. ).ToList();
  78. }
  79. foreach (var employee in employeesList)
  80. {
  81. var latestAttendance = list.LastOrDefault(a => a.UserId == employee.Id);
  82. var user = await _userService.GetUserWithAttachmentById(employee.Id);
  83. if (user != null)
  84. {
  85. var entitiy = MapperObject.Mapper.Map<UserBasicInfoDto>(user);
  86. //item.Employee = entitiy;
  87. var attach = user.UserAttachments?.FirstOrDefault(a => a.AttachmentTypeId == 9);
  88. if (attach != null)
  89. using (var stream = new MemoryStream(attach.Content))
  90. {
  91. var file = new FormFile(stream, 0, stream.Length, Path.GetFileNameWithoutExtension(attach.FileName), attach.FilePath)
  92. {
  93. Headers = new HeaderDictionary(),
  94. ContentType = attach.ContentType,
  95. };
  96. System.Net.Mime.ContentDisposition cd = new System.Net.Mime.ContentDisposition
  97. {
  98. FileName = file.FileName
  99. };
  100. file.ContentDisposition = cd.ToString();
  101. entitiy.ProfileImage = file;
  102. }
  103. employeeDictList.Add(employee.Id, entitiy);
  104. if (latestAttendance != null)
  105. latestAttendance.Employee = entitiy;
  106. else
  107. {
  108. latestAttendance = new AttendanceDto { UserId = employee.Id, UserName = employee.UserName, Employee = entitiy };
  109. }
  110. attendanceResult.Add(latestAttendance);
  111. }
  112. }
  113. }
  114. else
  115. {
  116. var user = await _userService.GetUserWithAttachmentById(PagingInputDto.UserId);
  117. if (user != null)
  118. {
  119. var entitiy = MapperObject.Mapper.Map<UserBasicInfoDto>(user);
  120. foreach (var item in list)
  121. {
  122. var attach = user.UserAttachments?.FirstOrDefault(a => a.AttachmentTypeId == 9);
  123. if (attach != null)
  124. using (var stream = new MemoryStream(attach.Content))
  125. {
  126. var file = new FormFile(stream, 0, stream.Length, Path.GetFileNameWithoutExtension(attach.FileName), attach.FilePath)
  127. {
  128. Headers = new HeaderDictionary(),
  129. ContentType = attach.ContentType,
  130. };
  131. System.Net.Mime.ContentDisposition cd = new System.Net.Mime.ContentDisposition
  132. {
  133. FileName = file.FileName
  134. };
  135. file.ContentDisposition = cd.ToString();
  136. entitiy.ProfileImage = file;
  137. }
  138. item.Employee = entitiy;
  139. }
  140. }
  141. }
  142. var response = new PagingResultDto<AttendanceDto>
  143. {
  144. Result = !string.IsNullOrEmpty(PagingInputDto.UserId) ? list : attendanceResult,
  145. //Result = ! string.IsNullOrEmpty( PagingInputDto.UserId ) ? list : dayGroupByUser,
  146. Total = !string.IsNullOrEmpty(PagingInputDto.UserId) ? total : attendanceResult.Count //total
  147. };
  148. return response;
  149. }
  150. public override async Task<AttendanceDto> Create(AttendanceDto input)
  151. {
  152. if (input.CheckInTime.HasValue)
  153. input.AttendanceDate = input.CheckInTime.Value.Date;
  154. var oldEntity = await _unitOfWork.Attendance.GetAttendanceByUserId(input.UserId, input.AttendanceDate);
  155. if (oldEntity is null)
  156. {
  157. var entitiy = MapperObject.Mapper.Map<Attendance>(input);
  158. if (entitiy is null)
  159. throw new AppException(ExceptionEnum.MapperIssue);
  160. var newEntity = await _unitOfWork.Attendance.AddAsync(entitiy);
  161. var Success = await _unitOfWork.CompleteAsync();
  162. var response = Mapper.MapperObject.Mapper.Map<AttendanceDto>(newEntity);
  163. return response;
  164. }
  165. else
  166. {
  167. throw new AppException(ExceptionEnum.UserAlreadyCheckedIn);
  168. var response = Mapper.MapperObject.Mapper.Map<AttendanceDto>(oldEntity);
  169. return response;
  170. }
  171. }
  172. public override async Task<AttendanceDto> Update(AttendanceDto input)
  173. {
  174. Attendance? entity = null;
  175. if (input.CheckInTime.HasValue)
  176. input.AttendanceDate = input.CheckInTime.Value.Date;
  177. else if (input.CheckOutTime.HasValue)
  178. input.AttendanceDate = input.CheckOutTime.Value.Date;
  179. if (input.Id > 0)
  180. entity = await _unitOfWork.Attendance.GetByIdAsync(input.Id);
  181. else
  182. entity = await _unitOfWork.Attendance.GetAttendanceByUserId(input.UserId, input.AttendanceDate);
  183. if (entity is null)
  184. throw new AppException(ExceptionEnum.RecordNotExist);
  185. entity.CheckOutTime = input.CheckOutTime;
  186. entity.LeaveType = input.LeaveType;
  187. entity.LeaveReason = input.LeaveReason;
  188. await _unitOfWork.CompleteAsync();
  189. var response = Mapper.MapperObject.Mapper.Map<AttendanceDto>(entity);
  190. return response;
  191. }
  192. public async Task<AttendanceDto?> GetAttendanceByUserId(string userId, DateTime attendanceDate)
  193. {
  194. var entity = await _unitOfWork.Attendance.GetAttendanceByUserId(userId, attendanceDate);
  195. if (entity is null)
  196. return null;
  197. var response = Mapper.MapperObject.Mapper.Map<AttendanceDto>(entity);
  198. return response;
  199. }
  200. }
  201. }