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 IRaCIS.Core.Infra.EFCore.Common; namespace IRaCIS.Application.Services { /// /// 阅片期配置 /// [ApiExplorerSettings(GroupName = "Reading")] public class ReadingPeriodSetService : BaseService { public IRepository _subjectVisitRepository; private readonly IRepository _readingPeriodSetRepository; private readonly IRepository _readModuleRepository; private readonly IRepository _siteSetRepository; public ReadingPeriodSetService(IRepository subjectVisitRepository, IRepository ReadingPeriodSetRepository, IRepository readModuleRepository, IRepository SiteSetRepository ) { _subjectVisitRepository = subjectVisitRepository; _readingPeriodSetRepository = ReadingPeriodSetRepository; this._readModuleRepository = readModuleRepository; _siteSetRepository = SiteSetRepository; } /// /// 新增或者修改 /// /// /// [HttpPost] public async Task AddOrUpdateReadingPeriodSet(ReadingPeriodSetAddOrEdit addOrEditReadingPeriodSet) { if (addOrEditReadingPeriodSet.Id == null) { var entity = _mapper.Map(addOrEditReadingPeriodSet); entity.ReadingPeriodSites = addOrEditReadingPeriodSet.SiteIds.Select(x => new ReadingPeriodSite() { ReadingPeriodSetId = entity.Id, TrialId =entity.TrialId, SiteId = x, }).ToList(); await _readingPeriodSetRepository.AddAsync(entity, true); return ResponseOutput.Ok(); } else { var entity = (await _readingPeriodSetRepository.Where(t => t.Id == addOrEditReadingPeriodSet.Id, true).Include(t => t.ReadingPeriodSites).FirstOrDefaultAsync()).IfNullThrowException(); _mapper.Map(addOrEditReadingPeriodSet, entity); entity.ReadingPeriodSites = addOrEditReadingPeriodSet.SiteIds.Select(x => new ReadingPeriodSite() { ReadingPeriodSetId = entity.Id, TrialId = entity.TrialId, SiteId = x, }).ToList(); var success = await _readingPeriodSetRepository.SaveChangesAsync(); return ResponseOutput.Ok(); } } /// /// 获取影像阅片的预览 /// /// public async Task> GetPreviewTheReadingList(PreviewTheReadingListInDto inDto) { var readset = (await _readingPeriodSetRepository.Where(x => x.Id == inDto.ReadingPeriodSetId).Include(x => x.ReadingPeriodSites).FirstOrDefaultAsync()).IfNullThrowConvertException(); var visitquery = _subjectVisitRepository.Where(x => x.TrialId == readset.TrialId && x.LatestScanDate != null && x.InPlan); if (readset.ReadingScope == ReadingScopeEnum.Site) { var siteids = readset.ReadingPeriodSites.Select(x => x.Id); visitquery = visitquery.Where(x => siteids.Contains(x.SiteId)); } visitquery = visitquery.WhereIf(readset.ExpirationDate != null, x => x.LatestScanDate <= readset.ExpirationDate.Value); visitquery = visitquery.WhereIf(readset.ExpirationVisitNum != null, x => x.VisitNum <= readset.ExpirationVisitNum); var visits = (await visitquery.Include(x=>x.Subject).Include(x=>x.TrialSite).GroupBy(x => x.SubjectId).Select(x => new { SubjectId = x.Key, visit = x.OrderByDescending(x => x.VisitNum).FirstOrDefault() }).ToListAsync()).Select(x => x.visit).ToList(); return visits.Where(x => _readModuleRepository.Where(y => y.ReadingSetType == readset.ReadingSetType && x.Id == y.SubjectVisitId).Count() == 0) .Select(x => new PreviewTheReadingListOutDto { ExpirationDate= readset.ExpirationDate, SubjectVisitId=x.Id, TrialSiteCode = x.TrialSite.TrialSiteCode, LatestScanDate=x.LatestScanDate, ReadingPeriodName= readset.ReadingPeriodName, ReadingPeriodSetId=readset.Id, SubjectCode=x.Subject.Code, SubjectId=x.SubjectId, Remark= readset.Remark }).ToList(); } /// /// 添加对应的阅片 /// /// /// public async Task ReadingToGenerate(ReadingToGenerateInDto inDto) { var readset = (await _readingPeriodSetRepository.Where(x => x.Id == inDto.ReadingPeriodSetId).Include(x => x.ReadingPeriodSites).FirstOrDefaultAsync()).IfNullThrowConvertException(); var visits = await _subjectVisitRepository.Where(x => inDto.SubjectVisitIds.Contains(x.Id)).ToListAsync(); List readModules = new List(); foreach (var item in visits) { readModules.Add(new ReadModule() { Id = NewId.NextGuid(), SubjectId = item.SubjectId, ModuleType = readset.ReadingSetType == ReadingSetType.ImageReading ? ModuleTypeEnum.Read : ModuleTypeEnum.Oncology, IsUrgent = item.IsUrgent, ModuleName = readset.ReadingPeriodName, SubjectVisitId = item.Id, ReadingSetType = readset.ReadingSetType, Status = ReadingCommon.GetVisitSubmitStateEnum(item), }); }; await _readModuleRepository.AddRangeAsync(readModules); var res = await _subjectVisitRepository.SaveChangesAsync(); return ResponseOutput.Result(res); } /// /// 分页获取 /// /// /// [HttpPost] public async Task> GetReadingPeriodSetList(ReadingPeriodSetQuery query) { var readquery =_readingPeriodSetRepository.AsQueryable().Include(x=>x.ReadingPeriodSites) .WhereIf(query.TrialId!=null,x=>x.TrialId==query.TrialId) .WhereIf(query.ReadingPeriodName != null, x => x.ReadingPeriodName.Contains(query.ReadingPeriodName)) .ProjectTo(_mapper.ConfigurationProvider); var pageList= await readquery.ToPagedListAsync(query.PageIndex, query.PageSize, query.SortField == null ? "CreateTime" : query.SortField, query.SortAsc); return pageList; } /// /// 获取单条 /// /// /// [HttpPost("{id:guid}")] public async Task GetReadingPeriodSet(Guid id) { var data = await _readingPeriodSetRepository.AsQueryable().Include(x => x.ReadingPeriodSites).Where(x => x.Id == id).ProjectTo(_mapper.ConfigurationProvider).FirstOrDefaultAsync(); return data; } /// /// 设置阅片期配置是否生效 /// /// /// [HttpPut] public async Task SetReadingPeriodSetEffect(SetReadingPeriodSetEffect indto) { var readquery =await _readingPeriodSetRepository.UpdatePartialNowNoQueryAsync(indto.Id, x => new ReadingPeriodSet() { IsTakeEffect = indto.IsTakeEffect }); return ResponseOutput.Result(true); } /// /// 删除 /// /// /// [HttpDelete("{readingPeriodSetId:guid}")] public async Task DeleteReadingPeriodSet(Guid readingPeriodSetId) { var success = await _repository.BatchDeleteAsync(t => t.Id == readingPeriodSetId); return ResponseOutput.Result(success); } } }