2021-04-30 10:28:37 +08:00
using BLL ;
using System ;
using System.Collections.Generic ;
using System.Data ;
using System.Data.SqlClient ;
using System.IO ;
using System.Linq ;
using System.Text ;
using System.Web.UI ;
namespace FineUIPro.Web.HSSE.EduTrain
{
public partial class TrainTestDB : PageBase
{
public string TrainTestId
{
get
{
return ( string ) ViewState [ "TrainTestId" ] ;
}
set
{
ViewState [ "TrainTestId" ] = value ;
}
}
protected void Page_Load ( object sender , EventArgs e )
{
if ( ! IsPostBack )
{
Funs . DropDownPageSize ( this . ddlPageSize ) ;
this . GetButtonPower ( ) ;
btnSelectColumns . OnClientClick = Window1 . GetShowReference ( "TrainTestDBSelectCloumn.aspx" ) ;
InitTreeMenu ( ) ;
}
}
private void InitTreeMenu ( )
{
this . trTrainTestDB . Nodes . Clear ( ) ;
this . trTrainTestDB . ShowBorder = false ;
this . trTrainTestDB . ShowHeader = false ;
this . trTrainTestDB . EnableIcons = true ;
this . trTrainTestDB . AutoScroll = true ;
this . trTrainTestDB . EnableSingleClickExpand = true ;
TreeNode rootNode = new TreeNode
{
Text = "安全试题库" ,
NodeID = "0" ,
Expanded = true
} ;
this . trTrainTestDB . Nodes . Add ( rootNode ) ;
BoundTree ( rootNode . Nodes , "0" ) ;
}
/// <summary>
/// 加载树
/// </summary>
/// <param name="nodes"></param>
/// <param name="menuId"></param>
private void BoundTree ( TreeNodeCollection nodes , string menuId )
{
var dt = BLL . TrainTestDBService . GetTrainTestDBBySupTrainTestId ( menuId ) ;
if ( dt . Count ( ) > 0 )
{
TreeNode tn = null ;
foreach ( var dr in dt )
{
tn = new TreeNode
{
Text = dr . TrainTestName ,
NodeID = dr . TrainTestId ,
EnableClickEvent = true ,
ToolTip = dr . TrainTestName
} ;
nodes . Add ( tn ) ;
BoundTree ( tn . Nodes , dr . TrainTestId ) ;
}
}
}
/// <summary>
/// 添加安全试题类型按钮
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void btnNew_Click ( object sender , EventArgs e )
{
if ( this . trTrainTestDB . SelectedNode ! = null )
{
Model . Training_TrainTestDB trainTestDB = BLL . TrainTestDBService . GetTrainTestDBById ( this . trTrainTestDB . SelectedNode . NodeID ) ;
if ( ( trainTestDB ! = null & & trainTestDB . IsEndLever = = false ) | | this . trTrainTestDB . SelectedNode . NodeID = = "0" ) //根节点或者非末级节点,可以增加
{
PageContext . RegisterStartupScript ( Window1 . GetShowReference ( String . Format ( "TrainTestDBEdit.aspx?SupTrainingId={0}" , this . trTrainTestDB . SelectedNode . NodeID , "编辑 - " ) ) ) ;
}
else
{
ShowNotify ( "选择的项已是末级!" , MessageBoxIcon . Warning ) ;
}
}
else
{
ShowNotify ( "请选择树节点!" , MessageBoxIcon . Warning ) ;
}
}
/// <summary>
/// 修改安全试题类型
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void btnEdit_Click ( object sender , EventArgs e )
{
if ( this . trTrainTestDB . SelectedNode ! = null )
{
if ( this . trTrainTestDB . SelectedNode . NodeID ! = "0" ) //非根节点可以编辑
{
PageContext . RegisterStartupScript ( Window1 . GetShowReference ( String . Format ( "TrainTestDBEdit.aspx?TrainTestId={0}" , this . trTrainTestDB . SelectedNode . NodeID , "编辑 - " ) ) ) ;
}
else
{
ShowNotify ( "根节点无法编辑!" , MessageBoxIcon . Warning ) ;
}
}
else
{
ShowNotify ( "请选择树节点!" , MessageBoxIcon . Warning ) ;
}
}
/// <summary>
/// 删除安全试题类型
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void btnDelete_Click ( object sender , EventArgs e )
{
if ( this . trTrainTestDB . SelectedNode ! = null )
{
var q = BLL . TrainTestDBService . GetTrainTestDBById ( this . trTrainTestDB . SelectedNode . NodeID ) ;
if ( q ! = null & & BLL . TrainTestDBService . IsDeleteTrainTestDB ( this . trTrainTestDB . SelectedNode . NodeID ) )
{
BLL . TrainTestDBItemService . DeleteTrainTestDBItemList ( this . trTrainTestDB . SelectedNode . NodeID ) ;
BLL . TrainTestDBService . DeleteTrainTestDB ( this . trTrainTestDB . SelectedNode . NodeID ) ;
InitTreeMenu ( ) ;
}
else
{
ShowNotify ( "存在下级菜单或已增加资源数据或者为内置项,不允许删除!" , MessageBoxIcon . Warning ) ;
}
}
else
{
ShowNotify ( "请选择删除项!" , MessageBoxIcon . Warning ) ;
}
}
/// <summary>
/// 加载tree
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void trTrainTestDB_NodeCommand ( object sender , TreeCommandEventArgs e )
{
BindGrid ( ) ;
}
private void BindGrid ( )
{
string strSql = @ "SELECT M.TrainTestItemId,M.TrainTestId,M.TrainTestItemCode,M.TraiinTestItemName,M.AttachUrl,M.AuditMan,M.AuditDate,M.IsPass,M.CompileMan,M.CompileDate,UR.UserName AS AuditManName,
SUBSTRING ( M . AttachUrl , CHARINDEX ( '~' , M . AttachUrl ) + 1 , LEN ( M . AttachUrl ) ) AS AttachUrlName
FROM dbo . Training_TrainTestDBItem AS M
LEFT JOIN dbo . Sys_User AS UR ON UR . UserId = M . AuditMan
WHERE TrainTestId = @TrainTestId ";
List < SqlParameter > listStr = new List < SqlParameter >
{
new SqlParameter ( "@TrainTestId" , this . trTrainTestDB . SelectedNode . NodeID )
} ;
if ( ! string . IsNullOrEmpty ( this . TrainTestItemCode . Text . Trim ( ) ) )
{
strSql + = " AND TrainTestItemCode LIKE @TrainTestItemCode" ;
listStr . Add ( new SqlParameter ( "@TrainTestItemCode" , "%" + this . TrainTestItemCode . Text . Trim ( ) + "%" ) ) ;
}
if ( ! string . IsNullOrEmpty ( this . TraiinTestItemName . Text . Trim ( ) ) )
{
strSql + = " AND TraiinTestItemName LIKE @TraiinTestItemName" ;
listStr . Add ( new SqlParameter ( "@TraiinTestItemName" , "%" + this . TraiinTestItemName . Text . Trim ( ) + "%" ) ) ;
}
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 ( ) ;
}
/// <summary>
/// 增加安全试题库明细
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void btnNewDetail_Click ( object sender , EventArgs e )
{
if ( this . trTrainTestDB . SelectedNode ! = null )
{
if ( this . trTrainTestDB . SelectedNode . Nodes . Count = = 0 & & this . trTrainTestDB . SelectedNode . NodeID ! = "0" )
{
PageContext . RegisterStartupScript ( Window2 . GetShowReference ( String . Format ( "TrainTestItemEdit.aspx?TrainTestId={0}" , this . trTrainTestDB . SelectedNode . NodeID , "编辑 - " ) ) ) ;
}
else
{
ShowNotify ( "请选择末级节点!" , MessageBoxIcon . Warning ) ;
}
}
else
{
ShowNotify ( "请选择树节点!" , MessageBoxIcon . Warning ) ;
}
}
/// <summary>
/// 编辑安全试题库明细
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void btnEditDetail_Click ( object sender , EventArgs e )
{
this . EditData ( ) ;
}
/// <summary>
/// 右键编辑事件
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void btnMenuEdit_Click ( object sender , EventArgs e )
{
this . EditData ( ) ;
}
/// <summary>
/// 编辑数据方法
/// </summary>
private void EditData ( )
{
if ( Grid1 . SelectedRowIndexArray . Length = = 0 )
{
Alert . ShowInTop ( "请至少选择一条记录!" , MessageBoxIcon . Warning ) ;
return ;
}
string trainTestItemId = Grid1 . SelectedRowID ;
PageContext . RegisterStartupScript ( Window2 . GetShowReference ( String . Format ( "TrainTestItemEdit.aspx?TrainTestItemId={0}" , trainTestItemId , "编辑 - " ) ) ) ;
}
/// <summary>
/// 删除安全试题库明细
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void btnDeleteDetail_Click ( object sender , EventArgs e )
{
this . DeleteData ( ) ;
}
/// <summary>
/// 右键删除事件
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void btnMenuDelete_Click ( object sender , EventArgs e )
{
this . DeleteData ( ) ;
}
/// <summary>
/// 删除方法
/// </summary>
private void DeleteData ( )
{
if ( Grid1 . SelectedRowIndexArray . Length > 0 )
{
foreach ( int rowIndex in Grid1 . SelectedRowIndexArray )
{
string rowID = Grid1 . DataKeys [ rowIndex ] [ 0 ] . ToString ( ) ;
var getV = BLL . TrainTestDBItemService . GetTrainTestDBItemById ( rowID ) ;
if ( getV ! = null )
{
BLL . LogService . AddSys_Log ( this . CurrUser , getV . TrainTestItemCode , getV . TrainTestItemId , BLL . Const . TrainTestDBMenuId , BLL . Const . BtnDelete ) ;
BLL . TrainTestDBItemService . DeleteTrainTestDBItemById ( rowID ) ;
} }
BindGrid ( ) ;
ShowNotify ( "删除数据成功!" ) ;
}
}
/// <summary>
///
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void Grid1_PageIndexChange ( object sender , GridPageEventArgs e )
{
Grid1 . PageIndex = e . NewPageIndex ;
BindGrid ( ) ;
}
/// <summary>
/// Grid1行双击事件
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void Grid1_RowDoubleClick ( object sender , GridRowClickEventArgs e )
{
this . EditData ( ) ;
}
/// <summary>
/// Grid1排序
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void Grid1_Sort ( object sender , GridSortEventArgs e )
{
Grid1 . SortDirection = e . SortDirection ;
Grid1 . SortField = e . SortField ;
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>
/// 关闭弹出窗口1
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void Window1_Close ( object sender , WindowCloseEventArgs e )
{
InitTreeMenu ( ) ;
}
/// <summary>
/// 关闭弹出窗口2
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void Window2_Close ( object sender , WindowCloseEventArgs e )
{
BindGrid ( ) ;
}
#region 导 出
/// <summary>
/// 关闭导出窗口
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void Window5_Close ( object sender , WindowCloseEventArgs e )
{
Response . ClearContent ( ) ;
Response . AddHeader ( "content-disposition" , "attachment; filename=MyExcelFile.xls" ) ;
Response . ContentType = "application/excel" ;
Response . ContentEncoding = System . Text . Encoding . UTF8 ;
Response . Write ( GetGridTableHtml ( Grid1 , e . CloseArgument . Split ( '#' ) ) ) ;
Response . End ( ) ;
}
/// <summary>
/// 导出
/// </summary>
/// <param name="grid"></param>
/// <param name="columns"></param>
/// <returns></returns>
private string GetGridTableHtml ( Grid grid , string [ ] columns )
{
StringBuilder sb = new StringBuilder ( ) ;
sb . Append ( "<meta http-equiv=\"content-type\" content=\"application/excel; charset=UTF-8\"/>" ) ;
List < string > columnHeaderTexts = new List < string > ( columns ) ;
List < int > columnIndexs = new List < int > ( ) ;
sb . Append ( "<table cellspacing=\"0\" rules=\"all\" border=\"1\" style=\"border-collapse:collapse;\">" ) ;
sb . Append ( "<tr>" ) ;
foreach ( GridColumn column in grid . Columns )
{
if ( columnHeaderTexts . Contains ( column . HeaderText ) )
{
sb . AppendFormat ( "<td>{0}</td>" , column . HeaderText ) ;
columnIndexs . Add ( column . ColumnIndex ) ;
}
}
sb . Append ( "</tr>" ) ;
foreach ( GridRow row in grid . Rows )
{
sb . Append ( "<tr>" ) ;
int columnIndex = 0 ;
foreach ( object value in row . Values )
{
if ( columnIndexs . Contains ( columnIndex ) )
{
string html = value . ToString ( ) ;
if ( html . StartsWith ( Grid . TEMPLATE_PLACEHOLDER_PREFIX ) )
{
// 模板列
string templateID = html . Substring ( Grid . TEMPLATE_PLACEHOLDER_PREFIX . Length ) ;
Control templateCtrl = row . FindControl ( templateID ) ;
html = GetRenderedHtmlSource ( templateCtrl ) ;
}
//else
//{
// // 处理CheckBox
// if (html.Contains("f-grid-static-checkbox"))
// {
// if (!html.Contains("f-checked"))
// {
// html = "× ";
// }
// else
// {
// html = "√";
// }
// }
// // 处理图片
// if (html.Contains("<img"))
// {
// string prefix = Request.Url.AbsoluteUri.Replace(Request.Url.AbsolutePath, "");
// html = html.Replace("src=\"", "src=\"" + prefix);
// }
//}
sb . AppendFormat ( "<td>{0}</td>" , html ) ;
}
columnIndex + + ;
}
sb . Append ( "</tr>" ) ;
}
sb . Append ( "</table>" ) ;
return sb . ToString ( ) ;
}
/// <summary>
/// 获取控件渲染后的HTML源代码
/// </summary>
/// <param name="ctrl"></param>
/// <returns></returns>
private string GetRenderedHtmlSource ( Control ctrl )
{
if ( ctrl ! = null )
{
using ( StringWriter sw = new StringWriter ( ) )
{
using ( HtmlTextWriter htw = new HtmlTextWriter ( sw ) )
{
ctrl . RenderControl ( htw ) ;
return sw . ToString ( ) ;
}
}
}
return String . Empty ;
}
#endregion
#region 按 钮 权 限
/// <summary>
/// 获取按钮权限
/// </summary>
/// <param name="button"></param>
/// <returns></returns>
private void GetButtonPower ( )
{
var buttonList = BLL . CommonService . GetAllButtonList ( this . CurrUser . LoginProjectId , this . CurrUser . UserId , BLL . Const . TrainTestDBMenuId ) ;
if ( buttonList . Count ( ) > 0 )
{
if ( buttonList . Contains ( BLL . Const . BtnAdd ) )
{
this . btnNew . Hidden = false ;
this . btnNewDetail . Hidden = false ;
}
if ( buttonList . Contains ( BLL . Const . BtnModify ) )
{
this . btnEdit . Hidden = false ;
this . btnMenuEdit . Hidden = false ;
}
if ( buttonList . Contains ( BLL . Const . BtnDelete ) )
{
this . btnDelete . Hidden = false ;
this . btnMenuDelete . Hidden = false ;
}
if ( buttonList . Contains ( BLL . Const . BtnOut ) )
{
this . btnSelectColumns . Hidden = false ;
}
}
}
#endregion
/// <summary>
/// 查询
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void TextBox_TextChanged ( object sender , EventArgs e )
{
this . BindGrid ( ) ;
}
2021-12-07 18:42:00 +08:00
/// <summary>
/// 从集团获取
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void btnGet_Click ( object sender , EventArgs e )
{
var returnValue = CNCECHSSEWebService . getTraining_TrainTestDBList ( ) ;
if ( returnValue . code = = 1 )
{
ShowNotify ( returnValue . message , MessageBoxIcon . Success ) ;
}
else
{
Alert . ShowInTop ( returnValue . message , MessageBoxIcon . Success ) ;
}
}
2021-04-30 10:28:37 +08:00
}
}