2025-04-07 17:43:30 +08:00
using BLL ;
using Newtonsoft.Json.Linq ;
using System ;
using System.Collections.Generic ;
using System.Data ;
using System.Data.SqlClient ;
using System.Linq ;
2026-04-09 16:09:11 +08:00
using System.Text ;
using AspNet = System . Web . UI . WebControls ;
2025-04-07 17:43:30 +08:00
namespace FineUIPro.Web.DataShow
{
public partial class QualityInstruments : PageBase
{
#region 项 目 主 键
/// <summary>
/// 项目主键
/// </summary>
public string ProjectId
{
get
{
return ( string ) ViewState [ "ProjectId" ] ;
}
set
{
ViewState [ "ProjectId" ] = value ;
}
}
#endregion
#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 ( ) ;
// 合计
OutputSummaryData ( ) ;
this . Panel1 . Title = "计量器具数据(" + BLL . UnitService . GetUnitNameByUnitId ( BLL . CommonService . GetThisUnitId ( ) ) + ") " ;
}
}
protected void changeTree ( object sender , EventArgs e )
{
this . ProjectId = this . ucTree . ProjectId ;
this . BindGrid ( ) ;
}
/// <summary>
/// 绑定数据
/// </summary>
private void BindGrid ( )
{
string strSql = @"select ProjectId,ProjectCode, ProjectName from Base_Project where ProjectState =1 and (isDelete IS NULL OR isDelete =0)" ;
List < SqlParameter > listStr = new List < SqlParameter > ( ) ;
string cpara = string . Empty ;
if ( ! string . IsNullOrEmpty ( this . ucTree . SelectedNodeID ) )
{
if ( ! string . IsNullOrEmpty ( this . ucTree . ProjectId ) )
{
strSql + = " AND projectId = @projectId" ; ///状态为已完成
listStr . Add ( new SqlParameter ( "@projectId" , this . ucTree . ProjectId ) ) ;
}
else
{
strSql + = " AND UnitId = @UnitId" ; ///状态为已完成
listStr . Add ( new SqlParameter ( "@UnitId" , this . ucTree . UnitId ) ) ;
}
}
//if (!string.IsNullOrEmpty(this.txtStartTime.Text))
//{
// strSql += " AND h.RegisterDate >=@StartTime";
// listStr.Add(new SqlParameter("@StartTime", this.txtStartTime.Text));
// cpara += " AND c.RegisterDate >=" + this.txtStartTime.Text;
//}
//if (!string.IsNullOrEmpty(this.txtEndTime.Text))
//{
// strSql += " AND h.RegisterDate <=@EndTime";
// listStr.Add(new SqlParameter("@EndTime", this.txtEndTime.Text));
// cpara += " AND c.RegisterDate <=" + this.txtEndTime.Text;
//}
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 ;
}
PageContext . RegisterStartupScript ( Window1 . GetShowReference ( String . Format ( "QualityInstrumentsItem.aspx?projectId={0}" , Grid1 . SelectedRowID , "查看 - " ) ) ) ;
}
#endregion
protected void btnView_Click ( object sender , EventArgs e )
{
EditData ( ) ;
}
/// <summary>
/// 总工时数
/// </summary>
/// <param name="state"></param>
/// <returns></returns>
protected int Count1 ( object projectId )
{
int cout1 = 0 ;
if ( projectId ! = null )
{
var datetime1 = Funs . GetNewDateTime ( this . txtStartTime . Text ) ;
2026-04-09 16:09:11 +08:00
var datetime2 = Funs . GetNewDateTime ( this . txtEndTime . Text ) ;
2025-04-07 17:43:30 +08:00
var getD1 = from x in Funs . DB . Comprehensive_InspectionMachine
2026-04-09 16:09:11 +08:00
where x . ProjectId = = projectId . ToString ( ) & & x . IsOnSite = = true & & x . InspectionType . Contains ( "计量" )
//&& x.CompileDate == Funs.minSysDate
select x ;
2025-04-07 17:43:30 +08:00
if ( datetime1 . HasValue )
{
getD1 = getD1 . Where ( x = > x . CompileDate > = datetime1 ) ;
}
if ( datetime2 . HasValue )
{
getD1 = getD1 . Where ( x = > x . CompileDate < = datetime2 ) ;
}
2026-04-09 16:09:11 +08:00
// cout1 = getD1.Count();
cout1 = getD1 . ToList ( ) . Sum ( x = > x . UnitsCount ? ? 1 ) ;
2025-04-07 17:43:30 +08:00
}
return cout1 ;
}
/// <summary>
/// 损失工时数
/// </summary>
/// <param name="state"></param>
/// <returns></returns>
protected int Count2 ( object projectId )
{
int cout1 = 0 ;
if ( projectId ! = null )
{
var datetime1 = Funs . GetNewDateTime ( this . txtStartTime . Text ) ;
2026-04-09 16:09:11 +08:00
var datetime2 = Funs . GetNewDateTime ( this . txtEndTime . Text ) ;
2025-04-07 17:43:30 +08:00
var getD1 = from x in Funs . DB . Comprehensive_InspectionMachine
2026-04-09 16:09:11 +08:00
where x . ProjectId = = projectId . ToString ( ) & & x . IsOnSite = = true & &
x . InspectionType . Contains ( "计量" ) & & x . IsCheckOK = = true
// && x.CompileDate == Funs.minSysDate
select x ;
2025-04-07 17:43:30 +08:00
if ( datetime1 . HasValue )
{
getD1 = getD1 . Where ( x = > x . CompileDate > = datetime1 ) ;
}
2026-04-09 16:09:11 +08:00
2025-04-07 17:43:30 +08:00
if ( datetime2 . HasValue )
{
getD1 = getD1 . Where ( x = > x . CompileDate < = datetime2 ) ;
}
2026-04-09 16:09:11 +08:00
// cout1 = getD1.Count();
cout1 = getD1 . ToList ( ) . Sum ( x = > x . UnitsCount ? ? 1 ) ;
2025-04-07 17:43:30 +08:00
}
return cout1 ;
}
#region 合 计
private void OutputSummaryData ( ) {
2026-04-09 16:09:11 +08:00
string strSql = @"select ProjectId,ProjectCode, ProjectName ,
isnull((select sum(isnull(a.UnitsCount,1)) from Comprehensive_InspectionMachine as a where a.ProjectId=P.ProjectId and a.IsOnSite=1 and a.InspectionType like '%计量%' ),0) as Count1,
isnull((select sum(isnull(a.UnitsCount,1)) from Comprehensive_InspectionMachine as a where a.ProjectId=P.ProjectId and a.IsOnSite=1 and a.InspectionType like '%计量%' and a.IsCheckOK=1 ),0) as Count2
from Base_Project as P where ProjectState =1 and (isDelete IS NULL OR isDelete =0) and (ProjectAttribute == 'GONGCHENG' OR ProjectAttribute IS NULL) " ;
List < SqlParameter > listStr = new List < SqlParameter > ( ) ;
SqlParameter [ ] parameter = listStr . ToArray ( ) ;
DataTable tb = SQLHelper . GetDataTableRunText ( strSql , parameter ) ;
int Count1 = 0 , Count2 = 0 ;
foreach ( DataRow row in tb . Rows )
{
Count1 + = Convert . ToInt32 ( row [ "Count1" ] ) ;
Count2 + = Convert . ToInt32 ( row [ "Count2" ] ) ;
}
JObject summary = new JObject ( ) ;
summary . Add ( "ProjectName" , "合计:" ) ;
summary . Add ( "Count1" , Count1 . ToString ( ) ) ;
summary . Add ( "Count2" , Count2 . ToString ( ) ) ;
Grid1 . SummaryData = summary ;
}
#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 ;
this . Grid1 . PageSize = this . Grid1 . RecordCount ;
this . BindGrid ( ) ;
Response . Write ( GetGridTableHtml ( Grid1 ) ) ;
Response . End ( ) ;
}
/// <summary>
/// 导出方法
/// </summary>
/// <param name="grid"></param>
/// <returns></returns>
private string GetGridTableHtml ( Grid grid )
{
StringBuilder sb = new StringBuilder ( ) ;
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;\">" ) ;
sb . Append ( "<tr>" ) ;
foreach ( GridColumn column in grid . Columns )
2025-04-07 17:43:30 +08:00
{
2026-04-09 16:09:11 +08:00
sb . AppendFormat ( "<td>{0}</td>" , column . HeaderText ) ;
}
sb . Append ( "</tr>" ) ;
foreach ( GridRow row in grid . Rows )
{
sb . Append ( "<tr>" ) ;
foreach ( GridColumn column in grid . Columns )
{
string html = row . Values [ column . ColumnIndex ] . ToString ( ) ;
if ( column . ColumnID = = "tfNumber" )
{
html = ( row . FindControl ( "lblNumber" ) as AspNet . Label ) . Text ;
}
if ( column . ColumnID = = "Count1" )
{
html = ( row . FindControl ( "Label2" ) as AspNet . Label ) . Text ;
}
if ( column . ColumnID = = "Count2" )
{
html = ( row . FindControl ( "Label1" ) as AspNet . Label ) . Text ;
}
sb . AppendFormat ( "<td>{0}</td>" , html ) ;
}
sb . Append ( "</tr>" ) ;
2025-04-07 17:43:30 +08:00
}
2026-04-09 16:09:11 +08:00
sb . Append ( "</table>" ) ;
return sb . ToString ( ) ;
2025-04-07 17:43:30 +08:00
}
2026-04-09 16:09:11 +08:00
#endregion
2025-04-07 17:43:30 +08:00
}
}