2023-11-10
This commit is contained in:
+70
-58
@@ -1,13 +1,16 @@
|
||||
using BLL;
|
||||
using Newtonsoft.Json.Linq;
|
||||
using System;
|
||||
using System.Collections.Concurrent;
|
||||
using System.Collections.Generic;
|
||||
using System.Data;
|
||||
using System.Linq;
|
||||
using System.Text;
|
||||
using System.Threading.Tasks;
|
||||
using System.Web;
|
||||
using System.Web.UI;
|
||||
using System.Web.UI.WebControls;
|
||||
using Model;
|
||||
|
||||
namespace FineUIPro.Web.PHTGL.ContractCompile
|
||||
{
|
||||
@@ -60,12 +63,12 @@ namespace FineUIPro.Web.PHTGL.ContractCompile
|
||||
Model.PHTGL_ContractTrack queryContractTrack = new Model.PHTGL_ContractTrack();
|
||||
queryContractTrack.ProjectId = this.CurrUser.LoginProjectId;
|
||||
queryContractTrack.ContractId = this.ContractId;
|
||||
var modelContractTracks = BLL.PhtglContractTrackService.GetPHTGL_ContractTrackByModle(queryContractTrack);
|
||||
if (modelContractTracks.Count==0) return;
|
||||
var modelContractTracks = BLL.PhtglContractTrackService.GetFirstPHTGL_ContractTrackByModle(queryContractTrack);
|
||||
if (modelContractTracks==null) return;
|
||||
|
||||
|
||||
Model.PHTGL_ContractTrackProgress table = new Model.PHTGL_ContractTrackProgress();
|
||||
table.ContractTrackId = modelContractTracks[0].Id;
|
||||
table.ContractTrackId = modelContractTracks.Id;
|
||||
var tb = BLL.PhtglContracttrackprogressService.GetPHTGL_ContractTrackProgressByModle(table);
|
||||
foreach (var item in tb)
|
||||
{
|
||||
@@ -81,8 +84,8 @@ namespace FineUIPro.Web.PHTGL.ContractCompile
|
||||
|
||||
GroupField p1BCWS = new GroupField();
|
||||
p1BCWS.HeaderText = "BCWS";
|
||||
p1BCWS.TextAlign = TextAlign.Center;
|
||||
|
||||
p1BCWS.TextAlign = TextAlign.Center;
|
||||
p1BCWS.Attributes["data-color"] = "color1";
|
||||
GroupField p1ACWP = new GroupField();
|
||||
p1ACWP.HeaderText = "ACWP";
|
||||
p1ACWP.TextAlign = TextAlign.Center;
|
||||
@@ -97,7 +100,7 @@ namespace FineUIPro.Web.PHTGL.ContractCompile
|
||||
GroupField p2BCWS = new GroupField();
|
||||
p2BCWS.HeaderText = "BCWS";
|
||||
p2BCWS.TextAlign = TextAlign.Center;
|
||||
|
||||
p2BCWS.Attributes["data-color"] = "color1";
|
||||
GroupField p2ACWP = new GroupField();
|
||||
p2ACWP.HeaderText = "ACWP";
|
||||
p2ACWP.TextAlign = TextAlign.Center;
|
||||
@@ -254,10 +257,10 @@ namespace FineUIPro.Web.PHTGL.ContractCompile
|
||||
Grid1.Columns.Add(p);
|
||||
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
}
|
||||
#endregion
|
||||
public string ContractId
|
||||
{
|
||||
@@ -284,9 +287,8 @@ namespace FineUIPro.Web.PHTGL.ContractCompile
|
||||
/// </summary>
|
||||
private void BindGrid()
|
||||
{
|
||||
if (!string .IsNullOrEmpty(ContractId))
|
||||
if (!string.IsNullOrEmpty(ContractId))
|
||||
{
|
||||
DataRow row;
|
||||
Model.PHTGL_ContractTrack queryContractTrack = new Model.PHTGL_ContractTrack();
|
||||
queryContractTrack.ProjectId = this.CurrUser.LoginProjectId;
|
||||
queryContractTrack.ContractId = this.ContractId;
|
||||
@@ -298,57 +300,72 @@ namespace FineUIPro.Web.PHTGL.ContractCompile
|
||||
|
||||
var modelContractTracks =
|
||||
BLL.PhtglContractTrackService.GetPHTGL_ContractTrackByModle(queryContractTrack);
|
||||
|
||||
|
||||
var count = BLL.PhtglContractTrackService.GetPHTGL_ContractTrackByModle(queryContractTrack).Count();
|
||||
modelContractTracks= modelContractTracks.Skip(Grid1.PageSize * Grid1.PageIndex).Take(Grid1.PageSize).ToList();
|
||||
foreach (var item in modelContractTracks)
|
||||
modelContractTracks = modelContractTracks.Skip(Grid1.PageSize * Grid1.PageIndex).Take(Grid1.PageSize).ToList();
|
||||
|
||||
var splitContractTracks = Funs.SplitList(modelContractTracks, 10);
|
||||
|
||||
ParallelOptions parallelOptions = new ParallelOptions();
|
||||
parallelOptions.MaxDegreeOfParallelism = Environment.ProcessorCount;
|
||||
var concurrentGridTable = new ConcurrentDictionary<string, DataRow>();
|
||||
// 使用 Parallel.ForEach 来并行处理拆分后的列表
|
||||
Parallel.ForEach(splitContractTracks, parallelOptions, sublist =>
|
||||
{
|
||||
row= GridTable.NewRow();
|
||||
row["Id"] = item.Id;
|
||||
row["MainItemCode"] = item.MainItemCode;
|
||||
row["MainItemName"] = item.MainItemName;
|
||||
row["MajorName"] = item.MajorName;
|
||||
row["MajorCode"] = item.MajorCode;
|
||||
//row["SubProject"] = item.SubProject;
|
||||
//row["SubItemProject"] = item.SubItemProject;
|
||||
row["ProjectCode"] = item.ProjectCode;
|
||||
row["ProjectName"] = item.ProjectName;
|
||||
row["ProjectDescription"] = item.ProjectDescription;
|
||||
row["UnitOfMeasurement"] = item.UnitOfMeasurement;
|
||||
|
||||
Model.PHTGL_ContractTrackProgress qContractTrackProgress = new Model.PHTGL_ContractTrackProgress();
|
||||
qContractTrackProgress.ContractTrackId = item.Id;
|
||||
var modelContractTrackProgresses = BLL.PhtglContracttrackprogressService.GetPHTGL_ContractTrackProgressByModle(qContractTrackProgress);
|
||||
foreach (var detail in modelContractTrackProgresses)
|
||||
var tempTable = GridTable.Clone(); // 创建临时的 DataTable
|
||||
foreach (var item in sublist)
|
||||
{
|
||||
// var date=detail.Date.Replace("-", "");
|
||||
var date=detail.Date + "#";
|
||||
row[date+ "BCWS_Quantity"] = detail.BCWS_Quantity;
|
||||
row[date+ "BCWS_OutputValue"] = detail.BCWS_OutputValue;
|
||||
row[date+ "BCWS_Percentage"] = detail.BCWS_Percentage;
|
||||
row[date+ "ACWP_Quantity"] = detail.ACWP_Quantity;
|
||||
row[date+ "ACWP_OutputValue"] = detail.ACWP_OutputValue;
|
||||
row[date+ "ACWP_Percentage"] = detail.ACWP_Percentage;
|
||||
DataRow row = tempTable.NewRow();
|
||||
row["Id"] = item.Id;
|
||||
row["MainItemCode"] = item.MainItemCode;
|
||||
row["MainItemName"] = item.MainItemName;
|
||||
row["MajorName"] = item.MajorName;
|
||||
row["MajorCode"] = item.MajorCode;
|
||||
//row["SubProject"] = item.SubProject;
|
||||
//row["SubItemProject"] = item.SubItemProject;
|
||||
row["ProjectCode"] = item.ProjectCode;
|
||||
row["ProjectName"] = item.ProjectName;
|
||||
row["ProjectDescription"] = item.ProjectDescription;
|
||||
row["UnitOfMeasurement"] = item.UnitOfMeasurement;
|
||||
|
||||
var SumModel = PhtglContracttrackprogressService.GetSumProgress(detail.ContractTrackProgressId);
|
||||
row[date + "SumBCWS_Quantity"] = SumModel.BCWS_Quantity;
|
||||
row[date + "SumBCWS_OutputValue"] = SumModel.BCWS_OutputValue;
|
||||
row[date + "SumBCWS_Percentage"] = SumModel.BCWS_Percentage;
|
||||
row[date + "SumACWP_Quantity"] = SumModel.ACWP_Quantity;
|
||||
row[date + "SumACWP_OutputValue"] = SumModel.ACWP_OutputValue;
|
||||
row[date + "SumACWP_Percentage"] = SumModel.ACWP_Percentage;
|
||||
Model.PHTGL_ContractTrackProgress qContractTrackProgress = new Model.PHTGL_ContractTrackProgress();
|
||||
qContractTrackProgress.ContractTrackId = item.Id;
|
||||
var modelContractTrackProgresses = BLL.PhtglContracttrackprogressService.GetPHTGL_ContractTrackProgressByModle(qContractTrackProgress);
|
||||
foreach (var detail in modelContractTrackProgresses)
|
||||
{
|
||||
// var date=detail.Date.Replace("-", "");
|
||||
var date = detail.Date + "#";
|
||||
row[date + "BCWS_Quantity"] = detail.BCWS_Quantity;
|
||||
row[date + "BCWS_OutputValue"] = detail.BCWS_OutputValue;
|
||||
row[date + "BCWS_Percentage"] = detail.BCWS_Percentage;
|
||||
row[date + "ACWP_Quantity"] = detail.ACWP_Quantity;
|
||||
row[date + "ACWP_OutputValue"] = detail.ACWP_OutputValue;
|
||||
row[date + "ACWP_Percentage"] = detail.ACWP_Percentage;
|
||||
|
||||
var SumModel = PhtglContracttrackprogressService.GetSumProgress(detail.ContractTrackProgressId);
|
||||
row[date + "SumBCWS_Quantity"] = SumModel.BCWS_Quantity;
|
||||
row[date + "SumBCWS_OutputValue"] = SumModel.BCWS_OutputValue;
|
||||
row[date + "SumBCWS_Percentage"] = SumModel.BCWS_Percentage;
|
||||
row[date + "SumACWP_Quantity"] = SumModel.ACWP_Quantity;
|
||||
row[date + "SumACWP_OutputValue"] = SumModel.ACWP_OutputValue;
|
||||
row[date + "SumACWP_Percentage"] = SumModel.ACWP_Percentage;
|
||||
}
|
||||
concurrentGridTable.TryAdd(item.Id, row);
|
||||
// GridTable.Rows.Add(row);
|
||||
}
|
||||
|
||||
GridTable.Rows.Add(row);
|
||||
});
|
||||
// 将线程安全的数据拷贝到 GridTable
|
||||
foreach (var kvp in concurrentGridTable)
|
||||
{
|
||||
DataRow newRow = GridTable.NewRow();
|
||||
newRow.ItemArray = kvp.Value.ItemArray; // 使用 ImportRow 方法创建新的行
|
||||
GridTable.Rows.Add(newRow);
|
||||
}
|
||||
|
||||
Grid1.RecordCount = count;
|
||||
Grid1.DataSource = GridTable;
|
||||
Grid1.DataBind();
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
}
|
||||
protected void Grid1_OnRowDataBound(object sender, GridRowEventArgs e)
|
||||
{
|
||||
if (!string.IsNullOrEmpty(ContractId))
|
||||
@@ -357,7 +374,7 @@ namespace FineUIPro.Web.PHTGL.ContractCompile
|
||||
queryContractTrack.ProjectId = this.CurrUser.LoginProjectId;
|
||||
queryContractTrack.ContractId = this.ContractId;
|
||||
var modelContractTracks = BLL.PhtglContractTrackService.GetFirstPHTGL_ContractTrackByModle(queryContractTrack);
|
||||
if (modelContractTracks ==null) return;
|
||||
if (modelContractTracks == null) return;
|
||||
Model.PHTGL_ContractTrackProgress qContractTrackProgress = new Model.PHTGL_ContractTrackProgress();
|
||||
qContractTrackProgress.ContractTrackId = modelContractTracks.Id;
|
||||
var modelContractTrackProgresses = BLL.PhtglContracttrackprogressService.GetPHTGL_ContractTrackProgressByModle(qContractTrackProgress);
|
||||
@@ -381,13 +398,8 @@ namespace FineUIPro.Web.PHTGL.ContractCompile
|
||||
e.CellAttributes[bf3.ColumnIndex]["data-color"] = "color1";
|
||||
e.CellAttributes[bf4.ColumnIndex]["data-color"] = "color1";
|
||||
|
||||
|
||||
}
|
||||
//foreach (var item in modelContractTracks)
|
||||
//{
|
||||
|
||||
|
||||
|
||||
//}
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user