2025-10-21 14:59:38 +08:00
|
|
|
|
using APT.BaseData.Domain.Entities;
|
|
|
|
|
|
using APT.BaseData.Domain.Entities.FM;
|
2025-08-25 09:56:57 +08:00
|
|
|
|
using APT.BaseData.Domain.Enums;
|
2025-10-21 14:59:38 +08:00
|
|
|
|
using APT.BaseData.Domain.Enums.PF;
|
2025-08-25 09:56:57 +08:00
|
|
|
|
using APT.BaseData.Domain.IServices;
|
2025-10-21 14:59:38 +08:00
|
|
|
|
using APT.BaseData.Domain.IServices.FM;
|
2025-08-25 09:56:57 +08:00
|
|
|
|
using APT.Infrastructure.Core;
|
|
|
|
|
|
using APT.MS.Domain.Entities.SK;
|
|
|
|
|
|
using APT.MS.Domain.Enums;
|
2025-10-21 14:59:38 +08:00
|
|
|
|
using APT.MS.Domain.Enums.SK;
|
2025-08-25 09:56:57 +08:00
|
|
|
|
using APT.Utility;
|
|
|
|
|
|
using Microsoft.AspNetCore.Mvc;
|
2025-10-21 14:59:38 +08:00
|
|
|
|
using Microsoft.VisualStudio.Web.CodeGeneration.Utils;
|
|
|
|
|
|
using Newtonsoft.Json;
|
2025-08-25 09:56:57 +08:00
|
|
|
|
using NPOI.SS.Formula.Functions;
|
|
|
|
|
|
using System;
|
2025-10-21 14:59:38 +08:00
|
|
|
|
using System.Collections.Generic;
|
2025-08-25 09:56:57 +08:00
|
|
|
|
using System.Linq;
|
|
|
|
|
|
|
|
|
|
|
|
namespace APT.SK.WebApi.Controllers.Api
|
|
|
|
|
|
{
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 安全风险辨识结果表
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
[Route("api/SK/SKRiskIdentifyResult")]
|
|
|
|
|
|
public partial class RiskIdentifyResultController : AuthorizeApiController<T_SK_RISK_IDENTIFY_RESULT>
|
|
|
|
|
|
{
|
|
|
|
|
|
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<bool> FullUpdate([FromBody] T_SK_RISK_IDENTIFY_RESULT entity)
|
|
|
|
|
|
{
|
|
|
|
|
|
return SafeExecute<bool>(() =>
|
|
|
|
|
|
{
|
|
|
|
|
|
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_SK_RISK_IDENTIFY>(t => t.ID == entity.IDENTIFY_ID)?.IDENTIFY_EVALUATION_PLAN_ID;
|
|
|
|
|
|
var details = entity.Nav_Details;
|
2025-10-21 14:59:38 +08:00
|
|
|
|
entity.Nav_Details = null;
|
|
|
|
|
|
var requires = entity.Nav_Requires;
|
|
|
|
|
|
entity.Nav_Requires = null;
|
2025-08-25 09:56:57 +08:00
|
|
|
|
var files = entity.Nav_Files;
|
2025-09-22 23:22:38 +08:00
|
|
|
|
entity.Nav_Files = null;
|
|
|
|
|
|
entity.ApplyDepartmentName = this.GetEntity<T_FM_DEPARTMENT>(t => t.ID == departId).NAME;
|
|
|
|
|
|
entity.ApplyPostName = this.GetEntity<T_FM_USER>(t => t.ID == userId, "Nav_Person.Nav_Post")?.Nav_Person?.Nav_Post?.NAME;
|
2025-08-25 09:56:57 +08:00
|
|
|
|
List<Guid> deleteMeasureIds = new List<Guid>();
|
|
|
|
|
|
List<Guid> deleteDepartIds = new List<Guid>();
|
2025-12-08 02:44:59 +08:00
|
|
|
|
List<Guid> deletePostIds = new List<Guid>();
|
|
|
|
|
|
List<Guid> deletePostDetailIds = new List<Guid>();
|
|
|
|
|
|
List<Guid> deleteDetailIds = new List<Guid>();
|
|
|
|
|
|
List<T_SK_RISK_IDENTIFY_RESULT_DETAIL> detailList = new List<T_SK_RISK_IDENTIFY_RESULT_DETAIL>();
|
2025-08-25 09:56:57 +08:00
|
|
|
|
List<T_SK_RISK_IDENTIFY_DETAIL_RESULT_MEASURE> measureList = new List<T_SK_RISK_IDENTIFY_DETAIL_RESULT_MEASURE>();
|
|
|
|
|
|
List<T_SK_RISK_IDENTIFY_DETAIL_RESULT_DEPART> departList = new List<T_SK_RISK_IDENTIFY_DETAIL_RESULT_DEPART>();
|
2025-12-08 02:44:59 +08:00
|
|
|
|
List<T_SK_RISK_IDENTIFY_DETAIL_RESULT_POST> postList = new List<T_SK_RISK_IDENTIFY_DETAIL_RESULT_POST>();
|
|
|
|
|
|
List<T_SK_RISK_IDENTIFY_DETAIL_RESULT_POST_DETAIL> postDetailList = new List<T_SK_RISK_IDENTIFY_DETAIL_RESULT_POST_DETAIL>();
|
2025-08-25 09:56:57 +08:00
|
|
|
|
//更新标识字段
|
|
|
|
|
|
var record = this.GetEntity<T_SK_RISK_IDENTIFY_RESULT>(t => t.ID == entity.ID, "Nav_Details");
|
|
|
|
|
|
if (record != null && record.Nav_Details != null && record.Nav_Details.Any() && details != null && details.Any())
|
|
|
|
|
|
{
|
2025-09-20 13:03:07 +08:00
|
|
|
|
deleteDetailIds = record.Nav_Details.Select(t => t.ID).ToList();
|
|
|
|
|
|
deleteMeasureIds = this.GetEntities<T_SK_RISK_IDENTIFY_DETAIL_RESULT_MEASURE>(t => deleteDetailIds.Contains(t.RISK_IDENTIFY_RESULT_DETAIL_ID), new BaseFilter(entity.ORG_ID)).Select(t => t.ID).ToList();
|
|
|
|
|
|
deleteDepartIds = this.GetEntities<T_SK_RISK_IDENTIFY_DETAIL_RESULT_DEPART>(t => deleteDetailIds.Contains(t.RISK_IDENTIFY_RESULT_DETAIL_ID), new BaseFilter(entity.ORG_ID)).Select(t => t.ID).ToList();
|
2025-12-08 02:44:59 +08:00
|
|
|
|
deletePostIds = this.GetEntities<T_SK_RISK_IDENTIFY_DETAIL_RESULT_POST>(t => deleteDetailIds.Contains(t.RISK_IDENTIFY_RESULT_DETAIL_ID), new BaseFilter(entity.ORG_ID)).Select(t => t.ID).ToList();
|
|
|
|
|
|
deletePostDetailIds = this.GetEntities<T_SK_RISK_IDENTIFY_DETAIL_RESULT_POST_DETAIL>(t => deletePostIds.Contains(t.RISK_IDENTIFY_DETAIL_RESULT_POST_ID), new BaseFilter(entity.ORG_ID)).Select(t => t.ID).ToList();
|
2025-09-20 13:03:07 +08:00
|
|
|
|
//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);
|
|
|
|
|
|
//});
|
2025-08-25 09:56:57 +08:00
|
|
|
|
foreach (var item in details)
|
|
|
|
|
|
{
|
2025-10-22 17:55:59 +08:00
|
|
|
|
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.MEASURE == item.MEASURE
|
2025-11-13 14:41:40 +08:00
|
|
|
|
&& t.EMERGENCY == item.EMERGENCY && t.DEPARTMENT_TYPE == item.DEPARTMENT_TYPE && t.IDENTIFY_DEPARTMENT == item.IDENTIFY_DEPARTMENT && t.IDENTIFY_POST == item.IDENTIFY_POST && t.ENABLE_STATUS == item.ENABLE_STATUS);
|
2025-10-22 17:55:59 +08:00
|
|
|
|
if (temp == null && item.MARK != SKMarkEnum.Add)
|
2025-08-25 09:56:57 +08:00
|
|
|
|
{
|
2025-10-22 17:55:59 +08:00
|
|
|
|
item.MARK = SKMarkEnum.Update;
|
2025-08-25 09:56:57 +08:00
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
if (details != null && details.Any())
|
|
|
|
|
|
{
|
|
|
|
|
|
foreach (var item in details)
|
2025-12-08 02:44:59 +08:00
|
|
|
|
{
|
|
|
|
|
|
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;
|
2025-08-25 09:56:57 +08:00
|
|
|
|
if (item.Nav_DetailMeasures != null && item.Nav_DetailMeasures.Any())
|
|
|
|
|
|
{
|
2025-12-08 02:44:59 +08:00
|
|
|
|
foreach (var mm in item.Nav_DetailMeasures)
|
2025-08-25 09:56:57 +08:00
|
|
|
|
{
|
2025-12-08 02:44:59 +08:00
|
|
|
|
T_SK_RISK_IDENTIFY_DETAIL_RESULT_MEASURE item2 = new T_SK_RISK_IDENTIFY_DETAIL_RESULT_MEASURE();
|
2025-08-25 09:56:57 +08:00
|
|
|
|
item2.ORG_ID = entity.ORG_ID;
|
2025-12-08 02:44:59 +08:00
|
|
|
|
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;
|
2025-08-25 09:56:57 +08:00
|
|
|
|
}
|
|
|
|
|
|
}
|
2025-12-08 02:44:59 +08:00
|
|
|
|
detailList.Add(de);
|
2025-08-25 09:56:57 +08:00
|
|
|
|
item.Nav_DetailMeasures = null;
|
|
|
|
|
|
if (item.Nav_DetailDeparts != null && item.Nav_DetailDeparts.Any())
|
|
|
|
|
|
{
|
2025-12-08 02:44:59 +08:00
|
|
|
|
foreach (var mm in item.Nav_DetailDeparts)
|
2025-08-25 09:56:57 +08:00
|
|
|
|
{
|
2025-12-08 02:44:59 +08:00
|
|
|
|
T_SK_RISK_IDENTIFY_DETAIL_RESULT_DEPART item2 = new T_SK_RISK_IDENTIFY_DETAIL_RESULT_DEPART();
|
2025-08-25 09:56:57 +08:00
|
|
|
|
item2.ORG_ID = entity.ORG_ID;
|
2025-12-08 02:44:59 +08:00
|
|
|
|
item2.RISK_IDENTIFY_RESULT_DETAIL_ID = de.ID;
|
|
|
|
|
|
item2.DEPARTMENT_TYPE = mm.DEPARTMENT_TYPE;
|
|
|
|
|
|
item2.DEPARTMENT_ID = mm.DEPARTMENT_ID;
|
2025-08-25 09:56:57 +08:00
|
|
|
|
departList.Add(item2);
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
item.Nav_DetailDeparts = null;
|
|
|
|
|
|
if (item.Nav_DetailPosts != null && item.Nav_DetailPosts.Any())
|
|
|
|
|
|
{
|
2025-12-08 02:44:59 +08:00
|
|
|
|
foreach (var mm in item.Nav_DetailPosts)
|
2025-08-25 09:56:57 +08:00
|
|
|
|
{
|
2025-12-08 02:44:59 +08:00
|
|
|
|
T_SK_RISK_IDENTIFY_DETAIL_RESULT_POST item2 = new T_SK_RISK_IDENTIFY_DETAIL_RESULT_POST();
|
2025-08-25 09:56:57 +08:00
|
|
|
|
item2.ORG_ID = entity.ORG_ID;
|
2025-12-08 02:44:59 +08:00
|
|
|
|
item2.RISK_IDENTIFY_RESULT_DETAIL_ID = de.ID;
|
|
|
|
|
|
item2.DEPARTMENT_TYPE = mm.DEPARTMENT_TYPE;
|
|
|
|
|
|
item2.DEPARTMENT_ID = mm.DEPARTMENT_ID;
|
2025-08-25 09:56:57 +08:00
|
|
|
|
postList.Add(item2);
|
2025-12-08 02:44:59 +08:00
|
|
|
|
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);
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
2025-08-25 09:56:57 +08:00
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
item.Nav_DetailPosts = null;
|
2025-12-08 02:44:59 +08:00
|
|
|
|
detailList.Add(de);
|
2025-08-25 09:56:57 +08:00
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
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;
|
|
|
|
|
|
}
|
2025-10-21 14:59:38 +08:00
|
|
|
|
}
|
|
|
|
|
|
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;
|
|
|
|
|
|
}
|
2025-08-25 09:56:57 +08:00
|
|
|
|
}
|
|
|
|
|
|
List<T_FM_NOTIFICATION_TASK> notices = new List<T_FM_NOTIFICATION_TASK>();
|
|
|
|
|
|
if (entity.PUBLISH != null && entity.PUBLISH.Equals("SaveAndNotify"))
|
|
|
|
|
|
{
|
2025-11-25 20:32:25 +08:00
|
|
|
|
var department = this.GetEntity<T_FM_DEPARTMENT>(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 = "公司级";
|
|
|
|
|
|
}
|
2025-08-25 09:56:57 +08:00
|
|
|
|
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<T_SK_RISK_IDENTIFY_DETAIL_RESULT_MEASURE>(deleteMeasureIds);
|
|
|
|
|
|
if (deleteDepartIds != null && deleteDepartIds.Any())
|
2025-12-08 02:44:59 +08:00
|
|
|
|
this.BantchDeleteEntityNoCommit<T_SK_RISK_IDENTIFY_DETAIL_RESULT_DEPART>(deleteDepartIds);
|
|
|
|
|
|
if (deletePostDetailIds != null && deletePostDetailIds.Any())
|
|
|
|
|
|
this.BantchDeleteEntityNoCommit<T_SK_RISK_IDENTIFY_DETAIL_RESULT_POST_DETAIL>(deletePostDetailIds);
|
2025-08-25 09:56:57 +08:00
|
|
|
|
if (deletePostIds != null && deletePostIds.Any())
|
|
|
|
|
|
this.BantchDeleteEntityNoCommit<T_SK_RISK_IDENTIFY_DETAIL_RESULT_POST>(deletePostIds);
|
|
|
|
|
|
if (deleteDetailIds != null && deleteDetailIds.Any())
|
|
|
|
|
|
this.BantchDeleteEntityNoCommit<T_SK_RISK_IDENTIFY_RESULT_DETAIL>(deleteDetailIds);
|
|
|
|
|
|
if (entity != null)
|
|
|
|
|
|
UpdateEntityNoCommit(entity);
|
2025-12-08 02:44:59 +08:00
|
|
|
|
if (detailList != null && detailList.Any())
|
|
|
|
|
|
BantchSaveEntityNoCommit(detailList);
|
2025-08-25 09:56:57 +08:00
|
|
|
|
if (files != null && files.Any())
|
2025-10-21 14:59:38 +08:00
|
|
|
|
BantchSaveEntityNoCommit(files);
|
|
|
|
|
|
if (requires != null && requires.Any())
|
|
|
|
|
|
BantchSaveEntityNoCommit(requires);
|
2025-08-25 09:56:57 +08:00
|
|
|
|
if (measureList != null && measureList.Any())
|
|
|
|
|
|
BantchSaveEntityNoCommit(measureList);
|
|
|
|
|
|
if (departList != null && departList.Any())
|
|
|
|
|
|
BantchSaveEntityNoCommit(departList);
|
|
|
|
|
|
if (postList != null && postList.Any())
|
|
|
|
|
|
BantchSaveEntityNoCommit(postList);
|
2025-12-08 02:44:59 +08:00
|
|
|
|
if (postDetailList != null && postDetailList.Any())
|
|
|
|
|
|
BantchSaveEntityNoCommit(postDetailList);
|
2025-08-25 09:56:57 +08:00
|
|
|
|
}, null, null, null, null, null, "SK035_SHOWPRINT", null, "安全风险辨识结果表审批");
|
|
|
|
|
|
return true;
|
|
|
|
|
|
}
|
|
|
|
|
|
this.UnifiedCommit(() =>
|
|
|
|
|
|
{
|
|
|
|
|
|
if (deleteMeasureIds != null && deleteMeasureIds.Any())
|
|
|
|
|
|
this.BantchDeleteEntityNoCommit<T_SK_RISK_IDENTIFY_DETAIL_RESULT_MEASURE>(deleteMeasureIds);
|
|
|
|
|
|
if (deleteDepartIds != null && deleteDepartIds.Any())
|
2025-12-08 02:44:59 +08:00
|
|
|
|
this.BantchDeleteEntityNoCommit<T_SK_RISK_IDENTIFY_DETAIL_RESULT_DEPART>(deleteDepartIds);
|
|
|
|
|
|
if (deletePostDetailIds != null && deletePostDetailIds.Any())
|
|
|
|
|
|
this.BantchDeleteEntityNoCommit<T_SK_RISK_IDENTIFY_DETAIL_RESULT_POST_DETAIL>(deletePostDetailIds);
|
2025-08-25 09:56:57 +08:00
|
|
|
|
if (deletePostIds != null && deletePostIds.Any())
|
|
|
|
|
|
this.BantchDeleteEntityNoCommit<T_SK_RISK_IDENTIFY_DETAIL_RESULT_POST>(deletePostIds);
|
|
|
|
|
|
if (deleteDetailIds != null && deleteDetailIds.Any())
|
|
|
|
|
|
this.BantchDeleteEntityNoCommit<T_SK_RISK_IDENTIFY_RESULT_DETAIL>(deleteDetailIds);
|
|
|
|
|
|
if (entity != null)
|
|
|
|
|
|
UpdateEntityNoCommit(entity);
|
2025-12-08 02:44:59 +08:00
|
|
|
|
if (detailList != null && detailList.Any())
|
|
|
|
|
|
BantchSaveEntityNoCommit(detailList);
|
2025-08-25 09:56:57 +08:00
|
|
|
|
if (files != null && files.Any())
|
2025-10-21 14:59:38 +08:00
|
|
|
|
BantchSaveEntityNoCommit(files);
|
|
|
|
|
|
if (requires != null && requires.Any())
|
|
|
|
|
|
BantchSaveEntityNoCommit(requires);
|
2025-08-25 09:56:57 +08:00
|
|
|
|
if (measureList != null && measureList.Any())
|
|
|
|
|
|
BantchSaveEntityNoCommit(measureList);
|
|
|
|
|
|
if (departList != null && departList.Any())
|
|
|
|
|
|
BantchSaveEntityNoCommit(departList);
|
|
|
|
|
|
if (postList != null && postList.Any())
|
2025-12-08 02:44:59 +08:00
|
|
|
|
BantchSaveEntityNoCommit(postList);
|
|
|
|
|
|
if (postDetailList != null && postDetailList.Any())
|
|
|
|
|
|
BantchSaveEntityNoCommit(postDetailList);
|
2025-08-25 09:56:57 +08:00
|
|
|
|
});
|
|
|
|
|
|
return true;
|
|
|
|
|
|
});
|
|
|
|
|
|
}
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 获得单条实体数据
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
/// <param name="filter">过滤实体</param>
|
|
|
|
|
|
/// <returns></returns>
|
|
|
|
|
|
[HttpPost, Route("SKGet")]
|
|
|
|
|
|
public JsonActionResult<T_SK_RISK_IDENTIFY_RESULT> SKGet([FromBody] KeywordFilter filter)
|
|
|
|
|
|
{
|
|
|
|
|
|
return SafeExecute(() =>
|
|
|
|
|
|
{
|
|
|
|
|
|
var id = filter.FilterGroup.Rules.FirstOrDefault(t => t.Field == "ID").Value.ToString();
|
2025-09-20 13:03:07 +08:00
|
|
|
|
if (string.IsNullOrEmpty(id))
|
|
|
|
|
|
this.ThrowError("060010");
|
2025-08-25 09:56:57 +08:00
|
|
|
|
filter.IgnoreDataRule = true;
|
|
|
|
|
|
var result = this.GetEntity<T_SK_RISK_IDENTIFY_RESULT>(id, new string[] { "Nav_ApplyUser", "Nav_ApplyDepartment","Nav_Require",
|
2025-10-21 14:59:38 +08:00
|
|
|
|
"Nav_Files.Nav_ImgFile","Nav_Requires.Nav_Require"});
|
2025-08-25 09:56:57 +08:00
|
|
|
|
if (result != null)
|
|
|
|
|
|
{
|
2025-12-05 12:19:53 +08:00
|
|
|
|
var details = this.GetEntities<T_SK_RISK_IDENTIFY_RESULT_DETAIL>(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");
|
2025-12-05 16:38:55 +08:00
|
|
|
|
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();
|
2025-12-05 17:27:17 +08:00
|
|
|
|
//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;
|
|
|
|
|
|
//}
|
2025-12-05 16:38:55 +08:00
|
|
|
|
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);
|
|
|
|
|
|
}
|
2025-08-25 09:56:57 +08:00
|
|
|
|
if (result.STATUS == PFStandardStatus.Rejected)
|
|
|
|
|
|
{
|
|
|
|
|
|
result.CONTEXT = ApproveCallBackService.RejectContent(result.ID);
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
return result;
|
|
|
|
|
|
});
|
|
|
|
|
|
}
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 回调函数
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
/// <param name="id"></param>
|
|
|
|
|
|
/// <returns></returns>
|
|
|
|
|
|
[HttpPost, Route("BackUpdateNew")]
|
|
|
|
|
|
public JsonActionResult<bool> BackUpdateNew([FromBody] T_PF_APPROVE entity)
|
|
|
|
|
|
{
|
|
|
|
|
|
return SafeExecute(() =>
|
|
|
|
|
|
{
|
|
|
|
|
|
return ApproveCallBackService.CallBackNew("SK/SKRiskIdentifyResult/BackUpdateNew", entity);
|
|
|
|
|
|
});
|
|
|
|
|
|
}
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 驳回
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
/// <param name="id"></param>
|
|
|
|
|
|
/// <returns></returns>
|
|
|
|
|
|
[HttpPost, Route("RejectUpdate")]
|
|
|
|
|
|
public JsonActionResult<bool> RejectUpdate([FromBody] T_PF_APPROVE model)
|
|
|
|
|
|
{
|
|
|
|
|
|
return SafeExecute(() =>
|
|
|
|
|
|
{
|
|
|
|
|
|
//公共 获取审批流信息
|
|
|
|
|
|
T_PF_APPROVE modelApp = null;
|
|
|
|
|
|
List<T_PF_APPROVE_DETAIL> 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<T_SK_RISK_IDENTIFY_RESULT>(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);
|
|
|
|
|
|
});
|
|
|
|
|
|
}
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 获得单条实体数据
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
/// <param name="filter">过滤实体</param>
|
|
|
|
|
|
/// <returns></returns>
|
|
|
|
|
|
[HttpPost, Route("GetDetail")]
|
|
|
|
|
|
public JsonActionResult<T_SK_RISK_IDENTIFY_RESULT_DETAIL> 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<T_SK_RISK_IDENTIFY_RESULT_DETAIL>(id);
|
|
|
|
|
|
return result;
|
|
|
|
|
|
});
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|