226 lines
9.2 KiB
C#
226 lines
9.2 KiB
C#
using IRaCIS.Application.Interfaces;
|
|
using IRaCIS.Core.Infra.EFCore;
|
|
using IRaCIS.Core.Domain.Share;
|
|
using IRaCIS.Core.Application.Filter;
|
|
using Microsoft.AspNetCore.Mvc;
|
|
using IRaCIS.Core.Application.Service.WorkLoad.DTO;
|
|
using Microsoft.AspNetCore.Authorization;
|
|
using IRaCIS.Core.Application.Auth;
|
|
using IRaCIS.Core.Application.Service.Reading.Dto;
|
|
using IRaCIS.Core.Domain.Share.Reading;
|
|
using MassTransit;
|
|
using System.ComponentModel.DataAnnotations;
|
|
using System.Reflection;
|
|
using IRaCIS.Core.Infra.EFCore.Common;
|
|
using IRaCIS.Core.Application.Contracts;
|
|
|
|
namespace IRaCIS.Application.Services
|
|
{
|
|
/// <summary>
|
|
/// 阅片临床数据配置
|
|
/// </summary>
|
|
[ApiExplorerSettings(GroupName = "Reading")]
|
|
public class ReadingClinicalDataService : BaseService, IReadingClinicalDataService
|
|
{
|
|
private readonly IRepository<ReadingClinicalData> _readingClinicalDataRepository;
|
|
private readonly IRepository<ClinicalDataTrialSet> _clinicalDataTrialSetRepository;
|
|
private readonly IRepository<ReadingClinicalDataPDF> _readingClinicalDataPDFRepository;
|
|
|
|
public ReadingClinicalDataService(IRepository<ReadingClinicalData> readingClinicalDataRepository,
|
|
IRepository<ClinicalDataTrialSet> clinicalDataTrialSetRepository,
|
|
IRepository<ReadingClinicalDataPDF> readingClinicalDataPDFRepository
|
|
)
|
|
{
|
|
this._readingClinicalDataRepository = readingClinicalDataRepository;
|
|
this._clinicalDataTrialSetRepository = clinicalDataTrialSetRepository;
|
|
this._readingClinicalDataPDFRepository = readingClinicalDataPDFRepository;
|
|
}
|
|
|
|
|
|
/// <summary>
|
|
/// 新增或者修改
|
|
/// </summary>
|
|
/// <param name="indto"></param>
|
|
/// <returns></returns>
|
|
[HttpPost]
|
|
public async Task<IResponseOutput> AddOrUpdateReadingClinicalData(AddOrUpdateReadingClinicalDataDto indto)
|
|
{
|
|
|
|
var existsQuery = _readingClinicalDataRepository
|
|
.WhereIf(indto.Id != null,x=>x.Id!=indto.Id)
|
|
.Where(x => x.ClinicalDataTrialSetId == indto.ClinicalDataTrialSetId&&x.ReadingId==indto.ReadingId);
|
|
|
|
if (await existsQuery.AnyAsync())
|
|
{
|
|
ResponseOutput.NotOk("存在同类型的临床数据");
|
|
}
|
|
|
|
var clinicalDataTrialSet = (await _clinicalDataTrialSetRepository.Where(x => x.Id == indto.ClinicalDataTrialSetId).FirstOrDefaultAsync()).IfNullThrowException();
|
|
if (indto.Id == null)
|
|
{
|
|
var entity = _mapper.Map<ReadingClinicalData>(indto);
|
|
entity.ReadingClinicalDataPDFList = indto.AddFileList.Select(x => new ReadingClinicalDataPDF()
|
|
{
|
|
TrialId = entity.TrialId,
|
|
SubjectId= indto.SubjectId,
|
|
FileName=x.FileName,
|
|
Path=x.Path,
|
|
ClinicalDataTrialSetId=indto.ClinicalDataTrialSetId,
|
|
IsVisit= indto.IsVisit,
|
|
ClinicalDataLevel= clinicalDataTrialSet.ClinicalDataLevel,
|
|
ReadingId=indto.ReadingId
|
|
}).ToList();
|
|
|
|
|
|
await _readingClinicalDataRepository.AddAsync(entity, true);
|
|
return ResponseOutput.Ok(entity.Id);
|
|
}
|
|
else
|
|
{
|
|
var entity = (await _readingClinicalDataRepository.Where(t => t.Id == indto.Id, true).FirstOrDefaultAsync()).IfNullThrowException();
|
|
_mapper.Map(indto, entity);
|
|
await _readingClinicalDataPDFRepository.DeleteFromQueryAsync(x => indto.DeleteFileIds.Contains(x.Id));
|
|
var addFileList = indto.AddFileList.Select(x => new ReadingClinicalDataPDF()
|
|
{
|
|
|
|
TrialId = entity.TrialId,
|
|
SubjectId = indto.SubjectId,
|
|
FileName = x.FileName,
|
|
Path = x.Path,
|
|
IsVisit = indto.IsVisit,
|
|
ClinicalDataLevel = clinicalDataTrialSet.ClinicalDataLevel,
|
|
ReadingId = indto.ReadingId
|
|
}).ToList();
|
|
await _readingClinicalDataPDFRepository.AddRangeAsync(addFileList);
|
|
|
|
var success = await _readingClinicalDataRepository.SaveChangesAsync();
|
|
return ResponseOutput.Ok(entity.Id);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
/// <summary>
|
|
/// 删除
|
|
/// </summary>
|
|
/// <param name="id"></param>
|
|
/// <returns></returns>
|
|
[HttpDelete("{id:guid}")]
|
|
public async Task<IResponseOutput> DeleteReadingClinicalData(Guid id)
|
|
{
|
|
|
|
await _readingClinicalDataRepository.DeleteFromQueryAsync(x => x.Id == id, true);
|
|
return ResponseOutput.Result(true);
|
|
}
|
|
|
|
|
|
/// <summary>
|
|
/// 获取下拉菜单
|
|
/// </summary>
|
|
/// <param name="inDto"></param>
|
|
/// <returns></returns>
|
|
[HttpPost]
|
|
public async Task<List<GetTrialClinicalDataSelectOutDto>> GetTrialClinicalDataSelect(GetTrialClinicalDataSelectIndto inDto)
|
|
{
|
|
|
|
List<GetTrialClinicalDataSelectOutDto> clinicalList = await _clinicalDataTrialSetRepository.Where(x=>x.TrialId==inDto.TrialId&&x.IsConfirm)
|
|
|
|
//.WhereIf(inDto.ReadingClinicalDataId==null, x=> _readingClinicalDataPDFRepository.Where(y=>y.ObjectId==inDto.ObjectId&&))
|
|
|
|
.Select(x => new GetTrialClinicalDataSelectOutDto()
|
|
{
|
|
ClinicalDataLevel = x.ClinicalDataLevel,
|
|
ClinicalDataSetName = x.ClinicalDataSetName,
|
|
ClinicalUploadType = x.ClinicalUploadType,
|
|
ClinicalDataLevelName = x.ClinicalDataLevel.GetDisplayName(),
|
|
ClinicalUploadTypeName = x.ClinicalUploadType.GetDisplayName(),
|
|
|
|
Id = x.Id
|
|
}).ToListAsync() ;
|
|
return clinicalList;
|
|
}
|
|
|
|
|
|
|
|
/// <summary>
|
|
/// 获取阅片临床数据列表
|
|
/// </summary>
|
|
/// <param name="inDto"></param>
|
|
/// <returns></returns>
|
|
[HttpPost]
|
|
public async Task<PageOutput<GetReadingClinicalDataListOutDto>> GetReadingClinicalDataList(GetReadingClinicalDataListIndto inDto)
|
|
{
|
|
var result = await _readingClinicalDataRepository.Where(x=>x.ReadingId==inDto.ReadingId).ProjectTo<GetReadingClinicalDataListOutDto>(_mapper.ConfigurationProvider).ToPagedListAsync(inDto.PageIndex, inDto.PageSize, inDto.SortField == null ? nameof(GetReadingClinicalDataListOutDto.ClinicalDataSetName) : inDto.SortField,
|
|
inDto.Asc);
|
|
|
|
|
|
foreach (var item in result.CurrentPageData)
|
|
{
|
|
item.ClinicalDataLevelName = item.ClinicalDataLevel.GetDisplayName();
|
|
item.ClinicalUploadTypeName = item.ClinicalUploadType.GetDisplayName();
|
|
item.FileList = item.ClinicalDataLevel != ClinicalLevel.Subject ? (await _readingClinicalDataPDFRepository.Where(y => y.ReadingClinicalDataId == item.Id).Select(y => new GetFileDto()
|
|
{
|
|
Id = y.Id,
|
|
FileName = y.FileName,
|
|
Path = y.Path
|
|
}).ToListAsync()) : (await _readingClinicalDataPDFRepository.Where(y => y.SubjectId == item.SubjectId).Select(y => new GetFileDto()
|
|
{
|
|
Id = y.Id,
|
|
FileName = y.FileName,
|
|
Path = y.Path
|
|
}).ToListAsync());
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
return result;
|
|
}
|
|
|
|
|
|
/// <summary>
|
|
/// 获取单个阅片临床数据的所有文件
|
|
/// </summary>
|
|
/// <param name="inDto"></param>
|
|
/// <returns></returns>
|
|
[HttpPost]
|
|
public async Task<PageOutput<GetReadingClinicalDataPDFListOutDto>> GetReadingClinicalDataPDFList(GetReadingClinicalDataPDFListIndto inDto) {
|
|
|
|
var result = await _readingClinicalDataPDFRepository.Where(x => x.ReadingClinicalDataId == inDto.ReadingClinicalDataId).ProjectTo<GetReadingClinicalDataPDFListOutDto>(_mapper.ConfigurationProvider)
|
|
.ToPagedListAsync(inDto.PageIndex, inDto.PageSize, inDto.SortField == null ? nameof(GetReadingClinicalDataPDFListOutDto.FileName) : inDto.SortField,
|
|
inDto.Asc);
|
|
|
|
return result;
|
|
}
|
|
|
|
///// <summary>
|
|
///// 新增或者修改PDF
|
|
///// </summary>
|
|
///// <param name="indto"></param>
|
|
///// <returns></returns>
|
|
//[HttpPost]
|
|
//public async Task<IResponseOutput> AddOrUpdateReadingClinicalDataPDF(AddOrUpdateReadingClinicalDataPDFDto indto)
|
|
//{
|
|
// var entity = await _readingClinicalDataPDFRepository.InsertOrUpdateAsync(indto, true);
|
|
// return ResponseOutput.Ok(entity.Id.ToString());
|
|
//}
|
|
|
|
|
|
/// <summary>
|
|
/// 删除PDF单个文件
|
|
/// </summary>
|
|
/// <param name="id"></param>
|
|
/// <returns></returns>
|
|
[HttpDelete("{id:guid}")]
|
|
public async Task<IResponseOutput> DeleteReadingClinicalDataPDF(Guid id)
|
|
{
|
|
await _readingClinicalDataPDFRepository.DeleteFromQueryAsync(x => x.Id == id, true);
|
|
return ResponseOutput.Result(true);
|
|
}
|
|
|
|
|
|
}
|
|
}
|