添加接口
							parent
							
								
									34dd484582
								
							
						
					
					
						commit
						348d2cb7d4
					
				|  | @ -91,6 +91,45 @@ namespace IRaCIS.Core.API.Controllers | |||
| 
 | ||||
|             return await _inspectionService.Enforcement(opt.OptCommand, opt.AuditInfo, opt.SignInfo, null, fun); | ||||
|         } | ||||
| 
 | ||||
| 
 | ||||
|         [HttpPost, Route("Inspection/subjectVisit/SetSubjectVisitUrgent")] | ||||
|         public async Task<IResponseOutput> SetSubjectVisitUrgent(DataInspectionDto<SetSubjectVisitUrgentCommand> opt) | ||||
|         { | ||||
| 
 | ||||
|             var fun = await _subjectVisitService.SetSubjectVisitUrgent(opt.OptCommand.subjectVisitId,opt.OptCommand.isUrgent); | ||||
|             if (!fun.IsSuccess) | ||||
|             { | ||||
|                 return ResponseOutput.NotOk(fun.ErrorMessage); | ||||
|             } | ||||
|             return await _inspectionService.Enforcement(opt.OptCommand, opt.AuditInfo, opt.SignInfo, null, fun); | ||||
|         } | ||||
| 
 | ||||
| 
 | ||||
|         [HttpPost, Route("Inspection/subjectVisit/DeleteSV")] | ||||
|         public async Task<IResponseOutput> DeleteSV(DataInspectionDto<DeleteSVCommand> opt) | ||||
|         { | ||||
| 
 | ||||
|             var fun = await _subjectVisitService.DeleteSV(opt.OptCommand.Id); | ||||
|             if (!fun.IsSuccess) | ||||
|             { | ||||
|                 return ResponseOutput.NotOk(fun.ErrorMessage); | ||||
|             } | ||||
|             return await _inspectionService.Enforcement(opt.OptCommand, opt.AuditInfo, opt.SignInfo, null, fun); | ||||
|         } | ||||
| 
 | ||||
|         [HttpPost, Route("Inspection/subjectVisit/SetSVExecuted")] | ||||
|         public async Task<IResponseOutput> SetSVExecuted(DataInspectionDto<DeleteSVCommand> opt) | ||||
|         { | ||||
| 
 | ||||
|             var fun = await _subjectVisitService.SetSVExecuted(opt.OptCommand.Id); | ||||
|             if (!fun.IsSuccess) | ||||
|             { | ||||
|                 return ResponseOutput.NotOk(fun.ErrorMessage); | ||||
|             } | ||||
|             return await _inspectionService.Enforcement(opt.OptCommand, opt.AuditInfo, opt.SignInfo, null, fun); | ||||
|         } | ||||
| 
 | ||||
|         #endregion | ||||
| 
 | ||||
|         #region 配置项目信息 | ||||
|  |  | |||
|  | @ -386,6 +386,16 @@ | |||
|         <member name="T:IRaCIS.Core.Application.ViewModel.FrontAuditConfigView"> | ||||
|             <summary> FrontAuditConfigView  列表视图模型 </summary> | ||||
|         </member> | ||||
|         <member name="P:IRaCIS.Core.Application.ViewModel.FrontAuditConfigView.IsHaveSign"> | ||||
|             <summary> | ||||
|             是否有签名 | ||||
|             </summary> | ||||
|         </member> | ||||
|         <member name="P:IRaCIS.Core.Application.ViewModel.FrontAuditConfigView.IsHaveReason"> | ||||
|             <summary> | ||||
|             是否有原因 | ||||
|             </summary> | ||||
|         </member> | ||||
|         <member name="P:IRaCIS.Core.Application.ViewModel.FrontAuditConfigView.IsForwardPosition"> | ||||
|             <summary> | ||||
|             是否向前站位 | ||||
|  | @ -430,6 +440,16 @@ | |||
|             标识 | ||||
|             </summary> | ||||
|         </member> | ||||
|         <member name="P:IRaCIS.Core.Application.ViewModel.FrontAuditConfigAddOrEdit.IsHaveSign"> | ||||
|             <summary> | ||||
|             是否有签名 | ||||
|             </summary> | ||||
|         </member> | ||||
|         <member name="P:IRaCIS.Core.Application.ViewModel.FrontAuditConfigAddOrEdit.IsHaveReason"> | ||||
|             <summary> | ||||
|             是否有原因 | ||||
|             </summary> | ||||
|         </member> | ||||
|         <member name="T:IRaCIS.Core.Application.ViewModel.SystemAnonymizationView"> | ||||
|             <summary> SystemAnonymizationView  列表视图模型 </summary> | ||||
|         </member> | ||||
|  |  | |||
|  | @ -58,6 +58,16 @@ namespace IRaCIS.Core.Application.ViewModel | |||
| 
 | ||||
|         public string ByTrialConfig { get; set; } = string.Empty; | ||||
| 
 | ||||
|         /// <summary> | ||||
| 		/// 是否有签名 | ||||
| 		/// </summary> | ||||
| 		public bool? IsHaveSign { get; set; } | ||||
| 
 | ||||
|         /// <summary> | ||||
|         /// 是否有原因 | ||||
|         /// </summary> | ||||
|         public bool? IsHaveReason { get; set; } | ||||
| 
 | ||||
| 
 | ||||
|         /// <summary> | ||||
| 		/// 是否向前站位 | ||||
|  | @ -179,6 +189,18 @@ namespace IRaCIS.Core.Application.ViewModel | |||
| 
 | ||||
| 
 | ||||
| 
 | ||||
|         /// <summary> | ||||
| 		/// 是否有签名 | ||||
| 		/// </summary> | ||||
| 		public bool? IsHaveSign { get; set; } | ||||
| 
 | ||||
|         /// <summary> | ||||
|         /// 是否有原因 | ||||
|         /// </summary> | ||||
|         public bool? IsHaveReason { get; set; } | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
|     } | ||||
| 
 | ||||
| 
 | ||||
|  |  | |||
|  | @ -111,7 +111,7 @@ namespace IRaCIS.Core.Application.Service | |||
|                      from leftOptTypeId in OptTypeIdtemp.DefaultIfEmpty() | ||||
|                      join ObjectTypeId in _repository.GetQueryable<Dictionary>() on data.ObjectTypeId equals ObjectTypeId.Id.ToString() into ObjectTypeIdtemp | ||||
|                      from leftObjectTypeIdtemp in ObjectTypeIdtemp.DefaultIfEmpty() | ||||
|                         select new FrontAuditConfigView() | ||||
|                      select new FrontAuditConfigView() | ||||
|                      { | ||||
| 
 | ||||
|                          IsShowParent = data.IsShowParent, | ||||
|  | @ -148,6 +148,8 @@ namespace IRaCIS.Core.Application.Service | |||
|                          ByTrialConfig=data.ByTrialConfig, | ||||
|                          IsForwardPosition=data.IsForwardPosition, | ||||
|                          Identification=data.Identification, | ||||
|                          IsHaveReason=data.IsHaveReason, | ||||
|                          IsHaveSign=data.IsHaveSign, | ||||
|                         }; | ||||
| 
 | ||||
|             query = query | ||||
|  |  | |||
|  | @ -212,8 +212,13 @@ namespace IRaCIS.Core.Application.Service.Inspection | |||
|             { | ||||
|                 try | ||||
|                 { | ||||
|                     var value = data.GetType().GetProperty(item).GetValue(data); | ||||
|                     mapData.GetType().GetProperty(item).SetValue(mapData, value); | ||||
|                     var i = mapData.GetType().GetProperty(item).GetValue(mapData); | ||||
|                     if (i == null) | ||||
|                     { | ||||
|                         var value = data.GetType().GetProperty(item).GetValue(data); | ||||
|                         mapData.GetType().GetProperty(item).SetValue(mapData, value); | ||||
|                     } | ||||
|                    | ||||
|                 } | ||||
|                 catch (Exception) | ||||
|                 { | ||||
|  |  | |||
|  | @ -43,6 +43,19 @@ namespace IRaCIS.Core.Application.Contracts | |||
| 
 | ||||
| 
 | ||||
|     } | ||||
| 
 | ||||
|     public class DeleteSVCommand | ||||
|     { | ||||
|         public Guid Id { get; set; } | ||||
|     } | ||||
| 
 | ||||
|     public class SetSubjectVisitUrgentCommand | ||||
|     { | ||||
|        public Guid subjectVisitId { get; set; } | ||||
| 
 | ||||
| 
 | ||||
|        public bool isUrgent { get; set; } | ||||
|     } | ||||
|     public class SubjectVisitDTO : SubjectVisitCommand | ||||
|     { | ||||
|         public SubjectStatus SubjectStatus { get; set; } | ||||
|  |  | |||
|  | @ -8,5 +8,7 @@ namespace IRaCIS.Core.Application.Interfaces | |||
|         Task<IResponseOutput> DeleteSV(Guid id); | ||||
|         Task<List<VisitStudyDTO>> GetVisitStudyList(Guid trialId, Guid sujectVisitId, int isReading); | ||||
|         Task<IResponseOutput> SetSVExecuted(Guid subjectVisitId); | ||||
| 
 | ||||
|         Task<IResponseOutput> SetSubjectVisitUrgent(Guid subjectVisitId, bool isUrgent); | ||||
|     } | ||||
| } | ||||
|  | @ -31,7 +31,7 @@ namespace IRaCIS.Application.Services | |||
|         [TypeFilter(typeof(TrialResourceFilter))] | ||||
|         public async Task<IResponseOutput<string>> AddOrUpdateSubject([FromBody] SubjectCommand subjectCommand) | ||||
|         { | ||||
| 
 | ||||
|             bool isadd = false; | ||||
|             if (await _repository.AnyAsync<Trial>(t => t.Id == subjectCommand.TrialId && !t.VisitPlanConfirmed)) | ||||
|             { | ||||
|                 return ResponseOutput.NotOk("The trial visit plan has not been confirmed yet.Please contact the project manager to confirm the visit plan before adding subject."); | ||||
|  | @ -43,16 +43,13 @@ namespace IRaCIS.Application.Services | |||
|                 VerifyMsg = "A subjects with the same subject ID already existed in this trial." | ||||
|             }; | ||||
| 
 | ||||
|             | ||||
| 
 | ||||
|             var mapedSubject = await _subjectRepository.InsertOrUpdateAsync(subjectCommand, false, verifyExp1/*, verifyExp2*/); | ||||
| 
 | ||||
|             if (subjectCommand.Id == null) //insert | ||||
|             { | ||||
|                 isadd = true; | ||||
|                 var IsEnrollementQualificationConfirm = await _repository.Where<Trial>(t => t.Id == mapedSubject.TrialId).Select(u => u.IsEnrollementQualificationConfirm).FirstOrDefaultAsync(); | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
|                 //添加受试者的时候,获取访视计划列表,添加到受试者访视表。 | ||||
|                 var visitPlan = await _repository.Where<VisitStage>(t => t.TrialId == subjectCommand.TrialId).ToListAsync(); | ||||
| 
 | ||||
|  | @ -101,7 +98,7 @@ namespace IRaCIS.Application.Services | |||
| 
 | ||||
|             var createtime = DateTime.Now.AddSeconds(1); | ||||
|             // 添加稽查记录 | ||||
|             if (subjectCommand.Id == null) | ||||
|             if (isadd) | ||||
|             { | ||||
|                 List<DataInspection> datas = new List<DataInspection>(); | ||||
|                 datas.Add(new DataInspection() | ||||
|  | @ -130,13 +127,38 @@ namespace IRaCIS.Application.Services | |||
|                         SubjectVisitId= item.Id, | ||||
|                         SubjectVisitName=item.VisitName, | ||||
|                         IsSign = false, | ||||
|                         CreateTime = createtime, | ||||
|                         Identification = "Subject|Init|Subject|Status", | ||||
|                         CreateTime = visittime, | ||||
|                         Identification = "Add|Visit|Info|Visit-Image Upload", | ||||
|                         JsonDetail = JsonConvert.SerializeObject(new | ||||
|                         { | ||||
|                             VisitName = item.VisitName, | ||||
|                             VisitNum = item.VisitNum, | ||||
|                             IsBaseLine=item.IsBaseLine, | ||||
|                             VisitExecuted= false, | ||||
|                             IsFinalVisit=item.IsFinalVisit, | ||||
|                             PDState="None", | ||||
|                             IsLostVisit=item.IsLostVisit, | ||||
| 
 | ||||
|                         }) | ||||
|                     }); | ||||
|                     datas.Add(new DataInspection() | ||||
|                     { | ||||
|                         TrialId = subjectCommand.TrialId, | ||||
|                         SiteId = subjectCommand.SiteId, | ||||
|                         SubjectId = subjectCommand.Id, | ||||
|                         SubjectCode = subjectCommand.Code, | ||||
|                         SubjectVisitId = item.Id, | ||||
|                         SubjectVisitName = item.VisitName, | ||||
|                         IsSign = false, | ||||
|                         CreateTime = visittime.AddSeconds(1), | ||||
|                         Identification = "Init|Visit|Status|Visit-Image Upload", | ||||
|                         JsonDetail = JsonConvert.SerializeObject(new | ||||
|                         { | ||||
|                             VisitName = item.VisitName, | ||||
|                             SubmitState = "", | ||||
|                             AuditState = "", | ||||
|                            | ||||
| 
 | ||||
|                         }) | ||||
|                     }); | ||||
|                 } | ||||
|  |  | |||
|  | @ -7,6 +7,8 @@ using Microsoft.AspNetCore.Authorization; | |||
| using IRaCIS.Core.Domain.Share; | ||||
| using IRaCIS.Core.Application.Contracts; | ||||
| using IRaCIS.Core.Application.Interfaces; | ||||
| using IRaCIS.Core.Application.Service.Inspection.Interface; | ||||
| using Newtonsoft.Json; | ||||
| 
 | ||||
| namespace IRaCIS.Core.Application.Services | ||||
| { | ||||
|  | @ -14,10 +16,12 @@ namespace IRaCIS.Core.Application.Services | |||
|     public class SubjectVisitService : BaseService, ISubjectVisitService | ||||
|     { | ||||
|         private readonly IRepository<SubjectVisit> _subjectVisitRepository; | ||||
|         private readonly IInspectionService _inspectionService; | ||||
| 
 | ||||
|         public SubjectVisitService(IRepository<SubjectVisit> subjectVisitRepository) | ||||
|         public SubjectVisitService(IRepository<SubjectVisit> subjectVisitRepository, IInspectionService inspectionService) | ||||
|         { | ||||
|             _subjectVisitRepository = subjectVisitRepository; | ||||
|             this._inspectionService = inspectionService; | ||||
|         } | ||||
| 
 | ||||
|         [HttpPost] | ||||
|  | @ -25,6 +29,12 @@ namespace IRaCIS.Core.Application.Services | |||
|         [UnitOfWork] | ||||
|         public async Task<IResponseOutput<string>> AddOrUpdateSV(SubjectVisitCommand svCommand) | ||||
|         { | ||||
|             bool isadd=false; | ||||
| 
 | ||||
|             if (svCommand.Id != null) | ||||
|             { | ||||
|                 isadd=true; | ||||
|             } | ||||
| 
 | ||||
|             var verifyExp1 = new EntityVerifyExp<SubjectVisit>() | ||||
|             { | ||||
|  | @ -123,7 +133,33 @@ namespace IRaCIS.Core.Application.Services | |||
|              | ||||
|             await _repository.SaveChangesAsync(); | ||||
| 
 | ||||
|             //if(svCommand.) | ||||
|             if (isadd) | ||||
|             { | ||||
|                 List<DataInspection> dataInspection=new List<DataInspection>(); | ||||
| 
 | ||||
|                 dataInspection.Add(new DataInspection() | ||||
|                 { | ||||
|                     TrialId = svCommand.TrialId, | ||||
|                     SiteId = svCommand.SiteId, | ||||
|                     SubjectId = svCommand.Id, | ||||
| 
 | ||||
|                     SubjectVisitId = svCommand.Id, | ||||
|                     SubjectVisitName = svCommand.VisitName, | ||||
|                     IsSign = false, | ||||
|                     CreateTime = DateTime.Now.AddSeconds(1), | ||||
|                     Identification = "Init|Visit|Status|Visit-Image Upload", | ||||
|                     JsonDetail = JsonConvert.SerializeObject(new | ||||
|                     { | ||||
|                         VisitName = svCommand.VisitName, | ||||
|                         SubmitState = "", | ||||
|                         AuditState = "", | ||||
| 
 | ||||
| 
 | ||||
|                     }) | ||||
|                 }); | ||||
| 
 | ||||
|                 await _inspectionService.AddListInspectionRecordAsync(dataInspection); | ||||
|             } | ||||
| 
 | ||||
|             // 保存数据后,重新算下是否缺失影像  应对状态撤回 | ||||
|             //if (svCommand.IsLostVisit == false) | ||||
|  |  | |||
|  | @ -127,6 +127,17 @@ namespace IRaCIS.Core.Domain.Models | |||
| 		public string Identification { get; set; } | ||||
| 
 | ||||
| 
 | ||||
| 		/// <summary> | ||||
| 		/// 是否有签名 | ||||
| 		/// </summary> | ||||
| 		public bool? IsHaveSign { get; set; } | ||||
| 
 | ||||
| 		/// <summary> | ||||
| 		/// 是否有原因 | ||||
| 		/// </summary> | ||||
| 		public bool? IsHaveReason { get; set; } | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 	} | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue