302 lines
12 KiB
C#
302 lines
12 KiB
C#
|
|
using System;
|
|||
|
|
using Model;
|
|||
|
|
using System.Collections.Generic;
|
|||
|
|
using System.Linq;
|
|||
|
|
|
|||
|
|
namespace BLL
|
|||
|
|
{
|
|||
|
|
/// <summary>
|
|||
|
|
/// 企业级检查主表服务
|
|||
|
|
/// </summary>
|
|||
|
|
public static class UnitHazardRegisterService
|
|||
|
|
{
|
|||
|
|
#region Fields
|
|||
|
|
|
|||
|
|
public static Dictionary<string, int> StateMap = new Dictionary<string, int>
|
|||
|
|
{
|
|||
|
|
{ "待提交" ,(int)StateInt.待提交},
|
|||
|
|
{ "待整改" ,(int)StateInt.待整改},
|
|||
|
|
{ "部分整改" ,(int)StateInt.部分整改},
|
|||
|
|
{ "已闭环" ,(int)StateInt.已闭环},
|
|||
|
|
};
|
|||
|
|
|
|||
|
|
#endregion Fields
|
|||
|
|
|
|||
|
|
#region Enums
|
|||
|
|
|
|||
|
|
public enum StateInt : int
|
|||
|
|
{
|
|||
|
|
待提交 = 0,
|
|||
|
|
待整改= 1,
|
|||
|
|
部分整改 = 2,
|
|||
|
|
已闭环 = 3,
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
#endregion Enums
|
|||
|
|
|
|||
|
|
#region Methods
|
|||
|
|
|
|||
|
|
/// <summary>
|
|||
|
|
/// 添加企业级检查记录
|
|||
|
|
/// </summary>
|
|||
|
|
/// <param name="register">企业级检查记录</param>
|
|||
|
|
public static void AddUnitHazardRegister(Model.Supervise_UnitHazardRegister register)
|
|||
|
|
{
|
|||
|
|
using (Model.SGGLDB db = new Model.SGGLDB(Funs.ConnString))
|
|||
|
|
{
|
|||
|
|
Model.Supervise_UnitHazardRegister newRegister = new Model.Supervise_UnitHazardRegister
|
|||
|
|
{
|
|||
|
|
UnitHazardRegisterId = register.UnitHazardRegisterId,
|
|||
|
|
UnitHazardRegisterCode = register.UnitHazardRegisterCode,
|
|||
|
|
CheckDate = register.CheckDate,
|
|||
|
|
CheckMainType = register.CheckMainType,
|
|||
|
|
CheckType = register.CheckType,
|
|||
|
|
ProjectId = register.ProjectId,
|
|||
|
|
CheckUnitId = register.CheckUnitId,
|
|||
|
|
CheckTeam = register.CheckTeam,
|
|||
|
|
CheckManIds = register.CheckManIds,
|
|||
|
|
CheckManNames = register.CheckManNames,
|
|||
|
|
InsResponsibleUserId = register.InsResponsibleUserId,
|
|||
|
|
EvaluationResult = register.EvaluationResult,
|
|||
|
|
AttachUrl = register.AttachUrl,
|
|||
|
|
States = register.States??0,
|
|||
|
|
CompileMan = register.CompileMan,
|
|||
|
|
CreateDate = DateTime.Now
|
|||
|
|
};
|
|||
|
|
db.Supervise_UnitHazardRegister.InsertOnSubmit(newRegister);
|
|||
|
|
db.SubmitChanges();
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
public static string ConvertState(int state)
|
|||
|
|
{
|
|||
|
|
string result = string.Empty;
|
|||
|
|
result = StateMap.First(c => c.Value == state).Key;
|
|||
|
|
return result;
|
|||
|
|
}
|
|||
|
|
/// <summary>
|
|||
|
|
/// 删除企业级检查记录
|
|||
|
|
/// </summary>
|
|||
|
|
/// <param name="registerId">检查记录ID</param>
|
|||
|
|
public static void DeleteUnitHazardRegisterById(string registerId)
|
|||
|
|
{
|
|||
|
|
using (Model.SGGLDB db = new Model.SGGLDB(Funs.ConnString))
|
|||
|
|
{
|
|||
|
|
var register = db.Supervise_UnitHazardRegister.FirstOrDefault(e => e.UnitHazardRegisterId == registerId);
|
|||
|
|
if (register != null)
|
|||
|
|
{
|
|||
|
|
// 删除附件
|
|||
|
|
if (!string.IsNullOrEmpty(register.AttachUrl))
|
|||
|
|
{
|
|||
|
|
BLL.UploadFileService.DeleteFile(Funs.RootPath, register.AttachUrl);
|
|||
|
|
}
|
|||
|
|
// 删除编码记录
|
|||
|
|
BLL.CodeRecordsService.DeleteCodeRecordsByDataId(registerId);
|
|||
|
|
// 删除附件
|
|||
|
|
BLL.CommonService.DeleteAttachFileById(registerId);
|
|||
|
|
// 删除流程
|
|||
|
|
BLL.CommonService.DeleteFlowOperateByID(registerId);
|
|||
|
|
|
|||
|
|
db.Supervise_UnitHazardRegister.DeleteOnSubmit(register);
|
|||
|
|
db.SubmitChanges();
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
/// <summary>
|
|||
|
|
/// 根据项目和时间段获取检查数量
|
|||
|
|
/// </summary>
|
|||
|
|
/// <param name="projectId">项目ID</param>
|
|||
|
|
/// <param name="startTime">开始时间</param>
|
|||
|
|
/// <param name="endTime">结束时间</param>
|
|||
|
|
/// <returns>检查数量</returns>
|
|||
|
|
public static int GetCount(string projectId, DateTime startTime, DateTime endTime)
|
|||
|
|
{
|
|||
|
|
return (from x in Funs.DB.Supervise_UnitHazardRegister
|
|||
|
|
where x.ProjectId == projectId && x.CheckDate >= startTime && x.CheckDate <= endTime
|
|||
|
|
select x).Count();
|
|||
|
|
}
|
|||
|
|
public static int GetCount(string checkMainType)
|
|||
|
|
{
|
|||
|
|
return (from x in Funs.DB.Supervise_UnitHazardRegister
|
|||
|
|
where x.CheckMainType ==checkMainType
|
|||
|
|
select x.UnitHazardRegisterId).Count();
|
|||
|
|
}
|
|||
|
|
/// <summary>
|
|||
|
|
/// 根据ID获取企业级检查记录
|
|||
|
|
/// </summary>
|
|||
|
|
/// <param name="registerId">检查记录ID</param>
|
|||
|
|
/// <returns>企业级检查记录</returns>
|
|||
|
|
public static Model.Supervise_UnitHazardRegister GetUnitHazardRegisterById(string registerId)
|
|||
|
|
{
|
|||
|
|
return Funs.DB.Supervise_UnitHazardRegister.FirstOrDefault(e => e.UnitHazardRegisterId == registerId);
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
/// <summary>
|
|||
|
|
/// 判断是否可以删除检查记录
|
|||
|
|
/// </summary>
|
|||
|
|
/// <param name="registerId">检查记录ID</param>
|
|||
|
|
/// <returns>true=可以删除,false=不能删除</returns>
|
|||
|
|
public static bool CanDeleteRegister(string registerId)
|
|||
|
|
{
|
|||
|
|
var register = GetUnitHazardRegisterById(registerId);
|
|||
|
|
if (register == null)
|
|||
|
|
{
|
|||
|
|
return false;
|
|||
|
|
}
|
|||
|
|
// 只有"待提交"状态可以删除,其他状态不能删除
|
|||
|
|
return register.States <= (int)StateInt.待提交;
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
/// <summary>
|
|||
|
|
/// 获取企业级检查列表(使用input对象,返回总数)
|
|||
|
|
/// </summary>
|
|||
|
|
/// <param name="input">查询条件</param>
|
|||
|
|
/// <param name="pageIndex">页码(从0开始)</param>
|
|||
|
|
/// <param name="pageSize">每页大小</param>
|
|||
|
|
/// <param name="returnAll">是否返回所有数据(不分页)</param>
|
|||
|
|
/// <param name="totalCount">总记录数</param>
|
|||
|
|
/// <returns>检查记录列表</returns>
|
|||
|
|
public static List<UnitHazardRegisterOutput> GetUnitHazardRegisters(
|
|||
|
|
UnitHazardRegisterInput input,
|
|||
|
|
int pageIndex,
|
|||
|
|
int pageSize,
|
|||
|
|
bool returnAll,
|
|||
|
|
out int totalCount)
|
|||
|
|
{
|
|||
|
|
var db = Funs.DB;
|
|||
|
|
// 使用JOIN一次性获取所有数据,解决N+1查询问题
|
|||
|
|
var query = from x in db.Supervise_UnitHazardRegister
|
|||
|
|
join ct in db.Base_SuperviseCheckType
|
|||
|
|
on new { MainType = x.CheckMainType, TypeCode = x.CheckType }
|
|||
|
|
equals new { MainType = ct.CheckMainType, TypeCode = ct.CheckTypeCode } into ctGroup
|
|||
|
|
from ct in ctGroup.DefaultIfEmpty()
|
|||
|
|
join u in db.Base_Unit
|
|||
|
|
on x.CheckUnitId equals u.UnitId into uGroup
|
|||
|
|
from u in uGroup.DefaultIfEmpty()
|
|||
|
|
join p in db.Base_Project on x.ProjectId equals p.ProjectId into pGroup
|
|||
|
|
from p in pGroup.DefaultIfEmpty()
|
|||
|
|
select new UnitHazardRegisterOutput
|
|||
|
|
{
|
|||
|
|
UnitHazardRegisterId = x.UnitHazardRegisterId,
|
|||
|
|
UnitHazardRegisterCode = x.UnitHazardRegisterCode,
|
|||
|
|
CheckDate = x.CheckDate,
|
|||
|
|
ProjectId = x.ProjectId,
|
|||
|
|
CheckMainTypeName = x.CheckMainType == "0" ? "安全" : "质量",
|
|||
|
|
CheckType = x.CheckType,
|
|||
|
|
CheckTypeName = ct.CheckTypeName,
|
|||
|
|
CheckObjectText = p.ProjectName,
|
|||
|
|
CheckUnitName = u.UnitName,
|
|||
|
|
CheckTeam = x.CheckTeam,
|
|||
|
|
EvaluationResult = x.EvaluationResult,
|
|||
|
|
StatesName = ConvertState(x.States.Value),
|
|||
|
|
AttachUrl = x.AttachUrl,
|
|||
|
|
};
|
|||
|
|
|
|||
|
|
// 应用检查大类过滤
|
|||
|
|
if (input != null && !string.IsNullOrEmpty(input.CheckMainType))
|
|||
|
|
{
|
|||
|
|
query = query.Where(x => x.CheckMainTypeName.Contains(input.CheckMainType == "0" ? "安全" : "质量"));
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// 应用文本搜索
|
|||
|
|
if (input != null && !string.IsNullOrEmpty(input.SearchText))
|
|||
|
|
{
|
|||
|
|
query = query.Where(x => x.UnitHazardRegisterCode.Contains(input.SearchText) ||
|
|||
|
|
x.CheckObjectText.Contains(input.SearchText) ||
|
|||
|
|
x.CheckTeam.Contains(input.SearchText) ||
|
|||
|
|
x.EvaluationResult.Contains(input.SearchText));
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// 应用检查类别过滤
|
|||
|
|
if (input != null && !string.IsNullOrEmpty(input.CheckType) && input.CheckType != BLL.Const._Null)
|
|||
|
|
{
|
|||
|
|
query = query.Where(x => x.CheckType == input.CheckType);
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// 项目权限过滤
|
|||
|
|
if (input != null && !string.IsNullOrEmpty(input.ProjectId))
|
|||
|
|
{
|
|||
|
|
query = query.Where(x => x.ProjectId != null && x.ProjectId == input.ProjectId);
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// 获取总数
|
|||
|
|
totalCount = query.Count();
|
|||
|
|
|
|||
|
|
// 排序和分页
|
|||
|
|
var orderedQuery = query.OrderByDescending(x => x.CheckDate);
|
|||
|
|
|
|||
|
|
if (returnAll)
|
|||
|
|
{
|
|||
|
|
return orderedQuery.ToList();
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
return orderedQuery
|
|||
|
|
.Skip(pageIndex * pageSize)
|
|||
|
|
.Take(pageSize)
|
|||
|
|
.ToList();
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
/// <summary>
|
|||
|
|
/// 更新企业级检查记录
|
|||
|
|
/// </summary>
|
|||
|
|
/// <param name="register">企业级检查记录</param>
|
|||
|
|
public static void UpdateUnitHazardRegister(Model.Supervise_UnitHazardRegister register)
|
|||
|
|
{
|
|||
|
|
using (Model.SGGLDB db = new Model.SGGLDB(Funs.ConnString))
|
|||
|
|
{
|
|||
|
|
Model.Supervise_UnitHazardRegister newRegister =
|
|||
|
|
db.Supervise_UnitHazardRegister.FirstOrDefault(e => e.UnitHazardRegisterId == register.UnitHazardRegisterId);
|
|||
|
|
if (newRegister != null)
|
|||
|
|
{
|
|||
|
|
newRegister.UnitHazardRegisterCode = register.UnitHazardRegisterCode;
|
|||
|
|
newRegister.CheckDate = register.CheckDate;
|
|||
|
|
newRegister.CheckMainType = register.CheckMainType;
|
|||
|
|
newRegister.CheckType = register.CheckType;
|
|||
|
|
newRegister.ProjectId = register.ProjectId;
|
|||
|
|
newRegister.CheckUnitId = register.CheckUnitId;
|
|||
|
|
newRegister.CheckTeam = register.CheckTeam;
|
|||
|
|
newRegister.CheckManIds = register.CheckManIds;
|
|||
|
|
newRegister.CheckManNames = register.CheckManNames;
|
|||
|
|
newRegister.EvaluationResult = register.EvaluationResult;
|
|||
|
|
newRegister.AttachUrl = register.AttachUrl;
|
|||
|
|
newRegister.States = register.States;
|
|||
|
|
newRegister.InsResponsibleUserId = register.InsResponsibleUserId;
|
|||
|
|
newRegister.UpdateDate = DateTime.Now;
|
|||
|
|
db.SubmitChanges();
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
/// <summary>
|
|||
|
|
/// 更新主单状态(根据明细的整改情况)
|
|||
|
|
/// </summary>
|
|||
|
|
public static void UpdateRegisterStatus(string registerId)
|
|||
|
|
{
|
|||
|
|
// 获取主单的所有明细的整改状态
|
|||
|
|
int rectifyStatus = BLL.UnitHazardRegisterItemService.GetRectifyStatus(registerId);
|
|||
|
|
|
|||
|
|
var register = BLL.UnitHazardRegisterService.GetUnitHazardRegisterById(registerId);
|
|||
|
|
if (register != null)
|
|||
|
|
{
|
|||
|
|
// 根据整改状态更新主单状态
|
|||
|
|
switch (rectifyStatus)
|
|||
|
|
{
|
|||
|
|
case 0: // 全部未整改
|
|||
|
|
register.States = (int)UnitHazardRegisterService.StateInt.待整改; // 待整改
|
|||
|
|
break;
|
|||
|
|
case 1: // 部分整改
|
|||
|
|
register.States = (int)UnitHazardRegisterService.StateInt.部分整改; ; // 待整改
|
|||
|
|
break;
|
|||
|
|
case 2: // 全部整改
|
|||
|
|
register.States = (int)UnitHazardRegisterService.StateInt.已闭环; ; // 已完成
|
|||
|
|
break;
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
BLL.UnitHazardRegisterService.UpdateUnitHazardRegister(register);
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
#endregion Methods
|
|||
|
|
}
|
|||
|
|
}
|