using APT.BaseData.Domain.Entities; using APT.BaseData.Domain.Entities.FM; using APT.BaseData.Domain.Enums; using APT.BaseData.Domain.Enums.PF; using APT.BaseData.Domain.IServices; using APT.BaseData.Domain.IServices.FM; using APT.Infrastructure.Core; using APT.MS.Domain.Entities.SK; using APT.MS.Domain.Enums; using APT.MS.Domain.Enums.SK; using APT.Utility; using Microsoft.AspNetCore.Mvc; using Microsoft.VisualStudio.Web.CodeGeneration.Utils; using Newtonsoft.Json; using NPOI.SS.Formula.Functions; using System; using System.Collections.Generic; using System.Linq; namespace APT.SK.WebApi.Controllers.Api { /// /// 安全风险辨识结果表 /// [Route("api/SK/SKRiskIdentifyResult")] public partial class RiskIdentifyResultController : AuthorizeApiController { IPFApproveCallBackService ApproveCallBackService { get; set; } IFMNotificationTaskService NotificationTaskService { get; set; } IPFCodeRuleService CodeRuleService { get; set; } IFMFlowPermitService MFlowPermitService { get; set; } public RiskIdentifyResultController(IFMNotificationTaskService notificationTaskService, IFMFlowPermitService mFlowPermitService, IPFCodeRuleService codeRuleService, IPFApproveCallBackService approveCallBackService) { NotificationTaskService = notificationTaskService; MFlowPermitService = mFlowPermitService; CodeRuleService = codeRuleService; ApproveCallBackService = approveCallBackService; } [HttpPost, Route("FullUpdate")] public JsonActionResult FullUpdate([FromBody] T_SK_RISK_IDENTIFY_RESULT entity) { return SafeExecute(() => { var userId = APT.Infrastructure.Api.AppContext.CurrentSession.UserID; var departId = APT.Infrastructure.Api.AppContext.CurrentSession.DepartmentID; if (entity.APPLY_USER_ID == null) entity.APPLY_USER_ID = userId; if (entity.APPLY_DEPARTMENT_ID == null) entity.APPLY_DEPARTMENT_ID = departId; if (entity.IDENTIFY_EVALUATION_PLAN_ID == null) entity.APPLY_DEPARTMENT_ID = this.GetEntity(t => t.ID == entity.IDENTIFY_ID)?.IDENTIFY_EVALUATION_PLAN_ID; var details = entity.Nav_Details; entity.Nav_Details = null; var requires = entity.Nav_Requires; entity.Nav_Requires = null; var files = entity.Nav_Files; entity.Nav_Files = null; entity.ApplyDepartmentName = this.GetEntity(t => t.ID == departId).NAME; entity.ApplyPostName = this.GetEntity(t => t.ID == userId, "Nav_Person.Nav_Post")?.Nav_Person?.Nav_Post?.NAME; List deleteMeasureIds = new List(); List deleteDepartIds = new List(); List deletePostIds = new List(); List deletePostDetailIds = new List(); List deleteDetailIds = new List(); List detailList = new List(); List measureList = new List(); List departList = new List(); List postList = new List(); List postDetailList = new List(); //更新标识字段 var record = this.GetEntity(t => t.ID == entity.ID, "Nav_Details"); if (record != null && record.Nav_Details != null && record.Nav_Details.Any() && details != null && details.Any()) { deleteDetailIds = record.Nav_Details.Select(t => t.ID).ToList(); var detailMes = this.GetEntities(t => deleteDetailIds.Contains(t.RISK_IDENTIFY_RESULT_DETAIL_ID), new BaseFilter(entity.ORG_ID)).ToList(); deleteMeasureIds = detailMes.Select(t => t.ID).ToList(); deleteDepartIds = this.GetEntities(t => deleteDetailIds.Contains(t.RISK_IDENTIFY_RESULT_DETAIL_ID), new BaseFilter(entity.ORG_ID)).Select(t => t.ID).ToList(); deletePostIds = this.GetEntities(t => deleteDetailIds.Contains(t.RISK_IDENTIFY_RESULT_DETAIL_ID), new BaseFilter(entity.ORG_ID)).Select(t => t.ID).ToList(); deletePostDetailIds = this.GetEntities(t => deletePostIds.Contains(t.RISK_IDENTIFY_DETAIL_RESULT_POST_ID), new BaseFilter(entity.ORG_ID)).Select(t => t.ID).ToList(); //record.Nav_Details.ForEach(t => //{ // if (t.Nav_DetailMeasures != null && t.Nav_DetailMeasures.Any()) // { // var tempIds = t.Nav_DetailMeasures.Select(m => m.ID).ToList(); // deleteMeasureIds.AddRange(tempIds); // } // if (t.Nav_DetailDeparts != null && t.Nav_DetailDeparts.Any()) // { // var tempIds = t.Nav_DetailDeparts.Select(m => m.ID).ToList(); // deleteDepartIds.AddRange(tempIds); // } // if (t.Nav_DetailPosts != null && t.Nav_DetailPosts.Any()) // { // var tempIds = t.Nav_DetailPosts.Select(m => m.ID).ToList(); // deletePostIds.AddRange(tempIds); // } // deleteDetailIds.Add(t.ID); //}); foreach (var item in details) { var temp = record.Nav_Details.FirstOrDefault(t => t.PRODUCTION_UNIT_ID == item.PRODUCTION_UNIT_ID && t.AREA_ID == item.AREA_ID && t.TYPE_ID == item.TYPE_ID && t.RISK_NAME == item.RISK_NAME && t.RISK_DESCRIPTION == item.RISK_DESCRIPTION && t.EMERGENCY == item.EMERGENCY && t.ENABLE_STATUS == item.ENABLE_STATUS); if (temp == null && item.MARK != SKMarkEnum.Add) { item.MARK = SKMarkEnum.Update; } if (item.Nav_DetailMeasures != null && item.Nav_DetailMeasures.Any()) { foreach (var mes in item.Nav_DetailMeasures) { var newMes = detailMes.FirstOrDefault(t => t.MEASURE == mes.MEASURE && t.RISK_IDENTIFY_RESULT_DETAIL_ID == item.ID); if (newMes == null && item.MARK != SKMarkEnum.Add) { item.MARK = SKMarkEnum.Update; } } } } } if (details != null && details.Any()) { foreach (var item in details) { T_SK_RISK_IDENTIFY_RESULT_DETAIL de = new T_SK_RISK_IDENTIFY_RESULT_DETAIL(); de.ORG_ID = entity.ORG_ID; de.RISK_IDENTIFY_RESULT_ID = entity.ID; de.PRODUCTION_UNIT_ID = item.PRODUCTION_UNIT_ID; de.AREA_ID = item.AREA_ID; de.RISK_NAME = item.RISK_NAME; de.RISK_DESCRIPTION = item.RISK_DESCRIPTION; de.TYPE_ID = item.TYPE_ID; de.ENABLE_STATUS = item.ENABLE_STATUS; de.MARK = item.MARK; de.EMERGENCY = item.EMERGENCY; de.ENTERPRISE_LIBRARY_ID = item.ENTERPRISE_LIBRARY_ID; if (item.Nav_DetailMeasures != null && item.Nav_DetailMeasures.Any()) { foreach (var mm in item.Nav_DetailMeasures) { T_SK_RISK_IDENTIFY_DETAIL_RESULT_MEASURE item2 = new T_SK_RISK_IDENTIFY_DETAIL_RESULT_MEASURE(); item2.ORG_ID = entity.ORG_ID; item2.RISK_IDENTIFY_RESULT_DETAIL_ID = de.ID; item2.NUM = mm.NUM; item2.MEASURE = mm.MEASURE; measureList.Add(item2); var temp = (item2.NUM == null || item2.NUM == 0) ? "1" : item2.NUM + "、" + item2.MEASURE + Environment.NewLine; de.MEASURE = de.MEASURE + temp; } } detailList.Add(de); item.Nav_DetailMeasures = null; if (item.Nav_DetailDeparts != null && item.Nav_DetailDeparts.Any()) { foreach (var mm in item.Nav_DetailDeparts) { T_SK_RISK_IDENTIFY_DETAIL_RESULT_DEPART item2 = new T_SK_RISK_IDENTIFY_DETAIL_RESULT_DEPART(); item2.ORG_ID = entity.ORG_ID; item2.RISK_IDENTIFY_RESULT_DETAIL_ID = de.ID; item2.DEPARTMENT_TYPE = mm.DEPARTMENT_TYPE; item2.DEPARTMENT_ID = mm.DEPARTMENT_ID; departList.Add(item2); } } item.Nav_DetailDeparts = null; if (item.Nav_DetailPosts != null && item.Nav_DetailPosts.Any()) { foreach (var mm in item.Nav_DetailPosts) { T_SK_RISK_IDENTIFY_DETAIL_RESULT_POST item2 = new T_SK_RISK_IDENTIFY_DETAIL_RESULT_POST(); item2.ORG_ID = entity.ORG_ID; item2.RISK_IDENTIFY_RESULT_DETAIL_ID = de.ID; item2.DEPARTMENT_TYPE = mm.DEPARTMENT_TYPE; item2.DEPARTMENT_ID = mm.DEPARTMENT_ID; postList.Add(item2); if (mm.Nav_ResultPostDets != null && mm.Nav_ResultPostDets.Any()) { foreach (var nn in mm.Nav_ResultPostDets) { T_SK_RISK_IDENTIFY_DETAIL_RESULT_POST_DETAIL item3 = new T_SK_RISK_IDENTIFY_DETAIL_RESULT_POST_DETAIL(); item3.ORG_ID = entity.ORG_ID; item3.RISK_IDENTIFY_DETAIL_RESULT_POST_ID = item2.ID; item3.POST_ID = nn.POST_ID; postDetailList.Add(item3); } } } } item.Nav_DetailPosts = null; detailList.Add(de); } } if (files != null && files.Any()) { foreach (var item in files) { item.ORG_ID = entity.ORG_ID; item.RISK_IDENTIFY_RESULT_ID = entity.ID; item.Nav_ImgFile = null; } } if (requires != null && requires.Any()) { foreach (var item in requires) { item.ORG_ID = entity.ORG_ID; item.RISK_IDENTIFY_RESULT_ID = entity.ID; item.Nav_Require = null; } } List notices = new List(); if (entity.PUBLISH != null && entity.PUBLISH.Equals("SaveAndNotify")) { var department = this.GetEntity(t => t.ID == entity.APPLY_DEPARTMENT_ID && t.ENABLE_STATUS == 0); var param = Enum.GetName(typeof(SKDepartmentTypeEnum), department.DEPARTMENT_TYPE); if (department.DEPARTMENT_STATUS == 2) { param = "公司级"; } entity.STATUS = PFStandardStatus.Approving; //取审批流水码 var sysFilter = new SystemCodeFilter(); sysFilter.CodeType = (int)PFCodeRuleType.审批流编码; sysFilter.Count = 1; sysFilter.OrgId = entity.ORG_ID; var codes = CodeRuleService.NewGenSerial(sysFilter); var serialCode = codes.Split(new char[] { ',' }); MFlowPermitService.InsertApprove(serialCode[0], "SK035", param, entity.ID, "SK035_SHOWPRINT", entity.TaskID, true, () => { if (deleteMeasureIds != null && deleteMeasureIds.Any()) this.BantchDeleteEntityNoCommit(deleteMeasureIds); if (deleteDepartIds != null && deleteDepartIds.Any()) this.BantchDeleteEntityNoCommit(deleteDepartIds); if (deletePostDetailIds != null && deletePostDetailIds.Any()) this.BantchDeleteEntityNoCommit(deletePostDetailIds); if (deletePostIds != null && deletePostIds.Any()) this.BantchDeleteEntityNoCommit(deletePostIds); if (deleteDetailIds != null && deleteDetailIds.Any()) this.BantchDeleteEntityNoCommit(deleteDetailIds); if (entity != null) UpdateEntityNoCommit(entity); if (detailList != null && detailList.Any()) BantchSaveEntityNoCommit(detailList); if (files != null && files.Any()) BantchSaveEntityNoCommit(files); if (requires != null && requires.Any()) BantchSaveEntityNoCommit(requires); if (measureList != null && measureList.Any()) BantchSaveEntityNoCommit(measureList); if (departList != null && departList.Any()) BantchSaveEntityNoCommit(departList); if (postList != null && postList.Any()) BantchSaveEntityNoCommit(postList); if (postDetailList != null && postDetailList.Any()) BantchSaveEntityNoCommit(postDetailList); }, null, null, null, null, null, "SK035_SHOWPRINT", null, "安全风险辨识结果表审批"); return true; } this.UnifiedCommit(() => { if (deleteMeasureIds != null && deleteMeasureIds.Any()) this.BantchDeleteEntityNoCommit(deleteMeasureIds); if (deleteDepartIds != null && deleteDepartIds.Any()) this.BantchDeleteEntityNoCommit(deleteDepartIds); if (deletePostDetailIds != null && deletePostDetailIds.Any()) this.BantchDeleteEntityNoCommit(deletePostDetailIds); if (deletePostIds != null && deletePostIds.Any()) this.BantchDeleteEntityNoCommit(deletePostIds); if (deleteDetailIds != null && deleteDetailIds.Any()) this.BantchDeleteEntityNoCommit(deleteDetailIds); if (entity != null) UpdateEntityNoCommit(entity); if (detailList != null && detailList.Any()) BantchSaveEntityNoCommit(detailList); if (files != null && files.Any()) BantchSaveEntityNoCommit(files); if (requires != null && requires.Any()) BantchSaveEntityNoCommit(requires); if (measureList != null && measureList.Any()) BantchSaveEntityNoCommit(measureList); if (departList != null && departList.Any()) BantchSaveEntityNoCommit(departList); if (postList != null && postList.Any()) BantchSaveEntityNoCommit(postList); if (postDetailList != null && postDetailList.Any()) BantchSaveEntityNoCommit(postDetailList); }); return true; }); } /// /// 获得单条实体数据 /// /// 过滤实体 /// [HttpPost, Route("SKGet")] public JsonActionResult SKGet([FromBody] KeywordFilter filter) { return SafeExecute(() => { var id = filter.FilterGroup.Rules.FirstOrDefault(t => t.Field == "ID").Value.ToString(); if (string.IsNullOrEmpty(id)) this.ThrowError("060010"); filter.IgnoreDataRule = true; var result = this.GetEntity(id, new string[] { "Nav_ApplyUser", "Nav_ApplyDepartment","Nav_Require", "Nav_Files.Nav_ImgFile","Nav_Requires.Nav_Require"}); if (result != null) { var details = this.GetEntities(t => t.RISK_IDENTIFY_RESULT_ID == result.ID, new BaseFilter(filter.OrgId), "Nav_Area", "Nav_Type", "Nav_RiskName", "Nav_ProductionUnit", "Nav_DetailMeasures", "Nav_DetailPosts.Nav_ResultPostDets.Nav_Post", "Nav_DetailPosts.Nav_Department"); result.Nav_Details = details.OrderBy(m => m.MineType).ThenBy(t => t.AREA_ID).ThenBy(x => x.TYPE_ID).ToList(); foreach (var d in result.Nav_Details) { d.Nav_DetailMeasures = d.Nav_DetailMeasures.OrderBy(t => t.NUM).ToList(); //foreach (var m in d.Nav_DetailMeasures) //{ // var temp = (m.NUM == null || m.NUM == 0) ? "1" : m.NUM + "、" + m.MEASURE + ";"; // d.MEASURE = d.MEASURE + temp; //} d.Nav_DetailPosts = d.Nav_DetailPosts.OrderBy(t => t.DEPARTMENT_TYPE).ToList(); var departTypes = d.Nav_DetailPosts.Select(t => t.DEPARTMENT_TYPE.GetDescription()).Distinct().ToList(); d.DEPARTMENT_TYPE = string.Join(",", departTypes); var departs = d.Nav_DetailPosts.Select(t => t.Nav_Department?.NAME).Distinct().ToList(); d.IDENTIFY_DEPARTMENT = string.Join(",", departs); var posts = d.Nav_DetailPosts.SelectMany(x=>x.Nav_ResultPostDets).Select(t => t.Nav_Post?.NAME).Distinct().ToList(); d.IDENTIFY_POST = string.Join(",", posts); } if (result.STATUS == PFStandardStatus.Rejected) { result.CONTEXT = ApproveCallBackService.RejectContent(result.ID); } } return result; }); } /// /// 回调函数 /// /// /// [HttpPost, Route("BackUpdateNew")] public JsonActionResult BackUpdateNew([FromBody] T_PF_APPROVE entity) { return SafeExecute(() => { return ApproveCallBackService.CallBackNew("SK/SKRiskIdentifyResult/BackUpdateNew", entity); }); } /// /// 驳回 /// /// /// [HttpPost, Route("RejectUpdate")] public JsonActionResult RejectUpdate([FromBody] T_PF_APPROVE model) { return SafeExecute(() => { //公共 获取审批流信息 T_PF_APPROVE modelApp = null; List listAppDetail = null; T_FM_NOTIFICATION_TASK taskFinish = null; string Msg = string.Empty; bool ResultGetInfo = ApproveCallBackService.GetApproject(model, ref modelApp, ref listAppDetail, ref taskFinish, ref Msg); if (!ResultGetInfo) throw new Exception("驳回失败!"); if (modelApp == null || listAppDetail == null) throw new Exception("获取驳回信息失败!"); var entity = this.GetEntity(model.DATA_ID, new string[] { "Nav_ApplyUser" }); entity.STATUS = PFStandardStatus.Rejected; T_FM_NOTIFICATION_TASK notice = new T_FM_NOTIFICATION_TASK(); if (entity.APPLY_USER_ID != null) { //发消息 notice = NotificationTaskService.InsertUserNoticeTaskModel("安全风险辨识结果表被驳回", entity.ID, entity.ORG_ID, (Guid)entity.APPLY_USER_ID, entity.Nav_ApplyUser?.NAME, DateTime.Now, DateTime.Now.AddHours(24), (int)FMNoticeTypeEnum.消息, "SK035"); } UnifiedCommit(() => { if (entity != null) this.UpdateEntityNoCommit(entity); if (notice != null) this.UpdateEntityNoCommit(notice); if (modelApp != null) UpdateEntityNoCommit(modelApp); if (listAppDetail != null && listAppDetail.Count > 0) BantchUpdateEntityNoCommit(listAppDetail); if (taskFinish != null) UpdateEntityNoCommit(taskFinish); }); return true; //return ApproveCallBackService.CallReject("HM/HMLicenseAnalysis/RejectUpdate", id); }); } /// /// 获得单条实体数据 /// /// 过滤实体 /// [HttpPost, Route("GetDetail")] public JsonActionResult GetDetail([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); return result; }); } } }