2024-11-19 09:45:27 +08:00
using BLL ;
using FineUIPro.Web.BaseInfo ;
using System ;
using System.Collections.Generic ;
using System.Data ;
using System.Data.SqlClient ;
using System.Linq ;
namespace FineUIPro.Web.DataShow
{
public partial class QualityAcceptance : PageBase
{
#region 加 载 页 面
/// <summary>
/// 加载页面
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void Page_Load ( object sender , EventArgs e )
{
if ( ! IsPostBack )
{
Funs . DropDownPageSize ( this . ddlPageSize ) ;
ddlPageSize . SelectedValue = Grid1 . PageSize . ToString ( ) ;
BLL . ProjectService . InitProjectDropDownList ( this . drpProject , true ) ;
// 绑定表格t
BindGrid ( ) ;
2025-08-08 17:54:10 +08:00
this . Panel1 . Title = "质量验收数据(" + BLL . UnitService . GetUnitNameByUnitId ( BLL . Const . UnitId_XJYJ ) + ") " ;
2024-11-19 09:45:27 +08:00
}
}
#endregion
/// <summary>
/// 绑定数据
/// </summary>
private void BindGrid ( )
{
string strSql = @"select ProjectId,ProjectCode, ProjectName + ( select top 1 case when ProjectState2 is null then '' when ProjectState2 !=3 then '<span style=""color:red"" >'+ ConstText+'<span/>' else ''end from Sys_Const where GroupId ='ProjectState' and (ProjectState2 is null or ProjectState2=ConstValue )) ProjectName from Base_Project where (ProjectAttribute='GONGCHENG' OR ProjectAttribute IS NULL ) and (isDelete is null or isDelete =0) and ProjectState =1 " ;
List < SqlParameter > listStr = new List < SqlParameter > ( ) ;
string cpara = string . Empty ;
if ( this . drpProject . SelectedValue ! = Const . _Null )
{
strSql + = " AND projectId = @projectId" ; ///状态为已完成
listStr . Add ( new SqlParameter ( "@projectId" , this . drpProject . SelectedValue ) ) ;
}
//if (!string.IsNullOrEmpty(this.txtStartTime.Text))
//{
// strSql += " AND h.RegisterDate >=@StartTime";
// listStr.Add(new SqlParameter("@StartTime", this.txtStartTime.Text));
// cpara += " AND c.RegisterDate >=" + this.txtStartTime.Text;
//}
//if (!string.IsNullOrEmpty(this.txtEndTime.Text))
//{
// strSql += " AND h.RegisterDate <=@EndTime";
// listStr.Add(new SqlParameter("@EndTime", this.txtEndTime.Text));
// cpara += " AND c.RegisterDate <=" + this.txtEndTime.Text;
//}
SqlParameter [ ] parameter = listStr . ToArray ( ) ;
DataTable tb = SQLHelper . GetDataTableRunText ( strSql , parameter ) ;
Grid1 . RecordCount = tb . Rows . Count ;
var table = this . GetPagedDataTable ( Grid1 , tb ) ;
Grid1 . DataSource = table ;
Grid1 . DataBind ( ) ;
}
#region 查 询
/// <summary>
/// 查询
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void TextBox_TextChanged ( object sender , EventArgs e )
{
this . BindGrid ( ) ;
}
#endregion
#region 表 排 序 、 分 页 、 关 闭 窗 口
/// <summary>
/// 分页
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void Grid1_PageIndexChange ( object sender , GridPageEventArgs e )
{
BindGrid ( ) ;
}
/// <summary>
/// 排序
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void Grid1_Sort ( object sender , GridSortEventArgs e )
{
BindGrid ( ) ;
}
/// <summary>
/// 分页显示条数下拉框
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void ddlPageSize_SelectedIndexChanged ( object sender , EventArgs e )
{
Grid1 . PageSize = Convert . ToInt32 ( ddlPageSize . SelectedValue ) ;
BindGrid ( ) ;
}
/// <summary>
/// 关闭弹出窗
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void Window1_Close ( object sender , WindowCloseEventArgs e )
{
BindGrid ( ) ;
}
#endregion
/// <summary>
/// 定义变量
/// </summary>
private static IQueryable < Model . QualityAcceptanceItem > getDataItemLists = from x in Funs . DB . ProcessControl_InspectionManagementDetail
join y in Funs . DB . ProcessControl_InspectionManagement on x . InspectionId equals y . InspectionId
join z in Funs . DB . WBS_BreakdownProject on x . ControlPointType equals z . BreakdownProjectId
select new Model . QualityAcceptanceItem
{
InspectionDetailId = x . InspectionDetailId ,
ProjectId = z . ProjectId ,
CheckAcceptType = z . CheckAcceptType ,
IsOnceQualified = y . IsOnceQualified
} ;
/// <summary>
/// 数量
/// </summary>
/// <param name="state"></param>
/// <returns></returns>
protected int Count1 ( object projectId )
{
int cout1 = 0 ;
if ( projectId ! = null )
{
var getT = getDataItemLists . Where ( x = > x . ProjectId = = projectId . ToString ( ) & & x . CheckAcceptType = = this . rbType . SelectedValue ) ;
cout1 = getT . Count ( ) ;
}
return cout1 ;
}
/// <summary>
/// 数量
/// </summary>
/// <param name="state"></param>
/// <returns></returns>
protected int Count2 ( object projectId )
{
int cout1 = 0 ;
if ( projectId ! = null )
{
var getT = getDataItemLists . Where ( x = > x . ProjectId = = projectId . ToString ( ) & & x . CheckAcceptType = = this . rbType . SelectedValue & & x . IsOnceQualified = = true ) ;
cout1 = getT . Count ( ) ;
}
return cout1 ;
}
/// <summary>
/// 数量
/// </summary>
/// <param name="state"></param>
/// <returns></returns>
protected int Count3 ( object projectId )
{
int cout1 = 0 ;
if ( projectId ! = null )
{
var getT1 = getDataItemLists . Where ( x = > x . ProjectId = = projectId . ToString ( ) & & x . CheckAcceptType = = this . rbType . SelectedValue ) ;
var getT2 = getDataItemLists . Where ( x = > x . ProjectId = = projectId . ToString ( ) & & x . CheckAcceptType = = this . rbType . SelectedValue & & x . IsOnceQualified = = true ) ;
cout1 = getT1 . Count ( ) - getT2 . Count ( ) ;
}
return cout1 ;
}
/// <summary>
/// 数量
/// </summary>
/// <param name="state"></param>
/// <returns></returns>
protected string Count4 ( object projectId )
{
string rate = string . Empty ;
if ( projectId ! = null )
{
var getT1 = getDataItemLists . Where ( x = > x . ProjectId = = projectId . ToString ( ) & & x . CheckAcceptType = = this . rbType . SelectedValue ) ;
var getT2 = getDataItemLists . Where ( x = > x . ProjectId = = projectId . ToString ( ) & & x . CheckAcceptType = = this . rbType . SelectedValue & & x . IsOnceQualified = = true ) ;
if ( getT1 . Count ( ) > 0 )
{
rate = Math . Round ( getT2 . Count ( ) * 1.0 / getT1 . Count ( ) * 100 , 2 ) . ToString ( ) ;
}
}
return rate ;
}
}
}