using System;
using System.Collections.Generic;
using System.Data.SqlClient;
using System.Data;
using System.Text;
using AspNet = System.Web.UI.WebControls;
using BLL;
namespace FineUIPro.Web.HJGL.MaterialManage
{
    public partial class StockSelect : PageBase
    {
        #region 加载页面
        /// 
        /// 加载页面
        /// 
        /// 
        /// 
        protected void Page_Load(object sender, EventArgs e)
        {
            if (!IsPostBack)
            {
                ddlPageSize.SelectedValue = Grid1.PageSize.ToString();
                this.drpWeldType.DataTextField = "Text";
                this.drpWeldType.DataValueField = "Value";
                this.drpWeldType.DataSource = BLL.DropListService.HJGL_ConsumablesTypeList();
                this.drpWeldType.DataBind();
                Funs.FineUIPleaseSelect(this.drpWeldType);
                BLL.UnitStoreService.InitUnitStoreDropDownList(drpUnitStore, null, true);
                // 绑定表格
                BindGrid();
            }
        }
        /// 
        /// 绑定数据
        /// 
        private void BindGrid()
        {
            string strSql = @"  SELECT v.WeldId, weld.ConsumablesCode, weld.ConsumablesName,weld.SteelFormat,case weld.ConsumablesType when '1' then '焊丝' when '2' then '焊条' when '3' then '焊剂' else '' end as WeldTypeName,weld.WeldUnit,(unit.UnitName+'('+store.UnitStoreName+')') AS UnitStoreName,
                                     (CASE WHEN weld.ConvertValue>0
                                           THEN v.RemainingAmount*weld.ConvertValue 
                                           ELSE v.[Weight] END) AS RemainingAmount,
                                     (CASE WHEN weld.ConvertValue>0
                                           THEN v.RecycleAmount*weld.ConvertValue 
                                           ELSE NULL END) AS RecycleAmount
                                 FROM                
                                     (SELECT stockIn.WeldId, (SUM(ISNULL(stockIn.Amount,0))-SUM(ISNULL(stockIn.UsingAmount,0)))AS RemainingAmount,SUM(stockIn.[Weight]) AS [Weight],stockIn.UnitStoreId,
									         SUM(ISNULL(stockIn.RecycleAmount,0)) AS RecycleAmount               
                                      FROM dbo.Weld_StockIn stockIn
                                      GROUP BY stockIn.UnitStoreId,stockIn.WeldId)v
                                      LEFT JOIN dbo.Base_Consumables AS weld ON weld.ConsumablesId=v.WeldId
                                      LEFT JOIN dbo.Weld_UnitStore store ON store.UnitStoreId=v.UnitStoreId
                                      LEFT JOIN dbo.Base_Unit unit ON unit.UnitId=store.UnitId
                                 WHERE 1=1";
            List listStr = new List();
            if (!string.IsNullOrEmpty(this.txtWeldCode.Text.Trim()))
            {
                strSql += " AND weld.ConsumablesCode LIKE @ConsumablesCode";
                listStr.Add(new SqlParameter("@ConsumablesCode", "%" + this.txtWeldCode.Text.Trim() + "%"));
            }
            if (this.drpUnitStore.SelectedValue != BLL.Const._Null)
            {
                strSql += " AND v.UnitStoreId = @UnitStoreId";
                listStr.Add(new SqlParameter("@UnitStoreId", drpUnitStore.SelectedValue));
            }
            if (drpWeldType.SelectedValue != BLL.Const._Null)
            {
                strSql += " AND weld.ConsumablesType = @WeldTypeId";
                listStr.Add(new SqlParameter("@WeldTypeId", drpWeldType.SelectedValue));
            }
            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();
        }
        #endregion
        #region 表头过滤
        protected void Grid1_FilterChange(object sender, EventArgs e)
        {
            BindGrid();
        }
        #endregion
        #region 页索引改变事件
        /// 
        /// 页索引改变事件
        /// 
        /// 
        /// 
        protected void Grid1_PageIndexChange(object sender, GridPageEventArgs e)
        {
            Grid1.PageIndex = e.NewPageIndex;
            BindGrid();
        }
        #endregion
        #region 排序
        /// 
        /// 排序
        /// 
        /// 
        /// 
        protected void Grid1_Sort(object sender, GridSortEventArgs e)
        {
            Grid1.SortDirection = e.SortDirection;
            Grid1.SortField = e.SortField;
            BindGrid();
        }
        #endregion
        #region 分页选择下拉改变事件
        /// 
        /// 分页选择下拉改变事件
        /// 
        /// 
        /// 
        protected void ddlPageSize_SelectedIndexChanged(object sender, EventArgs e)
        {
            Grid1.PageSize = Convert.ToInt32(ddlPageSize.SelectedValue);
            BindGrid();
        }
        #endregion
        #region 查询
        /// 
        /// 查询
        /// 
        /// 
        /// 
        protected void TextBox_TextChanged(object sender, EventArgs e)
        {
            BindGrid();
        }
        protected void drpWeldType_SelectedIndexChanged(object sender, EventArgs e)
        {
            BindGrid();
        }
        #endregion
        #region 查看明细
        /// 
        /// 双击Grid事件
        /// 
        /// 
        /// 
        protected void Grid1_RowDoubleClick(object sender, GridRowClickEventArgs e)
        {
            btnMenuView_Click(null, null);
        }
        /// 
        /// 查看初始化明细
        /// 
        /// 
        /// 
        protected void btnMenuView_Click(object sender, EventArgs e)
        {
            if (Grid1.SelectedRowIndexArray.Length == 0)
            {
                Alert.ShowInTop("请至少选择一条记录!", MessageBoxIcon.Warning);
                return;
            }
            string id = Grid1.SelectedRowID;
            if (!string.IsNullOrEmpty(id))
            {
                PageContext.RegisterStartupScript(Window1.GetShowReference(String.Format("StockSelectDetail.aspx?WeldId={0}", id, "编辑 - ")));
            }
        }
        #endregion
        #region 导出按钮
        /// 导出按钮
        /// 
        /// 
        /// 
        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();
            sb.Append("");
            sb.Append("");
            sb.Append("");
            this.Grid1.PageSize = 10000;
            BindGrid();
            foreach (GridColumn column in grid.Columns)
            {
                sb.AppendFormat("| {0} | ", column.HeaderText);
            }
            sb.Append("
");
            foreach (GridRow row in grid.Rows)
            {
                sb.Append("");
                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("| {0} | ", html);
                }
                sb.Append("
");
            }
            sb.Append("
");
            return sb.ToString();
        }
        #endregion
    }
}