using APT.BaseData.Domain.Entities;
using APT.BaseData.Domain.Entities.FM;
using APT.BaseData.Domain.Enums;
using APT.BaseData.Domain.IServices;
using APT.BaseData.Domain.IServices.FM;
using APT.BaseData.Services.DomainServices;
using APT.BaseData.Services.Services.FM;
using APT.Infrastructure.Core;
using APT.MS.Domain.Entities.FO;
using APT.MS.Domain.Entities.HM;
using APT.MS.Domain.Entities.SE;
using APT.MS.Domain.Enums;
using APT.Utility;
using Microsoft.AspNetCore.Mvc;
using Microsoft.Extensions.Logging;
using MySqlX.XDevAPI.Common;
using NPOI.SS.Formula.Functions;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;
namespace APT.FO.WebApi.Controllers
{
    /// 
    /// 作业活动记录(关键和许可)
    /// 
    [Route("api/FO/FOJobActivityRecord")]
    public partial class JobActivityRecordController : AuthorizeApiController
    {
        IPFCodeRuleService CodeRuleService { get; set; }
        IFMNotificationTaskService NotificationTaskService { get; set; }
        IFMDepartmentService DepartmentService { get; set; }
        /// 
        /// FOPreOperSch
        /// 
        /// 
        public JobActivityRecordController(IPFCodeRuleService codeRuleService, IFMNotificationTaskService notificationTaskService, IFMDepartmentService departmentService)
        {
            CodeRuleService = codeRuleService;
            NotificationTaskService = notificationTaskService;
            DepartmentService = departmentService;
        }
        /// 
        /// 获取
        /// 
        /// 
        /// 
        [HttpPost, Route("GetEditOld")]
        public JsonActionResult GetEditOld([FromBody] KeywordFilter filter)
        {
            return SafeExecute(() => {
                //filter.Include.Clear();
                //filter.Include.Add("Nav_CreateUser");
                //filter.Include.Add("Nav_OperationStep");
                //filter.Include.Add("Nav_JobActivityPerson");
                //filter.Include.Add("Nav_JobActivityPerson.Nav_User");
                //filter.Include.Add("Nav_JobActivityPerson.Nav_User.Nav_Department");
                //filter.Include.Add("Nav_JobName");
                //filter.Include.Add("Nav_Details");
                //filter.Include.Add("Nav_Details.Nav_Files");
                //filter.Include.Add("Nav_Details.Nav_Files.Nav_ImgFile");
                //filter.Include.Add("Nav_Details.Nav_Files.Nav_ImgFile");
                //filter.Include.Add("Nav_Flow");
                //filter.Include.Add("Nav_Flow.Nav_Files");
                //filter.Include.Add("Nav_Flow.Nav_Files.Nav_ImgFile");
                //filter.Include.Add("Nav_Flow.Nav_Files.Nav_ImgFile");
                //filter.Include.Add("Nav_Measure");
                //filter.Include.Add("Nav_Measure.Nav_Files");
                //filter.Include.Add("Nav_Measure.Nav_Files.Nav_ImgFile");
                //filter.Include.Add("Nav_Measure.Nav_Files.Nav_ImgFile");
                //return WitEntity(null, filter);
                var id = filter.FilterGroup.Rules.FirstOrDefault(t => t.Field == "ID").Value.ToString();
                if (string.IsNullOrEmpty(id))
                    this.ThrowError("060010");
                var result = this.GetEntity(id, new string[] { "Nav_CreateUser", "Nav_OperationStep",
            "Nav_JobActivityPerson","Nav_JobActivityPerson.Nav_User","Nav_JobActivityPerson.Nav_User.Nav_Department","Nav_JobActivityPerson.Nav_RelatedUser","Nav_JobName","Nav_Details",
                "Nav_Details.Nav_Files","Nav_Details.Nav_Files.Nav_ImgFile","Nav_Details.Nav_Files.Nav_ImgFile",
            "Nav_Flow","Nav_Flow.Nav_Files","Nav_Flow.Nav_Files.Nav_ImgFile","Nav_Flow.Nav_Files.Nav_ImgFile",
                "Nav_Measure","Nav_Measure.Nav_Files","Nav_Measure.Nav_Files.Nav_ImgFile","Nav_Measure.Nav_Files.Nav_ImgFile"});
                if (result != null)
                {
                    if (result.Nav_Details != null && result.Nav_Details.Any())
                        result.Nav_Details = result.Nav_Details.OrderBy(t => t.NUM).ThenBy(m => m.SafeConfirmsStr).ToList();
                    if (result.Nav_Flow != null && result.Nav_Flow.Any())
                        result.Nav_Flow = result.Nav_Flow.OrderBy(t => t.NUM).ThenBy(m => m.SafeMeasuresStr).ToList();
                    if (result.Nav_Measure != null && result.Nav_Measure.Any())
                        result.Nav_Measure = result.Nav_Measure.OrderBy(t => t.NUM).ThenBy(m => m.DealMeasuresStr).ToList();
                }
                return result;
            });
        }
        /// 
        /// 获取
        /// 
        /// 
        /// 
        [HttpPost, Route("GetEdit")]
        public JsonActionResult GetEdit([FromBody] KeywordFilter filter)
        {
            return SafeExecute(() => {
                var id = filter.FilterGroup.Rules.FirstOrDefault(t => t.Field == "ID").Value.ToString();
                if (string.IsNullOrEmpty(id))
                    this.ThrowError("060010");
                //    var result = this.GetEntity(id, new string[] { "Nav_CreateUser", "Nav_OperationStep",
                //"Nav_JobActivityPerson","Nav_JobActivityPerson.Nav_User","Nav_JobActivityPerson.Nav_User.Nav_Department","Nav_JobActivityPerson.Nav_RelatedUser","Nav_JobName","Nav_Details",
                //    "Nav_Details.Nav_Files","Nav_Details.Nav_Files.Nav_ImgFile","Nav_Details.Nav_Files.Nav_ImgFile",
                //"Nav_Flow","Nav_Flow.Nav_Files","Nav_Flow.Nav_Files.Nav_ImgFile","Nav_Flow.Nav_Files.Nav_ImgFile",
                //    "Nav_Measure","Nav_Measure.Nav_Files","Nav_Measure.Nav_Files.Nav_ImgFile","Nav_Measure.Nav_Files.Nav_ImgFile"});
                var entity = this.GetEntity(id, "Nav_CreateUser", "Nav_OperationStep", "Nav_JobName.Nav_MonitorUser");
                if (entity != null)
                {
                    var newFilter = new BaseFilter(filter.OrgId);
                    newFilter.SelectField = new List { "ID", "DEAL_STATUS", "JOB_ACTIVITY_RECORD_ID", "JOB_DOCUMENT", "USER_ID", "RELATED_USER_ID", "Nav_User.NAME", "Nav_User.CODE", "Nav_User.Nav_Department", "Nav_User.FILE_PATH", "Nav_RelatedUser.NAME", "Nav_RelatedUser.Nav_Signs.Nav_ImgFile" };
                    var persons = this.GetEntities(t => t.JOB_ACTIVITY_RECORD_ID == entity.ID, newFilter).ToList();
                    entity.Nav_JobActivityPerson = persons;
                    newFilter.SelectField = new List { "ID", "NUM", "JOB_ACTIVITY_RECORD_ID", "SafeConfirmsStr", "IS_CONFIRM", "Nav_Files.Nav_ImgFile.FILE_NAME", "Nav_Files.Nav_ImgFile.FILE_PATH", "Nav_Files.Nav_ImgFile.FILE_TYPE", "Nav_Files.Nav_ImgFile" };
                    var safeConfirms = this.GetEntities(t => t.JOB_ACTIVITY_RECORD_ID == entity.ID, newFilter).ToList();
                    entity.Nav_Details = safeConfirms.OrderBy(t => t.NUM).ThenBy(m => m.SafeConfirmsStr).ToList();
                    newFilter.SelectField = new List { "ID", "NUM", "JOB_ACTIVITY_RECORD_ID", "SafeMeasuresStr", "IS_CONFIRM", "Nav_Files.Nav_ImgFile.FILE_NAME", "Nav_Files.Nav_ImgFile.FILE_PATH", "Nav_Files.Nav_ImgFile.FILE_TYPE", "Nav_Files.Nav_ImgFile" };
                    var safeMeasures = this.GetEntities(t => t.JOB_ACTIVITY_RECORD_ID == entity.ID, newFilter).ToList();
                    entity.Nav_Flow = safeMeasures.OrderBy(t => t.NUM).ThenBy(m => m.SafeMeasuresStr).ToList();
                    newFilter.SelectField = new List { "ID", "NUM", "JOB_ACTIVITY_RECORD_ID", "DealMeasuresStr", "IS_CONFIRM", "Nav_Files.Nav_ImgFile.FILE_NAME", "Nav_Files.Nav_ImgFile.FILE_PATH", "Nav_Files.Nav_ImgFile.FILE_TYPE", "Nav_Files.Nav_ImgFile" };
                    var dealMeasures = this.GetEntities(t => t.JOB_ACTIVITY_RECORD_ID == entity.ID, newFilter).ToList();
                    entity.Nav_Measure = dealMeasures.OrderBy(t => t.NUM).ThenBy(m => m.DealMeasuresStr).ToList();
                    //if (result.Nav_Details != null && result.Nav_Details.Any())
                    //    result.Nav_Details = result.Nav_Details.OrderBy(t => t.NUM).ThenBy(m => m.SafeConfirmsStr).ToList();
                    //if (result.Nav_Flow != null && result.Nav_Flow.Any())
                    //    result.Nav_Flow = result.Nav_Flow.OrderBy(t => t.NUM).ThenBy(m => m.SafeMeasuresStr).ToList();
                    //if (result.Nav_Measure != null && result.Nav_Measure.Any())
                    //    result.Nav_Measure = result.Nav_Measure.OrderBy(t => t.NUM).ThenBy(m => m.DealMeasuresStr).ToList();
                }
                return entity;
            });
        }
        /// 
        /// 获取
        /// 
        /// 
        /// 
        [HttpPost, Route("FullGet")]
        public JsonActionResult FullGet([FromBody] KeywordFilter filter)
        {
            return SafeExecute(() => {
                T_FO_JOB_ACTIVITY_RECORD main = null;
                var id = filter.FilterGroup.Rules.FirstOrDefault(t => t.Field == "ID").Value.ToString();
                if (!string.IsNullOrEmpty(id))
                {
                    main = this.GetEntity(id, false, "Nav_CreateUser", "Nav_OperationStep", "Nav_JobActivityPerson", "Nav_JobActivityPerson.Nav_User",
                        "Nav_JobActivityPerson.Nav_User.Nav_Department", "Nav_JobName", "Nav_Details", "Nav_Details.Nav_Files", "Nav_Details.Nav_Files.Nav_ImgFile",
                        "Nav_Flow", "Nav_Flow.Nav_Files", "Nav_Flow.Nav_Files.Nav_ImgFile", "Nav_Measure", "Nav_Measure.Nav_Files", "Nav_Measure.Nav_Files.Nav_ImgFile");
                    if (main != null)
                    {
                        if (main.Nav_Details != null && main.Nav_Details.Any())
                            main.Nav_Details = main.Nav_Details.OrderBy(t => t.NUM).ThenBy(m => m.SafeConfirmsStr).ToList();
                        if (main.Nav_Flow != null && main.Nav_Flow.Any())
                            main.Nav_Flow = main.Nav_Flow.OrderBy(t => t.NUM).ThenBy(m => m.SafeMeasuresStr).ToList();
                        if (main.Nav_Measure != null && main.Nav_Measure.Any())
                            main.Nav_Measure = main.Nav_Measure.OrderBy(t => t.NUM).ThenBy(m => m.DealMeasuresStr).ToList();
                    }
                }
                return main;
            });
        }
        /// 
        /// 新增修改
        /// 
        /// 
        /// 
        [HttpPost, Route("FullUpdate")]
        public JsonActionResult FullUpdate([FromBody] T_FO_JOB_ACTIVITY_RECORD entity)
        {
            return SafeExecute(() =>
            {
                List file = new List();
                List flowFile = new List();
                List measureFile = new List();
                T_SE_TRAIN_NOTIFY notify = null;
                var users = entity.Nav_JobActivityPerson;
                if (users!=null && users.Any())
                {
                    users= users.Where(t =>!t.IS_DELETED).ToList();
                }
                entity.Nav_JobActivityPerson = null;
                var details = entity.Nav_Details;
                entity.Nav_Details = null;
                var flows = entity.Nav_Flow;
                entity.Nav_Flow = null;
                var measures = entity.Nav_Measure;
                entity.Nav_Measure = null;
                var userID = APT.Infrastructure.Api.AppContext.CurrentSession.UserID;
                if (entity.TaskID != Guid.Empty)
                {
                    var currTask = GetEntity(t => t.ID == entity.TaskID);
                    if (currTask != null)
                    {
                        userID = currTask.USER_ID;
                    }
                }
                entity.DEPARTMENT_ID = this.GetEntity(t => t.ENABLE_STATUS == 0 && t.ID == (Guid)userID)?.DEPARTMENT_ID;
                users.ForEach(t => {
                    t.Nav_User = null;
                    t.Nav_RelatedUser = null;
                    t.ORG_ID = entity.ORG_ID;
                    t.JOB_ACTIVITY_RECORD_ID = entity.ID;
                });
                if (details != null && details.Any())
                {
                    var noSubmit = details.FirstOrDefault(t => t.IS_DELETED == false && t.IS_CONFIRM == false);
                    if (noSubmit != null)
                    {
                        throw new Exception("作业前项目未全部确认,请检查");
                    }
                    details.ForEach(t =>
                    {
                        if (entity.PUBLISH != null && entity.PUBLISH.Equals("SaveAndNotify") && !t.IS_CONFIRM)
                        {
                            this.ThrowError("060001");
                        }
                        if (t.IS_CONFIRM)
                        {
                            t.CONFIRM_DATE = DateTime.Now;
                        }
                        t.ORG_ID = entity.ORG_ID;
                        t.JOB_ACTIVITY_RECORD_ID = entity.ID;
                        if (t.Nav_Files != null && t.Nav_Files.Any())
                        {
                            t.Nav_Files.ForEach(x =>
                            {
                                x.ORG_ID = entity.ORG_ID;
                                x.T_FO_JOB_ACTIVITY_DETAIL_ID = t.ID;
                                file.Add(x);
                            });
                        }
                        t.Nav_Files = null;
                    });
                }
                else
                {
                    if (entity.PUBLISH != null && entity.PUBLISH.Equals("SaveAndNotify"))
                    {
                        this.ThrowError("060007");
                    }
                }
                if (flows != null && flows.Any())
                {
                    var noSubmit = flows.FirstOrDefault(t => t.IS_DELETED == false && t.IS_CONFIRM == false);
                    if (noSubmit != null)
                    {
                        throw new Exception("作业中项目未全部确认,请检查");
                    }
                    flows.ForEach(t =>
                    {
                        if (entity.PUBLISH != null && entity.PUBLISH.Equals("SaveAndNotify") && !t.IS_CONFIRM)
                        {
                            this.ThrowError("060003");
                        }
                        if (t.IS_CONFIRM)
                        {
                            t.CONFIRM_DATE = DateTime.Now;
                        }
                        t.ORG_ID = entity.ORG_ID;
                        t.JOB_ACTIVITY_RECORD_ID = entity.ID;
                        if (t.Nav_Files != null && t.Nav_Files.Any())
                        {
                            t.Nav_Files.ForEach(x =>
                            {
                                x.ORG_ID = entity.ORG_ID;
                                x.T_FO_JOB_ACTIVITY_FLOW_ID = t.ID;
                                flowFile.Add(x);
                            });
                        }
                        t.Nav_Files = null;
                    });
                }
                else
                {
                    if (entity.PUBLISH != null && entity.PUBLISH.Equals("SaveAndNotify"))
                    {
                        this.ThrowError("060008");
                    }
                }
                if (measures != null && measures.Any())
                {
                    var noSubmit = measures.FirstOrDefault(t => t.IS_DELETED == false && t.IS_CONFIRM == false);
                    if (noSubmit != null)
                    {
                        throw new Exception("作业后项目未全部确认,请检查");
                    }
                    measures.ForEach(t =>
                    {
                        if (entity.PUBLISH != null && entity.PUBLISH.Equals("SaveAndNotify") && !t.IS_CONFIRM)
                        {
                            this.ThrowError("060005");
                        }
                        if (t.IS_CONFIRM)
                        {
                            t.CONFIRM_DATE = DateTime.Now;
                        }
                        t.ORG_ID = entity.ORG_ID;
                        t.JOB_ACTIVITY_RECORD_ID = entity.ID;
                        if (t.Nav_Files != null && t.Nav_Files.Any())
                        {
                            t.Nav_Files.ForEach(x =>
                            {
                                x.ORG_ID = entity.ORG_ID;
                                x.T_FO_JOB_ACTIVITY_MEASURE_ID = t.ID;
                                measureFile.Add(x);
                            });
                        }
                        t.Nav_Files = null;
                    });
                }
                else
                {
                    if (entity.PUBLISH != null && entity.PUBLISH.Equals("SaveAndNotify"))
                    {
                        this.ThrowError("060009");
                    }
                }
                entity.FORM_STATUS = (int)FOTeamActivityState.草稿;
                List notices = new List();
                List persons = new List();
                T_FM_NOTIFICATION_TASK task = null;
                List fileIds = new List();
                List flowFileIds = new List();
                List measureFileIds = new List();
                var detailIds = this.GetEntities(t => t.JOB_ACTIVITY_RECORD_ID == entity.ID, new BaseFilter(entity.ORG_ID)).Select(m => m.ID).ToList();
                fileIds = this.GetEntities(t => detailIds.Contains(t.T_FO_JOB_ACTIVITY_DETAIL_ID), new BaseFilter(entity.ORG_ID)).Select(m => m.ID).ToList();
                var flowIds = this.GetEntities(t => t.JOB_ACTIVITY_RECORD_ID == entity.ID, new BaseFilter(entity.ORG_ID)).Select(m => m.ID).ToList();
                flowFileIds = this.GetEntities(t => flowIds.Contains(t.T_FO_JOB_ACTIVITY_FLOW_ID), new BaseFilter(entity.ORG_ID)).Select(m => m.ID).ToList();
                var measureIds = this.GetEntities(t => t.JOB_ACTIVITY_RECORD_ID == entity.ID, new BaseFilter(entity.ORG_ID)).Select(m => m.ID).ToList();
                measureFileIds = this.GetEntities(t => measureIds.Contains(t.T_FO_JOB_ACTIVITY_MEASURE_ID), new BaseFilter(entity.ORG_ID)).Select(m => m.ID).ToList();
                if (entity.PUBLISH != null && entity.PUBLISH.Equals("SaveAndNotify"))
                {
                    //作业前中后必须有一个附件
                    if ((file == null || !file.Any()) && (flowFile == null || !flowFile.Any()) && (measureFile == null || !measureFile.Any()))
                    {
                        throw new Exception("作业前中后至少要上传一个附件");
                    }
                    entity.FORM_STATUS = (int)FOTeamActivityState.已归档;
                    DateTime dtEnd = NotificationTaskService.GetTaskEndTime(FMTASKTYPE.JobSite, entity.ORG_ID.Value, DateTime.Now, null, null);
                    //新增的消息通知
                    if (users != null && users.Any())
                    {
                        if (entity.IS_OUTSOURCE == true && entity.RELATED_ID != null)
                        {
                            entity.FORM_STATUS = (int)FOTeamActivityState.已归档;
                            users.ForEach(t => t.DEAL_STATUS = 1);
                        }
                        else
                        {
                            entity.FORM_STATUS = (int)FOTeamActivityState.签到中;
                            users.ForEach(t =>
                            {
                                if (t.USER_ID == userID)
                                    t.DEAL_STATUS = 1;
                            });
                            var userIds = users.Where(x => x.USER_ID != userID).Select(t => (Guid)t.USER_ID).Distinct().ToList();
                            if (userIds != null && userIds.Any())
                            {
                                var UserNames = new List();
                                var user = this.GetEntities(t => t.ENABLE_STATUS == (int)FMEnableStatusEnum.启用 && userIds.Contains(t.ID), new BaseFilter(entity.ORG_ID));
                                foreach (var u in userIds)
                                {
                                    var current = user.FirstOrDefault(t => t.ID == u);
                                    UserNames.Add(current?.NAME);
                                }
                                //发消息
                                notices = NotificationTaskService.InsertUserNoticeTaskModels("作业活动记录表单(关键和许可作业)", entity.ID, entity.ORG_ID, userIds, UserNames, DateTime.Now,
                                dtEnd, (int)FMNoticeTypeEnum.消息, "FO021_SHOWPRINT");
                                //触发完工验收
                                GetAutoNext(entity, ref notices);
                            }
                            else
                            {
                                entity.FORM_STATUS = (int)FOTeamActivityState.已归档;
                                //触发完工验收
                                GetAutoNext(entity, ref notices);
                            }
                        }
                    }
                    else
                    {
                        //触发完工验收
                        GetAutoNext(entity,ref notices);
                    }
                    //查询消息表
                    //var userID = APT.Infrastructure.Api.AppContext.CurrentSession.UserID;
                    //task = this.GetEntity(i => i.SOURCE_DATA_ID == entity.ID && i.USER_ID == userID
                    //&& (i.NOTICE_STATUS == FMNoticeStatusEnum.未处理.GetInt() || i.NOTICE_STATUS == FMNoticeStatusEnum.超期办理.GetInt()), false);
                    //if (task != null)
                    //{
                    //    task.NOTICE_STATUS = FMNoticeStatusEnum.正常已办.GetInt();
                    //    task.TASK_DT = DateTime.Now;
                    //    task.MODIFIER_ID = userID;
                    //}
                    if (entity.TaskID != Guid.Empty)
                    {
                        task = NotificationTaskService.GetTaskFinishModel(entity.TaskID);
                        task.SOURCE_FORMCODE = "FO021_SHOWPRINT";
                    }
                    if (entity.IS_NEED == (int)ISImportantEnum.否 && entity.IS_OUTSOURCE == false)
                    {
                        //触发培训通知给班组长
                        var departmentId = APT.Infrastructure.Api.AppContext.CurrentSession.DepartmentId;
                        var departmentInfo = this.GetEntity(t => t.ID == Guid.Parse(departmentId), "Nav_User");
                        if (departmentInfo != null && departmentInfo.USER_ID != null)
                        {
                            notify = new T_SE_TRAIN_NOTIFY();
                            notify.ORG_ID = entity.ORG_ID;
                            notify.LAUNCH_TIME = DateTime.Now;
                            notify.LAUNCH_DEPARTMENT_ID = departmentInfo.ID;
                            notify.LAUNCH_USER_ID = departmentInfo.USER_ID;
                            notify.CODE = DateTime.Now.ToString("yyyyMMddHHmmss");
                            notify.NAME = "关键许可作业活动记录培训通知";
                            notify.STATUS = SETrainNotifyStatus.草稿;
                            if (users.Any())
                            {
                                users.ForEach(t =>
                                {
                                    T_SE_TRAIN_NOTIFY_PERSONS person = new T_SE_TRAIN_NOTIFY_PERSONS();
                                    person.USER_ID = t.USER_ID.Value;
                                    person.NOTIFY_ID = notify.ID;
                                    person.ORG_ID = notify.ORG_ID;
                                    person.IS_LEAVE = SETrainYesNoEnum.参加;
                                    persons.Add(person);
                                });
                            }
                            notices.Add(NotificationTaskService.InsertUserNoticeTaskModel("关键许可作业活动记录培训通知", notify.ID, notify.ORG_ID, departmentInfo.USER_ID.Value, departmentInfo.Nav_User.NAME, DateTime.Now,
                        dtEnd, (int)FMNoticeTypeEnum.消息, "SE014"));
                        }
                    }
                }
                this.UnifiedCommit(() =>
                {
                    if (entity != null)
                        UpdateEntityNoCommit(entity);   //保存主表
                    if (users != null && users.Any())
                        BantchSaveEntityNoCommit(users);    //保存子表
                    if (details != null && details.Any())
                        BantchSaveEntityNoCommit(details);    //保存子表
                    if (flows != null && flows.Any())
                        BantchSaveEntityNoCommit(flows);    //保存子表
                    if (measures != null && measures.Any())
                        BantchSaveEntityNoCommit(measures);    //保存子表
                    if (fileIds != null && fileIds.Any())
                        BantchDeleteEntityNoCommit(fileIds);    //保存子表
                    if (flowFileIds != null && flowFileIds.Any())
                        BantchDeleteEntityNoCommit(flowFileIds);    //保存子表
                    if (measureFileIds != null && measureFileIds.Any())
                        BantchDeleteEntityNoCommit(measureFileIds);    //保存子表
                    if (file != null && file.Any())
                        BantchSaveEntityNoCommit(file);    //保存子表
                    if (flowFile != null && flowFile.Any())
                        BantchSaveEntityNoCommit(flowFile);    //保存子表
                    if (measureFile != null && measureFile.Any())
                        BantchSaveEntityNoCommit(measureFile);
                    if (notices != null && notices.Any())
                        BantchSaveEntityNoCommit(notices);
                    if (task != null)
                        UpdateEntityNoCommit(task);
                    if (notify != null)
                        UpdateEntityNoCommit(notify);   //保存主表
                    if (persons != null && persons.Any())
                        BantchSaveEntityNoCommit(persons);
                });
                return true;
            });
        }
        /// 
        /// 完工验收
        /// 
        private void GetAutoNext(T_FO_JOB_ACTIVITY_RECORD entity, ref List notices)
        {
            //触发完工验收
            var job = this.GetEntity(t => t.ID == entity.JOB_NAME_ID);
            if (job != null)
            {
                var userIds = new List();
                userIds.Add((Guid)job.APPLY_USER_ID);
                var jobUser = this.GetEntities(t => t.CRUCIAL_LICENSE_JOB_ID == job.ID, new BaseFilter(job.ORG_ID));
                var userTempIds = jobUser.Where(m => m.USER_ID != null).Select(t => (Guid)t.USER_ID).ToList();
                userIds.AddRange(userTempIds);
                userIds.Distinct();
                var userInfos = this.GetEntities(t => t.ENABLE_STATUS == 0, new BaseFilter(job.ORG_ID));
                var departIds = userInfos.Where(t => userIds.Contains(t.ID)).Select(m => m.DEPARTMENT_ID).Distinct().ToList();
                var chargeUserIds = this.GetEntities(t => departIds.Contains(t.ID) && t.USER_ID != null, new BaseFilter(job.ORG_ID)).Select(m => (Guid)m.USER_ID).Distinct().ToList();
                if (chargeUserIds != null && chargeUserIds.Any())
                {
                    var chargeUserNames = userInfos.Where(t => chargeUserIds.Contains(t.ID)).Select(m => m.NAME).ToList();
                    notices.AddRange(NotificationTaskService.InsertUserNoticeTaskModels("关键许可作业活动记录-完工验收", entity.ID, entity.ORG_ID, chargeUserIds, chargeUserNames, DateTime.Now,
           DateTime.Now.AddHours(24), (int)FMNoticeTypeEnum.消息, "FO022_SHOWPRINT"));
                }
            }
        }
        /// 
        /// 删除
        /// 
        /// 
        /// 
        [HttpGet, Route("FullDelete")]
        public JsonActionResult FullDelete(string id)
        {
            return SafeExecute(() =>
            {
                T_FO_JOB_ACTIVITY_RECORD entity = GetEntity(t => t.ID.ToString() == id, false, "Nav_JobActivityPerson", "Nav_Details", "Nav_Details.Nav_Files", "Nav_Flow", "Nav_Flow.Nav_Files", "Nav_Measure", "Nav_Measure.Nav_Files");
                List userIds = new List();
                List detailIds = new List();
                List fileIds = new List();
                List flowIds = new List();
                List flowFileIds = new List();
                List measureIds = new List();
                List measureFileIds = new List();
                if (entity.Nav_JobActivityPerson != null && entity.Nav_JobActivityPerson.Any())
                {
                    var userIdList = entity.Nav_JobActivityPerson.Select(t => t.ID).ToList();
                    userIds.AddRange(userIdList);
                }
                if (entity.Nav_Details != null && entity.Nav_Details.Any())
                {
                    var detailIdList = entity.Nav_Details.Select(t => t.ID).ToList();
                    detailIds.AddRange(detailIdList);
                    entity.Nav_Details.ForEach(t =>
                    {
                        var ids = t.Nav_Files.Select(t => t.ID).ToList();
                        fileIds.AddRange(ids);
                    });
                }
                if (entity.Nav_Flow != null && entity.Nav_Flow.Any())
                {
                    var flowIdList = entity.Nav_Flow.Select(t => t.ID).ToList();
                    flowIds.AddRange(flowIdList);
                    entity.Nav_Flow.ForEach(t =>
                    {
                        var ids = t.Nav_Files.Select(t => t.ID).ToList();
                        flowFileIds.AddRange(ids);
                    });
                }
                if (entity.Nav_Measure != null && entity.Nav_Measure.Any())
                {
                    var measureIdList = entity.Nav_Measure.Select(t => t.ID).ToList();
                    measureIds.AddRange(measureIdList);
                    entity.Nav_Measure.ForEach(t =>
                    {
                        var ids = t.Nav_Files.Select(t => t.ID).ToList();
                        measureFileIds.AddRange(ids);
                    });
                }
                UnifiedCommit(() =>
                {
                    if (userIds != null && userIds.Any())
                        this.BantchDeleteEntityNoCommit(userIds);
                    if (detailIds != null && detailIds.Any())
                        this.BantchDeleteEntityNoCommit(detailIds);
                    if (fileIds != null && fileIds.Any())
                        this.BantchDeleteEntityNoCommit(fileIds);
                    if (flowIds != null && flowIds.Any())
                        this.BantchDeleteEntityNoCommit(flowIds);
                    if (flowFileIds != null && flowFileIds.Any())
                        this.BantchDeleteEntityNoCommit(flowFileIds);
                    if (measureIds != null && measureIds.Any())
                        this.BantchDeleteEntityNoCommit(measureIds);
                    if (measureFileIds != null && measureFileIds.Any())
                        this.BantchDeleteEntityNoCommit(measureFileIds);
                    if (entity != null)
                        this.DeleteEntityNoCommit(entity);
                });
                return true;
            });
        }
        /// 
        /// 签到同意
        /// 
        /// 
        /// 
        [HttpPost, Route("PersonalAgree")]
        public JsonActionResult PersonalAgree([FromBody] T_FO_JOB_ACTIVITY_RECORD entity)
        {
            return SafeExecute(() =>
            {
                var orgId = APT.Infrastructure.Api.AppContext.CurrentSession.OrgId;
                var userID = APT.Infrastructure.Api.AppContext.CurrentSession.UserID;
                if (entity.TaskID != Guid.Empty)
                {
                    var currTask = GetEntity(t => t.ID == entity.TaskID);
                    if (currTask != null)
                    {
                        userID = currTask.USER_ID;
                    }
                }
                entity.ORG_ID = orgId;
                var user = this.GetEntity(t => t.JOB_ACTIVITY_RECORD_ID == entity.ID && t.USER_ID == userID, new BaseFilter(orgId));
                user.DEAL_STATUS = (int)FOUserShiftStatusEnum.已处理;
                var todoCount = this.GetCount(t => t.JOB_ACTIVITY_RECORD_ID == entity.ID && t.DEAL_STATUS == 0 && t.USER_ID != userID, new BaseFilter(orgId));
                T_FO_JOB_ACTIVITY_RECORD model = null;
                //List notices = new List();
                if (todoCount == 0)
                {
                    model = GetEntity(entity.ID.ToString());
                    model.FORM_STATUS = (int)FOTeamActivityState.已归档;
                    //触发完工验收
                    //var userIds = new List();
                    //var record = this.GetEntity(t=>t.ID == entity.ID);
                    //if (record != null)
                    //{
                    //    var job = this.GetEntity(t => t.ID == record.JOB_NAME_ID, "Nav_CrucialLicensePerson");
                    //    if (job != null)
                    //    {
                    //        userIds.Add((Guid)job.APPLY_USER_ID);
                    //        var jobUser = this.GetEntities(t => t.CRUCIAL_LICENSE_JOB_ID == job.ID,new BaseFilter(job.ORG_ID));
                    //        var userTempIds = jobUser.Where(m=>m.USER_ID!=null).Select(t => (Guid)t.USER_ID).ToList();
                    //        userIds.AddRange(userTempIds);
                    //        userIds.Distinct();
                    //        var users = this.GetEntities(t => t.ENABLE_STATUS==0, new BaseFilter(job.ORG_ID));
                    //        var departIds = users.Where(t=>userIds.Contains(t.ID)).Select(m=>m.DEPARTMENT_ID).Distinct().ToList();
                    //        var chargeUserIds= this.GetEntities(t => departIds.Contains(t.ID) && t.USER_ID != null, new BaseFilter(job.ORG_ID)).Select(m => (Guid)m.USER_ID).Distinct().ToList();
                    //        if (chargeUserIds!=null && chargeUserIds.Any())
                    //        {
                    //            var chargeUserNames = users.Where(t => chargeUserIds.Contains(t.ID)).Select(m=>m.NAME).ToList();
                    //            notices.AddRange(NotificationTaskService.InsertUserNoticeTaskModels("关键许可作业活动记录-完工验收", entity.ID, entity.ORG_ID, chargeUserIds, chargeUserNames, DateTime.Now,
                    //   DateTime.Now.AddHours(24), (int)FMNoticeTypeEnum.消息, "FO022_SHOWPRINT"));
                    //        }
                    //    }
                    //}
                }
                //查询消息表
                //var task = this.GetEntity(i => i.SOURCE_DATA_ID == entity.ID && i.USER_ID == userID
                //&& (i.NOTICE_STATUS == FMNoticeStatusEnum.未处理.GetInt() || i.NOTICE_STATUS == FMNoticeStatusEnum.超期办理.GetInt()), false);
                //if (task != null)
                //{
                //    task.NOTICE_STATUS = FMNoticeStatusEnum.正常已办.GetInt();
                //    task.TASK_DT = DateTime.Now;
                //    task.MODIFIER_ID = userID;
                //}
                T_FM_NOTIFICATION_TASK task = null;
                if (entity.TaskID != Guid.Empty)
                {
                    task = NotificationTaskService.GetTaskFinishModel(entity.TaskID);
                    task.SOURCE_FORMCODE = "FO021_SHOWPRINT";
                }
                this.UnifiedCommit(() =>
                {
                    if (model != null)
                        UpdateEntityNoCommit(model);
                    if (task != null)
                        this.UpdateEntityNoCommit(task);
                    if (user != null)
                        this.UpdateEntityNoCommit(user);
                    //if (notices != null && notices.Any())
                    //    BantchSaveEntityNoCommit(notices);
                });
                return true;
            });
        }
        /// 
        /// 完工验收
        /// 
        /// 
        /// 
        [HttpPost, Route("FinishAgree")]
        public JsonActionResult FinishAgree([FromBody] T_FO_JOB_ACTIVITY_RECORD entity)
        {
            return SafeExecute(() =>
            {
                var userID = APT.Infrastructure.Api.AppContext.CurrentSession.UserID;
                T_FM_NOTIFICATION_TASK task = null;
                if (entity.TaskID != Guid.Empty)
                {
                    var currTask = GetEntity(t => t.ID == entity.TaskID);
                    if (currTask != null)
                    {
                        userID = currTask.USER_ID;
                    }
                    task = NotificationTaskService.GetTaskFinishModel(entity.TaskID);
                    task.SOURCE_FORMCODE = "FO022_SHOWPRINT";
                }
                this.UnifiedCommit(() =>
                {
                    if (task != null)
                        this.UpdateEntityNoCommit(task);
                });
                return true;
            });
        }
        /// 
        /// 完工验收-驳回
        /// 
        /// 
        /// 
        [HttpPost, Route("FinishReject")]
        public JsonActionResult FinishReject([FromBody] T_FO_JOB_ACTIVITY_RECORD entity)
        {
            return SafeExecute(() =>
            {
                T_FM_NOTIFICATION_TASK task = null;
                T_FM_NOTIFICATION_TASK notice = null;
                var currTask = GetEntity(t => t.ID == entity.TaskID);
                if (currTask != null)
                {
                    task = NotificationTaskService.GetTaskFinishModel(entity.TaskID);
                }
                var record = this.GetEntity(entity.ID, "Nav_JobName");
                if (record != null)
                {
                    record.FORM_STATUS = (int)FOTeamActivityState.已驳回;
                    
                    if (record.Nav_JobName != null && record.Nav_JobName.MONITOR_USER_ID != null)
                    {
                        //驳回给监护人
                        var user = this.GetEntity(t=>t.ID == record.Nav_JobName.MONITOR_USER_ID);
                        if (user != null)
                        {
                            //发消息
                            notice = NotificationTaskService.InsertUserNoticeTaskModel("作业活动记录表(关键许可)已被驳回", record.ID, record.ORG_ID, user.ID, user.NAME, DateTime.Now,
                        DateTime.Now.AddHours(24), (int)FMNoticeTypeEnum.消息, "FO021");
                        }
                    }
                }
                UnifiedCommit(() =>
                {
                    if (record != null)
                        this.UpdateEntityNoCommit(record);
                    if (notice != null)
                        this.UpdateEntityNoCommit(notice);
                    if (task != null)
                        this.UpdateEntityNoCommit(task);
                });
                return true;
            });
        }
        /// 
        /// 排序分页查询数据
        /// 
        /// 分页过滤实体
        /// 
        [HttpPost, Route("FullOrderPaged")]
        public PagedActionResult FullOrderPaged([FromBody] KeywordPageFilter pageFilter)
        {
            var result = new PagedActionResult();
            var filter = pageFilter.FilterGroup.Rules.FirstOrDefault(t => t.Field == "PARENT_NAME");
            if (filter != null && !string.IsNullOrEmpty(filter.Value.ToString()))
                pageFilter.FilterGroup.Rules.Remove(filter);
            var loginDepartmentId = APT.Infrastructure.Api.AppContext.CurrentSession.DepartmentID;
            var loginUserId = APT.Infrastructure.Api.AppContext.CurrentSession.UserID;
            var loginUserCode = APT.Infrastructure.Api.AppContext.CurrentSession.UserCode;
            //安环部负责人departmentID
            var manageDepartId = this.GetEntity(t => t.Nav_ApproveRole != null && t.Nav_ApproveRole.NAME == "安环部负责人" && t.ENABLE_STATUS == 0)?.DEPARTMENT_ID;
            if (loginUserCode == "admin" || loginDepartmentId == manageDepartId)
            {
                result = this.GetOrderPageEntities(null, pageFilter);
            }
            else
            {
                List departmentId = new List() { loginDepartmentId.Value };
                List departmentIds = new List() { loginDepartmentId.Value };
                DepartmentService.GetDepartmentIds(pageFilter.OrgId.Value, departmentId, ref departmentIds);
                if (departmentIds != null && departmentIds.Any())
                {
                    result = this.GetOrderPageEntities(t => t.Nav_CreateUser.DEPARTMENT_ID != null && departmentIds.Contains(t.Nav_CreateUser.DEPARTMENT_ID.Value), pageFilter);//|| dataIds.Contains(t.ID)
                }
                else
                    result.Data = null;
            }
            if (result.Data.Any())
            {
                var departments = this.GetEntities(t => t.ENABLE_STATUS == 0, new BaseFilter(pageFilter.OrgId)).ToList();
                result.Data.ForEach(t =>
                {
                    if (t.Nav_CreateUser != null && t.Nav_CreateUser.DEPARTMENT_ID != null)
                    {
                        var depart = GetDEPARTMENTLevel(departments, (Guid)t.Nav_CreateUser.DEPARTMENT_ID);
                        t.PARENT_NAME = depart?.NAME;
                    }
                });
                if (filter != null && !string.IsNullOrEmpty(filter.Value.ToString()))
                    result.Data = result.Data.Where(t => t.PARENT_NAME != null && t.PARENT_NAME.Contains(filter.Value.ToString()));
            }
            if (result.Data != null && result.Data.Any())
            {
                result.Data.ForEach(t =>
                {
                    if (t.FORM_STATUS != 2)
                        t.MODIFY_TIME = null;
                });
            }
            return result;
        }
        public T_FM_DEPARTMENT GetDEPARTMENTLevel(List departList, Guid DepartmentID)
        {
            var department = departList.FirstOrDefault(t => t.ID == DepartmentID);
            if (department.DEPARTMENT_TYPE == (int)FMDepartmentType.公司)
            {
                return null;
            }
            else if (department.DEPARTMENT_TYPE == (int)FMDepartmentType.部门)
            {
                return department;
            }
            else
            {
                department = GetDEPARTMENTLevel(departList, department.PARENT_ID.Value);
            }
            return department;
        }
    }
}