using APT.BaseData.Domain.Entities;
using APT.BaseData.Domain.Entities.FM;
using APT.BaseData.Domain.Entities.PF;
using APT.BaseData.Domain.Entities.T4;
using APT.BaseData.Domain.Enums;
using APT.BaseData.Domain.Enums.PF;
using APT.Infrastructure.Core;
using APT.MS.Domain.Entities.BS;
using APT.MS.Domain.Entities.SC;
using APT.MS.Domain.Enums;
using APT.Utility;
using Microsoft.AspNetCore.Mvc;
using NPOI.SS.Formula.Functions;
using System;
using System.Collections.Generic;
using System.Linq;
namespace APT.FM.WebApi.Controllers.Api
{
///
/// 待办
///
[Route("api/FM/FMNotificationTask")]
public partial class NotificationTaskController : AuthorizeApiController
{
///
/// 首页查询
///
///
///
[HttpPost, Route("HomeOrderPaged")]
public JsonActionResult HomeOrderPaged([FromBody] KeywordPageFilter pageFilter)
{
return SafeExecute(() =>
{
//首页待办增加数量统计字段
dynamic ret = new System.Dynamic.ExpandoObject();
var userId = APT.Infrastructure.Api.AppContext.CurrentSession.UserID;
string todayShortDate = DateTime.Now.ToDateString();
DateTime shortToday = Convert.ToDateTime(todayShortDate + " 00:00:00");
var result = new PagedActionResult();
if (pageFilter.Sort == "CODE")
{
pageFilter.Sort = "";
}
if (pageFilter.Parameter1.Equals("1") || pageFilter.Parameter1.Equals("3"))
{
DataOrder order1 = new DataOrder();
order1.Field = "NOTICE_STATUS";
order1.Order = DbOrder.ASC;
pageFilter.Orders.Add(order1);
}
DataOrder order2 = new DataOrder();
order2.Field = "TASK_STARTDT";
order2.Order = DbOrder.DESC;
pageFilter.Orders.Add(order2);
pageFilter.OrgId = null;
pageFilter.IgnoreOrgRule = true;
var bear = new BaseFilter();
bear.IgnoreOrgRule = true;
var todoCount = GetCount(s => s.USER_ID == userId && s.NOTICE_STATUS == 0 && s.NOTICE_TYPE != 2 && s.NOTICE_TYPE != 7 && s.TASK_ENDDT >= DateTime.Now.AddMonths(-3), bear);
var todayNewCount = GetCount(s => s.USER_ID == userId && s.NOTICE_STATUS == 0 && (s.NOTICE_TYPE == 2 || s.NOTICE_TYPE == 7), bear);//&& s.TASK_STARTDT > shortToday
var doneCount = GetCount(s => s.USER_ID == userId && (s.NOTICE_STATUS == 1 || s.NOTICE_STATUS == 2) && s.NOTICE_TYPE != 2 && s.NOTICE_TYPE != 7, bear);
var timeOverCount = 0;
if (DataHelper.GetRequestType(Request.Headers) == 2)
{
if (pageFilter.Parameter1.Equals("1") && todoCount > 0)
{
result = GetOrderPageEntities(s => s.USER_ID == userId && s.NOTICE_STATUS == 0 && s.NOTICE_TYPE != 2 && s.NOTICE_TYPE != 7 && s.TASK_ENDDT >= DateTime.Now.AddMonths(-3), pageFilter);
}
if (pageFilter.Parameter1.Equals("2"))
{
result = GetOrderPageEntities(s => s.USER_ID == userId && (s.NOTICE_STATUS == 1 || s.NOTICE_STATUS == 2) && s.NOTICE_TYPE != 2 && s.NOTICE_TYPE != 7, pageFilter);
}
if (pageFilter.Parameter1.Equals("3") && todayNewCount > 0)
{
result = GetOrderPageEntities(s => s.USER_ID == userId && (s.NOTICE_TYPE == 2 || s.NOTICE_TYPE == 7), pageFilter);//&& s.TASK_STARTDT > shortToday
}
}
else
{
timeOverCount = GetCount(s => s.USER_ID == userId && s.NOTICE_STATUS == 0 && s.TASK_ENDDT < DateTime.Now.AddMonths(-3) && s.NOTICE_TYPE != 2 && s.NOTICE_TYPE != 7, bear);
if (pageFilter.Parameter1.Equals("1"))
{
result = GetOrderPageEntities(s => s.USER_ID == userId && s.NOTICE_STATUS == 0 && s.NOTICE_TYPE != 2 && s.NOTICE_TYPE != 7 && s.TASK_ENDDT >= DateTime.Now.AddMonths(-3), pageFilter);
}
if (pageFilter.Parameter1.Equals("2"))
{
result = GetOrderPageEntities(s => s.USER_ID == userId && (s.NOTICE_STATUS == 1 || s.NOTICE_STATUS == 2) && s.NOTICE_TYPE != 2 && s.NOTICE_TYPE != 7, pageFilter);
}
if (pageFilter.Parameter1.Equals("4"))
{
result = GetOrderPageEntities(s => s.USER_ID == userId && s.NOTICE_STATUS == 0 && s.TASK_ENDDT < DateTime.Now.AddMonths(-3) && s.NOTICE_TYPE != 2 && s.NOTICE_TYPE != 7, pageFilter);
}
if (pageFilter.Parameter1.Equals("3"))
{
result = GetOrderPageEntities(s => s.USER_ID == userId && (s.NOTICE_TYPE == 2 || s.NOTICE_TYPE == 7), pageFilter);//&& s.TASK_STARTDT > shortToday
//if (temps != null && temps.Data != null && temps.Data.Any())
//{
// result.Data = new List();
// var tempFirsts = temps.Data.Where(t => t.NOTICE_STATUS == 0).ToList();
// result.Data.ToList().AddRange(tempFirsts);
// var tempSeconds = temps.Data.Where(t => t.NOTICE_STATUS == 3).ToList();
// result.Data.ToList().AddRange(tempSeconds);
// var tempOthers = temps.Data.Where(t => t.NOTICE_STATUS != 0 && t.NOTICE_STATUS != 3).OrderBy(m=>m.NOTICE_STATUS).ToList();
// result.Data.ToList().AddRange(tempOthers);
//}
}
}
if (result != null && result.Data != null && result.Data.Any())
{
var formCode = result.Data.Select(t => t.SOURCE_FORMCODE).Distinct().ToList();
//var forms = this.GetEntities(t => formCode.Contains(t.CODE), new BaseFilter(pageFilter.OrgId)).ToList();
var forms = this.GetEntities(t => formCode.Contains(t.CODE), bear).ToList();
result.Data.ForEach(t =>
{
var formNow = forms.FirstOrDefault(m => m.CODE == t.SOURCE_FORMCODE);
t.ICON = formNow != null ? formNow.ICON : "";
t.OVER_TIME = (t.TASK_ENDDT < DateTime.Now && t.NOTICE_STATUS == 0) ? "超期" : "正常";
});
ret.newData = result.Data.ToList();
}
else
{
ret.newData = new List();
}
//if (pageFilter.Parameter1.Equals("3"))
//{
// ret.newData = result.Data.OrderBy(m => m.NOTICE_STATUS).ThenByDescending(t => t.TASK_STARTDT).ToList();
//}
//else if (pageFilter.Parameter1.Equals("1"))
//{
// ret.newData = result.Data.OrderBy(m => m.NOTICE_STATUS).ThenByDescending(t => t.TASK_STARTDT).ToList();
//}
//else if (pageFilter.Parameter1.Equals("2"))
//{
// ret.newData = result.Data.OrderByDescending(m => m.TASK_STARTDT).ThenByDescending(t => t.TASK_DT).ToList();
//}
//else
//{
// ret.newData = result.Data.OrderByDescending(m => m.TASK_STARTDT).ToList();
//}
ret.todoCount = todoCount;
ret.doneCount = doneCount;
ret.todayNewCount = todayNewCount;
ret.timeOverCount = timeOverCount;
ret.TotalCount = result.TotalCount;
return ret;
});
}
///
/// 首页查询 app版本查询
///
///
///
[HttpPost, Route("UserNotificationCount")]
public JsonActionResult UserNotificationCount([FromBody] BaseFilter filter)
{
return SafeExecute(() =>
{
//首页待办增加数量统计字段
dynamic ret = new System.Dynamic.ExpandoObject();
var userId = APT.Infrastructure.Api.AppContext.CurrentSession.UserID;
string todayShortDate = DateTime.Now.ToDateString();
DateTime shortToday = Convert.ToDateTime(todayShortDate + " 00:00:00");
var result = new PagedActionResult();
var task = GetCount(s => s.USER_ID == userId && s.NOTICE_STATUS == 0 && s.NOTICE_TYPE != 2 && s.NOTICE_TYPE != 7, filter);
var msg = GetCount(s => s.USER_ID == userId && s.NOTICE_STATUS == 0 && (s.NOTICE_TYPE == 2 || s.NOTICE_TYPE == 7), filter);//&& s.TASK_STARTDT > shortToday
ret.Task = task;
ret.Msg = msg;
var appFilter = new BaseFilter();
appFilter.Order = DbOrder.DESC;
appFilter.Sort = "CREATE_TIME";
//查询指定租户
appFilter.SpecifyTenant = HeadHelper.HeadtelnetCode;
appFilter.IsSpecifyDb = true;
appFilter.IgnoreOrgRule = true;
var appVersion = this.GetEntity(null, appFilter, "Nav_Files.Nav_ImgFile");
if (appVersion != null)
{
ret.AppVersion = new
{
Code = appVersion.CODE,
Desc = appVersion.REMARK,
Time = appVersion.CREATE_TIME.Value.ToDateString(),
Upgrade = appVersion.UPGRADE,
Url = appVersion.Nav_Files.FirstOrDefault()?.Nav_ImgFile.FILE_PATH
};
}
return ret;
});
}
///
/// 状态更新为已办
///
///
[HttpPost, Route("ChangeStatus")]
public JsonActionResult ChangeStatus([FromBody] KeywordFilter filter)
{
return SafeExecute(() =>
{
if (!string.IsNullOrEmpty(filter.Keyword))
{
Guid TaskID = new Guid(filter.Keyword);
//查询消息表更新状态为已阅
var task = this.GetEntity(i => i.ID == TaskID, false);
if (task != null)
{
task.TASK_DT = DateTime.Now;
if (task.NOTICE_TYPE == (int)FMNoticeTypeEnum.今日提醒)
task.NOTICE_STATUS = FMNoticeStatusEnum.正常已办.GetInt();
else
{
if (task.TASK_DT > task.TASK_ENDDT)
task.NOTICE_STATUS = FMNoticeStatusEnum.超期办理.GetInt();
else
task.NOTICE_STATUS = FMNoticeStatusEnum.正常已办.GetInt();
}
}
UnifiedCommit(() =>
{
if (task != null)
this.UpdateEntityNoCommit(task);
});
}
return true;
});
}
///
/// 状态更新为已读
///
///
[HttpPost, Route("ChangeReadStatus")]
public JsonActionResult ChangeReadStatus([FromBody] KeywordFilter filter)
{
return SafeExecute(() =>
{
if (!string.IsNullOrEmpty(filter.Keyword))
{
Guid TaskID = new Guid(filter.Keyword);
//查询消息表更新状态为已阅
var task = this.GetEntity(i => i.ID == TaskID, false);
if (task != null)
{
task.TASK_DT = DateTime.Now;
task.NOTICE_STATUS = FMNoticeStatusEnum.已阅.GetInt();
}
UnifiedCommit(() =>
{
if (task != null)
this.UpdateEntityNoCommit(task);
});
}
return true;
});
}
///
/// 排序分页查询数据
///
/// 分页过滤实体
///
[HttpPost, Route("FullOrderPaged")]
public PagedActionResult FullOrderPaged([FromBody] KeywordPageFilter pageFilter)
{
var result = new PagedActionResult();
var loginUserId = APT.Infrastructure.Api.AppContext.CurrentSession.UserID;
var admiId = this.GetEntity(t => t.CODE == "admin")?.ID;
if (loginUserId == null || loginUserId == admiId)
{
DataOrder order2 = new DataOrder();
order2.Field = "TASK_STARTDT";
order2.Order = DbOrder.DESC;
pageFilter.Orders.Add(order2);
result = this.GetOrderPageEntities(t => t.NOTICE_STATUS == 0, pageFilter);
}
else
{
var loginDepartmentId = this.GetEntity(loginUserId.ToString())?.DEPARTMENT_ID;
if (loginDepartmentId != null)
{
var depart = this.GetEntity(loginDepartmentId.ToString());
if (depart.DEPARTMENT_TYPE == 2 && depart.USER_ID != loginUserId)
{
DataOrder order2 = new DataOrder();
order2.Field = "TASK_STARTDT";
order2.Order = DbOrder.DESC;
pageFilter.Orders.Add(order2);
result = this.GetOrderPageEntities(t => t.USER_ID == (Guid)loginUserId && t.NOTICE_STATUS == 0 && t.NOTICE_TYPE != 2, pageFilter);
}
else
{
List departmentId = new List();
departmentId.Add((Guid)loginDepartmentId);
List departmentIds = new List();
GetDepartmentId(departmentId, ref departmentIds);
if (departmentIds != null && departmentIds.Any())
{
DataOrder order1 = new DataOrder();
order1.Field = "USER_ID";
order1.Order = DbOrder.ASC;
pageFilter.Orders.Add(order1);
DataOrder order2 = new DataOrder();
order2.Field = "TASK_STARTDT";
order2.Order = DbOrder.DESC;
pageFilter.Orders.Add(order2);
var userIds = this.GetEntities(t => t.DEPARTMENT_ID != null && departmentIds.Contains((Guid)t.DEPARTMENT_ID), new BaseFilter(pageFilter.OrgId)).Select(m => m.ID).OrderBy(x => x == (Guid)loginUserId).ToList();
result = this.GetOrderPageEntities(t => userIds.Contains(t.USER_ID) && t.NOTICE_STATUS == 0 && t.NOTICE_TYPE != 2, pageFilter);
}
else
result.Data = null;
}
}
else
result.Data = null;
}
return result;
}
///
/// 归档
///
/// 对象实体
///
[HttpGet, Route("Archive")]
public JsonActionResult Archive(Guid id)
{
return base.SafeExecute(() =>
{
var ret = string.Empty;
//查询消息表更新状态为已阅
var task = this.GetEntity(i => i.ID == id, false);
if (task != null)
{
task.TASK_DT = DateTime.Now;
if (task.NOTICE_TYPE == (int)FMNoticeTypeEnum.今日提醒)
task.NOTICE_STATUS = FMNoticeStatusEnum.正常已办.GetInt();
else
{
if (task.TASK_DT > task.TASK_ENDDT)
task.NOTICE_STATUS = FMNoticeStatusEnum.超期办理.GetInt();
else
task.NOTICE_STATUS = FMNoticeStatusEnum.正常已办.GetInt();
}
}
var rejectInfo = this.GetEntity(t => t.FORM_CODE == task.SOURCE_FORMCODE);
if (rejectInfo != null)
ret = rejectInfo.ARCHIVE_INTERFACE;
else
this.ThrowError("020030");
UnifiedCommit(() =>
{
if (task != null)
this.UpdateEntityNoCommit(task);
});
return ret;
});
}
///
/// 转办
///
/// 参数
///
[HttpPost, Route("Complaint")]
public JsonActionResult Complaint([FromBody] KeywordFilter keywordFilter)
{
return base.SafeExecute(() =>
{
if (string.IsNullOrEmpty(keywordFilter.Keyword))
this.ThrowError("020005");
if (string.IsNullOrEmpty(keywordFilter.Parameter1))
this.ThrowError("020024");
Guid userID = Guid.Empty;
string userName = string.Empty;
try
{
userID = new Guid(keywordFilter.Parameter1);
}
catch
{
throw new Exception("获取人员信息有误!");
}
if (!APT.Infrastructure.Api.AppContext.CurrentSession.UserID.HasValue)
{
throw new Exception("获取操作人员信息有误!");
}
T_PF_APPROVE_DETAIL dbApproveDetail = null;
//添加转办记录
//T_PF_COMPLAINT_LOG complant = null; //wyw 表单 字段太少 太局限 采用系统日志表单
T_PF_SYS_LOG log = new T_PF_SYS_LOG();//日志
#region 系统日志基本信息 赋值
log.LOG_TYPE = (int)PFSysLogTypeEnum.TaskUserChange;//待办转办
log.ID = Guid.NewGuid();
log.ORG_ID = keywordFilter.OrgId;
log.USER_ID = APT.Infrastructure.Api.AppContext.CurrentSession.UserID.Value;
log.LOG_TIME = DateTime.Now;
#endregion
T_SC_MT_MEETING meeting = null;
var task = this.GetEntity(keywordFilter.Keyword);
T_BS_RISK_SUBMIT_CONTENT_DEAL contentDeal = null;
T_BS_RISK_SUBMIT_CONTENT content = null;
T_BS_SAFE_CHECK check = null;
T_BS_SAFE_CHECK_RECORD checkRecord = null;
IEnumerable listDetailUser = null;
if (task != null && task.SOURCE_DATA_ID.HasValue)
{
if (task.NOTICE_STATUS != 0)
{
throw new Exception("只有待办事项才能转办!");
}
if (task.USER_ID == userID)
{
throw new Exception("转办人与原代办人一致,操作失败!");
}
userName = this.GetEntity(t => t.ID == userID)?.NAME;
string LOG_DATA = string.Empty;
string EXT_DATA = string.Empty;
switch (task.SOURCE_FORMCODE)
{
case "PF119"://审批
#region 审批流节点人员 修改
var dbApprove = this.GetEntity(t => t.ID == task.SOURCE_DATA_ID, false, "Nav_ApproveDetails");
if (dbApprove != null && dbApprove.Nav_ApproveDetails.Any())
{
dbApproveDetail = dbApprove.Nav_ApproveDetails.FirstOrDefault(t => t.IS_CURRENT == true && t.APPROVE_USER_ID == task.USER_ID);
if (dbApproveDetail != null)
{
dbApproveDetail.APPROVE_USER_ID = Guid.Parse(keywordFilter.Parameter1);
//complant = new T_PF_COMPLAINT_LOG();
//complant.ORG_ID = keywordFilter.OrgId;
//complant.APPROVE_DETAIL_ID = dbApproveDetail.ID;
//complant.COMPLAINT_USER_ID = Guid.Parse(keywordFilter.Parameter1);
LOG_DATA = dbApproveDetail.ID.ToString();
EXT_DATA = userID.ToString();
}
}
#endregion
break;
case "SC028":
case "SC032":
#region 会议召开 记录人 简单做 直接修改
meeting = GetEntity(task.SOURCE_DATA_ID.Value);
meeting.USER_ID_ORIGINATOR = userID;
LOG_DATA = task.USER_ID.ToString() + " (" + task.USER_NAME + ") " + " => " + userID + "(" + userName + ")";
EXT_DATA = meeting.ID.ToString();
#endregion
break;
case "BS032":
#region 检查任务制定 修改 制定检查表的人
check = GetEntity(task.SOURCE_DATA_ID.Value);
if (check != null)
{
check.USERID_DOPLAN = userID;//部门不去改变
listDetailUser = GetEntities(e => e.SAFE_CHECK_ID == task.SOURCE_DATA_ID && e.USER_ID == task.USER_ID, null, null);
if (listDetailUser != null && listDetailUser.Any())
{
listDetailUser.ForEach(e => e.USER_ID = userID);
check.CheckUsers = check.CheckUsers.Replace(task.USER_NAME, userName);
}
}
LOG_DATA = task.USER_ID.ToString() + " (" + task.USER_NAME + ") " + " => " + userID + "(" + userName + ")";
EXT_DATA = task.SOURCE_DATA_ID.ToString();
//if (check.STATECHECK != STATECHECK.Draft && check.STATECHECK == STATECHECK.WaitForCheck)
//{
// throw new Exception("该检查记录不能转办(状态:" + check.STATECHECK.GetDescription() + ")!");
//}
#endregion
break;
case "BS032_SHOWPRINT":
#region //检查任务表确认 修改检查人
listDetailUser = GetEntities(e => e.SAFE_CHECK_ID == task.SOURCE_DATA_ID && e.USER_ID == task.USER_ID, null, null);
if (listDetailUser != null && listDetailUser.Any())
{
listDetailUser.ForEach(e => e.USER_ID = userID);
check = GetEntity(task.SOURCE_DATA_ID.Value);
check.CheckUsers = check.CheckUsers.Replace(task.USER_NAME, userName);
}
LOG_DATA = task.USER_ID.ToString() + " (" + task.USER_NAME + ") " + " => " + userID + "(" + userName + ")";
EXT_DATA = task.SOURCE_DATA_ID.ToString();
#endregion
break;
case "BS044":
#region 隐患整改单 同步修改 整改落实人
contentDeal = GetEntity(task.SOURCE_DATA_ID.Value);
contentDeal.ACTUAL_DEAL_USER_ID = userID;
contentDeal.MODIFY_TIME = DateTime.Now;
if (!contentDeal.RISK_SUBMIT_CONTENT_ID.HasValue)
{
throw new Exception("获取上报明细有误转办失败!");
}
content = GetEntity(contentDeal.RISK_SUBMIT_CONTENT_ID.Value);
content.ACTUAL_DEAL_USER_ID = userID;
content.MODIFY_TIME = DateTime.Now;
LOG_DATA = task.USER_ID.ToString() + " (" + task.USER_NAME + ") " + " => " + userID + "(" + userName + ")";
EXT_DATA = task.SOURCE_DATA_ID.ToString();
#endregion
break;
case "BS057":
#region 检查登记 修改检查明细 检查人 信息
listDetailUser = GetEntities(e => e.SAFE_CHECK_ID == task.SOURCE_DATA_ID && e.USER_ID == task.USER_ID && (!e.SAFECHECKSTATE.HasValue || e.SAFECHECKSTATE.Value != 80), null, null);//SAFECHECKSTATEEnum.Send
if (listDetailUser != null && listDetailUser.Any())
{
foreach (var item in listDetailUser)
{
item.USER_ID = userID;
}
check = GetEntity(task.SOURCE_DATA_ID.Value);
check.CheckUsers = check.CheckUsers.Replace(task.USER_NAME, userName);
}
LOG_DATA = task.USER_ID.ToString() + " (" + task.USER_NAME + ") " + " => " + userID + "(" + userName + ")";
EXT_DATA = task.SOURCE_DATA_ID.ToString();
#endregion
break;
case "BS034":
#region 检查确认
checkRecord = GetEntity(task.SOURCE_DATA_ID.Value);
checkRecord.USER_ID = userID;
listDetailUser = GetEntities(e => e.SAFE_CHECK_ID == checkRecord.SAFE_CHECK_ID && e.USER_ID == task.USER_ID && (!e.SAFECHECKSTATE.HasValue || e.SAFECHECKSTATE.Value != 80), null, null);//SAFECHECKSTATEEnum.Send
if (listDetailUser != null && listDetailUser.Any())
{
foreach (var item in listDetailUser)
{
item.USER_ID = userID;
}
check = GetEntity(checkRecord.SAFE_CHECK_ID.Value);
check.CheckUsers = check.CheckUsers.Replace(task.USER_NAME, userName);
}
LOG_DATA = task.USER_ID.ToString() + " (" + task.USER_NAME + ") " + " => " + userID + "(" + userName + ")";
EXT_DATA = task.SOURCE_DATA_ID.ToString();
#endregion
break;
case "BS074":
#region 整改责任人指定落实人 修改责任人
content = GetEntity(e => e.RISK_SUBMIT_NOTICE_PERSON_ID.HasValue && e.RISK_SUBMIT_NOTICE_PERSON_ID == task.SOURCE_DATA_ID.Value);
content.DEAL_USER_ID = userID;
content.MODIFY_TIME = DateTime.Now;
LOG_DATA = task.USER_ID.ToString() + " (" + task.USER_NAME + ") " + " => " + userID + "(" + userName + ")";
EXT_DATA = task.SOURCE_DATA_ID.ToString();
#endregion
break;
case "BS042_SHOWPRINT":
#region 验收人确认
content = GetEntity(e => e.RISK_SUBMIT_NOTICE_PERSON_ID.HasValue && e.RISK_SUBMIT_NOTICE_PERSON_ID == task.SOURCE_DATA_ID.Value);
content.CHECK_USER_ID = userID;
content.MODIFY_TIME = DateTime.Now;
LOG_DATA = task.USER_ID.ToString() + " (" + task.USER_NAME + ") " + " => " + userID + "(" + userName + ")";
EXT_DATA = task.SOURCE_DATA_ID.ToString();
#endregion
break;
case "BS042_ACTUALCHECK":
#region 整改落实人确认
content = GetEntity(e => e.RISK_SUBMIT_NOTICE_PERSON_ID.HasValue && e.RISK_SUBMIT_NOTICE_PERSON_ID == task.SOURCE_DATA_ID.Value);
content.ACTUAL_DEAL_USER_ID = userID;
content.MODIFY_TIME = DateTime.Now;
contentDeal = GetEntity(e => e.RISK_SUBMIT_CONTENT_ID == content.ID);
if (contentDeal != null)
contentDeal.ACTUAL_DEAL_USER_ID = userID;
LOG_DATA = task.USER_ID.ToString() + " (" + task.USER_NAME + ") " + " => " + userID + "(" + userName + ")";
EXT_DATA = task.SOURCE_DATA_ID.ToString();
#endregion
break;
case "BS044_CHECK":
#region 责任人确认整改 验收人确认整改
contentDeal = GetEntity(task.SOURCE_DATA_ID.Value);
content = GetEntity(contentDeal.RISK_SUBMIT_CONTENT_ID.Value);
if (contentDeal.DEAL_USER_ID == task.USER_ID)
{
contentDeal.DEAL_USER_ID = userID;
contentDeal.MODIFY_TIME = DateTime.Now;
content.DEAL_USER_ID = userID;
}
else if (contentDeal.CHECK_USER_ID == task.USER_ID)
{
contentDeal.CHECK_USER_ID = userID;
contentDeal.MODIFY_TIME = DateTime.Now;
content.CHECK_USER_ID = userID;
}
LOG_DATA = task.USER_ID.ToString() + " (" + task.USER_NAME + ") " + " => " + userID + "(" + userName + ")";
EXT_DATA = task.SOURCE_DATA_ID.ToString();
#endregion
break;
case "BS073"://手动隐患上报-指定责任单位
case "BS006"://隐患待上报 //可能不需要处理
//无需处理
LOG_DATA = task.USER_ID.ToString() + " (" + task.USER_NAME + ") " + " => " + userID + "(" + userName + ")";
EXT_DATA = task.SOURCE_DATA_ID.ToString();
break;
default:
break;
}
log.LOG_DATA = LOG_DATA;
log.EXT_DATA = EXT_DATA;
}
#region 日志待办 统一赋值
task.USER_ID = userID;
task.USER_NAME = userName;
task.MODIFY_TIME = DateTime.Now;
task.SENDTIME = DateTime.MinValue;
log.LOG_TITLE = task.SOURCE_FORMCODE;
#endregion
UnifiedCommit(() =>
{
if (task != null)
this.UpdateEntityNoCommit(task);
if (dbApproveDetail != null)
this.UpdateEntityNoCommit(dbApproveDetail);
if (log != null)
this.AddEntityNoCommit(log);
if (meeting != null)
this.UpdateEntityNoCommit(meeting);
if (check != null)
this.UpdateEntityNoCommit(check);
if (checkRecord != null)
this.UpdateEntityNoCommit(checkRecord);
if (contentDeal != null)
this.UpdateEntityNoCommit(contentDeal);
if (content != null)
this.UpdateEntityNoCommit(content);
if (listDetailUser != null)
this.BantchSaveEntityNoCommit(listDetailUser);
});
return true;
});
}
///
/// 返回所有下级部门节点
///
///
private void GetDepartmentId(List departmentId, ref List departmentIds)
{
var orgId = APT.Infrastructure.Api.AppContext.CurrentSession.OrgId;
departmentIds.AddRange(departmentId);
var department = GetEntities(t => t.PARENT_ID != null && departmentId.Contains((Guid)t.PARENT_ID), new BaseFilter(orgId));
if (department != null && department.Any())
{
var ids = department.Select(t => t.ID).ToList();
GetDepartmentId(ids, ref departmentIds);
}
}
}
}