using BLL;
using System;
using System.Collections.Generic;
using System.Data;
using System.Linq;
namespace FineUIPro.Web.HSSE.InformationProject
{
    public partial class ConstructionStandardIdentifyEdit : PageBase
    {
        #region  定义项
        /// 
        /// 主键
        /// 
        private string ConstructionStandardIdentifyId
        {
            get
            {
                return (string)ViewState["ConstructionStandardIdentifyId"];
            }
            set
            {
                ViewState["ConstructionStandardIdentifyId"] = value;
            }
        }
        /// 
        /// 主键
        /// 
        private string ProjectId
        {
            get
            {
                return (string)ViewState["ProjectId"];
            }
            set
            {
                ViewState["ProjectId"] = value;
            }
        }
        /// 
        /// 选中项
        /// 
        public string[] arr
        {
            get
            {
                return (string[])ViewState["arr"];
            }
            set
            {
                ViewState["arr"] = value;
            }
        }
        /// 
        /// GV被选择项列表
        /// 
        public List ItemSelectedList
        {
            get
            {
                return (List)ViewState["ItemSelectedList"];
            }
            set
            {
                ViewState["ItemSelectedList"] = value;
            }
        }
        public List ItemSelectedList2
        {
            get
            {
                return (List)ViewState["ItemSelectedList2"];
            }
            set
            {
                ViewState["ItemSelectedList2"] = value;
            }
        }
        #endregion
        #region  页面加载
        /// 
        /// 页面加载
        /// 
        /// 
        /// 
        protected void Page_Load(object sender, EventArgs e)
        {
            if (!IsPostBack)
            {
                this.btnClose.OnClientClick = ActiveWindow.GetHideReference();
                this.ProjectId = this.CurrUser.LoginProjectId;
                BLL.ConstValue.InitConstValueDropDownList(this.drpCNProfessional, ConstValue.Group_CNProfessional, true);
                Funs.DropDownPageSize(this.ddlPageSize);
                this.ItemSelectedList = new List();
                this.ItemSelectedList2 = new List();
                this.ConstructionStandardIdentifyId = Request.Params["ConstructionStandardIdentifyId"];
                if (!string.IsNullOrEmpty(this.ConstructionStandardIdentifyId))
                {
                    Model.InformationProject_ConstructionStandardIdentify constructionStandardIdentify = BLL.ConstructionStandardIdentifyService.GetConstructionStandardIdentifyById(this.ConstructionStandardIdentifyId);
                    if (constructionStandardIdentify != null)
                    {
                        this.ProjectId = constructionStandardIdentify.ProjectId;
                        this.txtConstructionStandardIdentifyCode.Text = CodeRecordsService.ReturnCodeByDataId(this.ConstructionStandardIdentifyId);
                        this.txtRemark.Text = constructionStandardIdentify.Remark;
                    }
                    BindGridById(this.ConstructionStandardIdentifyId);//显示选中的项            
                }
                else
                {
                    // 绑定显示所有项
                    BindGrid();
                    this.ckbAll.Checked = true;
                    ////自动生成编码
                    this.txtConstructionStandardIdentifyCode.Text = BLL.CodeRecordsService.ReturnCodeByMenuIdProjectId(BLL.Const.ConstructionStandardIdentifyMenuId, this.ProjectId, this.CurrUser.UnitId);
                }
                ///初始化审核菜单
                this.ctlAuditFlow.MenuId = BLL.Const.ConstructionStandardIdentifyMenuId;
                this.ctlAuditFlow.DataId = this.ConstructionStandardIdentifyId;
                this.ctlAuditFlow.ProjectId = this.ProjectId;
                this.ctlAuditFlow.UnitId = this.CurrUser.UnitId;
            }
        }
        /// 
        /// 显示所有
        /// 
        /// 
        /// 
        protected void ckbAll_CheckedChanged(object sender, CheckedEventArgs e)
        {
            if (this.ckbAll.Checked == true)
            {
                BindGrid();
            }
            else
            {
                BindGridById(this.ConstructionStandardIdentifyId);
            }
        }
        /// 
        /// 显示勾选的项
        /// 
        private void BindGridById(string constructionStandardIdentifyId)
        {
            var q = (from x in Funs.DB.View_InformationProject_ConstructionStandardSelectedItem
                     where x.ConstructionStandardIdentifyId == constructionStandardIdentifyId
                     orderby x.StandardNo
                     select x).ToList();
            if (!string.IsNullOrEmpty(this.txtStandardGrade.Text.Trim()))
            {
                q = q.Where(e => e.StandardGrade.Contains(this.txtStandardGrade.Text.Trim())).ToList();
            }
            if (!string.IsNullOrEmpty(this.txtStandardNo.Text.Trim()))
            {
                q = q.Where(e => e.StandardNo.Contains(this.txtStandardNo.Text.Trim())).ToList();
            }
            if (!string.IsNullOrEmpty(this.txtStandardName.Text.Trim()))
            {
                q = q.Where(e => e.StandardName.Contains(this.txtStandardName.Text.Trim())).ToList();
            }
            if (this.drpCNProfessional.SelectedValue != BLL.Const._Null)
            {
                string code = this.drpCNProfessional.SelectedValue;
                if (code == "1")
                {
                    q = q.Where(e => e.IsSelected1 == true).ToList();
                }
                else if (code == "2")
                {
                    q = q.Where(e => e.IsSelected2 == true).ToList();
                }
                else if (code == "3")
                {
                    q = q.Where(e => e.IsSelected3 == true).ToList();
                }
                else if (code == "4")
                {
                    q = q.Where(e => e.IsSelected4 == true).ToList();
                }
                else if (code == "5")
                {
                    q = q.Where(e => e.IsSelected5 == true).ToList();
                }
                else if (code == "6")
                {
                    q = q.Where(e => e.IsSelected6 == true).ToList();
                }
                else if (code == "7")
                {
                    q = q.Where(e => e.IsSelected7 == true).ToList();
                }
                else if (code == "8")
                {
                    q = q.Where(e => e.IsSelected8 == true).ToList();
                }
                else if (code == "9")
                {
                    q = q.Where(e => e.IsSelected9 == true).ToList();
                }
                else if (code == "10")
                {
                    q = q.Where(e => e.IsSelected10 == true).ToList();
                }
                else if (code == "11")
                {
                    q = q.Where(e => e.IsSelected11 == true).ToList();
                }
                else if (code == "12")
                {
                    q = q.Where(e => e.IsSelected12 == true).ToList();
                }
                else if (code == "13")
                {
                    q = q.Where(e => e.IsSelected13 == true).ToList();
                }
                else if (code == "14")
                {
                    q = q.Where(e => e.IsSelected14 == true).ToList();
                }
                else if (code == "15")
                {
                    q = q.Where(e => e.IsSelected15 == true).ToList();
                }
                else if (code == "16")
                {
                    q = q.Where(e => e.IsSelected16 == true).ToList();
                }
                else if (code == "17")
                {
                    q = q.Where(e => e.IsSelected17 == true).ToList();
                }
                else if (code == "18")
                {
                    q = q.Where(e => e.IsSelected18 == true).ToList();
                }
                else if (code == "19")
                {
                    q = q.Where(e => e.IsSelected19 == true).ToList();
                }
                else if (code == "20")
                {
                    q = q.Where(e => e.IsSelected10 == true).ToList();
                }
                else if (code == "10")
                {
                    q = q.Where(e => e.IsSelected20 == true).ToList();
                }
                else if (code == "21")
                {
                    q = q.Where(e => e.IsSelected21 == true).ToList();
                }
                else if (code == "22")
                {
                    q = q.Where(e => e.IsSelected22 == true).ToList();
                }
                else if (code == "23")
                {
                    q = q.Where(e => e.IsSelected23 == true).ToList();
                }
                else if (code == "90")
                {
                    q = q.Where(e => e.IsSelected90 == true).ToList();
                }
            }
            DataTable tb = this.LINQToDataTable(q);
            // 2.获取当前分页数据
            Grid1.RecordCount = tb.Rows.Count;
            tb = GetFilteredTable(Grid1.FilteredData, tb);
            var table = this.GetPagedDataTable(Grid1, tb);
            Grid1.DataSource = table;
            Grid1.DataBind();
            List lists = BLL.ConstructionStandardSelectedItemService.GetConstructionStandardSelectedItemsByConstructionStandardIdentifyId(this.ConstructionStandardIdentifyId);
            if (lists!=null)
            {
                foreach (var item in lists)
                {
                    ItemSelectedList2.Add(item.StandardId.ToString());
                }
                var StandardIds = lists.Select(x => x.StandardId).ToArray();
                this.Grid1.SelectedRowIDArray = StandardIds;
            }
        }
        /// 
        /// 绑定显示所有项数据
        /// 
        private void BindGrid()
        {
            var q = (from x in Funs.DB.Law_HSSEStandardsList
                     orderby x.StandardNo
                     select x).ToList();
            if (!string.IsNullOrEmpty(this.txtStandardGrade.Text.Trim()))
            {
                q = q.Where(e => e.StandardGrade.Contains(this.txtStandardGrade.Text.Trim())).ToList();
            }
            if (!string.IsNullOrEmpty(this.txtStandardNo.Text.Trim()))
            {
                q = q.Where(e => e.StandardNo.Contains(this.txtStandardNo.Text.Trim())).ToList();
            }
            if (!string.IsNullOrEmpty(this.txtStandardName.Text.Trim()))
            {
                q = q.Where(e => e.StandardName.Contains(this.txtStandardName.Text.Trim())).ToList();
            }
            if (this.drpCNProfessional.SelectedValue != BLL.Const._Null)
            {
                string code = this.drpCNProfessional.SelectedValue;
                if (code == "1")
                {
                    q = q.Where(e => e.IsSelected1 == true).ToList();
                }
                else if (code == "2")
                {
                    q = q.Where(e => e.IsSelected2 == true).ToList();
                }
                else if (code == "3")
                {
                    q = q.Where(e => e.IsSelected3 == true).ToList();
                }
                else if (code == "4")
                {
                    q = q.Where(e => e.IsSelected4 == true).ToList();
                }
                else if (code == "5")
                {
                    q = q.Where(e => e.IsSelected5 == true).ToList();
                }
                else if (code == "6")
                {
                    q = q.Where(e => e.IsSelected6 == true).ToList();
                }
                else if (code == "7")
                {
                    q = q.Where(e => e.IsSelected7 == true).ToList();
                }
                else if (code == "8")
                {
                    q = q.Where(e => e.IsSelected8 == true).ToList();
                }
                else if (code == "9")
                {
                    q = q.Where(e => e.IsSelected9 == true).ToList();
                }
                else if (code == "10")
                {
                    q = q.Where(e => e.IsSelected10 == true).ToList();
                }
                else if (code == "11")
                {
                    q = q.Where(e => e.IsSelected11 == true).ToList();
                }
                else if (code == "12")
                {
                    q = q.Where(e => e.IsSelected12 == true).ToList();
                }
                else if (code == "13")
                {
                    q = q.Where(e => e.IsSelected13 == true).ToList();
                }
                else if (code == "14")
                {
                    q = q.Where(e => e.IsSelected14 == true).ToList();
                }
                else if (code == "15")
                {
                    q = q.Where(e => e.IsSelected15 == true).ToList();
                }
                else if (code == "16")
                {
                    q = q.Where(e => e.IsSelected16 == true).ToList();
                }
                else if (code == "17")
                {
                    q = q.Where(e => e.IsSelected17 == true).ToList();
                }
                else if (code == "18")
                {
                    q = q.Where(e => e.IsSelected18 == true).ToList();
                }
                else if (code == "19")
                {
                    q = q.Where(e => e.IsSelected19 == true).ToList();
                }
                else if (code == "20")
                {
                    q = q.Where(e => e.IsSelected10 == true).ToList();
                }
                else if (code == "10")
                {
                    q = q.Where(e => e.IsSelected20 == true).ToList();
                }
                else if (code == "21")
                {
                    q = q.Where(e => e.IsSelected21 == true).ToList();
                }
                else if (code == "22")
                {
                    q = q.Where(e => e.IsSelected22 == true).ToList();
                }
                else if (code == "23")
                {
                    q = q.Where(e => e.IsSelected23 == true).ToList();
                }
                else if (code == "90")
                {
                    q = q.Where(e => e.IsSelected90 == true).ToList();
                }
            }
            DataTable tb = this.LINQToDataTable(q);
            // 2.获取当前分页数据
            Grid1.RecordCount = tb.Rows.Count;
            tb = GetFilteredTable(Grid1.FilteredData, tb);
            var table = this.GetPagedDataTable(Grid1, tb);
            Grid1.DataSource = table;
            Grid1.DataBind();
            List lists = BLL.ConstructionStandardSelectedItemService.GetConstructionStandardSelectedItemsByConstructionStandardIdentifyId(this.ConstructionStandardIdentifyId);
            if (lists.Count() > 0)
            {
                if (lists != null)
                {
                    var StandardIds = lists.Select(x => x.StandardId).ToArray();
                    this.Grid1.SelectedRowIDArray = StandardIds;
                }
            }
        }
        /// 
        /// 查询
        /// 
        /// 
        /// 
        protected void TextBox_TextChanged(object sender, EventArgs e)
        {
            if (this.ckbAll.Checked == true)
            {
                this.BindGrid();
            }
            else
            {
                this.BindGridById(this.ConstructionStandardIdentifyId);
            }
        }
        /// 
        /// 分页索引事件
        /// 
        /// 
        /// 
        protected void Grid1_PageIndexChange(object sender, GridPageEventArgs e)
        {
            Grid1.PageIndex = e.NewPageIndex;
            if (this.ckbAll.Checked == true)
            {
                this.BindGrid();
            }
            else
            {
                this.BindGridById(this.ConstructionStandardIdentifyId);
            }
        }
        /// 
        /// 分页下拉选择
        /// 
        /// 
        /// 
        protected void ddlPageSize_SelectedIndexChanged(object sender, EventArgs e)
        {
            Grid1.PageSize = Convert.ToInt32(ddlPageSize.SelectedValue);
            if (this.ckbAll.Checked == true)
            {
                this.BindGrid();
            }
            else
            {
                this.BindGridById(this.ConstructionStandardIdentifyId);
            }
        }
        /// 
        /// 过滤
        /// 
        /// 
        /// 
        protected void Grid1_FilterChange(object sender, EventArgs e)
        {
            if (this.ckbAll.Checked == true)
            {
                this.BindGrid();
            }
            else
            {
                this.BindGridById(this.ConstructionStandardIdentifyId);
            }
        }
        #endregion
        #region  保存
        /// 
        /// 保存
        /// 
        /// 
        /// 
        protected void btnSave_Click(object sender, EventArgs e)
        {
            if (this.ckbAll.Checked == true)
            {
                if (Grid1.SelectedRowIDArray.Length == 0)
                {
                    Alert.ShowInParent("请至少选择一条记录!");
                    return;
                }
            }
            else
            {
                if (ItemSelectedList2.Count() == 0)
                {
                    Alert.ShowInParent("请至少选择一条记录!");
                    return;
                }
            }
            this.SaveData(BLL.Const.BtnSave);
            PageContext.RegisterStartupScript(ActiveWindow.GetHideRefreshReference());
        }
        /// 
        /// 提交按钮
        /// 
        /// 
        /// 
        protected void btnSubmit_Click(object sender, EventArgs e)
        {
            if (this.ckbAll.Checked == true)
            {
                if (Grid1.SelectedRowIDArray.Length == 0)
                {
                    Alert.ShowInParent("请至少选择一条记录!");
                    return;
                }
            }
            else
            {
                if (ItemSelectedList2.Count() == 0)
                {
                    Alert.ShowInParent("请至少选择一条记录!");
                    return;
                }
            }
            if (this.ctlAuditFlow.NextStep == BLL.Const.State_1 && this.ctlAuditFlow.NextPerson == BLL.Const._Null)
            {
                ShowNotify("请选择下一步办理人!", MessageBoxIcon.Warning);
                return;
            }
            this.SaveData(BLL.Const.BtnSubmit);
            PageContext.RegisterStartupScript(ActiveWindow.GetHideRefreshReference());
        }
        /// 
        /// 保存数据
        /// 
        /// 
        private void SaveData(string type)
        {
            ItemSelectedList.Clear();
            Model.InformationProject_ConstructionStandardIdentify constructionStandardIdentify = new Model.InformationProject_ConstructionStandardIdentify
            {
                ConstructionStandardIdentifyCode = this.txtConstructionStandardIdentifyCode.Text.Trim(),
                ProjectId = this.ProjectId,
                IdentifyPerson = this.CurrUser.UserId,
                IdentifyDate = DateTime.Now.Date,
                UpdateDate = DateTime.Now,
                State = BLL.Const.State_0
            };
            if (type == BLL.Const.BtnSubmit)
            {
                constructionStandardIdentify.State = this.ctlAuditFlow.NextStep;
                if (this.ctlAuditFlow.NextStep == BLL.Const.State_2)
                {
                    constructionStandardIdentify.VersionNumber = BLL.SQLHelper.RunProcNewId2("SpGetVersionNumber", "InformationProject_ConstructionStandardIdentify", "VersionNumber", this.ProjectId);
                }
            }
            constructionStandardIdentify.Remark = this.txtRemark.Text.Trim();
            if (string.IsNullOrEmpty(ConstructionStandardIdentifyId))  //新增
            {
                this.ConstructionStandardIdentifyId = SQLHelper.GetNewID(typeof(Model.InformationProject_ConstructionStandardIdentify));
                constructionStandardIdentify.ConstructionStandardIdentifyId = this.ConstructionStandardIdentifyId;
                BLL.ConstructionStandardIdentifyService.AddConstructionStandardIdentify(constructionStandardIdentify);
                BLL.LogService.AddSys_Log(this.CurrUser, constructionStandardIdentify.ConstructionStandardIdentifyCode, constructionStandardIdentify.ConstructionStandardIdentifyId, BLL.Const.ConstructionStandardIdentifyMenuId, BLL.Const.BtnAdd);
            }
            else   //重新选择
            {
                constructionStandardIdentify.ConstructionStandardIdentifyId = this.ConstructionStandardIdentifyId;
                BLL.ConstructionStandardIdentifyService.UpdateConstructionStandardIdentify(constructionStandardIdentify);
                BLL.LogService.AddSys_Log(this.CurrUser, constructionStandardIdentify.ConstructionStandardIdentifyCode, constructionStandardIdentify.ConstructionStandardIdentifyId, BLL.Const.ConstructionStandardIdentifyMenuId, BLL.Const.BtnModify);
                BLL.ConstructionStandardSelectedItemService.DeleteConstructionStandardSelectedItemByConstructionStandardIdentifyId(ConstructionStandardIdentifyId);
            }
            ///获取Grid列表选中的行
            int[] selections = Grid1.SelectedRowIndexArray;
            foreach (int rowIndex in selections)
            {
                if (!ItemSelectedList.Contains(Grid1.DataKeys[rowIndex][0].ToString()))
                {
                    ItemSelectedList.Add(Grid1.DataKeys[rowIndex][0].ToString());
                }
            }
            foreach (string item in ItemSelectedList)
            {
                Model.InformationProject_ConstructionStandardSelectedItem constructionStandardSelectedItem = new Model.InformationProject_ConstructionStandardSelectedItem
                {
                    ConstructionStandardIdentifyId = ConstructionStandardIdentifyId,
                    StandardId = item
                };
                BLL.ConstructionStandardSelectedItemService.AddConstructionStandardSelectedItem(constructionStandardSelectedItem);
            }
            ////保存流程审核数据         
            this.ctlAuditFlow.btnSaveData(this.ProjectId, BLL.Const.ConstructionStandardIdentifyMenuId, this.ConstructionStandardIdentifyId, (type == BLL.Const.BtnSubmit ? true : false), constructionStandardIdentify.ConstructionStandardIdentifyCode, "../InformationProject/ConstructionStandardIdentifyView.aspx?ConstructionStandardIdentifyId={0}");
        }
        #endregion
        #region 附件上传
        /// 
        /// 上传附件
        /// 
        /// 
        /// 
        protected void btnAttachUrl_Click(object sender, EventArgs e)
        {
            if (string.IsNullOrEmpty(this.ConstructionStandardIdentifyId))
            {
                SaveData(BLL.Const.BtnSave);
            }
            PageContext.RegisterStartupScript(WindowAtt.GetShowReference(String.Format("~/AttachFile/webuploader.aspx?toKeyId={0}&path=FileUpload/ConstructionStandardIdentifyAttachUrl&menuId={1}", ConstructionStandardIdentifyId, BLL.Const.ConstructionStandardIdentifyMenuId)));
        }
        #endregion
    }
}