//--------------------------------------------------------------------
//     此代码由T4模板自动生成  byzhouhang 20210918
//	   生成时间 2021-11-22 11:29:44 
//     对此文件的更改可能会导致不正确的行为,并且如果重新生成代码,这些更改将会丢失。
//--------------------------------------------------------------------
using Microsoft.AspNetCore.Mvc;
using IRaCIS.Core.Application.Service;

namespace IRaCIS.Core.Application.Contracts
{
    /// <summary>
    ///受试者临床信息
    /// </summary>	
    [ApiExplorerSettings(GroupName = "Image")]
    public class ClinicalDataService : BaseService, IClinicalDataService
    {
        public IRepository<PreviousOther> _previousOtherRepository { get; }
        private readonly IRepository<PreviousHistory> _previousHistoryRepository;
        private readonly IRepository<PreviousSurgery> _previousSurgeryRepository;
        private readonly IRepository<PreviousPDF> _previousPdfRepository;
        private readonly IRepository<SubjectVisit> _subjectVisitRepository;


        public ClinicalDataService(IRepository<PreviousHistory> previousHistoryRepository, 
            IRepository<PreviousOther> previousOtherRepository,
            IRepository<PreviousSurgery> previousSurgeryRepository,
            IRepository<PreviousPDF> previousPDFRepository,
             IRepository<SubjectVisit> subjectVisitRepository
            )
        {
            _previousOtherRepository = previousOtherRepository;
            _previousHistoryRepository = previousHistoryRepository;
            _previousSurgeryRepository = previousSurgeryRepository;
            _previousPdfRepository = previousPDFRepository;
            _subjectVisitRepository = subjectVisitRepository;
        }




        /// <summary>
        /// 获取访视+受试者级别的数据
        /// </summary>
        /// <param ></param>
        /// <returns></returns>
        [HttpGet("{subjectVisitId:guid}")]
        public async Task<SubjectClinicalDataDto> GetSubjectVisitClinicalData(Guid subjectVisitId)
        {

            // 最完美方式  其中TrialSite 通过导航属性 两个字段连接出来

            var clinicalObj = await _repository.Where<SubjectVisit>(t => t.Id == subjectVisitId)
            .ProjectTo<SubjectClinicalDataDto>(_mapper.ConfigurationProvider, new { subjectVisitId = subjectVisitId, token = _userInfo.UserToken }).FirstOrDefaultAsync().IfNullThrowException();

            return clinicalObj;

            #region 老方式  linq join 而且需要映射  


            //var query = from sv in _subjectVisitRepository.GetAll()
            //            join subject in _subjectRepository.GetAll() on sv.SubjectId equals subject.Id
            //            join trialSite in _trialSiteRepository.Find(t => t.TrialId == subjectClinicalDataQuery.TrialId) on sv.SiteId equals trialSite.SiteId
            //            select new SubjectClinicalDataDto()
            //            {
            //                SubjectId = sv.SubjectId,
            //                SubjectCode = subject.Code,
            //                SubjectVisitId = sv.Id,
            //                VisitName = sv.VisitName,
            //                VisitNum = sv.VisitNum,
            //                TrialSiteCode = trialSite.TrialSiteCode
            //            };

            //var clinicalObj = query.FirstOrDefault(t => t.SubjectVisitId == subjectClinicalDataQuery.SubjectVisitId);

            //clinicalObj.PreviousHistoryList = _previousHistoryRepository.Find(t => t.SubjectVisitId == subjectClinicalDataQuery.SubjectVisitId)
            //                                   .ProjectTo<PreviousHistoryView>(_mapper.ConfigurationProvider).ToList();
            //clinicalObj.PreviousOtherList = _previousOtherRepository.Find(t => t.SubjectVisitId == subjectClinicalDataQuery.SubjectVisitId)
            //                                   .ProjectTo<PreviousOtherView>(_mapper.ConfigurationProvider).ToList();
            //clinicalObj.PreviousSurgeryList = _previousSurgeryRepository.Find(t => t.SubjectVisitId == subjectClinicalDataQuery.SubjectVisitId)
            //                                   .ProjectTo<PreviousSurgeryView>(_mapper.ConfigurationProvider).ToList();

            #endregion

        }


        public async Task<List<PreviousHistoryView>> GetPreviousHistoryList(PreviousHistoryQuery queryPreviousHistory)
        {

            var previousHistoryQueryable = _previousHistoryRepository.WhereIf(queryPreviousHistory.IsSubjectLevel != null, t => t.IsSubjectLevel == queryPreviousHistory.IsSubjectLevel)
             .ProjectTo<PreviousHistoryView>(_mapper.ConfigurationProvider, new { token = _userInfo.UserToken });

            return await previousHistoryQueryable.ToListAsync();
        }

        [HttpPost("{trialId:guid}")]
        public async Task<IResponseOutput<Guid>> AddOrUpdatePreviousHistory(PreviousHistoryAddOrEdit addOrEditPreviousHistory)
        {
            await QCCommon.VerifyIsCRCSubmmitAsync(_repository, _userInfo, addOrEditPreviousHistory.SubjectVisitId);

            var entity = await _previousHistoryRepository.InsertOrUpdateAsync(addOrEditPreviousHistory, true);
            return ResponseOutput.Ok(entity.Id);
        }


        [HttpDelete("{trialId:guid}/{subjectVisitId:guid}/{previousHistoryId:guid}")]
        public async Task<IResponseOutput> DeletePreviousHistory(Guid previousHistoryId,Guid subjectVisitId)
        {
            await QCCommon.VerifyIsCRCSubmmitAsync(_repository, _userInfo, subjectVisitId);
            await _previousHistoryRepository.DeleteFromQueryAsync(t => t.Id == previousHistoryId,true);
            return ResponseOutput.Ok();
        }


        public async Task<List<PreviousOtherView>> GetPreviousOtherList(PreviousOtherQuery queryPreviousOther)
        {
            var previousOtherQueryable = _previousOtherRepository.WhereIf(queryPreviousOther.IsSubjectLevel != null, t => t.IsSubjectLevel == queryPreviousOther.IsSubjectLevel)
                .ProjectTo<PreviousOtherView>(_mapper.ConfigurationProvider, new { token = _userInfo.UserToken });
            return await previousOtherQueryable.ToListAsync();
        }


        [HttpPost("{trialId:guid}")]
        public async Task<IResponseOutput<Guid>> AddOrUpdatePreviousOther(PreviousOtherAddOrEdit addOrEditPreviousOther)
        {
            await QCCommon.VerifyIsCRCSubmmitAsync(_repository, _userInfo, addOrEditPreviousOther.SubjectVisitId);
            var entity = await _previousOtherRepository.InsertOrUpdateAsync(addOrEditPreviousOther, true);
            return ResponseOutput.Ok(entity.Id);

        }


        [HttpDelete("{trialId:guid}/{subjectVisitId:guid}/{previousOtherId:guid}")]
        public async Task<IResponseOutput> DeletePreviousOther(Guid previousOtherId, Guid subjectVisitId)
        {
            await QCCommon.VerifyIsCRCSubmmitAsync(_repository, _userInfo, subjectVisitId);

            await _previousOtherRepository.DeleteFromQueryAsync(t => t.Id == previousOtherId,true);
            return ResponseOutput.Ok();
        }


        public async Task<List<PreviousSurgeryView>> GetPreviousSurgeryList(PreviousSurgeryQuery queryPreviousSurgery)
        {
            var previousSurgeryQueryable = _previousSurgeryRepository.WhereIf(queryPreviousSurgery.IsSubjectLevel != null, t => t.IsSubjectLevel == queryPreviousSurgery.IsSubjectLevel)
             .ProjectTo<PreviousSurgeryView>(_mapper.ConfigurationProvider, new { token = _userInfo.UserToken });

            return await previousSurgeryQueryable.ToListAsync();
        }

        [HttpPost("{trialId:guid}")]
        public async Task<IResponseOutput<Guid>> AddOrUpdatePreviousSurgery(PreviousSurgeryAddOrEdit addOrEditPreviousSurgery)
        {
            await QCCommon.VerifyIsCRCSubmmitAsync(_repository, _userInfo, addOrEditPreviousSurgery.SubjectVisitId);
            var entity = await _previousSurgeryRepository.InsertOrUpdateAsync(addOrEditPreviousSurgery, true);
            return ResponseOutput.Ok(entity.Id);
        }


        [HttpDelete("{trialId:guid}/{subjectVisitId:guid}/{previousSurgeryId:guid}")]
        public async Task<IResponseOutput> DeletePreviousSurgery(Guid previousSurgeryId, Guid subjectVisitId)
        {
            await QCCommon.VerifyIsCRCSubmmitAsync(_repository, _userInfo, subjectVisitId);
            var success = await _previousSurgeryRepository.DeleteFromQueryAsync(t => t.Id == previousSurgeryId,true);
            return ResponseOutput.Ok();
        }

        [HttpGet("{subjectVisitId:guid}")]
        public async Task<List<PreviousPDFView>> GetPreviousPDFList(Guid subjectVisitId)
        {

            var previousPDFQueryable = _previousPdfRepository.Where(t => t.SubjectVisitId == subjectVisitId).ProjectTo<PreviousPDFView>(_mapper.ConfigurationProvider);

            return await previousPDFQueryable.ToListAsync();
        }


        public async Task<IResponseOutput> AddOrUpdatePreviousPDF(PreviousPDFAddOrEdit addOrEditPreviousPDF)
        {
            await QCCommon.VerifyIsCRCSubmmitAsync(_repository, _userInfo, addOrEditPreviousPDF.SubjectVisitId);
            var entity = await _previousPdfRepository.InsertOrUpdateAsync(addOrEditPreviousPDF, true);
            return ResponseOutput.Ok(entity.Id);

        }

        [HttpDelete("{trialId:guid}/{subjectVisitId:guid}/{previousPDFId:guid}")]
        public async Task<IResponseOutput> DeletePreviousPDF(Guid previousPDFId, Guid subjectVisitId)
        {
            await QCCommon.VerifyIsCRCSubmmitAsync(_repository, _userInfo, subjectVisitId);

            await _previousPdfRepository.DeleteFromQueryAsync(t => t.Id == previousPDFId,true);
            return ResponseOutput.Ok();
        }




    }
}