private void btnStampajSaOgranicenjem_Click(object sender, EventArgs e) { MaxGimIzKlubaUFinaluForm form = new MaxGimIzKlubaUFinaluForm(); if (form.ShowDialog() != DialogResult.OK) { return; } Cursor.Current = Cursors.WaitCursor; Cursor.Show(); ISession session = null; PoredakUkupno p = null; try { using (session = NHibernateHelper.Instance.OpenSession()) using (session.BeginTransaction()) { CurrentSessionContext.Bind(session); OcenaDAO ocenaDAO = DAOFactoryFactory.DAOFactory.GetOcenaDAO(); IList <Ocena> ocene = ocenaDAO.FindByDeoTakmicenja(takmicenje.Id, DeoTakmicenjaKod.Takmicenje1); p = new PoredakUkupno(DeoTakmicenjaKod.Takmicenje1); p.create(ActiveTakmicenje, ocene, true, form.MaxBrojTakmicaraIzKluba, form.MaxBrojTakmicaraVaziZaDrzavu); foreach (Ocena o in ocene) { ocenaDAO.Evict(o); } } } catch (Exception ex) { if (session != null && session.Transaction != null && session.Transaction.IsActive) { session.Transaction.Rollback(); } MessageDialogs.showError(ex.Message, this.Text); Close(); return; } finally { Cursor.Hide(); Cursor.Current = Cursors.Arrow; CurrentSessionContext.Unbind(NHibernateHelper.Instance.SessionFactory); } string nazivIzvestaja = "Finale vi" + Jezik.shMalo + "eboja"; stampaj(p, nazivIzvestaja); }
private void btnIzracunaj_Click(object sender, EventArgs e) { string msg; if (kvalColumnVisible()) { msg = "Da li zelite da izracunate poredak, kvalifikante i rezerve?"; } else { msg = "Da li zelite da izracunate poredak?"; } if (!MessageDialogs.queryConfirmation(msg, this.Text)) { return; } Cursor.Current = Cursors.WaitCursor; Cursor.Show(); ISession session = null; try { using (session = NHibernateHelper.Instance.OpenSession()) using (session.BeginTransaction()) { CurrentSessionContext.Bind(session); OcenaDAO ocenaDAO = DAOFactoryFactory.DAOFactory.GetOcenaDAO(); IList <Ocena> ocene = ocenaDAO.FindByDeoTakmicenja(takmicenje.Id, deoTakKod); if (ActiveSprava != Sprava.Preskok) { PoredakSprava p = ActiveTakmicenje.getPoredakSprava(deoTakKod, ActiveSprava); p.create(ActiveTakmicenje, ocene); DAOFactoryFactory.DAOFactory.GetPoredakSpravaDAO().Update(p); } else { PoredakPreskok p = ActiveTakmicenje.getPoredakPreskok(deoTakKod); p.create(ActiveTakmicenje, ocene); DAOFactoryFactory.DAOFactory.GetPoredakPreskokDAO().Update(p); } foreach (Ocena o in ocene) { ocenaDAO.Evict(o); } takmicenje = DAOFactoryFactory.DAOFactory.GetTakmicenjeDAO().FindById(takmicenje.Id); takmicenje.LastModified = DateTime.Now; session.Transaction.Commit(); } } catch (Exception ex) { if (session != null && session.Transaction != null && session.Transaction.IsActive) { session.Transaction.Rollback(); } MessageDialogs.showError(ex.Message, this.Text); return; } finally { Cursor.Hide(); Cursor.Current = Cursors.Arrow; CurrentSessionContext.Unbind(NHibernateHelper.Instance.SessionFactory); } setItems(); }
// Proveri da li za svaki rezultat postoji i ocena. public void proveriRezultateIOcene() { StreamWriter log = File.CreateText("proveri_rezultate_i_ocene.txt"); IList <int> takmicenjaId = getTakmicenjaId(); string takmicenjeHeader = String.Empty; for (int j = 0; j < takmicenjaId.Count; ++j) { ISession session = null; try { using (session = NHibernateHelper.Instance.OpenSession()) using (session.BeginTransaction()) { CurrentSessionContext.Bind(session); TakmicenjeDAO takmicenjeDAO = DAOFactoryFactory.DAOFactory.GetTakmicenjeDAO(); Takmicenje t = takmicenjeDAO.FindById(takmicenjaId[j]); if (t.ZbirViseKola) { continue; } takmicenjeHeader = j.ToString() + ". " + t.ToString(); takmicenjeHeader += " (" + t.Id + ")"; RezultatskoTakmicenjeDAO rezTakDAO = DAOFactoryFactory.DAOFactory.GetRezultatskoTakmicenjeDAO(); IList <RezultatskoTakmicenje> rezTakmicenja = rezTakDAO.FindByTakmicenje(t.Id); OcenaDAO ocenaDAO = DAOFactoryFactory.DAOFactory.GetOcenaDAO(); // Takmicenje 1 IList <Ocena> ocene = ocenaDAO.FindByDeoTakmicenja(t.Id, DeoTakmicenjaKod.Takmicenje1); IDictionary <int, IList <Ocena> > oceneMap = new Dictionary <int, IList <Ocena> >(); foreach (Ocena o in ocene) { if (!oceneMap.ContainsKey(o.Gimnasticar.Id)) { oceneMap.Add(o.Gimnasticar.Id, new List <Ocena>()); } oceneMap[o.Gimnasticar.Id].Add(o); } foreach (RezultatskoTakmicenje rt in rezTakmicenja) { foreach (PoredakSprava p in rt.Takmicenje1.PoredakSprava) { foreach (RezultatSprava r in p.Rezultati) { if (!oceneMap.ContainsKey(r.Gimnasticar.Id)) { if (r.Total != null) { log.WriteLine(takmicenjeHeader + ": " + r.Gimnasticar.ToString() + " nema nijednu ocenu" + " Takmicenje1"); } continue; } IList <Ocena> oceneList = oceneMap[r.Gimnasticar.Id]; Ocena o = null; foreach (Ocena o2 in oceneList) { if (o2.Sprava == p.Sprava) { o = o2; break; } } if (o == null && r.Total != null) { log.WriteLine(takmicenjeHeader + ": " + r.Gimnasticar.ToString() + " nema ocenu za " + p.Sprava.ToString() + " Takmicenje1"); } if (o != null && o.Total != r.Total) { log.WriteLine(takmicenjeHeader + ": " + r.Gimnasticar.ToString() + " total se razlikuje " + p.Sprava.ToString() + " Takmicenje1"); } } } foreach (RezultatPreskok r in rt.Takmicenje1.PoredakPreskok.Rezultati) { if (!oceneMap.ContainsKey(r.Gimnasticar.Id)) { if (r.Total != null || r.TotalObeOcene != null) { log.WriteLine(takmicenjeHeader + ": " + r.Gimnasticar.ToString() + " nema nijednu ocenu" + " Takmicenje1"); } continue; } IList <Ocena> oceneList = oceneMap[r.Gimnasticar.Id]; Ocena o = null; foreach (Ocena o2 in oceneList) { if (o2.Sprava == Sprava.Preskok) { o = o2; break; } } if (o == null && (r.Total != null || r.TotalObeOcene != null)) { log.WriteLine(takmicenjeHeader + ": " + r.Gimnasticar.ToString() + " nema ocenu za " + Sprava.Preskok.ToString() + " Takmicenje1"); } if (o != null && (o.Total != r.Total || o.TotalObeOcene != r.TotalObeOcene)) { log.WriteLine(takmicenjeHeader + ": " + r.Gimnasticar.ToString() + " total se razlikuje " + Sprava.Preskok.ToString() + " Takmicenje1"); } } } // Takmicenje 3 ocene = ocenaDAO.FindByDeoTakmicenja(t.Id, DeoTakmicenjaKod.Takmicenje3); oceneMap = new Dictionary <int, IList <Ocena> >(); foreach (Ocena o in ocene) { if (!oceneMap.ContainsKey(o.Gimnasticar.Id)) { oceneMap.Add(o.Gimnasticar.Id, new List <Ocena>()); } oceneMap[o.Gimnasticar.Id].Add(o); } foreach (RezultatskoTakmicenje rt in rezTakmicenja) { if (rt.Takmicenje3 == null) { continue; } if (!rt.odvojenoTak3()) { continue; } foreach (PoredakSprava p in rt.Takmicenje3.Poredak) { foreach (RezultatSprava r in p.Rezultati) { if (!oceneMap.ContainsKey(r.Gimnasticar.Id)) { if (r.Total != null) { log.WriteLine(takmicenjeHeader + ": " + r.Gimnasticar.ToString() + " nema nijednu ocenu" + " Takmicenje3"); } continue; } IList <Ocena> oceneList = oceneMap[r.Gimnasticar.Id]; Ocena o = null; foreach (Ocena o2 in oceneList) { if (o2.Sprava == p.Sprava) { o = o2; break; } } if (o == null && r.Total != null) { log.WriteLine(takmicenjeHeader + ": " + r.Gimnasticar.ToString() + " nema ocenu za " + p.Sprava.ToString() + " Takmicenje3"); } if (o != null && o.Total != r.Total) { log.WriteLine(takmicenjeHeader + ": " + r.Gimnasticar.ToString() + " total se razlikuje " + p.Sprava.ToString() + " Takmicenje3"); } } } foreach (RezultatPreskok r in rt.Takmicenje3.PoredakPreskok.Rezultati) { if (!oceneMap.ContainsKey(r.Gimnasticar.Id)) { if (r.Total != null || r.TotalObeOcene != null) { log.WriteLine(takmicenjeHeader + ": " + r.Gimnasticar.ToString() + " nema nijednu ocenu" + " Takmicenje3"); } continue; } IList <Ocena> oceneList = oceneMap[r.Gimnasticar.Id]; Ocena o = null; foreach (Ocena o2 in oceneList) { if (o2.Sprava == Sprava.Preskok) { o = o2; break; } } if (o == null && (r.Total != null || r.TotalObeOcene != null)) { log.WriteLine(takmicenjeHeader + ": " + r.Gimnasticar.ToString() + " nema ocenu za " + Sprava.Preskok.ToString() + " Takmicenje3"); } if (o != null && (o.Total != r.Total || o.TotalObeOcene != r.TotalObeOcene)) { log.WriteLine(takmicenjeHeader + ": " + r.Gimnasticar.ToString() + " total se razlikuje " + Sprava.Preskok.ToString() + " Takmicenje3"); } } } } } catch (Exception) { if (session != null && session.Transaction != null && session.Transaction.IsActive) { session.Transaction.Rollback(); } log.Close(); MessageBox.Show(takmicenjeHeader); throw; } finally { CurrentSessionContext.Unbind(NHibernateHelper.Instance.SessionFactory); } } log.Close(); }
private void mnSpraveKojeSeBoduju_Click(object sender, EventArgs e) { IList <GimnasticarUcesnik> selItems = getActiveDataGridViewUserControl() .getSelectedItems <GimnasticarUcesnik>(); if (selItems.Count != 1) { return; } GimnasticarUcesnik g = selItems[0]; List <int> checkedItems = new List <int>(); foreach (Sprava s in Sprave.getSprave(ActiveRezTakmicenje.Gimnastika)) { if (g.getSpravaSeBoduje(s)) { checkedItems.Add(Sprave.indexOf(s, ActiveRezTakmicenje.Gimnastika)); } } CheckListForm form = new CheckListForm( new List <string>(Sprave.getSpraveNazivi(ActiveRezTakmicenje.Gimnastika)), checkedItems, "Izaberite sprave koje se boduju", "Sprave koje se boduju", true, "Izaberite sprave", true); if (form.ShowDialog() != DialogResult.OK) { return; } Sprava[] sprave = Sprave.getSprave(ActiveRezTakmicenje.Gimnastika); IList <Sprava> spraveKojeSeBoduju = new List <Sprava>(); g.clearSpraveKojeSeBoduju(); foreach (int i in form.CheckedIndices) { g.setSpravaSeBoduje(sprave[i]); } Cursor.Current = Cursors.WaitCursor; Cursor.Show(); ISession session = null; try { using (session = NHibernateHelper.Instance.OpenSession()) using (session.BeginTransaction()) { CurrentSessionContext.Bind(session); DAOFactoryFactory.DAOFactory.GetGimnasticarUcesnikDAO().Update(g); PoredakSpravaDAO poredakSpravaDAO = DAOFactoryFactory.DAOFactory.GetPoredakSpravaDAO(); PoredakPreskokDAO poredakPreskokDAO = DAOFactoryFactory.DAOFactory.GetPoredakPreskokDAO(); OcenaDAO ocenaDAO = DAOFactoryFactory.DAOFactory.GetOcenaDAO(); IList <Ocena> ocene = ocenaDAO.FindByDeoTakmicenja(takmicenje.Id, DeoTakmicenjaKod.Takmicenje1); foreach (Sprava s in Sprave.getSprave(ActiveRezTakmicenje.Gimnastika)) { if (s != Sprava.Preskok) { PoredakSprava p = ActiveRezTakmicenje.getPoredakSprava(DeoTakmicenjaKod.Takmicenje1, s); poredakSpravaDAO.Attach(p, false); p.create(ActiveRezTakmicenje, ocene); poredakSpravaDAO.Update(p); } else { PoredakPreskok p = ActiveRezTakmicenje.getPoredakPreskok(DeoTakmicenjaKod.Takmicenje1); poredakPreskokDAO.Attach(p, false); p.create(ActiveRezTakmicenje, ocene); poredakPreskokDAO.Update(p); } } foreach (Ocena o in ocene) { ocenaDAO.Evict(o); } takmicenje = DAOFactoryFactory.DAOFactory.GetTakmicenjeDAO().FindById(takmicenje.Id); takmicenje.LastModified = DateTime.Now; session.Transaction.Commit(); } } catch (Exception ex) { if (session != null && session.Transaction != null && session.Transaction.IsActive) { session.Transaction.Rollback(); } MessageDialogs.showError(ex.Message, this.Text); Close(); return; } finally { Cursor.Hide(); Cursor.Current = Cursors.Arrow; CurrentSessionContext.Unbind(NHibernateHelper.Instance.SessionFactory); } }
public static void updateTakmicenjeOnChangedPropozicije(IList <RezultatskoTakmicenje> rezTakmicenja, IDictionary <int, Propozicije> origPropozicijeMap, IDictionary <int, Propozicije> origDescPropozicijeMap, Takmicenje takmicenje) { DAOFactoryFactory.DAOFactory.GetTakmicenjeDAO().Update(takmicenje); // ovo snima i propozicije za descriptions RezultatskoTakmicenjeDAO rezTakDAO = DAOFactoryFactory.DAOFactory.GetRezultatskoTakmicenjeDAO(); PropozicijeDAO propozicijeDAO = DAOFactoryFactory.DAOFactory.GetPropozicijeDAO(); OcenaDAO ocenaDAO = DAOFactoryFactory.DAOFactory.GetOcenaDAO(); IList <Ocena> oceneTak1 = null; foreach (RezultatskoTakmicenje rt in rezTakmicenja) { if (!rt.Propozicije.Equals(origPropozicijeMap[rt.Id])) { rezTakDAO.Update(rt); // ovo snima i propozicije i sve promene rezultata } else { rezTakDAO.Attach(rt, false); // moram da attachujem (ili da apdejtujem) sva rez. takmicenja zato } // sto se koriste u izracunavanju ekipnog poretka. } foreach (RezultatskoTakmicenjeDescription d in takmicenje.TakmicenjeDescriptions) { if (d.Propozicije.JednoTak4ZaSveKategorije != origDescPropozicijeMap[d.Id].JednoTak4ZaSveKategorije) { // Posto je opcija JednoTak4ZaSveKategorije onemogucena u propozicijama za konkretna rez. takmicenja, // moguce je da se promena u propozicijama za description ne prenosi na propozicije na konkretna // rez. takmicenja. Zato ponovo radim Update za sva rez. takmicenja, da bih bio siguran da ce promene // koje ce biti izvrsene u metodu updateImaEkipnoTakmicenje biti snimljene u bazu. foreach (RezultatskoTakmicenje rt in rezTakmicenja) { if (rt.TakmicenjeDescription.Equals(d)) { rezTakDAO.Update(rt); } } RezultatskoTakmicenje.updateImaEkipnoTakmicenje(rezTakmicenja, d); } } foreach (RezultatskoTakmicenje rt in rezTakmicenja) { if (!rt.Propozicije.Equals(origPropozicijeMap[rt.Id])) { if (oceneTak1 == null) { oceneTak1 = ocenaDAO.FindByDeoTakmicenja(takmicenje.Id, DeoTakmicenjaKod.Takmicenje1); } rt.updateRezultatiOnChangedPropozicije(origPropozicijeMap, takmicenje, rezTakmicenja, oceneTak1); } } if (oceneTak1 != null) { foreach (Ocena o in oceneTak1) { ocenaDAO.Evict(o); } } }