mh_sms/APT.MicroApi/APT.BS.WebApi/Controllers/Api/BSRiskSubmitDelayApplyController.cs

793 lines
40 KiB
C#
Raw Normal View History

2024-04-12 16:50:28 +08:00
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.Infrastructure.Core;
using APT.MS.Domain.Entities.BS;
using APT.MS.Domain.Entities.HM;
using APT.MS.Domain.Entities.PF;
using APT.MS.Domain.Enums;
using APT.Utility;
using APT.WebApi.Models;
using Microsoft.AspNetCore.Mvc;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Linq.Expressions;
namespace APT.BS.WebApi.Controllers.Api
{
[Route("api/BS/BSRiskSubmitDelayApply")]
public partial class BSRiskSubmitDelayApplyController : AuthorizeApiController<T_BS_RISK_SUBMIT_DELAY_APPLY>
{
IFMFlowPermitService MFlowPermitService { get; set; }
IFMNotificationTaskService NotificationTaskService { get; set; }
IPFCodeRuleService CodeRuleService { get; set; }
IPFApproveCallBackService ApproveCallBackService { get; set; }
IFMDepartmentService DepartmentService { get; set; }
public BSRiskSubmitDelayApplyController(IFMNotificationTaskService notificationTaskService, IFMFlowPermitService mFlowPermitService, IPFCodeRuleService codeRuleService, IPFApproveCallBackService approveCallBackService, IFMDepartmentService departmentService)
{
NotificationTaskService = notificationTaskService;
MFlowPermitService = mFlowPermitService;
CodeRuleService = codeRuleService;
ApproveCallBackService = approveCallBackService;
DepartmentService = departmentService;
}
/// <summary>
/// 排序分页查询数据
/// </summary>
/// <param name="pageFilter">分页过滤实体</param>
/// <returns></returns>
[HttpPost, Route("OrderPagedSubContent")]
public PagedActionResult<T_BS_RISK_SUBMIT_CONTENT> OrderPagedArea([FromBody] KeywordPageFilter pageFilter)
{
return SafeGetPagedData<T_BS_RISK_SUBMIT_CONTENT>((result) =>
{
DateTime dtNowDate = DateTime.Now.Date;
Guid LoginID = APT.Infrastructure.Api.AppContext.CurrentSession.UserID.Value;
//今天 审批退回 可以申请延期
// 实际整改人是登录者 未删除 截止时间小与当前日期
//非延期申请 落实整改人已经查阅整改通知
//延期申请 已退回
Expression<Func<T_BS_RISK_SUBMIT_CONTENT, bool>> expression = e => e.ACTUAL_DEAL_USER_ID.HasValue && e.ACTUAL_DEAL_USER_ID == LoginID && !e.IS_DELETED && e.LastDateUser.HasValue && e.LastDateUser.Value >= dtNowDate
&& (((!e.ISBACK.HasValue || !e.ISBACK.Value) && e.RiskContentState == (int)RiskContentState.ActualDealCheck) || (e.ISBACK.HasValue && e.ISBACK.Value && e.RiskContentState == (int)RiskContentState.OKNotBack)
);
//Expression<Func<T_BS_RISK_SUBMIT_CONTENT, bool>> expression = e => e.ACTUAL_DEAL_USER_ID.HasValue && e.ACTUAL_DEAL_USER_ID == LoginID && !e.IS_DELETED;//测试数据
var info = this.GetEntities<T_BS_RISK_SUBMIT_CONTENT>(expression, null, new string[] { "Nav_UserActualDeal.Nav_Department", "Nav_Question" }).ToList();
result.TotalCount = info.Count;
result.Data = info.Skip((pageFilter.PageIndex - 1) * pageFilter.Limit).Take(pageFilter.Limit).OrderByDescending(e => e.CREATE_TIME).ToList<T_BS_RISK_SUBMIT_CONTENT>();
});
}
/// <summary>
/// 排序分页查询数据
/// </summary>
/// <param name="pageFilter">分页过滤实体</param>
/// <returns></returns>
[HttpPost, Route("OrderPagedNoticePerson")]
public PagedActionResult<T_BS_RISK_SUBMIT_NOTICE_PERSON> OrderPagedNoticePerson([FromBody] KeywordPageFilter pageFilter)
{
return SafeGetPagedData<T_BS_RISK_SUBMIT_NOTICE_PERSON>((result) =>
{
DateTime dtNowDate = DateTime.Now.Date;
Guid LoginID = APT.Infrastructure.Api.AppContext.CurrentSession.UserID.Value;
//今天 审批退回 可以申请延期
// 实际整改人是登录者 未删除 截止时间小与当前日期
//非延期申请 落实整改人已经查阅整改通知
//延期申请 已退回
//Expression<Func<T_BS_RISK_SUBMIT_CONTENT, bool>> expression = e => e.ACTUAL_DEAL_USER_ID.HasValue && e.ACTUAL_DEAL_USER_ID == LoginID && !e.IS_DELETED && e.LastDateUser.HasValue && e.LastDateUser.Value >= dtNowDate
//&& (((!e.ISBACK.HasValue || !e.ISBACK.Value) && e.RiskContentState == (int)RiskContentState.ActualDealCheck) || (e.ISBACK.HasValue && e.ISBACK.Value && e.RiskContentState == (int)RiskContentState.OKNotBack)
//);
//var info = this.GetEntities<T_BS_RISK_SUBMIT_CONTENT>(expression, null, new string[] { "Nav_SubmitNoticePerson" }).Select(e => new T_BS_RISK_SUBMIT_NOTICE_PERSON {ID = e.Nav_SubmitNoticePerson.ID,NAME= e.Nav_SubmitNoticePerson.NAME, QUESTION_LEVEL=e.Nav_SubmitNoticePerson.QUESTION_LEVEL }).Distinct().ToList<T_BS_RISK_SUBMIT_NOTICE_PERSON>().Distinct();
//result.TotalCount = info.Count();
//result.Data = info.Skip((pageFilter.PageIndex - 1) * pageFilter.Limit).Take(pageFilter.Limit).OrderByDescending(e => e.CREATE_TIME).ToList<T_BS_RISK_SUBMIT_NOTICE_PERSON>();
// Func<T_BS_RISK_SUBMIT_CONTENT, bool> expression = e => e.ACTUAL_DEAL_USER_ID.HasValue && e.ACTUAL_DEAL_USER_ID == LoginID && !e.IS_DELETED && e.LastDateUser.HasValue && e.LastDateUser.Value >= dtNowDate
//&& (((!e.ISBACK.HasValue || !e.ISBACK.Value) && e.RiskContentState == (int)RiskContentState.ActualDealCheck) || (e.ISBACK.HasValue && e.ISBACK.Value && e.RiskContentState == (int)RiskContentState.OKNotBack)
//);
pageFilter.IgnoreDataRule = true;
var info = GetEntities<T_BS_RISK_SUBMIT_NOTICE_PERSON>(e => e.Nav_ListRiskSubmitContent.FirstOrDefault(e => e.ACTUAL_DEAL_USER_ID.HasValue && e.ACTUAL_DEAL_USER_ID.Value == LoginID && !e.IS_DELETED && e.LastDateUser.HasValue && e.LastDateUser.Value >= dtNowDate && (e.RiskContentState == (int)RiskContentState.ActualDealCheck || e.RiskContentState == (int)RiskContentState.OKNotBack)) != null, pageFilter, new string[] { "Nav_ListRiskSubmitContent" }).Distinct();
result.TotalCount = info.Count();
result.Data = info.Skip((pageFilter.PageIndex - 1) * pageFilter.Limit).Take(pageFilter.Limit).OrderByDescending(e => e.CODE).ToList<T_BS_RISK_SUBMIT_NOTICE_PERSON>();
//app调用 添加显示
if (result.TotalCount > 0 && DataHelper.GetRequestType(Request.Headers) == 2)
{
result.Data.ForEach(e =>
{
if (e.QUESTION_LEVEL > 0)
{
e.QUESTION_LEVEL_SHOW = ((BSQuestionLevelEnum)e.QUESTION_LEVEL).GetDescription();
}
});
}
});
}
//public JsonActionResult<IEnumerable<T_BS_RISK_SUBMIT_DELAY_APPLY>> OrderEntities([FromBody] KeywordFilter filter)
//{
// return WitOrderEntities(null, filter);
//}
/// <summary>
/// 排序分页查询数据
/// </summary>
/// <param name="filter">分页过滤实体</param>
/// <returns></returns>
[HttpPost, Route("GetNoticePersonCanDelayContent")]
public PagedActionResult<T_BS_RISK_SUBMIT_DELAY_APPLY_DETAIL> GetNoticePersonCanDelayContent([FromBody] KeywordFilter filter)
{
return SafeGetPagedData<T_BS_RISK_SUBMIT_DELAY_APPLY_DETAIL>((result) =>
{
if (!string.IsNullOrEmpty(filter.Keyword))
{
//今天 审批退回 可以申请延期
Guid NoticePersonID = new Guid(filter.Keyword);
DateTime dtNowDate = DateTime.Now.Date;
Guid LoginID = APT.Infrastructure.Api.AppContext.CurrentSession.UserID.Value;
var info = GetEntities<T_BS_RISK_SUBMIT_CONTENT>(e => e.RISK_SUBMIT_NOTICE_PERSON_ID == NoticePersonID && e.ACTUAL_DEAL_USER_ID.HasValue && e.ACTUAL_DEAL_USER_ID.Value == LoginID && !e.IS_DELETED && e.LastDateUser.HasValue && e.LastDateUser.Value >= dtNowDate && (e.RiskContentState == (int)RiskContentState.ActualDealCheck || e.RiskContentState == (int)RiskContentState.OKNotBack), filter, null).ToList();
var listContID = info.Select(e => e.ID);
var listDelay = GetEntities<T_BS_RISK_SUBMIT_DELAY_APPLY_DETAIL>(e => listContID.Contains(e.Nav_SubmitContent.ID), null, new string[] { "Nav_SubmitContent" }).Select(e => e.Nav_SubmitContent);
List<Guid> listContentDelayID = new List<Guid>();
if (listDelay != null && listDelay.Count() > 0)
{
listContentDelayID.AddRange(listDelay.Select(e => e.ID));
}
List<T_BS_RISK_SUBMIT_DELAY_APPLY_DETAIL> listInfo = new List<T_BS_RISK_SUBMIT_DELAY_APPLY_DETAIL>();
for (int i = 0; i < info.Count; i++)
{
if (listContentDelayID.Count > 0)
{
if (listContentDelayID.Contains(info[i].ID))
{
continue;
}
}
T_BS_RISK_SUBMIT_DELAY_APPLY_DETAIL temp = new T_BS_RISK_SUBMIT_DELAY_APPLY_DETAIL();
temp.RISK_SUBMIT_CONTENT_ID = info[i].ID;
temp.RISK_SUBMIT_NOTICE_PERSON_ID = info[i].RISK_SUBMIT_NOTICE_PERSON_ID.Value;
temp.QUESTION_LEVEL = info[i].QUESTION_LEVEL;
temp.CHECK_QUESTION_ID = info[i].CHECK_QUESTION_ID.Value;
temp.LastDate = info[i].LastDateUser;
temp.Nav_SubmitContent = info[i];
listInfo.Add(temp);
}
result.Data = listInfo;
}
});
}
/// <summary>
/// 更新 审批流参考 EvaluvationPlanController AddFullUpdate
/// </summary>
/// <param name="entity"></param>
/// <returns></returns>
[HttpPost, Route("FullUpdate")]
public JsonActionResult<bool> FullUpdate([FromBody] T_BS_RISK_SUBMIT_DELAY_APPLY entity)
{
return SafeExecute<bool>(() =>
{
//参考的审批流 api / HM / HMEvaluationPlan/ AddFullUpdate
//审批信息必须有 后续可能自动匹配
//必须要有检查明细 每项的检查人员必须有2个或以上的人员
var listApply = entity.Nav_ListApplyDetail;
if (listApply == null || listApply.Count < 1)
{
throw new Exception("延期整改明细不能为空!");
}
var listApplyDetail = listApply.ToList().FindAll(x => !x.IS_DELETED);
if (listApplyDetail == null || listApplyDetail.Count < 1)
{
throw new Exception("延期整改明细不能为空!");
}
//var listApplyDetail = entity.Nav_ListApplyDetail.ToList();
entity.NAME = entity.NAME.Replace("隐患整改通知:", "");
List<Guid> listContentID = new List<Guid>();
int rowIndex = 1;
for (int i = listApplyDetail.Count - 1; i > -1; i--)
{
if (listApplyDetail[i].RISK_SUBMIT_DELAY_APPLY_ID == Guid.Empty && listApplyDetail[i].IS_DELETED)
{
listApplyDetail.Remove(listApplyDetail[i]);
}
}
if (listApplyDetail.Count < 1)
{
throw new Exception("延期整改明细不能为空!");
}
foreach (var item in listApplyDetail)
{
if (entity.OPERARTETYPE != (int)OperateType.Temp)
{
//if (string.IsNullOrEmpty(item.Nav_SubmitContent.DESCREPTION))
//{
// throw new Exception("行【" + rowIndex + "】检查问题描述不能为空!");
//}
if (item.RISK_SUBMIT_CONTENT_ID == Guid.Empty)
{
throw new Exception("行【" + rowIndex + "】检查问题描述不能为空!");
}
if (string.IsNullOrEmpty(item.REASON))
{
throw new Exception("行【" + rowIndex + "】延期理由不能为空!");
}
if (string.IsNullOrEmpty(item.TEMPDEMAND) && item.QUESTION_LEVEL == (int)BSQuestionLevelEnum.)
{
throw new Exception("行【" + rowIndex + "】重大隐患临时整改建议与措施不能为空!");
}
if (item.LastDateApply == null)
{
throw new Exception("行【" + rowIndex + "】延期后整改期限不能为空!");
}
else
{
item.LastDateApply = item.LastDateApply.Value.Date.AddDays(1).AddSeconds(-1);
}
if (item.LastDateApply < item.LastDate)
{
throw new Exception("行【" + rowIndex + "】申请延期整改期限不能小于整改期限!");
}
if (item.LastDateApply < DateTime.Now.Date)
{
throw new Exception("行【" + rowIndex + "】申请延期整改期限不能小于当前日期!");
}
}
item.LastDateApply = item.LastDateApply.Value.Date.AddDays(1).AddSeconds(-1);
item.RISK_SUBMIT_DELAY_APPLY_ID = entity.ID;
item.ORG_ID = entity.ORG_ID;
item.NAME = entity.NAME + rowIndex;
item.CODE = entity.CODE + "_" + rowIndex;
listContentID.Add(item.RISK_SUBMIT_CONTENT_ID);
rowIndex++;
}
entity.NAME = "延期申请:" + entity.NAME.Replace("延期申请:", "");
var listContent = GetEntities<T_BS_RISK_SUBMIT_CONTENT>(e => listContentID.Contains(e.ID), null, new string[] { "Nav_UserDeal", "Nav_DepartmentDeal" }).ToList();
foreach (var item in listContent)
{
if (item.LastDateUser < DateTime.Now.Date)
{
throw new Exception("该隐患已经超过整改期限,不能延期整改!");
}
}
//var content = GetEntity<T_BS_RISK_SUBMIT_CONTENT>(entity.RISK_SUBMIT_CONTENT_ID, new string[] { "Nav_UserDeal" });
//if (content.LastDateUser < DateTime.Now.Date)
//{
// throw new Exception("该隐患已经超过整改期限,不能延期整改!");
//}
//var modelCheck = GetEntity<T_BS_RISK_SUBMIT_DELAY_APPLY>(e => e.ID != entity.ID && e.RISK_SUBMIT_CONTENT_ID == entity.RISK_SUBMIT_CONTENT_ID);
//if (modelCheck != null)
//{
// if (modelCheck.APPROVE_ID == null)
// {
// throw new Exception("该隐患内容有延期申请草稿,请修改该草稿信息!");
// }
// else
// {
// throw new Exception("该隐患内容已经申请过延期,操作失败!");
// }
//}
//var listCheckDetail = GetEntities<T_BS_RISK_SUBMIT_DELAY_APPLY_DETAIL>(e => listContentID.Contains(e.RISK_SUBMIT_CONTENT_ID), null, new string[] { "Nav_SubmitContent", "Nav_Apply" });
//if (listCheckDetail != null && listCheckDetail.Count() > 0)
//{
// List<string> listName = new List<string>();
// foreach (var item in listCheckDetail)
// {
// listName.Add(item.Nav_SubmitContent.NAME);
// }
// throw new Exception(string.Join(',', listName) + "有申请记录!");
//}
Guid LoginID = APT.Infrastructure.Api.AppContext.CurrentSession.UserID.Value;
entity.Nav_ListApplyDetail = null;
entity.APPLY_DEPARTMENT_ID = GetEntity<T_FM_USER>(LoginID).DEPARTMENT_ID.Value;
entity.USER_ID = LoginID;
if (entity.OPERARTETYPE == (int)OperateType.Temp)
{
this.UnifiedCommit(() =>
{
//保存草稿
UpdateEntity(entity);
BantchSaveEntityNoCommit(listApplyDetail);//延期申请明细
});
}
else
{
//List<T_BS_RISK_SUBMIT_DELAY_APPLY_DETAIL> listDetail = entity.Nav_ListApplyDetail.ToList();
foreach (var item in listApplyDetail)
{
if (item.Nav_SubmitContent == null)
{
item.Nav_SubmitContent = GetEntity<T_BS_RISK_SUBMIT_CONTENT>(item.RISK_SUBMIT_CONTENT_ID);
}
if (item.Nav_SubmitContent.ACTUAL_DEAL_USER_ID != LoginID)
{
throw new Exception("操作失败,不允许操作他人的延期申请!");
}
}
////entity.CREATER_ID != APT.Infrastructure.Api.AppContext.CurrentSession.UserID.Value
//if (entity.Nav_SubmitContent.ACTUAL_DEAL_USER_ID != APT.Infrastructure.Api.AppContext.CurrentSession.UserID.Value)
//{
// throw new Exception("操作失败,不允许操作他人的延期申请!");
//}
//保存并通知
var sysFilter = new SystemCodeFilter();
sysFilter.CodeType = (int)PFCodeRuleType.;
sysFilter.Count = 1;
sysFilter.OrgId = entity.ORG_ID;
var serialCode = CodeRuleService.NewGenSerial(sysFilter);
string parms = string.Empty;
if (entity.QUESTION_LEVEL == 10 || entity.QUESTION_LEVEL == 20)
{
parms = entity.QUESTION_LEVEL.ToString();
}
else
{
parms = "30_40_50";
}
//延期申请 状态修改
foreach (var item in listContent)
{
item.RiskContentState = (int)RiskContentState.ReportedDelayApply;
}
Dictionary<int, T_FM_USER> dicApproveUser = new Dictionary<int, T_FM_USER>();//自定义审批流人员信息
Dictionary<int, Guid> dicApproveDepartMent = new Dictionary<int, Guid>();//自定义审批流人员所在部门
//1 整改责任人
//2 整改部门负责人 (隐患通知责任人所在部门级别的负责人)
//3 发起部门负责人
//var CreateUser = GetEntity<T_FM_USER>(listContent[0].CREATER_ID.Value, new string[] { "Nav_Department" });
var CreateUser = GetEntity<T_FM_USER>(LoginID, new string[] { "Nav_Department" });//发起部门 是延期整改发起部门?
dicApproveUser.Add(1, listContent[0].Nav_UserDeal);
dicApproveDepartMent.Add(2, listContent[0].Nav_DepartmentDeal.ID);
var userModelNotice = listContent[0].Nav_User;
if (userModelNotice == null)
{
userModelNotice = GetEntity<T_FM_USER>(listContent[0].USER_ID.Value);
}
var userModel = GetDepartMentLevelMaster(userModelNotice);//隐患通知责任人
if (userModel != null && !string.IsNullOrEmpty(userModel.NAME))
{
dicApproveUser.Add(3, userModel);//隐患通知责任人 所在的部门级别负责人
}
else
{
dicApproveUser.Add(3, userModelNotice);
}
entity.APPROVE_ID = Guid.NewGuid();
MFlowPermitService.InsertApprove(serialCode, "BS046", parms, entity.ID, "BS046_SHOWPRINT", entity.TaskID, true, () =>
{
if (entity != null)
UpdateEntityNoCommit(entity); //保存主表 NoCommit
//UpdateEntityNoCommit(content); //延期申请提交
BantchSaveEntityNoCommit(listApplyDetail);//延期申请明细
BantchSaveEntityNoCommit(listContent);//延期申请提交
}, entity.APPROVE_ID, null, dicApproveUser, dicApproveDepartMent, null, null, null, null, FMTASKTYPE.BS_RiskUp_DealApply);
}
return true;
});
}
/// <summary>
/// 获取人员所在部门级负责人
/// </summary>
/// <param name="modelUser"></param>
/// <returns></returns>
private T_FM_USER GetDepartMentLevelMaster(T_FM_USER modelUser)
{
T_FM_USER user = new T_FM_USER();
var modelDep = GetEntity<T_FM_DEPARTMENT>(modelUser.DEPARTMENT_ID.Value);
if (modelDep.DEPARTMENT_TYPE != (int)FMDepartmentType.)
{
do
{
modelDep = GetEntity<T_FM_DEPARTMENT>(e => e.ID == modelDep.PARENT_ID);
} while (modelDep.DEPARTMENT_TYPE != (int)FMDepartmentType. && modelDep.PARENT_ID.HasValue);
}
if (modelDep.DEPARTMENT_TYPE == (int)FMDepartmentType.)
{
var approveRol = GetEntity<T_PF_APPROVAL_ROLE>(e => e.DEPARTMENT_TYPE == (int)FMDepartmentType. && e.NAME.Contains("负责人"));
if (approveRol != null)
{
user = GetEntity<T_FM_USER>(e => e.APPROVE_ROLE_ID == approveRol.ID && e.DEPARTMENT_ID == modelDep.ID);
}
}
return user;
}
/// <summary>
/// 延期申请 完成 修改状态、最后完成时间 给验收人发送通知
/// api/BS/BSRiskSubmit/DealEnd
/// </summary>
/// <param name="id"></param>
/// <returns></returns>
[HttpGet, Route("DealEnd")]
public JsonActionResult<bool> DealEnd(string id)
{
return SafeExecute<bool>(() =>
{
return ApproveCallBackService.CallBack("BS/BSRiskSubmitDelayApply/DealEnd", id);
});
}
/// <summary>
/// 获得单条实体数据 (好像没用到)
/// </summary>
/// <param name="filter">过滤实体</param>
/// <returns></returns>
[HttpPost, Route("GetAll")]
public JsonActionResult<T_BS_RISK_SUBMIT_DELAY_APPLY> GetAll([FromBody] KeywordFilter filter)
{
return SafeExecute(() =>
{
var mobelResult = this.GetEntity<T_BS_RISK_SUBMIT_DELAY_APPLY>(null, filter);
if (mobelResult == null)
{
Guid ID = Guid.Empty;
var rules = filter.FilterGroup.Rules;
if (rules != null)
{
List<FilterRule> listRule = rules.ToList();
foreach (var item in listRule)
{
if (item.Field == "ID")
{
ID = new Guid(item.Value.ToString());
}
}
}
var modelTemp = this.GetEntity<T_BS_RISK_SUBMIT_CONTENT_DEAL>(ID, new string[] { "Nav_SubmitContent" });
if (modelTemp != null)
{
mobelResult = new T_BS_RISK_SUBMIT_DELAY_APPLY();
mobelResult.USER_ID = APT.Infrastructure.Api.AppContext.CurrentSession.UserID.Value;
mobelResult.QUESTION_LEVEL = modelTemp.QUESTION_LEVEL;
//mobelResult.LastDate = modelTemp.Nav_SubmitContent.LastDateUser;//1
mobelResult.RISK_SUBMIT_ID = modelTemp.RISK_SUBMIT_ID.Value;
mobelResult.RISK_SUBMIT_CONTENT_ID = modelTemp.RISK_SUBMIT_CONTENT_ID.Value;
//mobelResult.APPLY_DEPARTMENT_ID = APT.Infrastructure.Api.AppContext.CurrentSession.DepartmentID.Value;
//mobelResult.DEMAND= mobelTemp.
//mobelResult.LastDateApply=
}
}
else
{
//如果 状态为延期中
//并且 审核人 为登录者 审批时间为空
if (mobelResult.OPERARTETYPE == (int)OperateType.Check)
{
Guid LoginID = APT.Infrastructure.Api.AppContext.CurrentSession.UserID.Value;
var detail = mobelResult.Nav_ListApplyDetail;
if (detail.Count() > 0)
{
var detailLogin = detail.ToList().FindAll(e => e.Nav_SubmitContent.RiskContentState == (int)RiskContentState.ReportedDelay && e.CHCEKUSERID == LoginID && e.CHCEKTIME == null);
if (detailLogin != null && detailLogin.Count > 0)
{
mobelResult.Nav_ListApplyDetail = detailLogin;
}
}
}
else
{
if (mobelResult.Nav_Approve != null && mobelResult.Nav_Approve.Nav_ApproveDetails != null && mobelResult.Nav_Approve.Nav_ApproveDetails.Count() > 0)
{
mobelResult.Nav_Approve.Nav_ApproveDetails = mobelResult.Nav_Approve.Nav_ApproveDetails.OrderBy(e => e.NUM).ToList();
}
}
}
//QUESTION_LEVEL_SHOW
if (mobelResult != null && mobelResult.QUESTION_LEVEL > 0 && DataHelper.GetRequestType(Request.Headers) == 2)
{
try
{
mobelResult.QUESTION_LEVEL_SHOW = ((BSQuestionLevelEnum)mobelResult.QUESTION_LEVEL).GetDescription();
}
catch { }
}
return mobelResult;
});
}
/// <summary>
/// 整改落实人 确认整改通知单 系统发送整改单给整改落实人
/// </summary>
/// <param name="filter"></param>
/// <returns></returns>
[HttpPost, Route("CheckDetail")]
public JsonActionResult<bool> CheckDetail([FromBody] KeywordFilter filter)
{
return SafeExecute<bool>(() =>
{
var DataID = new Guid(filter.Keyword);
var TaskID = new Guid(filter.Parameter1);
List<string> listDetailID = filter.Parameter2.Split(',', StringSplitOptions.RemoveEmptyEntries).ToList();
List<Guid> listDetailGuid = new List<Guid>();
foreach (var item in listDetailID)
{
listDetailGuid.Add(new Guid(item));
}
Guid LoginID = APT.Infrastructure.Api.AppContext.CurrentSession.UserID.Value;
//var details = GetEntities<T_BS_RISK_SUBMIT_DELAY_APPLY_DETAIL>(e => e.RISK_SUBMIT_DELAY_APPLY_ID == DataID && !e.IS_DELETED && e.CHCEKUSERID == LoginID, null, null).ToList();
var details = GetEntities<T_BS_RISK_SUBMIT_DELAY_APPLY_DETAIL>(e => listDetailGuid.Contains(e.ID) && e.CHCEKTIME == null, null, null).ToList();
for (int i = 0; i < details.Count; i++)
{
details[i].CHCEKTIME = DateTime.Now; //设置审批时间
}
T_FM_NOTIFICATION_TASK task = this.GetEntity<T_FM_NOTIFICATION_TASK>(TaskID);
task.TASK_DT = DateTime.Now;
if (task.TASK_ENDDT >= task.TASK_DT)
task.NOTICE_STATUS = FMNoticeStatusEnum..GetInt();
else
task.NOTICE_STATUS = FMNoticeStatusEnum..GetInt();
this.UnifiedCommit(() =>
{
BantchUpdateEntityNoCommit(details);
if (task != null)//代办消息 清除
UpdateEntityNoCommit(task, "NOTICE_STATUS", "TASK_DT", "MODIFIER_ID");
});
return true;
});
}
/// <summary>
///
/// </summary>
/// <param name="ids"></param>
/// <returns></returns>
[HttpGet, Route("BatchDeleteFull")]
public JsonActionResult<bool> BatchDeleteFull(string ids)
{
return SafeExecute<bool>(() =>
{
if (string.IsNullOrEmpty(ids))
{
return false;
}
List<Guid> aryList = (from i in ids.Split(new char[1] { ',' }, StringSplitOptions.RemoveEmptyEntries) select new Guid(i)).ToList();
var applyDetail = GetEntities<T_BS_RISK_SUBMIT_DELAY_APPLY_DETAIL>(e => aryList.Contains(e.RISK_SUBMIT_DELAY_APPLY_ID), null, new string[] { "Nav_Apply.Nav_Approve.Nav_ApproveDetails", "Nav_SubmitContent" }).ToList();
if (applyDetail != null && applyDetail.Count > 0)
{
Guid loginID = APT.Infrastructure.Api.AppContext.CurrentSession.UserID.Value;
List<Guid> ids = applyDetail.Select(e => e.ID).ToList();
List<Guid> idsApply = new List<Guid>();//ApplyID
List<T_BS_RISK_SUBMIT_CONTENT> content = new List<T_BS_RISK_SUBMIT_CONTENT>();
//List<T_PF_APPROVE> listApprove = null;
List<Guid> listApproveId = new List<Guid>();
List<Guid> listApproveDetailId = new List<Guid>();
List<T_PF_APPROVE_DETAIL> approveDetail = new List<T_PF_APPROVE_DETAIL>();
for (int i = 0; i < applyDetail.Count; i++)
{
applyDetail[i].Nav_SubmitContent.RiskContentState = (int)RiskContentState.ActualDealCheck;
content.Add(applyDetail[i].Nav_SubmitContent);
if (!idsApply.Contains(applyDetail[i].Nav_Apply.ID))
{
idsApply.Add(applyDetail[i].Nav_Apply.ID);
if (applyDetail[i].Nav_Apply.CREATER_ID != loginID)
{
throw new Exception("只能删除自己的延期申请!");
}
listApproveId.Add(applyDetail[i].Nav_Apply.Nav_Approve.ID);
if (!applyDetail[i].Nav_Apply.Nav_Approve.Nav_ApproveDetails.OrderBy(e => e.NUM).ToList()[0].IS_CURRENT)
{
throw new Exception("只能删除未审批过的延期申请!");
}
listApproveDetailId.AddRange(applyDetail[i].Nav_Apply.Nav_Approve.Nav_ApproveDetails.Select(e => e.ID));
}
}
var listTask = GetEntities<T_FM_NOTIFICATION_TASK>(e => e.SOURCE_DATA_ID.HasValue && listApproveId.Contains(e.SOURCE_DATA_ID.Value), null, null);
this.UnifiedCommit(() =>
{
BantchDeleteEntityNoCommit<T_BS_RISK_SUBMIT_DELAY_APPLY_DETAIL>(ids); //删除延期申请明细
BantchDeleteEntityNoCommit<T_BS_RISK_SUBMIT_DELAY_APPLY>(idsApply);//删除延期申请单
BantchDeleteEntityNoCommit<T_PF_APPROVE>(listApproveId);
BantchDeleteEntityNoCommit<T_PF_APPROVE_DETAIL>(listApproveDetailId);
BantchDeleteEntityNoCommit<T_FM_NOTIFICATION_TASK>(listTask.Select(e => e.ID).ToList());
BantchUpdateEntityNoCommit(content);//修改状态
});
}
return true;
});
}
/// <summary>
/// 根据主键删除数据
/// </summary>
/// <param name="id">主键ID</param>
/// <returns></returns>
[HttpGet, Route("DeleteFull")]
public JsonActionResult<bool> DeleteFull(string id)
{
return SafeExecute<bool>(() =>
{
if (string.IsNullOrEmpty(id))
{
return false;
}
Guid ApplyID = new Guid(id);
var applyDetail = GetEntities<T_BS_RISK_SUBMIT_DELAY_APPLY_DETAIL>(e => e.RISK_SUBMIT_DELAY_APPLY_ID == ApplyID, null, new string[] { "Nav_Apply.Nav_Approve.Nav_ApproveDetails", "Nav_SubmitContent" }).ToList();
if (applyDetail != null && applyDetail.Count > 0)
{
if (applyDetail[0].Nav_Apply.CREATER_ID != APT.Infrastructure.Api.AppContext.CurrentSession.UserID)
{
throw new Exception("只能删除自己的延期申请!");
}
List<Guid> ids = applyDetail.Select(e => e.ID).ToList();
List<T_BS_RISK_SUBMIT_CONTENT> content = new List<T_BS_RISK_SUBMIT_CONTENT>();
for (int i = 0; i < applyDetail.Count; i++)
{
applyDetail[i].Nav_SubmitContent.RiskContentState = (int)RiskContentState.ActualDealCheck;
content.Add(applyDetail[i].Nav_SubmitContent);
}
var appDetail = applyDetail[0].Nav_Apply.Nav_Approve.Nav_ApproveDetails.OrderBy(e => e.NUM).ToList();
if (!appDetail[0].IS_CURRENT)
{
throw new Exception("该延期申请已经审批过,操作失败!");
}
List<Guid> listDetailID = appDetail.Select(e => e.ID).ToList();
var task = GetEntity<T_FM_NOTIFICATION_TASK>(e => e.SOURCE_DATA_ID.HasValue && e.SOURCE_DATA_ID == applyDetail[0].Nav_Apply.ID);
this.UnifiedCommit(() =>
{
BantchDeleteEntityNoCommit<T_BS_RISK_SUBMIT_DELAY_APPLY_DETAIL>(ids); //删除延期申请明细
DeleteEntityNoCommit(applyDetail[0].Nav_Apply);//删除延期申请单
DeleteEntityNoCommit(applyDetail[0].Nav_Apply.Nav_Approve);//审批流
BantchDeleteEntityNoCommit<T_PF_APPROVE_DETAIL>(listDetailID);//审批流明细
DeleteEntityNoCommit(task);//任务
BantchUpdateEntityNoCommit(content);//修改状态
});
}
return true;
});
}
/// <summary>
/// 延期申请
/// </summary>
/// <param name="pageFilter">分页过滤实体</param>
/// <returns></returns>
[HttpPost, Route("OrderPaged")]
public PagedActionResult<T_BS_RISK_SUBMIT_DELAY_APPLY> ContentDetailOrderPaged([FromBody] KeywordPageFilter pageFilter)
{
return SafeGetPagedData(delegate (PagedActionResult<T_BS_RISK_SUBMIT_DELAY_APPLY> result)
{
List<Guid> departmentIds = new List<Guid>() { APT.Infrastructure.Api.AppContext.CurrentSession.DepartmentID.Value };
DepartmentService.GetDepartmentIds(pageFilter.OrgId.Value, new List<Guid>() { APT.Infrastructure.Api.AppContext.CurrentSession.DepartmentID.Value }, ref departmentIds);
var loginID = APT.Infrastructure.Api.AppContext.CurrentSession.UserID.Value;
Expression<Func<T_BS_RISK_SUBMIT_DELAY_APPLY, bool>> expression = e => !e.IS_DELETED && (e.USER_ID == loginID || departmentIds.Contains(e.APPLY_DEPARTMENT_ID));
PagedActionResult<T_BS_RISK_SUBMIT_DELAY_APPLY> orderPageEntities = GetOrderPageEntities(expression, pageFilter, null);
result.Data = orderPageEntities.Data;
result.TotalCount = orderPageEntities.TotalCount;
});
}
/// <summary>
/// 延期申请 完成 修改状态、最后完成时间 给验收人发送通知
/// api/BS/BSRiskSubmit/DealEnd
/// </summary>
/// <param name="entity"></param>
/// <returns></returns>
[HttpPost, Route("DealEndNew")]
public JsonActionResult<bool> DealEndNew([FromBody] T_PF_APPROVE entity)
{
return SafeExecute<bool>(() =>
{
return ApproveCallBackService.CallBackNew("BS/BSRiskSubmitDelayApply/DealEndNew", entity);
});
}
/// <summary>
/// 延期整改申请 驳回
/// </summary>
/// <param name="entity"></param>
/// <returns></returns>
[HttpPost, Route("DealBack")]
public JsonActionResult<bool> DealBack([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;
bool ResultGetInfo = ApproveCallBackService.GetApproject(entity, ref modelApp, ref listAppDetail, ref taskFinish, ref Msg);
if (!ResultGetInfo)
throw new Exception("驳回失败!");
if (modelApp == null || listAppDetail == null)
throw new Exception("获取驳回信息失败!");
#region
T_BS_RISK_SUBMIT_DELAY_APPLY apply = GetEntity<T_BS_RISK_SUBMIT_DELAY_APPLY>(entity.DATA_ID, "Nav_User");
apply.OPERARTETYPE = (int)OperateType.Back;
#endregion
T_FM_NOTIFICATION_TASK taskBack = NotificationTaskService.InsertUserNoticeTaskModel("延期整改申请驳回", entity.DATA_ID, entity.ORG_ID, apply.USER_ID, apply.Nav_User.NAME, DateTime.Now, DateTime.Now.AddHours(12), (int)FMNoticeTypeEnum., "BS046");
UnifiedCommit(() =>
{
if (modelApp != null)
UpdateEntityNoCommit(modelApp);
if (listAppDetail != null && listAppDetail.Count > 0)
BantchUpdateEntityNoCommit(listAppDetail);
if (taskFinish != null)
UpdateEntityNoCommit(taskFinish);
if (taskBack != null)
UpdateEntityNoCommit(taskBack);
});
return true;
});
}
}
}