using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; namespace BLL { public class ConfirmFormApproveService { public static Model.CQMS_ConfirmFormApprove GetSee(string ConfirmFormId, string userId) { Model.SGGLDB db = Funs.DB; return db.CQMS_ConfirmFormApprove.FirstOrDefault(x => x.ConfirmFormId == ConfirmFormId && x.ApproveType == "S" && x.ApproveMan == userId && x.ApproveDate == null); } public static void See(string ConfirmFormId, string userId) { using (var db = new Model.SGGLDB(Funs.ConnString)) { var res = db.CQMS_ConfirmFormApprove.FirstOrDefault(x => x.ConfirmFormId == ConfirmFormId && x.ApproveType == "S" && x.ApproveMan == userId && x.ApproveDate == null); if (res != null) { res.ApproveDate = DateTime.Now; db.SubmitChanges(); } } } /// /// 根据工程签证确认单发布Id获取对应组会签人id集合信息 /// /// 工程签证确认单发布Id /// 工程签证确认单审批集合 public static List GetUserIdsApprovesBySignType(string ConfirmFormId) { var edtion = GetUserIdsApprovesBySignTypeEditon(ConfirmFormId); return (from x in Funs.DB.CQMS_ConfirmFormApprove where x.ConfirmFormId == ConfirmFormId && x.ApproveType != "S" && x.Edition == edtion select x.ApproveMan).ToList(); } /// /// 根据工程签证确认单Id获取所有对应版次会签不同意的工程签证确认单审批信息 /// /// 工程签证确认单Id /// 版次 /// 工程签证确认单审批集合 public static List GetNotAggreeApprovesByConfirmFormIdAndEdtion(string confirmFormId, int edtion) { Model.SGGLDB db = Funs.DB; return (from x in db.CQMS_ConfirmFormApprove where x.ConfirmFormId == confirmFormId && x.Edition == edtion && x.IsAgree == false select x).ToList(); } public static int? GetUserIdsApprovesBySignTypeEditon(string ConfirmFormId) { int edition = 0; var solution = Funs.DB.CQMS_ConfirmForm.FirstOrDefault(p => p.ConfirmFormId == ConfirmFormId); if (solution != null) { edition = Convert.ToInt32(solution.Edition); } return edition; } /// /// 修改工程签证确认单审批信息 /// /// 工程签证确认单审批实体 public static void UpdateConfirmFormApprove(Model.CQMS_ConfirmFormApprove approve) { Model.SGGLDB db = Funs.DB; Model.CQMS_ConfirmFormApprove newApprove = db.CQMS_ConfirmFormApprove.First(e => e.ConfirmFormApproveId == approve.ConfirmFormApproveId && e.ApproveDate == null); newApprove.ConfirmFormId = approve.ConfirmFormId; newApprove.ApproveMan = approve.ApproveMan; newApprove.ApproveDate = approve.ApproveDate; newApprove.ApproveIdea = approve.ApproveIdea; newApprove.IsAgree = approve.IsAgree; newApprove.ApproveType = approve.ApproveType; newApprove.Edition = approve.Edition; db.SubmitChanges(); } /// /// 根据工程签证确认单发布Id获取所以对应工程签证确认单审批信息(查询全部会签状态) /// /// 工程签证确认单发布Id /// 工程签证确认单审批集合 public static List GetHandleConfirmFormApprovesByConfirmFormId(string ConfirmFormId, int edition) { var list = Funs.DB.CQMS_ConfirmFormApprove.Where(p => p.ConfirmFormId == ConfirmFormId && p.ApproveType == Const.ConfirmForm_Audit1 && p.Edition == edition).ToList(); return list; } public static List GetHandleConstruct(string ConfirmFormId, int edition) { var list = Funs.DB.CQMS_ConfirmFormApprove.Where(p => p.ConfirmFormId == ConfirmFormId && p.ApproveType != "S" && p.ApproveDate != null && p.Edition == edition).ToList(); return list; } /// /// 根据工程签证确认单发布Id获取所以对应工程签证确认单审批信息 /// /// 工程签证确认单发布Id /// 工程签证确认单审批集合 public static List GetConfirmFormApprovesByConfirmFormId(string ConfirmFormId, string state) { Model.SGGLDB db = Funs.DB; var reDate = (from x in db.CQMS_ConfirmFormApprove where x.ConfirmFormId == ConfirmFormId && x.ApproveType == BLL.Const.ConfirmForm_ReCompile orderby x.ApproveDate descending select x.ApproveDate).FirstOrDefault(); if (reDate == null) { return (from x in db.CQMS_ConfirmFormApprove where x.ConfirmFormId == ConfirmFormId && x.ApproveType == state select x).ToList(); } else { return (from x in db.CQMS_ConfirmFormApprove where x.ConfirmFormId == ConfirmFormId && x.ApproveType == state && (x.ApproveDate == null || x.ApproveDate > reDate) select x).ToList(); } } /// /// 获取工程签证确认单模板列表 /// /// /// /// public static IList getListData(string ConfirmFormId) { Model.SGGLDB db = Funs.DB; var res = from x in db.CQMS_ConfirmFormApprove where x.ConfirmFormId == ConfirmFormId && x.ApproveDate != null && x.ApproveType != "S" orderby x.ApproveDate select x; //select new //{ // x.ConfirmFormApproveId, // x.ConfirmFormId, // x.ApproveMan, // x.ApproveDate, // x.IsAgree, // x.ApproveIdea, // x.ApproveType, // x.SignType, // //= x.IsAgree == true ? "是" : "否", //}; return res.ToList(); } /// /// 获取未代办的记录数量 /// /// /// /// public static int getListSolutionApproveCount(string confirmFormId, string man) { var res = (from x in Funs.DB.CQMS_ConfirmFormApprove where x.ConfirmFormId == confirmFormId && x.ApproveDate == null && x.ApproveType != "S" && x.ApproveMan.Equals(man) orderby x.ApproveDate select x).Count(); return res; } public static IList getListSolutionApprove(string confirmFormId, string man) { var res = (from x in Funs.DB.CQMS_ConfirmFormApprove where x.ConfirmFormId == confirmFormId && x.ApproveDate == null && x.ApproveType != "S" && x.ApproveMan.Equals(man) orderby x.ApproveDate select x).ToList(); return res; } /// /// 删除未代办的记录 /// /// public static void delSolutionApprove(string confirmFormId, string man) { Model.SGGLDB db = Funs.DB; var q = (from x in Funs.DB.CQMS_ConfirmFormApprove where x.ConfirmFormId == confirmFormId && x.ApproveType != "S" && x.ApproveMan.Equals(man) && x.ApproveDate == null select x).ToList(); db.CQMS_ConfirmFormApprove.DeleteAllOnSubmit(q); db.SubmitChanges(); } /// /// 根据工程签证确认单编号删除对应的所有工程签证确认单审批信息 /// /// 工程签证确认单编号 public static void DeleteConfirmFormApprovesByConfirmFormId(string ConfirmFormId) { Model.SGGLDB db = Funs.DB; var q = (from x in Funs.DB.CQMS_ConfirmFormApprove where x.ConfirmFormId == ConfirmFormId select x).ToList(); db.CQMS_ConfirmFormApprove.DeleteAllOnSubmit(q); db.SubmitChanges(); } /// /// 根据工程签证确认单编号获取一个工程签证确认单审批信息 /// /// 工程签证确认单编号 /// 一个工程签证确认单审批实体 public static Model.CQMS_ConfirmFormApprove GetConfirmFormApproveByApproveMan(string ConfirmFormId, string approveMan) { return Funs.DB.CQMS_ConfirmFormApprove.FirstOrDefault(x => x.ConfirmFormId == ConfirmFormId && x.ApproveMan == approveMan && x.ApproveType != "S" && x.ApproveDate == null); } public static Model.CQMS_ConfirmFormApprove GetConstructSoluAppByApproveMan(string ConfirmFormId, string approveMan, int edtion) { return Funs.DB.CQMS_ConfirmFormApprove.FirstOrDefault(x => x.ConfirmFormId == ConfirmFormId && x.Edition == edtion && x.ApproveMan == approveMan && x.ApproveType != "S" && x.ApproveDate == null); } public static Model.CQMS_ConfirmFormApprove GetConstructSolApproveByApproveMan(string ConfirmFormId, string approveMan) { return Funs.DB.CQMS_ConfirmFormApprove.FirstOrDefault(x => x.ConfirmFormId == ConfirmFormId && x.ApproveMan == approveMan && x.ApproveType != "S" && x.ApproveDate == null); } public static Model.CQMS_ConfirmFormApprove GetCompile(string ConfirmFormId) { return Funs.DB.CQMS_ConfirmFormApprove.FirstOrDefault(x => x.ConfirmFormId == ConfirmFormId && x.ApproveType == BLL.Const.ConfirmForm_Compile); } /// /// 增加工程签证确认单审批信息 /// /// 工程签证确认单审批实体 public static void AddConfirmFormApprove(Model.CQMS_ConfirmFormApprove approve) { var db = Funs.DB; Model.CQMS_ConfirmFormApprove newApprove = new Model.CQMS_ConfirmFormApprove(); if (string.IsNullOrWhiteSpace(approve.ConfirmFormApproveId)) { newApprove.ConfirmFormApproveId = SQLHelper.GetNewID(typeof(Model.CQMS_ConfirmFormApprove)); } else { newApprove.ConfirmFormApproveId = approve.ConfirmFormApproveId; } newApprove.ConfirmFormId = approve.ConfirmFormId; newApprove.ApproveMan = approve.ApproveMan; newApprove.ApproveDate = approve.ApproveDate; newApprove.ApproveIdea = approve.ApproveIdea; newApprove.IsAgree = approve.IsAgree; newApprove.ApproveType = approve.ApproveType; newApprove.Edition = approve.Edition; db.CQMS_ConfirmFormApprove.InsertOnSubmit(newApprove); db.SubmitChanges(); } } }