2025-02-12 09:27:47 +08:00
using BLL ;
using Newtonsoft.Json ;
using Newtonsoft.Json.Linq ;
using System ;
using System.Collections ;
using System.Collections.Generic ;
using System.Data ;
using System.Data.SqlClient ;
using System.Linq ;
using System.Text ;
using AspNet = System . Web . UI . WebControls ;
namespace FineUIPro.Web.ProjectData
{
public partial class WorkArea : PageBase
{
#region 加 载
/// <summary>
/// 加载页面
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void Page_Load ( object sender , EventArgs e )
{
if ( ! IsPostBack )
{
////权限按钮方法
this . GetButtonPower ( ) ;
Funs . DropDownPageSize ( this . ddlPageSize ) ;
this . btnNew . OnClientClick = Window1 . GetShowReference ( "WorkAreaEdit.aspx" ) + "return false;" ;
if ( this . CurrUser ! = null & & this . CurrUser . PageSize . HasValue )
{
Grid1 . PageSize = this . CurrUser . PageSize . Value ;
}
this . ddlPageSize . SelectedValue = Grid1 . PageSize . ToString ( ) ;
// 绑定表格
this . BindGrid ( ) ;
}
}
/// <summary>
/// 绑定数据
/// </summary>
private void BindGrid ( )
{
2025-09-08 11:30:40 +08:00
string strSql = @"SELECT WorkArea.ProjectId, WorkArea.WorkAreaId,WorkArea.WorkAreaCode,WorkArea.SystemId,WorkArea.WorkAreaName,WorkArea.UnitId,Unit.UnitName,WorkArea.SupervisorUnitId,SupervisorUnit.UnitName AS SupervisorUnitName,WorkArea.InstallationId,Installation.InstallationName,WorkArea.Remark,WorkArea.CompletionDate"
+ @" FROM ProjectData_WorkArea AS WorkArea "
2025-02-12 09:27:47 +08:00
+ @" LEFT JOIN Project_Installation AS Installation ON WorkArea.InstallationId=Installation.InstallationId "
+ @" LEFT JOIN Base_Unit AS Unit ON WorkArea.UnitId=Unit.UnitId"
+ @" LEFT JOIN Base_Unit AS SupervisorUnit ON WorkArea.SupervisorUnitId=SupervisorUnit.UnitId WHERE 1=1 " ;
List < SqlParameter > listStr = new List < SqlParameter > ( ) ;
if ( ! string . IsNullOrEmpty ( Request . Params [ "projectId" ] ) ) ///是否文件柜查看页面传项目值
{
strSql + = " AND WorkArea.ProjectId = @ProjectId" ;
listStr . Add ( new SqlParameter ( "@ProjectId" , this . CurrUser . LoginProjectId ) ) ;
}
else
{
strSql + = " AND WorkArea.ProjectId = @ProjectId" ;
listStr . Add ( new SqlParameter ( "@ProjectId" , this . CurrUser . LoginProjectId ) ) ;
}
if ( ! string . IsNullOrEmpty ( this . txtWorkAreaName . Text . Trim ( ) ) )
{
strSql + = " AND WorkArea.WorkAreaName LIKE @WorkAreaName" ;
listStr . Add ( new SqlParameter ( "@WorkAreaName" , "%" + this . txtWorkAreaName . Text . Trim ( ) + "%" ) ) ;
}
if ( BLL . ProjectUnitService . GetProjectUnitTypeByProjectIdUnitId ( this . CurrUser . LoginProjectId , this . CurrUser . UnitId ) )
{
strSql + = " AND WorkArea.UnitId =@unitId" ;
listStr . Add ( new SqlParameter ( "@unitId" , this . CurrUser . UnitId ) ) ;
}
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 Grid1_PageIndexChange ( object sender , GridPageEventArgs 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 Grid1_Sort ( object sender , FineUIPro . GridSortEventArgs e )
{
BindGrid ( ) ;
}
/// <summary>
/// 关闭弹出窗口
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void Window1_Close ( object sender , EventArgs e )
{
BindGrid ( ) ;
}
#endregion
#region 编 辑
/// <summary>
/// 双击事件
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void Grid1_RowDoubleClick ( object sender , GridRowClickEventArgs 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 ;
}
if ( this . btnMenuEdit . Hidden ) ////双击事件 编辑权限有:编辑页面,无:查看页面 或者状态是完成时查看页面
{
PageContext . RegisterStartupScript ( Window1 . GetShowReference ( String . Format ( "WorkAreaView.aspx?WorkAreaId={0}" , Grid1 . SelectedRowID , "查看 - " ) ) ) ;
}
else
{
PageContext . RegisterStartupScript ( Window1 . GetShowReference ( String . Format ( "WorkAreaEdit.aspx?WorkAreaId={0}" , Grid1 . SelectedRowID , "编辑 - " ) ) ) ;
}
}
#endregion
#region 删 除
/// <summary>
/// 右键删除事件
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void btnMenuDelete_Click ( object sender , EventArgs e )
{
if ( Grid1 . SelectedRowIndexArray . Length > 0 )
{
bool isShow = false ;
if ( Grid1 . SelectedRowIndexArray . Length = = 1 )
{
isShow = true ;
}
foreach ( int rowIndex in Grid1 . SelectedRowIndexArray )
{
string rowID = Grid1 . DataKeys [ rowIndex ] [ 0 ] . ToString ( ) ;
if ( this . judgementDelete ( rowID , isShow ) )
{
var WorkArea = BLL . WorkAreaService . getWorkAreaByWorkAreaId ( rowID ) ;
if ( WorkArea ! = null )
{
BLL . LogService . AddSys_Log ( this . CurrUser , WorkArea . WorkAreaCode , WorkArea . WorkAreaId , BLL . Const . WorkAreaMenuId , BLL . Const . BtnDelete ) ;
BLL . WorkAreaService . DeleteWorkAreaById ( rowID ) ;
}
}
}
BindGrid ( ) ;
ShowNotify ( "删除数据成功!" , MessageBoxIcon . Success ) ;
}
}
/// <summary>
/// 判断是否可以删除
/// </summary>
/// <returns></returns>
private bool judgementDelete ( string id , bool isShow )
{
string content = string . Empty ;
if ( string . IsNullOrEmpty ( content ) )
{
return true ;
}
else
{
if ( isShow )
{
Alert . ShowInTop ( content ) ;
}
return false ;
}
}
#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="button"></param>
/// <returns></returns>
private void GetButtonPower ( )
{
if ( Request . Params [ "value" ] = = "0" ) ///文件柜时 没有操作权限
{
return ;
}
var buttonList = BLL . CommonService . GetAllButtonList ( this . CurrUser . LoginProjectId , this . CurrUser . UserId , BLL . Const . WorkAreaMenuId ) ;
if ( buttonList . Count ( ) > 0 )
{
if ( buttonList . Contains ( BLL . Const . BtnAdd ) )
{
this . btnNew . Hidden = false ;
}
if ( buttonList . Contains ( BLL . Const . BtnModify ) )
{
this . btnMenuEdit . Hidden = false ;
}
if ( buttonList . Contains ( BLL . Const . BtnDelete ) )
{
this . btnMenuDelete . 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 ;
this . Grid1 . PageSize = 500 ;
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 )
{
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 ;
}
sb . AppendFormat ( "<td>{0}</td>" , html ) ;
}
sb . Append ( "</tr>" ) ;
}
sb . Append ( "</table>" ) ;
return sb . ToString ( ) ;
}
#endregion
protected void btnImport_Click ( object sender , EventArgs e )
{
var project = Funs . DB . Base_Project . FirstOrDefault ( x = > x . ProjectId = = CurrUser . LoginProjectId ) ;
int total = 10 ;
int pageSize = 100 ;
int pageIndex = 0 ;
while ( pageSize * pageIndex < = total )
{
string pushContent = string . Empty ;
var dictTypeCode = new
{
criteria = new { _expr = new [ ] { new { _property = "project_code" , _value = project . ProjectCode , _op = "=" } , new { _property = "isusedcode" , _value = "0" , _op = "=" } } } ,
pageSize = pageSize ,
pageIndex = pageIndex
} ;
Hashtable newToken = new Hashtable
{
{ "userName" , "nuobida_construction" } ,
{ "password" , "nuobida@2023" } ,
{ "ClientId" , "com.tcc.pm.sggl" } ,
{ "OperationCode" , "com.tcc.dm.mdm.pm.workareainfo" }
} ;
pushContent = JsonConvert . SerializeObject ( dictTypeCode ) ;
string returndata = APIGetHttpService . OutsideHttp ( "https://esb.china-tcc.com:9090/com/tcc/dm/mdm/TCC_TM_PM_WORKAREA_INFO" , "POST" , "application/json;charset=utf-8" , newToken , pushContent ) ;
if ( ! string . IsNullOrEmpty ( returndata ) )
{
JObject obj = JObject . Parse ( returndata ) ;
total = int . Parse ( obj [ "total" ] . ToString ( ) ) ;
string datas = obj [ "datas" ] . ToString ( ) ;
JArray arr = JArray . Parse ( datas ) ;
foreach ( var item in arr )
{
string work_area_code = item [ "work_area_code" ] . ToString ( ) ;
string work_area_name = item [ "work_area_name" ] . ToString ( ) ;
string device_code = item [ "device_code" ] . ToString ( ) ;
string device_name = item [ "device_name" ] . ToString ( ) ;
string project_code = item [ "project_code" ] . ToString ( ) ;
string project_name = item [ "project_name" ] . ToString ( ) ;
var device = Funs . DB . Project_Installation . FirstOrDefault ( x = > x . InstallationCode = = device_code ) ;
if ( project ! = null & & device ! = null )
{
var workArea = Funs . DB . ProjectData_WorkArea . FirstOrDefault ( x = > x . WorkAreaCode = = work_area_code & & x . ProjectId = = project . ProjectId ) ;
if ( workArea ! = null )
{
workArea . WorkAreaCode = work_area_code ;
workArea . WorkAreaName = work_area_name ;
workArea . DataSource = "数据同步" ;
if ( project ! = null )
{
workArea . ProjectId = project . ProjectId ;
}
if ( device ! = null )
{
workArea . InstallationId = device . InstallationId ;
}
}
else
{
workArea = new Model . ProjectData_WorkArea ( ) ;
workArea . WorkAreaId = Guid . NewGuid ( ) . ToString ( ) ;
workArea . WorkAreaCode = work_area_code ;
workArea . WorkAreaName = work_area_name ;
workArea . DataSource = "数据同步" ;
if ( project ! = null )
{
workArea . ProjectId = project . ProjectId ;
}
if ( device ! = null )
{
workArea . InstallationId = device . InstallationId ;
}
Funs . DB . ProjectData_WorkArea . InsertOnSubmit ( workArea ) ;
}
}
}
Funs . DB . SubmitChanges ( ) ;
}
pageIndex + + ;
//}
}
this . BindGrid ( ) ;
}
}
}