using System; using System.Collections; using System.Collections.Generic; using System.Data; using System.Linq; using EmitMapper; using FineUIPro; using MiniExcelLibs; using MiniExcelLibs.Attributes; using Model; using WIA; namespace BLL { public static class PhtglContractTrackService { #region 获取列表 /// /// 记录数 /// public static int Count { get; set; } public static List GetPHTGL_ContractTrackByModle(PHTGL_ContractTrack table) { var q = from x in Funs.DB.PHTGL_ContractTrack where (string.IsNullOrEmpty(table.Id) || x.Id.Contains(table.Id)) && (string.IsNullOrEmpty(table.ContractNum) || x.ContractNum.Contains(table.ContractNum)) && (string.IsNullOrEmpty(table.MainItemCode) || x.MainItemCode.Contains(table.MainItemCode)) && (string.IsNullOrEmpty(table.MainItemName) || x.MainItemName.Contains(table.MainItemName)) && (string.IsNullOrEmpty(table.MajorName) || x.MajorName.Contains(table.MajorName)) && (string.IsNullOrEmpty(table.MajorCode) || x.MajorCode.Contains(table.MajorCode)) && (string.IsNullOrEmpty(table.SubProject) || x.SubProject.Contains(table.SubProject)) && (string.IsNullOrEmpty(table.SubItemProject) || x.SubItemProject.Contains(table.SubItemProject)) && (string.IsNullOrEmpty(table.ProjectCode) || x.ProjectCode.Contains(table.ProjectCode)) && (string.IsNullOrEmpty(table.ProjectName) || x.ProjectName.Contains(table.ProjectName)) && (string.IsNullOrEmpty(table.ProjectDescription) || x.ProjectDescription.Contains(table.ProjectDescription)) && (string.IsNullOrEmpty(table.UnitOfMeasurement) || x.UnitOfMeasurement.Contains(table.UnitOfMeasurement)) && (string.IsNullOrEmpty(table.Quantity) || x.Quantity.Contains(table.Quantity)) && (string.IsNullOrEmpty(table.TotalCostFixedComprehensiveUnitPrice) || x.TotalCostFixedComprehensiveUnitPrice.Contains(table.TotalCostFixedComprehensiveUnitPrice)) && (string.IsNullOrEmpty(table.MainMaterialCost) || x.MainMaterialCost.Contains(table.MainMaterialCost)) && (string.IsNullOrEmpty(table.TotalPrice) || x.TotalPrice.Contains(table.TotalPrice)) && (string.IsNullOrEmpty(table.CalculationRule) || x.CalculationRule.Contains(table.CalculationRule)) && (string.IsNullOrEmpty(table.WorkContent) || x.WorkContent.Contains(table.WorkContent)) && (string.IsNullOrEmpty(table.Remarks) || x.Remarks.Contains(table.Remarks)) && (string.IsNullOrEmpty(table.ConstructionSubcontractor) || x.ConstructionSubcontractor.Contains(table.ConstructionSubcontractor)) && (string.IsNullOrEmpty(table.ContractWeight) || x.ContractWeight.Contains(table.ContractWeight)) && (string.IsNullOrEmpty(table.MaterialSupplier) || x.MaterialSupplier.Contains(table.MaterialSupplier)) && (string.IsNullOrEmpty(table.EstimatedQuantity) || x.EstimatedQuantity.Contains(table.EstimatedQuantity)) && (string.IsNullOrEmpty(table.SettledQuantity) || x.SettledQuantity.Contains(table.SettledQuantity)) && (string.IsNullOrEmpty(table.ContractId) || x.ContractId.Contains(table.ContractId)) select x ; return q.ToList(); } /// /// 获取分页列表 /// /// /// /// public static IEnumerable GetListData(PHTGL_ContractTrack table, Grid grid1) { var q = GetPHTGL_ContractTrackByModle(table); Count = q.Count(); if (Count == 0) return null; q = q.Skip(grid1.PageSize * grid1.PageIndex).Take(grid1.PageSize).ToList(); // q = SortConditionHelper.SortingAndPaging(q, Grid1.SortField, Grid1.SortDirection, Grid1.PageIndex, Grid1.PageSize); return from x in q select new { x.Id, x.ContractNum, x.MainItemCode, x.MainItemName, x.MajorName, x.MajorCode, x.SubProject, x.SubItemProject, x.ProjectCode, x.ProjectName, x.ProjectDescription, x.UnitOfMeasurement, x.Quantity, x.TotalCostFixedComprehensiveUnitPrice, x.MainMaterialCost, x.TotalPrice, x.CalculationRule, x.WorkContent, x.Remarks, x.ConstructionSubcontractor, x.ContractWeight, x.MaterialSupplier, x.IsWithinGeneralContractScope, x.EstimatedQuantity, x.EstimatedAmount, x.SettledQuantity, x.SettledAmount, x.ContractId }; } #endregion public static PHTGL_ContractTrack GetPHTGL_ContractTrackById(string id) { return Funs.DB.PHTGL_ContractTrack.FirstOrDefault(x => x.Id == id); } public static void AddPHTGL_ContractTrack(PHTGL_ContractTrack newtable) { var table = new PHTGL_ContractTrack { Id = newtable.Id, ContractNum = newtable.ContractNum, MainItemCode = newtable.MainItemCode, MainItemName = newtable.MainItemName, MajorName = newtable.MajorName, MajorCode = newtable.MajorCode, SubProject = newtable.SubProject, SubItemProject = newtable.SubItemProject, ProjectCode = newtable.ProjectCode, ProjectName = newtable.ProjectName, ProjectDescription = newtable.ProjectDescription, UnitOfMeasurement = newtable.UnitOfMeasurement, Quantity = newtable.Quantity, TotalCostFixedComprehensiveUnitPrice = newtable.TotalCostFixedComprehensiveUnitPrice, MainMaterialCost = newtable.MainMaterialCost, TotalPrice = newtable.TotalPrice, CalculationRule = newtable.CalculationRule, WorkContent = newtable.WorkContent, Remarks = newtable.Remarks, ConstructionSubcontractor = newtable.ConstructionSubcontractor, ContractWeight = newtable.ContractWeight, MaterialSupplier = newtable.MaterialSupplier, IsWithinGeneralContractScope = newtable.IsWithinGeneralContractScope, EstimatedQuantity = newtable.EstimatedQuantity, EstimatedAmount = newtable.EstimatedAmount, SettledQuantity = newtable.SettledQuantity, SettledAmount = newtable.SettledAmount, ContractId = newtable.ContractId, ProjectId = newtable.ProjectId, }; Funs.DB.PHTGL_ContractTrack.InsertOnSubmit(table); Funs.DB.SubmitChanges(); PhtglContracttrackprogressService.CreateTemplateByContractTrackId(newtable.Id); } public static void UpdatePHTGL_ContractTrack(PHTGL_ContractTrack newtable) { var table = Funs.DB.PHTGL_ContractTrack.FirstOrDefault(x => x.Id == newtable.Id); if (table != null) { table.Id = newtable.Id; table.ContractNum = newtable.ContractNum; table.MainItemCode = newtable.MainItemCode; table.MainItemName = newtable.MainItemName; table.MajorName = newtable.MajorName; table.MajorCode = newtable.MajorCode; table.SubProject = newtable.SubProject; table.SubItemProject = newtable.SubItemProject; table.ProjectCode = newtable.ProjectCode; table.ProjectName = newtable.ProjectName; table.ProjectDescription = newtable.ProjectDescription; table.UnitOfMeasurement = newtable.UnitOfMeasurement; table.Quantity = newtable.Quantity; table.TotalCostFixedComprehensiveUnitPrice = newtable.TotalCostFixedComprehensiveUnitPrice; table.MainMaterialCost = newtable.MainMaterialCost; table.TotalPrice = newtable.TotalPrice; table.CalculationRule = newtable.CalculationRule; table.WorkContent = newtable.WorkContent; table.Remarks = newtable.Remarks; table.ConstructionSubcontractor = newtable.ConstructionSubcontractor; table.ContractWeight = newtable.ContractWeight; table.MaterialSupplier = newtable.MaterialSupplier; table.IsWithinGeneralContractScope = newtable.IsWithinGeneralContractScope; table.EstimatedQuantity = newtable.EstimatedQuantity; table.EstimatedAmount = newtable.EstimatedAmount; table.SettledQuantity = newtable.SettledQuantity; table.SettledAmount = newtable.SettledAmount; table.ContractId = newtable.ContractId; table.ProjectId = newtable.ProjectId; Funs.DB.SubmitChanges(); } } public static void DeletePHTGL_ContractTrackById(string id) { var table = Funs.DB.PHTGL_ContractTrack.FirstOrDefault(x => x.Id == id); if (table != null) { Funs.DB.PHTGL_ContractTrack.DeleteOnSubmit(table); Funs.DB.SubmitChanges(); } PhtglContracttrackprogressService.DeleteModleByContractTrackId(id); PhtglContracttrackmatchwbsService.DeleteModelByContractTrackId(id); } public static ResponeData ImportData(string path, string contractid, string projectid) { var responeData = new ResponeData(); List rows; try { rows = MiniExcel.Query(path).ToList(); } catch (Exception e) { responeData.code = 0; responeData.message = "模板错误"; return responeData; } var mapper = ObjectMapperManager.DefaultInstance.GetMapper, List>(); var modeList = mapper.Map(rows); if (modeList.Count == 0) { responeData.code = 0; responeData.message = "没有数据"; return responeData; } foreach (var item in modeList) { item.ContractId = contractid; item.ProjectId = projectid; var phtglContractTrack = new PHTGL_ContractTrack { ProjectCode = item.ProjectCode, ContractId = contractid, ProjectId = projectid, }; if (string.IsNullOrEmpty(item.ProjectCode)) continue; var resultModel = GetPHTGL_ContractTrackByModle(phtglContractTrack); item.ContractNum = ContractService.GetContractById(contractid)?.ContractNum; if (resultModel.Any()) { item.Id = resultModel[0].Id; UpdatePHTGL_ContractTrack(item); } else { item.Id = SQLHelper.GetNewID(); AddPHTGL_ContractTrack(item); } PhtglContracttrackprogressService.CreateTemplateByContractTrackId(item.Id); } return responeData; } /// /// 获取模拟树表格 /// /// public static DataTable GetAllTreeDataTable(string projectId, string IsOut, List contractNoList, List professionalList, List workPostIds, List machineIds, string constructionLogId) { using (var db = new Model.SGGLDB(Funs.ConnString)) { var pros = BLL.PHTGL_QuantityService.GetMajorItems(); List proNames = new List(); foreach (var item in professionalList) { var pro = pros.FirstOrDefault(x => x.Text == item); if (pro != null) { proNames.Add(pro.Value); } } IQueryable getContractTracks = from x in db.PHTGL_ContractTrack where x.ProjectId == projectId && contractNoList.Contains(x.ContractId) && proNames.Contains(x.MajorName) orderby x.ProjectCode, x.ProjectName select x; IQueryable workEfficiencys = from x in db.ZHGL_ConstructionLogWorkEfficiency where x.ConstructionLogId == constructionLogId select x; var unitWorks = (from x in getContractTracks select new { MainItemCode = x.MainItemCode, MainItemName = x.MainItemName }).Distinct().ToList(); DataTable table = new DataTable(); table.Columns.Add(new DataColumn("Id", typeof(String))); table.Columns.Add(new DataColumn("Code", typeof(String))); table.Columns.Add(new DataColumn("ProjectCode", typeof(String))); table.Columns.Add(new DataColumn("ProjectName", typeof(String))); table.Columns.Add(new DataColumn("UnitOfMeasurement", typeof(String))); table.Columns.Add(new DataColumn("PhysicalCompletionQuantity", typeof(String))); table.Columns.Add(new DataColumn("MaterialConsumption", typeof(String))); table.Columns.Add(new DataColumn("ShowId", typeof(String))); table.Columns.Add(new DataColumn("PersonConsumeHours0", typeof(String))); table.Columns.Add(new DataColumn("PersonWorkEfficiency0", typeof(String))); table.Columns.Add(new DataColumn("PersonConsumeHours1", typeof(String))); table.Columns.Add(new DataColumn("PersonWorkEfficiency1", typeof(String))); table.Columns.Add(new DataColumn("PersonConsumeHours2", typeof(String))); table.Columns.Add(new DataColumn("PersonWorkEfficiency2", typeof(String))); table.Columns.Add(new DataColumn("PersonConsumeHours3", typeof(String))); table.Columns.Add(new DataColumn("PersonWorkEfficiency3", typeof(String))); table.Columns.Add(new DataColumn("PersonConsumeHours4", typeof(String))); table.Columns.Add(new DataColumn("PersonWorkEfficiency4", typeof(String))); table.Columns.Add(new DataColumn("PersonConsumeHours5", typeof(String))); table.Columns.Add(new DataColumn("PersonWorkEfficiency5", typeof(String))); table.Columns.Add(new DataColumn("PersonConsumeHours6", typeof(String))); table.Columns.Add(new DataColumn("PersonWorkEfficiency6", typeof(String))); table.Columns.Add(new DataColumn("PersonConsumeHours7", typeof(String))); table.Columns.Add(new DataColumn("PersonWorkEfficiency7", typeof(String))); table.Columns.Add(new DataColumn("PersonConsumeHours8", typeof(String))); table.Columns.Add(new DataColumn("PersonWorkEfficiency8", typeof(String))); table.Columns.Add(new DataColumn("PersonConsumeHours9", typeof(String))); table.Columns.Add(new DataColumn("PersonWorkEfficiency9", typeof(String))); table.Columns.Add(new DataColumn("PersonConsumeHours10", typeof(String))); table.Columns.Add(new DataColumn("PersonWorkEfficiency10", typeof(String))); table.Columns.Add(new DataColumn("PersonConsumeHours11", typeof(String))); table.Columns.Add(new DataColumn("PersonWorkEfficiency11", typeof(String))); table.Columns.Add(new DataColumn("PersonConsumeHours12", typeof(String))); table.Columns.Add(new DataColumn("PersonWorkEfficiency12", typeof(String))); table.Columns.Add(new DataColumn("PersonConsumeHours13", typeof(String))); table.Columns.Add(new DataColumn("PersonWorkEfficiency13", typeof(String))); table.Columns.Add(new DataColumn("PersonConsumeHours14", typeof(String))); table.Columns.Add(new DataColumn("PersonWorkEfficiency14", typeof(String))); table.Columns.Add(new DataColumn("PersonConsumeHours15", typeof(String))); table.Columns.Add(new DataColumn("PersonWorkEfficiency15", typeof(String))); table.Columns.Add(new DataColumn("PersonConsumeHours16", typeof(String))); table.Columns.Add(new DataColumn("PersonWorkEfficiency16", typeof(String))); table.Columns.Add(new DataColumn("PersonConsumeHours17", typeof(String))); table.Columns.Add(new DataColumn("PersonWorkEfficiency17", typeof(String))); table.Columns.Add(new DataColumn("PersonConsumeHours18", typeof(String))); table.Columns.Add(new DataColumn("PersonWorkEfficiency18", typeof(String))); table.Columns.Add(new DataColumn("PersonConsumeHours19", typeof(String))); table.Columns.Add(new DataColumn("PersonWorkEfficiency19", typeof(String))); table.Columns.Add(new DataColumn("MachineConsumeHours0", typeof(String))); table.Columns.Add(new DataColumn("MachineWorkEfficiency0", typeof(String))); table.Columns.Add(new DataColumn("MachineConsumeHours1", typeof(String))); table.Columns.Add(new DataColumn("MachineWorkEfficiency1", typeof(String))); table.Columns.Add(new DataColumn("MachineConsumeHours2", typeof(String))); table.Columns.Add(new DataColumn("MachineWorkEfficiency2", typeof(String))); table.Columns.Add(new DataColumn("MachineConsumeHours3", typeof(String))); table.Columns.Add(new DataColumn("MachineWorkEfficiency3", typeof(String))); table.Columns.Add(new DataColumn("MachineConsumeHours4", typeof(String))); table.Columns.Add(new DataColumn("MachineWorkEfficiency4", typeof(String))); table.Columns.Add(new DataColumn("MachineConsumeHours5", typeof(String))); table.Columns.Add(new DataColumn("MachineWorkEfficiency5", typeof(String))); table.Columns.Add(new DataColumn("MachineConsumeHours6", typeof(String))); table.Columns.Add(new DataColumn("MachineWorkEfficiency6", typeof(String))); table.Columns.Add(new DataColumn("MachineConsumeHours7", typeof(String))); table.Columns.Add(new DataColumn("MachineWorkEfficiency7", typeof(String))); table.Columns.Add(new DataColumn("MachineConsumeHours8", typeof(String))); table.Columns.Add(new DataColumn("MachineWorkEfficiency8", typeof(String))); table.Columns.Add(new DataColumn("MachineConsumeHours9", typeof(String))); table.Columns.Add(new DataColumn("MachineWorkEfficiency9", typeof(String))); table.Columns.Add(new DataColumn("MachineConsumeHours10", typeof(String))); table.Columns.Add(new DataColumn("MachineWorkEfficiency10", typeof(String))); table.Columns.Add(new DataColumn("MachineConsumeHours11", typeof(String))); table.Columns.Add(new DataColumn("MachineWorkEfficiency11", typeof(String))); table.Columns.Add(new DataColumn("MachineConsumeHours12", typeof(String))); table.Columns.Add(new DataColumn("MachineWorkEfficiency12", typeof(String))); table.Columns.Add(new DataColumn("MachineConsumeHours13", typeof(String))); table.Columns.Add(new DataColumn("MachineWorkEfficiency13", typeof(String))); table.Columns.Add(new DataColumn("MachineConsumeHours14", typeof(String))); table.Columns.Add(new DataColumn("MachineWorkEfficiency14", typeof(String))); table.Columns.Add(new DataColumn("MachineConsumeHours15", typeof(String))); table.Columns.Add(new DataColumn("MachineWorkEfficiency15", typeof(String))); table.Columns.Add(new DataColumn("MachineConsumeHours16", typeof(String))); table.Columns.Add(new DataColumn("MachineWorkEfficiency16", typeof(String))); table.Columns.Add(new DataColumn("MachineConsumeHours17", typeof(String))); table.Columns.Add(new DataColumn("MachineWorkEfficiency17", typeof(String))); table.Columns.Add(new DataColumn("MachineConsumeHours18", typeof(String))); table.Columns.Add(new DataColumn("MachineWorkEfficiency18", typeof(String))); table.Columns.Add(new DataColumn("MachineConsumeHours19", typeof(String))); table.Columns.Add(new DataColumn("MachineWorkEfficiency19", typeof(String))); DataRow row; int a = 1; foreach (var unitWork in unitWorks) { row = table.NewRow(); row[0] = unitWork.MainItemCode; row[1] = a; row[2] = string.Empty; row[3] = unitWork.MainItemName; table.Rows.Add(row); int b = 1; foreach (var proName in proNames) { row = table.NewRow(); row[0] = unitWork.MainItemCode + b.ToString(); row[1] = a + "." + b; row[2] = string.Empty; row[3] = proName; table.Rows.Add(row); int c = 1; var contractTracks = getContractTracks.Where(x => x.MainItemCode == unitWork.MainItemCode && x.MajorName == proName); foreach (Model.PHTGL_ContractTrack item in contractTracks) { row = table.NewRow(); row[0] = item.Id; row[1] = a + "." + b + "." + c; row[2] = item.ProjectCode; row[3] = item.ProjectName; row[4] = item.UnitOfMeasurement; row[7] = item.Id; if (workEfficiencys.Count() > 0) { var we = workEfficiencys.FirstOrDefault(x => x.ContractTrackId == item.Id); if (we != null) { row[5] = we.PhysicalCompletionQuantity; row[6] = we.MaterialConsumption; } for (int i = 0; i < workPostIds.Count; i++) { var workEfficiency = workEfficiencys.FirstOrDefault(x => x.Type == "Person" && x.TypeId == workPostIds[i] && x.ContractTrackId == item.Id); if (workEfficiency != null) { if (workEfficiency.ConsumeHours != null) { row[8 + i * 2] = decimal.Round(Convert.ToDecimal(workEfficiency.ConsumeHours), 2); if (we.PhysicalCompletionQuantity != null && we.PhysicalCompletionQuantity > 0) { row[9 + i * 2] = decimal.Round(Convert.ToDecimal(we.PhysicalCompletionQuantity / workEfficiency.ConsumeHours), 2); } } } } for (int i = 0; i < machineIds.Count; i++) { var workEfficiency = workEfficiencys.FirstOrDefault(x => x.Type == "Machine" && x.TypeId == machineIds[i] && x.ContractTrackId == item.Id); if (workEfficiency != null) { if (workEfficiency.ConsumeHours != null) { row[48 + i * 2] = decimal.Round(Convert.ToDecimal(workEfficiency.ConsumeHours), 2); if (we.PhysicalCompletionQuantity != null && we.PhysicalCompletionQuantity > 0) { row[49 + i * 2] = decimal.Round(Convert.ToDecimal(we.PhysicalCompletionQuantity / workEfficiency.ConsumeHours), 2); } } } } } table.Rows.Add(row); c++; } b++; } a++; } return table; } } /// /// 获取模拟树表格 /// /// public static DataTable GetProjectAllTreeDataTable(string projectId, string IsOut, List contractNoList, List professionalList, List workPostIds, List machineIds, string compileDate) { using (var db = new Model.SGGLDB(Funs.ConnString)) { var pros = BLL.PHTGL_QuantityService.GetMajorItems(); List proNames = new List(); foreach (var item in professionalList) { var pro = pros.FirstOrDefault(x => x.Text == item); if (pro != null) { proNames.Add(pro.Value); } } proNames = proNames.Distinct().ToList(); IQueryable getContractTracks = from x in db.PHTGL_ContractTrack where x.ProjectId == projectId && contractNoList.Contains(x.ContractId) && proNames.Contains(x.MajorName) orderby x.ProjectCode, x.ProjectName select x; DateTime date = Funs.GetNewDateTimeOrNow(compileDate); var personLogIds = (from x in db.ZHGL_ConstructionLog where x.ProjectId == projectId && x.CompileDate == date orderby x.CompileDate descending select x.ConstructionLogId).ToList(); IQueryable workEfficiencys = from x in db.ZHGL_ConstructionLogWorkEfficiency where personLogIds.Contains(x.ConstructionLogId) select x; var unitWorks = (from x in getContractTracks select new { MainItemCode = x.MainItemCode, MainItemName = x.MainItemName }).Distinct().ToList(); DataTable table = new DataTable(); table.Columns.Add(new DataColumn("Id", typeof(String))); table.Columns.Add(new DataColumn("Code", typeof(String))); table.Columns.Add(new DataColumn("ProjectCode", typeof(String))); table.Columns.Add(new DataColumn("ProjectName", typeof(String))); table.Columns.Add(new DataColumn("UnitOfMeasurement", typeof(String))); table.Columns.Add(new DataColumn("PhysicalCompletionQuantity", typeof(String))); table.Columns.Add(new DataColumn("MaterialConsumption", typeof(String))); table.Columns.Add(new DataColumn("ShowId", typeof(String))); table.Columns.Add(new DataColumn("PersonConsumeHours0", typeof(String))); table.Columns.Add(new DataColumn("PersonWorkEfficiency0", typeof(String))); table.Columns.Add(new DataColumn("PersonConsumeHours1", typeof(String))); table.Columns.Add(new DataColumn("PersonWorkEfficiency1", typeof(String))); table.Columns.Add(new DataColumn("PersonConsumeHours2", typeof(String))); table.Columns.Add(new DataColumn("PersonWorkEfficiency2", typeof(String))); table.Columns.Add(new DataColumn("PersonConsumeHours3", typeof(String))); table.Columns.Add(new DataColumn("PersonWorkEfficiency3", typeof(String))); table.Columns.Add(new DataColumn("PersonConsumeHours4", typeof(String))); table.Columns.Add(new DataColumn("PersonWorkEfficiency4", typeof(String))); table.Columns.Add(new DataColumn("PersonConsumeHours5", typeof(String))); table.Columns.Add(new DataColumn("PersonWorkEfficiency5", typeof(String))); table.Columns.Add(new DataColumn("PersonConsumeHours6", typeof(String))); table.Columns.Add(new DataColumn("PersonWorkEfficiency6", typeof(String))); table.Columns.Add(new DataColumn("PersonConsumeHours7", typeof(String))); table.Columns.Add(new DataColumn("PersonWorkEfficiency7", typeof(String))); table.Columns.Add(new DataColumn("PersonConsumeHours8", typeof(String))); table.Columns.Add(new DataColumn("PersonWorkEfficiency8", typeof(String))); table.Columns.Add(new DataColumn("PersonConsumeHours9", typeof(String))); table.Columns.Add(new DataColumn("PersonWorkEfficiency9", typeof(String))); table.Columns.Add(new DataColumn("PersonConsumeHours10", typeof(String))); table.Columns.Add(new DataColumn("PersonWorkEfficiency10", typeof(String))); table.Columns.Add(new DataColumn("PersonConsumeHours11", typeof(String))); table.Columns.Add(new DataColumn("PersonWorkEfficiency11", typeof(String))); table.Columns.Add(new DataColumn("PersonConsumeHours12", typeof(String))); table.Columns.Add(new DataColumn("PersonWorkEfficiency12", typeof(String))); table.Columns.Add(new DataColumn("PersonConsumeHours13", typeof(String))); table.Columns.Add(new DataColumn("PersonWorkEfficiency13", typeof(String))); table.Columns.Add(new DataColumn("PersonConsumeHours14", typeof(String))); table.Columns.Add(new DataColumn("PersonWorkEfficiency14", typeof(String))); table.Columns.Add(new DataColumn("PersonConsumeHours15", typeof(String))); table.Columns.Add(new DataColumn("PersonWorkEfficiency15", typeof(String))); table.Columns.Add(new DataColumn("PersonConsumeHours16", typeof(String))); table.Columns.Add(new DataColumn("PersonWorkEfficiency16", typeof(String))); table.Columns.Add(new DataColumn("PersonConsumeHours17", typeof(String))); table.Columns.Add(new DataColumn("PersonWorkEfficiency17", typeof(String))); table.Columns.Add(new DataColumn("PersonConsumeHours18", typeof(String))); table.Columns.Add(new DataColumn("PersonWorkEfficiency18", typeof(String))); table.Columns.Add(new DataColumn("PersonConsumeHours19", typeof(String))); table.Columns.Add(new DataColumn("PersonWorkEfficiency19", typeof(String))); table.Columns.Add(new DataColumn("MachineConsumeHours0", typeof(String))); table.Columns.Add(new DataColumn("MachineWorkEfficiency0", typeof(String))); table.Columns.Add(new DataColumn("MachineConsumeHours1", typeof(String))); table.Columns.Add(new DataColumn("MachineWorkEfficiency1", typeof(String))); table.Columns.Add(new DataColumn("MachineConsumeHours2", typeof(String))); table.Columns.Add(new DataColumn("MachineWorkEfficiency2", typeof(String))); table.Columns.Add(new DataColumn("MachineConsumeHours3", typeof(String))); table.Columns.Add(new DataColumn("MachineWorkEfficiency3", typeof(String))); table.Columns.Add(new DataColumn("MachineConsumeHours4", typeof(String))); table.Columns.Add(new DataColumn("MachineWorkEfficiency4", typeof(String))); table.Columns.Add(new DataColumn("MachineConsumeHours5", typeof(String))); table.Columns.Add(new DataColumn("MachineWorkEfficiency5", typeof(String))); table.Columns.Add(new DataColumn("MachineConsumeHours6", typeof(String))); table.Columns.Add(new DataColumn("MachineWorkEfficiency6", typeof(String))); table.Columns.Add(new DataColumn("MachineConsumeHours7", typeof(String))); table.Columns.Add(new DataColumn("MachineWorkEfficiency7", typeof(String))); table.Columns.Add(new DataColumn("MachineConsumeHours8", typeof(String))); table.Columns.Add(new DataColumn("MachineWorkEfficiency8", typeof(String))); table.Columns.Add(new DataColumn("MachineConsumeHours9", typeof(String))); table.Columns.Add(new DataColumn("MachineWorkEfficiency9", typeof(String))); table.Columns.Add(new DataColumn("MachineConsumeHours10", typeof(String))); table.Columns.Add(new DataColumn("MachineWorkEfficiency10", typeof(String))); table.Columns.Add(new DataColumn("MachineConsumeHours11", typeof(String))); table.Columns.Add(new DataColumn("MachineWorkEfficiency11", typeof(String))); table.Columns.Add(new DataColumn("MachineConsumeHours12", typeof(String))); table.Columns.Add(new DataColumn("MachineWorkEfficiency12", typeof(String))); table.Columns.Add(new DataColumn("MachineConsumeHours13", typeof(String))); table.Columns.Add(new DataColumn("MachineWorkEfficiency13", typeof(String))); table.Columns.Add(new DataColumn("MachineConsumeHours14", typeof(String))); table.Columns.Add(new DataColumn("MachineWorkEfficiency14", typeof(String))); table.Columns.Add(new DataColumn("MachineConsumeHours15", typeof(String))); table.Columns.Add(new DataColumn("MachineWorkEfficiency15", typeof(String))); table.Columns.Add(new DataColumn("MachineConsumeHours16", typeof(String))); table.Columns.Add(new DataColumn("MachineWorkEfficiency16", typeof(String))); table.Columns.Add(new DataColumn("MachineConsumeHours17", typeof(String))); table.Columns.Add(new DataColumn("MachineWorkEfficiency17", typeof(String))); table.Columns.Add(new DataColumn("MachineConsumeHours18", typeof(String))); table.Columns.Add(new DataColumn("MachineWorkEfficiency18", typeof(String))); table.Columns.Add(new DataColumn("MachineConsumeHours19", typeof(String))); table.Columns.Add(new DataColumn("MachineWorkEfficiency19", typeof(String))); DataRow row; int a = 1; foreach (var unitWork in unitWorks) { row = table.NewRow(); row[0] = unitWork.MainItemCode; row[1] = a; row[2] = string.Empty; row[3] = unitWork.MainItemName; table.Rows.Add(row); int b = 1; foreach (var proName in proNames) { row = table.NewRow(); row[0] = unitWork.MainItemCode + b.ToString(); row[1] = a + "." + b; row[2] = string.Empty; row[3] = proName; table.Rows.Add(row); int c = 1; var contractTracks = getContractTracks.Where(x => x.MainItemCode == unitWork.MainItemCode && x.MajorName == proName); foreach (Model.PHTGL_ContractTrack item in contractTracks) { row = table.NewRow(); row[0] = item.Id; row[1] = a + "." + b + "." + c; row[2] = item.ProjectCode; row[3] = item.ProjectName; row[4] = item.UnitOfMeasurement; row[7] = item.Id; if (workEfficiencys.Count() > 0) { var we = workEfficiencys.FirstOrDefault(x => x.ContractTrackId == item.Id); if (we != null) { row[5] = we.PhysicalCompletionQuantity; row[6] = we.MaterialConsumption; } for (int i = 0; i < workPostIds.Count; i++) { var workEfficiencyList = workEfficiencys.Where(x => x.Type == "Person" && x.TypeId == workPostIds[i] && x.ContractTrackId == item.Id); if (workEfficiencyList.Count() > 0) { decimal d = 0; foreach (var workEfficiency in workEfficiencyList) { if (workEfficiency.ConsumeHours != null) { d += decimal.Round(Convert.ToDecimal(workEfficiency.ConsumeHours), 2); } } if (d > 0) { row[8 + i * 2] = decimal.Round(d, 2); if (we.PhysicalCompletionQuantity != null && we.PhysicalCompletionQuantity > 0) { row[9 + i * 2] = decimal.Round(Convert.ToDecimal(we.PhysicalCompletionQuantity / d), 2); } } } } for (int i = 0; i < machineIds.Count; i++) { var workEfficiencyList = workEfficiencys.Where(x => x.Type == "Machine" && x.TypeId == machineIds[i] && x.ContractTrackId == item.Id); if (workEfficiencyList.Count() > 0) { decimal d = 0; foreach (var workEfficiency in workEfficiencyList) { if (workEfficiency.ConsumeHours != null) { d += decimal.Round(Convert.ToDecimal(workEfficiency.ConsumeHours), 2); } } if (d > 0) { row[48 + i * 2] = decimal.Round(d, 2); if (we.PhysicalCompletionQuantity != null && we.PhysicalCompletionQuantity > 0) { row[49 + i * 2] = decimal.Round(Convert.ToDecimal(we.PhysicalCompletionQuantity / d), 2); } } } } } table.Rows.Add(row); c++; } b++; } a++; } return table; } } /// /// 获取模拟树表格 /// /// public static DataTable GetMonthProjectAllTreeDataTable(string projectId, string IsOut, List contractNoList, List professionalList, List workPostIds, List machineIds, DateTime startDate, DateTime endDate) { using (var db = new Model.SGGLDB(Funs.ConnString)) { var pros = BLL.PHTGL_QuantityService.GetMajorItems(); List proNames = new List(); foreach (var item in professionalList) { var pro = pros.FirstOrDefault(x => x.Text == item); if (pro != null) { proNames.Add(pro.Value); } } proNames = proNames.Distinct().ToList(); IQueryable getContractTracks = from x in db.PHTGL_ContractTrack where x.ProjectId == projectId && contractNoList.Contains(x.ContractId) && proNames.Contains(x.MajorName) orderby x.ProjectCode, x.ProjectName select x; var personLogIds = (from x in db.ZHGL_ConstructionLog where x.ProjectId == projectId && x.CompileDate >= startDate && x.CompileDate < endDate orderby x.CompileDate descending select x.ConstructionLogId).ToList(); IQueryable workEfficiencys = from x in db.ZHGL_ConstructionLogWorkEfficiency where personLogIds.Contains(x.ConstructionLogId) select x; var unitWorks = (from x in getContractTracks select new { MainItemCode = x.MainItemCode, MainItemName = x.MainItemName }).Distinct().ToList(); DataTable table = new DataTable(); table.Columns.Add(new DataColumn("Id", typeof(String))); table.Columns.Add(new DataColumn("Code", typeof(String))); table.Columns.Add(new DataColumn("ProjectCode", typeof(String))); table.Columns.Add(new DataColumn("ProjectName", typeof(String))); table.Columns.Add(new DataColumn("UnitOfMeasurement", typeof(String))); table.Columns.Add(new DataColumn("PhysicalCompletionQuantity", typeof(String))); table.Columns.Add(new DataColumn("MaterialConsumption", typeof(String))); table.Columns.Add(new DataColumn("ShowId", typeof(String))); table.Columns.Add(new DataColumn("PersonConsumeHours0", typeof(String))); table.Columns.Add(new DataColumn("PersonWorkEfficiency0", typeof(String))); table.Columns.Add(new DataColumn("PersonConsumeHours1", typeof(String))); table.Columns.Add(new DataColumn("PersonWorkEfficiency1", typeof(String))); table.Columns.Add(new DataColumn("PersonConsumeHours2", typeof(String))); table.Columns.Add(new DataColumn("PersonWorkEfficiency2", typeof(String))); table.Columns.Add(new DataColumn("PersonConsumeHours3", typeof(String))); table.Columns.Add(new DataColumn("PersonWorkEfficiency3", typeof(String))); table.Columns.Add(new DataColumn("PersonConsumeHours4", typeof(String))); table.Columns.Add(new DataColumn("PersonWorkEfficiency4", typeof(String))); table.Columns.Add(new DataColumn("PersonConsumeHours5", typeof(String))); table.Columns.Add(new DataColumn("PersonWorkEfficiency5", typeof(String))); table.Columns.Add(new DataColumn("PersonConsumeHours6", typeof(String))); table.Columns.Add(new DataColumn("PersonWorkEfficiency6", typeof(String))); table.Columns.Add(new DataColumn("PersonConsumeHours7", typeof(String))); table.Columns.Add(new DataColumn("PersonWorkEfficiency7", typeof(String))); table.Columns.Add(new DataColumn("PersonConsumeHours8", typeof(String))); table.Columns.Add(new DataColumn("PersonWorkEfficiency8", typeof(String))); table.Columns.Add(new DataColumn("PersonConsumeHours9", typeof(String))); table.Columns.Add(new DataColumn("PersonWorkEfficiency9", typeof(String))); table.Columns.Add(new DataColumn("PersonConsumeHours10", typeof(String))); table.Columns.Add(new DataColumn("PersonWorkEfficiency10", typeof(String))); table.Columns.Add(new DataColumn("PersonConsumeHours11", typeof(String))); table.Columns.Add(new DataColumn("PersonWorkEfficiency11", typeof(String))); table.Columns.Add(new DataColumn("PersonConsumeHours12", typeof(String))); table.Columns.Add(new DataColumn("PersonWorkEfficiency12", typeof(String))); table.Columns.Add(new DataColumn("PersonConsumeHours13", typeof(String))); table.Columns.Add(new DataColumn("PersonWorkEfficiency13", typeof(String))); table.Columns.Add(new DataColumn("PersonConsumeHours14", typeof(String))); table.Columns.Add(new DataColumn("PersonWorkEfficiency14", typeof(String))); table.Columns.Add(new DataColumn("PersonConsumeHours15", typeof(String))); table.Columns.Add(new DataColumn("PersonWorkEfficiency15", typeof(String))); table.Columns.Add(new DataColumn("PersonConsumeHours16", typeof(String))); table.Columns.Add(new DataColumn("PersonWorkEfficiency16", typeof(String))); table.Columns.Add(new DataColumn("PersonConsumeHours17", typeof(String))); table.Columns.Add(new DataColumn("PersonWorkEfficiency17", typeof(String))); table.Columns.Add(new DataColumn("PersonConsumeHours18", typeof(String))); table.Columns.Add(new DataColumn("PersonWorkEfficiency18", typeof(String))); table.Columns.Add(new DataColumn("PersonConsumeHours19", typeof(String))); table.Columns.Add(new DataColumn("PersonWorkEfficiency19", typeof(String))); table.Columns.Add(new DataColumn("MachineConsumeHours0", typeof(String))); table.Columns.Add(new DataColumn("MachineWorkEfficiency0", typeof(String))); table.Columns.Add(new DataColumn("MachineConsumeHours1", typeof(String))); table.Columns.Add(new DataColumn("MachineWorkEfficiency1", typeof(String))); table.Columns.Add(new DataColumn("MachineConsumeHours2", typeof(String))); table.Columns.Add(new DataColumn("MachineWorkEfficiency2", typeof(String))); table.Columns.Add(new DataColumn("MachineConsumeHours3", typeof(String))); table.Columns.Add(new DataColumn("MachineWorkEfficiency3", typeof(String))); table.Columns.Add(new DataColumn("MachineConsumeHours4", typeof(String))); table.Columns.Add(new DataColumn("MachineWorkEfficiency4", typeof(String))); table.Columns.Add(new DataColumn("MachineConsumeHours5", typeof(String))); table.Columns.Add(new DataColumn("MachineWorkEfficiency5", typeof(String))); table.Columns.Add(new DataColumn("MachineConsumeHours6", typeof(String))); table.Columns.Add(new DataColumn("MachineWorkEfficiency6", typeof(String))); table.Columns.Add(new DataColumn("MachineConsumeHours7", typeof(String))); table.Columns.Add(new DataColumn("MachineWorkEfficiency7", typeof(String))); table.Columns.Add(new DataColumn("MachineConsumeHours8", typeof(String))); table.Columns.Add(new DataColumn("MachineWorkEfficiency8", typeof(String))); table.Columns.Add(new DataColumn("MachineConsumeHours9", typeof(String))); table.Columns.Add(new DataColumn("MachineWorkEfficiency9", typeof(String))); table.Columns.Add(new DataColumn("MachineConsumeHours10", typeof(String))); table.Columns.Add(new DataColumn("MachineWorkEfficiency10", typeof(String))); table.Columns.Add(new DataColumn("MachineConsumeHours11", typeof(String))); table.Columns.Add(new DataColumn("MachineWorkEfficiency11", typeof(String))); table.Columns.Add(new DataColumn("MachineConsumeHours12", typeof(String))); table.Columns.Add(new DataColumn("MachineWorkEfficiency12", typeof(String))); table.Columns.Add(new DataColumn("MachineConsumeHours13", typeof(String))); table.Columns.Add(new DataColumn("MachineWorkEfficiency13", typeof(String))); table.Columns.Add(new DataColumn("MachineConsumeHours14", typeof(String))); table.Columns.Add(new DataColumn("MachineWorkEfficiency14", typeof(String))); table.Columns.Add(new DataColumn("MachineConsumeHours15", typeof(String))); table.Columns.Add(new DataColumn("MachineWorkEfficiency15", typeof(String))); table.Columns.Add(new DataColumn("MachineConsumeHours16", typeof(String))); table.Columns.Add(new DataColumn("MachineWorkEfficiency16", typeof(String))); table.Columns.Add(new DataColumn("MachineConsumeHours17", typeof(String))); table.Columns.Add(new DataColumn("MachineWorkEfficiency17", typeof(String))); table.Columns.Add(new DataColumn("MachineConsumeHours18", typeof(String))); table.Columns.Add(new DataColumn("MachineWorkEfficiency18", typeof(String))); table.Columns.Add(new DataColumn("MachineConsumeHours19", typeof(String))); table.Columns.Add(new DataColumn("MachineWorkEfficiency19", typeof(String))); DataRow row; int a = 1; foreach (var unitWork in unitWorks) { row = table.NewRow(); row[0] = unitWork.MainItemCode; row[1] = a; row[2] = string.Empty; row[3] = unitWork.MainItemName; table.Rows.Add(row); int b = 1; foreach (var proName in proNames) { row = table.NewRow(); row[0] = unitWork.MainItemCode + b.ToString(); row[1] = a + "." + b; row[2] = string.Empty; row[3] = proName; table.Rows.Add(row); int c = 1; var contractTracks = getContractTracks.Where(x => x.MainItemCode == unitWork.MainItemCode && x.MajorName == proName); foreach (Model.PHTGL_ContractTrack item in contractTracks) { row = table.NewRow(); row[0] = item.Id; row[1] = a + "." + b + "." + c; row[2] = item.ProjectCode; row[3] = item.ProjectName; row[4] = item.UnitOfMeasurement; row[7] = item.Id; if (workEfficiencys.Count() > 0) { var we = (from x in workEfficiencys where x.ContractTrackId == item.Id select new { x.ConstructionLogId, x.ContractTrackId, x.PhysicalCompletionQuantity, x.MaterialConsumption }).Distinct().ToList(); decimal physicalCompletionQuantity = 0, materialConsumption = 0; if (we.Count() > 0) { foreach (var w in we) { physicalCompletionQuantity += w.PhysicalCompletionQuantity ?? 0; materialConsumption += w.MaterialConsumption ?? 0; } row[5] = physicalCompletionQuantity; row[6] = materialConsumption; } for (int i = 0; i < workPostIds.Count; i++) { var workEfficiencyList = workEfficiencys.Where(x => x.Type == "Person" && x.TypeId == workPostIds[i] && x.ContractTrackId == item.Id); if (workEfficiencyList.Count() > 0) { decimal d = 0; foreach (var workEfficiency in workEfficiencyList) { if (workEfficiency.ConsumeHours != null) { d += decimal.Round(Convert.ToDecimal(workEfficiency.ConsumeHours), 2); } } if (d > 0) { row[8 + i * 2] = decimal.Round(d, 2); if (physicalCompletionQuantity > 0) { row[9 + i * 2] = decimal.Round(Convert.ToDecimal(physicalCompletionQuantity / d), 2); } } } } for (int i = 0; i < machineIds.Count; i++) { var workEfficiencyList = workEfficiencys.Where(x => x.Type == "Machine" && x.TypeId == machineIds[i] && x.ContractTrackId == item.Id); if (workEfficiencyList.Count() > 0) { decimal d = 0; foreach (var workEfficiency in workEfficiencyList) { if (workEfficiency.ConsumeHours != null) { d += decimal.Round(Convert.ToDecimal(workEfficiency.ConsumeHours), 2); } } if (d > 0) { row[48 + i * 2] = decimal.Round(d, 2); if (physicalCompletionQuantity > 0) { row[49 + i * 2] = decimal.Round(Convert.ToDecimal(physicalCompletionQuantity / d), 2); } } } } } table.Rows.Add(row); c++; } b++; } a++; } return table; } } } public class PHTGL_ContractTrackDtoIn { /// /// 主项号 /// [ExcelColumnIndex("B")] public string MainItemCode { get; set; } /// /// 主项名称 /// [ExcelColumnIndex("C")] public string MainItemName { get; set; } /// /// 专业代码 /// [ExcelColumnIndex("D")] public string MajorCode { get; set; } /// /// 专业工程名称 /// [ExcelColumnIndex("E")] public string MajorName { get; set; } /// /// 项目编码 /// [ExcelColumnIndex("F")] public string ProjectCode { get; set; } /// /// 项目名称 /// [ExcelColumnIndex("G")] public string ProjectName { get; set; } /// /// 项目特征描述 /// [ExcelColumnIndex("H")] public string ProjectDescription { get; set; } /// /// 计量单位 /// [ExcelColumnIndex("I")] public string UnitOfMeasurement { get; set; } /// /// 工程量 /// [ExcelColumnIndex("J")] public string Quantity { get; set; } /// /// 全费用固定综合单价 /// [ExcelColumnIndex("K")] public string TotalCostFixedComprehensiveUnitPrice { get; set; } /// /// 其中:主材费 /// [ExcelColumnIndex("L")] public string MainMaterialCost { get; set; } /// /// 合价/元 /// [ExcelColumnIndex("M")] public string TotalPrice { get; set; } /// /// 计算规则 /// [ExcelColumnIndex("N")] public string CalculationRule { get; set; } /// /// 工作内容 /// [ExcelColumnIndex("O")] public string WorkContent { get; set; } /// /// 备注 /// [ExcelColumnIndex("P")] public string Remarks { get; set; } } }