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; } } }