mh_sms/APT.MicroApi/APT.HM.WebApi/Controllers/Api/RiskRecordController.cs
2024-05-24 14:20:41 +08:00

333 lines
17 KiB
C#

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.HM;
using APT.MS.Domain.Enums;
using APT.Utility;
using InfluxData.Net.InfluxDb.Models.Responses;
using Microsoft.AspNetCore.Mvc;
using System;
using System.Collections.Generic;
using System.Linq;
namespace APT.HM.WebApi.Controllers.Api
{
[Route("api/HM/HMRiskRecord")]
public partial class RiskRecordController : AuthorizeApiController<T_HM_RISK_RECORD>
{
IFMNotificationTaskService NotificationTaskService { get; set; }
IPFCodeRuleService CodeRuleService { get; set; }
IFMFlowPermitService MFlowPermitService { get; set; }
IPFApproveCallBackService ApproveCallBackService { get; set; }
/// <summary>
/// 作业任务分析
/// </summary>
public RiskRecordController(IPFCodeRuleService codeRuleService, IFMNotificationTaskService notificationTaskService, IFMFlowPermitService mFlowPermitService, IPFApproveCallBackService approveCallBackService)
{
NotificationTaskService = notificationTaskService;
CodeRuleService = codeRuleService;
MFlowPermitService = mFlowPermitService;
ApproveCallBackService = approveCallBackService;
}
/// <summary>
/// 更新
/// </summary>
/// <param name="entity"></param>
/// <returns></returns>
[HttpPost, Route("FullUpdate")]
public JsonActionResult<bool> FullUpdate([FromBody] T_HM_RISK_RECORD entity)
{
return SafeExecute<bool>(() =>
{
var details = entity.Nav_Details;
var allAreas = details.Select(t => t.AREA_ID);
var users = GetEntities<T_HM_RISK_RECORD_USER>(t => t.RECORD_ID == entity.ID && allAreas.Contains(t.AREA_ID), new BaseFilter(entity.ORG_ID));
var identifyings = entity.Nav_Identifyings;
var files = entity.Nav_Files;
entity.Nav_Users = null;
entity.Nav_Identifyings = null;
entity.Nav_Files = null;
entity.Nav_Details = null;
List<T_HM_RISK_RECORD_DETAIL_WORKDUTY> workdutys = new List<T_HM_RISK_RECORD_DETAIL_WORKDUTY>();
List<T_HM_RISK_RECORD_DETAIL_EQUIPMENT> equipments = new List<T_HM_RISK_RECORD_DETAIL_EQUIPMENT>();
List<T_HM_RISK_RECORD_DETAIL_FACILITIES> facilities = new List<T_HM_RISK_RECORD_DETAIL_FACILITIES>();
details.ForEach(detail =>
{
if (detail.Nav_EvaluateRiskRecordWorkduty != null)
{
workdutys.AddRange(detail.Nav_EvaluateRiskRecordWorkduty);
detail.Nav_EvaluateRiskRecordWorkduty = null;
}
if (detail.Nav_EvaluateRiskRecordEquipment != null)
{
equipments.AddRange(detail.Nav_EvaluateRiskRecordEquipment);
detail.Nav_EvaluateRiskRecordEquipment = null;
}
if (detail.Nav_EvaluateRiskRecordFacilities != null)
{
facilities.AddRange(detail.Nav_EvaluateRiskRecordFacilities);
detail.Nav_EvaluateRiskRecordFacilities = null;
}
if(detail.LIABLE_USER_ID == null)
{
var liableUser = GetEntity<T_FM_USER>(t => t.DEPARTMENT_ID == detail.DEPARTMENT_LIABLE_ID && t.APPROVE_ROLE_ID == detail.POST_LIABLE_ID);
if(liableUser != null)
{
detail.LIABLE_USER_ID=liableUser.ID;
}
else
{
throw new Exception("未能找到对应责任人!");
}
}
});
List<T_FM_NOTIFICATION_TASK> sendNotices = null;
T_FM_NOTIFICATION_TASK finishNotice = null;
if (entity.PUBLISH != null && entity.PUBLISH.Equals("SaveAndNotify"))
{
entity.STATUS = FOPreMeetingStatusEnum.;
var noticeTitles = new List<string>();
var noticeUserIds = new List<Guid>();
var noticeUserNames = new List<string>();
var noticeDataIds = new List<Guid>();
var userDeal = users.DistinctBy(t=>t.USER_ID).Where(t => t.DEAL_STATUS == FOUserShiftStatusEnum.);
if (userDeal.Count() > 0)
{
var allusers = GetEntities<T_FM_USER>(null, new BaseFilter(entity.ORG_ID));
//var allareas = GetEntities<T_HM_RISK_AREA>(null, new BaseFilter(entity.ORG_ID));
foreach (var user in userDeal)
{
if (user.DEAL_STATUS != FOUserShiftStatusEnum.)
{
var userName = allusers.Where(t => t.ID == user.USER_ID).FirstOrDefault();
//var userArea = allareas.Where(t => t.ID == user.AREA_ID).FirstOrDefault();
noticeUserIds.Add(user.USER_ID);
noticeUserNames.Add(userName.NAME);
noticeTitles.Add("危险源辨识记录待确认");
noticeDataIds.Add(entity.ID);
}
}
sendNotices = NotificationTaskService.InsertUserNoticeTaskModels(noticeTitles, noticeDataIds, entity.ORG_ID, noticeUserIds, noticeUserNames, DateTime.Now, DateTime.Parse(DateTime.Now.AddDays(1).ToShortDateString() + " 23:59:59"), 1, "HM063_SHOWPRINT");
finishNotice = NotificationTaskService.FOGetTaskFinishModel(entity.TaskID,entity.ID, "HM063_SHOWPRINT");
}
else
{
entity.STATUS = FOPreMeetingStatusEnum.;
entity.APPROVECODE = DateTime.Now.ToString("yyyyMMddHHmmss");
MFlowPermitService.InsertApprove(entity.APPROVECODE, "HM064", "", entity.ID, "HM063_SHOWPRINT", entity.TaskID, true, () =>
{
}, null, entity.NOTE_TAKER_ID,null,null,null, "HM063_SHOWPRINT");
}
}
this.UnifiedCommit(() =>
{
if (entity != null)
UpdateEntityNoCommit(entity); //保存主表
if (users != null && users.Any())
BantchSaveEntityNoCommit(users); //保存子表
if (identifyings != null && identifyings.Any())
BantchSaveEntityNoCommit(identifyings); //保存子表
if (files != null && files.Any())
BantchSaveEntityNoCommit(files); //保存子表
if (details != null && details.Any())
BantchSaveEntityNoCommit(details); //保存子表
if (workdutys != null && workdutys.Any())
BantchSaveEntityNoCommit(workdutys); //保存孙表
if (equipments != null && equipments.Any())
BantchSaveEntityNoCommit(equipments); //保存孙表
if (facilities != null && facilities.Any())
BantchSaveEntityNoCommit(facilities); //保存孙表
if (sendNotices != null && sendNotices.Any())
BantchSaveEntityNoCommit(sendNotices);
if (finishNotice != null)
UpdateEntityNoCommit(finishNotice);
});
return true;
});
}
/// <summary>
/// 获取个人的风险记录
/// </summary>
/// <param name="pageFilter"></param>
/// <returns></returns>
[HttpPost, Route("GetRiskRecord")]
public JsonActionResult<bool> GetRiskRecord([FromBody] T_HM_RISK_RECORD entity)
{
return SafeExecute<bool>(() =>
{
var model = GetEntity<T_HM_RISK_RECORD>(entity.ID.ToString());
//if (model.STATUS != FOPreMeetingStatusEnum.签到中)
// return false;
var orgId = APT.Infrastructure.Api.AppContext.CurrentSession.OrgId;
var userId = APT.Infrastructure.Api.AppContext.CurrentSession.UserID;
var count = GetCount<T_HM_RISK_RECORD_USER>(t => t.RECORD_ID == entity.ID && t.USER_ID == userId && t.DEAL_STATUS == 0, new BaseFilter());
if (count > 0) //该用户在该记录中是否参与且未同意则显示同意按钮
{
return true;
}
else
{
return false;
}
});
}
/// <summary>
/// 获得单条实体数据
/// </summary>
/// <param name="filter">过滤实体</param>
/// <returns></returns>
[HttpPost, Route("FullGet")]
public JsonActionResult<T_HM_RISK_RECORD> FullGet([FromBody] KeywordFilter filter)
{
if (filter.Parameter1 == null)
{
filter.Include = new string[] { "Nav_Request", "Nav_InitiatingDepartment",
"Nav_Identifyings.Nav_Identifying", "Nav_Files.Nav_ImgFile.Nav_File","Nav_NoteTaker"
};
}
var result = WitEntity(null, filter);
var ID = new Guid(filter.FilterGroup.Rules.ToList()[0].Value.ToString());
var filter1 = new BaseFilter(filter.GetOrgId());
filter1.SelectField = new string[] { "RECORD_ID","Nav_EvaluateRiskRecordEquipment.Nav_Equipment.NAME", "Nav_EvaluateRiskRecordWorkduty.Nav_Workduty.NAME", "Nav_Area.NAME", "Nav_Identifying.NAME", "Nav_Type.NAME", "Nav_OperationStep.NAME", "Nav_LiableUser.NAME", "Nav_DepartmentLiable.NAME", "Nav_PostLiable.NAME","RISK_NAME", "RISK_PLACE" };
var detailData = GetEntities<T_HM_RISK_RECORD_DETAIL>(t => t.RECORD_ID == ID, filter1);
var record = GetEntity<T_HM_RISK_RECORD>(ID);
var filter2 = new BaseFilter(filter.GetOrgId());
filter2.SelectField = new string[] { "Nav_Area.NAME","Nav_Users.Nav_User.NAME", "Nav_Users.DEAL_STATUS", "Nav_Users.Nav_User.Nav_UserSignFiles.Nav_ImgFile.Nav_File" };
var riskUsers = GetEntities<T_HM_RISK_TASK_DETAIL>(t => t.TASK_ID == record.TASK_ID && t.RECORD_USER_ID == record.NOTE_TAKER_ID,filter2);
List<T_HM_RISK_RECORD_USER> Nav_Users = new List<T_HM_RISK_RECORD_USER>();
result.Data.Nav_Users= Nav_Users;
foreach ( var riskUser in riskUsers)
{
var userNames = "";
List<T_FM_USER_SIGN_FILE> signfile = new List<T_FM_USER_SIGN_FILE>();
foreach (var user in riskUser.Nav_Users)
{
userNames += user.Nav_User.NAME+" ";
signfile= user.Nav_User.Nav_UserSignFiles;
}
T_HM_RISK_AREA area = new T_HM_RISK_AREA();
T_FM_USER fmuser = new T_FM_USER();
T_HM_RISK_RECORD_USER item =new T_HM_RISK_RECORD_USER()
{
Nav_Area = area,
Nav_User = fmuser,
};
item.Nav_Area.NAME = riskUser.Nav_Area.NAME;
item.Nav_User.NAME = userNames;
item.Nav_User.Nav_UserSignFiles = signfile;
item.DEAL_STATUS = FOUserShiftStatusEnum.;
result.Data.Nav_Users.Add(item);
}
result.Data.Nav_Details = detailData.ToList();
if (result.Data != null)
{
result.Data.Nav_Details = result.Data.Nav_Details.OrderBy(t => t.AREA_ID).ThenBy(n=>n.IDENTIFYING_ID).ThenBy(x=>x.TYPE_ID).ThenBy(c=>c.RISK_NAME).ToList();
}
return result;
}
/// <summary>
/// 同意
/// </summary>
/// <param name="id"></param>
/// <returns></returns>
[HttpPost, Route("PersonalAgree")]
public JsonActionResult<bool> PersonalAgree([FromBody] T_HM_RISK_RECORD entity)
{
return SafeExecute<bool>(() =>
{
var orgId = APT.Infrastructure.Api.AppContext.CurrentSession.OrgId;
var userId = APT.Infrastructure.Api.AppContext.CurrentSession.UserID;
var userAll = GetEntities<T_HM_RISK_RECORD_USER>(t => t.RECORD_ID == entity.ID, new BaseFilter(orgId));
var users = userAll.Where(t => t.USER_ID == userId);
foreach (var user in users)
{
user.DEAL_STATUS = FOUserShiftStatusEnum.;
}
var todoCount = userAll.Where(t => t.DEAL_STATUS == 0).Count();
#region
if (todoCount == 0)
{
var riskRecord = GetEntity<T_HM_RISK_RECORD>(entity.ID);
riskRecord.STATUS = FOPreMeetingStatusEnum.;
MFlowPermitService.InsertApprove(DateTime.Now.ToString("yyyyMMddHHmmss"), "HM064", "", entity.ID, "HM063_SHOWPRINT", entity.TaskID, true, () =>
{
UpdateEntityNoCommit(riskRecord, "STATUS");
if (users != null && users.Any())
BantchUpdateEntityNoCommit(users, "DEAL_STATUS");
}, null, userId);
}
else
{
NotificationTaskService.NotificationTaskFinish(entity.TaskID, () =>
{
if (users != null && users.Any())
BantchUpdateEntityNoCommit(users, "DEAL_STATUS");
});
}
#endregion
return true;
});
}
/// <summary>
/// 审批流回调
/// </summary>
/// <param name="id"></param>
/// <returns></returns>
[HttpGet, Route("PersonalApprove")]
public JsonActionResult<bool> PersonalApprove(string id)
{
return SafeExecute<bool>(() =>
{
return ApproveCallBackService.CallBack("HM/HMRiskRecord/PersonalApprove", id);
});
}
/// <summary>
/// 审批流回调
/// </summary>
/// <param name="id"></param>
/// <returns></returns>
[HttpPost, Route("RejectUpdate")]
public JsonActionResult<bool> RejectUpdate([FromBody] T_PF_APPROVE entity)
{
return SafeExecute<bool>(() =>
{
T_PF_APPROVE modelApp = null;
List<T_PF_APPROVE_DETAIL> listAppDetail = null;
T_FM_NOTIFICATION_TASK taskFinish = null;
string Msg = string.Empty;
var record = GetEntity<T_HM_RISK_RECORD>(entity.DATA_ID, new string[] { "Nav_NoteTaker" });
var recordUsers = GetEntities<T_HM_RISK_RECORD_USER>(t => t.RECORD_ID == entity.DATA_ID && t.USER_ID != record.NOTE_TAKER_ID, new BaseFilter(record.ORG_ID));
bool ResultGetInfo = ApproveCallBackService.GetApproject(entity, ref modelApp, ref listAppDetail, ref taskFinish, ref Msg);
if (!ResultGetInfo)
throw new Exception("驳回失败!");
foreach (var user in recordUsers)
{
user.DEAL_STATUS = 0;
}
record.STATUS = FOPreMeetingStatusEnum.;
var sendNotice = NotificationTaskService.InsertUserNoticeTaskModel("风险源辨识记录-驳回", entity.DATA_ID, record.ORG_ID, (Guid)record.NOTE_TAKER_ID, record.Nav_NoteTaker.NAME, DateTime.Now, DateTime.Now.AddHours(24), 0, "HM064");
UnifiedCommit(() =>
{
if (record != null)
UpdateEntityNoCommit(record); //保存主表
if (sendNotice != null)
AddEntityNoCommit(sendNotice);
if (recordUsers.Any())
BantchSaveEntityNoCommit(recordUsers);
});
return true;
});
}
}
}