2023-03-25 14:46:00 +08:00
using BLL ;
using System ;
using System.Collections.Generic ;
using System.Data ;
using System.Data.SqlClient ;
using System.Linq ;
namespace FineUIPro.Web.DataShow
{
public partial class ProjectPerson : 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 ( ) ;
2023-06-07 18:55:33 +08:00
this . Panel1 . Title = "项目现场人员(" + BLL . UnitService . GetUnitNameByUnitId ( BLL . Const . UnitId_CWCEC ) + ") " ;
2023-03-25 14:46:00 +08:00
}
}
/// <summary>
/// 绑定数据
/// </summary>
private void BindGrid ( )
{
string strSql = @ "SELECT Person.ProjectId,Project.ProjectCode,Project.ProjectName,Unit.UnitId,Unit.UnitId,Unit.UnitName,
Person . PersonName , Person . PersonId , Person . IdentityCard , Person . Sex , Person . WorkPostId , WorkPost . WorkPostName , Person . Telephone
, ( CASE WHEN Sex = 2 THEN '女' WHEN Sex = 1 THEN '男' ELSE ' ' END ) AS SexStr
FROM SitePerson_Person AS Person
LEFT JOIN Base_Project AS Project ON Person . ProjectId = Project . ProjectId
LEFT JOIN Base_Unit AS Unit ON Person . UnitId = Unit . UnitId
LEFT JOIN Base_WorkPost AS WorkPost ON Person . WorkPostId = WorkPost . WorkPostId
WHERE IsUsed = 1 AND InTime < = GETDATE ( ) AND ( OutTime IS NULL OR OutTime > GETDATE ( ) ) ";
2025-04-23 15:19:37 +08:00
//在建项目数据
strSql + = " AND (Project.ProjectState = '1' OR Project.ProjectState IS NULL)" ;
2023-03-25 14:46:00 +08:00
List < SqlParameter > listStr = new List < SqlParameter > ( ) ;
if ( this . drpProject . SelectedValue ! = Const . _Null )
{
strSql + = " AND Person.ProjectId = @ProjectId" ;
listStr . Add ( new SqlParameter ( "@ProjectId" , this . drpProject . SelectedValue ) ) ;
}
if ( rbType . SelectedValue = = "0" )
{
strSql + = " AND Person.WorkPostId = @WorkPostId" ;
listStr . Add ( new SqlParameter ( "@WorkPostId" , Const . WorkPost_HSSEDirector ) ) ;
}
else if ( rbType . SelectedValue = = "1" )
{
strSql + = " AND WorkPost.IsHsse = 1" ;
}
else if ( rbType . SelectedValue = = "2" )
{
strSql + = " AND Person.IsSafetyMonitoring = 1" ;
}
else if ( rbType . SelectedValue = = "3" )
{
strSql + = " AND (SELECT COUNT(*) FROM QualityAudit_PersonQuality AS Q LEFT JOIN Base_Certificate AS Cer ON Q.CertificateId =Cer.CertificateId WHERE Q.PersonId = Person.PersonId AND IsRegisterHSSE =1) > 0" ;
}
else if ( rbType . SelectedValue = = "4" )
{
strSql + = " AND (SELECT COUNT(*) FROM QualityAudit_PersonQuality AS Q LEFT JOIN Base_Certificate AS Cer ON Q.CertificateId =Cer.CertificateId WHERE Q.PersonId = Person.PersonId AND CertificateType ='A') > 0" ;
}
else if ( rbType . SelectedValue = = "5" )
{
strSql + = " AND (SELECT COUNT(*) FROM QualityAudit_PersonQuality AS Q LEFT JOIN Base_Certificate AS Cer ON Q.CertificateId =Cer.CertificateId WHERE Q.PersonId = Person.PersonId AND CertificateType ='B') > 0" ;
}
else if ( rbType . SelectedValue = = "6" )
{
strSql + = " AND (SELECT COUNT(*) FROM QualityAudit_PersonQuality AS Q LEFT JOIN Base_Certificate AS Cer ON Q.CertificateId =Cer.CertificateId WHERE Q.PersonId = Person.PersonId AND CertificateType ='C') > 0" ;
}
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 ( ) ;
}
#endregion
#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
#region Grid双击事件 编 辑
/// <summary>
/// Grid行双击事件
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void Grid1_RowDoubleClick ( object sender , GridRowClickEventArgs e )
{
EditData ( ) ;
}
/// <summary>
///
/// </summary>
private void EditData ( )
{
if ( Grid1 . SelectedRowIndexArray . Length = = 0 )
{
Alert . ShowInTop ( "请至少选择一条记录!" , MessageBoxIcon . Warning ) ;
return ;
}
2023-03-28 17:41:09 +08:00
PageContext . RegisterStartupScript ( Window1 . GetShowReference ( String . Format ( "../HSSE/SitePerson/PersonListEdit.aspx?PersonId={0}&type=show" , Grid1 . SelectedRowID , "查看 - " ) ) ) ;
2023-03-25 14:46:00 +08:00
}
#endregion
protected void btnView_Click ( object sender , EventArgs e )
{
EditData ( ) ;
}
}
}