// GET: EczaneNobet/NobetDurum public ActionResult Index() { var user = _userService.GetByUserName(User.Identity.Name); var nobetUstGruplar = _nobetUstGrupService.GetListByUser(user); var nobetAltGruplar = _nobetAltGrupService.GetDetaylarByNobetUstGrup(nobetUstGruplar.Select(s => s.Id).ToList()); ViewBag.NobetAltGrupId = new SelectList(nobetAltGruplar, "Id", "Adi"); var nobetDurumlar = _nobetDurumService.GetDetaylar(nobetUstGruplar.Select(s => s.Id).ToList()) .OrderBy(o => o.NobetAltGrupAdi1) .ThenBy(o => o.NobetAltGrupAdi2) .ThenBy(o => o.NobetAltGrupAdi3).ToList(); return(View(nobetDurumlar)); }
private OsmaniyeDataModel EczaneNobetDataModel(EczaneNobetDataModelParametre eczaneNobetDataModelParametre) { #region parametreler var nobetUstGrupId = eczaneNobetDataModelParametre.NobetUstGrupId; var nobetGrupIdListe = eczaneNobetDataModelParametre.NobetGrupId.ToList(); //var nobetGorevTipId = eczaneNobetDataModelParametre.NobetGorevTipId; var nobetUstGrupBaslangicTarihi = eczaneNobetDataModelParametre.NobetUstGrupBaslangicTarihi; var baslangicTarihi = eczaneNobetDataModelParametre.BaslangicTarihi; var bitisTarihi = eczaneNobetDataModelParametre.BitisTarihi; var nobetGrupGorevTipler = eczaneNobetDataModelParametre.NobetGrupGorevTipler; var nobetGorevTipler = eczaneNobetDataModelParametre.NobetGrupGorevTipler.Select(s => s.NobetGorevTipId).Distinct().ToList(); #endregion if (baslangicTarihi < nobetUstGrupBaslangicTarihi) { throw new Exception($"Nöbet başlangıç tarihi <strong>({baslangicTarihi.ToShortDateString()})</strong> üst grup başlama tarihinden <strong>({nobetUstGrupBaslangicTarihi.ToShortDateString()})</strong> küçük olamaz."); } var debugYapilacakEczaneler = _debugEczaneService.GetDetaylarAktifOlanlar(nobetUstGrupId); var nobetGruplar = _nobetGrupService.GetDetaylar(nobetGrupIdListe).OrderBy(s => s.Id).ToList(); //var nobetGrupGorevTipler = _nobetGrupGorevTipService.GetDetaylar(nobetGrupIdListe); //nobetGorevTipId, var eczaneNobetSonuclar = _eczaneNobetSonucService.GetSonuclar(nobetUstGrupId); var eczaneNobetMazeretNobettenDusenler = new List <EczaneNobetMazeretSayilari>(); var mazeret = _nobetUstGrupKisitService.GetKisitPasifMi("mazeret", nobetUstGrupId); if (mazeret) { eczaneNobetMazeretNobettenDusenler = _eczaneNobetMazeretService.GetEczaneNobetMazeretSayilari(baslangicTarihi, bitisTarihi, nobetGrupIdListe); } var eczaneNobetGruplarTumu = _eczaneNobetGrupService.GetDetaylar(nobetGrupIdListe, baslangicTarihi, bitisTarihi) .Where(w => !eczaneNobetMazeretNobettenDusenler.Select(s => s.EczaneNobetGrupId).Contains(w.Id) //&& w.EczaneAdi == "ÖZGÜR" ).ToList(); var nobetGorevTipId = 1; if (!nobetGorevTipler.Contains(nobetGorevTipId)) { nobetGorevTipId = 0; } var eczaneNobetGruplarGorevTip1 = eczaneNobetGruplarTumu .Where(w => w.NobetGorevTipId == nobetGorevTipId).ToList(); nobetGorevTipId = 2; if (!nobetGorevTipler.Contains(nobetGorevTipId)) { nobetGorevTipId = 0; } var eczaneNobetGruplarGorevTip2 = eczaneNobetGruplarTumu .Where(w => w.NobetGorevTipId == nobetGorevTipId).ToList(); var eczaneNobetSonuclarOncekiAylar = eczaneNobetSonuclar .Where(w => w.Tarih >= nobetUstGrupBaslangicTarihi && eczaneNobetGruplarTumu.Select(s => s.Id).Contains(w.EczaneNobetGrupId) //görevtip: tümü //&& eczaneNobetGruplarGorevTip1.Select(s => s.Id).Contains(w.EczaneNobetGrupId) //görevtip: 1 ).ToList(); var eczaneNobetSonuclarCozulenGruplar = eczaneNobetSonuclar .Where(w => eczaneNobetGruplarTumu.Select(s => s.Id).Contains(w.EczaneNobetGrupId)).ToList(); var son3Ay = baslangicTarihi.AddMonths(-2); var eczaneNobetSonuclarSon3Ay = eczaneNobetSonuclarCozulenGruplar .Where(w => w.Tarih >= son3Ay).ToList(); var sonuclarKontrol = _eczaneNobetSonucService.GetSonuclar(baslangicTarihi, bitisTarihi, eczaneNobetSonuclarCozulenGruplar); if (sonuclarKontrol.Count > 0) { throw new Exception("Kriterlere uygun <strong>daha önce yazılmış nöbetler</strong> bulunmaktadır. Lütfen kontrol ediniz!"); } var enSonNobetler = _eczaneNobetOrtakService.GetEczaneNobetGrupGunKuralIstatistik(eczaneNobetGruplarTumu, eczaneNobetSonuclarCozulenGruplar); var enSonNobetlerSon3Ay = _eczaneNobetOrtakService.GetEczaneNobetGrupGunKuralIstatistik(eczaneNobetGruplarTumu, eczaneNobetSonuclarSon3Ay); var eczaneNobetGrupGunKuralIstatistikYatay = _eczaneNobetOrtakService.GetEczaneNobetGrupGunKuralIstatistikYatay(enSonNobetler); var eczaneNobetGrupGunKuralIstatistikYataySon3Ay = _eczaneNobetOrtakService.GetEczaneNobetGrupGunKuralIstatistikYatay(enSonNobetlerSon3Ay); //var bak = eczaneNobetGrupGunKuralIstatistikYatay.Where(w => w.NobetGorevTipId == 2).ToList(); var anahtarListe = eczaneNobetSonuclar .Where(w => w.Tarih < nobetUstGrupBaslangicTarihi && nobetGrupIdListe.Contains(w.NobetGrupId)).ToList(); //var haftaIciAnahtarListeTumEczaneler = _takvimService.AnahtarListeyiBuGuneTasi(nobetGrupIdListe, 1, nobetUstGrupBaslangicTarihi, eczaneNobetGruplarTumu, eczaneNobetGrupGunKuralIstatistikYatay, anahtarListe, "Hafta İçi"); var haftaIciAnahtarListeTumEczaneler = _takvimService.AnahtarListeyiBuGuneTasi(nobetGrupIdListe, nobetGorevTipId, nobetUstGrupBaslangicTarihi, eczaneNobetGruplarTumu, eczaneNobetGrupGunKuralIstatistikYatay, anahtarListe, "Hafta İçi"); var nobetBorcluEczanelerhaftaIci = (from s in eczaneNobetGrupGunKuralIstatistikYatay from b in haftaIciAnahtarListeTumEczaneler where s.EczaneNobetGrupId == b.EczaneNobetGrupId && s.NobetSayisiHaftaIci == b.NobetSayisi select new EczaneNobetAlacakVerecek { EczaneNobetGrupId = s.EczaneNobetGrupId, EczaneId = s.EczaneId, EczaneAdi = s.EczaneAdi, NobetGrupAdi = s.NobetGrupAdi, NobetGrupId = s.NobetGrupId, NobetSayisi = s.NobetSayisiHaftaIci, SonNobetTarihi = s.SonNobetTarihiHaftaIci, AnahtarTarih = b.Tarih, BorcluGunSayisi = (int)(s.NobetSayisiHaftaIci > 0 ? (s.SonNobetTarihiHaftaIci - b.Tarih).TotalDays : (s.SonNobetTarihiHaftaIci - b.Tarih).TotalDays - (s.SonNobetTarihiHaftaIci - b.NobetUstGrupBaslamaTarihi).TotalDays), GunGrupAdi = "Hafta İçi" }).ToList(); foreach (var eczane in nobetBorcluEczanelerhaftaIci) { eczaneNobetGrupGunKuralIstatistikYatay .Where(w => w.EczaneNobetGrupId == eczane.EczaneNobetGrupId) .FirstOrDefault().BorcluNobetSayisiHaftaIci = (int)eczane.BorcluGunSayisi; } var grupluEczaneNobetSonuclar = _eczaneNobetSonucService.GetSonuclar(baslangicTarihi, bitisTarihi, eczaneNobetSonuclar); var eczaneGrupEdges = _eczaneGrupService.GetEdges(nobetUstGrupId) .Where(e => (nobetGrupIdListe.Contains(e.FromNobetGrupId) || nobetGrupIdListe.Contains(e.ToNobetGrupId))) .Where(w => (grupluEczaneNobetSonuclar.Select(s => s.EczaneId).Distinct().Contains(w.From) || grupluEczaneNobetSonuclar.Select(s => s.EczaneId).Distinct().Contains(w.To)) ).ToList(); //sonuçlarda ilişkili eczaneler var eczaneGruplar = _eczaneGrupService.GetDetaylarAktifGruplar(nobetUstGrupId) .Where(x => (eczaneGrupEdges.Select(s => s.From).Distinct().Contains(x.EczaneId) || eczaneGrupEdges.Select(s => s.To).Distinct().Contains(x.EczaneId)) || nobetGrupIdListe.Contains(x.NobetGrupId) ).ToList(); //fazladan gelen tanımlar var iyileştirmekte fayda var var eczaneGrupTanimlar = _eczaneGrupTanimService.GetDetaylarAktifTanimList(eczaneGruplar.Select(x => x.EczaneGrupTanimId).ToList()); var eczaneGruplar2 = _eczaneGrupService.GetDetaylarByEczaneGrupTanimId(eczaneGrupTanimlar.Select(s => s.Id).ToList()); var eczaneGrupNobetSonuclar = grupluEczaneNobetSonuclar .Where(w => eczaneGruplar2.Select(s => s.EczaneId).Contains(w.EczaneId)).ToList(); //nöbet yazılacak tarih aralığı(örn. Ocak ayının tüm günleri) var tarihAralik = _takvimService.GetTakvimNobetGruplar(baslangicTarihi, bitisTarihi, nobetGrupGorevTipler); var eczaneKumulatifHedefler = new List <EczaneNobetIstatistik>(); var eczaneNobetIstatistikler = new List <EczaneNobetIstatistik>(); //2.görev tipi için sadece cumartesi olduğu için tüm günler tüm görev tiplerini almaya gerek yok. //var eczaneNobetTarihAralik = _takvimService.GetEczaneNobetTarihAralik(baslangicTarihi, bitisTarihi, nobetGrupGorevTipler) // .Where(w => eczaneNobetGruplar.Select(s => s.EczaneId).Contains(w.EczaneId)).ToList(); var nobetGrupGorevTipGunKurallar = _nobetGrupGorevTipGunKuralService.GetDetaylarAktifList(nobetGrupGorevTipler.Select(s => s.Id).ToList()); nobetGorevTipId = 1; var nobetGrupGorevTip1 = nobetGrupGorevTipler.Where(w => w.NobetGorevTipId == nobetGorevTipId).ToList(); var eczaneNobetTarihAralik1 = _takvimService.GetEczaneNobetTarihAralik(baslangicTarihi, bitisTarihi, nobetGrupGorevTip1) .Where(w => eczaneNobetGruplarGorevTip1.Select(s => s.Id).Contains(w.EczaneNobetGrupId)).ToList(); //nobetGorevTipId = 2; //var nobetGrupGorevTip2 = nobetGrupGorevTipler.Where(w => w.NobetGorevTipId == nobetGorevTipId).ToList(); //var noberGunKurallar = nobetGrupGorevTipGunKurallar.Where(w => nobetGrupGorevTip2.Select(s => s.Id).Contains(w.NobetGrupGorevTipId)).Select(s => s.NobetGunKuralId).ToList(); //var eczaneNobetTarihAralik2 = _takvimService.GetEczaneNobetTarihAralik(baslangicTarihi, bitisTarihi, nobetGrupGorevTip2, noberGunKurallar) // .Where(w => eczaneNobetGruplarGorevTip2.Select(s => s.Id).Contains(w.EczaneNobetGrupId)).ToList(); var eczaneNobetTarihAralik = _eczaneNobetOrtakService.AmacFonksiyonuKatsayisiBelirle(eczaneNobetTarihAralik1, eczaneNobetGrupGunKuralIstatistikYatay); //.Union(eczaneNobetTarihAralik2).ToList(); var eczaneNobetIstekler = _eczaneNobetIstekService.GetDetaylarByNobetGrupIdList(baslangicTarihi, bitisTarihi, nobetGrupIdListe) .Where(w => eczaneNobetGruplarTumu.Select(s => s.EczaneId).Contains(w.EczaneId)).ToList(); var eczaneNobetMazeretler = _eczaneNobetMazeretService.GetDetaylarByEczaneIdList(baslangicTarihi, bitisTarihi, eczaneNobetGruplarTumu.Select(s => s.EczaneId).Distinct().ToList()) .Where(w => w.MazeretId != 3) .ToList(); var takvimNobetGrupGunDegerIstatistikler = _takvimService.GetTakvimNobetGrupGunDegerIstatistikler(nobetUstGrupBaslangicTarihi, bitisTarihi, nobetGrupGorevTipler); var eczaneNobetGrupAltGruplar = _eczaneNobetGrupAltGrupService.GetDetaylar(nobetUstGrupId); #region önceki aylar aynı gün nöbet tutanlar çözülen ayda aynı gün nöbetçi olmasın var oncekiAylardaAyniGunNobetTutanEczaneler = new List <EczaneGrupDetay>(); var oncekiAylarAyniGunNobet = _nobetUstGrupKisitService.GetDetay("oncekiAylarAyniGunNobet", nobetUstGrupId); if (!oncekiAylarAyniGunNobet.PasifMi) { oncekiAylardaAyniGunNobetTutanEczaneler = _eczaneNobetSonucService.OncekiAylardaAyniGunNobetTutanlar(baslangicTarihi, eczaneNobetSonuclarOncekiAylar, 0, (int)oncekiAylarAyniGunNobet.SagTarafDegeri); } #endregion var ikiliEczaneler = _ayniGunTutulanNobetService.GetDetaylar(nobetGrupIdListe); var nobetGrupKurallar = _nobetGrupKuralService.GetDetaylarByNobetGrupGorevTipIdList(nobetGrupGorevTipler.Select(s => s.Id).ToList()); var dataModel = new OsmaniyeDataModel() { Yil = eczaneNobetDataModelParametre.YilBaslangic, Ay = eczaneNobetDataModelParametre.AyBitis, TimeLimit = eczaneNobetDataModelParametre.TimeLimit, CalismaSayisiLimit = eczaneNobetDataModelParametre.CalismaSayisi, LowerBound = 0, UpperBound = 1, BaslangicTarihi = baslangicTarihi, BitisTarihi = bitisTarihi, NobetUstGrupBaslangicTarihi = nobetUstGrupBaslangicTarihi, NobetUstGrupId = nobetUstGrupId, EczaneNobetTarihAralik = eczaneNobetTarihAralik, //karar değişkeni EczaneKumulatifHedefler = eczaneKumulatifHedefler, //.Where(w => w.EczaneId != 121).ToList(), EczaneNobetIstatistikler = eczaneNobetIstatistikler, EczaneNobetMazeretler = eczaneNobetMazeretler, EczaneGrupTanimlar = eczaneGrupTanimlar, TarihAraligi = tarihAralik, NobetGruplar = nobetGruplar, EczaneGruplar = eczaneGruplar2, AyniGunNobetTutanEsGruplar = new List <EczaneGrupDetay>(), //ayniGunNoetTutanEczaneGruplar, OncekiAylardaAyniGunNobetTutanEczaneler = oncekiAylardaAyniGunNobetTutanEczaneler, EczaneNobetIstekler = eczaneNobetIstekler, NobetGrupGunKurallar = _nobetGrupGunKuralService.GetAktifList(nobetGrupIdListe), NobetGrupGorevTipGunKurallar = _nobetGrupGorevTipGunKuralService.GetDetaylarAktifList(nobetGrupGorevTipler.Select(s => s.Id).ToList()), NobetGrupKurallar = nobetGrupKurallar, NobetGrupGorevTipler = nobetGrupGorevTipler, NobetGrupTalepler = _nobetGrupTalepService.GetDetaylar(nobetGrupIdListe, baslangicTarihi, bitisTarihi), EczaneNobetGruplar = eczaneNobetGruplarTumu, NobetUstGrupKisitlar = _nobetUstGrupKisitService.GetDetaylar(nobetUstGrupId), EczaneGrupNobetSonuclar = eczaneGrupNobetSonuclar, EczaneNobetSonuclar = eczaneNobetSonuclarCozulenGruplar, EczaneGrupNobetSonuclarTumu = eczaneNobetSonuclar, EczaneNobetGrupGunKuralIstatistikler = enSonNobetler, TakvimNobetGrupGunDegerIstatistikler = takvimNobetGrupGunDegerIstatistikler, EczaneNobetGrupGunKuralIstatistikYatay = eczaneNobetGrupGunKuralIstatistikYatay, EczaneNobetGrupGunKuralIstatistikYataySon3Ay = eczaneNobetGrupGunKuralIstatistikYataySon3Ay, EczaneNobetGrupAltGruplar = eczaneNobetGrupAltGruplar, Kalibrasyonlar = _kalibrasyonService.GetKalibrasyonlarYatay(nobetUstGrupId), IkiliEczaneler = ikiliEczaneler, NobetDurumlar = _nobetDurumService.GetDetaylar(nobetUstGrupId), DebugYapilacakEczaneler = debugYapilacakEczaneler }; //_eczaneNobetOrtakService.KurallariKontrolEtHaftaIciEnAzEnCok(nobetUstGrupId, eczaneNobetGrupGunKuralIstatistikYatay); _eczaneNobetOrtakService.KurallariKontrolEtMazeretIstek(nobetUstGrupId, eczaneNobetMazeretler, eczaneNobetIstekler); _eczaneNobetOrtakService.KurallariKontrolEtIstek(nobetUstGrupId, eczaneNobetIstekler, nobetGrupKurallar); return(dataModel); }