protected void GridView1_DataBinding(object sender, EventArgs e) { GridViewRow headerGridRow = new GridViewRow(0, 0, DataControlRowType.Header, DataControlRowState.Insert); //creating new Header Type TableCell headerCell = new TableCell(); //creating HeaderCell headerCell.ColumnSpan = 4; headerGridRow.Cells.Add(headerCell);//Adding HeaderCell to header. var expenses = AssociationExpensesManager.GetByMonthAndYearNotDisabled(Association.Id, Year, Month).GroupBy(ee => ee.Id_ExpenseType).OrderBy(er => er.Key).ToList(); foreach (var expense in expenses) { var headerCell2 = new TableCell(); headerCell2.Text = expense.FirstOrDefault().ExpenseTypes.Name; headerCell2.ColumnSpan = expense.ToList().Count; headerGridRow.Cells.Add(headerCell2);//Adding HeaderCell to header. } TableCell HeaderCell3 = new TableCell(); //creating HeaderCell HeaderCell3.ColumnSpan = GridView1.Rows[0].Cells.Count - 4 - expenses.Select(c => c.ToList()).Count(); headerGridRow.Cells.Add(HeaderCell3);//Adding HeaderCell to header. GridView1.Controls[0].Controls.AddAt(0, headerGridRow); }
protected void lblExpenseMeessageDownload_Click(object sender, EventArgs e) { DataTable dt; int stairCase; if (int.TryParse(drpDisplayMode.SelectedValue, out stairCase)) { dt = ApartmentExpensesManager.GetMonthlyRaportAsDataTable(Association.Id, Year, Month, stairCase); dt.Rows.Add(new TableCell()); } else { dt = ApartmentExpensesManager.GetMonthlyRaportAsDataTable(Association.Id, Year, Month, null); } MemoryStream stream; using (XLWorkbook wb = new XLWorkbook()) { var ws = wb.Worksheets.Add(dt, "Cheltuieli"); ws.Row(1).InsertRowsAbove(1); ws.Cells("A1").Value = ws.Cell(2, 1).Value; ws.Range("A1:A2").Merge(); ws.Cells("B1").Value = ws.Cell(2, 2).Value; ws.Range("B1:B2").Merge(); ws.Cells("C1").Value = ws.Cell(3, 2).Value; ws.Range("C1:C2").Merge(); ws.Cells("D1").Value = ws.Cell(4, 2).Value; ws.Range("D1:D2").Merge(); var expenses = AssociationExpensesManager.GetByMonthAndYearNotDisabled(Association.Id, Year, Month).GroupBy(ee => ee.Id_ExpenseType).OrderBy(er => er.Key); char position = 'E'; foreach (var expense in expenses) { var tempPosition = position; position = (char)(position + expense.ToList().Count - 1); var range = string.Format("{0}1:{1}1", tempPosition.ToString(), position.ToString()); ws.Cells(tempPosition + "1").Value = expense.FirstOrDefault().ExpenseTypes.Name; ws.Range(range).Merge(); position = (char)(position + 1); } stream = GetStream(wb); } string myName = Server.UrlEncode("Cheltuieli" + "_" + DateTime.Now.ToShortDateString() + ".xlsx"); Response.Clear(); Response.Buffer = true; Response.AddHeader("content-disposition", "attachment; filename=" + myName); Response.ContentType = "application/vnd.ms-excel"; Response.BinaryWrite(stream.ToArray()); Response.Flush(); Response.SuppressContent = true; }
private void AddBodyPanels(int associationId, int yearNr, int monthNr) { string mainRowCssFormat = "col-md-12 col-sm-12 xs-12 cashBokItemsRow {0}"; bool even = false; IEnumerable <Administratoro.DAL.Expenses> allExpenses = ExpensesManager.GetAllExpenses(); var associationExpenses = AssociationExpensesManager.GetByMonthAndYearNotDisabled(associationId, yearNr, monthNr).OrderBy(ee => ee.Id_ExpenseType); // add expense panels foreach (Expenses expense in allExpenses) { var associationExpense = associationExpenses.FirstOrDefault(ea => ea.Id_Expense == expense.Id); if (associationExpense != null) { var mainCol = new Panel(); if (even) { even = false; mainCol.CssClass = string.Format(mainRowCssFormat, "evenRow"); } else { even = true; mainCol.CssClass = string.Format(mainRowCssFormat, "oddRow"); } bool isExpensePerIndex = associationExpense.ExpenseTypes.Id == (int)ExpenseType.PerIndex; var col0 = AddBodyPanelCol0(associationExpense, isExpensePerIndex); var col1 = AddBodyPanelCol1(expense, associationExpense); TextBox tb2; var col2 = AddBodyPanelCol2(associationExpense, out tb2); TextBox tb3; var col3 = AddBodyPanelCol3(associationExpense, tb2, out tb3); var col6 = AddBodyPanelCol6(associationExpense); var col4 = AddBodyPanelCol4(associationExpense, tb2); var col5 = AddBodyPanelCol5(associationExpense, isExpensePerIndex); mainCol.Controls.Add(col0); mainCol.Controls.Add(col1); mainCol.Controls.Add(col2); mainCol.Controls.Add(col3); mainCol.Controls.Add(col6); mainCol.Controls.Add(col4); mainCol.Controls.Add(col5); invoiceMain.Controls.Add(mainCol); } } }
private void InitializeExpenses() { //tblMonthlyExpenses.Rows.Clear(); int month; int _year = Year().HasValue ? Year().Value : 2017; if (int.TryParse(drpExpenseMonth.SelectedValue, out month)) { var estate = (Associations)Session[SessionConstants.SelectedAssociation]; if (estate != null) { var ee = AssociationExpensesManager.GetByMonthAndYearNotDisabled(estate.Id, _year, month); var eeAlsoDisabled = AssociationExpensesManager.GetAllAssociationExpensesByMonthAndYearIncludingDisabled(estate.Id, _year, month); IEnumerable <Expenses> expenses = ExpensesManager.GetAllExpenses(); foreach (var expense in expenses) { TableRow row = new TableRow(); // add expense that were added TableCell expenseExists = new TableCell(); CheckBox esexExists = new CheckBox(); esexExists.AutoPostBack = false; esexExists.ID = String.Format("esateExpense{0}", expense.Id); esexExists.Checked = IsExpenseSelected(expense, ee, _year, month); expenseExists.Controls.Add(esexExists); row.Cells.Add(expenseExists); // add expense name TableCell expenseName = new TableCell { Text = expense.Name }; row.Cells.Add(expenseName); // add expense type TableCell expenseType = new TableCell(); AssociationExpenses esex = eeAlsoDisabled.FirstOrDefault(s => s.Id_Expense == expense.Id && s.Month == month && s.Year == _year && s.Id_Estate == estate.Id); DropDownList dp = new DropDownList(); if (expense.Id != (int)Expense.AjutorÎncălzire) { var selected1 = IsDplExpenseTypesSelected(esex, ExpenseType.PerIndex); dp.Items.Add(new ListItem { Value = "1", Text = "Individuală prin indecși", Selected = selected1 }); var selected2 = IsDplExpenseTypesSelected(esex, ExpenseType.PerCotaIndiviza); dp.Items.Add(new ListItem { Value = "2", Text = "Cotă indiviză de proprietate", Selected = selected2 }); var selected3 = IsDplExpenseTypesSelected(esex, ExpenseType.PerNrTenants); dp.Items.Add(new ListItem { Value = "3", Text = "Per număr persoane imobil", Selected = selected3 }); var selected4 = IsDplExpenseTypesSelected(esex, ExpenseType.PerApartament); dp.Items.Add(new ListItem { Value = ((int)ExpenseType.PerApartament).ToString(), Text = ExpenseType.PerApartament.ToDescription(), Selected = selected4 }); } dp.Items.Add(new ListItem { Value = "6", Text = "Individual", }); expenseType.Controls.Add(dp); row.Cells.Add(expenseType); if (estate.HasStaircase) { TableCell tcStairCase = new TableCell(); CheckBox stairCaseSplit = new CheckBox(); stairCaseSplit.AutoPostBack = false; stairCaseSplit.Checked = IsStairCaseSplitSelected(expense, ee, _year, month); tcStairCase.Controls.Add(stairCaseSplit); row.Cells.Add(tcStairCase); } else { tblMonthlyExpensesStairCaseSplit.Visible = false; } tblMonthlyExpenses.Rows.Add(row); } } } }
protected void btnStep2_Click(object sender, EventArgs e) { step11.Visible = false; step22.Visible = false; step33.Visible = true; expenseListHref1.Attributes["class"] = "done"; expenseListHref1.Attributes["isdone"] = "1"; expenseListHref2.Attributes["class"] = "done"; expenseListHref3.Attributes["class"] = "selected"; int _month; int _year = Year().HasValue ? Year().Value : 2017; if (int.TryParse(drpExpenseMonth.SelectedValue, out _month)) { var estate = (Associations)Session[SessionConstants.SelectedAssociation]; if (estate != null) { var existingAssociationExpenses = AssociationExpensesManager.GetByMonthAndYearNotDisabled(estate.Id, _year, _month); var existingAssociationExpensesIncludingDisabled = AssociationExpensesManager.GetAllAssociationExpensesByMonthAndYearIncludingDisabled(estate.Id, _year, _month); foreach (TableRow row in tblMonthlyExpenses.Rows) { if (row != null && row.Cells.Count > 2 && row.Cells[0] != null && row.Cells[0].Controls.Count > 0 && row.Cells[0].Controls[0] != null) { if (row.Cells[0].Controls[0] is CheckBox && row.Cells[2].Controls[0] is DropDownList) { bool?cbExpensePerStaircase = null; if (row.Cells.Count > 3 && row.Cells[3].Controls[0] is CheckBox) { CheckBox cbStairCase = (CheckBox)row.Cells[3].Controls[0]; cbExpensePerStaircase = cbStairCase.Checked; } CheckBox cbExpenseSelect = (CheckBox)row.Cells[0].Controls[0]; DropDownList dpExpenseType = (DropDownList)row.Cells[2].Controls[0]; int expenseId = 0; if (int.TryParse(cbExpenseSelect.ID.Replace("esateExpense", ""), out expenseId)) { bool existingAssociationExpensesContainsItem = existingAssociationExpenses.Select(esex => esex.Id_Expense).Contains(expenseId); bool existingAssociationExpensesContainsItemAsDisabled = existingAssociationExpensesIncludingDisabled .Where(es => es.WasDisabled).Select(esex => esex.Id_Expense).Contains(expenseId); AssociationExpenses ee = null; // if selected and non existing in the prev. config if (cbExpenseSelect.Checked && existingAssociationExpensesContainsItemAsDisabled) { // enables it ee = AssociationExpensesManager.GetAssociationExpensesByMonthAndYearAndDisabled(estate.Id, expenseId, _year, _month); AssociationExpensesManager.MarkAssociationExpensesDisableProperty(ee, false, cbExpensePerStaircase); } else if (!cbExpenseSelect.Checked && existingAssociationExpensesContainsItem) { // disables it ee = AssociationExpensesManager.GetAssociationExpensesByMonthAndYearAndDisabled(estate.Id, expenseId, _year, _month, false); AssociationExpensesManager.MarkAssociationExpensesDisableProperty(ee, true, cbExpensePerStaircase); } else if (cbExpenseSelect.Checked && !existingAssociationExpensesContainsItem) { ee = AssociationExpensesManager.GetAssociationExpensesByMonthAndYearAndDisabled(expenseId, estate.Id, _year, _month); if (ee != null) { // disables it AssociationExpensesManager.MarkAssociationExpensesDisableProperty(ee, true, cbExpensePerStaircase); } else { // adds it AssociationExpensesManager.Add(estate.Id, expenseId, _month, _year, dpExpenseType.SelectedValue, false); } } ExpenseType selectedExpenseType; if (Enum.TryParse <ExpenseType>(dpExpenseType.SelectedValue, out selectedExpenseType)) { if (ee == null) { ee = AssociationExpensesManager.GetAssociationExpense(estate.Id, expenseId, _year, _month); } if (ee == null) { continue; } if ((ExpenseType)ee.ExpenseTypes.Id != selectedExpenseType) { AssociationExpensesManager.UpdateAssociationExpenseType(ee, selectedExpenseType); } if (!ee.SplitPerStairCase.HasValue || ee.SplitPerStairCase.Value != cbExpensePerStaircase) { AssociationExpensesManager.MarkAssociationExpensesDisableProperty(ee, !cbExpenseSelect.Checked, cbExpensePerStaircase); } } } } } } } } if (Year() != null && Month() != null && step33.Visible) { Response.Redirect("~/Expenses/Invoices.aspx?year=" + Year() + "&month=" + Month()); } }
protected void btnDownload_Click(object sender, EventArgs e) { BaseFont bfTimes = BaseFont.CreateFont(BaseFont.TIMES_ROMAN, BaseFont.CP1250, false); Font times = new Font(bfTimes, 12, Font.ITALIC, BaseColor.BLACK); //server folder path which is stored your PDF documents string path = Server.MapPath(""); string filename = path + "\\Doc1.pdf"; var apartments = ApartmentsManager.Get(Association.Id); Font boldFont = new Font(null, 12, Font.BOLD); //Create new PDF document Document document = new Document(PageSize.A4, 80f, 80f, 20f, 20f); using (Document doc = new Document()) { MemoryStream msPDFData = new MemoryStream(); doc.Open(); doc.Add(new Paragraph("I'm a pdf!")); byte[] pdfData = msPDFData.ToArray(); } var association = Association; try { PdfWriter.GetInstance(document, new FileStream(filename, FileMode.Create)); document.Open(); foreach (var apartment in apartments) { decimal? sumToPay = 0; PdfPTable tblHeader = new PdfPTable(2) { WidthPercentage = 100 }; tblHeader.AddCell(GetCell("ASOCIATIA DE PROPRIETARI " + association.Name + ", CF " + association.FiscalCode, PdfPCell.ALIGN_LEFT)); tblHeader.AddCell(GetCell("CONTUL BANCAR " + association.BanckAccont, PdfPCell.ALIGN_RIGHT)); document.Add(tblHeader); document.Add(new Phrase("\n")); PdfPTable tbAp = new PdfPTable(4); tbAp.WidthPercentage = 100; tbAp.AddCell(GetCell("Ap.: " + apartment.Number, PdfPCell.ALIGN_CENTER)); tbAp.AddCell(GetCell("Nume: " + apartment.Name, PdfPCell.ALIGN_CENTER)); tbAp.AddCell(GetCell("Cota: " + (apartment.CotaIndiviza.HasValue ? apartment.CotaIndiviza.Value.ToString(CultureInfo.InvariantCulture) : string.Empty), PdfPCell.ALIGN_CENTER)); tbAp.AddCell(GetCell("Nr. Pers: " + apartment.Dependents, PdfPCell.ALIGN_CENTER)); document.Add(tbAp); document.Add(new Phrase("\n")); var associationExpensesGrouped = AssociationExpensesManager.GetByMonthAndYearNotDisabled(association.Id, GetYear(), GetMonth()) .GroupBy(ee => ee.Id_ExpenseType).OrderBy(er => er.Key); foreach (var assocExpenses in associationExpensesGrouped) { // add header document.Add(new Paragraph("Cheltuielile de tipulîățșț " + assocExpenses.FirstOrDefault().ExpenseTypes.Name, times)); if (assocExpenses.FirstOrDefault().Id_ExpenseType == (int)ExpenseType.PerIndex) { foreach (var assocExpense in assocExpenses) { var apExpenses = assocExpense.ApartmentExpenses.Where(w => w.Id_Tenant == apartment.Id).ToList(); if (apExpenses.Any()) { sumToPay = sumToPay + AddIndexTable(document, apExpenses, apartment, assocExpense.Id); } } } else if (assocExpenses.FirstOrDefault().Id_ExpenseType == (int)ExpenseType.PerCotaIndiviza) { sumToPay = sumToPay + AddCotaTable(document, assocExpenses.ToList(), apartment.Id); } else if (assocExpenses.FirstOrDefault().Id_ExpenseType == (int)ExpenseType.PerNrTenants) { sumToPay = sumToPay + AddTenantsTable(document, assocExpenses.ToList(), apartment.Id); } // add rows // add subtotal } document.Add(new Paragraph("TOTAL DE PLATA: " + sumToPay, boldFont)); document.NewPage(); } } catch (Exception) { } finally { document.Close(); ShowPdf(filename); } }
private void InitializeExpenses() { tblMonthlyExpenses.Rows.Clear(); int month = 0; int year = 0; if (int.TryParse(drpOpeningMonth.SelectedValue, out month) && int.TryParse(drpOpeningYear.SelectedValue, out year)) { var estate = (Associations)Session[SessionConstants.SelectedAssociation]; if (estate != null) { int defaultYear = 2017; int defaultMonth = 1; var defaultEe = AssociationExpensesManager.GetFromLastestOpenedMonth(estate.Id); if (defaultEe.Any()) { defaultYear = defaultEe.FirstOrDefault().Year; defaultMonth = defaultEe.FirstOrDefault().Month; } var eeAlsoDisabled = AssociationExpensesManager.GetAllAssociationExpensesByMonthAndYearIncludingDisabled(estate.Id, defaultYear, defaultMonth); IEnumerable <Expenses> expenses = ExpensesManager.GetAllExpenses(); var ee = AssociationExpensesManager.GetByMonthAndYearNotDisabled(estate.Id, defaultYear, defaultMonth); TableRow defaultRow = new TableRow(); // add expense exists TableCell defaultExpenseSelected = new TableCell { Text = "Activează pentru noua lună" }; defaultRow.Cells.Add(defaultExpenseSelected); // add expense name TableCell defaultExpenseName = new TableCell { Text = "Cheltuială" }; defaultRow.Cells.Add(defaultExpenseName); // add expense type TableCell defaultExpenseType = new TableCell() { Text = "Tip calcul cheltuială" }; defaultRow.Cells.Add(defaultExpenseType); if (estate.HasStaircase) { TableCell tcStairCaseDefaule = new TableCell() { Text = "Contor individual per scară" }; defaultRow.Cells.Add(tcStairCaseDefaule); } tblMonthlyExpenses.Rows.Add(defaultRow); foreach (var expense in expenses) { TableRow row = new TableRow(); // add expense exists TableCell expenseExists = new TableCell(); CheckBox esexExists = new CheckBox(); esexExists.AutoPostBack = false; esexExists.ID = String.Format("expense{0}", expense.Id); esexExists.Checked = IsExpenseSelected(expense, defaultEe); expenseExists.Controls.Add(esexExists); row.Cells.Add(expenseExists); // add expense name TableCell expenseName = new TableCell { Text = expense.Name }; row.Cells.Add(expenseName); // add expense type TableCell expenseType = new TableCell(); DropDownList dp = new DropDownList(); if (expense.Id != (int)Expense.AjutorÎncălzire) { AssociationExpenses esex = eeAlsoDisabled.FirstOrDefault(s => s.Id_Expense == expense.Id); var selected1 = IsDplExpenseTypesSelected(esex, ExpenseType.PerIndex, expense.LegalType); dp.Items.Add(new ListItem { Value = ((int)ExpenseType.PerIndex).ToString(), Text = "Individuală prin indecși", Selected = selected1 }); var selected2 = IsDplExpenseTypesSelected(esex, ExpenseType.PerCotaIndiviza, expense.LegalType); dp.Items.Add(new ListItem { Value = ((int)ExpenseType.PerCotaIndiviza).ToString(), Text = "Cotă indiviză de proprietate", Selected = selected2 }); var selected3 = IsDplExpenseTypesSelected(esex, ExpenseType.PerNrTenants, expense.LegalType); dp.Items.Add(new ListItem { Value = ((int)ExpenseType.PerNrTenants).ToString(), Text = "Per număr persoane imobil", Selected = selected3 }); var selected4 = IsDplExpenseTypesSelected(esex, ExpenseType.PerApartament, expense.LegalType); dp.Items.Add(new ListItem { Value = ((int)ExpenseType.PerApartament).ToString(), Text = ExpenseType.PerApartament.ToDescription(), Selected = selected4 }); } else { dp.Items.Add(new ListItem { Value = ((int)ExpenseType.Individual).ToString(), Text = "Individual", Selected = expense.LegalType == (int)ExpenseType.Individual }); } expenseType.Controls.Add(dp); row.Cells.Add(expenseType); if (estate.HasStaircase) { TableCell tcStairCase = new TableCell(); CheckBox stairCaseSplit = new CheckBox(); stairCaseSplit.AutoPostBack = false; stairCaseSplit.Checked = IsStairCaseSplitSelected(expense, ee, defaultYear, defaultMonth); tcStairCase.Controls.Add(stairCaseSplit); row.Cells.Add(tcStairCase); } tblMonthlyExpenses.Rows.Add(row); } } } }