using BLL;
using FineUIPro.Web.Controls;
using System;
using System.Collections.Generic;
using System.Data;
using System.Data.SqlClient;
using System.Text;
using AspNet = System.Web.UI.WebControls;
using Model;
namespace FineUIPro.Web.HJGL.PersonManage
{
    public partial class TestApplication : PageBase
    {
        #region 加载
        /// 
        /// 加载页面
        /// 
        /// 
        /// 
        protected void Page_Load(object sender, EventArgs e)
        {
            if (!IsPostBack)
            {
                this.ddlPageSize.SelectedValue = Grid1.PageSize.ToString();
                BLL.UnitService.InitUnitByProjectIdUnitTypeDropDownList(this.drpUnitId, this.CurrUser.LoginProjectId, BLL.Const.ProjectUnitType_2, true);
                // 绑定表格
                this.BindGrid();
            }
        }
       /// 
       /// 数据绑定
       /// 
        private void BindGrid()
        {
            string strSql = @"SELECT testApplication.ApplicationTestId, 
                                     testApplication.ProjectId, 
                                     testApplication.ConUnit, 
                                     testApplication.ConUnitWeldingEngineer, 
                                     testApplication.Certificate, 
                                     testApplication.CertificateValidity, 
                                     testApplication.PreTestDate, 
                                     testApplication.WelderClass, 
                                     testApplication.WelderCode, 
                                     testApplication.WelderName, 
                                     testApplication.IdentityCard, 
                                     testApplication.WeldingPosition, 
                                     testApplication.WeldingMethod, 
                                     testApplication.SpecimenSize, 
                                     testApplication.MaterialCategory, 
                                     testApplication.AppearanceEvaluation, 
                                     testApplication.FirstExamination, 
                                     testApplication.SecondExamination, 
                                     testApplication.WelderCondition, 
                                     testApplication.ExamDate, 
                                     testApplication.InvigilatorConfirmed, 
                                     testApplication.Area, 
                                     testApplication.ExamTrustDate, 
                                     testApplication.ExamTrustCode, 
                                     testApplication.CheckDate, 
                                     testApplication.CheckResult, 
                                     testApplication.NDTFilm, 
                                     testApplication.CheckUnit, 
                                     testApplication.OwnerNum, 
                                     Unit.UnitName,
                                     u.UserName AS ConUnitWeldingEngineerName,
									 WeldingMethod.WeldingMethodCode,
									 workArea.WorkAreaName,
									 checkUnit.UnitName AS CheckUnitName"
                         + @" FROM Welder_TestApplication AS testApplication"
                         + @" LEFT JOIN Base_Unit AS Unit ON Unit.UnitId = testApplication.ConUnit"
                         + @" LEFT JOIN Sys_User AS u ON u.UserId = testApplication.ConUnitWeldingEngineer"
                         + @" LEFT JOIN Base_WeldingMethod AS WeldingMethod ON WeldingMethod.WeldingMethodId = testApplication.WeldingMethod"
                         + @" LEFT JOIN ProjectData_WorkArea AS workArea ON workArea.WorkAreaId = testApplication.Area"
                         + @" LEFT JOIN Base_Unit AS checkUnit ON checkUnit.UnitId = testApplication.CheckUnit"
                         + @" WHERE testApplication.ProjectId=@projectId";
            List listStr = new List();
            listStr.Add(new SqlParameter("@projectId", this.CurrUser.LoginProjectId));
            if (this.drpUnitId.SelectedValue != BLL.Const._Null)
            {
                strSql += " AND testApplication.ConUnit = @unitId";
                listStr.Add(new SqlParameter("@unitId", this.drpUnitId.SelectedValue));
            }
            if (!string.IsNullOrEmpty(this.txtWelderName.Text.Trim()))
            {
                strSql += " AND testApplication.WelderName LIKE @welderName";
                listStr.Add(new SqlParameter("@welderName", "%" + this.txtWelderName.Text.Trim() + "%"));
            }
            if (!string.IsNullOrEmpty(this.drpWelderCondition.SelectedValue))
            {
                strSql += " AND testApplication.WelderCondition = @welderCondition";
                listStr.Add(new SqlParameter("@welderCondition", this.drpWelderCondition.SelectedValue));
            }
            if (!string.IsNullOrEmpty(this.txtStateDate.Text.Trim()))
            {
                strSql += " AND testApplication.ExamDate >= @startDate";
                listStr.Add(new SqlParameter("@startDate", this.txtStateDate.Text.Trim()));
            }
            if (!string.IsNullOrEmpty(this.txtEndDate.Text.Trim()))
            {
                strSql += " AND testApplication.ExamDate <= @endDate";
                listStr.Add(new SqlParameter("@endDate", this.txtEndDate.Text.Trim()));
            }
            if (this.CurrUser.UnitId != BLL.Const.UnitId_XJYJ)
            {
                var user = BLL.ProjectUserService.GetCurrProjectUserByUserId(this.CurrUser.UserId);
                if (user != null)
                {
                    if (!string.IsNullOrEmpty(user.RoleId) && user.RoleId.Contains(BLL.Const.CVWeldingManager))
                    {
                        strSql += " AND testApplication.WelderClass='土建'";
                    }
                    else
                    {
                        strSql += " AND testApplication.WelderClass <> '土建'";
                    }
                }
            }
            SqlParameter[] parameter = listStr.ToArray();
            DataTable tb = SQLHelper.GetDataTableRunText(strSql, parameter);
            Grid1.RecordCount = tb.Rows.Count;
            //tb = GetFilteredTable(Grid1.FilteredData, tb);
            var table = this.GetPagedDataTable(Grid1, tb);
            Grid1.DataSource = table;
            Grid1.DataBind();
        }
        /// 
        /// 查询
        /// 
        /// 
        /// 
        protected void btnQuery_Click(object sender, EventArgs e)
        {
            BindGrid();
        }
        /// 
        /// 分页下拉选择事件
        /// 
        /// 
        /// 
        protected void ddlPageSize_SelectedIndexChanged(object sender, EventArgs e)
        {
            Grid1.PageSize = Convert.ToInt32(ddlPageSize.SelectedValue);
            BindGrid();
        }
        
        /// 
        /// 排序
        /// 
        /// 
        /// 
        protected void Grid1_Sort(object sender, GridSortEventArgs e)
        {
            BindGrid();
        }
        /// 
        /// 改变索引事件
        /// 
        /// 
        /// 
        protected void Grid1_PageIndexChange(object sender, GridPageEventArgs e)
        {
            BindGrid();
        }
        /// 
        /// 关闭弹出窗体
        /// 
        /// 
        /// 
        protected void Window1_Close(object sender, WindowCloseEventArgs e)
        {
            BindGrid();
        }
        #endregion
        #region 增加
        /// 
        /// 增加按钮
        /// 
        /// 
        /// 
        protected void btnNew_Click(object sender, EventArgs e)
        {
            if (GetButtonPower(Const.BtnAdd))
            {
                PageContext.RegisterStartupScript(Window1.GetShowReference(String.Format("TestApplicationEdit.aspx", "新增 - ")));
            }
            else
            {
                Alert.ShowInTop("您没有这个权限,请与管理员联系!", MessageBoxIcon.Warning);
                return;
            }
        }
        #endregion
        #region 编辑
        /// 
        /// 右键编辑
        /// 
        /// 
        /// 
        protected void btnMenuEdit_Click(object sender, EventArgs e)
        {
            this.EditData();
        }
        /// 
        /// 编辑数据方法
        /// 
        private void EditData()
        {
            if (GetButtonPower(Const.BtnModify))
            {
                if (Grid1.SelectedRowIndexArray.Length == 0)
                {
                    Alert.ShowInTop("请至少选择一条记录", MessageBoxIcon.Warning);
                    return;
                }
                PageContext.RegisterStartupScript(Window1.GetShowReference(String.Format("TestApplicationEdit.aspx?applicationTestId={0}", Grid1.SelectedRowID, "编辑 - ")));
            }
            else
            {
                Alert.ShowInTop("您没有这个权限,请与管理员联系!", MessageBoxIcon.Warning);
                return;
            }
        }
        /// 
        /// 行双击事件
        /// 
        /// 
        /// 
        protected void Grid1_RowDoubleClick(object sender, GridRowClickEventArgs e)
        {
            this.EditData();
        }
        #endregion
        #region 删除
        /// 
        /// 右键删除
        /// 
        /// 
        /// 
        protected void btnMenuDelete_Click(object sender, EventArgs e)
        {
            if (GetButtonPower(Const.BtnDelete))
            {
                if (Grid1.SelectedRowIndexArray.Length > 0)
                {
                    string strShowNotify = string.Empty;
                    foreach (int rowIndex in Grid1.SelectedRowIndexArray)
                    {
                        string rowID = Grid1.DataKeys[rowIndex][0].ToString();
                        var testApplication = BLL.TestApplicationService.GetTestApplicationById(rowID);
                        if (testApplication != null)
                        {
                            string cont = judgementDelete(rowID);
                            if (string.IsNullOrEmpty(cont))
                            {
                                BLL.TestApplicationService.DeleteTestApplicationById(rowID);
                            }
                            else
                            {
                                strShowNotify += "焊工考试申请" + ":" + testApplication.WelderCode + cont;
                            }
                        }
                    }
                    BindGrid();
                    if (!string.IsNullOrEmpty(strShowNotify))
                    {
                        Alert.ShowInTop(strShowNotify, MessageBoxIcon.Warning);
                    }
                    else
                    {
                        ShowNotify("删除成功!", MessageBoxIcon.Success);
                    }
                }
            }
            else
            {
                Alert.ShowInTop("您没有这个权限,请与管理员联系!", MessageBoxIcon.Warning);
                return;
            }
        }
        #region 判断是否可删除
        /// 
        /// 判断是否可以删除
        /// 
        /// 
        private string judgementDelete(string id)
        {
            string content = string.Empty;
            //if (Funs.DB.BS_WeldMethodItem.FirstOrDefault(x => x.WED_ID == id) != null)
            //{
            //    content += "已在【焊口信息】中使用,不能删除!";
            //}
            return content;
        }
        #endregion
        #endregion
        #region 导入、导出
        /// 
        /// 导入
        /// 
        /// 
        /// 
        protected void btnImport_Click(object sender, EventArgs e)
        {
            if (GetButtonPower(Const.BtnAdd))
            {
                PageContext.RegisterStartupScript(Window1.GetShowReference(String.Format("TestApplicationDataIn.aspx", "导入 - ")));
            }
            else
            {
                Alert.ShowInTop("您没有这个权限,请与管理员联系!", MessageBoxIcon.Warning);
                return;
            }
        }
        /// 
        /// 导出
        /// 
        /// 
        /// 
        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();
        }
        ///  
        /// 导出方法
        /// 
        /// 
        /// 
        private string GetGridTableHtml(Grid grid)
        {
            StringBuilder sb = new StringBuilder();
            grid.PageSize = this.Grid1.RecordCount;
            BindGrid();
            MultiHeaderTable mht = new MultiHeaderTable();
            mht.ResolveMultiHeaderTable(Grid1.Columns);
            sb.Append("");
            sb.Append("");
            foreach (List
");
            return sb.ToString();
        }
        #endregion
        #region 获取按钮权限
        /// 
        /// 获取按钮权限
        /// 
        /// 
        /// 
        private bool GetButtonPower(string button)
        {
            return BLL.CommonService.GetAllButtonPowerList(this.CurrUser.LoginProjectId, this.CurrUser.UserId, BLL.Const.HJGL_TestApplicationMenuId, button);
        }
        #endregion
        
    }
}