mh_sms/APT.MicroApi/APT.SC.WebApi/Controllers/Api/CMController/CMEquipmentDemandSurveyController.cs

263 lines
13 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.Enums.PF;
using APT.BaseData.Domain.IServices;
using APT.BaseData.Domain.IServices.FM;
using APT.Infrastructure.Core;
using APT.MS.Domain.Entities.CM;
using APT.MS.Domain.Enums;
using APT.Utility;
using Microsoft.AspNetCore.Mvc;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Linq.Expressions;
namespace APT.SC.WebApi.Controllers.Api.CM
{
[Route("api/CM/CMEquipmentDemandSurvey")]
public class CMEquipmentDemandSurveyController : AuthorizeApiController<T_CM_EQUIPMENT_DEMAND_SURVEY>
{
IFMFlowPermitService MFlowPermitService { get; set; }
IPFApproveCallBackService ApproveCallBackService { get; set; }
IFMNotificationTaskService NotificationTaskService { get; set; }
IFMUserService UserService { get; set; }
public CMEquipmentDemandSurveyController(IFMFlowPermitService mFlowPermitService, IPFApproveCallBackService approveCallBackService, IFMNotificationTaskService notificationTaskService, IFMUserService userService)
{
MFlowPermitService = mFlowPermitService;
ApproveCallBackService = approveCallBackService;
NotificationTaskService = notificationTaskService;
UserService = userService;
}
/// <summary>
/// 应急装备需求调查表 修改
/// </summary>
/// <param name="entity"></param>
/// <returns></returns>
[HttpPost, Route("FullUpdate")]
public JsonActionResult<bool> FullUpdate([FromBody] T_CM_EQUIPMENT_DEMAND_SURVEY entity)
{
return SafeExecute<bool>(() =>
{
if (entity.USER_ID.HasValue && entity.USER_ID.Value != APT.Infrastructure.Api.AppContext.CurrentSession.UserID)
{
throw new Exception("您没有权限操作此表单!");
}
if (entity.END_TIME == DateTime.MinValue)
{
throw new Exception("请选择截止时间!");
}
if (entity.START_TIME > entity.END_TIME)
{
throw new Exception("截止时间不能小于发起时间!");
}
if (entity.Nav_ListDetail == null || !entity.Nav_ListDetail.Any())
{
throw new Exception("应急装备需求明细不能为空!");
}
T_FM_NOTIFICATION_TASK taskEnd = null;
if (entity.STATUS == PFStandardStatus.Sign)
{
if (entity.TaskID != Guid.Empty)
{
taskEnd = NotificationTaskService.GetEntityTask(entity.TaskID, "CM030_SHOWPRINT");
}
int RowIndex = 1;
foreach (var item in entity.Nav_ListDetail)
{
if (item.TYPE_ID == Guid.Empty)
{
throw new Exception("类型不能为空【行:" + RowIndex + "】!");
}
if (string.IsNullOrEmpty(item.MATERIAL_NAME))
{
throw new Exception("装备名称不能为空【行:" + RowIndex + "】!");
}
if (!item.AVAILABLE_COUNT.HasValue)
{
throw new Exception("请填写库内现有数量【行:" + RowIndex + "】!");
}
if (item.NEED_COUNT == 0)
{
throw new Exception("需求数量不能为空【行:" + RowIndex + "】!");
}
RowIndex++;
}
RowIndex = 1;
T_CM_EQUIPMENT_DEMAND_SURVEY_DETAIL check = null;
foreach (var item in entity.Nav_ListDetail)
{
check = entity.Nav_ListDetail.FirstOrDefault(e => e.TYPE_ID == item.TYPE_ID && e.LIBRARY_ID == item.LIBRARY_ID && e.ID != item.ID && !e.IS_DELETED);
if (check != null)
{
throw new Exception("【装备明细】装备名称不能重复【行:" + RowIndex + "】!");
}
RowIndex++;
}
}
var Files = entity.Nav_Files;
entity.Nav_Files = null;
var ListDetail = entity.Nav_ListDetail;
entity.Nav_ListDetail = null;
#region
T_CM_EQUIPMENT_DEMAND_SURVEY_MASTER modelSurveyMaster = null;
List<T_CM_EQUIPMENT_DEMAND_SURVEY_DETAIL> listSurveyDetail = null;
T_FM_NOTIFICATION_TASK taskSurveyMaster = null;
DateTime dtNow = DateTime.Now;
if (entity.STATUS == PFStandardStatus.Sign && dtNow <= entity.END_TIME)
{
var listSurveyCheck = GetEntities<T_CM_EQUIPMENT_DEMAND_SURVEY>(e => e.YEAR == dtNow.Year && !e.IS_DELETED && e.ID != entity.ID, null, null);
if (listSurveyCheck != null && listSurveyCheck.Any())
{
var check = listSurveyCheck.FirstOrDefault(e => e.STATUS == PFStandardStatus.Draft);
if (check == null)
{
var SurveyMaster = GetEntity<T_CM_EQUIPMENT_DEMAND_SURVEY_MASTER>(e => e.YEAR == dtNow.Year && !e.IS_DELETED);
if (SurveyMaster == null)
{
string Msg = string.Empty;
T_FM_USER userSafeMaster = null;
var configDate = GetEntity<T_CM_CONFIG>(e => e.ORG_ID == entity.ORG_ID);
if (configDate != null && configDate.DEPARTMENT_ID.HasValue && configDate.DEPARTMENT_ID.Value != Guid.Empty && configDate.POST_ID.HasValue && configDate.POST_ID.Value != Guid.Empty)
{
var listUser = UserService.GetDepPostUser(ref Msg, configDate.DEPARTMENT_ID.Value, configDate.POST_ID.Value, true);
if (listUser != null && listUser.Any())
userSafeMaster = listUser[0];
}
if (userSafeMaster == null)
userSafeMaster = UserService.GetRoleUser(ref Msg, "安环部负责人", null, null);
if (userSafeMaster != null)
{
modelSurveyMaster = new T_CM_EQUIPMENT_DEMAND_SURVEY_MASTER();
modelSurveyMaster.ID = Guid.NewGuid();
modelSurveyMaster.START_TIME = dtNow;
modelSurveyMaster.END_TIME = dtNow.AddDays(1);
modelSurveyMaster.USER_ID = userSafeMaster.ID;
modelSurveyMaster.YEAR = dtNow.Year;
modelSurveyMaster.STATUS = PFStandardStatus.Draft;
modelSurveyMaster.IS_DELETED = false;
modelSurveyMaster.ORG_ID = entity.ORG_ID;
//modelSurveyMaster.ENTITY_ORG_TPYE = ;
//modelSurveyMaster.FORM_ID = ;
//modelSurveyMaster.FLOW_STATUS = ;
//modelSurveyMaster.FLOW_SEND_STATUS = ;
//modelSurveyMaster.FLOW_ID = ;
modelSurveyMaster.CREATE_TIME = dtNow;
modelSurveyMaster.MODIFY_TIME = dtNow;
//modelSurveyMaster.CREATER_ID = ;
//modelSurveyMaster.MODIFIER_ID = ;
var listSurvey = GetEntities<T_CM_EQUIPMENT_DEMAND_SURVEY>(e => e.YEAR == dtNow.Year && e.STATUS == PFStandardStatus.Sign && !e.IS_DELETED, null, "Nav_ListDetail");
if (listSurvey != null && listSurvey.Any())
{
listSurveyDetail = new List<T_CM_EQUIPMENT_DEMAND_SURVEY_DETAIL>();
foreach (var item in listSurvey)
{
listSurveyDetail.AddRange(item.Nav_ListDetail);
}
foreach (var item in listSurveyDetail)
{
item.SURVEY_MASTER_ID = modelSurveyMaster.ID;
}
//本次操作的数据 修改
foreach (var item in ListDetail)
{
item.SURVEY_MASTER_ID = modelSurveyMaster.ID;
}
}
taskSurveyMaster = NotificationTaskService.InsertUserNoticeTaskModel("应急装备需求评估", modelSurveyMaster.ID, modelSurveyMaster.ORG_ID, modelSurveyMaster.USER_ID.Value, userSafeMaster.NAME, dtNow, dtNow.AddDays(1), 0, "CM032");
}
}
}
}
}
#endregion
this.UnifiedCommit(() =>
{
if (entity != null)
UpdateEntityNoCommit(entity);
if (Files != null && Files.Any())
BantchSaveEntityNoCommit(Files);
if (ListDetail != null && ListDetail.Any())
BantchSaveEntityNoCommit(ListDetail);
if (taskEnd != null)
UpdateEntityNoCommit(taskEnd);
if (modelSurveyMaster != null)//安环负责人评估
UpdateEntityNoCommit(modelSurveyMaster);
if (taskSurveyMaster != null)
UpdateEntityNoCommit(taskSurveyMaster);
if (listSurveyDetail != null && listSurveyDetail.Any())
BantchSaveEntityNoCommit(listSurveyDetail);
});
return true;
});
}
/// <summary>
///
/// </summary>
/// <param name="filter"></param>
/// <returns></returns>
[HttpPost, Route("GetOrder")]
public JsonActionResult<T_CM_EQUIPMENT_DEMAND_SURVEY> GetOrder([FromBody] KeywordFilter filter)
{
return SafeExecute(() =>
{
var SurveyMaster = GetEntity<T_CM_EQUIPMENT_DEMAND_SURVEY>(null, filter, null);
if (SurveyMaster.Nav_ListDetail != null && SurveyMaster.Nav_ListDetail.Any())
{
SurveyMaster.Nav_ListDetail = SurveyMaster.Nav_ListDetail.OrderBy(e => e.TYPE_ID).ThenBy(e => e.MATERIAL_NAME).ToList();
}
return SurveyMaster;
});
}
/// <summary>
/// 评估人员签到
/// </summary>
/// <param name="filter"></param>
/// <returns></returns>
[HttpPost, Route("Sign")]
public JsonActionResult<bool> Sign([FromBody] KeywordFilter filter)
{
return SafeExecute<bool>(() =>
{
////评估人员签到,所有评估人员签到后触发审批
Guid ID = new Guid(filter.Keyword);
var survey = GetEntity<T_CM_EQUIPMENT_DEMAND_SURVEY>(e => e.ID == ID);
survey.STATUS = PFStandardStatus.Approving;
Guid taskID = Guid.Empty;
if (!string.IsNullOrEmpty(filter.Parameter1))
taskID = new Guid(filter.Parameter1);
//给自己发送今日提醒
T_FM_NOTIFICATION_TASK taskRead = NotificationTaskService.InsertUserNoticeTaskModel("跟踪应急装备采买过程,购买后更新“应急物资库”的信息", ID, survey.ORG_ID, APT.Infrastructure.Api.AppContext.CurrentSession.UserID.Value, APT.Infrastructure.Api.AppContext.CurrentSession.UserName, DateTime.Now, DateTime.Now.AddDays(1), 2, "");
//结束 待办
T_FM_NOTIFICATION_TASK task = NotificationTaskService.GetEntityTask(taskID);
this.UnifiedCommit(() =>
{
if (survey != null)
UpdateEntityNoCommit(survey);
if (task != null)//代办消息 清除
UpdateEntityNoCommit(task);
if (taskRead != null)//今日提醒
UpdateEntityNoCommit(taskRead);
});
return true;
});
}
}
}