修改访视
parent
e9b389ab3e
commit
009fcae3d8
|
@ -3366,7 +3366,7 @@
|
|||
<param name="trialConfig"></param>
|
||||
<returns></returns>
|
||||
</member>
|
||||
<member name="T:IRaCIS.Core.Application.Triggers.AddVisitPlanTrigger">
|
||||
<member name="T:IRaCIS.Core.Application.Triggers.AddSubjectTrigger">
|
||||
<summary>
|
||||
添加访视计划 要给改项目下的所有Subject 添加该访视
|
||||
</summary>
|
||||
|
|
|
@ -55,24 +55,6 @@ namespace IRaCIS.Application.Services
|
|||
mapedSubject= await _subjectRepository.InsertFromDTOAsync(subjectCommand, false, verifyExp1);
|
||||
|
||||
|
||||
//添加受试者的时候,获取访视计划列表,添加到受试者访视表。
|
||||
var visitPlan = await _repository.Where<VisitStage>(t => t.TrialId == subjectCommand.TrialId&&t.IsConfirmed).ToListAsync();
|
||||
|
||||
svlist = _mapper.Map<List<SubjectVisit>>(visitPlan);
|
||||
|
||||
var IsEnrollementQualificationConfirm = await _repository.Where<Trial>(t => t.Id == mapedSubject.TrialId).Select(u => u.IsEnrollementQualificationConfirm).FirstOrDefaultAsync();
|
||||
|
||||
svlist.ForEach(t =>
|
||||
{
|
||||
t.Subject = mapedSubject;
|
||||
t.SubjectId = mapedSubject.Id;
|
||||
t.TrialId = subjectCommand.TrialId;
|
||||
t.SiteId = subjectCommand.SiteId;
|
||||
t.IsEnrollmentConfirm = t.IsBaseLine ? IsEnrollementQualificationConfirm : false;
|
||||
});
|
||||
|
||||
|
||||
await _subjectVisitRepository.AddRangeAsync(svlist);
|
||||
}
|
||||
else //update
|
||||
{
|
||||
|
|
|
@ -23,10 +23,10 @@ namespace IRaCIS.Application.Services
|
|||
private readonly IRepository<Subject> _subjectRepository;
|
||||
private readonly IRepository<VisitPlanInfluenceStat> _visitPlanInfluenceStatRepository;
|
||||
|
||||
|
||||
|
||||
|
||||
public VisitPlanService(IRepository<VisitStage> visitStageRepository, IRepository<Trial> trialRepository, IRepository<SubjectVisit> subjectVisitRepository,
|
||||
IRepository<VisitPlanInfluenceStudy> visitPlanInfluenceStudy,IRepository<Subject> subjectRepository, IRepository<VisitPlanInfluenceStat> visitPlanInfluenceStatRepository)
|
||||
IRepository<VisitPlanInfluenceStudy> visitPlanInfluenceStudy, IRepository<Subject> subjectRepository, IRepository<VisitPlanInfluenceStat> visitPlanInfluenceStatRepository)
|
||||
{
|
||||
_visitStageRepository = visitStageRepository;
|
||||
_trialRepository = trialRepository;
|
||||
|
@ -128,7 +128,6 @@ namespace IRaCIS.Application.Services
|
|||
{
|
||||
var trial = (await _trialRepository.FirstOrDefaultAsync(t => t.Id == visitPlan.TrialId)).IfNullThrowException();
|
||||
|
||||
trial.VisitPlanConfirmed = false;
|
||||
|
||||
if (await _visitStageRepository.AnyAsync(t => t.TrialId == visitPlan.TrialId && (t.VisitName == visitPlan.VisitName || t.VisitNum == visitPlan.VisitNum), true))
|
||||
{
|
||||
|
@ -228,17 +227,6 @@ namespace IRaCIS.Application.Services
|
|||
trial.VisitPlanConfirmed = true;
|
||||
|
||||
|
||||
var subjects = _subjectRepository.Where(x => x.TrialId == trialId).Select(x => new
|
||||
{
|
||||
x.Code,
|
||||
x.SiteId,
|
||||
x.Id,
|
||||
x.IsEnrollment,
|
||||
x.IsUrgent,
|
||||
x.TrialId
|
||||
|
||||
});
|
||||
|
||||
#region 统一给Subject 增加访视任务
|
||||
|
||||
//首次确认时 IsHaveFirstConfirmed都为false 不需要给Subject 加访视
|
||||
|
@ -250,26 +238,39 @@ namespace IRaCIS.Application.Services
|
|||
|
||||
foreach (var visitPlan in addvisitStages)
|
||||
{
|
||||
foreach (var subject in subjects)
|
||||
{
|
||||
var addSv = _mapper.Map<SubjectVisit>(visitPlan);
|
||||
|
||||
addSv.SubjectId = subject.Id;
|
||||
addSv.TrialId = subject.TrialId;
|
||||
addSv.SiteId = subject.SiteId;
|
||||
var subjectSVS = await _subjectVisitRepository.Where(t => t.TrialId == visitPlan.TrialId).Select(t => new { t.SubjectId, t.SiteId, t.IsFinalVisit }).Distinct().ToListAsync();
|
||||
|
||||
var subjectList = subjectSVS.Select(t => new { t.SubjectId, t.SiteId }).Distinct().ToList();
|
||||
|
||||
foreach (var subject in subjectList)
|
||||
{
|
||||
|
||||
var svItem = _mapper.Map<SubjectVisit>(visitPlan);
|
||||
svItem.SiteId = subject.SiteId;
|
||||
svItem.SubjectId = subject.SubjectId;
|
||||
|
||||
//设置了末次访视,那么加访视计划的时候,设置为不可用
|
||||
if (subjectSVS.Any(t => t.SubjectId == svItem.SubjectId && t.IsFinalVisit))
|
||||
{
|
||||
svItem.VisitExecuted = VisitExecutedEnum.Unavailable;
|
||||
}
|
||||
|
||||
//再加一层保险,防止重复
|
||||
if (!await _subjectVisitRepository.AnyAsync(t => t.VisitStageId == visitPlan.Id && t.SubjectId == subject.Id))
|
||||
if (!await _subjectVisitRepository.AnyAsync(t => t.VisitStageId == visitPlan.Id && t.SubjectId == subject.SubjectId))
|
||||
{
|
||||
subjectVisits.Add(addSv);
|
||||
await _subjectVisitRepository.AddAsync(svItem);
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
|
||||
await _subjectVisitRepository.AddRangeAsync(subjectVisits);
|
||||
}
|
||||
|
||||
|
||||
|
||||
#endregion
|
||||
|
||||
|
||||
|
|
|
@ -0,0 +1,90 @@
|
|||
using AutoMapper;
|
||||
using EntityFrameworkCore.Triggered;
|
||||
using IRaCIS.Core.Domain.Share;
|
||||
using MassTransit;
|
||||
|
||||
namespace IRaCIS.Core.Application.Triggers
|
||||
{
|
||||
/// <summary>
|
||||
/// 添加访视计划 要给改项目下的所有Subject 添加该访视
|
||||
/// </summary>
|
||||
public class AddSubjectTrigger : IBeforeSaveTrigger<Subject>
|
||||
{
|
||||
private readonly IRepository<SubjectVisit> _subjectVisitRepository;
|
||||
|
||||
private readonly IRepository<VisitStage> _visitStageRepository;
|
||||
private readonly IRepository<Trial> _trialRepository;
|
||||
private readonly IMapper _mapper;
|
||||
|
||||
public AddSubjectTrigger(IRepository<SubjectVisit> subjectVisitRepository, IMapper mapper, IRepository<VisitStage> visitStageRepository, IRepository<Trial> trialRepository)
|
||||
{
|
||||
_subjectVisitRepository = subjectVisitRepository;
|
||||
_trialRepository = trialRepository;
|
||||
|
||||
_visitStageRepository = visitStageRepository;
|
||||
_mapper = mapper;
|
||||
}
|
||||
|
||||
public async Task BeforeSave(ITriggerContext<Subject> context, CancellationToken cancellationToken)
|
||||
{
|
||||
var subject = context.Entity;
|
||||
|
||||
if (context.ChangeType == ChangeType.Added)
|
||||
{
|
||||
|
||||
|
||||
|
||||
//添加受试者的时候,获取访视计划列表,添加到受试者访视表。
|
||||
var visitPlanList = await _visitStageRepository.Where(t => t.TrialId == subject.TrialId && t.IsConfirmed).ToListAsync();
|
||||
|
||||
var svList = _mapper.Map<List<SubjectVisit>>(visitPlanList);
|
||||
|
||||
var IsEnrollementQualificationConfirm = await _trialRepository.Where(t => t.Id == subject.TrialId).Select(u => u.IsEnrollementQualificationConfirm).FirstOrDefaultAsync();
|
||||
|
||||
svList.ForEach(t =>
|
||||
{
|
||||
t.Subject = subject;
|
||||
t.SubjectId = subject.Id;
|
||||
t.TrialId = subject.TrialId;
|
||||
t.SiteId = subject.SiteId;
|
||||
t.IsEnrollmentConfirm = t.IsBaseLine ? IsEnrollementQualificationConfirm : false;
|
||||
});
|
||||
|
||||
|
||||
await _subjectVisitRepository.AddRangeAsync(svList);
|
||||
|
||||
|
||||
#region 在f访视计划确认的时候处理 给subject添加访视计划
|
||||
////已添加受试者 都不存在该新增的计划名称 那么该项目所有受试者都增加一个访视记录
|
||||
//if (!await _subjectVisitRepository.AnyAsync(t => t.VisitName == visitPlan.VisitName && t.TrialId == visitPlan.TrialId))
|
||||
//{
|
||||
// var subjectSVS = await _subjectVisitRepository.Where(t => t.TrialId == visitPlan.TrialId).Select(t => new { t.SubjectId, t.SiteId, t.IsFinalVisit }).Distinct().ToListAsync();
|
||||
|
||||
// var subjects = subjectSVS.Select(t => new { t.SubjectId, t.SiteId }).Distinct().ToList();
|
||||
|
||||
// foreach (var subject in subjects)
|
||||
// {
|
||||
|
||||
// var svItem = _mapper.Map<SubjectVisit>(visitPlan);
|
||||
// svItem.SiteId = subject.SiteId;
|
||||
// svItem.SubjectId = subject.SubjectId;
|
||||
// svItem.Id = NewId.NextGuid();
|
||||
|
||||
// //设置了末次访视,那么加访视计划的时候,设置为不可用
|
||||
// if (subjectSVS.Any(t => t.SubjectId == svItem.SubjectId && t.IsFinalVisit))
|
||||
// {
|
||||
// svItem.VisitExecuted = VisitExecutedEnum.Unavailable;
|
||||
// }
|
||||
|
||||
// await _subjectVisitRepository.AddAsync(svItem);
|
||||
// }
|
||||
|
||||
// await _subjectVisitRepository.SaveChangesAsync();
|
||||
//}
|
||||
#endregion
|
||||
|
||||
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
|
@ -1,58 +0,0 @@
|
|||
using AutoMapper;
|
||||
using EntityFrameworkCore.Triggered;
|
||||
using IRaCIS.Core.Domain.Share;
|
||||
using MassTransit;
|
||||
|
||||
namespace IRaCIS.Core.Application.Triggers
|
||||
{
|
||||
/// <summary>
|
||||
/// 添加访视计划 要给改项目下的所有Subject 添加该访视
|
||||
/// </summary>
|
||||
public class AddVisitPlanTrigger : IAfterSaveTrigger<VisitStage>
|
||||
{
|
||||
private readonly IRepository<SubjectVisit> _subjectVisitRepository;
|
||||
private readonly IMapper _mapper;
|
||||
|
||||
public AddVisitPlanTrigger(IRepository<SubjectVisit> subjectVisitRepository,IMapper mapper)
|
||||
{
|
||||
_subjectVisitRepository = subjectVisitRepository;
|
||||
_mapper = mapper;
|
||||
}
|
||||
|
||||
public async Task AfterSave(ITriggerContext<VisitStage> context, CancellationToken cancellationToken)
|
||||
{
|
||||
var visitPlan = context.Entity;
|
||||
|
||||
if (context.ChangeType == ChangeType.Added)
|
||||
{
|
||||
//已添加受试者 都不存在该新增的计划名称 那么该项目所有受试者都增加一个访视记录
|
||||
if (!await _subjectVisitRepository.AnyAsync(t => t.VisitName == visitPlan.VisitName && t.TrialId == visitPlan.TrialId))
|
||||
{
|
||||
var subjectSVS = await _subjectVisitRepository.Where(t => t.TrialId == visitPlan.TrialId).Select(t => new { t.SubjectId, t.SiteId, t.IsFinalVisit }).Distinct().ToListAsync();
|
||||
|
||||
var subjects = subjectSVS.Select(t => new { t.SubjectId, t.SiteId }).Distinct().ToList();
|
||||
|
||||
foreach (var subject in subjects)
|
||||
{
|
||||
|
||||
var svItem = _mapper.Map<SubjectVisit>(visitPlan);
|
||||
svItem.SiteId = subject.SiteId;
|
||||
svItem.SubjectId = subject.SubjectId;
|
||||
svItem.Id = NewId.NextGuid();
|
||||
|
||||
//设置了末次访视,那么加访视计划的时候,设置为不可用
|
||||
if (subjectSVS.Any(t => t.SubjectId == svItem.SubjectId && t.IsFinalVisit))
|
||||
{
|
||||
svItem.VisitExecuted = VisitExecutedEnum.Unavailable;
|
||||
}
|
||||
|
||||
await _subjectVisitRepository.AddAsync(svItem);
|
||||
}
|
||||
|
||||
await _subjectVisitRepository.SaveChangesAsync();
|
||||
}
|
||||
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue