|
|
@ -309,7 +309,7 @@ def deadline_v_rocniku(datum, rocnik): |
|
|
|
deadliny.append((TypDeadline.FinalDeadline, c, c.datum_deadline)) |
|
|
|
deadliny = sorted(deadliny, key=lambda x: x[2]) # podle data |
|
|
|
for dl in deadliny: |
|
|
|
if datum <= dl: |
|
|
|
if datum <= dl[2]: |
|
|
|
# První takový deadline je ten nejtěsnější |
|
|
|
return dl |
|
|
|
|
|
|
@ -319,20 +319,22 @@ def deadline(datum): |
|
|
|
Vrací trojici (TypDeadline, Cislo, datumDeadline: date). |
|
|
|
""" |
|
|
|
|
|
|
|
if isinstance(datum, datetime.datetime): |
|
|
|
datum = datum.date() |
|
|
|
rok = datum.year |
|
|
|
# Dva ročníky podezřelé z obsahování dat |
|
|
|
pozdejsi_rocnik = m.Rocnik.filter(prvni_rok=rok) |
|
|
|
drivejsi_rocnik = m.Rocnik.filter(druhy_rok=rok) |
|
|
|
if any( |
|
|
|
pozdejsi_rocnik = m.Rocnik.objects.filter(prvni_rok=rok) |
|
|
|
drivejsi_rocnik = m.Rocnik.objects.filter(prvni_rok=rok-1) |
|
|
|
if any([ |
|
|
|
pozdejsi_rocnik.count() > 1, |
|
|
|
drivejsi_rocnik.count() > 1, |
|
|
|
): |
|
|
|
]): |
|
|
|
raise ValueError(f"Více ročníků začíná/končí stejným rokem: {rok}") |
|
|
|
pozdejsi_rocnik = pozdejsi_rocnik.first() if pozdejsi_rocnik.count() > 0 else None |
|
|
|
drivejsi_rocnik = drivejsi_rocnik.first() if drivejsi_rocnik.count() > 0 else None |
|
|
|
|
|
|
|
# Předpokládáme, že neexistuje číslo, které má deadline ale nemá finální deadline. |
|
|
|
posledni_deadline_drivejsiho_rocniku = m.Cislo.objects.get(rocnik=drivejsi_rocnik, datum_deadline__isnull=False).datum_deadline |
|
|
|
posledni_deadline_drivejsiho_rocniku = m.Cislo.objects.filter(rocnik=drivejsi_rocnik, datum_deadline__isnull=False).last().datum_deadline |
|
|
|
|
|
|
|
if datum <= posledni_deadline_drivejsiho_rocniku: |
|
|
|
return deadline_v_rocniku(datum, drivejsi_rocnik) |
|
|
|