using BLL; using Model; using System; using System.Collections.Generic; using System.Data; using System.IO; using System.Linq; using System.Text; using System.Web; using System.Web.UI; using System.Web.UI.WebControls; namespace FineUIPro.Web.PHTGL.InvoiceManage { public partial class InvoiceOrder : PageBase { protected void Page_Load(object sender, EventArgs e) { if (!IsPostBack) { this.GetButtonPower(); this.ddlPageSize.SelectedValue = this.Grid1.PageSize.ToString(); this.DropContractCode.DataTextField = "ContractNum"; this.DropContractCode.DataValueField = "ContractId"; this.DropContractCode.DataSource = BLL.PHTGL_ContractReviewService.GetContractReview_CompleteData(this.CurrUser.LoginProjectId); this.DropContractCode.DataBind(); Funs.FineUIPleaseSelect(DropContractCode); // 绑定表格 this.BindGrid(); } } #region 绑定数据 /// /// 绑定数据 /// private void BindGrid() { Model.PHTGL_Invoice table = new Model.PHTGL_Invoice(); table.ProjectId = this.CurrUser.LoginProjectId; if( DropContractCode.SelectedValue!=Const._Null) { table.ContractId = this.DropContractCode.SelectedValue; } var tb = BLL.PhtglInvoiceService.GetOrderInListData(table, Grid1,drpStates.SelectedValue); Grid1.RecordCount = PhtglInvoiceService.Count; //tb = GetFilteredTable(Grid1.FilteredData, tb); Grid1.DataSource = tb; Grid1.DataBind(); } #endregion #region GV 数据操作 /// /// 过滤表头 /// /// /// //protected void Grid1_FilterChange(object sender, EventArgs e) //{ // this.BindGrid(); //} /// /// 分页 /// /// /// protected void Grid1_PageIndexChange(object sender, GridPageEventArgs e) { this.Grid1.PageIndex = e.NewPageIndex; this.BindGrid(); } /// /// 排序 /// /// /// protected void Grid1_Sort(object sender, GridSortEventArgs e) { this.Grid1.SortDirection = e.SortDirection; this.Grid1.SortField = e.SortField; this.BindGrid(); } /// /// 分页显示条数下拉框 /// /// /// protected void ddlPageSize_SelectedIndexChanged(object sender, EventArgs e) { this.Grid1.PageSize = Convert.ToInt32(this.ddlPageSize.SelectedValue); this.BindGrid(); } #endregion #region 关闭弹出窗 /// /// 关闭弹出窗 /// /// /// protected void Window1_Close(object sender, WindowCloseEventArgs e) { BindGrid(); } #endregion #region 获取权限按钮 /// /// 获取按钮权限 /// /// /// private void GetButtonPower() { var buttonList = BLL.CommonService.GetAllButtonList(this.CurrUser.LoginProjectId, this.CurrUser.PersonId, BLL.Const.PHTGL_InvoiceStandingBookMenuId); 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 导出按钮 /// 导出按钮 /// /// /// 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(); } /// /// 导出方法 /// /// /// private string GetGridTableHtml(Grid grid) { StringBuilder sb = new StringBuilder(); sb.Append(""); sb.Append(""); sb.Append(""); foreach (GridColumn column in grid.Columns) { sb.AppendFormat("", 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 System.Web.UI.WebControls.Label).Text; } sb.AppendFormat("", html); } sb.Append(""); } sb.Append("
{0}
{0}
"); return sb.ToString(); } #endregion protected void Grid1_RowCommand(object sender, GridCommandEventArgs e) { if (e.CommandName== "OrderInDetail") { Window1.Title = "入库单详情"; PageContext.RegisterStartupScript(Window1.GetShowReference(String.Format("InvoiceOrderDetail.aspx?InvoiceId={0}&&Type={1}", e.RowID, "0", "编辑 - "))); } else if(e.CommandName== "OrderOutDetail") { Window1.Title = "出库单详情"; PageContext.RegisterStartupScript(Window1.GetShowReference(String.Format("InvoiceOrderDetail.aspx?InvoiceId={0}&&Type={1}", e.RowID, "1", "编辑 - "))); } else if (e.CommandName == "OrderInDetailPrint") { Print(e.RowID,"0"); } else if (e.CommandName == "OrderOutDetailPrint") { Print(e.RowID, "1"); } } protected void Grid1_RowDataBound(object sender, GridRowEventArgs e) { var id = e.RowID; var model = BLL.PhtglInvoiceService.GetPHTGL_InvoiceById(id); if (model.State> PhtglInvoiceService.StateDataIn) { Grid1.FindColumn("btnOrderInDetail").Hidden = false; Grid1.FindColumn("btnOrderInDetailPrint").Hidden = false; } if (model.State >= PhtglInvoiceService.StateInPutApproveSuccess) { Grid1.FindColumn("btnOrderOutDetail").Hidden = false; Grid1.FindColumn("btnOrderOutDetailPrint").Hidden = false; } } private void Print(string Id,string Type) { BLL.FastReportService.ResetData(); if (string.IsNullOrEmpty(Id)) { ShowNotify("请选择要打印的项", MessageBoxIcon.Warning); return; } var printModel= PhtglInvoiceService.GetPHTGL_InvoicePrintModel(Id); List orders = new List(); orders.Add(printModel.Order); DataTable Table1 = LINQToDataTable(orders); if (Table1 != null) { Table1.TableName = "Table1"; } DataTable Data = LINQToDataTable(printModel.Data); if (Data != null) { Data.TableName = "Data"; } List orderApproveIns = new List(); orderApproveIns.Add(printModel.ApproveIn); DataTable ApproveInData = LINQToDataTable(orderApproveIns); if (ApproveInData != null) { ApproveInData.TableName = "ApproveInData"; } List orderApproveOuts = new List(); orderApproveOuts.Add(printModel.ApproveOut); DataTable ApproveOutData = LINQToDataTable(orderApproveOuts); if (ApproveOutData != null) { ApproveOutData.TableName = "ApproveOutData"; } Dictionary keyValuePairs = new Dictionary(); keyValuePairs.Add("AmountInWords", Funs.NumericCapitalization(printModel.Data.Sum(p => p.Amount))); BLL.FastReportService.AddFastreportTable(Table1); BLL.FastReportService.AddFastreportTable(Data); BLL.FastReportService.AddFastreportTable(ApproveInData); BLL.FastReportService.AddFastreportTable(ApproveOutData); BLL.FastReportService.AddFastreportParameter(keyValuePairs); string initTemplatePath = ""; string rootPath = Server.MapPath("~/"); if (Type=="0") { initTemplatePath = "File\\Fastreport\\发票存货入库单.frx"; } else { initTemplatePath = "File\\Fastreport\\发票存货出库单.frx"; } if (File.Exists(rootPath + initTemplatePath)) { PageContext.RegisterStartupScript(Window2.GetShowReference(String.Format("~/Controls/Fastreport.aspx?ReportPath={0}", rootPath + initTemplatePath))); } } #region 查询 /// /// 查询按钮 /// /// /// protected void btnSearch_Click(object sender, EventArgs e) { BindGrid(); } #endregion } }