Uat_Study
			
			
		
		
							parent
							
								
									f2cfb7b370
								
							
						
					
					
						commit
						5132d02526
					
				| 
						 | 
					@ -400,6 +400,23 @@ namespace IRaCIS.Core.Application.Service
 | 
				
			||||||
                                            //配置了医生 
 | 
					                                            //配置了医生 
 | 
				
			||||||
                                            if (assignConfigList.Count > 0)
 | 
					                                            if (assignConfigList.Count > 0)
 | 
				
			||||||
                                            {
 | 
					                                            {
 | 
				
			||||||
 | 
					                         
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					                                                #region 重阅/退回的时候,需要将取消分配的访视类型的  任务重新分配
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					                                                if (trialConfig.IsReadingTaskViewInOrder)
 | 
				
			||||||
 | 
					                                                {
 | 
				
			||||||
 | 
					                                                    //之前有回退的访视 那么当前访视一致性核查通过的时候,对后续访视不生成或者分配   当前访视生成但是不分配出去
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					                                                    var beforeBackVisitTask = await _visitTaskRepository.Where(t => t.TrialId == trialId && t.SubjectId == subjectVisit.SubjectId && t.VisitTaskNum < subjectVisit.VisitNum && t.ReadingCategory == ReadingCategory.Visit && t.SourceSubjectVisit.CheckState != CheckStateEnum.CVPassed).OrderBy(t => t.VisitTaskNum).FirstOrDefaultAsync();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					                                                    if (beforeBackVisitTask == null)
 | 
				
			||||||
 | 
					                                                    {
 | 
				
			||||||
 | 
					                                                        #region 访视2 PM 回退  基线回退  访视2先一致性核查通过,生成访视2任务,但是不分配
 | 
				
			||||||
 | 
					
 | 
				
			||||||
                                                        var defaultState = trialConfig.FollowVisitAutoAssignDefaultState == TaskAllocateDefaultState.InitAllocated ? TaskAllocationState.InitAllocated : TaskAllocationState.Allocated;
 | 
					                                                        var defaultState = trialConfig.FollowVisitAutoAssignDefaultState == TaskAllocateDefaultState.InitAllocated ? TaskAllocationState.InitAllocated : TaskAllocationState.Allocated;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
                                                        singleTask.TaskAllocationState = defaultState;
 | 
					                                                        singleTask.TaskAllocationState = defaultState;
 | 
				
			||||||
| 
						 | 
					@ -408,50 +425,50 @@ namespace IRaCIS.Core.Application.Service
 | 
				
			||||||
 | 
					
 | 
				
			||||||
                                                        singleTask.AllocateTime = DateTime.Now;
 | 
					                                                        singleTask.AllocateTime = DateTime.Now;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					                                                        #endregion
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
                                                #region 重阅/退回的时候,需要将取消分配的访视类型的  任务重新分配
 | 
					                                                        var followBackVisitTask = await _visitTaskRepository.Where(t => t.TrialId == trialId && t.SubjectId == subjectVisit.SubjectId && t.VisitTaskNum > subjectVisit.VisitNum && t.ReadingCategory == ReadingCategory.Visit && t.SourceSubjectVisit.CheckState != CheckStateEnum.CVPassed).OrderBy(t => t.VisitTaskNum).FirstOrDefaultAsync();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					                                                        //存在退回访视1  又退回基线 这种情况   生成任务  考虑基线先一致性核查通过,但是访视1还未通过时  生成任务
 | 
				
			||||||
 | 
					                                                        var followVisitTaskList = await _visitTaskRepository
 | 
				
			||||||
 | 
					                                                             .Where(t => t.TrialId == trialId && t.SubjectId == subjectVisit.SubjectId && t.VisitTaskNum > subjectVisit.VisitNum && t.SourceSubjectVisit.CheckState == CheckStateEnum.CVPassed && t.ReadingCategory == ReadingCategory.Visit, true)
 | 
				
			||||||
 | 
					                                                             .WhereIf(followBackVisitTask != null, t => t.VisitTaskNum < followBackVisitTask.VisitTaskNum)
 | 
				
			||||||
 | 
					                                                             .ToListAsync();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					                                                        var followVisitGroup = followVisitTaskList.GroupBy(t => t.VisitTaskNum);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					                                                        //每个访视去判断  是分配还是生成
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
                                                //后续未分配的访视  PM 有序退回  或者PM  有序 申请重阅
 | 
					                                                        foreach (var visitGroup in followVisitGroup)
 | 
				
			||||||
 | 
					 | 
				
			||||||
                                                var notAllocateList = await _visitTaskRepository.Where(t => t.TrialId == trialId && t.SubjectId == subjectVisit.SubjectId && t.TaskState == TaskState.Effect && t.DoctorUserId == null
 | 
					 | 
				
			||||||
                                                   && t.VisitTaskNum > subjectVisit.VisitNum && t.ReadingCategory == ReadingCategory.Visit, true).ToListAsync();
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
                                                foreach (var notAllocate in notAllocateList)
 | 
					 | 
				
			||||||
                                                        {
 | 
					                                                        {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
                                                    notAllocate.TaskAllocationState = TaskAllocationState.Allocated;
 | 
					                                                            var arm = visitGroup.FirstOrDefault(t => t.TaskState == TaskState.Effect && t.TaskAllocationState == TaskAllocationState.NotAllocate && t.DoctorUserId == null && t.ArmEnum == Arm.SingleReadingArm);
 | 
				
			||||||
                                                    notAllocate.AllocateTime = DateTime.Now;
 | 
					                                                            if (arm != null)
 | 
				
			||||||
 | 
					                                                            {
 | 
				
			||||||
                                                    notAllocate.DoctorUserId = singleTask.DoctorUserId;
 | 
					                                                                arm.TaskAllocationState = TaskAllocationState.Allocated;
 | 
				
			||||||
 | 
					                                                                arm.AllocateTime = DateTime.Now;
 | 
				
			||||||
 | 
					                                                                arm.DoctorUserId = singleTask.DoctorUserId;
 | 
				
			||||||
                                                            }
 | 
					                                                            }
 | 
				
			||||||
 | 
					                                                            else
 | 
				
			||||||
                                                //后续 废弃的任务  重阅重置,或者失效的  访视 需要重新生成
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
                                                var needAddTaskList = await _visitTaskRepository.Where(t => t.TrialId == trialId && t.SubjectId == subjectVisit.SubjectId && (t.TaskState == TaskState.Adbandon || t.TaskState == TaskState.HaveReturned) && t.VisitTaskNum > subjectVisit.VisitNum && t.ReadingCategory == ReadingCategory.Visit).ToListAsync();
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
                                                //可能存在多次申请重阅 所以这里会有重复
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
                                                foreach (var group in needAddTaskList.GroupBy(t => new { t.SubjectId, t.VisitTaskNum }))
 | 
					 | 
				
			||||||
                                                            {
 | 
					                                                            {
 | 
				
			||||||
                                                    var latestTask = group.OrderByDescending(t => t.CreateTime).First();
 | 
					                                                                var latestTask = visitGroup.Where(t => t.ArmEnum == Arm.SingleReadingArm).OrderByDescending(t => t.CreateTime).First();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
                                                                var taskOne = await _visitTaskRepository.AddAsync(new VisitTask()
 | 
					                                                                var taskOne = await _visitTaskRepository.AddAsync(new VisitTask()
 | 
				
			||||||
                                                                {
 | 
					                                                                {
 | 
				
			||||||
                                                                    TrialId = trialId,
 | 
					                                                                    TrialId = trialId,
 | 
				
			||||||
                                                                    SubjectId = subjectVisit.SubjectId,
 | 
					                                                                    SubjectId = subjectVisit.SubjectId,
 | 
				
			||||||
                                                                    IsUrgent = subjectVisit.IsUrgent,
 | 
					                                                                    IsUrgent = subjectVisit.IsUrgent,
 | 
				
			||||||
                                                        TaskBlindName = subjectVisit.BlindName,
 | 
					                                                                    ArmEnum = Arm.SingleReadingArm,//特殊
 | 
				
			||||||
                                                        TaskName = subjectVisit.VisitName,
 | 
					 | 
				
			||||||
                                                        VisitTaskNum = subjectVisit.VisitNum,
 | 
					 | 
				
			||||||
                                                        ArmEnum = Arm.DoubleReadingArm1,//特殊
 | 
					 | 
				
			||||||
                                                                    Code = currentMaxCodeInt + 1,
 | 
					                                                                    Code = currentMaxCodeInt + 1,
 | 
				
			||||||
                                                        SourceSubjectVisitId = subjectVisit.Id,
 | 
					 | 
				
			||||||
                                                                    TaskCode = AppSettings.GetCodeStr(currentMaxCodeInt + 1, nameof(VisitTask)),
 | 
					                                                                    TaskCode = AppSettings.GetCodeStr(currentMaxCodeInt + 1, nameof(VisitTask)),
 | 
				
			||||||
                                                                    ReadingCategory = ReadingCategory.Visit,
 | 
					                                                                    ReadingCategory = ReadingCategory.Visit,
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					                                                                    SourceSubjectVisitId = latestTask.SourceSubjectVisitId,
 | 
				
			||||||
 | 
					                                                                    VisitTaskNum = latestTask.VisitTaskNum,
 | 
				
			||||||
 | 
					                                                                    TaskBlindName = latestTask.TaskBlindName,
 | 
				
			||||||
 | 
					                                                                    TaskName = latestTask.TaskName,
 | 
				
			||||||
 | 
					
 | 
				
			||||||
                                                                    BlindSubjectCode = latestTask.BlindSubjectCode,
 | 
					                                                                    BlindSubjectCode = latestTask.BlindSubjectCode,
 | 
				
			||||||
                                                                    BlindTrialSiteCode = latestTask.BlindTrialSiteCode,
 | 
					                                                                    BlindTrialSiteCode = latestTask.BlindTrialSiteCode,
 | 
				
			||||||
| 
						 | 
					@ -462,12 +479,35 @@ namespace IRaCIS.Core.Application.Service
 | 
				
			||||||
                                                                    DoctorUserId = singleTask.DoctorUserId
 | 
					                                                                    DoctorUserId = singleTask.DoctorUserId
 | 
				
			||||||
                                                                });
 | 
					                                                                });
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 | 
				
			||||||
                                                                currentMaxCodeInt = currentMaxCodeInt + 1;
 | 
					                                                                currentMaxCodeInt = currentMaxCodeInt + 1;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
                                                                _provider.Set<int>($"{trialId}_{StaticData.CacheKey.TaskMaxCode}", currentMaxCodeInt, TimeSpan.FromMinutes(30));
 | 
					                                                                _provider.Set<int>($"{trialId}_{StaticData.CacheKey.TaskMaxCode}", currentMaxCodeInt, TimeSpan.FromMinutes(30));
 | 
				
			||||||
                                                            }
 | 
					                                                            }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					                                                        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					                                                    }
 | 
				
			||||||
 | 
					                                                    //之前有回退的    后续访视不生成或者分配   当前访视生成但是不分配出去
 | 
				
			||||||
 | 
					                                                    else
 | 
				
			||||||
 | 
					                                                    {
 | 
				
			||||||
 | 
					                                                        //不用进行额外处理
 | 
				
			||||||
 | 
					                                                    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					                                                }
 | 
				
			||||||
 | 
					                                                //无序的时候    生成任务并分配出去
 | 
				
			||||||
 | 
					                                                else
 | 
				
			||||||
 | 
					                                                {
 | 
				
			||||||
 | 
					                                                    var defaultState = trialConfig.FollowVisitAutoAssignDefaultState == TaskAllocateDefaultState.InitAllocated ? TaskAllocationState.InitAllocated : TaskAllocationState.Allocated;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					                                                    singleTask.TaskAllocationState = defaultState;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					                                                    singleTask.DoctorUserId = assignConfigList.FirstOrDefault(t => t.ArmEnum == 0).DoctorUserId;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					                                                    singleTask.AllocateTime = DateTime.Now;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					                                                }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
                                                #endregion
 | 
					                                                #endregion
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -609,6 +609,9 @@ namespace IRaCIS.Core.Application.Service
 | 
				
			||||||
            var taskList = _visitTaskRepository.Where(t => t.TrialId == assignConfirmCommand.TrialId && t.DoctorUserId == null, true)
 | 
					            var taskList = _visitTaskRepository.Where(t => t.TrialId == assignConfirmCommand.TrialId && t.DoctorUserId == null, true)
 | 
				
			||||||
                    .WhereIf(subjectIdList.Count() > 0 && assignConfirmCommand.IsJudgeDoctor == false, t => subjectIdList.Contains(t.SubjectId) && t.Subject.SubjectDoctorList.Where(t => t.ArmEnum != Arm.JudgeArm).Any())
 | 
					                    .WhereIf(subjectIdList.Count() > 0 && assignConfirmCommand.IsJudgeDoctor == false, t => subjectIdList.Contains(t.SubjectId) && t.Subject.SubjectDoctorList.Where(t => t.ArmEnum != Arm.JudgeArm).Any())
 | 
				
			||||||
                    .WhereIf(subjectIdList.Count() > 0 && assignConfirmCommand.IsJudgeDoctor, t => subjectIdList.Contains(t.SubjectId) && t.Subject.SubjectDoctorList.Where(t => t.ArmEnum == Arm.JudgeArm).Any())
 | 
					                    .WhereIf(subjectIdList.Count() > 0 && assignConfirmCommand.IsJudgeDoctor, t => subjectIdList.Contains(t.SubjectId) && t.Subject.SubjectDoctorList.Where(t => t.ArmEnum == Arm.JudgeArm).Any())
 | 
				
			||||||
 | 
					                    //过滤掉  那些回退的subject
 | 
				
			||||||
 | 
					                    .Where(t => !t.Subject.SubjectVisitList.Any(t => t.IsPMBackOrReReading))
 | 
				
			||||||
 | 
					                
 | 
				
			||||||
                   .ToList();
 | 
					                   .ToList();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					@ -623,15 +626,11 @@ namespace IRaCIS.Core.Application.Service
 | 
				
			||||||
 | 
					
 | 
				
			||||||
                if (assignConfirmCommand.SubjectDoctorUserList.Count == 0)
 | 
					                if (assignConfirmCommand.SubjectDoctorUserList.Count == 0)
 | 
				
			||||||
                {
 | 
					                {
 | 
				
			||||||
 | 
					 | 
				
			||||||
                    subjectDoctorIdArmList = _subjectUserRepository.Where(t => t.SubjectId == subjectId && t.OrignalSubjectUserId == null).Select(t => new DoctorArm() { DoctorUserId = t.DoctorUserId, ArmEnum = t.ArmEnum }).ToList();
 | 
					                    subjectDoctorIdArmList = _subjectUserRepository.Where(t => t.SubjectId == subjectId && t.OrignalSubjectUserId == null).Select(t => new DoctorArm() { DoctorUserId = t.DoctorUserId, ArmEnum = t.ArmEnum }).ToList();
 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
                }
 | 
					                }
 | 
				
			||||||
                else
 | 
					                else
 | 
				
			||||||
                {
 | 
					                {
 | 
				
			||||||
                    subjectDoctorIdArmList = assignConfirmCommand.SubjectDoctorUserList.Where(t => t.SubjectId == subjectId).First().DoctorUserIdArmList;
 | 
					                    subjectDoctorIdArmList = assignConfirmCommand.SubjectDoctorUserList.Where(t => t.SubjectId == subjectId).First().DoctorUserIdArmList;
 | 
				
			||||||
 | 
					 | 
				
			||||||
                }
 | 
					                }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					@ -696,8 +695,8 @@ namespace IRaCIS.Core.Application.Service
 | 
				
			||||||
            var subjectList = _subjectRepository.Where(t => t.TrialId == trialId)
 | 
					            var subjectList = _subjectRepository.Where(t => t.TrialId == trialId)
 | 
				
			||||||
                .WhereIf(isJudge == false, t => t.SubjectVisitTaskList.Where(t => t.ArmEnum != Arm.JudgeArm).Any())
 | 
					                .WhereIf(isJudge == false, t => t.SubjectVisitTaskList.Where(t => t.ArmEnum != Arm.JudgeArm).Any())
 | 
				
			||||||
                .WhereIf(isJudge, t => t.SubjectVisitTaskList.Where(t => t.ArmEnum == Arm.JudgeArm).Any())
 | 
					                .WhereIf(isJudge, t => t.SubjectVisitTaskList.Where(t => t.ArmEnum == Arm.JudgeArm).Any())
 | 
				
			||||||
                //过滤掉  那些回退的subject
 | 
					                ////过滤掉  那些回退的subject
 | 
				
			||||||
                .Where(t => !t.SubjectVisitList.Any(t => t.IsPMBackOrReReading))
 | 
					                //.Where(t => !t.SubjectVisitList.Any(t => t.IsPMBackOrReReading))
 | 
				
			||||||
                .Select(t => new
 | 
					                .Select(t => new
 | 
				
			||||||
                {
 | 
					                {
 | 
				
			||||||
                    SubjectId = t.Id,
 | 
					                    SubjectId = t.Id,
 | 
				
			||||||
| 
						 | 
					@ -1025,7 +1024,8 @@ namespace IRaCIS.Core.Application.Service
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
                //当前访视之前 已有任务申请
 | 
					                //当前访视之前 已有任务申请
 | 
				
			||||||
                if (trialConfig.IsReadingTaskViewInOrder && await _visitTaskRepository.AnyAsync(t => t.TrialId == task.TrialId && t.SubjectId == task.SubjectId && t.TaskState == TaskState.Effect && t.ReadingCategory==ReadingCategory.Visit
 | 
					                if (trialConfig.IsReadingTaskViewInOrder && _userInfo.UserTypeEnumInt == (int)UserTypeEnum.ProjectManager
 | 
				
			||||||
 | 
					                    && await _visitTaskRepository.AnyAsync(t => t.TrialId == task.TrialId && t.SubjectId == task.SubjectId && t.TaskState == TaskState.Effect && t.ReadingCategory==ReadingCategory.Visit
 | 
				
			||||||
                                                && t.ReadingTaskState == ReadingTaskState.HaveSigned  && t.VisitTaskNum <= task.VisitTaskNum && t.Id!= task.Id && t.ReReadingApplyState == ReReadingApplyState.HaveApplyed ))
 | 
					                                                && t.ReadingTaskState == ReadingTaskState.HaveSigned  && t.VisitTaskNum <= task.VisitTaskNum && t.Id!= task.Id && t.ReReadingApplyState == ReReadingApplyState.HaveApplyed ))
 | 
				
			||||||
                {
 | 
					                {
 | 
				
			||||||
                    return ResponseOutput.NotOk("当前为有序阅片,之前有访视,或其他IR的本次访视已申请重阅,还未处理,不允许申请");
 | 
					                    return ResponseOutput.NotOk("当前为有序阅片,之前有访视,或其他IR的本次访视已申请重阅,还未处理,不允许申请");
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Loading…
	
		Reference in New Issue