206 lines
11 KiB
C#
206 lines
11 KiB
C#
using APT.Infrastructure.Core;
|
|
using APT.MS.Domain.Entities.FO;
|
|
using APT.Utility;
|
|
using Google.Protobuf.Collections;
|
|
using Microsoft.AspNetCore.Mvc;
|
|
using System;
|
|
using System.Collections.Generic;
|
|
using System.Linq;
|
|
|
|
namespace APT.FO.WebApi.Controllers
|
|
{
|
|
/// <summary>
|
|
/// 领导带班下井记录
|
|
/// </summary>
|
|
[Route("api/FO/FOLeaderWellRecord")]
|
|
public partial class LeaderWellRecordController : AuthorizeApiController<T_FO_LEADER_WELL_RECORD>
|
|
{
|
|
|
|
[HttpPost, Route("GetEdit")]
|
|
public JsonActionResult<T_FO_LEADER_WELL_RECORD> GetEdit([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 entity = this.GetEntity<T_FO_LEADER_WELL_RECORD>(id, "Nav_ApplyUser", "Nav_Company", "Nav_ApplyDepartment", "Nav_ProductionUnit", "Nav_Class", "Nav_Users.Nav_User",
|
|
"Nav_Files.Nav_ImgFile.Nav_File");
|
|
if (entity != null)
|
|
{
|
|
var details = this.GetEntities<T_FO_LEADER_WELL_RECORD_DETAIL>(t => t.LEADER_WELL_RECORD_ID == entity.ID, new BaseFilter(entity.ORG_ID), "Nav_DetailFiles.Nav_ImgFile.Nav_File", "Nav_User", "Nav_PreUser", "Nav_AfterUser", "Nav_DetailAreas.Nav_Area").ToList();
|
|
entity.Nav_Details = details.OrderByDescending(t => t.START_DATE).ToList();
|
|
}
|
|
return entity;
|
|
});
|
|
}
|
|
/// <summary>
|
|
/// 新增修改
|
|
/// </summary>
|
|
/// <param name="entity"></param>
|
|
/// <returns></returns>
|
|
[HttpPost, Route("FullUpdate")]
|
|
public JsonActionResult<bool> FullUpdate([FromBody] T_FO_LEADER_WELL_RECORD entity)
|
|
{
|
|
return SafeExecute<bool>(() =>
|
|
{
|
|
var loginUserId = APT.Infrastructure.Api.AppContext.CurrentSession.UserID;
|
|
var departmentId = APT.Infrastructure.Api.AppContext.CurrentSession.DepartmentID;
|
|
entity.APPLY_USER_ID = loginUserId;
|
|
entity.APPLY_DEPARTMENT_ID = departmentId;
|
|
var details = entity.Nav_Details;
|
|
if (details != null && details.Any())
|
|
{
|
|
details = details.Where(t => !t.IS_DELETED).ToList();
|
|
}
|
|
entity.Nav_Details = null;
|
|
var userIds = this.GetEntities<T_FO_LEADER_WELL_RECORD_USER>(t => t.LEADER_WELL_RECORD_ID == entity.ID, new BaseFilter(entity.ORG_ID)).Select(m => m.ID).ToList();
|
|
var fileIds = this.GetEntities<T_FO_LEADER_WELL_RECORD_FILE>(t => t.LEADER_WELL_RECORD_ID == entity.ID, new BaseFilter(entity.ORG_ID)).Select(m => m.ID).ToList();
|
|
var detailIds = this.GetEntities<T_FO_LEADER_WELL_RECORD_DETAIL>(t => t.LEADER_WELL_RECORD_ID == entity.ID, new BaseFilter(entity.ORG_ID)).Select(m => m.ID).ToList();
|
|
var detailFileIds = this.GetEntities<T_FO_LEADER_WELL_RECORD_DETAIL_FILE>(t => detailIds.Contains(t.LEADER_WELL_RECORD_DETAIL_ID), new BaseFilter(entity.ORG_ID)).Select(m => m.ID).ToList();
|
|
var detailAreaIds = this.GetEntities<T_FO_LEADER_WELL_RECORD_DETAIL_AREA>(t => detailIds.Contains(t.LEADER_WELL_RECORD_DETAIL_ID), new BaseFilter(entity.ORG_ID)).Select(m => m.ID).ToList();
|
|
var detailPreUserIds = this.GetEntities<T_FO_LEADER_WELL_RECORD_DETAIL_PREUSER>(t => detailIds.Contains(t.LEADER_WELL_RECORD_DETAIL_ID), new BaseFilter(entity.ORG_ID)).Select(m => m.ID).ToList();
|
|
var detailAfterUserIds = this.GetEntities<T_FO_LEADER_WELL_RECORD_DETAIL_AFTERUSER>(t => detailIds.Contains(t.LEADER_WELL_RECORD_DETAIL_ID), new BaseFilter(entity.ORG_ID)).Select(m => m.ID).ToList();
|
|
var userList = new List<T_FO_LEADER_WELL_RECORD_USER>();
|
|
var fileList = new List<T_FO_LEADER_WELL_RECORD_FILE>();
|
|
var detailList = new List<T_FO_LEADER_WELL_RECORD_DETAIL>();
|
|
var detailFileList = new List<T_FO_LEADER_WELL_RECORD_DETAIL_FILE>();
|
|
var detailAreaList = new List<T_FO_LEADER_WELL_RECORD_DETAIL_AREA>();
|
|
var detailPreUserList = new List<T_FO_LEADER_WELL_RECORD_DETAIL_PREUSER>();
|
|
var detailAfterUserList = new List<T_FO_LEADER_WELL_RECORD_DETAIL_AFTERUSER>();
|
|
if (details != null && details.Any())
|
|
{
|
|
foreach (var item in details)
|
|
{
|
|
if (item.Nav_DetailFiles != null && item.Nav_DetailFiles.Any())
|
|
{
|
|
foreach (var item2 in item.Nav_DetailFiles)
|
|
{
|
|
item2.ORG_ID = entity.ORG_ID;
|
|
item2.LEADER_WELL_RECORD_DETAIL_ID = item.ID;
|
|
item2.Nav_ImgFile = null;
|
|
detailFileList.Add(item2);
|
|
}
|
|
}
|
|
if (item.Nav_DetailAreas != null && item.Nav_DetailAreas.Any())
|
|
{
|
|
foreach (var item2 in item.Nav_DetailAreas)
|
|
{
|
|
item2.ORG_ID = entity.ORG_ID;
|
|
item2.LEADER_WELL_RECORD_DETAIL_ID = item.ID;
|
|
item2.Nav_Area = null;
|
|
detailAreaList.Add(item2);
|
|
}
|
|
}
|
|
if (item.Nav_PreUsers != null && item.Nav_PreUsers.Any())
|
|
{
|
|
foreach (var item2 in item.Nav_PreUsers)
|
|
{
|
|
item2.ORG_ID = entity.ORG_ID;
|
|
item2.LEADER_WELL_RECORD_DETAIL_ID = item.ID;
|
|
item2.Nav_PreUser = null;
|
|
detailPreUserList.Add(item2);
|
|
}
|
|
}
|
|
if (item.Nav_AfterUsers != null && item.Nav_AfterUsers.Any())
|
|
{
|
|
foreach (var item2 in item.Nav_AfterUsers)
|
|
{
|
|
item2.ORG_ID = entity.ORG_ID;
|
|
item2.LEADER_WELL_RECORD_DETAIL_ID = item.ID;
|
|
item2.Nav_AfterUser = null;
|
|
detailAfterUserList.Add(item2);
|
|
}
|
|
}
|
|
item.ORG_ID = entity.ORG_ID;
|
|
item.LEADER_WELL_RECORD_ID = entity.ID;
|
|
item.Nav_DetailFiles = null;
|
|
detailList.Add(item);
|
|
}
|
|
}
|
|
var files = entity.Nav_Files;
|
|
if (files != null && files.Any())
|
|
{
|
|
files = files.Where(t => !t.IS_DELETED).ToList();
|
|
}
|
|
entity.Nav_Files = null;
|
|
if (files != null && files.Any())
|
|
{
|
|
foreach (var item in files)
|
|
{
|
|
item.ORG_ID = entity.ORG_ID;
|
|
item.LEADER_WELL_RECORD_ID = entity.ID;
|
|
item.Nav_ImgFile = null;
|
|
fileList.Add(item);
|
|
}
|
|
}
|
|
var users = entity.Nav_Users;
|
|
if (users != null && users.Any())
|
|
{
|
|
users = users.Where(t => !t.IS_DELETED).ToList();
|
|
}
|
|
entity.Nav_Users = null;
|
|
if (users != null && users.Any())
|
|
{
|
|
foreach (var item in users)
|
|
{
|
|
item.ORG_ID = entity.ORG_ID;
|
|
item.LEADER_WELL_RECORD_ID = entity.ID;
|
|
item.Nav_User = null;
|
|
userList.Add(item);
|
|
}
|
|
}
|
|
if (entity.PUBLISH != null && entity.PUBLISH.Equals("SaveAndNotify"))
|
|
{
|
|
if (entity.STATUS == MS.Domain.Enums.FOStatusEnum.Draft)
|
|
{
|
|
foreach (var user in users)
|
|
{
|
|
if (user.USER_ID == loginUserId)
|
|
{
|
|
user.DEAL_STATUS = MS.Domain.Enums.FOUserShiftStatusEnum.已处理;
|
|
}
|
|
}
|
|
var sendUserIds= users.Where(t=>t.USER_ID != loginUserId && t.USER_ID!=null).Select(m=>m.USER_ID).Distinct().ToList();
|
|
|
|
}
|
|
}
|
|
this.UnifiedCommit(() =>
|
|
{
|
|
if (detailPreUserIds != null && detailPreUserIds.Any())
|
|
this.BantchDeleteEntityNoCommit<T_FO_LEADER_WELL_RECORD_DETAIL_PREUSER>(detailPreUserIds);
|
|
if (detailAfterUserIds != null && detailAfterUserIds.Any())
|
|
this.BantchDeleteEntityNoCommit<T_FO_LEADER_WELL_RECORD_DETAIL_AFTERUSER>(detailAfterUserIds);
|
|
if (detailFileIds != null && detailFileIds.Any())
|
|
this.BantchDeleteEntityNoCommit<T_FO_LEADER_WELL_RECORD_DETAIL_FILE>(detailFileIds);
|
|
if (detailAreaIds != null && detailAreaIds.Any())
|
|
this.BantchDeleteEntityNoCommit<T_FO_LEADER_WELL_RECORD_DETAIL_AREA>(detailAreaIds);
|
|
if (detailIds != null && detailIds.Any())
|
|
this.BantchDeleteEntityNoCommit<T_FO_LEADER_WELL_RECORD_DETAIL>(detailIds);
|
|
if (fileIds != null && fileIds.Any())
|
|
this.BantchDeleteEntityNoCommit<T_FO_LEADER_WELL_RECORD_FILE>(fileIds);
|
|
if (userIds != null && userIds.Any())
|
|
this.BantchDeleteEntityNoCommit<T_FO_LEADER_WELL_RECORD_USER>(userIds);
|
|
if (entity != null)
|
|
UpdateEntityNoCommit(entity);
|
|
if (detailList != null && detailList.Any())
|
|
this.BantchSaveEntityNoCommit(detailList);
|
|
if (detailFileList != null && detailFileList.Any())
|
|
this.BantchSaveEntityNoCommit(detailFileList);
|
|
if (detailAreaList != null && detailAreaList.Any())
|
|
this.BantchSaveEntityNoCommit(detailAreaList);
|
|
if (detailPreUserList != null && detailPreUserList.Any())
|
|
this.BantchSaveEntityNoCommit(detailPreUserList);
|
|
if (detailAfterUserList != null && detailAfterUserList.Any())
|
|
this.BantchSaveEntityNoCommit(detailAfterUserList);
|
|
if (userList != null && userList.Any())
|
|
this.BantchSaveEntityNoCommit(userList);
|
|
if (fileList != null && fileList.Any())
|
|
this.BantchSaveEntityNoCommit(fileList);
|
|
});
|
|
return true;
|
|
});
|
|
}
|
|
}
|
|
}
|