2021-04-30 10:28:37 +08:00
using System ;
using System.Collections.Generic ;
using System.Data ;
using System.Data.SqlClient ;
using System.Linq ;
using System.Text ;
using BLL ;
2023-10-18 15:55:42 +08:00
using Newtonsoft.Json ;
2021-04-30 10:28:37 +08:00
using AspNet = System . Web . UI . WebControls ;
namespace FineUIPro.Web.ProjectData
{
public partial class ProjectSet : PageBase
2023-10-18 15:55:42 +08:00
{
public string URLToken
{
get
{
return ( string ) ViewState [ "URLToken" ] ;
}
set
{
ViewState [ "URLToken" ] = value ;
}
}
#region 加 载
/// <summary>
/// 加载页面
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void Page_Load ( object sender , EventArgs e )
2021-04-30 10:28:37 +08:00
{
if ( ! IsPostBack )
{
////权限按钮方法
this . GetButtonPower ( ) ;
Funs . DropDownPageSize ( this . ddlPageSize ) ;
this . btnNew . OnClientClick = Window1 . GetShowReference ( "ProjectSetSave.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 ( ) ;
}
}
#endregion
#region 绑 定 数 据
/// <summary>
/// 绑定数据
/// </summary>
private void BindGrid ( )
{
string strSql = "SELECT Project.ProjectId,Project.ProjectCode,Project.ProjectName,unit.UnitName,Project.StartDate,Project.EndDate,Project.ProjectAddress,ProjectType.ProjectTypeName AS ProjectTypeName,ShortName, "
+ @" (CASE WHEN ProjectState='" + BLL . Const . ProjectState_2 + "' THEN '暂停中' WHEN ProjectState='" + BLL . Const . ProjectState_3 + "' THEN '已完工' ELSE '施工中' END) AS ProjectStateName,Project.ProjectState,sysConst.ConstText as ProjectStateName2"
+ @" FROM Base_Project AS Project LEFT JOIN Base_Unit as unit on unit.UnitId=Project.UnitId"
+ @" LEFT JOIN Base_ProjectType AS ProjectType ON Project.ProjectType =ProjectType.ProjectTypeId"
+ @" LEFT JOIN Sys_Const AS sysConst ON Project.ProjectState2 =sysConst.ConstValue AND sysConst.GroupId= '" + BLL . ConstValue . GroupId_ProjectState + "' "
+ @" WHERE 1=1 " ;
List < SqlParameter > listStr = new List < SqlParameter > ( ) ;
//if (!string.IsNullOrEmpty(Request.Params["projectId"])) ///是否文件柜查看页面传项目值
//{
// strSql += " AND ProjectId = @ProjectId";
// listStr.Add(new SqlParameter("@ProjectId", Request.Params["projectId"]));
//}
//else if (!string.IsNullOrEmpty(this.CurrUser.LoginProjectId))
//{
// strSql += " AND ProjectId = @ProjectId";
// listStr.Add(new SqlParameter("@ProjectId", this.CurrUser.LoginProjectId));
//}
if ( ! string . IsNullOrEmpty ( this . txtProjectName . Text . Trim ( ) ) )
{
strSql + = " AND ProjectName LIKE @ProjectName" ;
listStr . Add ( new SqlParameter ( "@ProjectName" , "%" + this . txtProjectName . Text . Trim ( ) + "%" ) ) ;
}
if ( this . ckState . SelectedValue ! = "0" )
{
if ( this . ckState . SelectedValue = = "1" )
{
strSql + = " AND (ProjectState = '1' OR ProjectState IS NULL)" ;
}
else
{
strSql + = " AND (ProjectState = @states )" ;
listStr . Add ( new SqlParameter ( "@states" , this . ckState . SelectedValue ) ) ;
}
}
SqlParameter [ ] parameter = listStr . ToArray ( ) ;
DataTable tb = SQLHelper . GetDataTableRunText ( strSql , parameter ) ;
Grid1 . RecordCount = tb . Rows . Count ;
Grid1 . DataSource = this . GetPagedDataTable ( Grid1 , tb ) ;
Grid1 . DataBind ( ) ;
}
#endregion
#region 操 作 Events
/// <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 project = BLL . ProjectService . GetProjectByProjectId ( rowID ) ;
if ( project ! = null )
{
BLL . LogService . DeleteLog ( rowID ) ;
//BLL.ReportRemindService.DeleteReportRemindByProjectId(rowID);
//BLL.ProjectUnitService.DeleteProjectUnitByProjectId(rowID);
BLL . ProjectService . DeleteProject ( rowID ) ;
}
}
}
BindGrid ( ) ;
ShowNotify ( "操作完成!" , MessageBoxIcon . Success ) ;
}
}
#endregion
/// <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 ( ) ;
}
protected void Grid1_Sort ( object sender , FineUIPro . GridSortEventArgs e )
{
BindGrid ( ) ;
}
/// <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 ;
}
var project = BLL . ProjectService . GetProjectByProjectId ( Grid1 . SelectedRowID ) ;
if ( project ! = null )
{
if ( project . ProjectState = = BLL . Const . ProjectState_2 | | project . ProjectState = = BLL . Const . ProjectState_3 )
{
if ( this . CurrUser . UserId = = BLL . Const . sysglyId ) //系统管理员可修改停工或竣工的状态
{
PageContext . RegisterStartupScript ( Window1 . GetShowReference ( String . Format ( "ProjectSetSave.aspx?ProjectId={0}" , Grid1 . SelectedRowID , "编辑 - " ) ) ) ;
}
else
{
PageContext . RegisterStartupScript ( Window1 . GetShowReference ( String . Format ( "ProjectSetView.aspx?ProjectId={0}" , Grid1 . SelectedRowID , "查看 - " ) ) ) ;
}
}
else
{
if ( this . btnMenuEdit . Hidden & & this . CurrUser . UserId ! = BLL . Const . sysglyId ) ////双击事件 编辑权限有:编辑页面,无:查看页面 或者状态是完成时查看页面
{
PageContext . RegisterStartupScript ( Window1 . GetShowReference ( String . Format ( "ProjectSetView.aspx?ProjectId={0}" , Grid1 . SelectedRowID , "查看 - " ) ) ) ;
}
else
{
PageContext . RegisterStartupScript ( Window1 . GetShowReference ( String . Format ( "ProjectSetSave.aspx?ProjectId={0}" , Grid1 . SelectedRowID , "编辑 - " ) ) ) ;
}
}
}
}
2023-10-18 15:55:42 +08:00
/// <summary>
/// 关联摄像头
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void btnMonitor_Click ( object sender , EventArgs e )
{
var sysSet16 = ( from x in Funs . DB . Sys_Set where x . SetName = = "视频监控地址" select x ) . ToList ( ) . FirstOrDefault ( ) ;
var sysSet17 = ( from x in Funs . DB . Sys_Set where x . SetName = = "视频监控密码" select x ) . ToList ( ) . FirstOrDefault ( ) ;
if ( sysSet16 = = null )
{
ShowNotify ( "视频监控地址未设置!" , MessageBoxIcon . Warning ) ;
return ;
}
if ( sysSet17 = = null )
{
ShowNotify ( "视频监控密码未设置!" , MessageBoxIcon . Warning ) ;
return ;
}
if ( ! string . IsNullOrEmpty ( Grid1 . SelectedRowID ) )
{
string url = sysSet16 . SetValue ;
string username = "admin" ;
string password = sysSet17 . SetValue ;
2021-04-30 10:28:37 +08:00
2023-10-18 15:55:42 +08:00
if ( string . IsNullOrEmpty ( URLToken ) )
{
String res = BLL . CommonService . CreateGetHttpResponse ( url + "api/v1/login?username=" + username + "&password=" + Funs . EncryptionPassword ( password ) ) ;
Dictionary < string , string > dicres = JsonConvert . DeserializeObject < Dictionary < string , string > > ( res ) ;
URLToken = dicres [ "URLToken" ] ;
}
var project = Funs . DB . Base_Project . FirstOrDefault ( x = > x . ProjectId = = Grid1 . SelectedRowID ) ;
string resUserInfor = BLL . CommonService . CreateGetHttpResponse ( url + "api/v1/user/info?token=" + URLToken + "&username=" + project . ProjectCode ) ;
if ( "user not found" . Equals ( resUserInfor ) | | "远程服务器返回错误: (400) 错误的请求。" . Equals ( resUserInfor ) )
{
string resUserSave = BLL . CommonService . CreateGetHttpResponse ( url + "api/v1/user/save?token=" + URLToken + "&ID=0&Username=" + project . ProjectCode + "&Role=操作员,观众&Enable=true" ) ;
Dictionary < string , string > dicUserSave = JsonConvert . DeserializeObject < Dictionary < string , string > > ( resUserSave ) ;
project . MonitorId = dicUserSave [ "ID" ] ;
string newPassWord = Funs . EncryptionPassword ( DateTime . Now . Ticks . ToString ( ) ) ;
newPassWord = newPassWord . Substring ( newPassWord . Length - 9 , 8 ) ;
string resResPS = BLL . CommonService . CreateGetHttpResponse ( url + "api/v1/user/resetpassword?token=" + URLToken + "&id=" + dicUserSave [ "ID" ] + "&password=" + newPassWord ) ;
project . MonitorPW = newPassWord ;
Funs . DB . SubmitChanges ( ) ;
}
PageContext . RegisterStartupScript ( Window1 . GetShowReference ( String . Format ( "ProjectMonitorList.aspx?ProjectCode={0}&Id={1}&URLToken={2}" , project . ProjectCode , project . MonitorId , URLToken , "查看 - " ) ) ) ;
}
else
{
ShowNotify ( "请选择项目进入!" , MessageBoxIcon . Warning ) ;
}
}
/// <summary>
/// 查看
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void btnView_Click ( object sender , EventArgs e )
2021-04-30 10:28:37 +08:00
{
if ( ! string . IsNullOrEmpty ( Grid1 . SelectedRowID ) )
{ PageContext . RegisterStartupScript ( Window1 . GetShowReference ( String . Format ( "ProjectSetMap.aspx?projectId={0}&value=0" , Grid1 . SelectedRowID , "查看 - " ) ) ) ; }
}
#region 获 取 按 钮 权 限
/// <summary>
/// 获取按钮权限
/// </summary>
/// <param name="button"></param>
/// <returns></returns>
private void GetButtonPower ( )
{
if ( Request . Params [ "value" ] = = "0" )
{
return ;
}
string menuId = Const . SeverProjectSetMenuId ;
if ( ! string . IsNullOrEmpty ( this . CurrUser . LoginProjectId ) )
{
menuId = BLL . Const . ProjectSetMenuId ;
}
var buttonList = BLL . CommonService . GetAllButtonList ( this . CurrUser . LoginProjectId , this . CurrUser . UserId , menuId ) ;
if ( buttonList . Count ( ) > 0 )
{
if ( buttonList . Contains ( BLL . Const . BtnAdd ) )
{
this . btnNew . Hidden = false ;
}
if ( buttonList . Contains ( BLL . Const . BtnModify ) | | buttonList . Contains ( BLL . Const . BtnSave ) )
{
this . btnMenuEdit . Hidden = false ;
}
if ( buttonList . Contains ( BLL . Const . BtnDelete ) )
{
this . btnMenuDelete . Hidden = false ;
}
}
}
#endregion
#region 判 断 是 否 可 删 除
/// <summary>
/// 判断是否可以删除
/// </summary>
/// <returns></returns>
private bool judgementDelete ( string id , bool isShow )
{
string content = string . Empty ;
//if (Funs.DB.ProjectData_TeamGroup.FirstOrDefault(x => x.ProjectId == id) != null)
//{
// content += "该项目已在【项目班组】中使用,不能删除!";
//}
//if (Funs.DB.ProjectData_WorkArea.FirstOrDefault(x => x.ProjectId == id) != null)
//{
// content += "该项目已在【单位工程】中使用,不能删除!";
//}
//if (Funs.DB.Project_ProjectUnit.FirstOrDefault(x => x.ProjectId == id) != null)
//{
// content += "该项目已在【项目单位】中使用,不能删除!";
//}
//if (Funs.DB.Project_ProjectUser.FirstOrDefault(x => x.ProjectId == id) != null)
//{
// content += "该项目已在【项目用户】中使用,不能删除!";
//}
//if (Funs.DB.SecuritySystem_SafetyManageOrganization.FirstOrDefault(x => x.ProjectId == id) != null)
//{
// content += "该项目已在【项目安全管理组织机构表】中使用,不能删除!";
//}
//if (Funs.DB.SecuritySystem_SafetyOrganization.FirstOrDefault(x => x.ProjectId == id) != null)
//{
// content += "该项目已在【项目安全管理机构表】中使用,不能删除!";
//}
//if (Funs.DB.SecuritySystem_SafetySystem.FirstOrDefault(x => x.ProjectId == id) != null)
//{
// content += "该项目已在【项目安全组织体系表】中使用,不能删除!";
//}
//var sysCode = Funs.DB.Sys_CodeRecords.Where(x => x.ProjectId == id);
//if (sysCode.Count()> 0)
//{
// foreach (var item in sysCode)
// {
// var menu = Funs.DB.Sys_Menu.FirstOrDefault(x => x.MenuId == item.MenuId);
// if (menu != null)
// {
// content += "该项目已在【" + menu.MenuName + "】中使用,不能删除!";
// }
// else
// {
// content += "该项目已在【单据编码】中使用,不能删除!";
// }
// }
//}
//var flowOperate = Funs.DB.Sys_FlowOperate.Where(x => x.ProjectId == id);
//if (flowOperate.Count() > 0)
//{
// foreach (var item in flowOperate)
// {
// var menu = Funs.DB.Sys_Menu.FirstOrDefault(x => x.MenuId == item.MenuId);
// if (menu != null)
// {
// content += "该项目已在【" + menu.MenuName + "】中使用,不能删除!";
// }
// else
// {
// content += "该项目已在【审核流程】中使用,不能删除!";
// }
// }
//}
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="unitId"></param>
/// <returns></returns>
protected string ConvertProjectManager ( object projectId )
{
return ProjectService . GetProjectManagerName ( projectId . ToString ( ) ) ;
}
/// <summary>
/// 施工经理
/// </summary>
/// <param name="unitId"></param>
/// <returns></returns>
protected string ConvertConstructionManager ( object projectId )
{
return BLL . ProjectService . GetConstructionManagerName ( projectId . ToString ( ) ) ;
}
/// <summary>
/// 安全经理
/// </summary>
/// <param name="unitId"></param>
/// <returns></returns>
protected string ConvertHSSEManager ( object projectId )
{
return BLL . ProjectService . GetHSSEManagerName ( projectId . ToString ( ) ) ;
}
#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 ( ) ;
}
#endregion
/// <summary>
/// 进入项目现场
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void btnEnter_Click ( object sender , EventArgs e )
{
if ( ! string . IsNullOrEmpty ( Grid1 . SelectedRowID ) )
{
string url = "~/indexProject.aspx?projectId=" + Grid1 . SelectedRowID ;
UserService . UpdateLastUserInfo ( this . CurrUser . UserId , null , false , Grid1 . SelectedRowID ) ;
PageContext . Redirect ( url , "_top" ) ;
}
else
{
ShowNotify ( "请选择项目进入!" , MessageBoxIcon . Warning ) ;
}
}
}
}