2026-04-01 09:49:34 +08:00
using BLL ;
using System ;
using System.Collections.Generic ;
using System.Data ;
using System.Data.SqlClient ;
using System.Linq ;
using System.Text ;
namespace FineUIPro.Web.ReportManage.HazardFactor
{
public partial class HazardFactorSafetySummary : PageBase
{
/// <summary>
/// 项目id
/// </summary>
public string ProjectId
{
get
{
return ( string ) ViewState [ "ProjectId" ] ;
}
set
{
ViewState [ "ProjectId" ] = value ;
}
}
#region 加 载 页 面
/// <summary>
/// 加载页面
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void Page_Load ( object sender , EventArgs e )
{
if ( ! IsPostBack )
{
BLL . ProjectService . InitProjectDropDownList ( this . drpProject , true ) ;
BLL . ConstValue . InitConstValueDropDownList ( this . drpMonth , ConstValue . Group_0009 , true ) ;
BLL . ConstValue . InitConstValueDropDownList ( this . drpYear , ConstValue . Group_0008 , true ) ;
Funs . DropDownPageSize ( this . ddlPageSize ) ;
////权限按钮方法
this . GetButtonPower ( ) ;
ddlPageSize . SelectedValue = Grid1 . PageSize . ToString ( ) ;
// 绑定表格
BindGrid ( ) ;
}
}
/// <summary>
/// 绑定数据
/// </summary>
private void BindGrid ( )
{
StringBuilder sb = new StringBuilder ( ) ;
List < SqlParameter > listStr = new List < SqlParameter > ( ) ;
2026-04-02 17:00:38 +08:00
string dedupe = rbDedupe . SelectedValue ;
if ( ! string . IsNullOrWhiteSpace ( dedupe ) )
{
sb . Append ( "WITH CTE AS ( " ) ;
if ( dedupe = = "0" )
{ //按月
sb . Append ( "SELECT ROW_NUMBER() OVER (PARTITION BY tba.Year,tba.Month,tba.WorkPlace,tba.JobStep,tba.Hazard,tba.Consequence,tba.Illegality,tba.BaseRiskSeverity,tba.BaseRiskProbability,tba.BaseRiskScore,tba.BaseRiskLevel,tba.BaseRiskAcceptabity,tba.NetRiskControlMeasures,tba.NetRiskSeverity,tba.NetRiskProbability,tba.NetRiskScore,tba.NetRiskLevel,tba.NetRiskAcceptabity,tba.AdditionalControlMeasures ORDER BY CompileDate desc) as rn,tbb.ProjectName,tba.* " ) ;
}
else
{ //按年
sb . Append ( "SELECT ROW_NUMBER() OVER (PARTITION BY tba.Year,tba.WorkPlace,tba.JobStep,tba.Hazard,tba.Consequence,tba.Illegality,tba.BaseRiskSeverity,tba.BaseRiskProbability,tba.BaseRiskScore,tba.BaseRiskLevel,tba.BaseRiskAcceptabity,tba.NetRiskControlMeasures,tba.NetRiskSeverity,tba.NetRiskProbability,tba.NetRiskScore,tba.NetRiskLevel,tba.NetRiskAcceptabity,tba.AdditionalControlMeasures ORDER BY CompileDate desc) as rn,tbb.ProjectName,tba.* " ) ;
}
}
else
{
sb . Append ( "SELECT tbb.ProjectName,tba.* " ) ;
}
2026-04-01 09:49:34 +08:00
sb . Append ( "FROM HazardFactor_Safety AS tba WITH(NOLOCK) " ) ;
sb . Append ( "LEFT JOIN Base_Project AS tbb WITH(NOLOCK) ON tbb.ProjectId = tba.ProjectId " ) ;
sb . Append ( "WHERE 1=1 AND tba.State = 1 " ) ; //取已提交数据
if ( ! string . IsNullOrWhiteSpace ( this . drpProject . SelectedValue ) & & this . drpProject . SelectedValue ! = Const . _Null )
{
sb . Append ( "AND tba.ProjectId = @ProjectId " ) ;
listStr . Add ( new SqlParameter ( "@ProjectId" , this . drpProject . SelectedValue ) ) ;
}
if ( ! string . IsNullOrWhiteSpace ( this . drpYear . SelectedValue ) & & this . drpYear . SelectedValue ! = Const . _Null )
{
sb . Append ( "AND tba.Year = @Year " ) ;
listStr . Add ( new SqlParameter ( "@Year" , this . drpYear . SelectedValue ) ) ;
}
if ( ! string . IsNullOrWhiteSpace ( this . drpMonth . SelectedValue ) & & this . drpMonth . SelectedValue ! = Const . _Null )
{
string month = this . drpMonth . SelectedValue ;
sb . Append ( "AND tba.Month = @Month " ) ;
listStr . Add ( new SqlParameter ( "@Month" , month . Length = = 1 ? $"0{month}" : month ) ) ;
}
//if (!string.IsNullOrEmpty(this.rbState.SelectedValue))
//{
// sb.Append("AND tba.State = @State ");
// listStr.Add(new SqlParameter("@State", this.rbState.SelectedValue));
//}
if ( ! string . IsNullOrEmpty ( this . rbIllegality . SelectedValue ) )
{
sb . Append ( "AND tba.Illegality = @Illegality " ) ;
listStr . Add ( new SqlParameter ( "@Illegality" , this . rbIllegality . SelectedValue = = "1" ? true : false ) ) ;
}
2026-04-02 17:00:38 +08:00
if ( ! string . IsNullOrWhiteSpace ( dedupe ) )
{
sb . Append ( ") " ) ;
sb . Append ( "SELECT * FROM CTE WHERE rn = 1; " ) ;
}
string sqlStr = sb . ToString ( ) ;
2026-04-01 09:49:34 +08:00
SqlParameter [ ] parameter = listStr . ToArray ( ) ;
2026-04-02 17:00:38 +08:00
DataTable tb = SQLHelper . GetDataTableRunText ( sqlStr , parameter ) ;
2026-04-01 09:49:34 +08:00
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 )
{
Grid1 . PageIndex = e . NewPageIndex ;
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 )
{
btnMenuView_Click ( null , null ) ;
}
#endregion
#region 查 看
/// <summary>
/// 查看按钮
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void btnMenuView_Click ( object sender , EventArgs e )
{
if ( Grid1 . SelectedRowIndexArray . Length = = 0 )
{
Alert . ShowInTop ( "请至少选择一条记录!" , MessageBoxIcon . Warning ) ;
return ;
}
string HazardID = Grid1 . SelectedRowID . Split ( ',' ) [ 0 ] ;
var model = Funs . DB . HazardFactor_Safety . FirstOrDefault ( x = > x . ID = = HazardID ) ;
if ( model ! = null )
{
PageContext . RegisterStartupScript ( Window1 . GetShowReference ( String . Format ( "HazardFactorSafetyView.aspx?HazardID={0}" , HazardID , "查看 - " ) ) ) ;
}
}
#endregion
#region 删 除
/// <summary>
/// 批量删除
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void btnMenuDel_Click ( object sender , EventArgs e )
{
if ( Grid1 . SelectedRowIndexArray . Length > 0 )
{
var db = Funs . DB ;
foreach ( int rowIndex in Grid1 . SelectedRowIndexArray )
{
string rowID = Grid1 . DataKeys [ rowIndex ] [ 0 ] . ToString ( ) ;
HazardFactorSafetyService . DeleteHazardFactorSafetyById ( rowID , this . CurrUser ) ;
}
BindGrid ( ) ;
ShowNotify ( "删除数据成功!" ) ;
}
}
#endregion
#region 获 取 按 钮 权 限
/// <summary>
/// 获取按钮权限
/// </summary>
/// <param name="button"></param>
/// <returns></returns>
private void GetButtonPower ( )
{
try
{
if ( Request . Params [ "value" ] = = "0" )
{
return ;
}
this . btnMenuView . Hidden = false ;
if ( this . CurrUser . UserId = = Const . hfnbdId | | this . CurrUser . UserId = = Const . sysglyId )
{
this . btnMenuDel . Hidden = false ;
}
}
catch ( Exception e )
{
}
}
#endregion
#region 导 出 按 钮
/// 导出按钮
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void btnOut_Click ( object sender , EventArgs e )
{
Response . ClearContent ( ) ;
2026-04-02 17:00:38 +08:00
string year = ! string . IsNullOrWhiteSpace ( this . drpYear . SelectedValue ) & & this . drpYear . SelectedValue ! = Const . _Null ? $"{this.drpYear.SelectedValue}年" : string . Empty ;
string month = ! string . IsNullOrWhiteSpace ( this . drpMonth . SelectedValue ) & & this . drpMonth . SelectedValue ! = Const . _Null ? $"{this.drpMonth.SelectedValue}月" : string . Empty ;
string fileName = System . Web . HttpUtility . UrlEncode ( $"{year}{month}安全危害因素清单" + Funs . GetNewFileName ( ) , System . Text . Encoding . UTF8 ) ;
Response . AddHeader ( "content-disposition" , "attachment; filename=" + fileName + ".xls" ) ;
2026-04-01 09:49:34 +08:00
Response . ContentType = "application/excel" ;
Response . ContentEncoding = System . Text . Encoding . UTF8 ;
this . Grid1 . PageSize = 10000 ;
this . BindGrid ( ) ;
Response . Write ( GetGridMultiHeaderTableHtml ( Grid1 ) ) ;
//Response.Write(GetGridTableHtml(Grid1));
Response . End ( ) ;
}
#endregion
/// <summary>
/// 格式化数据
/// </summary>
/// <param name="data"></param>
/// <returns></returns>
protected string ConvertDataState ( object data )
{
string result = string . Empty ;
string dataStr = data . ToString ( ) ;
if ( data ! = null )
{
result = dataStr = = "1" ? "已提交" : "未提交" ;
}
return result ;
}
}
}