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 MassTransit; using IRaCIS.Core.Infra.EFCore.Common; using IRaCIS.Core.Infrastructure.Extention; 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 _visitStageRepository; private readonly IRepository _readingPeriodPlanRepository; private readonly IRepository _siteSetRepository; private readonly IRepository _subjectRepository; public ReadingPeriodSetService(IRepository subjectVisitRepository, IRepository ReadingPeriodSetRepository, IRepository readModuleRepository, IRepository visitStageRepository, IRepository readingPeriodPlanRepository, IRepository SiteSetRepository, IRepository subjectRepository ) { _subjectVisitRepository = subjectVisitRepository; _readingPeriodSetRepository = ReadingPeriodSetRepository; this._readModuleRepository = readModuleRepository; this._visitStageRepository = visitStageRepository; this._readingPeriodPlanRepository = readingPeriodPlanRepository; _siteSetRepository = SiteSetRepository; _subjectRepository = subjectRepository; } /// /// 新增或者修改 /// /// /// [HttpPost] public async Task AddOrUpdateReadingPeriodSet(ReadingPeriodSetAddOrEdit addOrEditReadingPeriodSet) { if (await _readingPeriodSetRepository.AnyAsync(x => x.Id != addOrEditReadingPeriodSet.Id&&x.IsTakeEffect!= ReadingPeriodStatus.Revocation && x.TrialId == addOrEditReadingPeriodSet.TrialId && x.ReadingPeriodName == addOrEditReadingPeriodSet.ReadingPeriodName)) { return ResponseOutput.NotOk("阅片期名称重复,操作失败"); } if (addOrEditReadingPeriodSet.ReadingPeriodName == "Global") { return ResponseOutput.NotOk("阅片期名称不能为Global"); } 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(); entity.ReadingPeriodPlanList = addOrEditReadingPeriodSet.SubjectVisitIds.Select(x => new ReadingPeriodPlan { ReadingPeriodSetId = entity.Id, SubjectVisitId = x, }).ToList(); await _readingPeriodSetRepository.AddAsync(entity, true); return ResponseOutput.Ok(entity.Id); } else { var entity = (await _readingPeriodSetRepository.Where(t => t.Id == addOrEditReadingPeriodSet.Id, true).Include(t => t.ReadingPeriodSites).Include(x => x.ReadingPeriodPlanList).FirstOrDefaultAsync()).IfNullThrowException(); _mapper.Map(addOrEditReadingPeriodSet, entity); entity.ReadingPeriodSites = addOrEditReadingPeriodSet.SiteIds.Select(x => new ReadingPeriodSite() { ReadingPeriodSetId = entity.Id, TrialId = entity.TrialId, SiteId = x, }).ToList(); entity.ReadingPeriodPlanList = addOrEditReadingPeriodSet.SubjectVisitIds.Select(x => new ReadingPeriodPlan { ReadingPeriodSetId = entity.Id, SubjectVisitId = x, }).ToList(); var success = await _readingPeriodSetRepository.SaveChangesAsync(); return ResponseOutput.Ok(entity.Id); } } /// /// 获取影像阅片的预览 // 需要清除之前已经选中的 /// /// [HttpPost] public async Task> GetPreviewTheReadingList(PreviewTheReadingListInDto inDto) { // 当前项目 最晚拍片日期不为null 中心筛选 var visitQuery = _subjectVisitRepository.Where(x => x.TrialId == inDto.TrialId &&x.LatestScanDate!=null&&!x.IsLostVisit) .WhereIf(inDto.ReadingScope== ReadingScopeEnum.Site, x => inDto.SiteIds.Contains(x.SiteId)); // 已经存在的访视 需要排除 var existsBubjectVisitsQuery= _readModuleRepository.Where(y => y.ReadingSetType == inDto.ReadingSetType && y.TrialId == inDto.TrialId).Select(x => x.SubjectVisitId); visitQuery = visitQuery.Where(x => !existsBubjectVisitsQuery.Contains(x.Id)) .WhereIf(inDto.ExpirationDate != null, x => x.LatestScanDate <= inDto.ExpirationDate.Value) .WhereIf(inDto.ExpirationVisitNum != null, x => x.VisitNum == inDto.ExpirationVisitNum); var subjectIdlist = await visitQuery.OrderBy(x => x.SubjectId).Select(x => x.SubjectId).Distinct().Skip((inDto.PageIndex - 1) * inDto.PageSize).Take(inDto.PageSize).ToListAsync(); var totalCount = visitQuery.Select(x => x.SubjectId).Distinct().Count(); var visitlist = await visitQuery.Include(x => x.Subject).Include(x => x.TrialSite).Where(x => subjectIdlist.Contains(x.SubjectId)).ToListAsync(); var subjectVisits = visitlist.GroupBy(x => x.SubjectId).Select(x => new { SubjectId = x.Key, Visits = x.ToList() }); List visits = new List(); subjectVisits.ForEach(x => { var visit = x.Visits.OrderByDescending(x => x.VisitNum).FirstOrDefault(); if (visit != null) { visits.Add(visit); } }); PageOutput result = new PageOutput() { CurrentPageData = visits .Select(x => new PreviewTheReadingListOutDto { ExpirationDate = inDto.ExpirationDate, SubjectVisitId = x.Id, TrialSiteCode = x.TrialSite.TrialSiteCode, LatestScanDate = x.LatestScanDate, ReadingPeriodName = inDto.ReadingPeriodName, SubjectCode = x.Subject.Code, SubjectId = x.SubjectId, SubjectVisitName = x.VisitName, }).ToList(), PageSize = inDto.PageSize, PageIndex = inDto.PageIndex, TotalCount = totalCount, }; return result; } /// /// 添加对应的阅片 /// /// /// public async Task GenerateReadingTask(ReadingToGenerateInDto inDto) { List plans = new List(); inDto.SubjectVisitIds.ForEach(x => { plans.Add(new ReadingPeriodPlan() { SubjectVisitId = x, ReadingPeriodSetId = inDto.ReadingPeriodSetId }); }); await _readingPeriodPlanRepository.DeleteFromQueryAsync(x => x.ReadingPeriodSetId == inDto.ReadingPeriodSetId); await _readingPeriodPlanRepository.SaveChangesAsync(); await _readingPeriodPlanRepository.AddRangeAsync(plans); var result = await _readingPeriodPlanRepository.SaveChangesAsync(); return ResponseOutput.Result(result); } /// /// 获取选中的计划 /// /// /// [HttpPost] public async Task> GetPreviewTheReadingPlanList(PreviewTheReadingListDto inDto) { var plans = _readingPeriodPlanRepository.Where(x => x.ReadingPeriodSetId == inDto.ReadingPeriodSetId).Include(x => x.SubjectVisit).Include(x => x.SubjectVisit.TrialSite).Include(x => x.SubjectVisit.Subject) .Include(x => x.ReadingPeriodSet).Select(x => new PreviewTheReadingListOutDto { Id = x.Id, ExpirationDate = x.ReadingPeriodSet.ExpirationDate, SubjectVisitId = x.SubjectVisitId, TrialSiteCode = x.SubjectVisit.TrialSite.TrialSiteCode, LatestScanDate = x.SubjectVisit.LatestScanDate, ReadingPeriodName = x.ReadingPeriodSet.ReadingPeriodName, ReadingPeriodSetId = x.ReadingPeriodSetId, SubjectCode = x.SubjectVisit.Subject.Code, SubjectId = x.SubjectVisit.SubjectId, SubjectVisitName = x.SubjectVisit.VisitName, EffectOfTime = x.ReadingPeriodSet.EffectOfTime, }); return await plans.ToPagedListAsync(inDto.PageIndex, inDto.PageSize, inDto.SortField == null ? nameof(PreviewTheReadingListOutDto.SubjectId) : inDto.SortField, inDto.Asc); } /// /// 分页获取 /// /// /// [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 ? nameof(ReadingPeriodSetView.CreateTime) : query.SortField, query.Asc); pageList.CurrentPageData.ForEach(x => { x.SubjectVisitName = x.IsGlobal ? "末次访视" : x.SubjectVisitName; }); return pageList; } /// /// 获取单条 /// /// /// [HttpPost("{id:guid}")] public async Task GetReadingPeriodSet(Guid id) { return await _readingPeriodSetRepository.AsQueryable().Include(x => x.ReadingPeriodSites).Where(x => x.Id == id).ProjectTo(_mapper.ConfigurationProvider).FirstOrDefaultAsync(); } /// /// 获取阅片期配置的截至访视的下拉框 /// /// /// [HttpPost] public async Task> GetReadingVisitList(GetReadingVisitListInDto inDto) { var maxVisitNum = await _readingPeriodSetRepository.Where(x => x.TrialId == inDto.TrialId && x.ReadingSetType == inDto.ReadingSetType&&(x.IsTakeEffect== ReadingPeriodStatus.TakeEffect||x.IsTakeEffect==ReadingPeriodStatus.Revocation)).MaxAsync(x => x.ExpirationVisitNum)??0; var thisVisitNum = await _readingPeriodSetRepository.Where(x => x.Id == inDto.ReadingPeriodSetId).Select(x => x.ExpirationVisitNum).FirstOrDefaultAsync() ?? -1; List result = await _visitStageRepository.Where(x => x.TrialId == inDto.TrialId ).Where(x=>x.VisitNum== thisVisitNum || x.VisitNum >= maxVisitNum).Select(x => new GetReadingVisitListOutDto() { VisitName = x.VisitName, VisitNum = x.VisitNum, VisitStageId = x.Id, }).ToListAsync(); return result; } /// /// 设置阅片期配置是否生效 /// /// /// [HttpPut] public async Task SetReadingPeriodSetEffect(SetReadingPeriodSetEffect indto) { if (indto.IsTakeEffect == ReadingPeriodStatus.TakeEffect) { var readingPeriodSet = await _readingPeriodSetRepository.Where(x => x.Id == indto.Id).FirstOrDefaultAsync(); var plans = _readingPeriodPlanRepository.Where(x => x.ReadingPeriodSetId == indto.Id).Include(x => x.SubjectVisit) .Include(x => x.ReadingPeriodSet).Include(x => x.SubjectVisit).ToList(); var needAddVisitIds = plans.Select(x => x.SubjectVisitId).ToList(); var repeatVisitNames = _readModuleRepository.Where(x => x.ReadingSetType == ReadingSetType.ImageReading && needAddVisitIds.Contains(x.SubjectVisitId)).Select(x =>x.Subject.Code+"的"+ x.SubjectVisit.VisitName).ToList(); if(repeatVisitNames.Count!=0) { return ResponseOutput.NotOk($"{string.Join(",", repeatVisitNames)}已经添加过阅片期,无法设置生效"); } List readModules = new List(); foreach (var item in plans) { readModules.Add(new ReadModule() { Id = NewId.NextGuid(), SubjectId = item.SubjectVisit.SubjectId, ModuleType = item.ReadingPeriodSet.ReadingSetType == ReadingSetType.ImageReading ? ModuleTypeEnum.Read : ModuleTypeEnum.Oncology, IsUrgent = item.SubjectVisit.IsUrgent, ModuleName = item.ReadingPeriodSet.ReadingPeriodName, SubjectVisitId = item.SubjectVisitId, ReadingSetType = item.ReadingPeriodSet.ReadingSetType, ReadingPeriodSetId = item.ReadingPeriodSet.Id, Status = ReadModuleEnum.TaskAllocation, TrialId = readingPeriodSet.TrialId, VisitNum = item.SubjectVisit.VisitNum, }); }; await _readModuleRepository.AddRangeAsync(readModules); } else { await _readModuleRepository.DeleteFromQueryAsync(x => x.ReadingPeriodSetId == indto.Id); } var readQuery = await _readingPeriodSetRepository.UpdatePartialFromQueryAsync(indto.Id, x => new ReadingPeriodSet() { IsTakeEffect = indto.IsTakeEffect, EffectOfTime = indto.IsTakeEffect == ReadingPeriodStatus.TakeEffect ? DateTime.Now : null, }); var result = await _readingPeriodSetRepository.SaveChangesAsync(); return ResponseOutput.Result(result); } /// /// 删除 /// /// /// [HttpDelete("{readingPeriodSetId:guid}")] public async Task DeleteReadingPeriodSet(Guid readingPeriodSetId) { var success = await _repository.BatchDeleteAsync(t => t.Id == readingPeriodSetId); return ResponseOutput.Result(success); } } }