2022-09-05 16:36:31 +08:00
using BLL ;
using System ;
using System.Collections.Generic ;
using System.Data ;
using System.Data.SqlClient ;
using System.Linq ;
namespace FineUIPro.Web.CQMS.Material
{
public partial class MaterialTest : PageBase
{
/// <summary>
/// 项目id
/// </summary>
public string ProjectId
{
get
{
return ( string ) ViewState [ "ProjectId" ] ;
}
set
{
ViewState [ "ProjectId" ] = value ;
}
}
protected void Page_Load ( object sender , EventArgs e )
{
if ( ! IsPostBack )
{
this . ProjectId = this . CurrUser . LoginProjectId ;
2023-06-26 15:42:26 +08:00
BLL . UnitService . InitUnitDropDownList ( this . drpUnit , this . ProjectId , true ) ;
2022-09-05 16:36:31 +08:00
btnNew . OnClientClick = Window1 . GetShowReference ( "MaterialTestEdit.aspx" ) + "return false;" ;
GetButtonPower ( ) ;
BindGrid ( ) ;
}
}
/// <summary>
/// 绑定数据
/// </summary>
public void BindGrid ( )
{
DataTable tb = ChecklistData ( ) ;
Grid1 . RecordCount = tb . Rows . Count ;
tb = GetFilteredTable ( Grid1 . FilteredData , tb ) ;
var table = this . GetPagedDataTable ( Grid1 , tb ) ;
Grid1 . DataSource = table ;
Grid1 . DataBind ( ) ;
}
protected DataTable ChecklistData ( )
{
string strSql = @ "select C.*,I.InspectionCode,U.UnitName,M.MaterialTypeName,CU.UnitName as CheckUnitName,case CheckResult when 1 then '合格' when 0 then '不合格' else '' end as CheckResultStr from [dbo].[Material_MaterialTest] C
left join [ dbo ] . [ Base_Unit ] CU on C . CheckUnit = CU . UnitId
left join [ dbo ] . [ Base_MaterialType ] M on C . MaterialTypeId = M . MaterialTypeId
left join [ dbo ] . [ Material_Inspection ] I on C . InspectionId = I . InspectionId
left join [ dbo ] . [ Base_Unit ] U on U . UnitId = C . UnitId where 1 = 1 ";
List < SqlParameter > listStr = new List < SqlParameter > ( ) ;
strSql + = " AND C.ProjectId = @ProjectId" ;
listStr . Add ( new SqlParameter ( "@ProjectId" , this . ProjectId ) ) ;
if ( drpUnit . SelectedValue ! = BLL . Const . _Null )
{
strSql + = " AND C.UnitId=@UnitId" ;
listStr . Add ( new SqlParameter ( "@UnitId" , drpUnit . SelectedValue ) ) ;
}
SqlParameter [ ] parameter = listStr . ToArray ( ) ;
DataTable tb = SQLHelper . GetDataTableRunText ( strSql , parameter ) ;
return tb ;
}
/// <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 ( ) ;
}
//右键编辑
protected void btnMenuModify_Click ( object sender , EventArgs e )
{
EditData ( ) ;
}
//双击编辑
protected void Grid1_RowDoubleClick ( object sender , GridRowClickEventArgs e )
{
EditData ( ) ;
}
//分页
protected void Grid1_PageIndexChange ( object sender , GridPageEventArgs e )
{
BindGrid ( ) ;
}
/// <summary>
/// 编辑数据方法
/// </summary>
private void EditData ( )
{
if ( Grid1 . SelectedRowIndexArray . Length = = 0 )
{
Alert . ShowInTop ( "请至少选择一条记录" , MessageBoxIcon . Warning ) ;
return ;
}
PageContext . RegisterStartupScript ( Window1 . GetShowReference ( String . Format ( "MaterialTestEdit.aspx?MaterialTestId={0}" , Grid1 . SelectedRowID , "编辑 - " ) ) ) ;
}
//右键查看
protected void btnMenuView_Click ( object sender , EventArgs e )
{
if ( Grid1 . SelectedRowIndexArray . Length = = 0 )
{
Alert . ShowInTop ( "请至少选择一条记录" , MessageBoxIcon . Warning ) ;
return ;
}
PageContext . RegisterStartupScript ( Window1 . GetShowReference ( String . Format ( "MaterialTestView.aspx?MaterialTestId={0}" , Grid1 . SelectedRowID , "查看 - " ) ) ) ;
}
//右键删除
protected void btnMenuDel_Click ( object sender , EventArgs e )
{
if ( Grid1 . SelectedRowIndexArray . Length > 0 )
{
foreach ( int rowIndex in Grid1 . SelectedRowIndexArray )
{
string rowID = Grid1 . DataKeys [ rowIndex ] [ 0 ] . ToString ( ) ;
var Unitwork = BLL . CQMS_MaterialTestService . GetMaterialTestByMaterialTestId ( rowID ) ;
if ( Unitwork ! = null )
{
BLL . CQMS_MaterialTestService . DeleteMaterialTestById ( rowID ) ;
}
}
BindGrid ( ) ;
ShowNotify ( "删除数据成功!" , MessageBoxIcon . Success ) ;
}
}
/// <summary>
/// 搜索
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void btnSearch_Click ( object sender , EventArgs e )
{
BindGrid ( ) ;
}
/// <summary>
/// 重置
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void btnRset_Click ( object sender , EventArgs e )
{
drpUnit . SelectedIndex = 0 ;
BindGrid ( ) ;
}
#region 获 取 按 钮 权 限
/// <summary>
/// 获取按钮权限
/// </summary>
/// <param name="button"></param>
/// <returns></returns>
private void GetButtonPower ( )
{
if ( Request . Params [ "value" ] = = "0" )
{
return ;
}
var buttonList = BLL . CommonService . GetAllButtonList ( this . ProjectId , this . CurrUser . PersonId , BLL . Const . MaterialTestMenuId ) ;
if ( buttonList . Count ( ) > 0 )
{
if ( buttonList . Contains ( BLL . Const . BtnAdd ) )
{
//this.btnNew.Hidden = false;
}
if ( buttonList . Contains ( BLL . Const . BtnModify ) )
{
this . btnMenuModify . Hidden = false ;
}
if ( buttonList . Contains ( BLL . Const . BtnDelete ) )
{
//this.btnMenuDel.Hidden = false;
}
}
}
#endregion
}
}