|
|
|
@ -36,6 +36,8 @@ namespace Shentun.Peis.LisRequests |
|
|
|
private readonly IRepository<Asbitem, Guid> _asbitemRepository; |
|
|
|
private readonly ILisRequestReportRepository _lisRequestReportRepository; |
|
|
|
private readonly LisRequestManager _lisRequestManager; |
|
|
|
private readonly IRepository<SampleGroup, Guid> _sampleGroupRepository; |
|
|
|
private readonly IRepository<SampleGroupDetail> _sampleGroupDetailRepository; |
|
|
|
private readonly CacheService _cacheService; |
|
|
|
private readonly IRepository<CustomerOrg, Guid> _customerOrgRepository; |
|
|
|
private readonly CustomerOrgManager _customerOrgManager; |
|
|
|
@ -54,7 +56,9 @@ namespace Shentun.Peis.LisRequests |
|
|
|
IRepository<RegisterCheck, Guid> registerCheckRepository, |
|
|
|
IRepository<Asbitem, Guid> asbitemRepository, |
|
|
|
IRepository<SampleContainer, Guid> sampleContainerRepository, |
|
|
|
IRepository<SampleType, Guid> sampleTypeRepository |
|
|
|
IRepository<SampleType, Guid> sampleTypeRepository, |
|
|
|
IRepository<SampleGroup, Guid> sampleGroupRepository, |
|
|
|
IRepository<SampleGroupDetail> sampleGroupDetailRepository |
|
|
|
) |
|
|
|
{ |
|
|
|
this._userRepository = userRepository; |
|
|
|
@ -70,6 +74,8 @@ namespace Shentun.Peis.LisRequests |
|
|
|
_asbitemRepository = asbitemRepository; |
|
|
|
_sampleContainerRepository = sampleContainerRepository; |
|
|
|
_sampleTypeRepository = sampleTypeRepository; |
|
|
|
_sampleGroupRepository = sampleGroupRepository; |
|
|
|
_sampleGroupDetailRepository = sampleGroupDetailRepository; |
|
|
|
} |
|
|
|
|
|
|
|
[HttpPost("api/app/LisRequest/GetListInFilter")] |
|
|
|
@ -182,7 +188,7 @@ namespace Shentun.Peis.LisRequests |
|
|
|
SampleContainerName = patient.sampleContainer.DisplayName, |
|
|
|
ContainerColor = patient.sampleContainer.ContainerColor, |
|
|
|
SampleContainerRemark = patient.sampleContainer.ContainerRemark, |
|
|
|
AsbitemName = string.Join(",", patientList.OrderBy(o=>o.asbitem.DisplayOrder).Select(o=> o.asbitem.DisplayName ).Distinct()), |
|
|
|
AsbitemNames = string.Join(",", patientList.OrderBy(o=>o.asbitem.DisplayOrder).Select(o=> o.asbitem.DisplayName ).Distinct()), |
|
|
|
CustomerOrgName = _cacheService.GetTopCustomerOrgAsync(patient.patientRegister.CustomerOrgId).Result.DisplayName, |
|
|
|
DepartmentName = _cacheService.GetCustomerOrgNameAsync(patient.patientRegister.CustomerOrgId).Result |
|
|
|
}; |
|
|
|
@ -194,7 +200,151 @@ namespace Shentun.Peis.LisRequests |
|
|
|
return result; |
|
|
|
} |
|
|
|
|
|
|
|
[HttpPost("api/app/LisRequest/GetListByFilter")] |
|
|
|
public async Task<PagedResultDto<LisRequestDto>> GetListByFilterAsync(GetLisRequestListDto input) |
|
|
|
{ |
|
|
|
//var customerOrgList = await _customerOrgRepository.GetListAsync();
|
|
|
|
|
|
|
|
//Stopwatch stopwatch = Stopwatch.StartNew();
|
|
|
|
//stopwatch.Start();
|
|
|
|
|
|
|
|
#region MyRegion
|
|
|
|
var patientRegisterQuery = (await _patientRegisterRepository.GetQueryableAsync()).Include(x => x.Patient).AsQueryable(); |
|
|
|
|
|
|
|
if (!string.IsNullOrEmpty(input.PatientNo)) |
|
|
|
patientRegisterQuery = patientRegisterQuery.Where(m => m.Patient.PatientNo == input.PatientNo); |
|
|
|
|
|
|
|
if (!string.IsNullOrEmpty(input.IdNo)) |
|
|
|
patientRegisterQuery = patientRegisterQuery.Where(m => m.Patient.IdNo == input.IdNo); |
|
|
|
|
|
|
|
if (!string.IsNullOrEmpty(input.PatientName)) |
|
|
|
patientRegisterQuery = patientRegisterQuery.Where(m => !string.IsNullOrEmpty(m.PatientName) && m.PatientName.Contains(input.PatientName)); |
|
|
|
|
|
|
|
if (!string.IsNullOrEmpty(input.PatientRegisterNo)) |
|
|
|
patientRegisterQuery = patientRegisterQuery.Where(m => m.PatientRegisterNo == input.PatientRegisterNo); |
|
|
|
|
|
|
|
if (!string.IsNullOrEmpty(input.Phone)) |
|
|
|
patientRegisterQuery = patientRegisterQuery.Where(m => m.Patient.MobileTelephone == input.Phone || m.Patient.Telephone == input.Phone); |
|
|
|
|
|
|
|
if (input.SexId != null && input.SexId != ForSexFlag.All) |
|
|
|
patientRegisterQuery = patientRegisterQuery.Where(m => m.SexId == input.SexId); |
|
|
|
|
|
|
|
if (input.EndDate == null) |
|
|
|
input.EndDate = DateTime.Now; |
|
|
|
|
|
|
|
if (input.StartDate != null && input.EndDate != null) |
|
|
|
patientRegisterQuery = patientRegisterQuery.Where(m => m.CreationTime >= input.StartDate && |
|
|
|
m.CreationTime < ((DateTime)input.EndDate).AddDays(1)); |
|
|
|
|
|
|
|
|
|
|
|
if (input.CustomerOrgId != null) |
|
|
|
{ |
|
|
|
var CustomerOrgIds = await _customerOrgManager.GetCustomerOrgChildrenId(input.CustomerOrgId.Value); |
|
|
|
patientRegisterQuery = patientRegisterQuery.Where(m => CustomerOrgIds.Contains(m.CustomerOrgId)); |
|
|
|
} |
|
|
|
|
|
|
|
if (input.CustomerOrgRegisterId != null && input.CustomerOrgRegisterId != Guid.Empty) |
|
|
|
{ |
|
|
|
patientRegisterQuery = patientRegisterQuery.Where(m => m.CustomerOrgRegisterId == input.CustomerOrgRegisterId); |
|
|
|
} |
|
|
|
patientRegisterQuery.Where(o => o.CompleteFlag != PatientRegisterCompleteFlag.PreRegistration); |
|
|
|
#endregion
|
|
|
|
|
|
|
|
|
|
|
|
int totalCount = patientRegisterQuery.Count(); |
|
|
|
|
|
|
|
patientRegisterQuery = patientRegisterQuery.Skip(input.SkipCount * input.MaxResultCount).Take(input.MaxResultCount); |
|
|
|
var patientRegisterList = patientRegisterQuery.ToList(); |
|
|
|
if (patientRegisterList.Count > 10000) |
|
|
|
{ |
|
|
|
throw new UserFriendlyException("选择的人员数不能超过1万条"); |
|
|
|
} |
|
|
|
var sampleGroups = await _sampleGroupRepository.GetListAsync(); |
|
|
|
var _sampleGroupDetail = await _sampleGroupDetailRepository.GetListAsync(); |
|
|
|
var patientRegisterRequests = ( |
|
|
|
from patientRegister in patientRegisterQuery |
|
|
|
join registerCheck in await _registerCheckRepository.GetQueryableAsync() |
|
|
|
on patientRegister.Id equals registerCheck.PatientRegisterId |
|
|
|
join registerCheckAsbitem in await _registerCheckAsbitemRepository.GetQueryableAsync() |
|
|
|
on registerCheck.Id equals registerCheckAsbitem.RegisterCheckId |
|
|
|
select new |
|
|
|
{ |
|
|
|
patientRegister, |
|
|
|
registerCheckAsbitem |
|
|
|
}).ToList(); |
|
|
|
//生成LIS申请数据
|
|
|
|
var patientRegisters = patientRegisterRequests.Select(o=>o.patientRegister).Distinct().ToList(); |
|
|
|
var createLisRequestList = new List<LisRequest>(); |
|
|
|
var updateRegisterCheckAsbitemList = new List<RegisterCheckAsbitem>(); |
|
|
|
foreach (var patientRegister in patientRegisters) |
|
|
|
{ |
|
|
|
var registerCheckAsbitems = patientRegisterRequests.Select(o=>o.registerCheckAsbitem) |
|
|
|
.Where(o => o.PatientRegisterId == patientRegister.Id).Distinct().ToList(); |
|
|
|
_lisRequestManager.Create(patientRegister, registerCheckAsbitems, sampleGroups, _sampleGroupDetail |
|
|
|
, out var updateRegisterCheckAsbitems, out var createLisRequests); |
|
|
|
createLisRequestList.AddRange(createLisRequests); |
|
|
|
updateRegisterCheckAsbitemList.AddRange(updateRegisterCheckAsbitems); |
|
|
|
} |
|
|
|
await _lisRequestReportRepository.InsertManyAsync(createLisRequestList,true); |
|
|
|
await _registerCheckAsbitemRepository.UpdateManyAsync(updateRegisterCheckAsbitemList, true); |
|
|
|
|
|
|
|
//返回检索到的数据
|
|
|
|
var list = (from patient in await _patientRepository.GetQueryableAsync() |
|
|
|
join patientRegister in patientRegisterQuery |
|
|
|
on patient.Id equals patientRegister.PatientId |
|
|
|
join registerCheck in await _registerCheckRepository.GetQueryableAsync() |
|
|
|
on patientRegister.Id equals registerCheck.PatientRegisterId |
|
|
|
join registerCheckAsbitem in await _registerCheckAsbitemRepository.GetQueryableAsync() |
|
|
|
on registerCheck.Id equals registerCheckAsbitem.RegisterCheckId |
|
|
|
join asbitem in await _asbitemRepository.GetQueryableAsync() |
|
|
|
on registerCheckAsbitem.AsbitemId equals asbitem.Id |
|
|
|
join lisRequest in await _lisRequestReportRepository.GetQueryableAsync() |
|
|
|
on registerCheckAsbitem.LisRequestId equals lisRequest.Id |
|
|
|
join sampleContainer in await _sampleContainerRepository.GetQueryableAsync() |
|
|
|
on lisRequest.SampleContainerId equals sampleContainer.Id |
|
|
|
join sampleType in await _sampleTypeRepository.GetQueryableAsync() |
|
|
|
on lisRequest.SampleTypeId equals sampleType.Id |
|
|
|
select new |
|
|
|
{ |
|
|
|
patient, |
|
|
|
patientRegister, |
|
|
|
asbitem, |
|
|
|
lisRequest, |
|
|
|
sampleContainer, |
|
|
|
sampleType |
|
|
|
|
|
|
|
}).ToList(); |
|
|
|
var lisRequestIds = list.Select(o => new { Id = o.lisRequest.Id }).Distinct().ToList(); |
|
|
|
|
|
|
|
var lisRequestDtoList = new List<LisRequestDto>(); |
|
|
|
foreach (var lisRequestId in lisRequestIds) |
|
|
|
{ |
|
|
|
var patientList = list.Where(o => o.lisRequest.Id == lisRequestId.Id).Distinct().ToList(); |
|
|
|
var patient = patientList.First(); |
|
|
|
var lisRequestDto = new LisRequestDto() |
|
|
|
{ |
|
|
|
Id = lisRequestId.Id, |
|
|
|
LisRequestNo = patient.lisRequest.LisRequestNo, |
|
|
|
PatientNo = patient.patient.PatientNo, |
|
|
|
PatientRegisterNo = patient.patientRegister.PatientRegisterNo, |
|
|
|
PatientName = patient.patientRegister.PatientName, |
|
|
|
SexName = _cacheService.GetSexNameAsync(patient.patientRegister.SexId).Result, |
|
|
|
Age = patient.patientRegister.Age, |
|
|
|
SampleTypeName = patient.sampleType.DisplayName, |
|
|
|
SampleContainerName = patient.sampleContainer.DisplayName, |
|
|
|
ContainerColor = patient.sampleContainer.ContainerColor, |
|
|
|
SampleContainerRemark = patient.sampleContainer.ContainerRemark, |
|
|
|
AsbitemNames = string.Join(",", patientList.OrderBy(o => o.asbitem.DisplayOrder).Select(o => o.asbitem.DisplayName).Distinct()), |
|
|
|
CustomerOrgName = _cacheService.GetTopCustomerOrgAsync(patient.patientRegister.CustomerOrgId).Result.DisplayName, |
|
|
|
DepartmentName = _cacheService.GetCustomerOrgNameAsync(patient.patientRegister.CustomerOrgId).Result |
|
|
|
}; |
|
|
|
lisRequestDtoList.Add(lisRequestDto); |
|
|
|
} |
|
|
|
lisRequestDtoList = lisRequestDtoList.OrderBy(o => o.PatientNo).ToList(); |
|
|
|
var result = new PagedResultDto<LisRequestDto>(patientRegisterList.Count, lisRequestDtoList); |
|
|
|
|
|
|
|
return result; |
|
|
|
} |
|
|
|
/// <summary>
|
|
|
|
/// 生成检验申请单 首次自动生成
|
|
|
|
/// </summary>
|
|
|
|
|