2014-11-17 12:05:46 +01:00
# -*- coding: utf-8 -*-
2015-03-13 20:08:18 +01:00
import os
import random
2014-11-17 12:05:46 +01:00
from django . db import models
from django . contrib import auth
from django . utils import timezone
from django . conf import settings
2015-03-13 20:08:18 +01:00
from django . utils . encoding import python_2_unicode_compatible
2019-04-16 21:30:56 +02:00
from django . utils . encoding import force_text
2015-05-11 12:56:39 +02:00
from django . utils . text import slugify
2015-04-01 14:01:13 +02:00
from django . core . urlresolvers import reverse
2015-05-21 22:58:37 +02:00
from django . core . cache import cache
2016-06-05 21:17:28 +02:00
from django . core . exceptions import ObjectDoesNotExist
2016-09-03 21:52:08 +02:00
from django . utils . text import get_valid_filename
2015-11-20 20:21:22 +01:00
from imagekit . models import ImageSpecField , ProcessedImageField
from imagekit . processors import ResizeToFit , Transpose
2015-05-21 22:58:37 +02:00
2015-03-14 15:41:29 +01:00
from django_countries . fields import CountryField
from solo . models import SingletonModel
2015-05-15 15:28:00 +02:00
from taggit . managers import TaggableManager
2015-03-14 15:41:29 +01:00
2016-01-09 17:03:40 +01:00
from reversion import revisions as reversion
2015-05-14 16:02:00 +02:00
2015-05-11 12:56:39 +02:00
from seminar . utils import roman
2016-09-03 21:52:08 +02:00
from unidecode import unidecode
2016-06-05 21:17:28 +02:00
2015-05-11 12:56:39 +02:00
class SeminarModelBase ( models . Model ) :
2015-05-06 17:07:32 +02:00
2019-03-26 21:14:10 +01:00
class Meta :
abstract = True
2015-05-06 17:07:32 +02:00
2019-03-26 21:14:10 +01:00
def verejne ( self ) :
return False
2015-05-11 12:56:39 +02:00
2019-03-26 21:14:10 +01:00
def get_absolute_url ( self ) :
return self . verejne_url ( ) # TODO "absolute"
2015-05-06 17:07:32 +02:00
2019-03-26 21:14:10 +01:00
def admin_url ( self ) :
model_name = self . __class__ . __name__ . lower ( )
return reverse ( ' admin:seminar_ %s _change ' % ( model_name , ) , args = ( self . id , ) )
2015-05-11 12:56:39 +02:00
2019-03-26 21:14:10 +01:00
def verejne_url ( self ) :
return None
2015-05-06 17:07:32 +02:00
2018-08-20 22:30:16 +02:00
@reversion.register ( ignore_duplicates = True )
2015-03-13 20:08:18 +01:00
@python_2_unicode_compatible
2019-03-27 01:01:57 +01:00
class Osoba ( SeminarModelBase ) :
2019-03-26 21:14:10 +01:00
class Meta :
2019-03-27 01:01:57 +01:00
db_table = ' seminar_osoby '
2019-04-16 21:13:36 +02:00
verbose_name = ' Osoba '
verbose_name_plural = ' Osoby '
2019-03-27 01:01:57 +01:00
ordering = [ ' prijmeni ' , ' jmeno ' ]
2019-03-26 21:14:10 +01:00
id = models . AutoField ( primary_key = True )
2014-11-17 12:05:46 +01:00
2019-04-16 21:13:36 +02:00
jmeno = models . CharField ( ' jméno ' , max_length = 256 )
2014-11-17 12:05:46 +01:00
2019-04-16 21:13:36 +02:00
prijmeni = models . CharField ( ' příjmení ' , max_length = 256 )
2014-11-17 12:05:46 +01:00
2019-04-16 21:13:36 +02:00
prezdivka = models . CharField ( ' přezdívka ' , max_length = 256 )
2019-03-27 01:01:57 +01:00
2019-03-26 21:14:10 +01:00
# User, pokud má na webu účet
2019-05-10 23:20:42 +02:00
user = models . OneToOneField ( settings . AUTH_USER_MODEL , blank = True , null = True ,
2019-05-11 01:15:05 +02:00
verbose_name = ' uživatel ' )
2014-11-17 12:05:46 +01:00
2019-03-26 21:14:10 +01:00
# Pohlaví. Že ho neznáme se snad nestane (a ušetří to práci při programování)
2019-04-16 21:13:36 +02:00
pohlavi_muz = models . BooleanField ( ' pohlaví (muž) ' , default = False )
2014-11-17 12:05:46 +01:00
2019-04-16 21:13:36 +02:00
email = models . EmailField ( ' e-mail ' , max_length = 256 , blank = True , default = ' ' )
2019-03-26 21:14:10 +01:00
2019-04-16 21:13:36 +02:00
telefon = models . CharField ( ' telefon ' , max_length = 256 , blank = True , default = ' ' )
2019-03-26 21:14:10 +01:00
2019-04-16 21:13:36 +02:00
datum_narozeni = models . DateField ( ' datum narození ' , blank = True , null = True )
2019-03-26 21:14:10 +01:00
# NULL dokud nedali souhlas
2019-04-16 21:13:36 +02:00
datum_souhlasu_udaje = models . DateField ( ' datum souhlasu (údaje) ' , blank = True , null = True ,
help_text = ' Datum souhlasu se zpracováním osobních údajů ' )
2014-11-17 12:05:46 +01:00
2019-03-26 21:14:10 +01:00
# NULL dokud nedali souhlas
2019-04-16 21:13:36 +02:00
datum_souhlasu_zasilani = models . DateField ( ' datum souhlasu (spam) ' , blank = True , null = True ,
help_text = ' Datum souhlasu se zasíláním MFF materiálů ' )
2014-11-17 12:05:46 +01:00
2019-03-26 21:14:10 +01:00
# Alespoň odhad (rok či i měsíc)
2019-04-16 21:13:36 +02:00
datum_registrace = models . DateField ( ' datum registrace do semináře ' , default = timezone . now )
2014-11-17 12:05:46 +01:00
2019-03-26 21:14:10 +01:00
# Ulice může být i jen číslo
2019-04-16 21:13:36 +02:00
ulice = models . CharField ( ' ulice ' , max_length = 256 , blank = True , default = ' ' )
2014-11-17 12:05:46 +01:00
2019-04-16 21:13:36 +02:00
mesto = models . CharField ( ' město ' , max_length = 256 , blank = True , default = ' ' )
2014-11-17 12:05:46 +01:00
2019-04-16 21:13:36 +02:00
psc = models . CharField ( ' PSČ ' , max_length = 32 , blank = True , default = ' ' )
2014-11-17 12:05:46 +01:00
2019-03-26 21:14:10 +01:00
# ISO 3166-1 dvojznakovy kod zeme velkym pismem (CZ, SK)
# Ekvivalentní s CharField(max_length=2, default='CZ', ...)
2019-04-16 21:13:36 +02:00
stat = CountryField ( ' stát ' , default = ' CZ ' ,
help_text = ' ISO 3166-1 kód země velkými písmeny (CZ, SK, ...) ' )
2014-11-17 12:05:46 +01:00
2019-04-16 21:13:36 +02:00
poznamka = models . TextField ( ' neveřejná poznámka ' , blank = True ,
help_text = ' Neveřejná poznámka k osobě (plain text) ' )
2015-05-11 12:56:39 +02:00
2019-03-27 01:01:57 +01:00
foto = ProcessedImageField ( verbose_name = ' Fotografie osoby ' ,
upload_to = ' image_osoby/velke/ % Y/ ' , null = True , blank = True ,
help_text = ' Vlož fotografii osoby o libovolné velikosti ' ,
processors = [
Transpose ( Transpose . AUTO ) ,
ResizeToFit ( 500 , 500 , upscale = False )
] ,
options = { ' quality ' : 95 } )
foto_male = ImageSpecField ( source = ' foto ' ,
processors = [
ResizeToFit ( 200 , 200 , upscale = False )
] ,
options = { ' quality ' : 95 } )
2015-05-15 00:18:39 +02:00
2019-03-26 21:14:10 +01:00
def plne_jmeno ( self ) :
2019-04-16 21:13:36 +02:00
return force_unicode ( ' %s %s ' % ( self . jmeno , self . prijmeni ) )
2015-03-13 20:08:18 +01:00
2019-03-26 21:14:10 +01:00
def inicial_krestni ( self ) :
2019-04-30 23:37:11 +02:00
jmena = self . jmeno . split ( )
return " " . join ( [ ' {} . ' . format ( jmeno [ 0 ] ) for jmeno in jmena ] )
2015-12-03 01:05:06 +01:00
2019-03-26 21:14:10 +01:00
def __str__ ( self ) :
2019-03-27 01:01:57 +01:00
return force_unicode ( " Osoba( {} ) " . format ( self . plne_jmeno ( ) ) )
2019-04-23 22:25:18 +02:00
#
# Mělo by být částečně vytaženo z Aesopa
# viz https://ovvp.mff.cuni.cz/wiki/aesop/export-skol.
#
2019-04-16 21:30:56 +02:00
@reversion.register ( ignore_duplicates = True )
@python_2_unicode_compatible
class Skola ( SeminarModelBase ) :
class Meta :
db_table = ' seminar_skoly '
verbose_name = ' Škola '
verbose_name_plural = ' Školy '
ordering = [ ' mesto ' , ' nazev ' ]
# Interní ID
id = models . AutoField ( primary_key = True )
# Aesopi ID "izo:..." nebo "aesop:..."
# NULL znamená v exportu do aesopa "ufo"
aesop_id = models . CharField ( ' Aesop ID ' , max_length = 32 , blank = True , default = ' ' ,
help_text = ' Aesopi ID typu " izo:... " nebo " aesop:... " ' )
# IZO školy (jen české školy)
izo = models . CharField ( ' IZO ' , max_length = 32 , blank = True ,
help_text = ' IZO školy (jen české školy) ' )
# Celý název školy
nazev = models . CharField ( ' název ' , max_length = 256 ,
help_text = ' Celý název školy ' )
# Zkraceny nazev pro zobrazení ve výsledkovce, volitelné.
# Není v Aesopovi, musíme vytvářet sami.
kratky_nazev = models . CharField ( ' zkrácený název ' , max_length = 256 , blank = True ,
help_text = " Zkrácený název pro zobrazení ve výsledkovce " )
# Ulice může být jen číslo
ulice = models . CharField ( ' ulice ' , max_length = 256 )
mesto = models . CharField ( ' město ' , max_length = 256 )
psc = models . CharField ( ' PSČ ' , max_length = 32 )
# ISO 3166-1 dvojznakovy kod zeme velkym pismem (CZ, SK)
# Ekvivalentní s CharField(max_length=2, default='CZ', ...)
stat = CountryField ( ' stát ' , default = ' CZ ' ,
help_text = ' ISO 3166-1 kód země velkými písmeny (CZ, SK, ...) ' )
# Jaké vzdělání škpla poskytuje?
je_zs = models . BooleanField ( ' základní stupeň ' , default = True )
je_ss = models . BooleanField ( ' střední stupeň ' , default = True )
poznamka = models . TextField ( ' neveřejná poznámka ' , blank = True ,
help_text = ' Neveřejná poznámka ke škole (plain text) ' )
kontaktni_osoba = models . ForeignKey ( Osoba , verbose_name = ' Kontaktní osoba ' ,
blank = True , null = True )
def __str__ ( self ) :
return force_unicode ( ' %s , %s , %s ' % ( self . nazev , self . ulice , self . mesto ) )
2019-03-27 01:01:57 +01:00
class Prijemce ( SeminarModelBase ) :
class Meta :
db_table = ' seminar_prijemce '
2019-04-16 21:13:36 +02:00
verbose_name = ' příjemce '
verbose_name_plural = ' příjemce '
2019-03-27 01:01:57 +01:00
# Interní ID
id = models . AutoField ( primary_key = True )
2019-04-16 21:13:36 +02:00
poznamka = models . TextField ( ' neveřejná poznámka ' , blank = True ,
help_text = ' Neveřejná poznámka k příemci čísel (plain text) ' )
2019-03-27 01:01:57 +01:00
2019-04-16 21:13:36 +02:00
osoba = models . ForeignKey ( Osoba , verbose_name = ' komu ' , blank = False , null = False ,
help_text = ' Které osobě či na jakou adresu se mají zasílat čísla ' )
2019-03-27 01:01:57 +01:00
# FIXME: možná chceme něco jako vazbu na osobu XOR školu a počet kusů k zaslání
@reversion.register ( ignore_duplicates = True )
@python_2_unicode_compatible
class Resitel ( SeminarModelBase ) :
class Meta :
db_table = ' seminar_resitele '
2019-04-16 21:13:36 +02:00
verbose_name = ' Řešitel '
verbose_name_plural = ' Řešitelé '
2019-03-27 01:01:57 +01:00
ordering = [ ' osoba ' ]
# Interní ID
id = models . AutoField ( primary_key = True )
2019-05-10 22:30:51 +02:00
osoba = models . OneToOneField ( Osoba , blank = False , null = True , verbose_name = ' osoba ' ) # FIXME opravit po prvni migraci
2019-03-27 01:01:57 +01:00
2019-04-16 21:13:36 +02:00
skola = models . ForeignKey ( Skola , blank = True , null = True , verbose_name = ' škola ' )
2019-03-27 01:01:57 +01:00
# Očekávaný rok maturity a vyřazení z aktivních řešitelů
2019-04-16 21:13:36 +02:00
rok_maturity = models . IntegerField ( ' rok maturity ' , blank = True , null = True )
2019-03-27 01:01:57 +01:00
ZASILAT_DOMU = ' domu '
ZASILAT_DO_SKOLY = ' do_skoly '
ZASILAT_NIKAM = ' nikam '
ZASILAT_CHOICES = [
2019-04-16 21:13:36 +02:00
( ZASILAT_DOMU , ' Domů ' ) ,
( ZASILAT_DO_SKOLY , ' Do školy ' ) ,
( ZASILAT_NIKAM , ' Nikam ' ) ,
2019-03-27 01:01:57 +01:00
]
2019-04-16 21:13:36 +02:00
zasilat = models . CharField ( ' kam zasílat ' , max_length = 32 , choices = ZASILAT_CHOICES , blank = False , default = ZASILAT_DOMU )
2019-03-27 01:01:57 +01:00
2019-04-16 21:13:36 +02:00
poznamka = models . TextField ( ' neveřejná poznámka ' , blank = True ,
help_text = ' Neveřejná poznámka k řešiteli (plain text) ' )
2019-03-27 01:01:57 +01:00
2014-11-17 12:05:46 +01:00
2019-03-26 21:14:10 +01:00
def export_row ( self ) :
2019-03-27 01:01:57 +01:00
" Slovnik pro pouziti v AESOP exportu "
2019-03-26 21:14:10 +01:00
return {
2019-03-27 01:01:57 +01:00
' id ' : self . id ,
' name ' : self . osoba . jmeno ,
' surname ' : self . osoba . prijmeni ,
' gender ' : ' M ' if self . osoba . pohlavi_muz else ' F ' ,
' born ' : self . osoba . datum_narozeni . isoformat ( ) if self . osoba . datum_narozeni else ' ' ,
' email ' : self . osoba . email ,
' end-year ' : self . rok_maturity or ' ' ,
' street ' : self . osoba . ulice ,
' town ' : self . osoba . mesto ,
' postcode ' : self . osoba . psc ,
' country ' : self . osoba . stat ,
' spam-flag ' : ' Y ' if self . osoba . datum_souhlasu_zasilani else ' ' ,
' spam-date ' : self . osoba . datum_souhlasu_zasilani . isoformat ( ) if self . osoba . datum_souhlasu_zasilani else ' ' ,
' school ' : self . skola . aesop_id if self . skola else ' ' ,
' school-name ' : str ( self . skola ) if self . skola else ' Skola neni znama ' ,
2019-03-26 21:14:10 +01:00
}
2015-06-29 00:27:02 +02:00
2019-03-26 21:14:10 +01:00
def rocnik ( self , rocnik ) :
""" Vrati skolni rocnik resitele pro zadany Rocnik.
Vraci ' ' pro neznamy rok maturity resitele , Z * pro ekvivalent ZŠ . """
if self . rok_maturity is None :
return ' '
rozdil = 5 - ( self . rok_maturity - rocnik . prvni_rok )
if rozdil > = 1 :
return str ( rozdil )
else :
return ' Z ' + str ( rozdil + 9 )
def get_titul ( self , celkove_body ) :
" Vrati titul podle zadaneho poctu bodu. "
if celkove_body < 10 :
return ' '
elif celkove_body < 20 :
return ' Bc. '
elif celkove_body < 50 :
return ' Mgr. '
elif celkove_body < 100 :
return ' Dr. '
elif celkove_body < 200 :
return ' Doc. '
elif celkove_body < 500 :
return ' Prof. '
else :
return ' Akad. '
2019-04-23 22:25:18 +02:00
def __str__ ( ) :
return ( force_unicode ( u " Řešitel ( {} ) " . format ( self . osoba . plne_jmeno ( ) ) ) )
2015-07-09 11:46:46 +02:00
2015-07-09 03:07:29 +02:00
2014-11-17 12:05:46 +01:00
2018-08-20 22:30:16 +02:00
@reversion.register ( ignore_duplicates = True )
2015-03-13 20:08:18 +01:00
@python_2_unicode_compatible
2015-05-11 12:56:39 +02:00
class Rocnik ( SeminarModelBase ) :
2014-11-17 12:05:46 +01:00
2019-03-26 21:14:10 +01:00
class Meta :
db_table = ' seminar_rocniky '
2019-04-16 21:13:36 +02:00
verbose_name = ' Ročník '
verbose_name_plural = ' Ročníky '
2019-03-26 21:14:10 +01:00
ordering = [ ' -rocnik ' ]
2014-11-17 12:05:46 +01:00
2019-03-26 21:14:10 +01:00
# Interní ID
id = models . AutoField ( primary_key = True )
2014-11-17 12:05:46 +01:00
2019-04-16 21:13:36 +02:00
prvni_rok = models . IntegerField ( ' první rok ' , db_index = True , unique = True )
2015-03-13 20:08:18 +01:00
2019-04-16 21:13:36 +02:00
rocnik = models . IntegerField ( ' číslo ročníku ' , db_index = True , unique = True )
2015-03-13 20:08:18 +01:00
2019-04-16 21:13:36 +02:00
exportovat = models . BooleanField ( ' export do AESOPa ' , db_column = ' exportovat ' , default = False ,
help_text = ' Exportuje se jen podle tohoto flagu (ne veřejnosti), a to jen čísla s veřejnou výsledkovkou ' )
2015-07-23 20:42:50 +02:00
2019-03-26 21:14:10 +01:00
def __str__ ( self ) :
2019-04-16 21:13:36 +02:00
return force_unicode ( ' %s ( %d / %d ) ' % ( self . rocnik , self . prvni_rok , self . prvni_rok + 1 ) )
2014-11-17 12:05:46 +01:00
2019-03-27 01:01:57 +01:00
# Ročník v římských číslech
2019-03-26 21:14:10 +01:00
def roman ( self ) :
return force_unicode ( roman ( int ( self . rocnik ) ) )
2014-11-17 12:05:46 +01:00
2019-03-26 21:14:10 +01:00
def verejne ( self ) :
return len ( self . verejna_cisla ( ) ) > 0
verejne . boolean = True
2019-04-16 21:13:36 +02:00
verejne . short_description = ' Veřejný (jen dle čísel) '
2019-03-26 21:14:10 +01:00
def verejna_cisla ( self ) :
vc = [ c for c in self . cisla . all ( ) if c . verejne ( ) ]
vc . sort ( key = lambda c : c . cislo )
return vc
2015-05-06 17:07:32 +02:00
2019-03-26 21:14:10 +01:00
def posledni_verejne_cislo ( self ) :
vc = self . verejna_cisla ( )
return vc [ - 1 ] if vc else None
2015-04-01 14:01:13 +02:00
2019-03-26 21:14:10 +01:00
def verejne_vysledkovky_cisla ( self ) :
vc = list ( self . cisla . filter ( verejna_vysledkovka = True ) )
vc . sort ( key = lambda c : c . cislo )
return vc
2015-07-23 20:52:56 +02:00
2019-03-26 21:14:10 +01:00
def posledni_zverejnena_vysledkovka_cislo ( self ) :
vc = self . verejne_vysledkovky_cisla ( )
return vc [ - 1 ] if vc else None
2015-07-23 20:52:56 +02:00
2019-03-26 21:14:10 +01:00
def druhy_rok ( self ) :
return self . prvni_rok + 1
2015-04-01 14:01:13 +02:00
2019-03-26 21:14:10 +01:00
def verejne_url ( self ) :
return reverse ( ' seminar_rocnik ' , kwargs = { ' rocnik ' : self . rocnik } )
2015-05-11 12:56:39 +02:00
2019-03-26 21:14:10 +01:00
@classmethod
def cached_rocnik ( cls , r_id ) :
name = ' rocnik_ %s ' % ( r_id , )
c = cache . get ( name )
if c is None :
c = cls . objects . get ( id = r_id )
cache . set ( name , c , 300 )
return c
2015-05-21 22:58:37 +02:00
2015-09-12 12:35:30 +02:00
def cislo_pdf_filename ( self , filename ) :
2019-03-26 21:14:10 +01:00
rocnik = str ( self . rocnik . rocnik )
return os . path . join ( ' cislo ' , ' pdf ' , rocnik , ' {} - {} .pdf ' . format ( rocnik , self . cislo ) )
2015-05-11 12:56:39 +02:00
2018-08-20 22:30:16 +02:00
@reversion.register ( ignore_duplicates = True )
2015-03-13 20:08:18 +01:00
@python_2_unicode_compatible
2015-05-11 12:56:39 +02:00
class Cislo ( SeminarModelBase ) :
2014-11-17 12:05:46 +01:00
2019-03-26 21:14:10 +01:00
class Meta :
db_table = ' seminar_cisla '
2019-04-16 21:13:36 +02:00
verbose_name = ' Číslo '
verbose_name_plural = ' Čísla '
2019-03-26 21:14:10 +01:00
ordering = [ ' -rocnik__rocnik ' , ' -cislo ' ]
# Interní ID
id = models . AutoField ( primary_key = True )
2019-04-16 21:13:36 +02:00
rocnik = models . ForeignKey ( Rocnik , verbose_name = ' ročník ' , related_name = ' cisla ' , db_index = True )
2019-03-26 21:14:10 +01:00
2019-04-16 21:13:36 +02:00
cislo = models . CharField ( ' název čísla ' , max_length = 32 , db_index = True ,
help_text = ' Většinou jen " 1 " , vyjímečně " 7-8 " , lexikograficky určuje pořadí v ročníku! ' )
2019-03-26 21:14:10 +01:00
2019-04-16 21:13:36 +02:00
datum_vydani = models . DateField ( ' datum vydání ' , blank = True , null = True ,
help_text = ' Datum vydání finální verze ' )
2019-03-26 21:14:10 +01:00
2019-04-16 21:13:36 +02:00
datum_deadline = models . DateField ( ' datum deadline ' , blank = True , null = True ,
help_text = ' Datum pro příjem řešení úloh zadaných v tomto čísle ' )
2019-03-26 21:14:10 +01:00
datum_deadline_soustredeni = models . DateField (
2019-04-16 21:13:36 +02:00
' datum deadline soustředění ' ,
2019-03-26 21:14:10 +01:00
blank = True , null = True ,
2019-04-16 21:13:36 +02:00
help_text = ' Datum pro příjem řešení pro účast na soustředění ' )
2019-03-26 21:14:10 +01:00
2019-04-16 21:13:36 +02:00
verejne_db = models . BooleanField ( ' číslo zveřejněno ' ,
2019-03-27 01:01:57 +01:00
db_column = ' verejne ' , default = False )
2019-03-26 21:14:10 +01:00
verejna_vysledkovka = models . BooleanField (
2019-04-16 21:13:36 +02:00
' zveřejněna výsledkovka ' ,
2019-03-26 21:14:10 +01:00
default = False ,
2019-04-16 21:13:36 +02:00
help_text = ' Je-li false u veřejného čísla, \
2019-05-11 02:00:41 +02:00
není výsledkovka zatím veřejná . ' )
2019-03-26 21:14:10 +01:00
2019-04-16 21:13:36 +02:00
poznamka = models . TextField ( ' neveřejná poznámka ' , blank = True ,
help_text = ' Neveřejná poznámka k číslu (plain text) ' )
2019-03-26 21:14:10 +01:00
2019-04-16 21:13:36 +02:00
pdf = models . FileField ( ' pdf ' , upload_to = cislo_pdf_filename , null = True , blank = True ,
help_text = ' Pdf čísla, které si mohou řešitelé stáhnout ' )
2019-03-26 21:14:10 +01:00
def kod ( self ) :
2019-04-16 21:13:36 +02:00
return ' %s . %s ' % ( self . rocnik . rocnik , self . cislo )
kod . short_description = ' Kód čísla '
2019-03-26 21:14:10 +01:00
def __str__ ( self ) :
# Potenciální DB HOG, pokud by se ročník necachoval
r = Rocnik . cached_rocnik ( self . rocnik_id )
2019-04-16 21:13:36 +02:00
return force_unicode ( ' %s . %s ' % ( r . rocnik , self . cislo , ) )
2019-03-26 21:14:10 +01:00
def verejne ( self ) :
return self . verejne_db
verejne . boolean = True
def verejne_url ( self ) :
return reverse ( ' seminar_cislo ' , kwargs = { ' rocnik ' : self . rocnik . rocnik , ' cislo ' : self . cislo } )
def nasledujici ( self ) :
u " Vrací None, pokud je toto poslední "
return self . relativni_v_rocniku ( 1 )
def predchozi ( self ) :
u " Vrací None, pokud je toto první "
return self . relativni_v_rocniku ( - 1 )
def relativni_v_rocniku ( self , rel_index ) :
u " Číslo o `index` dále v ročníku. None pokud neexistuje. "
cs = self . rocnik . cisla . order_by ( ' cislo ' ) . all ( )
i = list ( cs ) . index ( self ) + rel_index
if ( i < 0 ) or ( i > = len ( cs ) ) :
return None
return cs [ i ]
@classmethod
def get ( cls , rocnik , cislo ) :
try :
r = Rocnik . objects . get ( rocnik = rocnik )
c = r . cisla . get ( cislo = cislo )
except ObjectDoesNotExist :
return None
return c
2016-06-05 21:17:28 +02:00
2019-04-16 21:45:43 +02:00
@reversion.register ( ignore_duplicates = True )
@python_2_unicode_compatible
class Organizator ( SeminarModelBase ) :
# zmena dedicnosti z models.Model na SeminarModelBase, potencialni vznik bugu
2019-05-10 22:30:51 +02:00
osoba = models . OneToOneField ( Osoba , verbose_name = ' osoba ' , related_name = ' org ' ,
2019-05-10 20:48:00 +02:00
help_text = ' osobní údaje organizátora ' , null = True , blank = False ) #FIXME opravit po migraci
2019-04-16 21:45:43 +02:00
vytvoreno = models . DateTimeField (
' Vytvořeno ' ,
default = timezone . now ,
blank = True ,
editable = False
)
2019-05-17 19:42:49 +02:00
organizuje_od = models . DateTimeField ( ' Organizuje od ' , blank = True , null = True )
2019-04-16 21:45:43 +02:00
organizuje_do = models . DateTimeField ( ' Organizuje do ' , blank = True , null = True )
studuje = models . CharField ( ' Studium aj. ' , max_length = 256 ,
null = True , blank = True ,
help_text = u " Např. ' Studuje Obecnou fyziku (Bc.), 3. ročník ' , "
" ' Vystudovala Diskrétní modely a algoritmy (Mgr.) ' nebo "
" ' Přednáší na MFF ' " )
strucny_popis_organizatora = models . TextField ( ' Stručný popis organizátora ' ,
null = True , blank = True )
skola = models . CharField ( ' Škola, kterou studuje ' , max_length = 256 , null = True , blank = True ,
help_text = u " Škola, např. MFF, VŠCHT, VUT, ... prostě aby se nemuselo psát do studuje "
" školu, ale jen obor, možnost zobrazit zvlášť " )
def __str__ ( self ) :
if self . osoba . prezdivka :
return u " %s ' %s ' %s " . format ( self . osoba . jmeno ,
self . osoba . prezdivka ,
self . osoba . prijmeni )
else :
return u " %s %s " . format ( self . osoba . jmeno , self . osoba . prijmeni )
class Meta :
verbose_name = ' Organizátor '
verbose_name_plural = ' Organizátoři '
@reversion.register ( ignore_duplicates = True )
@python_2_unicode_compatible
class Soustredeni ( SeminarModelBase ) :
class Meta :
db_table = ' seminar_soustredeni '
verbose_name = ' Soustředění '
verbose_name_plural = ' Soustředění '
ordering = [ ' -rocnik__rocnik ' , ' -datum_zacatku ' ]
# Interní ID
id = models . AutoField ( primary_key = True )
rocnik = models . ForeignKey ( Rocnik , verbose_name = ' ročník ' , related_name = ' soustredeni ' )
datum_zacatku = models . DateField ( ' datum začátku ' , blank = True , null = True ,
help_text = ' První den soustředění ' )
datum_konce = models . DateField ( ' datum konce ' , blank = True , null = True ,
help_text = ' Poslední den soustředění ' )
verejne_db = models . BooleanField ( ' soustředění zveřejněno ' , db_column = ' verejne ' , default = False )
misto = models . CharField ( ' místo soustředění ' , max_length = 256 , blank = True , default = ' ' ,
help_text = ' Místo (název obce, volitelně též objektu ' )
ucastnici = models . ManyToManyField ( Resitel , verbose_name = ' účastníci soustředění ' ,
help_text = ' Seznam účastníků soustředění ' , through = ' Soustredeni_Ucastnici ' )
organizatori = models . ManyToManyField ( Organizator ,
verbose_name = ' Organizátoři soustředění ' ,
help_text = ' Seznam organizátorů soustředění ' ,
through = ' Soustredeni_Organizatori ' )
text = models . TextField ( ' text k soustředění (HTML) ' , blank = True , default = ' ' )
TYP_JARNI = ' jarni '
TYP_PODZIMNI = ' podzimni '
TYP_VIKEND = ' vikend '
TYP_CHOICES = [
( TYP_JARNI , ' Jarní soustředění ' ) ,
( TYP_PODZIMNI , ' Podzimní soustředění ' ) ,
( TYP_VIKEND , ' Víkendový sraz ' ) ,
]
typ = models . CharField ( ' typ akce ' , max_length = 16 , choices = TYP_CHOICES , blank = False , default = TYP_PODZIMNI )
exportovat = models . BooleanField ( ' export do AESOPa ' , db_column = ' exportovat ' , default = False ,
help_text = ' Exportuje se jen podle tohoto flagu (ne veřejnosti) ' )
def __str__ ( self ) :
return force_unicode ( ' %s ( %s ) ' . format ( self . misto , self . datum_zacatku ) )
def verejne ( self ) :
return self . verejne_db
verejne . boolean = True
def verejne_url ( self ) :
#return reverse('seminar_soustredeni', kwargs={'pk': self.id})
return reverse ( ' seminar_seznam_soustredeni ' )
2015-09-12 12:35:30 +02:00
2018-08-20 22:30:16 +02:00
@reversion.register ( ignore_duplicates = True )
2015-03-13 20:08:18 +01:00
@python_2_unicode_compatible
2015-05-11 12:56:39 +02:00
class Problem ( SeminarModelBase ) :
2014-11-17 12:05:46 +01:00
2019-03-26 21:14:10 +01:00
class Meta :
2019-04-30 21:19:52 +02:00
# Není abstraktní, protože se na něj jinak nedají dělat ForeignKeys.
# TODO: Udělat to polymorfní (pomocí django-polymorphic), abychom dostali po těch vazbách přímo tu úlohu/témátko vč. fieldů, které nejsou součástí modelu Problem?
#abstract = True
2019-05-16 23:06:06 +02:00
db_table = ' seminar_problemy '
2019-04-16 21:13:36 +02:00
verbose_name = ' Problém '
verbose_name_plural = ' Problémy '
2019-03-26 21:14:10 +01:00
ordering = [ ' nazev ' ]
# Interní ID
id = models . AutoField ( primary_key = True )
# Název
2019-04-16 21:13:36 +02:00
nazev = models . CharField ( ' název ' , max_length = 256 )
2019-03-26 21:14:10 +01:00
2019-03-27 01:01:57 +01:00
# Problém má podproblémy
2019-04-16 21:45:43 +02:00
nadproblem = models . ForeignKey ( ' self ' , verbose_name = ' nadřazený problém ' ,
2019-04-30 21:19:02 +02:00
related_name = ' nadproblem_ %(class)s ' , null = True , blank = True )
2019-03-26 21:14:10 +01:00
STAV_NAVRH = ' navrh '
STAV_ZADANY = ' zadany '
2019-03-27 01:01:57 +01:00
STAV_VYRESENY = ' vyreseny '
2019-03-26 21:14:10 +01:00
STAV_SMAZANY = ' smazany '
STAV_CHOICES = [
2019-04-16 21:13:36 +02:00
( STAV_NAVRH , ' Návrh ' ) ,
( STAV_ZADANY , ' Zadaný ' ) ,
( STAV_VYRESENY , ' Vyřešený ' ) ,
( STAV_SMAZANY , ' Smazaný ' ) ,
2019-03-26 21:14:10 +01:00
]
2019-04-16 21:13:36 +02:00
stav = models . CharField ( ' stav problému ' , max_length = 32 , choices = STAV_CHOICES , blank = False , default = STAV_NAVRH )
2019-03-26 21:14:10 +01:00
2019-04-16 21:13:36 +02:00
zamereni = TaggableManager ( verbose_name = ' zaměření ' , help_text = ' Zaměření M/F/I/O problému, příp. další tagy ' , blank = True )
2019-03-26 21:14:10 +01:00
2019-04-16 21:13:36 +02:00
poznamka = models . TextField ( ' org poznámky (HTML) ' , blank = True ,
help_text = ' Neveřejný návrh úlohy, návrh řešení, text zadání, poznámky ... ' )
2019-03-26 21:14:10 +01:00
2019-04-16 21:13:36 +02:00
autor = models . ForeignKey ( Organizator , verbose_name = ' autor problému ' ,
2019-04-30 21:19:02 +02:00
related_name = ' autor_problemu_ %(class)s ' , null = True , blank = True )
2019-03-26 21:14:10 +01:00
2019-04-16 21:13:36 +02:00
garant = models . ForeignKey ( Organizator , verbose_name = ' garant zadaného problému ' ,
2019-04-30 21:19:02 +02:00
related_name = ' garant_problemu_ %(class)s ' , null = True , blank = True )
2019-03-26 21:14:10 +01:00
2019-04-16 21:13:36 +02:00
opravovatele = models . ManyToManyField ( Organizator , verbose_name = ' opravovatelé ' ,
2019-04-30 21:26:25 +02:00
blank = True , related_name = ' opravovatele_ %(class)s ' )
2019-03-26 21:14:10 +01:00
2019-04-16 21:13:36 +02:00
kod = models . CharField ( ' lokální kód ' , max_length = 32 , blank = True , default = ' ' ,
help_text = ' Číslo/kód úlohy v čísle nebo kód tématu/článku/seriálu v ročníku ' )
2019-03-26 21:14:10 +01:00
2019-04-16 21:13:36 +02:00
vytvoreno = models . DateTimeField ( ' vytvořeno ' , default = timezone . now , blank = True , editable = False )
2019-03-26 21:14:10 +01:00
def __str__ ( self ) :
2019-04-16 21:13:36 +02:00
return force_unicode ( ' %s ' % ( self . nazev , ) )
2019-03-26 21:14:10 +01:00
2019-03-27 01:01:57 +01:00
# Implicitini implementace, jednotlivé dědící třídy si přepíšou
2019-03-26 21:14:10 +01:00
def kod_v_rocniku ( self ) :
if self . stav == ' zadany ' :
2019-03-27 01:01:57 +01:00
if self . nadproblem :
return force_unicode ( self . nadproblem . kod_v_rocniku ( ) + " . {} " . format ( self . kod ) )
return force_unicode ( str ( self . kod ) )
2019-04-16 21:13:36 +02:00
return ' <Není zadaný> '
2019-03-26 21:14:10 +01:00
def verejne ( self ) :
return ( self . cislo_zadani and self . cislo_zadani . verejne ( ) )
verejne . boolean = True
def verejne_url ( self ) :
return reverse ( ' seminar_problem ' , kwargs = { ' pk ' : self . id } )
def admin_url ( self ) :
if self . stav == Problem . STAV_ZADANY :
return reverse ( ' admin:seminar_problemzadany_change ' , args = ( self . id , ) )
else :
return reverse ( ' admin:seminar_problemnavrh_change ' , args = ( self . id , ) )
2019-03-27 01:01:57 +01:00
# FIXME - k úloze
2019-03-26 21:14:10 +01:00
def body_v_zavorce ( self ) :
""" Vrať string s body v závorce jsou-li u problému vyplněné, jinak ' '
Je - li desetinná část nulová , nezobrazuj ji .
"""
pocet_bodu = None
if self . body :
b = self . body
pocet_bodu = int ( b ) if int ( b ) == b else b
return u " ( {} \u2009 b) " . format ( pocet_bodu ) if self . body else " "
2015-09-10 15:45:27 +02:00
2019-03-27 01:01:57 +01:00
class Tema ( Problem ) :
class Meta :
db_table = ' seminar_temata '
2019-04-16 21:13:36 +02:00
verbose_name = ' Téma '
verbose_name_plural = ' Témata '
2019-03-27 01:01:57 +01:00
TEMA_TEMA = ' tema '
TEMA_SERIAL = ' serial '
TEMA_CHOICES = [
2019-04-16 21:13:36 +02:00
( TEMA_TEMA , ' Téma ' ) ,
( TEMA_SERIAL , ' Seriál ' ) ,
2019-03-27 01:01:57 +01:00
]
2019-05-10 20:48:00 +02:00
tema_typ = models . CharField ( ' Typ tématu ' , max_length = 16 , choices = TEMA_CHOICES , blank = False , default = TEMA_TEMA )
2019-03-27 01:01:57 +01:00
2019-04-30 21:19:02 +02:00
rocnik = models . ForeignKey ( Rocnik , verbose_name = ' ročník ' , blank = True , null = True )
2019-03-27 01:01:57 +01:00
def kod_v_rocniku ( self ) :
if self . stav == ' zadany ' :
if self . nadproblem :
return force_unicode ( self . nadproblem . kod_v_rocniku ( ) + " .t {} " . format ( self . kod ) )
return force_unicode ( " t {} " . format ( self . kod ) )
2019-04-16 21:13:36 +02:00
return ' <Není zadaný> '
2019-03-27 01:01:57 +01:00
class Clanek ( Problem ) :
class Meta :
db_table = ' seminar_clanky '
2019-04-16 21:13:36 +02:00
verbose_name = ' Článek '
verbose_name_plural = ' Články '
2019-03-27 01:01:57 +01:00
2019-04-30 21:19:02 +02:00
cislo = models . ForeignKey ( Cislo , verbose_name = ' číslo ' , blank = True , null = True )
2019-03-27 01:01:57 +01:00
def kod_v_rocniku ( self ) :
if self . stav == ' zadany ' :
# Nemělo by být potřeba
# if self.nadproblem:
# return force_unicode(self.nadproblem.kod_v_rocniku()+".c{}".format(self.kod))
return force_unicode ( " c {} " . format ( self . kod ) )
2019-04-16 21:13:36 +02:00
return ' <Není zadaný> '
2019-04-16 21:45:43 +02:00
class Text ( SeminarModelBase ) :
class Meta :
db_table = ' seminar_texty '
verbose_name = ' text '
verbose_name_plural = ' texty '
na_web = models . TextField ( ' text na web ' , blank = True ,
help_text = ' Text ke zveřejnění na webu ' )
do_cisla = models . TextField ( ' text do čísla ' , blank = True ,
help_text = ' Text ke zveřejnění v čísle ' )
# obrázky mají návaznost opačným směrem (vazba z druhé strany)
2019-03-27 01:01:57 +01:00
class Uloha ( Problem ) :
class Meta :
db_table = ' seminar_ulohy '
2019-04-16 21:13:36 +02:00
verbose_name = ' Úloha '
verbose_name_plural = ' Úlohy '
2019-03-27 01:01:57 +01:00
2019-05-10 22:30:51 +02:00
zadani = models . OneToOneField ( Text , verbose_name = ' veřejné zadání ' , related_name = " uloha_zadani_set " , blank = True , null = True )
2019-03-27 01:01:57 +01:00
2019-05-10 22:30:51 +02:00
vzorak = models . OneToOneField ( Text , verbose_name = ' vzorové řešení ' , related_name = " uloha_vzorak_set " , blank = True , null = True )
2019-03-27 01:01:57 +01:00
2019-04-16 21:13:36 +02:00
cislo_zadani = models . ForeignKey ( Cislo , verbose_name = ' číslo zadání ' , blank = True , null = True , related_name = ' zadane_ulohy ' )
2019-03-27 01:01:57 +01:00
2019-04-16 21:13:36 +02:00
cislo_deadline = models . ForeignKey ( Cislo , verbose_name = ' číslo deadlinu ' , blank = True , null = True , related_name = ' deadlinove_ulohy ' )
2019-03-27 01:01:57 +01:00
2019-04-16 21:13:36 +02:00
cislo_reseni = models . ForeignKey ( Cislo , verbose_name = ' číslo řešení ' , blank = True , null = True , related_name = ' resene_ulohy ' ,
help_text = ' Číslo s řešením úlohy, jen pro úlohy ' )
2019-03-27 01:01:57 +01:00
2019-04-16 21:13:36 +02:00
max_body = models . DecimalField ( max_digits = 8 , decimal_places = 1 , verbose_name = ' maximum bodů ' , blank = True , null = True )
2019-03-27 01:01:57 +01:00
def kod_v_rocniku ( self ) :
if self . stav == ' zadany ' :
name = u " {} .u {} " . format ( self . cislo_zadani . cislo , self . kod )
if self . nadproblem :
return force_unicode ( self . nadproblem . kod_v_rocniku ( ) + name )
return force_unicode ( name )
2019-04-16 21:13:36 +02:00
return ' <Není zadaný> '
2019-03-27 01:01:57 +01:00
2015-03-13 20:08:18 +01:00
2018-08-20 22:30:16 +02:00
@reversion.register ( ignore_duplicates = True )
2015-03-13 20:08:18 +01:00
@python_2_unicode_compatible
2015-05-11 12:56:39 +02:00
class Reseni ( SeminarModelBase ) :
2015-03-13 20:08:18 +01:00
2019-03-26 21:14:10 +01:00
class Meta :
db_table = ' seminar_reseni '
2019-04-16 21:13:36 +02:00
verbose_name = ' Řešení '
verbose_name_plural = ' Řešení '
2019-04-30 21:19:52 +02:00
#ordering = ['-problem', 'resitele'] # FIXME: Takhle to chceme, ale nefunguje to.
ordering = [ ' -cas_doruceni ' ]
2015-03-13 20:08:18 +01:00
2019-03-26 21:14:10 +01:00
# Interní ID
id = models . AutoField ( primary_key = True )
2015-03-13 20:08:18 +01:00
2019-03-27 01:01:57 +01:00
# Ke každé dvojici řešní a problém existuje nanejvýš jedno hodnocení, doplnění vazby.
2019-04-16 21:13:36 +02:00
problem = models . ManyToManyField ( Problem , verbose_name = ' problém ' , help_text = ' Problém ' ,
2019-03-27 01:01:57 +01:00
through = ' Hodnoceni ' )
2015-03-13 20:08:18 +01:00
2019-04-16 21:13:36 +02:00
resitele = models . ManyToManyField ( Resitel , verbose_name = ' autoři řešení ' ,
help_text = ' Seznam autorů řešení ' , through = ' Reseni_Resitele ' )
2015-03-13 20:08:18 +01:00
2019-04-16 21:13:36 +02:00
cas_doruceni = models . DateTimeField ( ' čas_doručení ' , default = timezone . now , blank = True )
2015-03-13 20:08:18 +01:00
2019-03-26 21:14:10 +01:00
FORMA_PAPIR = ' papir '
FORMA_EMAIL = ' email '
FORMA_UPLOAD = ' upload '
FORMA_CHOICES = [
2019-04-16 21:13:36 +02:00
( FORMA_PAPIR , ' Papírové řešení ' ) ,
( FORMA_EMAIL , ' Emailem ' ) ,
( FORMA_UPLOAD , ' Upload přes web ' ) ,
2019-03-26 21:14:10 +01:00
]
2019-04-16 21:13:36 +02:00
forma = models . CharField ( ' forma řešení ' , max_length = 16 , choices = FORMA_CHOICES , blank = False ,
2019-03-27 01:01:57 +01:00
default = FORMA_EMAIL )
2015-05-15 21:27:02 +02:00
2019-05-10 22:30:51 +02:00
text_cely = models . OneToOneField ( Text , verbose_name = ' Plná verze textu řešení ' ,
2019-04-30 21:19:02 +02:00
blank = True , null = True , related_name = " reseni_cely_set " )
2019-03-27 01:01:57 +01:00
2019-04-16 21:13:36 +02:00
text_zkraceny = models . ManyToManyField ( Text , verbose_name = ' zkrácené verze řešení ' ,
2019-04-30 21:19:02 +02:00
help_text = ' Seznam úryvků z řešení ' , related_name = " reseni_zkraceny_set " )
2019-03-27 01:01:57 +01:00
2019-04-16 21:13:36 +02:00
poznamka = models . TextField ( ' neveřejná poznámka ' , blank = True ,
help_text = ' Neveřejná poznámka k řešení (plain text) ' )
2015-05-11 12:56:39 +02:00
2019-04-16 21:13:36 +02:00
zverejneno = models . BooleanField ( ' řešení zveřejněno ' , default = False ,
help_text = ' Udává, zda je řešení zveřejněno ' )
2019-03-27 01:01:57 +01:00
2019-03-26 21:14:10 +01:00
def __str__ ( self ) :
2019-03-27 01:01:57 +01:00
return force_unicode ( u " %s : %s " . format ( self . resitel . osoba . plne_jmeno ( ) ,
self . problem . nazev ) )
2019-03-26 21:14:10 +01:00
# NOTE: Potenciální DB HOG (bez select_related)
2015-03-13 20:08:18 +01:00
2019-03-27 01:01:57 +01:00
## Pravdepodobne uz nebude potreba:
# def save(self, *args, **kwargs):
# if ((self.cislo_body is None) and (self.problem.cislo_reseni) and
# (self.problem.typ == Problem.TYP_ULOHA)):
# self.cislo_body = self.problem.cislo_reseni
# super(Reseni, self).save(*args, **kwargs)
class Hodnoceni ( SeminarModelBase ) :
class Meta :
db_table = ' seminar_hodnoceni '
2019-04-16 21:13:36 +02:00
verbose_name = ' Hodnocení '
2019-04-16 21:45:43 +02:00
verbose_name_plural = ' Hodnocení '
2019-03-27 01:01:57 +01:00
# Interní ID
id = models . AutoField ( primary_key = True )
2019-04-16 21:13:36 +02:00
body = models . DecimalField ( max_digits = 8 , decimal_places = 1 , verbose_name = ' body ' ,
2019-03-27 01:01:57 +01:00
blank = False , null = False )
2019-04-16 21:13:36 +02:00
cislo_body = models . ForeignKey ( Cislo , verbose_name = ' číslo pro body ' ,
2019-03-27 01:01:57 +01:00
related_name = ' hodnoceni ' , blank = False , null = False )
2019-04-16 21:13:36 +02:00
reseni = models . ForeignKey ( Reseni , verbose_name = ' řešení ' )
2019-03-27 01:01:57 +01:00
2019-04-16 21:13:36 +02:00
problem = models . ForeignKey ( Problem , verbose_name = ' problém ' )
2015-06-08 22:18:15 +02:00
2015-03-13 20:08:18 +01:00
2019-03-27 01:01:57 +01:00
## FIXME: Budeme řešit později, pokud to bude potřeba.
#def aux_generate_filename(self, filename):
# """Pomocná funkce generující ošetřený název souboru v adresáři s datem"""
# clean = get_valid_filename(
# unidecode(filename.replace('/', '-').replace('\0', ''))
# )
# datedir = timezone.now().strftime('%Y-%m')
# fname = "%s_%s" % (
# timezone.now().strftime('%Y-%m-%d-%H:%M'),
# clean)
# return os.path.join(datedir, fname)
2016-09-03 21:52:08 +02:00
# Django neumí jednoduše serializovat partial nebo třídu s __call__
# (https://docs.djangoproject.com/en/1.8/topics/migrations/),
2019-05-11 02:00:41 +02:00
# neprojdou pak migrace. Takže rozlišení funkcí generujících názvy souboru
2016-09-03 21:52:08 +02:00
# podle adresáře řešíme takto.
2019-03-27 01:01:57 +01:00
##
2019-04-16 21:45:43 +02:00
def generate_filename_konfera ( self , filename ) :
return os . path . join (
settings . SEMINAR_KONFERY_DIR ,
aux_generate_filename ( self , filename )
)
2015-03-24 01:12:20 +01:00
2019-03-27 01:01:57 +01:00
##
2019-04-16 21:45:43 +02:00
def generate_filename ( self , filename ) :
return os . path . join (
settings . SEMINAR_RESENI_DIR ,
aux_generate_filename ( self , filename )
)
2015-03-24 01:12:20 +01:00
2015-05-11 12:56:39 +02:00
2018-08-20 22:30:16 +02:00
@reversion.register ( ignore_duplicates = True )
2015-03-13 20:08:18 +01:00
@python_2_unicode_compatible
2015-05-11 12:56:39 +02:00
class PrilohaReseni ( SeminarModelBase ) :
2015-03-13 20:08:18 +01:00
2019-03-26 21:14:10 +01:00
class Meta :
db_table = ' seminar_priloha_reseni '
2019-04-16 21:13:36 +02:00
verbose_name = ' Příloha řešení '
verbose_name_plural = ' Přílohy řešení '
2019-04-30 21:19:52 +02:00
ordering = [ ' reseni ' , ' vytvoreno ' ]
2015-03-13 20:08:18 +01:00
2019-03-26 21:14:10 +01:00
# Interní ID
id = models . AutoField ( primary_key = True )
2015-03-13 20:08:18 +01:00
2019-04-16 21:13:36 +02:00
reseni = models . ForeignKey ( Reseni , verbose_name = ' řešení ' , related_name = ' prilohy ' )
2015-03-13 20:08:18 +01:00
2019-04-16 21:13:36 +02:00
vytvoreno = models . DateTimeField ( ' vytvořeno ' , default = timezone . now , blank = True , editable = False )
2015-03-13 20:08:18 +01:00
2019-04-16 21:13:36 +02:00
soubor = models . FileField ( ' soubor ' , upload_to = generate_filename )
2015-03-13 20:08:18 +01:00
2019-04-16 21:13:36 +02:00
poznamka = models . TextField ( ' neveřejná poznámka ' , blank = True ,
help_text = ' Neveřejná poznámka k příloze řešení (plain text), např. o původu ' )
2015-05-14 16:02:00 +02:00
2019-03-26 21:14:10 +01:00
def __str__ ( self ) :
return force_unicode ( self . soubor )
2015-03-13 20:08:18 +01:00
2016-02-16 00:04:26 +01:00
@python_2_unicode_compatible
class Pohadka ( SeminarModelBase ) :
2019-03-26 21:14:10 +01:00
u """ Kus pohádky před/za úlohou v čísle """
2016-02-16 00:04:26 +01:00
2019-03-26 21:14:10 +01:00
class Meta :
db_table = ' seminar_pohadky '
2019-04-16 21:13:36 +02:00
verbose_name = ' Pohádka '
verbose_name_plural = ' Pohádky '
2019-03-26 21:14:10 +01:00
ordering = [ ' uloha__cislo_zadani ' , ' uloha__kod ' , ' -pred ' ]
2016-02-16 00:04:26 +01:00
2019-03-26 21:14:10 +01:00
# Interní ID
id = models . AutoField ( primary_key = True )
2016-02-16 00:04:26 +01:00
2019-04-16 21:13:36 +02:00
text = models . TextField ( ' Text pohádky ' )
2019-03-26 21:14:10 +01:00
uloha = models . ForeignKey (
2019-03-27 01:01:57 +01:00
Uloha ,
2019-04-16 21:13:36 +02:00
verbose_name = ' Úloha ' ,
2019-05-16 23:06:06 +02:00
related_name = ' pohadky ' ,
null = True
2019-03-26 21:14:10 +01:00
)
2016-02-16 00:04:26 +01:00
2019-03-26 21:14:10 +01:00
# Kusů pohádky je v čísle obvykle o 1 více, než úloh. Jeden bude za úlohou
# místo před ní.
2019-04-16 21:13:36 +02:00
pred = models . BooleanField ( ' Před úlohou ' , default = True )
2016-02-16 00:04:26 +01:00
2019-03-26 21:14:10 +01:00
autor = models . ForeignKey (
2019-03-27 01:01:57 +01:00
Organizator ,
2019-03-26 21:14:10 +01:00
verbose_name = " Autor pohádky " ,
2016-02-17 16:13:11 +01:00
2019-03-26 21:14:10 +01:00
# Při nahrávání z TeXu není vyplnění vyžadováno, v adminu je
null = True ,
blank = False
)
2016-02-16 00:04:26 +01:00
2019-03-27 01:01:57 +01:00
vytvoreno = models . DateTimeField (
2019-04-16 21:13:36 +02:00
' Vytvořeno ' ,
2019-03-26 21:14:10 +01:00
default = timezone . now ,
blank = True ,
editable = False
)
2016-02-16 00:04:26 +01:00
2019-03-26 21:14:10 +01:00
def __str__ ( self ) :
2019-03-27 01:01:57 +01:00
uryvek = self . text if len ( self . text ) < 50 else self . text [ : ( 50 - 3 ) ] + " ... "
2019-03-26 21:14:10 +01:00
return force_unicode ( uryvek )
2016-02-16 00:04:26 +01:00
2018-08-20 22:30:16 +02:00
@reversion.register ( ignore_duplicates = True )
2015-05-21 17:43:38 +02:00
@python_2_unicode_compatible
2019-03-27 01:01:57 +01:00
class Soustredeni_Ucastnici ( SeminarModelBase ) :
# zmena dedicnosti z models.Model na SeminarModelBase, potencialni vznik bugu
2015-05-21 17:43:38 +02:00
2019-03-26 21:14:10 +01:00
class Meta :
db_table = ' seminar_soustredeni_ucastnici '
2019-04-16 21:13:36 +02:00
verbose_name = ' Účast na soustředění '
verbose_name_plural = ' Účasti na soustředění '
2019-03-26 21:14:10 +01:00
ordering = [ ' soustredeni ' , ' resitel ' ]
2015-05-21 17:43:38 +02:00
2019-03-26 21:14:10 +01:00
# Interní ID
id = models . AutoField ( primary_key = True )
2015-05-21 17:43:38 +02:00
2019-04-16 21:13:36 +02:00
resitel = models . ForeignKey ( Resitel , verbose_name = ' řešitel ' )
2015-05-21 17:43:38 +02:00
2019-04-16 21:13:36 +02:00
soustredeni = models . ForeignKey ( Soustredeni , verbose_name = ' soustředění ' )
2015-05-21 17:43:38 +02:00
2019-04-16 21:13:36 +02:00
poznamka = models . TextField ( ' neveřejná poznámka ' , blank = True ,
help_text = ' Neveřejná poznámka k účasti (plain text) ' )
2015-05-21 17:43:38 +02:00
2019-03-26 21:14:10 +01:00
def __str__ ( self ) :
2019-04-16 21:13:36 +02:00
return force_unicode ( ' %s na %s ' . format ( self . resitel , self . soustredeni ) )
2019-03-26 21:14:10 +01:00
# NOTE: Poteciální DB HOG bez select_related
2015-05-21 17:43:38 +02:00
2018-08-20 22:30:16 +02:00
@reversion.register ( ignore_duplicates = True )
2015-12-22 15:22:40 +01:00
@python_2_unicode_compatible
2019-03-27 01:01:57 +01:00
class Soustredeni_Organizatori ( SeminarModelBase ) :
# zmena dedicnosti z models.Model na SeminarModelBase, potencialni vznik bugu
2015-12-22 15:22:40 +01:00
2019-03-26 21:14:10 +01:00
class Meta :
db_table = ' seminar_soustredeni_organizatori '
2019-04-16 21:13:36 +02:00
verbose_name = ' Účast organizátorů na soustředění '
verbose_name_plural = ' Účasti organizátorů na soustředění '
2019-03-26 21:14:10 +01:00
ordering = [ ' soustredeni ' , ' organizator ' ]
2015-12-22 15:22:40 +01:00
2019-03-26 21:14:10 +01:00
# Interní ID
id = models . AutoField ( primary_key = True )
2015-12-22 15:22:40 +01:00
2019-04-16 21:13:36 +02:00
organizator = models . ForeignKey ( Organizator , verbose_name = ' organizátor ' )
2015-12-22 15:22:40 +01:00
2019-04-16 21:13:36 +02:00
soustredeni = models . ForeignKey ( Soustredeni , verbose_name = ' soustředění ' )
2015-12-22 15:22:40 +01:00
2019-04-16 21:13:36 +02:00
poznamka = models . TextField ( ' neveřejná poznámka ' , blank = True ,
help_text = ' Neveřejná poznámka k účasti organizátora (plain text) ' )
2015-12-22 15:22:40 +01:00
2019-03-26 21:14:10 +01:00
def __str__ ( self ) :
2019-04-16 21:13:36 +02:00
return force_unicode ( ' %s na %s ' . format ( self . organizator , self . soustredeni ) )
2019-03-26 21:14:10 +01:00
# NOTE: Poteciální DB HOG bez select_related
2015-12-22 15:22:40 +01:00
2015-05-21 17:43:38 +02:00
2016-01-08 13:12:04 +01:00
2018-08-20 22:30:16 +02:00
@reversion.register ( ignore_duplicates = True )
2016-02-27 19:36:13 +01:00
@python_2_unicode_compatible
class Konfera ( models . Model ) :
2019-03-26 21:14:10 +01:00
class Meta :
db_table = ' seminar_konfera '
2019-04-16 21:13:36 +02:00
verbose_name = ' Konfera '
verbose_name_plural = ' Konfery '
2019-03-26 21:14:10 +01:00
# Interní ID
id = models . AutoField ( primary_key = True )
2019-03-27 01:01:57 +01:00
2019-04-16 21:13:36 +02:00
nazev = models . CharField ( ' název konfery ' , max_length = 40 , help_text = ' Název konfery ' )
2019-03-27 01:01:57 +01:00
2019-04-16 21:13:36 +02:00
anotace = models . TextField ( ' anotace ' , blank = True ,
help_text = ' Popis, o čem bude konfera. ' )
2019-03-27 01:01:57 +01:00
2019-04-16 21:13:36 +02:00
abstrakt = models . TextField ( ' abstrakt ' , blank = True ,
help_text = ' Abstrakt konfery tak, jak byl uveden ve sborníku ' )
2019-03-27 01:01:57 +01:00
2019-04-16 21:13:36 +02:00
organizator = models . ForeignKey ( Organizator , verbose_name = ' organizátor ' , related_name = ' konfery ' ,
2019-03-26 21:14:10 +01:00
on_delete = models . SET_NULL , null = True )
2019-03-27 01:01:57 +01:00
2019-04-16 21:13:36 +02:00
ucastnici = models . ManyToManyField ( Resitel , verbose_name = ' účastníci konfery ' ,
help_text = ' Seznam účastníků konfery ' , through = ' Konfery_Ucastnici ' )
2019-03-27 01:01:57 +01:00
2019-04-16 21:13:36 +02:00
soustredeni = models . ForeignKey ( Soustredeni , verbose_name = ' soustředění ' ,
2019-03-27 01:01:57 +01:00
related_name = ' konfery ' , on_delete = models . SET_NULL , null = True )
2019-04-16 21:13:36 +02:00
poznamka = models . TextField ( ' neveřejná poznámka ' , blank = True ,
help_text = ' Neveřejná poznámka ke konfeře(plain text) ' )
2019-05-10 22:30:51 +02:00
# Jedno reseni se vztahuje nejvyse k jedne konfere
reseni = models . OneToOneField ( Reseni , verbose_name = ' článek ke konfeře ' , related_name = ' konfery ' ,
2019-04-16 21:13:36 +02:00
help_text = ' Účastnický přípěvek o konfeře ' , on_delete = models . SET_NULL ,
2019-03-27 01:01:57 +01:00
null = True , blank = True )
2019-03-26 21:14:10 +01:00
TYP_VELETRH = ' veletrh '
TYP_PREZENTACE = ' prezentace '
TYP_CHOICES = [
2019-04-16 21:13:36 +02:00
( TYP_VELETRH , ' Veletrh (postery) ' ) ,
( TYP_PREZENTACE , ' Prezentace (přednáška) ' ) ,
2019-03-26 21:14:10 +01:00
]
2019-04-16 21:13:36 +02:00
typ_prezentace = models . CharField ( ' typ prezentace ' , max_length = 16 , choices = TYP_CHOICES ,
2019-03-27 01:01:57 +01:00
blank = False , default = TYP_VELETRH )
2019-04-16 21:13:36 +02:00
prezentace = models . FileField ( ' prezentace ' , help_text = ' Prezentace nebo fotka posteru ' ,
2019-03-26 21:14:10 +01:00
upload_to = generate_filename_konfera , blank = True )
2019-03-27 01:01:57 +01:00
2019-04-16 21:13:36 +02:00
materialy = models . FileField ( ' materialy ' ,
help_text = ' Další materiály ke konfeře zabalené do jednoho souboru ' ,
2019-03-26 21:14:10 +01:00
upload_to = generate_filename_konfera , blank = True )
def __str__ ( self ) :
2019-03-27 01:01:57 +01:00
return force_unicode ( u " %s : ( %s ) " . format ( self . nazev , self . soustredeni ) )
2016-02-27 19:36:13 +01:00
2019-04-23 23:26:37 +02:00
# Vazebna tabulka. Mozna se generuje automaticky.
@reversion.register ( ignore_duplicates = True )
@python_2_unicode_compatible
class Reseni_Resitele ( models . Model ) :
class Meta :
db_table = ' seminar_reseni_resitele '
verbose_name = ' Řešení řešitelů '
verbose_name_plural = ' Řešení řešitelů '
ordering = [ ' reseni ' , ' resitele ' ]
# Interní ID
id = models . AutoField ( primary_key = True )
resitele = models . ForeignKey ( Resitel , verbose_name = ' řešitel ' )
reseni = models . ForeignKey ( Reseni , verbose_name = ' řešení ' )
def __str__ ( self ) :
return force_unicode ( ' %s od %s ' . format ( self . reseni , self . resitel ) )
# NOTE: Poteciální DB HOG bez select_related
2016-02-27 19:36:13 +01:00
2018-08-20 22:30:16 +02:00
@reversion.register ( ignore_duplicates = True )
2016-02-27 19:36:13 +01:00
@python_2_unicode_compatible
class Konfery_Ucastnici ( models . Model ) :
2019-03-26 21:14:10 +01:00
class Meta :
db_table = ' seminar_konfery_ucastnici '
2019-04-16 21:13:36 +02:00
verbose_name = ' Účast na konfeře '
verbose_name_plural = ' Účasti na konfeře '
2019-03-26 21:14:10 +01:00
ordering = [ ' konfera ' , ' resitel ' ]
2016-02-27 19:36:13 +01:00
2019-03-26 21:14:10 +01:00
# Interní ID
id = models . AutoField ( primary_key = True )
2016-02-27 19:36:13 +01:00
2019-04-16 21:13:36 +02:00
resitel = models . ForeignKey ( Resitel , verbose_name = ' řešitel ' )
2016-02-27 19:36:13 +01:00
2019-04-16 21:13:36 +02:00
konfera = models . ForeignKey ( Konfera , verbose_name = ' konfera ' )
2016-02-27 19:36:13 +01:00
2019-04-16 21:13:36 +02:00
poznamka = models . TextField ( ' neveřejná poznámka ' , blank = True ,
help_text = ' Neveřejná poznámka k účasti (plain text) ' )
2016-02-27 19:36:13 +01:00
2019-03-26 21:14:10 +01:00
def __str__ ( self ) :
2019-04-16 21:13:36 +02:00
return force_unicode ( ' %s na %s ' . format ( self . resitel , self . konfera , ) )
2019-03-26 21:14:10 +01:00
# NOTE: Poteciální DB HOG bez select_related
2016-01-08 13:01:03 +01:00
2019-03-27 01:01:57 +01:00
class Obrazek ( SeminarModelBase ) :
2019-03-26 21:14:10 +01:00
class Meta :
2019-03-27 01:01:57 +01:00
db_table = ' seminar_obrazky '
2019-04-16 21:13:36 +02:00
verbose_name = ' obrázek '
verbose_name_plural = ' obrázky '
2015-07-26 15:21:44 +02:00
2019-03-27 01:01:57 +01:00
# Interní ID
id = models . AutoField ( primary_key = True )
2015-03-24 01:12:20 +01:00
2019-04-16 21:13:36 +02:00
na_web = models . ImageField ( ' obrázek na web ' , upload_to = ' obrazky/ % Y/ % m/ %d / ' ,
2019-03-27 01:01:57 +01:00
null = True , blank = True )
2015-03-24 01:12:20 +01:00
2019-04-16 21:30:56 +02:00
text = models . ForeignKey ( Text , verbose_name = ' text ' ,
2019-04-30 23:37:11 +02:00
help_text = ' text, ve kterém se obrázek vyskytuje ' , null = False , blank = False )
2015-03-24 01:12:20 +01:00
2019-04-16 21:13:36 +02:00
do_cisla_barevny = models . FileField ( ' barevný obrázek do čísla ' ,
help_text = ' Barevná verze obrázku do čísla ' ,
2019-03-27 01:01:57 +01:00
upload_to = ' obrazky/ % Y/ % m/ %d / ' , blank = True , null = True )
2015-03-24 01:12:20 +01:00
2019-04-16 21:13:36 +02:00
do_cisla_cernobily = models . FileField ( ' černobílý obrázek do čísla ' ,
help_text = ' Černobílá verze obrázku do čísla ' ,
2019-03-27 01:01:57 +01:00
upload_to = ' obrazky/ % Y/ % m/ %d / ' , blank = True , null = True )
2015-03-24 01:12:20 +01:00
2019-04-23 21:32:39 +02:00
class TreeNode ( models . Model ) :
class Meta :
abstract = True
root = models . ForeignKey ( ' self ' ,
2019-05-01 00:46:59 +02:00
related_name = " potomci_set " ,
2019-04-23 21:32:39 +02:00
null = True ,
blank = False ,
on_delete = models . SET_NULL , # Vrcholy s null kořenem jsou sirotci bez ročníku
2019-04-23 22:25:18 +02:00
verbose_name = " kořen stromu " )
2019-04-23 21:32:39 +02:00
first_child = models . ForeignKey ( ' self ' ,
null = True ,
blank = True ,
on_delete = models . SET_NULL ,
verbose_name = " první potomek " )
2019-05-10 22:30:51 +02:00
succ = models . OneToOneField ( ' self ' ,
2019-05-01 00:46:59 +02:00
related_name = " prev " ,
2019-04-23 21:32:39 +02:00
null = True ,
blank = True ,
on_delete = models . SET_NULL ,
verbose_name = " další element na stejné úrovni " )
class RocnikNode ( TreeNode ) :
class Meta :
db_table = ' seminar_nodes_rocnik '
verbose_name = ' Ročník (Node) '
verbose_name_plural = ' Ročníky (Node) '
2019-05-10 22:30:51 +02:00
rocnik = models . OneToOneField ( Rocnik ,
2019-04-23 21:32:39 +02:00
on_delete = models . PROTECT , # Pokud chci mazat ročník, musím si Node pořešit ručně
verbose_name = " ročník " )
class CisloNode ( TreeNode ) :
class Meta :
db_table = ' seminar_nodes_cislo '
verbose_name = ' Číslo (Node) '
verbose_name_plural = ' Čísla (Node) '
2019-05-10 22:30:51 +02:00
cislo = models . OneToOneField ( Cislo ,
2019-04-23 21:32:39 +02:00
on_delete = models . PROTECT , # Pokud chci mazat číslo, musím si Node pořešit ručně
verbose_name = " číslo " )
class MezicisloNode ( TreeNode ) :
class Meta :
db_table = ' seminar_nodes_mezicislo '
verbose_name = ' Mezičíslo (Node) '
verbose_name_plural = ' Mezičísla (Node) '
class TemaVCisleNode ( TreeNode ) :
""" Obsahuje příspěvky k tématu v daném čísle """
class Meta :
db_table = ' seminar_nodes_temavcisle '
verbose_name = ' Téma v čísle (Node) '
verbose_name_plural = ' Témata v čísle (Node) '
tema = models . ForeignKey ( Tema ,
on_delete = models . PROTECT , # Pokud chci mazat téma, musím si Node pořešit ručně
verbose_name = " téma v čísle " )
class KonferaNode ( TreeNode ) :
class Meta :
db_table = ' seminar_nodes_konfera '
verbose_name = ' Konfera (Node) '
verbose_name_plural = ' Konfery (Node) '
class ClanekNode ( TreeNode ) :
class Meta :
db_table = ' seminar_nodes_clanek '
verbose_name = ' Článek (Node) '
verbose_name_plural = ' Články (Node) '
class UlohaNode ( TreeNode ) :
class Meta :
db_table = ' seminar_nodes_uloha '
verbose_name = ' Úloha (Node) '
verbose_name_plural = ' Úlohy (Node) '
class TextNode ( TreeNode ) :
class Meta :
db_table = ' seminar_nodes_obsah '
verbose_name = ' Text (Node) '
verbose_name_plural = ' Text (Node) '
text = models . ForeignKey ( Text ,
on_delete = models . PROTECT ,
verbose_name = ' text ' )
2015-07-26 15:21:44 +02:00
2019-03-27 01:01:57 +01:00
## FIXME: Logiku přesunout do views.
#@python_2_unicode_compatible
#class VysledkyBase(SeminarModelBase):
#
# class Meta:
2019-04-16 21:13:36 +02:00
# verbose_name = 'Řádek výsledkovky'
# verbose_name_plural = 'Řádky výsledkovky'
2019-03-27 01:01:57 +01:00
# ordering = ['body']
# abstract = True
# managed = False
#
2019-04-16 21:13:36 +02:00
# dummy_id = models.CharField('dummy ID pro view', max_length=32, primary_key=True,
2019-03-27 01:01:57 +01:00
# db_column='id')
#
2019-04-16 21:13:36 +02:00
# cislo = models.ForeignKey(Cislo, verbose_name='číslo pro body', db_column='cislo_id',
2019-03-27 01:01:57 +01:00
# on_delete=models.DO_NOTHING)
#
2019-04-16 21:13:36 +02:00
# resitel = models.ForeignKey(Resitel, verbose_name='řešitel', db_column='resitel_id',
2019-03-27 01:01:57 +01:00
# on_delete=models.DO_NOTHING)
#
2019-03-26 21:14:10 +01:00
# body = models.DecimalField(max_digits=8, decimal_places=1, db_column='body',
2019-04-16 21:13:36 +02:00
# verbose_name='body za číslo')
2019-03-27 01:01:57 +01:00
#
# def __str__(self):
# return force_unicode(u"%s: %sb (%s)".format(self.resitel.plne_jmeno(), self.body,
# str(self.cislo)))
# # NOTE: DB zatez pri vypisu (ale nepouzivany)
2015-08-13 10:52:43 +02:00
2019-03-27 01:01:57 +01:00
## FIXME: Logiku přesunout do views.
#class VysledkyZaCislo(VysledkyBase):
#
# class Meta:
# db_table = 'seminar_body_za_cislo'
# abstract = False
# managed = False
#
#
## FIXME: Logiku přesunout do views.
#class VysledkyKCisluZaRocnik(VysledkyBase):
#
# class Meta:
# db_table = 'seminar_body_k_cislu_rocnik'
# abstract = False
# managed = False
#
## body = models.DecimalField(max_digits=8, decimal_places=1, db_column='body',
2019-04-16 21:13:36 +02:00
## verbose_name='body do čísla (za ročník)')
2019-03-27 01:01:57 +01:00
#
#
## FIXME: Logiku přesunout do views.
#class VysledkyKCisluOdjakziva(VysledkyBase):
#
# class Meta:
# db_table = 'seminar_body_k_cislu_odjakziva'
# abstract = False
# managed = False
#
## body = models.DecimalField(max_digits=8, decimal_places=1, db_column='body',
2019-04-16 21:13:36 +02:00
## verbose_name='body do čísla (i minulé ročníky)')
2019-03-27 01:01:57 +01:00
#
#
## FIXME: Logiku přesunout do views.
#@python_2_unicode_compatible
#class VysledkyCelkemKCislu(VysledkyBase):
#
# class Meta:
# db_table = 'seminar_body_celkem_k_cislu'
# abstract = False
# managed = False
#
# body_celkem = models.DecimalField(max_digits=8, decimal_places=1, db_column='body_celkem',
2019-04-16 21:13:36 +02:00
# verbose_name='body celkem do čísla včetně minulých ročníků')
2019-03-27 01:01:57 +01:00
#
# def __str__(self):
# # NOTE: DB HOG (ale nepouzivany)
# return force_unicode(u"%s: %sb / %sb (do %s)" % (self.resitel.plne_jmeno(), self.body, self.body_celkem, str(self.cislo)))
##mozna potreba upravit
2015-08-13 10:52:43 +02:00
2018-08-20 22:30:16 +02:00
@reversion.register ( ignore_duplicates = True )
2015-03-14 15:41:29 +01:00
@python_2_unicode_compatible
class Nastaveni ( SingletonModel ) :
2019-03-26 21:14:10 +01:00
class Meta :
db_table = ' seminar_nastaveni '
2019-04-16 21:13:36 +02:00
verbose_name = ' Nastavení semináře '
2015-03-14 15:41:29 +01:00
2019-04-16 21:13:36 +02:00
aktualni_rocnik = models . ForeignKey ( Rocnik , verbose_name = ' aktuální ročník ' , null = False )
2015-03-14 15:41:29 +01:00
2019-04-16 21:13:36 +02:00
aktualni_cislo = models . ForeignKey ( Cislo , verbose_name = ' poslední vydané číslo ' ,
2019-03-27 01:01:57 +01:00
null = False )
2015-03-14 15:41:29 +01:00
2019-03-26 21:14:10 +01:00
def __str__ ( self ) :
2019-04-16 21:13:36 +02:00
return ' Nastavení semináře '
2015-03-14 15:41:29 +01:00
2019-03-26 21:14:10 +01:00
def admin_url ( self ) :
return reverse ( ' admin:seminar_nastaveni_change ' , args = ( self . id , ) )
def verejne ( self ) :
return False
2015-06-23 10:50:58 +02:00
2018-08-20 22:30:16 +02:00
@reversion.register ( ignore_duplicates = True )
2015-06-23 10:50:58 +02:00
@python_2_unicode_compatible
class Novinky ( models . Model ) :
2019-03-26 21:14:10 +01:00
datum = models . DateField ( auto_now_add = True )
2019-03-27 01:01:57 +01:00
2019-03-26 21:14:10 +01:00
text = models . TextField ( ' Text novinky ' , blank = True , null = True )
2019-03-27 01:01:57 +01:00
2019-03-26 21:14:10 +01:00
obrazek = models . ImageField ( ' Obrázek ' , upload_to = ' image_novinky/ % Y/ % m/ %d / ' ,
null = True , blank = True )
2019-03-27 01:01:57 +01:00
2019-03-26 21:14:10 +01:00
obrazek_maly = ImageSpecField ( source = ' obrazek ' ,
processors = [
ResizeToFit ( 350 , 200 , upscale = False )
] ,
options = { ' quality ' : 95 } )
2019-05-16 23:06:06 +02:00
autor = models . ForeignKey ( Organizator , verbose_name = ' Autor novinky ' , null = True )
2019-03-27 01:01:57 +01:00
2019-03-26 21:14:10 +01:00
zverejneno = models . BooleanField ( ' Zveřejněno ' , default = " False " )
def __str__ ( self ) :
return ' [ ' + str ( self . datum ) + ' ] ' + self . text [ 0 : 50 ]
class Meta :
verbose_name = ' Novinka '
verbose_name_plural = ' Novinky '
2019-03-27 01:01:57 +01:00
ordering = [ ' -datum ' ]
2015-06-25 10:48:06 +02:00