private void GilFondObjects_Load(object sender, EventArgs e) { gfObjectsAdapter.FillByActiveAudit(ds.GilFondObject, ActiveAudit.ID, ActiveAudit.ID_Company); grdGFObjects.DataSource = gfObjectsAdapter.GetDataByActiveAudit(ActiveAudit.ID, ActiveAudit.ID_Company); porchAdapter.FillBySelectObject(ds.PorchGilFondОbjects, this.currObjID); grdPorch.DataSource = porchAdapter.GetDataBySelectObject(this.currPorchID); pomeschAdapter.FillBySelectedPorch(ds.PomeschGilFondОbs, currPorchID); grdPomesch.DataSource = pomeschAdapter.GetDataBySelectedPorch(this.currPorchID); grdGFObjects.Columns[0].Visible = false; grdGFObjects.Columns[1].Visible = false; grdGFObjects.Columns[2].Visible = false; //foreach(DataGridView dc in grdGFObjects.Columns) //{ // dc.Width = grdGFObjects.Width / 11; //} grdGFObjects.Columns[3].Width = grdGFObjects.Width / 12; grdGFObjects.Columns[4].Width = grdGFObjects.Width / 12; grdGFObjects.Columns[5].Width = grdGFObjects.Width / 11; grdGFObjects.Columns[6].Width = grdGFObjects.Width / 11; grdGFObjects.Columns[7].Width = grdGFObjects.Width / 11; grdGFObjects.Columns[8].Width = grdGFObjects.Width / 12; grdGFObjects.Columns[9].Width = grdGFObjects.Width / 12; grdGFObjects.Columns[10].Width = grdGFObjects.Width / 11; grdGFObjects.Columns[11].Width = grdGFObjects.Width / 11; grdGFObjects.Columns[12].Width = grdGFObjects.Width / 11; grdGFObjects.Columns[13].Width = grdGFObjects.Width / 11; grdPorch.Columns[0].Visible = false; grdPorch.Columns[1].Visible = false; grdPorch.Columns[2].Visible = false; grdPorch.Columns[3].Visible = false; grdPorch.Columns[4].Width = grdPorch.Width / 5; grdPorch.Columns[5].Width = grdPorch.Width / 4; grdPorch.Columns[6].Width = grdPorch.Width / 4; grdPorch.Columns[7].Width = grdPorch.Width / 4; grdPomesch.Columns[0].Visible = false; grdPomesch.Columns[1].Visible = false; grdPomesch.Columns[2].Visible = false; grdPomesch.Columns[3].Visible = false; grdPomesch.Columns[4].Width = grdPomesch.Width / 10; grdPomesch.Columns[5].Width = grdPomesch.Width / 7; grdPomesch.Columns[6].Width = grdPomesch.Width / 7; grdPomesch.Columns[7].Width = grdPomesch.Width / 7; grdPomesch.Columns[8].Width = grdPomesch.Width / 7; grdPomesch.Columns[9].Width = grdPomesch.Width / 7; grdPomesch.Columns[10].Width = grdPomesch.Width / 7; }
//ОТЧЕТ private void btnReport_Click(object sender, EventArgs e) { Cursor.Current = Cursors.WaitCursor; try { ds.AcceptChanges(); licenseAdapter.FillByActiveAudit(ds.License, ActiveAudit.ID, ActiveAudit.ID_Company); elHouseAdapter.FillByActiveAudit(ds.ElHouse, ActiveAudit.ID, ActiveAudit.ID_Company); elHouseParamAdapter.Fill(ds.ElHouseParams); gfObjectsAdapter.FillByActiveAudit(ds.GilFondObject, ActiveAudit.ID, ActiveAudit.ID_Company); porchAdapter.Fill(ds.PorchGilFondОbjects); pomeschAdapter.Fill(ds.PomeschGilFondОbs); qrLSPlatDocsAdapter.Fill(ds.qrLicSchet_PlatDocs, ActiveAudit.ID, ActiveAudit.ID_Company); //query LS -> PlatDocs lichouseAdapter.FillByActiveAudit(ds.LicenseHouses, ActiveAudit.ID, ActiveAudit.ID_Company); DataSet1.LicenseHousesRow[] licHouseArr = ds.LicenseHouses.ToArray(); //Дома по лицензии dogUprAdapter.FillByActiveAudit(ds.DogUpravl, ActiveAudit.ID, ActiveAudit.ID_Company); //договоры упр DataSet1.DogUpravlRow[] doguprArr = ds.DogUpravl.ToArray(); //Дома по договорам companiesAdapter.Fill(ds.Companies); //Сравниваем дома в договорах управления и лицензиях - ОТЛОЖЕНО /* * /// повтор вызов приводит к ошибке dogUprAdapter.FillByActiveAudit(ds.DogUpravl, ActiveAudit.ID, ActiveAudit.ID_Company); //договоры упр * string[] dogupr_Arr = ds.DogUpravl.Select(d => d.Управляемые_объекты).ToArray(); * /// повтор вызов приводит к ошибке lichouseAdapter.FillByActiveAudit(ds.LicenseHouses, ActiveAudit.ID, ActiveAudit.ID_Company); * string[] licHouse_Arr = ds.LicenseHouses.Select(d => d.Адрес).ToArray(); */ priborAdapter.FillByActiveAudit(ds.Pribor, ActiveAudit.ID, ActiveAudit.ID_Company); DataSet1.PriborRow[] priborArr = ds.Pribor.ToArray(); ///////////////// repGFObj.Clear(); DataSet1.LicenseRow LicenseCompany = null; if (ds.License.Rows.Count > 0) { LicenseCompany = (DataSet1.LicenseRow)ds.License.Rows[0]; } //для случая с ТСЖ DataSet1.CompaniesRow ActiveCompany = ds.Companies.Where(c => c.ID == ActiveAudit.ID_Company).FirstOrDefault(); foreach (DataSet1.GilFondObjectRow gfoRow in ds.GilFondObject.Rows) { repGFObj.Add(new repGilFondObj { ID_GilFondObject = gfoRow.ID_GilFondObject, ID_Audit = ActiveAudit.ID, ID_Company = ActiveAudit.ID_Company, CompanyName = LicenseCompany != null ? LicenseCompany.Лицензиат : ActiveAudit.Company, CompanyAddress = LicenseCompany != null ? LicenseCompany.Адрес : "???", CompanyINN = LicenseCompany != null ? LicenseCompany.ИНН : ActiveCompany.INN, CompanyLicense = LicenseCompany != null ? LicenseCompany.Лицензия : "????", Address = gfoRow.Адрес, quantGilPom = gfoRow._Кол_во_помещений.Split('/')[0] == "-" ? 0 : Convert.ToInt32(gfoRow._Кол_во_помещений.Split('/')[0]), quantNoGilPom = gfoRow._Кол_во_помещений.Split('/')[1] == "- " ? 0 : Convert.ToInt32(gfoRow._Кол_во_помещений.Split('/')[1]) }); DataSet1.PorchGilFondОbjectsRow[] arr = (DataSet1.PorchGilFondОbjectsRow[])gfoRow.GetChildRows("GilFondObjectPorchGilFondОbjects"); foreach (DataSet1.PorchGilFondОbjectsRow porch in arr) { DataSet1.PomeschGilFondОbsRow[] pomscharr = (DataSet1.PomeschGilFondОbsRow[])porch.GetChildRows("PorchGilFondОbjectsPomeschGilFondОbs"); // Console.WriteLine(pomscharr); } } //Лицевые счета licSchetAdapter.FillByActiveAudit(ds.LicSchet, ActiveAudit.ID, ActiveAudit.ID_Company); DataSet1.LicSchetRow[] lsArr = ds.LicSchet.ToArray(); int quantLS = lsArr.Count(); //общее кол-во ЛС //???? DateTime tls = Convert.ToDateTime(lsArr.Max(l => Convert.ToDateTime(l.Дата_события))); //Макс дата выгрузки ЛС //Перечень работ и услуг pereschRabUslAdapter.FillByActiveAudit(ds.PerechRabUslug, ActiveAudit.ID, ActiveAudit.ID_Company); DataSet1.PerechRabUslugRow[] perArr = ds.PerechRabUslug.ToArray(); //Голосования votingAdapter.FillByActiveAudit(ds.Voting, ActiveAudit.ID, ActiveAudit.ID_Company); DataSet1.VotingRow[] votingArr = ds.Voting.ToArray(); DataSet1.qrLicSchet_PlatDocsRow[] qrLSDocsArr = ds.qrLicSchet_PlatDocs.ToArray(); foreach (repGilFondObj gfo in repGFObj) { gfo.quantPribor = QuantPriborByHouse(priborArr, gfo.Address); if (!ActiveAudit.Company.StartsWith("ТСЖ") && !ActiveAudit.Company.StartsWith("ЖСК") && !ActiveAudit.Company.StartsWith("ТСН")) { Tuple <string, string> dates = DatesByLicensyAndDogUpr(licHouseArr, doguprArr, gfo.Address); gfo.BeginDateByLic = dates.Item1; gfo.BeginDateByDogUpr = dates.Item2; } if (ActiveAudit.Company.StartsWith("ТСЖ") || ActiveAudit.Company.StartsWith("ЖСК") || ActiveAudit.Company.StartsWith("ТСН")) { ustavHouseAdapter.FillByCurrentAudit(ds.UstavHouse, ActiveAudit.ID); DataSet1.UstavHouseRow[] ustavHousesArr = ds.UstavHouse.ToArray(); DataSet1.UstavHouseRow uhrow = ustavHousesArr.Where(h => h.Адрес == gfo.Address).FirstOrDefault(); gfo.BeginDateByLic = "отсутствует"; if (uhrow != null) { gfo.BeginDateByDogUpr = uhrow.Период; } else { gfo.BeginDateByDogUpr = "-"; } } DataSet1.PerechRabUslugRow x = perArr.Where(p => p.Адрес == gfo.Address).FirstOrDefault(); if (x != null) { gfo.perechRabUsl = x.Перечень; } else { gfo.perechRabUsl = "отсутствует"; } Tuple <int, DateTime?> ls = LS_Quant_Date(lsArr, gfo.Address); //Кол-во и дата ЛС по объекту gfo.quantLS = ls.Item1; gfo.maxDateLS = ls.Item2; Tuple <int, DateTime?> vot = Voting_Qiant_Date(votingArr, gfo.Address); gfo.quantVoting = vot.Item1; gfo.maxDateVoting = vot.Item2; //////// Платежные док-ты со статусами Размещен и Проект gfo.quantPlatDocsRazm = qrLSDocsArr .Where(d => !d.IsСтатус_документаNull()) .Where(d => d.Адрес.Contains(gfo.Address)) .Where(s => s.Статус_документа == "Размещен") .Count(); gfo.quantPlatDocsNoRazm = qrLSDocsArr .Where(d => !d.IsСтатус_документаNull()) .Where(d => d.Адрес.Contains(gfo.Address)) .Where(s => s.Статус_документа == "Проект") .Count(); } frmReport ft = new frmReport(repGFObj); ft.Show(); } catch (Exception ex) { MessageBox.Show(ex.Message); } finally { Cursor.Current = Cursors.Default; } }