diff --git a/IRaCIS.Core.Application/Triggers/SubjectVisitCheckPassedTrigger.cs b/IRaCIS.Core.Application/Triggers/SubjectVisitCheckPassedTrigger.cs index 5c7a110a..0bf325a0 100644 --- a/IRaCIS.Core.Application/Triggers/SubjectVisitCheckPassedTrigger.cs +++ b/IRaCIS.Core.Application/Triggers/SubjectVisitCheckPassedTrigger.cs @@ -11,38 +11,25 @@ namespace IRaCIS.Core.Application.Triggers /// /// 处理 访视 末次评估 会影响Subject 状态 /// - public class SubjectVisitCheckPassedTrigger : IAfterSaveTrigger + public class SubjectVisitCheckPassedTrigger : IBeforeSaveTrigger { - private readonly IRepository _subjectVisitRepository; - private readonly IRepository _visitTaskRepository; - - private readonly IRepository _trialRepository; - private readonly IRepository _taskAllocationRuleRepository; - - private readonly IEasyCachingProvider _provider; + private readonly IVisitTaskHelpeService _visitTaskHelpeService; - private readonly IMapper _mapper; - public SubjectVisitCheckPassedTrigger(IRepository subjectVisitRepository, IRepository visitTaskRepository, - IRepository trialRepository, - IRepository taskAllocationRuleRepository, - IEasyCachingProvider provider, - IVisitTaskHelpeService visitTaskHelpeService, - IMapper mapper) + public SubjectVisitCheckPassedTrigger( + + IVisitTaskHelpeService visitTaskHelpeService) { - _subjectVisitRepository = subjectVisitRepository; - _visitTaskRepository = visitTaskRepository; - _provider = provider; - _mapper = mapper; - _taskAllocationRuleRepository = taskAllocationRuleRepository; - _trialRepository = trialRepository; + + _visitTaskHelpeService = visitTaskHelpeService; } - public async Task AfterSave(ITriggerContext context, CancellationToken cancellationToken) - { + + public async Task BeforeSave(ITriggerContext context, CancellationToken cancellationToken) + { var subjectVisit = context.Entity; @@ -53,196 +40,12 @@ namespace IRaCIS.Core.Application.Triggers if (context.UnmodifiedEntity?.CheckState != subjectVisit.CheckState && subjectVisit.CheckState == CheckStateEnum.CVPassed) { - #region 产生任务并分配 暂时废弃 - - //if (_taskAllocationRuleRepository.Where(t => t.TrialId == subjectVisit.TrialId && t.IsEnable).Count() < 2) - //{ - // throw new BusinessValidationFailedException("能参与读片的医生数量必须大于2,自动分配任务中止"); - //} - - //var dbMaxCode = _visitTaskRepository.Where(t => t.TrialId == subjectVisit.TrialId).Select(t => t.Code).DefaultIfEmpty().Max(); - - //var cacheMaxCodeInt = _provider.Get($"{subjectVisit.TrialId }_{ StaticData.CacheKey.TaskMaxCode}").Value; - - //int currentMaxCodeInt = cacheMaxCodeInt > dbMaxCode ? cacheMaxCodeInt : dbMaxCode; - - //_provider.Set($"{subjectVisit.TrialId }_{ StaticData.CacheKey.TaskMaxCode}", currentMaxCodeInt + 2, TimeSpan.FromMinutes(30)); - - //var trialConfig = (await _trialRepository.Where(t => t.Id == subjectVisit.TrialId).Select(t => new { TrialId = t.Id, t.ReadingType, t.TaskAllocateDefaultState, t.TaskAllocateObjEnum }).FirstOrDefaultAsync()).IfNullThrowException(); - - ////统计当前医生分配信息 有效医生数量必须大于2 已做验证 - //var allocateStat = _taskAllocationRuleRepository.Where(t => t.TrialId == subjectVisit.TrialId && t.IsEnable).ProjectTo(_mapper.ConfigurationProvider).ToList(); - - //if (trialConfig.ReadingType == ReadingMethod.Double) - //{ - - // //每个访视 根据项目配置生成任务 双审生成两个 - // var task1 = await _visitTaskRepository.AddAsync(new VisitTask() - // { - // TrialId = subjectVisit.TrialId, - // SubjectId = subjectVisit.SubjectId, - // IsUrgent = subjectVisit.IsUrgent, - // TaskBlindName = subjectVisit.BlindName, - // TaskName = subjectVisit.VisitName, - // CheckPassedTime = subjectVisit.CheckPassedTime, - // ArmEnum = 1,//特殊 - // Code = currentMaxCodeInt + 1, - // TaskCode = AppSettings.GetCodeStr(currentMaxCodeInt + 1, nameof(VisitTask)), - // ReadingCategory = ReadingCategory.Visit - // }); - - // var task2 = await _visitTaskRepository.AddAsync(new VisitTask() - // { - // TrialId = subjectVisit.TrialId, - // SubjectId = subjectVisit.SubjectId, - // IsUrgent = subjectVisit.IsUrgent, - // TaskBlindName = subjectVisit.BlindName, - // TaskName = subjectVisit.VisitName, - // CheckPassedTime = subjectVisit.CheckPassedTime, - // ArmEnum = 2,//特殊 - // Code = currentMaxCodeInt + 2, - // TaskCode = AppSettings.GetCodeStr(currentMaxCodeInt + 2, nameof(VisitTask)), - // ReadingCategory = ReadingCategory.Visit - // }); - - - // if (trialConfig.TaskAllocateDefaultState == TaskAllocateDefaultState.Allocated) - // { - // task1.TaskAllocationState = TaskAllocationState.Allocated; - // task2.TaskAllocationState = TaskAllocationState.Allocated; - // } - // else if (trialConfig.TaskAllocateDefaultState == TaskAllocateDefaultState.InitAllocated) - // { - // task1.TaskAllocationState = TaskAllocationState.InitAllocated; - // task2.TaskAllocationState = TaskAllocationState.InitAllocated; - // } - - // if (trialConfig.TaskAllocateObjEnum == TaskAllocateObj.Subject) - // { - - // //该Subject 之前是否有已分配的 如果改变配置 可能会出现 一个Subject 分配的同一个医生 有的在Arm1 有的在Arm2 - // var allocateSubjectArmList = _visitTaskRepository.Where(t => t.SubjectId == subjectVisit.SubjectId && t.TrialId == subjectVisit.TrialId && t.DoctorUserId != null).Select(t => new { t.DoctorUserId, t.ArmEnum }).Distinct().ToList(); - - // //初次自动分配 - // if (allocateSubjectArmList.Count == 0) - // { - // //排除已经入选其他Arm的阅片人 - - // //是否有做过Arm1的医生 没有新的医生未分配 - // if (allocateStat.Any(t => t.ArmList.Any(t => t == 1)) && !allocateStat.Any(t => t.ArmList.Count == 0)) - // { - - // task1.DoctorUserId = allocateStat.Where(t => t.ArmList.Any(t => t == 1)).OrderByDescending(t => t.TotalTaskCount * t.PlanReadingRatio * 0.01 - t.SelfTaskCount).ThenByDescending(t => t.PlanReadingRatio).FirstOrDefault().DoctorUserId; - - // } - // else - // { - // //找到最优的需要分配任务的医生 - // task1.DoctorUserId = allocateStat.OrderByDescending(t => t.TotalTaskCount * t.PlanReadingRatio * 0.01 - t.SelfTaskCount).ThenByDescending(t => t.PlanReadingRatio).FirstOrDefault().DoctorUserId; - - // //分配之后,加入进去 - // allocateStat.FirstOrDefault(t => t.DoctorUserId == task1.DoctorUserId).ArmList.Add(1); - // } - - - // //是否有做过Arm2的医生 有新的医生未分配 按照最优法找 - // if (allocateStat.Any(t => t.ArmList.Any(t => t == 2)) && !allocateStat.Any(t => t.ArmList.Count == 0)) - // { - - // task2.DoctorUserId = allocateStat.Where(t => t.ArmList.Any(t => t == 2)).OrderByDescending(t => t.TotalTaskCount * t.PlanReadingRatio * 0.01 - t.SelfTaskCount).ThenByDescending(t => t.PlanReadingRatio).FirstOrDefault().DoctorUserId; - // } - // else - // { - // //找到最优的需要分配任务的医生 - // task2.DoctorUserId = allocateStat.OrderByDescending(t => t.TotalTaskCount * t.PlanReadingRatio * 0.01 - t.SelfTaskCount).ThenByDescending(t => t.PlanReadingRatio).Skip(1).FirstOrDefault().DoctorUserId; - // } - - // } - // else - // { - // if (allocateSubjectArmList.GroupBy(t => t.DoctorUserId).Any(g => g.Count() == 2)) - // { - // throw new BusinessValidationFailedException("请确认是否改了配置,导致同一受试者 分配给同一个医生 在不同的Arm,无法完成自动分配"); - // } - - // //手动分配的时候 如果只分配了Arm1 没有分配Arm2 就会有问题 - // if (!(allocateSubjectArmList.Any(t => t.ArmEnum == 1) && allocateSubjectArmList.Any(t => t.ArmEnum == 2))) - // { - // throw new BusinessValidationFailedException("请确认是否改了配置,或者手动分配时,只分配了一个Arm "); - // } - - // //分配给对应Arm的人 - // task1.DoctorUserId = allocateSubjectArmList.FirstOrDefault(t => t.ArmEnum == 1).DoctorUserId; - // task2.DoctorUserId = allocateSubjectArmList.FirstOrDefault(t => t.ArmEnum == 2).DoctorUserId; - // } - - // task1.AllocateTime = DateTime.Now; - // task2.AllocateTime = DateTime.Now; - // } - - //} - //else if (trialConfig.ReadingType == ReadingMethod.Single) - //{ - // var singleTask = await _visitTaskRepository.AddAsync(new VisitTask() - // { - // TrialId = subjectVisit.TrialId, - // SubjectId = subjectVisit.SubjectId, - // IsUrgent = subjectVisit.IsUrgent, - // TaskBlindName = subjectVisit.BlindName, - // TaskName = subjectVisit.VisitName, - // CheckPassedTime = subjectVisit.CheckPassedTime, - // ArmEnum = 0, //特殊 - // Code = currentMaxCodeInt + 1, - // TaskCode = AppSettings.GetCodeStr(currentMaxCodeInt + 1, nameof(VisitTask)), - // ReadingCategory = ReadingCategory.Visit - // }); - - // if (trialConfig.TaskAllocateDefaultState == TaskAllocateDefaultState.Allocated) - // { - // singleTask.TaskAllocationState = TaskAllocationState.Allocated; - // } - // else if (trialConfig.TaskAllocateDefaultState == TaskAllocateDefaultState.InitAllocated) - // { - // singleTask.TaskAllocationState = TaskAllocationState.InitAllocated; - // } - - // if (trialConfig.TaskAllocateObjEnum == TaskAllocateObj.Subject) - // { - // //该Subject 之前是否有已分配的 如果改变配置 可能会出现 一个Subject 分配的同一个医生 有的在Arm1 有的在Arm2 - // var allocateSubjectArmList = _visitTaskRepository.Where(t => t.SubjectId == subjectVisit.SubjectId && t.TrialId == subjectVisit.TrialId && t.DoctorUserId != null).Select(t => new { t.DoctorUserId, t.ArmEnum }).Distinct().ToList(); - - // //初次自动分配 - // if (allocateSubjectArmList.Count == 0) - // { - // singleTask.DoctorUserId = allocateStat.OrderByDescending(t => t.TotalTaskCount * t.PlanReadingRatio * 0.01 - t.SelfTaskCount).ThenByDescending(t => t.PlanReadingRatio).FirstOrDefault().DoctorUserId; - // } - // else - // { - // singleTask.DoctorUserId = allocateSubjectArmList.FirstOrDefault(t => t.ArmEnum == 0).DoctorUserId; - // } - - - // } - - //} - - - //await _visitTaskRepository.SaveChangesAsync(); - - #endregion - context.Entity.IsPMBackOrReReading = false; await _visitTaskHelpeService.GenerateVisitTaskAsync(subjectVisit.TrialId, new List() { subjectVisit.Id }, true); } } - } - - - - - } } \ No newline at end of file