2021-04-30 10:28:37 +08:00
using System ;
2024-01-17 16:12:42 +08:00
using System.Collections ;
2021-04-30 10:28:37 +08:00
using System.Collections.Generic ;
using System.Data ;
using System.Data.SqlClient ;
2024-01-17 16:12:42 +08:00
using System.Linq ;
2021-04-30 10:28:37 +08:00
using System.Text ;
using BLL ;
2024-01-17 16:12:42 +08:00
using Newtonsoft.Json.Linq ;
2021-04-30 10:28:37 +08:00
using AspNet = System . Web . UI . WebControls ;
namespace FineUIPro.Web.ZHGL.ServerCheck
{
public partial class CheckRectify : PageBase
{
protected void Page_Load ( object sender , EventArgs e )
{
if ( ! IsPostBack )
{
this . GetButtonPower ( ) ;
//btnNew.OnClientClick = Window1.GetShowReference("CheckRectifyEdit.aspx") + "return false;";
ddlPageSize . SelectedValue = Grid1 . PageSize . ToString ( ) ;
// 绑定表格
BindGrid ( ) ;
}
}
/// <summary>
/// 绑定数据
/// </summary>
private void BindGrid ( )
{
string strSql = string . Empty ;
SqlParameter [ ] parameter = new SqlParameter [ ] { } ;
strSql = "SELECT S.CheckRectifyId,S.CheckRectifyCode,S.ProjectId,S.UnitId,U.UnitName,S.CheckDate,CASE S.HandleState WHEN '" + BLL . Const . State_1 + "' THEN '未签发' WHEN '" + BLL . Const . State_2 + "' THEN '未上报' ELSE '已上报' END AS HandleState,"
+ @" S.IssueMan,S.IssueDate,ISNULL(TotalCount.TotalCount,0) AS TotalCount ,ISNULL(CompleteCount.CompleteCount,0) AS CompleteCount,(ISNULL(TotalCount.TotalCount,0) -ISNULL(CompleteCount.CompleteCount,0)) AS UnCompleteCount"
+ @" FROM dbo.Check_CheckRectify AS S LEFT JOIN dbo.Base_Unit AS U ON U.UnitId = S.UnitId"
+ @" LEFT JOIN (SELECT COUNT(*) AS TotalCount, CheckRectifyId FROM dbo.Check_CheckRectifyItem GROUP BY CheckRectifyId) AS TotalCount ON S.CheckRectifyId=TotalCount.CheckRectifyId"
+ @" LEFT JOIN (SELECT COUNT(*) AS CompleteCount, CheckRectifyId FROM dbo.Check_CheckRectifyItem WHERE RealEndDate IS NOT NULL GROUP BY CheckRectifyId) AS CompleteCount ON S.CheckRectifyId=CompleteCount.CheckRectifyId"
+ @" ORDER BY HandleState" ;
DataTable tb = SQLHelper . GetDataTableRunText ( strSql , parameter ) ;
// 2.获取当前分页数据
//var table = this.GetPagedDataTable(Grid1, tb1);
Grid1 . RecordCount = tb . Rows . Count ;
//tb = GetFilteredTable(Grid1.FilteredData, tb);
var table = this . GetPagedDataTable ( Grid1 , tb ) ;
Grid1 . DataSource = table ;
Grid1 . DataBind ( ) ;
for ( int i = 0 ; i < Grid1 . Rows . Count ; i + + )
{
Model . Check_CheckRectify rectify = BLL . CheckRectifyService . GetCheckRectifyByCheckRectifyId ( Grid1 . Rows [ i ] . DataKeys [ 0 ] . ToString ( ) ) ;
if ( rectify ! = null )
{
if ( rectify . HandleState = = "1" )
{
Grid1 . Rows [ i ] . RowCssClass = "yellow" ;
}
else if ( rectify . HandleState = = "2" )
{
Grid1 . Rows [ i ] . RowCssClass = "red" ;
}
}
}
}
/// <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 ( ) ;
}
#region 数 据 编 辑 事 件
/// <summary>
/// 右键编辑事件
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void btnMenuEdit_Click ( object sender , EventArgs e )
{
this . EditData ( ) ;
}
/// <summary>
/// Grid行双击事件
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void Grid1_RowDoubleClick ( object sender , GridRowClickEventArgs e )
{
this . EditData ( ) ;
}
/// <summary>
/// 编辑数据方法
/// </summary>
private void EditData ( )
{
if ( Grid1 . SelectedRowIndexArray . Length = = 0 )
{
Alert . ShowInTop ( "请至少选择一条记录!" , MessageBoxIcon . Warning ) ;
return ;
}
string CheckRectifyId = Grid1 . SelectedRowID ;
PageContext . RegisterStartupScript ( Window1 . GetShowReference ( String . Format ( "CheckRectifyEdit.aspx?CheckRectifyId={0}" , CheckRectifyId , "编辑 - " ) ) ) ;
}
#endregion
/// <summary>
/// 关闭弹出窗
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void Window1_Close ( object sender , WindowCloseEventArgs e )
{
BindGrid ( ) ;
}
#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 . CheckRectifyMenuId ) ;
if ( buttonList . Count > 0 )
{
if ( buttonList . Contains ( BLL . Const . BtnModify ) )
{
this . btnMenuEdit . Hidden = false ;
}
}
}
#endregion
#region 导 出 按 钮
/// 导出按钮
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void btnOut_Click ( object sender , EventArgs e )
{
Response . ClearContent ( ) ;
string filename = Funs . GetNewFileName ( ) ;
Response . AddHeader ( "content-disposition" , "attachment; filename=" + System . Web . HttpUtility . UrlEncode ( "集团下发监督检查整改" + filename , System . Text . Encoding . UTF8 ) + ".xls" ) ;
Response . ContentType = "application/excel" ;
Response . ContentEncoding = System . Text . Encoding . UTF8 ;
Response . Write ( GetGridTableHtml ( Grid1 ) ) ;
Response . End ( ) ;
}
/// <summary>
/// 导出方法
/// </summary>
/// <param name="grid"></param>
/// <returns></returns>
private string GetGridTableHtml ( Grid grid )
{
StringBuilder sb = new StringBuilder ( ) ;
MultiHeaderTable mht = new MultiHeaderTable ( ) ;
mht . ResolveMultiHeaderTable ( Grid1 . Columns ) ;
sb . Append ( "<meta http-equiv=\"content-type\" content=\"application/excel; charset=UTF-8\"/>" ) ;
sb . Append ( "<table cellspacing=\"0\" rules=\"all\" border=\"1\" style=\"border-collapse:collapse;\">" ) ;
foreach ( List < object [ ] > rows in mht . MultiTable )
{
sb . Append ( "<tr>" ) ;
foreach ( object [ ] cell in rows )
{
int rowspan = Convert . ToInt32 ( cell [ 0 ] ) ;
int colspan = Convert . ToInt32 ( cell [ 1 ] ) ;
GridColumn column = cell [ 2 ] as GridColumn ;
sb . AppendFormat ( "<th{0}{1}{2}>{3}</th>" ,
rowspan ! = 1 ? " rowspan=\"" + rowspan + "\"" : "" ,
colspan ! = 1 ? " colspan=\"" + colspan + "\"" : "" ,
colspan ! = 1 ? " style=\"text-align:center;\"" : "" ,
column . HeaderText ) ;
}
sb . Append ( "</tr>" ) ;
}
foreach ( GridRow row in grid . Rows )
{
sb . Append ( "<tr>" ) ;
foreach ( GridColumn column in mht . Columns )
{
string html = row . Values [ column . ColumnIndex ] . ToString ( ) ;
if ( column . ColumnID = = "tfNumber" )
{
html = ( row . FindControl ( "lblNumber" ) as AspNet . Label ) . Text ;
}
if ( column . ColumnID = = "UnitName" )
{
html = ( row . FindControl ( "lblUnit" ) as AspNet . Label ) . Text ;
}
if ( column . ColumnID = = "ProjectId" )
{
html = ( row . FindControl ( "lblProjectId" ) as AspNet . Label ) . Text ;
}
sb . AppendFormat ( "<td>{0}</td>" , html ) ;
}
sb . Append ( "</tr>" ) ;
}
sb . Append ( "</table>" ) ;
return sb . ToString ( ) ;
}
#region 多 表 头 处 理
/// <summary>
/// 多表头处理
/// </summary>
public class MultiHeaderTable
{
// 包含 rowspan, colspan 的多表头,方便生成 HTML 的 table 标签
public List < List < object [ ] > > MultiTable = new List < List < object [ ] > > ( ) ;
// 最终渲染的列数组
public List < GridColumn > Columns = new List < GridColumn > ( ) ;
public void ResolveMultiHeaderTable ( GridColumnCollection columns )
{
List < object [ ] > row = new List < object [ ] > ( ) ;
foreach ( GridColumn column in columns )
{
object [ ] cell = new object [ 4 ] ;
cell [ 0 ] = 1 ; // rowspan
cell [ 1 ] = 1 ; // colspan
cell [ 2 ] = column ;
cell [ 3 ] = null ;
row . Add ( cell ) ;
}
ResolveMultiTable ( row , 0 ) ;
ResolveColumns ( row ) ;
}
private void ResolveColumns ( List < object [ ] > row )
{
foreach ( object [ ] cell in row )
{
GroupField groupField = cell [ 2 ] as GroupField ;
if ( groupField ! = null & & groupField . Columns . Count > 0 )
{
List < object [ ] > subrow = new List < object [ ] > ( ) ;
foreach ( GridColumn column in groupField . Columns )
{
subrow . Add ( new object [ ]
{
1 ,
1 ,
column ,
groupField
} ) ;
}
ResolveColumns ( subrow ) ;
}
else
{
Columns . Add ( cell [ 2 ] as GridColumn ) ;
}
}
}
private void ResolveMultiTable ( List < object [ ] > row , int level )
{
List < object [ ] > nextrow = new List < object [ ] > ( ) ;
foreach ( object [ ] cell in row )
{
GroupField groupField = cell [ 2 ] as GroupField ;
if ( groupField ! = null & & groupField . Columns . Count > 0 )
{
// 如果当前列包含子列,则更改当前列的 colspan, 以及增加父列( 向上递归) 的colspan
cell [ 1 ] = Convert . ToInt32 ( groupField . Columns . Count ) ;
PlusColspan ( level - 1 , cell [ 3 ] as GridColumn , groupField . Columns . Count - 1 ) ;
foreach ( GridColumn column in groupField . Columns )
{
nextrow . Add ( new object [ ]
{
1 ,
1 ,
column ,
groupField
} ) ;
}
}
}
MultiTable . Add ( row ) ;
// 如果当前下一行,则增加上一行(向上递归)中没有子列的列的 rowspan
if ( nextrow . Count > 0 )
{
PlusRowspan ( level ) ;
ResolveMultiTable ( nextrow , level + 1 ) ;
}
}
private void PlusRowspan ( int level )
{
if ( level < 0 )
{
return ;
}
foreach ( object [ ] cells in MultiTable [ level ] )
{
GroupField groupField = cells [ 2 ] as GroupField ;
if ( groupField ! = null & & groupField . Columns . Count > 0 )
{
// ...
}
else
{
cells [ 0 ] = Convert . ToInt32 ( cells [ 0 ] ) + 1 ;
}
}
PlusRowspan ( level - 1 ) ;
}
private void PlusColspan ( int level , GridColumn parent , int plusCount )
{
if ( level < 0 )
{
return ;
}
foreach ( object [ ] cells in MultiTable [ level ] )
{
GridColumn column = cells [ 2 ] as GridColumn ;
if ( column = = parent )
{
cells [ 1 ] = Convert . ToInt32 ( cells [ 1 ] ) + plusCount ;
PlusColspan ( level - 1 , cells [ 3 ] as GridColumn , plusCount ) ;
}
}
}
}
#endregion
2021-12-02 10:44:15 +08:00
2021-04-30 10:28:37 +08:00
#endregion
2021-12-02 10:44:15 +08:00
/// <summary>
/// 从集团获取
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void btnGet_Click ( object sender , EventArgs e )
{
2024-01-17 16:12:42 +08:00
var returnValue = getCheck_CheckRectifyListToSUB ( ) ;
2021-12-02 10:44:15 +08:00
if ( returnValue . code = = 1 )
{
ShowNotify ( returnValue . message , MessageBoxIcon . Success ) ;
}
else
{
Alert . ShowInTop ( returnValue . message , MessageBoxIcon . Success ) ;
}
}
2024-01-17 16:12:42 +08:00
#region 获 取
/// <summary>
/// 获取
/// </summary>
/// <param name="type"></param>
/// <returns></returns>
public static Model . ResponeData getCheck_CheckRectifyListToSUB ( )
{
var responeData = new Model . ResponeData ( ) ;
try
{
string unitId = CommonService . GetThisUnitId ( ) ;
string baseurl = SysConstSetService . CNCECPath + "/api/HSSEData/getCheckRectify?unitId=" + unitId ;
string contenttype = "application/json;charset=unicode" ;
Hashtable newToken = new Hashtable
{
{ "token" , ServerService . GetToken ( ) . Token }
} ;
var strJosn = APIGetHttpService . Http ( baseurl , "GET" , contenttype , newToken , null ) ;
if ( ! string . IsNullOrEmpty ( strJosn ) )
{
JObject obj = JObject . Parse ( strJosn ) ;
responeData . code = Funs . GetNewIntOrZero ( obj [ "code" ] . ToString ( ) ) ;
responeData . message = obj [ "message" ] . ToString ( ) ;
if ( responeData . code = = 1 )
{
JArray getData = JArray . Parse ( obj [ "data" ] . ToString ( ) ) ;
if ( getData . Count ( ) > 0 )
{
using ( Model . SGGLDB db = new Model . SGGLDB ( Funs . ConnString ) )
{
List < string > ids = new List < string > ( ) ;
foreach ( var item in getData )
{
string getCheckRectifyId = item [ "CheckRectifyId" ] . ToString ( ) ;
if ( ! ids . Contains ( getCheckRectifyId ) )
{
var newRectify = db . Check_CheckRectify . FirstOrDefault ( e = > e . CheckRectifyId = = getCheckRectifyId ) ;
if ( newRectify = = null )
{
ids . Add ( getCheckRectifyId ) ;
Model . Check_CheckRectify newCheckRectify = new Model . Check_CheckRectify
{
CheckRectifyId = getCheckRectifyId ,
CheckRectifyCode = item [ "CheckRectifyCode" ] . ToString ( ) ,
ProjectId = item [ "ProjectId" ] . ToString ( ) ,
UnitId = unitId ,
CheckDate = Funs . GetNewDateTime ( item [ "CheckDate" ] . ToString ( ) ) ,
IssueMan = item [ "IssueMan" ] . ToString ( ) ,
IssueDate = Funs . GetNewDateTime ( item [ "IssueDate" ] . ToString ( ) ) ,
HandleState = item [ "HandleState" ] . ToString ( )
} ;
db . Check_CheckRectify . InsertOnSubmit ( newCheckRectify ) ;
db . SubmitChanges ( ) ;
}
else
{
newRectify . CheckRectifyCode = item [ "CheckRectifyCode" ] . ToString ( ) ;
db . SubmitChanges ( ) ;
}
//获取对应主表主键的明细集合
string getTable5ItemId = item [ "Table5ItemId" ] . ToString ( ) ;
var oldItem5 = db . Check_CheckInfo_Table5Item . FirstOrDefault ( x = > x . ID = = getTable5ItemId ) ;
if ( oldItem5 = = null )
{
Model . Check_CheckInfo_Table5Item newCheckRectifyItem = new Model . Check_CheckInfo_Table5Item
{
ID = getTable5ItemId ,
SortIndex = Funs . GetNewInt ( item [ "SortIndex" ] . ToString ( ) ) ,
WorkType = item [ "WorkType" ] . ToString ( ) ,
DangerPoint = item [ "DangerPoint" ] . ToString ( ) ,
RiskExists = item [ "RiskExists" ] . ToString ( ) ,
IsProject = Convert . ToBoolean ( item [ "IsProject" ] . ToString ( ) ) ,
CheckMan = item [ "CheckMan" ] . ToString ( ) ,
SubjectUnitMan = item [ "SubjectUnitMan" ] . ToString ( ) ,
} ;
db . Check_CheckInfo_Table5Item . InsertOnSubmit ( newCheckRectifyItem ) ;
db . SubmitChanges ( ) ;
}
BLL . CommonService . DeleteAttachFileById ( getTable5ItemId ) ; //删除附件
////上传附件
string getAttachFileId = item [ "AttachFileId" ] . ToString ( ) ;
if ( ! string . IsNullOrEmpty ( getAttachFileId ) )
{
JArray byteList = item [ "FileContext" ] as JArray ;
List < byte [ ] > resultList = new List < byte [ ] > ( ) ;
foreach ( JToken token in byteList )
{
byte [ ] byteArray = Convert . FromBase64String ( token . ToString ( ) ) ;
resultList . Add ( byteArray ) ;
}
//List<byte[]> fileContext = new List<byte[]>();
//fileContext.Add(Convert.FromBase64String(item["FileContext"].ToString()));
BLL . FileInsertService . InsertAttachFile ( getAttachFileId , getTable5ItemId , item [ "AttachSource" ] . ToString ( ) , item [ "AttachUrl" ] . ToString ( ) , resultList ) ;
}
string getCheckRectifyItemId = item [ "CheckRectifyItemId" ] . ToString ( ) ;
var oldItem = db . Check_CheckRectifyItem . FirstOrDefault ( e = > e . CheckRectifyItemId = = getCheckRectifyItemId ) ;
if ( oldItem = = null )
{
Model . Check_CheckRectifyItem newCheckRectifyItem = new Model . Check_CheckRectifyItem
{
CheckRectifyItemId = getCheckRectifyItemId ,
CheckRectifyId = getCheckRectifyId ,
Table5ItemId = getTable5ItemId ,
ConfirmMan = item [ "ConfirmMan" ] . ToString ( ) ,
ConfirmDate = Funs . GetNewDateTime ( item [ "ConfirmDate" ] . ToString ( ) ) ,
OrderEndDate = Funs . GetNewDateTime ( item [ "OrderEndDate" ] . ToString ( ) ) ,
OrderEndPerson = item [ "OrderEndPerson" ] . ToString ( ) ,
RealEndDate = Funs . GetNewDateTime ( item [ "RealEndDate" ] . ToString ( ) ) ,
} ;
db . Check_CheckRectifyItem . InsertOnSubmit ( newCheckRectifyItem ) ;
db . SubmitChanges ( ) ;
}
}
}
}
}
responeData . message = "获取成功:整改明细记录" + getData . Count ( ) . ToString ( ) + "条" ;
}
}
}
catch ( Exception ex )
{
responeData . code = 0 ;
responeData . message = "获取失败:" + ex . Message ;
ErrLogInfo . WriteLog ( "安全监督检查通知单获取!" , ex ) ;
}
return responeData ;
}
#endregion
2021-04-30 10:28:37 +08:00
}
}