insignia4
Some checks failed
release-dev / release-dev (push) Failing after 14s

This commit is contained in:
kittapath 2025-02-13 17:20:58 +07:00
parent 077d20a779
commit 764a27fbd5
2 changed files with 88 additions and 3 deletions

View file

@ -1536,6 +1536,67 @@ namespace BMA.EHR.Application.Repositories.Reports
return insignia;
}
public async Task<dynamic> GetKhr4TotalReport(Guid id, string type = null, int node = -1, Guid nodeId = default)
{
var period = await _dbContext.Set<InsigniaNote>()
.FirstOrDefaultAsync(x => x.Id == id);
if (period == null)
throw new Exception(GlobalMessages.InsigniaPeriodNotFound);
var data_insigniaQuery = _dbContext.Set<InsigniaNoteProfile>()
.Include(x => x.RequestInsignia)
.ThenInclude(x => x.InsigniaType)
.Where(x => x.InsigniaNote.Id == period.Id)
.Where(x => x.Status == "DONE")
.Where(x => x.RequestInsignia.InsigniaType != null);
if (type == "officer")
{
data_insigniaQuery = data_insigniaQuery.Where(r => r.ProfileType.Trim().ToUpper() == "OFFICER");
}
else if (type == "employee")
{
data_insigniaQuery = data_insigniaQuery.Where(r => r.ProfileType.Trim().ToUpper() == "EMPLOYEE");
}
switch (node)
{
case 0:
data_insigniaQuery = data_insigniaQuery.Where(r => r.RootDnaId == nodeId);
break;
case 1:
data_insigniaQuery = data_insigniaQuery.Where(r => r.Child1DnaId == nodeId);
break;
case 2:
data_insigniaQuery = data_insigniaQuery.Where(r => r.Child2DnaId == nodeId);
break;
case 3:
data_insigniaQuery = data_insigniaQuery.Where(r => r.Child3DnaId == nodeId);
break;
case 4:
data_insigniaQuery = data_insigniaQuery.Where(r => r.Child4DnaId == nodeId);
break;
default:
break;
}
var data = await data_insigniaQuery.Select(x => new
{
CitizenId = x.CitizenId,
FullName = $"{x.Prefix}{x.FirstName} {x.LastName}",
PosTypeName = x.PosTypeName,
PosLevelName = x.PosLevelName,
Position = x.Position,
Root = x.Root
}).ToListAsync();
return data;
}
#endregion
}
}