//--------------------------------------------------------------------
//     此代码由T4模板自动生成  byzhouhang 20210918
//	   生成时间 2022-06-07 13:14:38 
//     对此文件的更改可能会导致不正确的行为,并且如果重新生成代码,这些更改将会丢失。
//--------------------------------------------------------------------
using IRaCIS.Core.Domain.Models;
using Microsoft.AspNetCore.Mvc;
using IRaCIS.Core.Application.Interfaces;
using IRaCIS.Core.Application.ViewModel;
using IRaCIS.Core.Application.Contracts;
namespace IRaCIS.Core.Application.Service
{
    /// 
    /// 分配规则
    /// 	
    [ApiExplorerSettings(GroupName = "Trial")]
    public class TaskAllocationRuleService : BaseService, ITaskAllocationRuleService
    {
        private readonly IRepository _taskAllocationRuleRepository;
        private readonly IRepository _userRepository;
        private readonly IRepository _trialRepository;
        
        public TaskAllocationRuleService(IRepository taskAllocationRuleRepository, IRepository userRepository, IRepository trialRepository)
        {
            _taskAllocationRuleRepository = taskAllocationRuleRepository;
            _userRepository = userRepository;
            _trialRepository= trialRepository;
        }
        [HttpPost]
        public async Task<(List,object)> GetTaskAllocationRuleList(TaskAllocationRuleQuery queryTaskAllocationRule)
        {
            var taskAllocationRuleQueryable = _taskAllocationRuleRepository.Where(t=>t.TrialId== queryTaskAllocationRule.TrialId && t.IsJudgeDoctor == queryTaskAllocationRule.IsJudgeDoctor)
             .ProjectTo(_mapper.ConfigurationProvider);
            var trialTaskConfig= _trialRepository.Where(t=>t.Id==queryTaskAllocationRule.TrialId).ProjectTo(_mapper.ConfigurationProvider, new {  isJudgeDoctor = queryTaskAllocationRule.IsJudgeDoctor }).FirstOrDefault();
            return (await taskAllocationRuleQueryable.ToListAsync(), trialTaskConfig);
        }
        /// 
        /// 获取访视任务   应用Subject后  医生比率情况
        /// 
        /// 
       [HttpPost]
        public async Task> GetSubjectApplyDoctorTaskStatList(ApplySubjectCommand assignConfirmCommand)
        {
            var taskAllocationRuleQueryable = _taskAllocationRuleRepository.Where(t => t.TrialId == assignConfirmCommand.TrialId && t.IsJudgeDoctor == assignConfirmCommand.IsJudgeDoctor)
            .ProjectTo(_mapper.ConfigurationProvider, new { subjectIdList = assignConfirmCommand.SubjectIdList , isJudgeDoctor = assignConfirmCommand.IsJudgeDoctor });
            return  await taskAllocationRuleQueryable.ToListAsync();
        }
       
        public async Task AddOrUpdateTaskAllocationRule(TaskAllocationRuleAddOrEdit addOrEditTaskAllocationRule)
        {
            var verifyExp1 = new EntityVerifyExp()
            {
                VerifyExp = t => t.DoctorUserId == addOrEditTaskAllocationRule.DoctorUserId && t.TrialId== addOrEditTaskAllocationRule.TrialId && t.IsJudgeDoctor,
                VerifyMsg = "已有该医生配置,不允许继续增加"
            };
            var entity = await _taskAllocationRuleRepository.InsertOrUpdateAsync(addOrEditTaskAllocationRule, true, verifyExp1);
            return ResponseOutput.Ok(entity.Id.ToString());
        }
        [HttpDelete("{taskAllocationRuleId:guid}/{isJudgeDoctor:bool}")]
        public async Task DeleteTaskAllocationRule(Guid taskAllocationRuleId, bool isJudgeDoctor )
        {
            if(await _taskAllocationRuleRepository.Where(t => t.Id == taskAllocationRuleId ).AnyAsync(t => t.DoctorVisitTaskList.Where(t=>isJudgeDoctor?t.ArmEnum==Domain.Share.Arm.JudgeArm: t.ArmEnum != Domain.Share.Arm.JudgeArm).Count() > 0))
            {
                return ResponseOutput.NotOk("已分配任务给该医生,不允许删除");
            }
            var success = await _taskAllocationRuleRepository.DeleteFromQueryAsync(t => t.Id == taskAllocationRuleId, true);
            return ResponseOutput.Ok();
        }
        /// 
        /// 获取项目下 医生账户信息下拉
        /// 
        /// 
        /// 
        /// 
        [HttpGet("{trialId:guid}")]
        public async Task> GetDoctorUserSelectList(Guid trialId,[FromServices]  IRepository _enrollRepository)
        {
            var query = from enroll in _enrollRepository.Where(t => t.TrialId == trialId)
                        join user in _userRepository.AsQueryable() on enroll.DoctorId equals user.DoctorId
                        select new TrialDoctorUserSelectView()
                        {
                            TrialId = enroll.TrialId,
                            ReadingType=enroll.Trial.ReadingType,
                            DoctorUserId= user.Id,
                            FullName=user.FullName,
                            UserCode=user.UserCode,
                            UserName=user.UserName,
                            UserTypeEnum=user.UserTypeRole.UserTypeEnum
                        };
            return query.ToList();
        }
    }
}