修改临床数据
parent
4c123a6227
commit
55b98cae7b
|
@ -62,20 +62,22 @@ namespace IRaCIS.Application.Services
|
||||||
return ResponseOutput.NotOk("存在同类型的临床数据,操作失败");
|
return ResponseOutput.NotOk("存在同类型的临床数据,操作失败");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
indto.CriterionEnumListStr= $"|{String.Join('|', indto.CriterionEnumList)}|";
|
||||||
|
|
||||||
var entity = await _clinicalDataSystemSetRepository.InsertOrUpdateAsync(indto);
|
var entity = await _clinicalDataSystemSetRepository.InsertOrUpdateAsync(indto);
|
||||||
|
|
||||||
entity.SystemClinicalDataCriterionList = indto.SystemCriterionIdList.Select(t => new SystemClinicalDataCriterion()
|
//entity.SystemClinicalDataCriterionList = indto.SystemCriterionIdList.Select(t => new SystemClinicalDataCriterion()
|
||||||
{
|
//{
|
||||||
SystemClinicalDataSetId = entity.Id,
|
// SystemClinicalDataSetId = entity.Id,
|
||||||
SystemReadingCriterionId = t
|
// SystemReadingCriterionId = t
|
||||||
}).ToList();
|
//}).ToList();
|
||||||
|
|
||||||
if (indto.Id != null)
|
//if (indto.Id != null)
|
||||||
{
|
//{
|
||||||
await _systemClinicalDataCriterionRepository.BatchDeleteNoTrackingAsync(t => t.SystemClinicalDataSetId == entity.Id);
|
// await _systemClinicalDataCriterionRepository.BatchDeleteNoTrackingAsync(t => t.SystemClinicalDataSetId == entity.Id);
|
||||||
|
|
||||||
await _systemClinicalDataCriterionRepository.AddRangeAsync(entity.SystemClinicalDataCriterionList);
|
// await _systemClinicalDataCriterionRepository.AddRangeAsync(entity.SystemClinicalDataCriterionList);
|
||||||
}
|
//}
|
||||||
|
|
||||||
await _clinicalDataSystemSetRepository.SaveChangesAsync();
|
await _clinicalDataSystemSetRepository.SaveChangesAsync();
|
||||||
|
|
||||||
|
@ -131,20 +133,25 @@ namespace IRaCIS.Application.Services
|
||||||
return ResponseOutput.NotOk("存在同类型的临床数据,操作失败");
|
return ResponseOutput.NotOk("存在同类型的临床数据,操作失败");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
indto.CriterionEnumListStr = $"|{String.Join('|', indto.CriterionEnumList)}|";
|
||||||
|
|
||||||
var entity = await _clinicalDataTrialSetRepository.InsertOrUpdateAsync(indto, true);
|
var entity = await _clinicalDataTrialSetRepository.InsertOrUpdateAsync(indto, true);
|
||||||
|
|
||||||
entity.TrialClinicalDataCriterionList = indto.TrialCriterionIdList.Select(t => new TrialClinicalDataCriterion()
|
//entity.TrialClinicalDataCriterionList = indto.TrialCriterionIdList.Select(t => new TrialClinicalDataCriterion()
|
||||||
{
|
//{
|
||||||
TrialClinicalDataSetId = entity.Id,
|
// TrialClinicalDataSetId = entity.Id,
|
||||||
TrialReadingCriterionId = t
|
// TrialReadingCriterionId = t
|
||||||
}).ToList();
|
//}).ToList();
|
||||||
|
|
||||||
|
//if (indto.Id != null)
|
||||||
|
//{
|
||||||
|
// await _trialClinicalDataCriterionRepository.BatchDeleteNoTrackingAsync(t => t.TrialClinicalDataSetId == entity.Id);
|
||||||
|
|
||||||
|
// await _trialClinicalDataCriterionRepository.AddRangeAsync(entity.TrialClinicalDataCriterionList);
|
||||||
|
//}
|
||||||
|
|
||||||
|
|
||||||
if (indto.Id != null)
|
|
||||||
{
|
|
||||||
await _trialClinicalDataCriterionRepository.BatchDeleteNoTrackingAsync(t => t.TrialClinicalDataSetId == entity.Id);
|
|
||||||
|
|
||||||
await _trialClinicalDataCriterionRepository.AddRangeAsync(entity.TrialClinicalDataCriterionList);
|
|
||||||
}
|
|
||||||
await _clinicalDataTrialSetRepository.SaveChangesAsync();
|
await _clinicalDataTrialSetRepository.SaveChangesAsync();
|
||||||
return ResponseOutput.Ok(entity.Id.ToString());
|
return ResponseOutput.Ok(entity.Id.ToString());
|
||||||
}
|
}
|
||||||
|
@ -163,6 +170,7 @@ namespace IRaCIS.Application.Services
|
||||||
public async Task<List<ClinicalDataTrialSetView>> GetTrialClinicalDataTrialSetList(GetTrialClinicalDataTrialIndto inDto)
|
public async Task<List<ClinicalDataTrialSetView>> GetTrialClinicalDataTrialSetList(GetTrialClinicalDataTrialIndto inDto)
|
||||||
{
|
{
|
||||||
await this.AddTrialClinicalDataTrialSet(inDto.TrialId);
|
await this.AddTrialClinicalDataTrialSet(inDto.TrialId);
|
||||||
|
|
||||||
var trialClinicalDataList = await _clinicalDataTrialSetRepository.AsQueryable()
|
var trialClinicalDataList = await _clinicalDataTrialSetRepository.AsQueryable()
|
||||||
.Where(x => x.TrialId == inDto.TrialId)
|
.Where(x => x.TrialId == inDto.TrialId)
|
||||||
.WhereIf(inDto.ClinicalDataLevel != null, x => x.ClinicalDataLevel == inDto.ClinicalDataLevel)
|
.WhereIf(inDto.ClinicalDataLevel != null, x => x.ClinicalDataLevel == inDto.ClinicalDataLevel)
|
||||||
|
@ -190,40 +198,40 @@ namespace IRaCIS.Application.Services
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
|
|
||||||
#region 系统和项目标准下拉 界面上配置和临床数据关联
|
#region 系统和项目标准下拉 界面上配置和临床数据关联 废弃
|
||||||
|
|
||||||
[HttpPost]
|
//[HttpPost]
|
||||||
public async Task<List<SystemCriterionSelectDto>> GetSystemCriterionSelectList(SystemCriterionSelectQuery inQuery)
|
//public async Task<List<SystemCriterionSelectDto>> GetSystemCriterionSelectList(SystemCriterionSelectQuery inQuery)
|
||||||
{
|
//{
|
||||||
return await _repository.Where<ReadingQuestionCriterionSystem>()
|
// return await _repository.Where<ReadingQuestionCriterionSystem>()
|
||||||
.WhereIf(!string.IsNullOrEmpty(inQuery.CriterionName), t => t.CriterionName.Contains(inQuery.CriterionName))
|
// .WhereIf(!string.IsNullOrEmpty(inQuery.CriterionName), t => t.CriterionName.Contains(inQuery.CriterionName))
|
||||||
.WhereIf(inQuery.IsEnable != null, t => t.IsEnable == inQuery.IsEnable)
|
// .WhereIf(inQuery.IsEnable != null, t => t.IsEnable == inQuery.IsEnable)
|
||||||
.WhereIf(inQuery.IsCompleteConfig != null, t => t.IsCompleteConfig == inQuery.IsCompleteConfig)
|
// .WhereIf(inQuery.IsCompleteConfig != null, t => t.IsCompleteConfig == inQuery.IsCompleteConfig)
|
||||||
.Select(t => new SystemCriterionSelectDto()
|
// .Select(t => new SystemCriterionSelectDto()
|
||||||
{
|
// {
|
||||||
Id = t.Id,
|
// Id = t.Id,
|
||||||
CriterionName = t.CriterionName,
|
// CriterionName = t.CriterionName,
|
||||||
IsCompleteConfig = t.IsCompleteConfig,
|
// IsCompleteConfig = t.IsCompleteConfig,
|
||||||
IsEnable = t.IsEnable
|
// IsEnable = t.IsEnable
|
||||||
}).ToListAsync();
|
// }).ToListAsync();
|
||||||
}
|
//}
|
||||||
|
|
||||||
|
|
||||||
[HttpPost]
|
//[HttpPost]
|
||||||
public async Task<List<TrialCriterionSelectDto>> GetTrialCriterionSelectList(TrialCriterionSelectQuery inQuery)
|
//public async Task<List<TrialCriterionSelectDto>> GetTrialCriterionSelectList(TrialCriterionSelectQuery inQuery)
|
||||||
{
|
//{
|
||||||
return await _repository.Where<ReadingQuestionCriterionTrial>(t => t.TrialId == inQuery.TrialId)
|
// return await _repository.Where<ReadingQuestionCriterionTrial>(t => t.TrialId == inQuery.TrialId)
|
||||||
.WhereIf(!string.IsNullOrEmpty(inQuery.CriterionName), t => t.CriterionName.Contains(inQuery.CriterionName))
|
// .WhereIf(!string.IsNullOrEmpty(inQuery.CriterionName), t => t.CriterionName.Contains(inQuery.CriterionName))
|
||||||
.WhereIf(inQuery.IsEnable != null, t => t.IsEnable == inQuery.IsEnable)
|
// .WhereIf(inQuery.IsEnable != null, t => t.IsEnable == inQuery.IsEnable)
|
||||||
.WhereIf(inQuery.IsCompleteConfig != null, t => t.IsCompleteConfig == inQuery.IsCompleteConfig)
|
// .WhereIf(inQuery.IsCompleteConfig != null, t => t.IsCompleteConfig == inQuery.IsCompleteConfig)
|
||||||
.Select(t => new TrialCriterionSelectDto()
|
// .Select(t => new TrialCriterionSelectDto()
|
||||||
{
|
// {
|
||||||
Id = t.Id,
|
// Id = t.Id,
|
||||||
CriterionName = t.CriterionName,
|
// CriterionName = t.CriterionName,
|
||||||
IsCompleteConfig = t.IsCompleteConfig,
|
// IsCompleteConfig = t.IsCompleteConfig,
|
||||||
IsEnable = t.IsEnable
|
// IsEnable = t.IsEnable
|
||||||
}).ToListAsync();
|
// }).ToListAsync();
|
||||||
}
|
//}
|
||||||
|
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
@ -240,10 +248,13 @@ namespace IRaCIS.Application.Services
|
||||||
|
|
||||||
private async Task AddTrialClinicalDataTrialSet(Guid trialId)
|
private async Task AddTrialClinicalDataTrialSet(Guid trialId)
|
||||||
{
|
{
|
||||||
var syncClinicalDataTime = await _trialRepository.Where(x => x.Id == trialId).Select(x => x.SyncClinicalDataTime).FirstOrDefaultAsync();
|
|
||||||
if (syncClinicalDataTime == null)
|
#region MyRegion
|
||||||
|
|
||||||
|
|
||||||
|
if (!await _clinicalDataTrialSetRepository.AnyAsync(x => x.TrialId == trialId && x.SystemClinicalDataSetId != null))
|
||||||
{
|
{
|
||||||
var systemClinicalDataList = await _clinicalDataSystemSetRepository.AsQueryable().Include(t=>t.SystemClinicalDataCriterionList).ToListAsync();
|
var systemClinicalDataList = await _clinicalDataSystemSetRepository.AsQueryable()/*.Include(t => t.SystemClinicalDataCriterionList)*/.ToListAsync();
|
||||||
var systemIds = systemClinicalDataList.Select(x => x.Id).ToList();
|
var systemIds = systemClinicalDataList.Select(x => x.Id).ToList();
|
||||||
|
|
||||||
var trialSystemClinicalDataSetIds = await _clinicalDataTrialSetRepository.Where(x => x.TrialId == trialId && x.SystemClinicalDataSetId != null).Select(x => x.SystemClinicalDataSetId.Value).ToListAsync();
|
var trialSystemClinicalDataSetIds = await _clinicalDataTrialSetRepository.Where(x => x.TrialId == trialId && x.SystemClinicalDataSetId != null).Select(x => x.SystemClinicalDataSetId.Value).ToListAsync();
|
||||||
|
@ -268,48 +279,99 @@ namespace IRaCIS.Application.Services
|
||||||
Path = x.Path,
|
Path = x.Path,
|
||||||
TrialId = trialId,
|
TrialId = trialId,
|
||||||
|
|
||||||
TrialClinicalDataCriterionList = readingCriterionList.Where(t => x.SystemClinicalDataCriterionList.Select(c => (Guid?)c.SystemReadingCriterionId).ToList().Contains(t.ReadingQuestionCriterionSystemId)).Select(c =>
|
CriterionEnumListStr=x.CriterionEnumListStr
|
||||||
new TrialClinicalDataCriterion() { TrialReadingCriterionId = c.TrialReadingCriterionId }).ToList()
|
|
||||||
|
//TrialClinicalDataCriterionList = readingCriterionList.Where(t => x.SystemClinicalDataCriterionList.Select(c => (Guid?)c.SystemReadingCriterionId).ToList().Contains(t.ReadingQuestionCriterionSystemId)).Select(c =>
|
||||||
|
//new TrialClinicalDataCriterion() { TrialReadingCriterionId = c.TrialReadingCriterionId }).ToList()
|
||||||
}).ToList();
|
}).ToList();
|
||||||
|
|
||||||
|
|
||||||
#region 临床数据标准
|
|
||||||
|
|
||||||
|
|
||||||
// dataSets.ForEach(x =>
|
|
||||||
//x.TrialClinicalDataCriterionList = systemClinicalDataList.Where(t => t.Id == x.SystemClinicalDataSetId)
|
|
||||||
// .Select(t => new TrialClinicalDataCriterion() { TrialReadingCriterionId = x.cl }).ToList()
|
|
||||||
// );
|
|
||||||
|
|
||||||
#endregion
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
await _clinicalDataTrialSetRepository.AddRangeAsync(dataSets);
|
await _clinicalDataTrialSetRepository.AddRangeAsync(dataSets);
|
||||||
|
|
||||||
//var needUpdateitemList = await _clinicalDataTrialSetRepository.Where(x => x.TrialId == trialId && needUpdateIds.Contains(x.SystemClinicalDataSetId.Value)).ToListAsync();
|
|
||||||
//foreach (var item in needUpdateitemList)
|
|
||||||
//{
|
|
||||||
// var systemData = systemClinicalDataList.FirstOrDefault(x => x.Id == item.SystemClinicalDataSetId);
|
|
||||||
// await _clinicalDataTrialSetRepository.UpdatePartialNoQueryAsync(item.Id,x=>new ClinicalDataTrialSet() {
|
|
||||||
|
|
||||||
// ClinicalDataSetName = systemData.ClinicalDataSetName,
|
|
||||||
// ClinicalDataLevel = systemData.ClinicalDataLevel,
|
|
||||||
// ClinicalUploadType = systemData.ClinicalUploadType,
|
|
||||||
// UploadRole = systemData.UploadRole,
|
|
||||||
// FileName = systemData.FileName,
|
|
||||||
// Path = systemData.Path,
|
|
||||||
// });
|
|
||||||
//}
|
|
||||||
|
|
||||||
await _trialRepository.BatchUpdateNoTrackingAsync(x => x.Id == trialId, x => new Trial()
|
|
||||||
{
|
|
||||||
SyncClinicalDataTime = DateTime.Now,
|
|
||||||
});
|
|
||||||
var result = await _clinicalDataTrialSetRepository.SaveChangesAsync();
|
var result = await _clinicalDataTrialSetRepository.SaveChangesAsync();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
|
||||||
|
#region OLd
|
||||||
|
//var syncClinicalDataTime = await _trialRepository.Where(x => x.Id == trialId).Select(x => x.SyncClinicalDataTime).FirstOrDefaultAsync();
|
||||||
|
//if (syncClinicalDataTime == null)
|
||||||
|
//{
|
||||||
|
// var systemClinicalDataList = await _clinicalDataSystemSetRepository.AsQueryable().Include(t => t.SystemClinicalDataCriterionList).ToListAsync();
|
||||||
|
// var systemIds = systemClinicalDataList.Select(x => x.Id).ToList();
|
||||||
|
|
||||||
|
// var trialSystemClinicalDataSetIds = await _clinicalDataTrialSetRepository.Where(x => x.TrialId == trialId && x.SystemClinicalDataSetId != null).Select(x => x.SystemClinicalDataSetId.Value).ToListAsync();
|
||||||
|
|
||||||
|
// var needAddids = systemIds.Except(trialSystemClinicalDataSetIds).ToList();
|
||||||
|
|
||||||
|
// var systemDataList = systemClinicalDataList.Where(x => needAddids.Contains(x.Id)).ToList();
|
||||||
|
|
||||||
|
// var readingCriterionList = _repository.Where<ReadingQuestionCriterionTrial>(t => t.TrialId == trialId).Where(t => t.ReadingQuestionCriterionSystemId != null)
|
||||||
|
// .Select(t => new { t.ReadingQuestionCriterionSystemId, TrialReadingCriterionId = t.Id }).ToList();
|
||||||
|
|
||||||
|
|
||||||
|
// List<ClinicalDataTrialSet> dataSets = systemDataList.Select(x => new ClinicalDataTrialSet()
|
||||||
|
// {
|
||||||
|
// Id = NewId.NextGuid(),
|
||||||
|
// SystemClinicalDataSetId = x.Id,
|
||||||
|
// ClinicalDataSetName = x.ClinicalDataSetName,
|
||||||
|
// ClinicalDataLevel = x.ClinicalDataLevel,
|
||||||
|
// ClinicalUploadType = x.ClinicalUploadType,
|
||||||
|
// UploadRole = x.UploadRole,
|
||||||
|
// FileName = x.FileName,
|
||||||
|
// Path = x.Path,
|
||||||
|
// TrialId = trialId,
|
||||||
|
|
||||||
|
// TrialClinicalDataCriterionList = readingCriterionList.Where(t => x.SystemClinicalDataCriterionList.Select(c => (Guid?)c.SystemReadingCriterionId).ToList().Contains(t.ReadingQuestionCriterionSystemId)).Select(c =>
|
||||||
|
// new TrialClinicalDataCriterion() { TrialReadingCriterionId = c.TrialReadingCriterionId }).ToList()
|
||||||
|
// }).ToList();
|
||||||
|
|
||||||
|
|
||||||
|
// #region 临床数据标准
|
||||||
|
|
||||||
|
|
||||||
|
// // dataSets.ForEach(x =>
|
||||||
|
// //x.TrialClinicalDataCriterionList = systemClinicalDataList.Where(t => t.Id == x.SystemClinicalDataSetId)
|
||||||
|
// // .Select(t => new TrialClinicalDataCriterion() { TrialReadingCriterionId = x.cl }).ToList()
|
||||||
|
// // );
|
||||||
|
|
||||||
|
// #endregion
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
// await _clinicalDataTrialSetRepository.AddRangeAsync(dataSets);
|
||||||
|
|
||||||
|
// //var needUpdateitemList = await _clinicalDataTrialSetRepository.Where(x => x.TrialId == trialId && needUpdateIds.Contains(x.SystemClinicalDataSetId.Value)).ToListAsync();
|
||||||
|
// //foreach (var item in needUpdateitemList)
|
||||||
|
// //{
|
||||||
|
// // var systemData = systemClinicalDataList.FirstOrDefault(x => x.Id == item.SystemClinicalDataSetId);
|
||||||
|
// // await _clinicalDataTrialSetRepository.UpdatePartialNoQueryAsync(item.Id,x=>new ClinicalDataTrialSet() {
|
||||||
|
|
||||||
|
// // ClinicalDataSetName = systemData.ClinicalDataSetName,
|
||||||
|
// // ClinicalDataLevel = systemData.ClinicalDataLevel,
|
||||||
|
// // ClinicalUploadType = systemData.ClinicalUploadType,
|
||||||
|
// // UploadRole = systemData.UploadRole,
|
||||||
|
// // FileName = systemData.FileName,
|
||||||
|
// // Path = systemData.Path,
|
||||||
|
// // });
|
||||||
|
// //}
|
||||||
|
|
||||||
|
// await _trialRepository.BatchUpdateNoTrackingAsync(x => x.Id == trialId, x => new Trial()
|
||||||
|
// {
|
||||||
|
// SyncClinicalDataTime = DateTime.Now,
|
||||||
|
// });
|
||||||
|
|
||||||
|
|
||||||
|
// var result = await _clinicalDataTrialSetRepository.SaveChangesAsync();
|
||||||
|
|
||||||
|
//}
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
#endregion
|
#endregion
|
||||||
}
|
}
|
||||||
|
|
|
@ -301,7 +301,9 @@ namespace IRaCIS.Application.Services
|
||||||
List<GetTrialClinicalDataSelectOutDto> clinicalList = await _clinicalDataTrialSetRepository.Where(x => x.TrialId == inDto.TrialId && x.IsConfirm)
|
List<GetTrialClinicalDataSelectOutDto> clinicalList = await _clinicalDataTrialSetRepository.Where(x => x.TrialId == inDto.TrialId && x.IsConfirm)
|
||||||
.WhereIf(inDto.UploadRole != null, x => x.UploadRole == inDto.UploadRole)
|
.WhereIf(inDto.UploadRole != null, x => x.UploadRole == inDto.UploadRole)
|
||||||
.Where(x => !usedIdsQuery.Contains(x.Id))
|
.Where(x => !usedIdsQuery.Contains(x.Id))
|
||||||
.WhereIf(inDto.TrialReadingCriterionId != null, t => t.TrialClinicalDataCriterionList.Any(t => t.TrialReadingCriterionId == inDto.TrialReadingCriterionId))
|
|
||||||
|
//.WhereIf(inDto.TrialReadingCriterionId != null, t => t.TrialClinicalDataCriterionList.Any(t => t.TrialReadingCriterionId == inDto.TrialReadingCriterionId))
|
||||||
|
|
||||||
.WhereIf(inDto.IsVisit && inDto.IsBaseLine, x => x.ClinicalDataLevel == ClinicalLevel.Subject || x.ClinicalDataLevel == ClinicalLevel.SubjectVisit)
|
.WhereIf(inDto.IsVisit && inDto.IsBaseLine, x => x.ClinicalDataLevel == ClinicalLevel.Subject || x.ClinicalDataLevel == ClinicalLevel.SubjectVisit)
|
||||||
.WhereIf(inDto.IsVisit && !inDto.IsBaseLine, x => x.ClinicalDataLevel == ClinicalLevel.SubjectVisit)
|
.WhereIf(inDto.IsVisit && !inDto.IsBaseLine, x => x.ClinicalDataLevel == ClinicalLevel.SubjectVisit)
|
||||||
.WhereIf(!inDto.IsVisit, x => x.ClinicalDataLevel == ClinicalLevel.ImageRead || x.ClinicalDataLevel == ClinicalLevel.OncologyRead)
|
.WhereIf(!inDto.IsVisit, x => x.ClinicalDataLevel == ClinicalLevel.ImageRead || x.ClinicalDataLevel == ClinicalLevel.OncologyRead)
|
||||||
|
|
|
@ -61,7 +61,11 @@ namespace IRaCIS.Core.Application.Service.Reading.Dto
|
||||||
public string Path { get; set; }
|
public string Path { get; set; }
|
||||||
|
|
||||||
|
|
||||||
public List<Guid> TrialCriterionIdList { get; set; }
|
//public List<Guid> TrialCriterionIdList { get; set; }
|
||||||
|
|
||||||
|
public string CriterionEnumListStr { get; set; } = String.Empty;
|
||||||
|
|
||||||
|
public List<int> CriterionEnumList { get; set; }
|
||||||
}
|
}
|
||||||
|
|
||||||
public class ClinicalDataSystemSetAddOrEdit
|
public class ClinicalDataSystemSetAddOrEdit
|
||||||
|
@ -111,7 +115,12 @@ namespace IRaCIS.Core.Application.Service.Reading.Dto
|
||||||
public string Path { get; set; }
|
public string Path { get; set; }
|
||||||
|
|
||||||
|
|
||||||
public List<Guid> SystemCriterionIdList { get; set; }
|
//public List<Guid> SystemCriterionIdList { get; set; }
|
||||||
|
|
||||||
|
|
||||||
|
public string CriterionEnumListStr { get; set; } = String.Empty;
|
||||||
|
|
||||||
|
public List<int> CriterionEnumList { get; set; }
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -120,7 +129,7 @@ namespace IRaCIS.Core.Application.Service.Reading.Dto
|
||||||
|
|
||||||
public class ClinicalDataTrialSetView: ClinicalDataTrialSetAddOrEdit
|
public class ClinicalDataTrialSetView: ClinicalDataTrialSetAddOrEdit
|
||||||
{
|
{
|
||||||
public List<string> TrialCriterionNameList { get; set; }
|
//public List<string> TrialCriterionNameList { get; set; }
|
||||||
|
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
|
@ -164,7 +173,7 @@ namespace IRaCIS.Core.Application.Service.Reading.Dto
|
||||||
public class ClinicalDataSystemSetView : ClinicalDataSystemSetAddOrEdit
|
public class ClinicalDataSystemSetView : ClinicalDataSystemSetAddOrEdit
|
||||||
{
|
{
|
||||||
|
|
||||||
public List<string> SystemCriterionNameList { get; set; }
|
//public List<string> SystemCriterionNameList { get; set; }
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// 创建时间
|
/// 创建时间
|
||||||
|
|
|
@ -52,13 +52,13 @@ namespace IRaCIS.Core.Application.Service
|
||||||
CreateMap<ClinicalDataSystemSet, ClinicalDataSystemSetAddOrEdit>().ReverseMap();
|
CreateMap<ClinicalDataSystemSet, ClinicalDataSystemSetAddOrEdit>().ReverseMap();
|
||||||
|
|
||||||
CreateMap<ClinicalDataTrialSet, ClinicalDataTrialSetView>()
|
CreateMap<ClinicalDataTrialSet, ClinicalDataTrialSetView>()
|
||||||
.ForMember(t => t.TrialCriterionNameList, u => u.MapFrom(c => c.TrialClinicalDataCriterionList.Select(t => t.TrialReadingCriterion.CriterionName)))
|
//.ForMember(t => t.TrialCriterionNameList, u => u.MapFrom(c => c.TrialClinicalDataCriterionList.Select(t => t.TrialReadingCriterion.CriterionName)))
|
||||||
.ForMember(t => t.TrialCriterionIdList, u => u.MapFrom(c => c.TrialClinicalDataCriterionList.Select(t => t.TrialReadingCriterion.Id)))
|
//.ForMember(t => t.TrialCriterionIdList, u => u.MapFrom(c => c.TrialClinicalDataCriterionList.Select(t => t.TrialReadingCriterion.Id)))
|
||||||
.ForMember(d => d.IsUsed, u => u.MapFrom(s => s.ReadingClinicalDataList.Count()>0));
|
.ForMember(d => d.IsUsed, u => u.MapFrom(s => s.ReadingClinicalDataList.Count()>0));
|
||||||
|
|
||||||
CreateMap<ClinicalDataSystemSet, ClinicalDataSystemSetView>()
|
CreateMap<ClinicalDataSystemSet, ClinicalDataSystemSetView>();
|
||||||
.ForMember(t=>t.SystemCriterionNameList,u=>u.MapFrom(c=>c.SystemClinicalDataCriterionList.Select(t=>t.SystemReadingCriterion.CriterionName)))
|
//.ForMember(t=>t.SystemCriterionNameList,u=>u.MapFrom(c=>c.SystemClinicalDataCriterionList.Select(t=>t.SystemReadingCriterion.CriterionName)))
|
||||||
.ForMember(t => t.SystemCriterionIdList, u => u.MapFrom(c => c.SystemClinicalDataCriterionList.Select(t => t.SystemReadingCriterion.Id)));
|
//.ForMember(t => t.SystemCriterionIdList, u => u.MapFrom(c => c.SystemClinicalDataCriterionList.Select(t => t.SystemReadingCriterion.Id)));
|
||||||
|
|
||||||
CreateMap<PreviousPDF, PreviousPDFAddOrEdit>().ReverseMap();
|
CreateMap<PreviousPDF, PreviousPDFAddOrEdit>().ReverseMap();
|
||||||
|
|
||||||
|
|
|
@ -5,6 +5,7 @@ using IRaCIS.Core.Domain.Share;
|
||||||
using System.ComponentModel.DataAnnotations;
|
using System.ComponentModel.DataAnnotations;
|
||||||
using System.ComponentModel.DataAnnotations.Schema;
|
using System.ComponentModel.DataAnnotations.Schema;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
|
using System.Linq;
|
||||||
|
|
||||||
namespace IRaCIS.Core.Domain.Models
|
namespace IRaCIS.Core.Domain.Models
|
||||||
{
|
{
|
||||||
|
@ -66,7 +67,15 @@ namespace IRaCIS.Core.Domain.Models
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public string Path { get; set; }
|
public string Path { get; set; }
|
||||||
|
|
||||||
public List<SystemClinicalDataCriterion> SystemClinicalDataCriterionList { get; set; } = new List<SystemClinicalDataCriterion>();
|
public string CriterionEnumListStr { get; set; }=String.Empty;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
[NotMapped]
|
||||||
|
public List<int> CriterionEnumList => CriterionEnumListStr.Split('|', StringSplitOptions.RemoveEmptyEntries).Where(t => !string.IsNullOrEmpty(t) && int.TryParse(t.Trim(),out var s)).Select(t => int.Parse(t.Trim()) ).ToList();
|
||||||
|
|
||||||
|
//public List<SystemClinicalDataCriterion> SystemClinicalDataCriterionList { get; set; } = new List<SystemClinicalDataCriterion>();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -5,6 +5,7 @@ using IRaCIS.Core.Domain.Share;
|
||||||
using System.ComponentModel.DataAnnotations;
|
using System.ComponentModel.DataAnnotations;
|
||||||
using System.ComponentModel.DataAnnotations.Schema;
|
using System.ComponentModel.DataAnnotations.Schema;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
|
using System.Linq;
|
||||||
|
|
||||||
namespace IRaCIS.Core.Domain.Models
|
namespace IRaCIS.Core.Domain.Models
|
||||||
{
|
{
|
||||||
|
@ -83,7 +84,12 @@ namespace IRaCIS.Core.Domain.Models
|
||||||
[ForeignKey("TrialId")]
|
[ForeignKey("TrialId")]
|
||||||
public Trial Trial { get; set; }
|
public Trial Trial { get; set; }
|
||||||
|
|
||||||
public List<TrialClinicalDataCriterion> TrialClinicalDataCriterionList { get; set; } = new List<TrialClinicalDataCriterion>();
|
//public List<TrialClinicalDataCriterion> TrialClinicalDataCriterionList { get; set; } = new List<TrialClinicalDataCriterion>();
|
||||||
|
|
||||||
|
public string CriterionEnumListStr { get; set; } = String.Empty;
|
||||||
|
|
||||||
|
[NotMapped]
|
||||||
|
public List<int> CriterionEnumList => CriterionEnumListStr.Split('|', StringSplitOptions.RemoveEmptyEntries).Where(t => !string.IsNullOrEmpty(t) && int.TryParse(t.Trim(), out var s)).Select(t => int.Parse(t.Trim())).ToList();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue