Merge branch 'Test.IRC' of http://192.168.3.69:2000/XCKJ/irc-netcore-api into Test.IRC
						commit
						9d446a6e29
					
				| 
						 | 
				
			
			@ -300,6 +300,15 @@
 | 
			
		|||
            <param name="_attachmentrepository"></param>
 | 
			
		||||
            <returns></returns>
 | 
			
		||||
        </member>
 | 
			
		||||
        <member name="M:IRaCIS.Core.API.Controllers.FileController.GetDoctorAttachment(IRaCIS.Core.API.Controllers.GetDoctoreAttachPathCommand,IRaCIS.Application.Interfaces.IDoctorService,IRaCIS.Core.Infra.EFCore.IRepository{IRaCIS.Core.Domain.Models.Attachment})">
 | 
			
		||||
            <summary>
 | 
			
		||||
            new  医生详情   下载指定简历
 | 
			
		||||
            </summary>
 | 
			
		||||
            <param name="command"></param>
 | 
			
		||||
            <param name="_doctorService"></param>
 | 
			
		||||
            <param name="_attachmentrepository"></param>
 | 
			
		||||
            <returns></returns>
 | 
			
		||||
        </member>
 | 
			
		||||
        <member name="M:IRaCIS.Core.API.Controllers.FileController.DownloadAttachment(System.Guid[])">
 | 
			
		||||
            <summary>
 | 
			
		||||
            下载多个医生的所有附件
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -4813,6 +4813,11 @@
 | 
			
		|||
            Path
 | 
			
		||||
            </summary>
 | 
			
		||||
        </member>
 | 
			
		||||
        <member name="P:IRaCIS.Core.Application.Service.Reading.Dto.GetDicomReadingQuestionAnswerInDto.GroupClassifyList">
 | 
			
		||||
            <summary>
 | 
			
		||||
            分组分类
 | 
			
		||||
            </summary>
 | 
			
		||||
        </member>
 | 
			
		||||
        <member name="P:IRaCIS.Core.Application.Service.Reading.Dto.GetDicomReadingQuestionAnswerInDto.QuestionClassify">
 | 
			
		||||
            <summary>
 | 
			
		||||
            问题分类
 | 
			
		||||
| 
						 | 
				
			
			@ -6598,6 +6603,11 @@
 | 
			
		|||
            问题分类
 | 
			
		||||
            </summary>
 | 
			
		||||
        </member>
 | 
			
		||||
        <member name="P:IRaCIS.Core.Application.Service.Reading.Dto.ReadingTableQuestionTrialAddOrEdit.GroupClassify">
 | 
			
		||||
            <summary>
 | 
			
		||||
            分组分类
 | 
			
		||||
            </summary>
 | 
			
		||||
        </member>
 | 
			
		||||
        <member name="P:IRaCIS.Core.Application.Service.Reading.Dto.ReadingTableQuestionTrialAddOrEdit.Unit">
 | 
			
		||||
            <summary>
 | 
			
		||||
            单位
 | 
			
		||||
| 
						 | 
				
			
			@ -6676,6 +6686,11 @@
 | 
			
		|||
            问题分类
 | 
			
		||||
            </summary>
 | 
			
		||||
        </member>
 | 
			
		||||
        <member name="P:IRaCIS.Core.Application.Service.Reading.Dto.ReadingTableQuestionSystemAddOrEdit.GroupClassify">
 | 
			
		||||
            <summary>
 | 
			
		||||
            分组分类
 | 
			
		||||
            </summary>
 | 
			
		||||
        </member>
 | 
			
		||||
        <member name="P:IRaCIS.Core.Application.Service.Reading.Dto.ReadingTableQuestionSystemAddOrEdit.DataSource">
 | 
			
		||||
            <summary>
 | 
			
		||||
            数据来源
 | 
			
		||||
| 
						 | 
				
			
			@ -7024,6 +7039,11 @@
 | 
			
		|||
            问题分类
 | 
			
		||||
            </summary>
 | 
			
		||||
        </member>
 | 
			
		||||
        <member name="P:IRaCIS.Core.Application.Service.Reading.Dto.ReadingQuestionTrialView.GroupClassify">
 | 
			
		||||
            <summary>
 | 
			
		||||
            分组分类
 | 
			
		||||
            </summary>
 | 
			
		||||
        </member>
 | 
			
		||||
        <member name="P:IRaCIS.Core.Application.Service.Reading.Dto.ReadingQuestionTrialView.Unit">
 | 
			
		||||
            <summary>
 | 
			
		||||
            单位
 | 
			
		||||
| 
						 | 
				
			
			@ -7084,6 +7104,11 @@
 | 
			
		|||
            问题分类
 | 
			
		||||
            </summary>
 | 
			
		||||
        </member>
 | 
			
		||||
        <member name="P:IRaCIS.Core.Application.Service.Reading.Dto.ReadingQuestionSystemView.GroupClassify">
 | 
			
		||||
            <summary>
 | 
			
		||||
            分组分类
 | 
			
		||||
            </summary>
 | 
			
		||||
        </member>
 | 
			
		||||
        <member name="P:IRaCIS.Core.Application.Service.Reading.Dto.ReadingQuestionSystemView.Remark">
 | 
			
		||||
            <summary>
 | 
			
		||||
            备注
 | 
			
		||||
| 
						 | 
				
			
			@ -7439,6 +7464,11 @@
 | 
			
		|||
            问题分类
 | 
			
		||||
            </summary>
 | 
			
		||||
        </member>
 | 
			
		||||
        <member name="P:IRaCIS.Core.Application.Service.Reading.Dto.AddOrUpdateReadingQuestionSystemInDto.GroupClassify">
 | 
			
		||||
            <summary>
 | 
			
		||||
            分组分类
 | 
			
		||||
            </summary>
 | 
			
		||||
        </member>
 | 
			
		||||
        <member name="P:IRaCIS.Core.Application.Service.Reading.Dto.AddOrUpdateReadingQuestionSystemInDto.LimitEdit">
 | 
			
		||||
            <summary>
 | 
			
		||||
            限制编辑
 | 
			
		||||
| 
						 | 
				
			
			@ -7769,6 +7799,11 @@
 | 
			
		|||
            问题分类
 | 
			
		||||
            </summary>
 | 
			
		||||
        </member>
 | 
			
		||||
        <member name="P:IRaCIS.Core.Application.Service.Reading.Dto.AddOrUpdateReadingQuestionTrialInDto.GroupClassify">
 | 
			
		||||
            <summary>
 | 
			
		||||
            分组分类
 | 
			
		||||
            </summary>
 | 
			
		||||
        </member>
 | 
			
		||||
        <member name="P:IRaCIS.Core.Application.Service.Reading.Dto.AddOrUpdateReadingQuestionTrialInDto.DataSource">
 | 
			
		||||
            <summary>
 | 
			
		||||
            数据来源
 | 
			
		||||
| 
						 | 
				
			
			@ -13183,7 +13218,7 @@
 | 
			
		|||
            <param name="inDto"></param>
 | 
			
		||||
            <returns></returns>
 | 
			
		||||
        </member>
 | 
			
		||||
        <member name="M:IRaCIS.Application.Services.ReadingImageTaskService.GetReadingQuestion(System.Guid,System.Nullable{System.Guid},System.Nullable{IRaCIS.Core.Domain.Share.QuestionClassify})">
 | 
			
		||||
        <member name="M:IRaCIS.Application.Services.ReadingImageTaskService.GetReadingQuestion(System.Guid,System.Nullable{System.Guid},System.Nullable{IRaCIS.Core.Domain.Share.QuestionClassify},System.Collections.Generic.List{IRaCIS.Core.Domain.Share.GroupClassify})">
 | 
			
		||||
            <summary>
 | 
			
		||||
            获取阅片外层问题
 | 
			
		||||
            </summary>
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -370,10 +370,6 @@ namespace IRaCIS.Core.Application.Service
 | 
			
		|||
 | 
			
		||||
 | 
			
		||||
                    }
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
                }
 | 
			
		||||
                else if (businessScenarioEnum == EmailBusinessScenario.PDConfirmed)
 | 
			
		||||
                {
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -12,8 +12,11 @@ namespace IRaCIS.Core.Application.Service
 | 
			
		|||
    {
 | 
			
		||||
        public ImageAndDocConfig()
 | 
			
		||||
        {
 | 
			
		||||
            CreateMap<AddOrUpdateStudyDto, DicomStudy>();
 | 
			
		||||
            CreateMap<AddOrUpdateSeriesDto, DicomSeries>();
 | 
			
		||||
            CreateMap<AddOrUpdateStudyDto, DicomStudy>()
 | 
			
		||||
               .ForMember(d => d.SeriesList, u => u.Ignore());
 | 
			
		||||
            CreateMap<AddOrUpdateSeriesDto, DicomSeries>()
 | 
			
		||||
                 .ForMember(d => d.DicomInstanceList, u => u.Ignore());
 | 
			
		||||
 | 
			
		||||
            CreateMap<AddInstanceDto, DicomInstance>();
 | 
			
		||||
 | 
			
		||||
            CreateMap<Report, ReportDTO>();
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -84,7 +84,6 @@ namespace IRaCIS.Core.Application.Contracts
 | 
			
		|||
 | 
			
		||||
 | 
			
		||||
        public bool? IsGenerateAccount { get; set; }
 | 
			
		||||
        public Guid? TrialRoleNameId { get; set; }
 | 
			
		||||
 | 
			
		||||
        public TrialSiteUserStateEnum? State { get; set; }
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -168,6 +167,29 @@ namespace IRaCIS.Core.Application.Contracts
 | 
			
		|||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public class TrialSiteSurveySelectView
 | 
			
		||||
    {
 | 
			
		||||
        public Guid Id { get; set; }
 | 
			
		||||
        public TrialSiteSurveyEnum State { get; set; }
 | 
			
		||||
        public DateTime CreateTime { get; set; }
 | 
			
		||||
        public bool IsDeleted { get; set; }
 | 
			
		||||
 | 
			
		||||
        public string Phone { get; set; } = string.Empty;
 | 
			
		||||
        public string Email { get; set; } = string.Empty;
 | 
			
		||||
 | 
			
		||||
        public string UserName { get; set; } = string.Empty;
 | 
			
		||||
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public class TrialSiteSurveySelectquery
 | 
			
		||||
    {
 | 
			
		||||
        public Guid TrialId { get; set; }
 | 
			
		||||
 | 
			
		||||
        public Guid SiteId { get; set; }
 | 
			
		||||
 | 
			
		||||
        public Guid TrialSiteSurveyId { get; set; }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    ///<summary>TrialSiteSurveyQuery  列表查询参数模型</summary>
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -5,7 +5,9 @@
 | 
			
		|||
//--------------------------------------------------------------------
 | 
			
		||||
using IRaCIS.Core.Application.Helper;
 | 
			
		||||
using IRaCIS.Core.Domain.Share;
 | 
			
		||||
using MiniExcelLibs.Attributes;
 | 
			
		||||
using Newtonsoft.Json;
 | 
			
		||||
using System.ComponentModel.DataAnnotations;
 | 
			
		||||
 | 
			
		||||
namespace IRaCIS.Core.Application.Contracts
 | 
			
		||||
{
 | 
			
		||||
| 
						 | 
				
			
			@ -48,14 +50,18 @@ namespace IRaCIS.Core.Application.Contracts
 | 
			
		|||
            }
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        public string TrialRoleName { get; set; }
 | 
			
		||||
 | 
			
		||||
        public string TrialRoleCode { get; set; }
 | 
			
		||||
 | 
			
		||||
        public UserTypeEnum? UserTypeEnum { get; set; }
 | 
			
		||||
 | 
			
		||||
        public Guid? SystemUserId { get; set; }
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
        public bool? IsHistoryUserOriginDeleted { get; set; }
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -98,11 +104,20 @@ namespace IRaCIS.Core.Application.Contracts
 | 
			
		|||
 | 
			
		||||
        [DictionaryTranslateAttribute("YesOrNo")]
 | 
			
		||||
        public bool IsGenerateAccount { get; set; }
 | 
			
		||||
        public Guid TrialRoleNameId { get; set; }
 | 
			
		||||
        public int TrialRoleCode { get; set; }
 | 
			
		||||
 | 
			
		||||
        public string OrganizationName { get; set; } = string.Empty;
 | 
			
		||||
 | 
			
		||||
        public bool IsHistoryUser { get; set; }
 | 
			
		||||
        public bool? IsHistoryUserDeleted { get; set; }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public class TrialSiteUserSurverQuery
 | 
			
		||||
    {
 | 
			
		||||
        public Guid TrialSiteSurveyId { get; set; }
 | 
			
		||||
 | 
			
		||||
        public bool? IsHistoryUser { get; set; }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public class TrialSiteUserSurveyVerfyResult
 | 
			
		||||
    {
 | 
			
		||||
| 
						 | 
				
			
			@ -111,6 +126,44 @@ namespace IRaCIS.Core.Application.Contracts
 | 
			
		|||
        public List<string> ErroMsgList { get; set; } = new List<string>();
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public class SiteSurveyUserImportUploadDto
 | 
			
		||||
    {
 | 
			
		||||
        [NotDefault]
 | 
			
		||||
        public Guid TrialId { get; set; }
 | 
			
		||||
 | 
			
		||||
        public string BaseUrl { get; set; }
 | 
			
		||||
        public string RouteUrl { get; set; }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public class SiteSurveyUserImportDto
 | 
			
		||||
    {
 | 
			
		||||
        public string TrialSiteCode { get; set; } = string.Empty;
 | 
			
		||||
        public string FirstName { get; set; } = string.Empty;
 | 
			
		||||
        public string LastName { get; set; } = string.Empty;
 | 
			
		||||
        public string Email { get; set; } = string.Empty;
 | 
			
		||||
        public string Phone { get; set; } = string.Empty;
 | 
			
		||||
        public string OrganizationName { get; set; } = string.Empty;
 | 
			
		||||
 | 
			
		||||
        [ExcelColumnName("UserType")]
 | 
			
		||||
        public string UserTypeStr { get; set; }
 | 
			
		||||
 | 
			
		||||
        [JsonIgnore]
 | 
			
		||||
        public Guid SiteId { get; set; }
 | 
			
		||||
 | 
			
		||||
        [JsonIgnore]
 | 
			
		||||
        public UserTypeEnum UserTypeEnum { get; set; } = UserTypeEnum.Undefined;
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
        [JsonIgnore]
 | 
			
		||||
        public Guid UserTypeId { get; set; }
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
        [JsonIgnore]
 | 
			
		||||
        public bool IsGeneratedAccount { get; set; }
 | 
			
		||||
        [JsonIgnore]
 | 
			
		||||
        public bool IsJoinedTrial { get; set; }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -10,6 +10,6 @@ namespace IRaCIS.Core.Application.Contracts
 | 
			
		|||
    {
 | 
			
		||||
        Task<IResponseOutput> AddOrUpdateTrialSiteUserSurvey(TrialSiteUserSurveyAddOrEdit addOrEditTrialSiteUserSurvey);
 | 
			
		||||
        Task<IResponseOutput> DeleteTrialSiteUserSurvey(Guid trialSiteUserSurveyId);
 | 
			
		||||
        Task<List<TrialSiteUserSurveyView>> GetTrialSiteUserSurveyList(Guid trialSiteSurveyId);
 | 
			
		||||
        Task<List<TrialSiteUserSurveyView>> GetTrialSiteUserSurveyList(TrialSiteUserSurverQuery inquery);
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
| 
						 | 
				
			
			@ -17,10 +17,12 @@ namespace IRaCIS.Core.Application.Contracts
 | 
			
		|||
    public class TrialSiteEquipmentSurveyService : BaseService, ITrialSiteEquipmentSurveyService
 | 
			
		||||
    {
 | 
			
		||||
        private readonly IRepository<TrialSiteEquipmentSurvey> _trialSiteEquipmentSurveyRepository;
 | 
			
		||||
        private readonly IRepository<TrialSiteSurvey> _trialSiteSurveyRepository;
 | 
			
		||||
 | 
			
		||||
        public TrialSiteEquipmentSurveyService(IRepository<TrialSiteEquipmentSurvey> trialSiteEquipmentSurveyRepository)
 | 
			
		||||
        public TrialSiteEquipmentSurveyService(IRepository<TrialSiteEquipmentSurvey> trialSiteEquipmentSurveyRepository, IRepository<TrialSiteSurvey> trialSiteSurveyRepository)
 | 
			
		||||
        {
 | 
			
		||||
            _trialSiteEquipmentSurveyRepository = trialSiteEquipmentSurveyRepository;
 | 
			
		||||
            _trialSiteSurveyRepository = trialSiteSurveyRepository;
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -39,15 +41,10 @@ namespace IRaCIS.Core.Application.Contracts
 | 
			
		|||
        public async Task<IResponseOutput> AddOrUpdateTrialSiteEquipmentSurvey(TrialSiteEquipmentSurveyAddOrEdit addOrEditTrialSiteEquipmentSurvey)
 | 
			
		||||
        {
 | 
			
		||||
 | 
			
		||||
            if (addOrEditTrialSiteEquipmentSurvey.Id != null)
 | 
			
		||||
            if (await _trialSiteSurveyRepository.AnyAsync(t => t.Id == addOrEditTrialSiteEquipmentSurvey.TrialSiteSurveyId && (t.IsDeleted == true || t.State == TrialSiteSurveyEnum.PMCreatedAndLock), true))
 | 
			
		||||
            {
 | 
			
		||||
                if (await _trialSiteEquipmentSurveyRepository.Where(t => t.Id == addOrEditTrialSiteEquipmentSurvey.Id).AnyAsync(t => t.TrialSiteSurvey.State==TrialSiteSurveyEnum.PMCreatedAndLock))
 | 
			
		||||
                {
 | 
			
		||||
                //---已锁定,不允许操作
 | 
			
		||||
                    return ResponseOutput.NotOk(_localizer["TrialSiteEquipment_Locked"]);
 | 
			
		||||
                return ResponseOutput.NotOk(_localizer["TrialSiteEquipment_Invalid"]);
 | 
			
		||||
            }
 | 
			
		||||
            }
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
            var entity = await _trialSiteEquipmentSurveyRepository.InsertOrUpdateAsync(addOrEditTrialSiteEquipmentSurvey, true);
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -15,6 +15,11 @@ using MailKit.Security;
 | 
			
		|||
using MimeKit;
 | 
			
		||||
using IRaCIS.Core.Application.Helper;
 | 
			
		||||
using IRaCIS.Core.Application.Filter;
 | 
			
		||||
using IRaCIS.Core.Infrastructure.Extention;
 | 
			
		||||
using Microsoft.VisualBasic;
 | 
			
		||||
using DocumentFormat.OpenXml.Spreadsheet;
 | 
			
		||||
using IRaCIS.Core.Domain.Models;
 | 
			
		||||
using IRaCIS.Core.Application.ViewModel;
 | 
			
		||||
using Medallion.Threading;
 | 
			
		||||
 | 
			
		||||
namespace IRaCIS.Core.Application.Contracts
 | 
			
		||||
| 
						 | 
				
			
			@ -29,26 +34,25 @@ namespace IRaCIS.Core.Application.Contracts
 | 
			
		|||
        private readonly IRepository<TrialSiteUserSurvey> _trialSiteUserSurveyRepository;
 | 
			
		||||
        private readonly IRepository<User> _userRepository;
 | 
			
		||||
        private readonly IRepository<TrialSite> _trialSiteRepository;
 | 
			
		||||
        private readonly IRepository<Doctor> _doctorRepository;
 | 
			
		||||
        private readonly IRepository<TrialUser> _trialUserRepository;
 | 
			
		||||
        private readonly IRepository<TrialSiteUser> _trialSiteUserRepository;
 | 
			
		||||
        private readonly IDistributedLockProvider _distributedLockProvider;
 | 
			
		||||
        private readonly ITokenService _tokenService;
 | 
			
		||||
        private readonly IMailVerificationService _mailVerificationService;
 | 
			
		||||
        private readonly IDistributedLockProvider _distributedLockProvider;
 | 
			
		||||
 | 
			
		||||
        public TrialSiteSurveyService(IRepository<TrialSiteSurvey> trialSiteSurveyRepository, IRepository<TrialUser> trialUserRepository, IRepository<TrialSiteUserSurvey> trialSiteUserSurveyRepository,
 | 
			
		||||
            IRepository<User> userRepository, IRepository<TrialSite> trialSiteRepository,
 | 
			
		||||
             IRepository<Doctor> doctorRepository,
 | 
			
		||||
            ITokenService tokenService,
 | 
			
		||||
           IMailVerificationService mailVerificationService, IDistributedLockProvider distributedLockProvider)
 | 
			
		||||
           IMailVerificationService mailVerificationService, IRepository<TrialSiteUser> trialSiteUserRepository, IDistributedLockProvider distributedLockProvider)
 | 
			
		||||
        {
 | 
			
		||||
            _trialSiteSurveyRepository = trialSiteSurveyRepository;
 | 
			
		||||
            _trialSiteUserSurveyRepository = trialSiteUserSurveyRepository;
 | 
			
		||||
            _userRepository = userRepository;
 | 
			
		||||
            _trialUserRepository = trialUserRepository;
 | 
			
		||||
            _trialSiteRepository = trialSiteRepository;
 | 
			
		||||
            _doctorRepository = doctorRepository;
 | 
			
		||||
            _tokenService = tokenService;
 | 
			
		||||
            _mailVerificationService = mailVerificationService;
 | 
			
		||||
            _trialSiteUserRepository = trialSiteUserRepository;
 | 
			
		||||
            _distributedLockProvider = distributedLockProvider;
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -88,11 +92,6 @@ namespace IRaCIS.Core.Application.Contracts
 | 
			
		|||
            var verificationRecord = await _repository.GetQueryable<VerificationCode>().OrderByDescending(x => x.ExpirationTime).Where(t => (t.EmailOrPhone == inDto.EmailOrPhone) && t.Code == inDto.VerificationCode && t.CodeType == VerifyType.Email).FirstOrDefaultAsync();
 | 
			
		||||
            VerifyEmialGetDoctorInfoOutDto result = new VerifyEmialGetDoctorInfoOutDto();
 | 
			
		||||
 | 
			
		||||
            var doctorInfo = await _doctorRepository.Where(x => x.EMail == inDto.EmailOrPhone).FirstOrDefaultAsync();
 | 
			
		||||
 | 
			
		||||
            result.DoctorId = doctorInfo == null ? null : doctorInfo.Id;
 | 
			
		||||
            result.ReviewStatus = doctorInfo == null ? null : doctorInfo.ReviewStatus;
 | 
			
		||||
 | 
			
		||||
            //检查数据库是否存在该验证码
 | 
			
		||||
            if (verificationRecord == null)
 | 
			
		||||
            {
 | 
			
		||||
| 
						 | 
				
			
			@ -117,7 +116,7 @@ namespace IRaCIS.Core.Application.Contracts
 | 
			
		|||
        }
 | 
			
		||||
 | 
			
		||||
        /// <summary>
 | 
			
		||||
        /// 发送验证码
 | 
			
		||||
        ///site 调研 发送验证码
 | 
			
		||||
        /// </summary>
 | 
			
		||||
        /// <param name="userInfo"></param>
 | 
			
		||||
        /// <returns></returns>
 | 
			
		||||
| 
						 | 
				
			
			@ -160,106 +159,118 @@ namespace IRaCIS.Core.Application.Contracts
 | 
			
		|||
        public async Task<IResponseOutput> VerifySendCode(LoginDto userInfo, [FromServices] ITokenService _tokenService)
 | 
			
		||||
        {
 | 
			
		||||
 | 
			
		||||
            var isReplaceUser = !string.IsNullOrEmpty(userInfo.ReplaceUserEmailOrPhone);
 | 
			
		||||
 | 
			
		||||
            #region 20230804  修改调研表逻辑
 | 
			
		||||
 | 
			
		||||
            var verifyRecord = await _repository.FirstOrDefaultAsync<VerificationCode>(t => (t.EmailOrPhone == userInfo.EmailOrPhone) && t.Code == userInfo.verificationCode && t.CodeType == userInfo.verificationType);
 | 
			
		||||
            //检查数据库是否存在该验证码
 | 
			
		||||
            if (verifyRecord == null)
 | 
			
		||||
            {
 | 
			
		||||
                //---验证码错误。
 | 
			
		||||
                return ResponseOutput.NotOk(_localizer["TrialSiteSurvey_WrongVerificationCode"]);
 | 
			
		||||
            }
 | 
			
		||||
            else if (verifyRecord.ExpirationTime < DateTime.Now)
 | 
			
		||||
            {
 | 
			
		||||
                return ResponseOutput.NotOk(_localizer["TrialSiteSurvey_WrongVerificationCode"]);
 | 
			
		||||
            }
 | 
			
		||||
            else
 | 
			
		||||
            {
 | 
			
		||||
                //验证码正确 不处理
 | 
			
		||||
            }
 | 
			
		||||
 | 
			
		||||
            TrialSiteSurvey? currentEntity = null;
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
            if (userInfo.IsUpdate && isReplaceUser && !await _trialSiteSurveyRepository.AnyAsync(t => (t.Email == userInfo.ReplaceUserEmailOrPhone || t.Phone == userInfo.ReplaceUserEmailOrPhone) && t.SiteId == userInfo.SiteId && t.TrialId == userInfo.TrialId))
 | 
			
		||||
            var userList = await _trialSiteUserRepository.Where(t => t.TrialId == userInfo.TrialId && t.SiteId == userInfo.SiteId, false, true).ProjectTo<TrialSiteUserSurvey>(_mapper.ConfigurationProvider).ToListAsync();
 | 
			
		||||
 | 
			
		||||
            //普通登录
 | 
			
		||||
            if (userInfo.IsUpdate == false)
 | 
			
		||||
            {
 | 
			
		||||
 | 
			
		||||
                var dbEntityList = await _trialSiteSurveyRepository.Where(t => t.TrialId == userInfo.TrialId && t.SiteId == userInfo.SiteId).ToListAsync();
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
                //没有记录  new一份
 | 
			
		||||
                if (dbEntityList.Count == 0)
 | 
			
		||||
                {
 | 
			
		||||
                    var addSurvey = _mapper.Map<TrialSiteSurvey>(userInfo);
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
                    //从项目site 中找到已存在的 加到历史人员中
 | 
			
		||||
                    addSurvey.TrialSiteUserSurveyList = userList;
 | 
			
		||||
 | 
			
		||||
                    currentEntity = await _repository.AddAsync(addSurvey);
 | 
			
		||||
 | 
			
		||||
                }
 | 
			
		||||
                else
 | 
			
		||||
                {
 | 
			
		||||
 | 
			
		||||
                    //找到当前最新的调研表 
 | 
			
		||||
 | 
			
		||||
                    var currentLatest = dbEntityList.OrderByDescending(t => t.CreateTime).FirstOrDefault();
 | 
			
		||||
 | 
			
		||||
                    if (currentLatest!.Email != userInfo.EmailOrPhone)
 | 
			
		||||
                    {
 | 
			
		||||
                        //---该中心下已经有其他用户已填写的调研表,您不被允许继续填写
 | 
			
		||||
                        return ResponseOutput.NotOk(_localizer["TrialSiteSurvey_AlreadyFilledByOtherUsers"]);
 | 
			
		||||
                    }
 | 
			
		||||
 | 
			
		||||
                    currentEntity = currentLatest;
 | 
			
		||||
 | 
			
		||||
                    if (currentEntity.State != TrialSiteSurveyEnum.PMCreatedAndLock)
 | 
			
		||||
                    {
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
                        await UnlockSyncSiteUserAsync(userInfo.TrialId, userInfo.SiteId, currentEntity.Id, userList);
 | 
			
		||||
 | 
			
		||||
                    }
 | 
			
		||||
 | 
			
		||||
                }
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
            }
 | 
			
		||||
            //更新调研表
 | 
			
		||||
            else
 | 
			
		||||
            {
 | 
			
		||||
                //找到最新的调研表
 | 
			
		||||
 | 
			
		||||
                var currentLatest = await _trialSiteSurveyRepository.Where(t => t.TrialId == userInfo.TrialId && t.SiteId == userInfo.SiteId, true)
 | 
			
		||||
                     .Include(u => u.TrialSiteEquipmentSurveyList).Include(u => u.TrialSiteUserSurveyList).OrderByDescending(t => t.CreateTime).FirstOrDefaultAsync();
 | 
			
		||||
 | 
			
		||||
                if (currentLatest == null)
 | 
			
		||||
                {
 | 
			
		||||
                    return ResponseOutput.NotOk(_localizer["TrialSite_NoSurveyToUpdate"]);
 | 
			
		||||
                }
 | 
			
		||||
 | 
			
		||||
                if (currentLatest.Email != userInfo.ReplaceUserEmailOrPhone)
 | 
			
		||||
                {
 | 
			
		||||
                    //---该中心不存在该交接人的中心调研记录表,不允许选择更新。
 | 
			
		||||
                    return ResponseOutput.NotOk(_localizer["TrialSiteSurvey_NoRecordToUpdate"]);
 | 
			
		||||
                }
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
            if (userInfo.IsUpdate && await _trialSiteSurveyRepository.AnyAsync(t => (t.Email == userInfo.EmailOrPhone || t.Phone == userInfo.EmailOrPhone) && t.SiteId == userInfo.SiteId && t.TrialId == userInfo.TrialId && t.State != TrialSiteSurveyEnum.PMCreatedAndLock))
 | 
			
		||||
 | 
			
		||||
                //未锁定的状态  就改为废除
 | 
			
		||||
                if (currentLatest.State != TrialSiteSurveyEnum.PMCreatedAndLock)
 | 
			
		||||
                {
 | 
			
		||||
                //---您的中心调研记录正在审核中,不允许进行更新操作。若需要更新,请在驳回后进行操作。
 | 
			
		||||
                return ResponseOutput.NotOk(_localizer["TrialSiteSurvey_RecordUnderReview"]);
 | 
			
		||||
            }
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
            //自己的记录锁定了 只能更新自己的,不能更新别人的(但是别人能更新自己锁定的)
 | 
			
		||||
            if (userInfo.IsUpdate && userInfo.ReplaceUserEmailOrPhone != userInfo.EmailOrPhone && await _trialSiteSurveyRepository.AnyAsync(t => (t.Email == userInfo.EmailOrPhone || t.Phone == userInfo.EmailOrPhone) && t.SiteId == userInfo.SiteId && t.TrialId == userInfo.TrialId && t.State == TrialSiteSurveyEnum.PMCreatedAndLock))
 | 
			
		||||
            {
 | 
			
		||||
                //自己的锁了 想更新别人的
 | 
			
		||||
                //---当前中心中,您提交调研记录表已锁定,不允许更新其他人邮箱调研记录。
 | 
			
		||||
                return ResponseOutput.NotOk(_localizer["TrialSiteSurvey_LockedByCurrentUser"]);
 | 
			
		||||
            }
 | 
			
		||||
 | 
			
		||||
            //自己的锁定了  如果有其他未锁定的,也不能更新自己的
 | 
			
		||||
            if (userInfo.IsUpdate && userInfo.ReplaceUserEmailOrPhone == userInfo.EmailOrPhone &&
 | 
			
		||||
                await _trialSiteSurveyRepository.AnyAsync(t => (t.Email == userInfo.EmailOrPhone || t.Phone == userInfo.EmailOrPhone) && t.SiteId == userInfo.SiteId && t.TrialId == userInfo.TrialId && t.State == TrialSiteSurveyEnum.PMCreatedAndLock)
 | 
			
		||||
               && await _trialSiteSurveyRepository.AnyAsync(t => (t.Email != userInfo.EmailOrPhone && t.Phone != userInfo.EmailOrPhone) && t.SiteId == userInfo.SiteId && t.TrialId == userInfo.TrialId && t.State != TrialSiteSurveyEnum.PMCreatedAndLock))
 | 
			
		||||
            {
 | 
			
		||||
 | 
			
		||||
                //---当前中心,您提交的调研记录表已锁定。当前存在其他人员提交的调研记录表未锁定,不允许更新您之前提交的调研记录。
 | 
			
		||||
                return ResponseOutput.NotOk(_localizer["TrialSiteSurvey_LockedByOtherUsers"]);
 | 
			
		||||
            }
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
            ////存在未锁定的记录,却去更新已锁定的
 | 
			
		||||
            if (userInfo.IsUpdate && userInfo.ReplaceUserEmailOrPhone != userInfo.EmailOrPhone && await _trialSiteSurveyRepository.AnyAsync(t => t.SiteId == userInfo.SiteId && t.TrialId == userInfo.TrialId && t.State != TrialSiteSurveyEnum.PMCreatedAndLock)
 | 
			
		||||
            && await _trialSiteSurveyRepository.AnyAsync(t => (t.Email == userInfo.ReplaceUserEmailOrPhone || t.Phone == userInfo.ReplaceUserEmailOrPhone) && t.SiteId == userInfo.SiteId && t.TrialId == userInfo.TrialId && t.State == TrialSiteSurveyEnum.PMCreatedAndLock)
 | 
			
		||||
            && !await _trialSiteSurveyRepository.AnyAsync(t => (t.Email == userInfo.ReplaceUserEmailOrPhone || t.Phone == userInfo.ReplaceUserEmailOrPhone) && t.SiteId == userInfo.SiteId && t.TrialId == userInfo.TrialId && t.State != TrialSiteSurveyEnum.PMCreatedAndLock)
 | 
			
		||||
            )
 | 
			
		||||
            {
 | 
			
		||||
                //---当前中心存在未锁定的调研记录,不允许更新已锁定的调研记录。
 | 
			
		||||
                return ResponseOutput.NotOk(_localizer["TrialSiteSurvey_UnlockedRecordsExist"]);
 | 
			
		||||
            }
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
            var verificationRecord = await _repository
 | 
			
		||||
                  .FirstOrDefaultAsync<VerificationCode>(t => (t.EmailOrPhone == userInfo.EmailOrPhone) && t.Code == userInfo.verificationCode && t.CodeType == userInfo.verificationType);
 | 
			
		||||
 | 
			
		||||
            //检查数据库是否存在该验证码
 | 
			
		||||
            if (verificationRecord == null)
 | 
			
		||||
            {
 | 
			
		||||
                //---验证码错误。
 | 
			
		||||
                return ResponseOutput.NotOk(_localizer["TrialSiteSurvey_WrongVerificationCode"]);
 | 
			
		||||
                    currentLatest.IsDeleted = true;
 | 
			
		||||
                }
 | 
			
		||||
                //锁定的 需要改状态么?
 | 
			
		||||
                else
 | 
			
		||||
                {
 | 
			
		||||
                //检查验证码是否失效
 | 
			
		||||
                if (verificationRecord.ExpirationTime < DateTime.Now)
 | 
			
		||||
                {
 | 
			
		||||
                //---验证码已经过期。
 | 
			
		||||
                    return ResponseOutput.NotOk(_localizer["TrialSiteSurvey_ExpiredVerificationCode"]);
 | 
			
		||||
 | 
			
		||||
                }
 | 
			
		||||
                else //验证码正确 并且 没有超时 
 | 
			
		||||
                {
 | 
			
		||||
 | 
			
		||||
                    TrialSiteSurvey? dbEntity = null;
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
                    //替换交接人
 | 
			
		||||
                    if (isReplaceUser)
 | 
			
		||||
                    {
 | 
			
		||||
                        //该交接人的记录 是否有未锁定的  有就用未锁定的,没有就用  锁定的最后一条
 | 
			
		||||
 | 
			
		||||
                        var noLockedLastSurvey = await _trialSiteSurveyRepository.Where(t => (t.Email == userInfo.ReplaceUserEmailOrPhone || t.Phone == userInfo.ReplaceUserEmailOrPhone) && t.SiteId == userInfo.SiteId && t.TrialId == userInfo.TrialId && t.State == TrialSiteSurveyEnum.PMCreatedAndLock == false, true)
 | 
			
		||||
                            .Include(u => u.TrialSiteEquipmentSurveyList).Include(u => u.TrialSiteUserSurveyList).OrderByDescending(t => t.CreateTime).FirstOrDefaultAsync();
 | 
			
		||||
 | 
			
		||||
                        //都是锁定的
 | 
			
		||||
                        if (noLockedLastSurvey == null)
 | 
			
		||||
                        {
 | 
			
		||||
 | 
			
		||||
                            var latestLock = await _trialSiteSurveyRepository.Where(t => t.SiteId == userInfo.SiteId && t.TrialId == userInfo.TrialId).OrderByDescending(t => t.CreateTime).FirstOrDefaultAsync();
 | 
			
		||||
 | 
			
		||||
                            if (latestLock!.Email != userInfo.ReplaceUserEmailOrPhone)
 | 
			
		||||
                            {
 | 
			
		||||
                                return ResponseOutput.NotOk($"该邮箱{userInfo.ReplaceUserEmailOrPhone}对应的调查表不是最新锁定的记录,不允许更新!");
 | 
			
		||||
                            }
 | 
			
		||||
 | 
			
		||||
                            var lockedLastSurvey = await _trialSiteSurveyRepository.Where(t => (t.Email == userInfo.ReplaceUserEmailOrPhone || t.Phone == userInfo.ReplaceUserEmailOrPhone) && t.SiteId == userInfo.SiteId && t.TrialId == userInfo.TrialId && t.State == TrialSiteSurveyEnum.PMCreatedAndLock == true)
 | 
			
		||||
                           .Include(u => u.TrialSiteEquipmentSurveyList).Include(u => u.TrialSiteUserSurveyList).OrderByDescending(t => t.CreateTime).FirstOrDefaultAsync().IfNullThrowException();
 | 
			
		||||
 | 
			
		||||
                            //Copy 一份  更换邮箱
 | 
			
		||||
 | 
			
		||||
                            var copy = lockedLastSurvey.Clone();
 | 
			
		||||
                var copy = currentLatest.Clone();
 | 
			
		||||
 | 
			
		||||
                copy.State = TrialSiteSurveyEnum.ToSubmit;
 | 
			
		||||
                copy.IsDeleted = false;
 | 
			
		||||
 | 
			
		||||
                copy.Phone = string.Empty;
 | 
			
		||||
                copy.UserName = string.Empty;
 | 
			
		||||
                copy.Email = userInfo.EmailOrPhone;
 | 
			
		||||
                copy.Id = Guid.Empty;
 | 
			
		||||
                copy.CreateTime = DateAndTime.Now;
 | 
			
		||||
 | 
			
		||||
                if (userInfo.ReplaceUserEmailOrPhone != userInfo.EmailOrPhone)
 | 
			
		||||
                {
 | 
			
		||||
| 
						 | 
				
			
			@ -268,86 +279,23 @@ namespace IRaCIS.Core.Application.Contracts
 | 
			
		|||
                }
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
                            copy.Id = Guid.Empty;
 | 
			
		||||
                            copy.TrialSiteEquipmentSurveyList.ForEach(t => t.Id = Guid.Empty);
 | 
			
		||||
                            copy.TrialSiteUserSurveyList.ForEach(t => t.Id = Guid.Empty);
 | 
			
		||||
 | 
			
		||||
                            dbEntity = await _repository.AddAsync(copy);
 | 
			
		||||
                copy.TrialSiteEquipmentSurveyList = currentLatest.TrialSiteEquipmentSurveyList.Clone();
 | 
			
		||||
                copy.TrialSiteEquipmentSurveyList.ForEach(t => { t.Id = Guid.Empty; t.CreateTime = DateTime.Now; });
 | 
			
		||||
 | 
			
		||||
                        }
 | 
			
		||||
                        else
 | 
			
		||||
                //锁定了的话,就不拷贝
 | 
			
		||||
                if (currentLatest.State != TrialSiteSurveyEnum.PMCreatedAndLock)
 | 
			
		||||
                {
 | 
			
		||||
                            //有未锁定的 更新下邮箱
 | 
			
		||||
                            noLockedLastSurvey.Email = userInfo.EmailOrPhone;
 | 
			
		||||
                            noLockedLastSurvey.UserName = String.Empty;
 | 
			
		||||
                            noLockedLastSurvey.Phone = String.Empty;
 | 
			
		||||
 | 
			
		||||
                            dbEntity = noLockedLastSurvey;
 | 
			
		||||
                    copy.TrialSiteUserSurveyList = currentLatest.TrialSiteUserSurveyList.Clone().Where(t => t.IsHistoryUser == false).ToList();
 | 
			
		||||
                    copy.TrialSiteUserSurveyList.ForEach(t => { t.Id = Guid.Empty; t.IsGenerateSuccess = false; t.CreateTime = DateTime.Now; });
 | 
			
		||||
                }
 | 
			
		||||
 | 
			
		||||
                //从项目site 中找到已存在的 加到历史人员中
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
                        ////邮箱相同的话  就是同一个人进来   copy一份
 | 
			
		||||
                        //if (userInfo.EmailOrPhone == userInfo.ReplaceUserEmailOrPhone)
 | 
			
		||||
                        //{
 | 
			
		||||
                        //    dbEntity = await _repository.Where<TrialSiteSurvey>(t => (t.Email == userInfo.EmailOrPhone || t.Phone == userInfo.EmailOrPhone) && t.SiteId == userInfo.SiteId && t.TrialId == userInfo.TrialId).Include(u => u.TrialSiteEquipmentSurveyList).Include(u => u.TrialSiteUserSurveyList).FirstOrDefaultAsync().IfNullThrowConvertException();
 | 
			
		||||
 | 
			
		||||
                        //    var clone = dbEntity.Clone();
 | 
			
		||||
                        //    clone.Id = Guid.Empty;
 | 
			
		||||
                        //    clone.TrialSiteEquipmentSurveyList.ForEach(t => t.Id = Guid.Empty);
 | 
			
		||||
                        //    clone.TrialSiteUserSurveyList.ForEach(t => t.Id = Guid.Empty);
 | 
			
		||||
                        //    clone.State = TrialSiteSurveyEnum.ToSubmit;
 | 
			
		||||
 | 
			
		||||
                        //    dbEntity = await _repository.AddAsync(clone);
 | 
			
		||||
 | 
			
		||||
                        //}
 | 
			
		||||
 | 
			
		||||
                    }
 | 
			
		||||
                    else
 | 
			
		||||
                    {
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
                        var dbEntityList = await _trialSiteSurveyRepository.Where(t => t.TrialId == userInfo.TrialId && t.SiteId == userInfo.SiteId).ToListAsync();
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
                        //没有记录  new一份
 | 
			
		||||
                        if (dbEntityList.Count == 0)
 | 
			
		||||
                        {
 | 
			
		||||
 | 
			
		||||
                            dbEntity = await _repository.AddAsync(_mapper.Map<TrialSiteSurvey>(userInfo));
 | 
			
		||||
 | 
			
		||||
                        }
 | 
			
		||||
                        else
 | 
			
		||||
                        {
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
                            //该site 下不存在该邮箱的记录
 | 
			
		||||
                            if (!dbEntityList.Any(t => t.Email == userInfo.EmailOrPhone || t.Phone == userInfo.EmailOrPhone))
 | 
			
		||||
                            {
 | 
			
		||||
                //---该中心下已经有其他用户已填写的调研表,您不被允许继续填写
 | 
			
		||||
                                return ResponseOutput.NotOk(_localizer["TrialSiteSurvey_AlreadyFilledByOtherUsers"]);
 | 
			
		||||
                            }
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
                            //有没有该邮箱 未锁定的
 | 
			
		||||
                            var nolockEntity = dbEntityList.Where(t => t.Email == userInfo.EmailOrPhone || t.Phone == userInfo.EmailOrPhone).FirstOrDefault(t => t.State != TrialSiteSurveyEnum.PMCreatedAndLock);
 | 
			
		||||
 | 
			
		||||
                            //  未锁定的 为空
 | 
			
		||||
                            if (nolockEntity == null)
 | 
			
		||||
                            {
 | 
			
		||||
                                //查看最新锁定的
 | 
			
		||||
                                dbEntity = dbEntityList.Where(t => t.Email == userInfo.EmailOrPhone || t.Phone == userInfo.EmailOrPhone).OrderByDescending(t => t.CreateTime).FirstOrDefault(t => t.State == TrialSiteSurveyEnum.PMCreatedAndLock).IfNullThrowException();
 | 
			
		||||
 | 
			
		||||
                            }
 | 
			
		||||
                            else //有未锁定的  直接用未锁定的
 | 
			
		||||
                            {
 | 
			
		||||
                                dbEntity = nolockEntity;
 | 
			
		||||
                            }
 | 
			
		||||
 | 
			
		||||
                        }
 | 
			
		||||
                        //_mapper.Map(userInfo, dbEntity);
 | 
			
		||||
                copy.TrialSiteUserSurveyList.AddRange(userList);
 | 
			
		||||
 | 
			
		||||
                currentEntity = await _trialSiteSurveyRepository.AddAsync(copy);
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -357,11 +305,11 @@ namespace IRaCIS.Core.Application.Contracts
 | 
			
		|||
            //删除验证码历史记录
 | 
			
		||||
            await _repository.BatchDeleteAsync<VerificationCode>(t => t.EmailOrPhone == userInfo.EmailOrPhone && t.Code == userInfo.verificationCode && t.CodeType == userInfo.verificationType);
 | 
			
		||||
 | 
			
		||||
                    await _repository.SaveChangesAsync();
 | 
			
		||||
            await _trialSiteSurveyRepository.SaveChangesAsync();
 | 
			
		||||
 | 
			
		||||
            return ResponseOutput.Ok(new
 | 
			
		||||
            {
 | 
			
		||||
                        TrialSiteSurveyId = dbEntity!.Id,
 | 
			
		||||
                TrialSiteSurveyId = currentEntity!.Id,
 | 
			
		||||
                Token = _tokenService.GetToken(IRaCISClaims.Create(new UserBasicInfo()
 | 
			
		||||
                {
 | 
			
		||||
                    Id = Guid.NewGuid(),
 | 
			
		||||
| 
						 | 
				
			
			@ -376,9 +324,29 @@ namespace IRaCIS.Core.Application.Contracts
 | 
			
		|||
                }))
 | 
			
		||||
            });
 | 
			
		||||
 | 
			
		||||
            #endregion
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        private async Task UnlockSyncSiteUserAsync(Guid trialId, Guid siteId, Guid trialSiteSurveyId, List<TrialSiteUserSurvey> userList)
 | 
			
		||||
        {
 | 
			
		||||
            var existList = await _trialSiteUserSurveyRepository.Where(t => t.IsHistoryUser && t.TrialSiteSurvey.TrialId == trialId && t.TrialSiteSurvey.SiteId == siteId, true).ToListAsync();
 | 
			
		||||
 | 
			
		||||
            foreach (var item in userList)
 | 
			
		||||
            {
 | 
			
		||||
                var find = existList.FirstOrDefault(t => t.SystemUserId == item.SystemUserId);
 | 
			
		||||
                //不存在就加入
 | 
			
		||||
                if (find == null)
 | 
			
		||||
                {
 | 
			
		||||
                    item.TrialSiteSurveyId = trialSiteSurveyId;
 | 
			
		||||
                    await _trialSiteUserSurveyRepository.AddAsync(item);
 | 
			
		||||
                }
 | 
			
		||||
                else
 | 
			
		||||
                {
 | 
			
		||||
                    find.IsHistoryUserOriginDeleted = item.IsHistoryUserOriginDeleted;
 | 
			
		||||
                }
 | 
			
		||||
            }
 | 
			
		||||
 | 
			
		||||
            await _trialSiteUserSurveyRepository.SaveChangesAsync();
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -389,9 +357,24 @@ namespace IRaCIS.Core.Application.Contracts
 | 
			
		|||
        [HttpGet("{trialId:guid}/{trialSiteSurveyId:guid}")]
 | 
			
		||||
        public async Task<LoginReturnDTO> GetSiteSurveyInfo(Guid trialSiteSurveyId, Guid trialId)
 | 
			
		||||
        {
 | 
			
		||||
            var result = await _trialSiteSurveyRepository.Where(t => t.Id == trialSiteSurveyId && t.TrialId == trialId)
 | 
			
		||||
                .ProjectTo<LoginReturnDTO>(_mapper.ConfigurationProvider).FirstOrDefaultAsync().IfNullThrowException();
 | 
			
		||||
 | 
			
		||||
            //有可能填表人提交了,但是此时PM手动对人员信息进行了更改,此时需要将数据同步下(选择在这里同步是因为  不想改动 中心人员哪里的两个接口的逻辑)
 | 
			
		||||
            var find = await _trialSiteSurveyRepository.FirstOrDefaultAsync(t => t.Id == trialSiteSurveyId, true);
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
            if (find.State != TrialSiteSurveyEnum.PMCreatedAndLock && find.IsDeleted != true)
 | 
			
		||||
            {
 | 
			
		||||
                var userList = await _trialSiteUserRepository.Where(t => t.TrialId == find.TrialId && t.SiteId == find.SiteId, false, true).ProjectTo<TrialSiteUserSurvey>(_mapper.ConfigurationProvider).ToListAsync();
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
                await UnlockSyncSiteUserAsync(find.TrialId, find.SiteId, find.Id, userList);
 | 
			
		||||
            }
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
            var result = await _trialSiteSurveyRepository.Where(t => t.Id == trialSiteSurveyId && t.TrialId == trialId).IgnoreQueryFilters()
 | 
			
		||||
                .ProjectTo<LoginReturnDTO>(_mapper.ConfigurationProvider).FirstOrDefaultAsync().IfNullThrowException();
 | 
			
		||||
            return result;
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -469,11 +452,21 @@ namespace IRaCIS.Core.Application.Contracts
 | 
			
		|||
             .WhereIf(surveyQueryDTO.UpdateTimeBegin != null, t => t.UpdateTime >= surveyQueryDTO.UpdateTimeBegin)
 | 
			
		||||
             .WhereIf(surveyQueryDTO.UpdateTimeEnd != null, t => t.UpdateTime <= surveyQueryDTO.UpdateTimeEnd)
 | 
			
		||||
 | 
			
		||||
             .ProjectTo<TrialSiteSurveyView>(_mapper.ConfigurationProvider);
 | 
			
		||||
             .ProjectTo<TrialSiteSurveyView>(_mapper.ConfigurationProvider, new { isEn_Us = _userInfo.IsEn_Us });
 | 
			
		||||
 | 
			
		||||
            return await trialSiteSurveyQueryable.ToPagedListAsync(surveyQueryDTO.PageIndex, surveyQueryDTO.PageSize, surveyQueryDTO.SortField, surveyQueryDTO.Asc);
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        [HttpPost]
 | 
			
		||||
        public async Task<List<TrialSiteSurveySelectView>> GetTrialSiteSurveySelectList(TrialSiteSurveySelectquery inQuery)
 | 
			
		||||
        {
 | 
			
		||||
            var trialSiteSurveyQueryable = _trialSiteSurveyRepository
 | 
			
		||||
                .Where(t => t.Id != inQuery.TrialSiteSurveyId)
 | 
			
		||||
                .Where(t => t.TrialId == inQuery.TrialId && t.SiteId == inQuery.SiteId).IgnoreQueryFilters()
 | 
			
		||||
             .ProjectTo<TrialSiteSurveySelectView>(_mapper.ConfigurationProvider);
 | 
			
		||||
 | 
			
		||||
            return await trialSiteSurveyQueryable.ToListAsync();
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        /// <summary>
 | 
			
		||||
        /// 项目Site调研用户列表  所有site的调研用户 最新的调研表的记录的用户 new
 | 
			
		||||
| 
						 | 
				
			
			@ -495,27 +488,12 @@ namespace IRaCIS.Core.Application.Contracts
 | 
			
		|||
                .Where(t => groupSelectIdQuery.Contains(t.TrialSiteSurveyId))
 | 
			
		||||
                .WhereIf(queryParam.UserTypeId != null, t => t.UserTypeId == queryParam.UserTypeId)
 | 
			
		||||
                .WhereIf(queryParam.IsGenerateAccount != null, t => t.IsGenerateAccount == queryParam.IsGenerateAccount)
 | 
			
		||||
                .WhereIf(queryParam.TrialRoleNameId != null, t => t.TrialRoleNameId == queryParam.TrialRoleNameId)
 | 
			
		||||
                .WhereIf(queryParam.State != null && queryParam.State != TrialSiteUserStateEnum.OverTime, t => t.InviteState == queryParam.State)
 | 
			
		||||
                .WhereIf(queryParam.State != null && queryParam.State == TrialSiteUserStateEnum.OverTime, t => t.InviteState == TrialSiteUserStateEnum.HasSend && t.ExpireTime < DateTime.Now)
 | 
			
		||||
                .WhereIf(!string.IsNullOrEmpty(queryParam.UserName), t => (t.LastName + " / " + t.FirstName).Contains(queryParam.UserName))
 | 
			
		||||
                .WhereIf(!string.IsNullOrEmpty(queryParam.OrganizationName), t => t.OrganizationName.Contains(queryParam.OrganizationName))
 | 
			
		||||
 | 
			
		||||
                .ProjectTo<TrialSiteUserSurveyAllDTO>(_mapper.ConfigurationProvider);
 | 
			
		||||
 | 
			
		||||
            //var query = _trialSiteSurveyRepository.Where(t => t.TrialId == queryParam.TrialId && t.IsAbandon == false)
 | 
			
		||||
            //    .WhereIf(queryParam.SiteId != null, t => t.SiteId == queryParam.SiteId)
 | 
			
		||||
            //    .WhereIf(!string.IsNullOrEmpty(queryParam.FormWriterKeyInfo), t => (t.UserName).Contains(queryParam.FormWriterKeyInfo) || t.Email.Contains(queryParam.FormWriterKeyInfo) || t.Phone.Contains(queryParam.FormWriterKeyInfo))
 | 
			
		||||
            //    .GroupBy(t => t.SiteId)
 | 
			
		||||
            //    .Select(g => g.OrderByDescending(u => u.CreateTime).FirstOrDefault())
 | 
			
		||||
            //    .SelectMany(t => t.TrialSiteUserSurveyList)
 | 
			
		||||
            //.WhereIf(queryParam.UserTypeId != null, t => t.UserTypeId == queryParam.UserTypeId)
 | 
			
		||||
            //.WhereIf(queryParam.IsGenerateAccount != null, t => t.IsGenerateAccount == queryParam.IsGenerateAccount)
 | 
			
		||||
            //.WhereIf(queryParam.TrialRoleNameId != null, t => t.TrialRoleNameId == queryParam.TrialRoleNameId)
 | 
			
		||||
            //.WhereIf(queryParam.State != null && queryParam.State != TrialSiteUserStateEnum.OverTime, t => t.InviteState == queryParam.State)
 | 
			
		||||
            //.WhereIf(queryParam.State != null && queryParam.State == TrialSiteUserStateEnum.OverTime, t => t.InviteState == TrialSiteUserStateEnum.HasSend && t.ExpireTime < DateTime.Now)
 | 
			
		||||
            //.WhereIf(!string.IsNullOrEmpty(queryParam.UserKeyInfo), t => (t.LastName + " / " + t.FirstName).Contains(queryParam.UserKeyInfo) || t.Email.Contains(queryParam.UserKeyInfo) || t.Phone.Contains(queryParam.UserKeyInfo))
 | 
			
		||||
            //.ProjectTo<TrialSiteUserSurveyAllDTO>(_mapper.ConfigurationProvider);
 | 
			
		||||
 | 
			
		||||
            return await query.ToPagedListAsync(queryParam.PageIndex, queryParam.PageSize, queryParam.SortField, queryParam.Asc);
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -561,13 +539,11 @@ namespace IRaCIS.Core.Application.Contracts
 | 
			
		|||
            var messageToSend = new MimeMessage();
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
            if (await _repository.AnyAsync<TrialSiteSurvey>(t => t.State == TrialSiteSurveyEnum.PMCreatedAndLock && t.Id == trialSiteSurveyId))
 | 
			
		||||
            {
 | 
			
		||||
                //---中心调研已锁定,不允许操作。
 | 
			
		||||
                return ResponseOutput.NotOk(_localizer["TrialSiteSurvey_Locked"]);
 | 
			
		||||
            }
 | 
			
		||||
 | 
			
		||||
            if (_userInfo.UserTypeEnumInt == (int)UserTypeEnum.SPM || _userInfo.UserTypeEnumInt == (int)UserTypeEnum.CPM)
 | 
			
		||||
            {
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -595,6 +571,7 @@ namespace IRaCIS.Core.Application.Contracts
 | 
			
		|||
                }
 | 
			
		||||
                else
 | 
			
		||||
                {
 | 
			
		||||
 | 
			
		||||
                    //没有SPM  给填表人发
 | 
			
		||||
                    messageToSend.To.Add(new MailboxAddress(String.Empty, survey.Email));
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -651,52 +628,13 @@ namespace IRaCIS.Core.Application.Contracts
 | 
			
		|||
            await _IMailVerificationService.SiteSurveyRejectEmail(messageToSend);
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
            await _trialSiteSurveyRepository.SaveChangesAsync();
 | 
			
		||||
 | 
			
		||||
            return ResponseOutput.Ok();
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
        /// <summary>
 | 
			
		||||
        /// 驳回
 | 
			
		||||
        /// </summary>
 | 
			
		||||
        /// <param name="trialId"></param>
 | 
			
		||||
        /// <param name="trialSiteSurveyId"></param>
 | 
			
		||||
        /// <returns></returns>
 | 
			
		||||
        [HttpPut("{trialId:guid}/{trialSiteSurveyId:guid}")]
 | 
			
		||||
        [Obsolete]
 | 
			
		||||
        public async Task<IResponseOutput> SubmissionRejection(Guid trialId, Guid trialSiteSurveyId)
 | 
			
		||||
        {
 | 
			
		||||
            if (await _repository.AnyAsync<TrialSiteSurvey>(t => t.State == TrialSiteSurveyEnum.PMCreatedAndLock && t.Id == trialSiteSurveyId))
 | 
			
		||||
            {
 | 
			
		||||
                //---中心调研已锁定,不允许操作。
 | 
			
		||||
                return ResponseOutput.NotOk(_localizer["TrialSiteSurvey_Locked"]);
 | 
			
		||||
            }
 | 
			
		||||
 | 
			
		||||
            if (_userInfo.UserTypeEnumInt == (int)UserTypeEnum.SPM || _userInfo.UserTypeEnumInt == (int)UserTypeEnum.CPM)
 | 
			
		||||
            {
 | 
			
		||||
                await _repository.BatchUpdateAsync<TrialSiteSurvey>(t => t.Id == trialSiteSurveyId, u => new TrialSiteSurvey() { State = TrialSiteSurveyEnum.ToSubmit });
 | 
			
		||||
            }
 | 
			
		||||
            else if (_userInfo.UserTypeEnumInt == (int)UserTypeEnum.ProjectManager || _userInfo.UserTypeEnumInt == (int)UserTypeEnum.APM)
 | 
			
		||||
            {
 | 
			
		||||
                var hasSPMOrCPM = await _trialSiteSurveyRepository.AnyAsync(t => t.TrialId == trialId && t.Trial.TrialUserList.Any(u => u.User.UserTypeEnum == UserTypeEnum.SPM || u.User.UserTypeEnum == UserTypeEnum.CPM));
 | 
			
		||||
 | 
			
		||||
                if (hasSPMOrCPM)
 | 
			
		||||
                {
 | 
			
		||||
                    await _trialSiteSurveyRepository.BatchUpdateNoTrackingAsync(t => t.Id == trialSiteSurveyId, u => new TrialSiteSurvey() { State = TrialSiteSurveyEnum.CRCSubmitted });
 | 
			
		||||
 | 
			
		||||
                }
 | 
			
		||||
                else
 | 
			
		||||
                {
 | 
			
		||||
                    await _trialSiteSurveyRepository.BatchUpdateNoTrackingAsync(t => t.Id == trialSiteSurveyId, u => new TrialSiteSurvey() { State = TrialSiteSurveyEnum.ToSubmit });
 | 
			
		||||
                }
 | 
			
		||||
            }
 | 
			
		||||
            return ResponseOutput.Ok();
 | 
			
		||||
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
        [HttpPut("{trialId:guid}/{trialSiteSurveyId:guid}")]
 | 
			
		||||
| 
						 | 
				
			
			@ -736,13 +674,48 @@ namespace IRaCIS.Core.Application.Contracts
 | 
			
		|||
            var trialId = siteSurvyeSubmit.TrialId;
 | 
			
		||||
            var trialSiteSurveyId = siteSurvyeSubmit.TrialSiteSurveyId;
 | 
			
		||||
 | 
			
		||||
            if (_userInfo.IsAdmin)
 | 
			
		||||
            var trialSiteSurvey = (await _trialSiteSurveyRepository.Where(t => t.Id == trialSiteSurveyId, false, true).FirstOrDefaultAsync()).IfNullThrowException();
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
            if (trialSiteSurvey.IsDeleted == true || trialSiteSurvey.State == TrialSiteSurveyEnum.PMCreatedAndLock)
 | 
			
		||||
            {
 | 
			
		||||
                //---不允许管理员操作。
 | 
			
		||||
                return ResponseOutput.NotOk(_localizer["TrialSiteSurvey_NoAdminAcces"]);
 | 
			
		||||
                throw new BusinessValidationFailedException(_localizer["TrialSiteSurvey_Invalid"]);
 | 
			
		||||
            }
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
            var siteUserList = await _trialSiteUserSurveyRepository.Where(t => t.TrialSiteSurveyId == trialSiteSurveyId)
 | 
			
		||||
                .Where(t => !(t.IsHistoryUser && t.IsHistoryUserDeleted == true))
 | 
			
		||||
                .Select(t =>
 | 
			
		||||
            new
 | 
			
		||||
            {
 | 
			
		||||
                t.TrialSiteSurveyId,
 | 
			
		||||
                t.IsGenerateAccount,
 | 
			
		||||
                t.IsGenerateSuccess,
 | 
			
		||||
                t.UserTypeId,
 | 
			
		||||
                UserTypeEnum = (UserTypeEnum?)t.UserTypeRole.UserTypeEnum,
 | 
			
		||||
                t.TrialRoleCode,
 | 
			
		||||
                t.Email,
 | 
			
		||||
            }).ToListAsync();
 | 
			
		||||
 | 
			
		||||
            var currentUserList = siteUserList.Where(t => t.TrialSiteSurveyId == trialSiteSurveyId).ToList();
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
            if (!currentUserList.Any(t => t.UserTypeEnum == UserTypeEnum.ClinicalResearchCoordinator) ||
 | 
			
		||||
                !currentUserList.Any(t => t.UserTypeEnum == UserTypeEnum.SR))
 | 
			
		||||
            {
 | 
			
		||||
                throw new BusinessValidationFailedException(_localizer["TrialSiteSurvey_MissingAccount"]);
 | 
			
		||||
            }
 | 
			
		||||
 | 
			
		||||
            if (currentUserList.GroupBy(t => new { t.UserTypeId, t.Email })
 | 
			
		||||
                .Any(g => g.Count() > 1))
 | 
			
		||||
            {
 | 
			
		||||
                throw new BusinessValidationFailedException(_localizer["TrialSiteSurvey_DuplicateEmail"]);
 | 
			
		||||
            }
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
            if (_userInfo.UserTypeEnumInt == (int)UserTypeEnum.Undefined)
 | 
			
		||||
            {
 | 
			
		||||
                var hasSPMOrCPM = await _trialSiteSurveyRepository.AnyAsync(t => t.TrialId == trialId && t.Trial.TrialUserList.Any(u => u.User.UserTypeEnum == UserTypeEnum.SPM || u.User.UserTypeEnum == UserTypeEnum.CPM));
 | 
			
		||||
| 
						 | 
				
			
			@ -765,23 +738,28 @@ namespace IRaCIS.Core.Application.Contracts
 | 
			
		|||
                await _trialSiteSurveyRepository.UpdatePartialFromQueryAsync(t => t.Id == trialSiteSurveyId && t.State == TrialSiteSurveyEnum.CRCSubmitted, u => new TrialSiteSurvey() { State = TrialSiteSurveyEnum.SPMApproved, PreliminaryUserId = _userInfo.Id, PreliminaryTime = DateTime.Now });
 | 
			
		||||
 | 
			
		||||
            }
 | 
			
		||||
            else if (_userInfo.UserTypeEnumInt == (int)UserTypeEnum.APM || _userInfo.UserTypeEnumInt == (int)UserTypeEnum.ProjectManager)
 | 
			
		||||
            else if (_userInfo.UserTypeEnumInt == (int)UserTypeEnum.ProjectManager|| _userInfo.UserTypeEnumInt == (int)UserTypeEnum.APM)
 | 
			
		||||
            {
 | 
			
		||||
 | 
			
		||||
                var trialSiteSurvey = (await _trialSiteSurveyRepository.Where(t => t.Id == trialSiteSurveyId).FirstOrDefaultAsync()).IfNullThrowException();
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
                var allUserList = _trialSiteUserSurveyRepository.Where(t => t.TrialSiteSurveyId == trialSiteSurveyId).ProjectTo<TrialSiteUserSurveyView>(_mapper.ConfigurationProvider).ToList();
 | 
			
		||||
 | 
			
		||||
                //已生成的不管  管的只需要是  生成失败的并且需要生成账号的
 | 
			
		||||
                var needGenerateList = _trialSiteUserSurveyRepository.Where(t => t.TrialSiteSurveyId == trialSiteSurveyId && t.IsGenerateAccount && t.IsJoin != true).ProjectTo<TrialSiteUserSurveyView>(_mapper.ConfigurationProvider).ToList();
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
                //await SendInviteEmail(new InviteEmailCommand() { TrialId = trialId, RouteUrl = siteSurvyeSubmit.RouteUrl, UserList = needGenerateList });
 | 
			
		||||
 | 
			
		||||
                var needGenerateList = allUserList.Where(t => t.IsHistoryUser == false && t.IsGenerateAccount && t.IsJoin != true).ToList();
 | 
			
		||||
 | 
			
		||||
                await GenerateAccountAsync(needGenerateList, trialId);
 | 
			
		||||
                await SendSiteSurveyUserJoinEmail(new TrialSiteUserSurveyJoinCommand() { TrialId = trialId, TrialSiteSurveyId = trialSiteSurveyId, RouteUrl = siteSurvyeSubmit.RouteUrl, BaseUrl = siteSurvyeSubmit.BaseUrl, UserList = needGenerateList });
 | 
			
		||||
 | 
			
		||||
                //新加入的 或者历史人员退出改为加入的
 | 
			
		||||
                var needSendEmailList = allUserList.Where(t => (t.IsHistoryUser == false && t.IsGenerateAccount && t.IsJoin != true) || (t.IsHistoryUser == true && t.IsHistoryUserOriginDeleted == true && t.IsHistoryUserDeleted == false)).ToList();
 | 
			
		||||
 | 
			
		||||
                await SendSiteSurveyUserJoinEmail(new TrialSiteUserSurveyJoinCommand() { TrialId = trialId, TrialSiteSurveyId = trialSiteSurveyId, RouteUrl = siteSurvyeSubmit.RouteUrl, BaseUrl = siteSurvyeSubmit.BaseUrl, UserList = needSendEmailList });
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
                var needQuitUserList = allUserList.Where(t => t.IsHistoryUser && t.IsHistoryUserOriginDeleted == false && t.IsHistoryUserDeleted == true).ToList();
 | 
			
		||||
 | 
			
		||||
                await DealSiteUserQuitSiteAsync(trialId, trialSiteSurvey.SiteId, needQuitUserList);
 | 
			
		||||
 | 
			
		||||
                //将历史锁定的调研表废弃
 | 
			
		||||
                await _trialSiteSurveyRepository.BatchUpdateNoTrackingAsync(t => t.TrialId == trialId && t.SiteId == trialSiteSurvey.SiteId && t.State == TrialSiteSurveyEnum.PMCreatedAndLock && t.Id != trialSiteSurveyId, z => new TrialSiteSurvey() { IsDeleted = true });
 | 
			
		||||
 | 
			
		||||
            }
 | 
			
		||||
            await _trialSiteSurveyRepository.SaveChangesAsync();
 | 
			
		||||
| 
						 | 
				
			
			@ -792,13 +770,14 @@ namespace IRaCIS.Core.Application.Contracts
 | 
			
		|||
 | 
			
		||||
        private async Task GenerateAccountAsync(List<TrialSiteUserSurveyView> needGenerateList, Guid trialId)
 | 
			
		||||
        {
 | 
			
		||||
            var trialType = _repository.Where<Trial>(t => t.Id == trialId).Select(t => t.TrialType).FirstOrDefault();
 | 
			
		||||
 | 
			
		||||
            foreach (var item in needGenerateList)
 | 
			
		||||
            {
 | 
			
		||||
 | 
			
		||||
                //找下系统中是否存在该用户类型的 并且邮箱 或者手机的账户
 | 
			
		||||
                var sysUserInfo = await _userRepository.Where(t => t.UserTypeId == item.UserTypeId && t.EMail == item.Email).Include(t => t.UserTypeRole).FirstOrDefaultAsync();
 | 
			
		||||
 | 
			
		||||
                var trialType = _repository.Where<Trial>(t => t.Id == trialId).Select(t => t.TrialType).FirstOrDefault();
 | 
			
		||||
 | 
			
		||||
                if (sysUserInfo == null)
 | 
			
		||||
                {
 | 
			
		||||
| 
						 | 
				
			
			@ -825,7 +804,6 @@ namespace IRaCIS.Core.Application.Contracts
 | 
			
		|||
 | 
			
		||||
                        saveItem.UserTypeEnum = _repository.Where<UserType>(t => t.Id == saveItem.UserTypeId).Select(t => t.UserTypeEnum).First();
 | 
			
		||||
 | 
			
		||||
                        //saveItem.Password = MD5Helper.Md5(verificationCode.ToString());
 | 
			
		||||
 | 
			
		||||
                        var newUser = _userRepository.AddAsync(saveItem).Result;
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -834,29 +812,24 @@ namespace IRaCIS.Core.Application.Contracts
 | 
			
		|||
 | 
			
		||||
 | 
			
		||||
                        sysUserInfo = newUser;
 | 
			
		||||
 | 
			
		||||
                    }
 | 
			
		||||
 | 
			
		||||
                    await _trialSiteUserSurveyRepository.BatchUpdateNoTrackingAsync(t => t.Id == item.Id, u => new TrialSiteUserSurvey() { IsGenerateSuccess = true, SystemUserId = sysUserInfo.Id });
 | 
			
		||||
 | 
			
		||||
                }
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
                //发送邮件的时候需要用到该字段
 | 
			
		||||
                item.SystemUserId = sysUserInfo.Id;
 | 
			
		||||
 | 
			
		||||
                await _trialSiteUserSurveyRepository.BatchUpdateNoTrackingAsync(t => t.Id == item.Id, u => new TrialSiteUserSurvey() { IsGenerateSuccess = true, SystemUserId = sysUserInfo.Id });
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
            }
 | 
			
		||||
 | 
			
		||||
            await _trialSiteUserSurveyRepository.SaveChangesAsync();
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
        [TypeFilter(typeof(TrialResourceFilter), Arguments = new object[] { "AfterStopCannNotOpt" })]
 | 
			
		||||
        public async Task<IResponseOutput> SendSiteSurveyUserJoinEmail(TrialSiteUserSurveyJoinCommand joinCommand)
 | 
			
		||||
        private async Task<IResponseOutput> SendSiteSurveyUserJoinEmail(TrialSiteUserSurveyJoinCommand joinCommand)
 | 
			
		||||
        {
 | 
			
		||||
            var trialSiteSurvey = await _trialSiteSurveyRepository.FirstAsync(t => t.Id == joinCommand.TrialSiteSurveyId);
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -877,24 +850,48 @@ namespace IRaCIS.Core.Application.Contracts
 | 
			
		|||
 | 
			
		||||
 | 
			
		||||
                //判断TrialUser中是否存在  不存在就插入
 | 
			
		||||
                if (!await _trialUserRepository.AnyAsync(t => t.TrialId == trialId && t.UserId == userId, true))
 | 
			
		||||
 | 
			
		||||
                var findTrialUser = await _trialUserRepository.FirstOrDefaultAsync(t => t.TrialId == trialId && t.UserId == userId, true);
 | 
			
		||||
                if (findTrialUser == null)
 | 
			
		||||
                {
 | 
			
		||||
                    await _repository.AddAsync(new TrialUser() { TrialId = trialId, UserId = userId, JoinTime = DateTime.Now });
 | 
			
		||||
                }
 | 
			
		||||
                if (!await _repository.AnyAsync<TrialSiteUser>(t => t.TrialId == trialId && t.UserId == userId && t.SiteId==siteId, true))
 | 
			
		||||
                {
 | 
			
		||||
                    await _repository.AddAsync(new TrialSiteUser() { TrialId = trialId, SiteId = siteId, UserId = userId });
 | 
			
		||||
                }
 | 
			
		||||
 | 
			
		||||
                await _userRepository.BatchUpdateNoTrackingAsync(t => t.Id == userId, u => new User() { Status = UserStateEnum.Enable });
 | 
			
		||||
 | 
			
		||||
                await _trialSiteUserSurveyRepository.UpdatePartialFromQueryAsync(t => t.Id == userInfo.Id, u => new TrialSiteUserSurvey() { IsJoin = true });
 | 
			
		||||
 | 
			
		||||
                    await _mailVerificationService.SiteSurveyUserJoinEmail(trialId, userId, joinCommand.BaseUrl, joinCommand.RouteUrl);
 | 
			
		||||
 | 
			
		||||
                }
 | 
			
		||||
                else if (findTrialUser.IsDeleted == true)
 | 
			
		||||
                {
 | 
			
		||||
                    await _trialUserRepository.UpdatePartialFromQueryAsync(t => t.TrialId == trialId && t.UserId == userId, c => new TrialUser()
 | 
			
		||||
                    {
 | 
			
		||||
                        IsDeleted = false,
 | 
			
		||||
                        DeletedTime = null,
 | 
			
		||||
                        JoinTime = DateTime.Now,
 | 
			
		||||
                    });
 | 
			
		||||
 | 
			
		||||
                    await _mailVerificationService.SiteSurveyUserJoinEmail(trialId, userId, joinCommand.BaseUrl, joinCommand.RouteUrl);
 | 
			
		||||
                }
 | 
			
		||||
 | 
			
		||||
                var findTrialSiteUser = await _trialSiteUserRepository.FirstOrDefaultAsync(t => t.TrialId == trialId && t.UserId == userId && t.SiteId == siteId, true);
 | 
			
		||||
 | 
			
		||||
                if (findTrialSiteUser == null)
 | 
			
		||||
                {
 | 
			
		||||
                    await _repository.AddAsync(new TrialSiteUser() { TrialId = trialId, SiteId = siteId, UserId = userId });
 | 
			
		||||
 | 
			
		||||
                }
 | 
			
		||||
                else
 | 
			
		||||
                {
 | 
			
		||||
                    findTrialSiteUser.IsDeleted = false;
 | 
			
		||||
                    findTrialSiteUser.DeletedTime = null;
 | 
			
		||||
                }
 | 
			
		||||
 | 
			
		||||
                await _userRepository.BatchUpdateNoTrackingAsync(t => t.Id == userId, u => new User() { Status = UserStateEnum.Enable });
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
                await _trialSiteUserSurveyRepository.UpdatePartialFromQueryAsync(t => t.Id == userInfo.Id, u => new TrialSiteUserSurvey() { IsJoin = true });
 | 
			
		||||
            }
 | 
			
		||||
 | 
			
		||||
            await _trialSiteSurveyRepository.UpdatePartialFromQueryAsync(t => t.Id == trialSiteSurvey.Id && t.State == TrialSiteSurveyEnum.SPMApproved, u => new TrialSiteSurvey() { State = TrialSiteSurveyEnum.PMCreatedAndLock, ReviewerUserId = _userInfo.Id, ReviewerTime = DateTime.Now });
 | 
			
		||||
 | 
			
		||||
            await _userRepository.SaveChangesAsync();
 | 
			
		||||
 | 
			
		||||
            return ResponseOutput.Ok();
 | 
			
		||||
| 
						 | 
				
			
			@ -903,11 +900,118 @@ namespace IRaCIS.Core.Application.Contracts
 | 
			
		|||
        }
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
        private async Task DealSiteUserQuitSiteAsync(Guid trialId, Guid siteId, List<TrialSiteUserSurveyView> list)
 | 
			
		||||
        {
 | 
			
		||||
 | 
			
		||||
            var userIdList = list.Select(t => t.SystemUserId).ToList();
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
            await _trialSiteUserRepository.UpdatePartialFromQueryAsync(t => t.TrialId == trialId && t.SiteId == siteId && userIdList.Contains(t.UserId), c => new TrialSiteUser()
 | 
			
		||||
            {
 | 
			
		||||
                IsDeleted = true,
 | 
			
		||||
                DeletedTime = DateTime.Now,
 | 
			
		||||
            });
 | 
			
		||||
 | 
			
		||||
           
 | 
			
		||||
            await _repository.SaveChangesAsync();
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
        public async Task ImportGenerateAccountAndJoinTrialAsync(Guid trialId, string baseUrl, string routeUrl, List<SiteSurveyUserImportDto> list)
 | 
			
		||||
        {
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
            var trialType = _repository.Where<Trial>(t => t.Id == trialId).Select(t => t.TrialType).FirstOrDefault();
 | 
			
		||||
 | 
			
		||||
            //判断是否有系统账号
 | 
			
		||||
            foreach (var item in list)
 | 
			
		||||
            {
 | 
			
		||||
                //找下系统中是否存在该用户类型的 并且邮箱 或者手机的账户
 | 
			
		||||
                var sysUserInfo = await _userRepository.Where(t => t.UserTypeId == item.UserTypeId && t.EMail == item.Email).Include(t => t.UserTypeRole).FirstOrDefaultAsync();
 | 
			
		||||
 | 
			
		||||
                if (sysUserInfo == null)
 | 
			
		||||
                {
 | 
			
		||||
 | 
			
		||||
                    var @lock = _distributedLockProvider.CreateLock($"UserCode");
 | 
			
		||||
 | 
			
		||||
                    using (await @lock.AcquireAsync())
 | 
			
		||||
                    {
 | 
			
		||||
                        var saveItem = _mapper.Map<User>(item);
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
                        if (trialType == TrialType.NoneOfficial)
 | 
			
		||||
                        {
 | 
			
		||||
                            saveItem.IsTestUser = true;
 | 
			
		||||
                        }
 | 
			
		||||
 | 
			
		||||
                        // 中心调研生成账号 都是外部的
 | 
			
		||||
                        saveItem.IsZhiZhun = false;
 | 
			
		||||
                        saveItem.Code = _userRepository.Select(t => t.Code).DefaultIfEmpty().Max() + 1;
 | 
			
		||||
 | 
			
		||||
                        saveItem.UserCode = AppSettings.GetCodeStr(saveItem.Code, nameof(User));
 | 
			
		||||
 | 
			
		||||
                        saveItem.UserName = saveItem.UserCode;
 | 
			
		||||
 | 
			
		||||
                        var newUser = _userRepository.AddAsync(saveItem).Result;
 | 
			
		||||
 | 
			
		||||
                        _ = _userRepository.SaveChangesAsync().Result;
 | 
			
		||||
 | 
			
		||||
                        sysUserInfo = newUser;
 | 
			
		||||
 | 
			
		||||
                    }
 | 
			
		||||
 | 
			
		||||
                    item.IsGeneratedAccount = true;
 | 
			
		||||
 | 
			
		||||
                }
 | 
			
		||||
 | 
			
		||||
                var userId = sysUserInfo.Id;
 | 
			
		||||
                var siteId = item.SiteId;
 | 
			
		||||
 | 
			
		||||
                //判断是否加入到项目
 | 
			
		||||
                var findTrialUser = await _trialUserRepository.FirstOrDefaultAsync(t => t.TrialId == trialId && t.UserId == userId, true);
 | 
			
		||||
                if (findTrialUser == null)
 | 
			
		||||
                {
 | 
			
		||||
                    await _repository.AddAsync(new TrialUser() { TrialId = trialId, UserId = userId, JoinTime = DateTime.Now });
 | 
			
		||||
 | 
			
		||||
                    await _mailVerificationService.SiteSurveyUserJoinEmail(trialId, userId, baseUrl, routeUrl);
 | 
			
		||||
 | 
			
		||||
                }
 | 
			
		||||
                else if (findTrialUser.IsDeleted == true)
 | 
			
		||||
                {
 | 
			
		||||
                    await _trialUserRepository.UpdatePartialFromQueryAsync(t => t.TrialId == trialId && t.UserId == userId, c => new TrialUser()
 | 
			
		||||
                    {
 | 
			
		||||
                        IsDeleted = false,
 | 
			
		||||
                        DeletedTime = null,
 | 
			
		||||
                        JoinTime = DateTime.Now,
 | 
			
		||||
                    });
 | 
			
		||||
 | 
			
		||||
                    await _mailVerificationService.SiteSurveyUserJoinEmail(trialId, userId, baseUrl, routeUrl);
 | 
			
		||||
                }
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
                var findTrialSiteUser = await _trialSiteUserRepository.FirstOrDefaultAsync(t => t.TrialId == trialId && t.UserId == userId && t.SiteId == siteId, true);
 | 
			
		||||
 | 
			
		||||
                if (findTrialSiteUser == null)
 | 
			
		||||
                {
 | 
			
		||||
                    await _repository.AddAsync(new TrialSiteUser() { TrialId = trialId, SiteId = siteId, UserId = userId });
 | 
			
		||||
 | 
			
		||||
                }
 | 
			
		||||
                else
 | 
			
		||||
                {
 | 
			
		||||
                    findTrialSiteUser.IsDeleted = false;
 | 
			
		||||
                    findTrialSiteUser.DeletedTime = null;
 | 
			
		||||
                }
 | 
			
		||||
 | 
			
		||||
                await _userRepository.BatchUpdateNoTrackingAsync(t => t.Id == userId, u => new User() { Status = UserStateEnum.Enable });
 | 
			
		||||
 | 
			
		||||
                await _trialSiteUserRepository.SaveChangesAsync();
 | 
			
		||||
 | 
			
		||||
            }
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
    }
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -7,6 +7,7 @@ using Microsoft.AspNetCore.Mvc;
 | 
			
		|||
using IRaCIS.Core.Domain.Share;
 | 
			
		||||
using IRaCIS.Core.Application.Filter;
 | 
			
		||||
using IRaCIS.Core.Infrastructure;
 | 
			
		||||
using IRaCIS.Application.Contracts;
 | 
			
		||||
 | 
			
		||||
namespace IRaCIS.Core.Application.Contracts
 | 
			
		||||
{
 | 
			
		||||
| 
						 | 
				
			
			@ -17,57 +18,43 @@ namespace IRaCIS.Core.Application.Contracts
 | 
			
		|||
    public class TrialSiteUserSurveyService : BaseService, ITrialSiteUserSurveyService
 | 
			
		||||
    {
 | 
			
		||||
        private readonly IRepository<TrialSiteUserSurvey> _trialSiteUserSurveyRepository;
 | 
			
		||||
        private readonly IRepository<TrialSiteSurvey> _trialSiteSurveyRepository;
 | 
			
		||||
 | 
			
		||||
        public TrialSiteUserSurveyService(IRepository<TrialSiteUserSurvey> trialSiteUserSurveyRepository)
 | 
			
		||||
        public TrialSiteUserSurveyService(IRepository<TrialSiteUserSurvey> trialSiteUserSurveyRepository, IRepository<TrialSiteSurvey> trialSiteSurveyRepository)
 | 
			
		||||
        {
 | 
			
		||||
            _trialSiteUserSurveyRepository = trialSiteUserSurveyRepository;
 | 
			
		||||
            _trialSiteSurveyRepository = trialSiteSurveyRepository;
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        [HttpGet("{trialSiteSurveyId:guid}")]
 | 
			
		||||
        public async Task<List<TrialSiteUserSurveyView>> GetTrialSiteUserSurveyList(Guid trialSiteSurveyId)
 | 
			
		||||
        [HttpPost]
 | 
			
		||||
        public async Task<List<TrialSiteUserSurveyView>> GetTrialSiteUserSurveyList(TrialSiteUserSurverQuery inquery)
 | 
			
		||||
        {
 | 
			
		||||
 | 
			
		||||
            var trialSiteUserSurveyQueryable = _trialSiteUserSurveyRepository.Where(t => t.TrialSiteSurveyId == trialSiteSurveyId)
 | 
			
		||||
             //.WhereIf(_userInfo.UserTypeEnumInt == (int)UserTypeEnum.SPM, t => t.TrialSiteSurvey.State >= TrialSiteSurveyEnum.CRCSubmitted)
 | 
			
		||||
             //.WhereIf(_userInfo.UserTypeEnumInt == (int)UserTypeEnum.ProjectManager || _userInfo.UserTypeEnumInt == (int)UserTypeEnum.APM|| _userInfo.UserTypeEnumInt == (int)UserTypeEnum.CPM, t => t.TrialSiteSurvey.State >= TrialSiteSurveyEnum.SPMApproved)
 | 
			
		||||
            var trialSiteUserSurveyQueryable = _trialSiteUserSurveyRepository.Where(t => t.TrialSiteSurveyId == inquery.TrialSiteSurveyId)
 | 
			
		||||
             .WhereIf(inquery.IsHistoryUser != null, t => t.IsHistoryUser == inquery.IsHistoryUser)
 | 
			
		||||
             .ProjectTo<TrialSiteUserSurveyView>(_mapper.ConfigurationProvider, new { isEn_Us = _userInfo.IsEn_Us });
 | 
			
		||||
 | 
			
		||||
            return await trialSiteUserSurveyQueryable.ToListAsync();
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
        [TypeFilter(typeof(TrialResourceFilter), Arguments = new object[] { "AfterStopCannNotOpt" })]
 | 
			
		||||
        [HttpPost("{trialId:guid}")]
 | 
			
		||||
        public async Task<IResponseOutput> AddOrUpdateTrialSiteUserSurvey(TrialSiteUserSurveyAddOrEdit addOrEditTrialSiteUserSurvey)
 | 
			
		||||
        {
 | 
			
		||||
 | 
			
		||||
            if (await _trialSiteUserSurveyRepository.Where(t => t.Id == addOrEditTrialSiteUserSurvey.Id).AnyAsync(t => t.TrialSiteSurvey.State == TrialSiteSurveyEnum.PMCreatedAndLock))
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
            if (await _trialSiteSurveyRepository.AnyAsync(t => t.Id == addOrEditTrialSiteUserSurvey.TrialSiteSurveyId && (t.IsDeleted == true || t.State == TrialSiteSurveyEnum.PMCreatedAndLock), true))
 | 
			
		||||
            {
 | 
			
		||||
                //---已锁定,不允许操作
 | 
			
		||||
                return ResponseOutput.NotOk(_localizer["TrialSiteUser_Locked"]);
 | 
			
		||||
            }
 | 
			
		||||
 | 
			
		||||
            if (addOrEditTrialSiteUserSurvey.UserTypeId != null && ( _userInfo.UserTypeEnumInt == (int)UserTypeEnum.ProjectManager || _userInfo.UserTypeEnumInt == (int)UserTypeEnum.APM))
 | 
			
		||||
            {
 | 
			
		||||
                var existSysUser = await _repository.FirstOrDefaultAsync<User>(t => t.EMail == addOrEditTrialSiteUserSurvey.Email && t.UserTypeId == addOrEditTrialSiteUserSurvey.UserTypeId);
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
                if (existSysUser != null)
 | 
			
		||||
                {
 | 
			
		||||
                    if (existSysUser.LastName != addOrEditTrialSiteUserSurvey.LastName || existSysUser.FirstName != addOrEditTrialSiteUserSurvey.FirstName)
 | 
			
		||||
                    {
 | 
			
		||||
                        //$"该用户在系统中账户名为:{existSysUser.LastName + " / " + existSysUser.FirstName} ,与填写信息存在不一致项, 现将界面信息修改为与系统一致,可进行保存"
 | 
			
		||||
                        return ResponseOutput.NotOk(_localizer["TrialSiteUser_InconsistentInfo", existSysUser.LastName + " / " + existSysUser.FirstName,existSysUser.Phone],
 | 
			
		||||
                            new { existSysUser.LastName, existSysUser.FirstName, existSysUser.Phone,existSysUser.IsTestUser,existSysUser.IsZhiZhun }, ApiResponseCodeEnum.NeedTips);
 | 
			
		||||
                    }
 | 
			
		||||
 | 
			
		||||
                }
 | 
			
		||||
 | 
			
		||||
                //当前调研表已废除,或者调研表状态已锁定,不允许操作
 | 
			
		||||
                return ResponseOutput.NotOk(_localizer["TrialSiteUserSurvey_Invalid"]);
 | 
			
		||||
            }
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
            if (addOrEditTrialSiteUserSurvey.IsGenerateAccount)
 | 
			
		||||
            {
 | 
			
		||||
                var trialId= _trialSiteUserSurveyRepository.Where(t=>t.TrialSiteSurveyId == addOrEditTrialSiteUserSurvey.TrialSiteSurveyId).Select(t=>t.TrialSiteSurvey.TrialId).FirstOrDefault();
 | 
			
		||||
                var trialId = _trialSiteSurveyRepository.Where(t => t.Id == addOrEditTrialSiteUserSurvey.TrialSiteSurveyId, false, true).Select(t => t.TrialId).FirstOrDefault();
 | 
			
		||||
 | 
			
		||||
                var trialType = _repository.Where<Trial>(t => t.Id == trialId).Select(t => t.TrialType).FirstOrDefault();
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -105,7 +92,40 @@ namespace IRaCIS.Core.Application.Contracts
 | 
			
		|||
 | 
			
		||||
            }
 | 
			
		||||
 | 
			
		||||
            var entity = await _trialSiteUserSurveyRepository.InsertOrUpdateAsync(addOrEditTrialSiteUserSurvey, true);
 | 
			
		||||
            var verifyExp1 = new EntityVerifyExp<TrialSiteUserSurvey>()
 | 
			
		||||
            {
 | 
			
		||||
                VerifyExp = u => u.UserTypeId == addOrEditTrialSiteUserSurvey.UserTypeId && u.Email == addOrEditTrialSiteUserSurvey.Email && u.TrialSiteSurveyId == addOrEditTrialSiteUserSurvey.TrialSiteSurveyId,
 | 
			
		||||
                VerifyMsg = "同一邮箱同一用户类型,生成账号的数据只允许存在一条!",
 | 
			
		||||
                IsVerify = addOrEditTrialSiteUserSurvey.IsGenerateAccount
 | 
			
		||||
 | 
			
		||||
            };
 | 
			
		||||
 | 
			
		||||
            if (addOrEditTrialSiteUserSurvey.UserTypeId != null)
 | 
			
		||||
            {
 | 
			
		||||
                var existSysUser = await _repository.Where<User>(t => t.EMail == addOrEditTrialSiteUserSurvey.Email && t.UserTypeId == addOrEditTrialSiteUserSurvey.UserTypeId).Include(d => d.UserTypeRole).FirstOrDefaultAsync();
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
                if (existSysUser != null)
 | 
			
		||||
                {
 | 
			
		||||
                    if (existSysUser.LastName != addOrEditTrialSiteUserSurvey.LastName || existSysUser.FirstName != addOrEditTrialSiteUserSurvey.FirstName)
 | 
			
		||||
                    {
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
                        var optEntity = await _trialSiteUserSurveyRepository.InsertOrUpdateAsync(addOrEditTrialSiteUserSurvey, true, verifyExp1);
 | 
			
		||||
 | 
			
		||||
                        //$"该用户在系统中账户名为:{existSysUser.LastName + " / " + existSysUser.FirstName} ,与填写信息存在不一致项, 现将界面信息修改为与系统一致,可进行保存"
 | 
			
		||||
                        return ResponseOutput.NotOk(_localizer["TrialSiteUser_InconsistentInfo", existSysUser.UserTypeRole.UserTypeShortName, existSysUser.EMail, existSysUser.LastName + " / " + existSysUser.FirstName, existSysUser.Phone],
 | 
			
		||||
                            new { Id = optEntity.Id, existSysUser.LastName, existSysUser.FirstName, existSysUser.Phone, existSysUser.IsTestUser, existSysUser.IsZhiZhun }, ApiResponseCodeEnum.NeedTips);
 | 
			
		||||
                    }
 | 
			
		||||
 | 
			
		||||
                }
 | 
			
		||||
            }
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
            var entity = await _trialSiteUserSurveyRepository.InsertOrUpdateAsync(addOrEditTrialSiteUserSurvey, true, verifyExp1);
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
            return ResponseOutput.Ok(entity.Id.ToString());
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -267,8 +267,7 @@ namespace IRaCIS.Core.Application.Services
 | 
			
		|||
            foreach (var t in studyList)
 | 
			
		||||
            {
 | 
			
		||||
                t.SeriesList = await _repository.Where<DicomSeries>(s => s.StudyId == t.StudyId)
 | 
			
		||||
               .WhereIf(isReading == 1, s => s.IsReading).OrderBy(s => s.SeriesNumber).
 | 
			
		||||
               ThenBy(s => s.SeriesTime)
 | 
			
		||||
               .WhereIf(isReading == 1, s => s.IsReading).OrderBy(s => s.SeriesNumber).ThenBy(s => s.SeriesTime)
 | 
			
		||||
               .ProjectTo<DicomSeriesDTO>(_mapper.ConfigurationProvider).ToListAsync();
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -28,11 +28,11 @@ namespace IRaCIS.Core.Domain.Models
 | 
			
		|||
        public Guid? UserTypeId { get; set; }
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
        public Guid TrialRoleNameId { get; set; }
 | 
			
		||||
 | 
			
		||||
        public Dictionary TrialRoleName { get; set; }
 | 
			
		||||
        //public Guid TrialRoleNameId { get; set; }
 | 
			
		||||
 | 
			
		||||
        //public Dictionary TrialRoleName { get; set; }
 | 
			
		||||
 | 
			
		||||
        public int? TrialRoleCode { get; set; }
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
        /// <summary>
 | 
			
		||||
| 
						 | 
				
			
			@ -59,7 +59,6 @@ namespace IRaCIS.Core.Domain.Models
 | 
			
		|||
        [Required]
 | 
			
		||||
        public Guid UpdateUserId { get; set; }
 | 
			
		||||
 | 
			
		||||
        public string UserName { get; set; } = string.Empty;
 | 
			
		||||
 | 
			
		||||
        /// <summary>
 | 
			
		||||
        /// Phone
 | 
			
		||||
| 
						 | 
				
			
			@ -85,13 +84,6 @@ namespace IRaCIS.Core.Domain.Models
 | 
			
		|||
        public Guid? SystemUserId { get; set; }
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
        public DateTime? ExpireTime { get; set; }
 | 
			
		||||
 | 
			
		||||
        public bool IsJoin { get; set; }
 | 
			
		||||
 | 
			
		||||
        public DateTime? ConfirmTime { get; set; }
 | 
			
		||||
 | 
			
		||||
        public string RejectReason { get; set; } = string.Empty;
 | 
			
		||||
 | 
			
		||||
        /// <summary>
 | 
			
		||||
        /// IsGenerateAccount
 | 
			
		||||
| 
						 | 
				
			
			@ -104,6 +96,15 @@ namespace IRaCIS.Core.Domain.Models
 | 
			
		|||
 | 
			
		||||
        public TrialSiteUserStateEnum InviteState { get; set; } = TrialSiteUserStateEnum.WaitSent;
 | 
			
		||||
 | 
			
		||||
        public bool IsJoin { get; set; }
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
        public bool IsHistoryUser { get; set; }
 | 
			
		||||
 | 
			
		||||
        public bool? IsHistoryUserDeleted { get; set; }
 | 
			
		||||
 | 
			
		||||
        public bool? IsHistoryUserOriginDeleted { get; set; }
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
		Reference in New Issue