diff --git a/api/tests/test_skola_autocomplete.py b/api/tests/test_skola_autocomplete.py index 9fc4aee6..36df97e8 100644 --- a/api/tests/test_skola_autocomplete.py +++ b/api/tests/test_skola_autocomplete.py @@ -1,9 +1,10 @@ -from django.test import TestCase +from django.test import TestCase, tag from django.urls import reverse import seminar.models as m import seminar.views as v from seminar.utils import sync_skoly +@tag('stejny-model-na-produkci') class OrgSkolyAutocompleteTestCase(TestCase): @classmethod def setUpClass(cls): diff --git a/deploy_v2/admin_org_prava.json b/deploy_v2/admin_org_prava.json index 3ef169a5..9caa6eb2 100644 --- a/deploy_v2/admin_org_prava.json +++ b/deploy_v2/admin_org_prava.json @@ -271,62 +271,62 @@ }, { "codename": "add_konfera", - "ct_app_label": "seminar", + "ct_app_label": "soustredeni", "ct_model": "konfera" }, { "codename": "change_konfera", - "ct_app_label": "seminar", + "ct_app_label": "soustredeni", "ct_model": "konfera" }, { "codename": "delete_konfera", - "ct_app_label": "seminar", + "ct_app_label": "soustredeni", "ct_model": "konfera" }, { "codename": "view_konfera", - "ct_app_label": "seminar", + "ct_app_label": "soustredeni", "ct_model": "konfera" }, { "codename": "add_konfery_ucastnici", - "ct_app_label": "seminar", + "ct_app_label": "soustredeni", "ct_model": "konfery_ucastnici" }, { "codename": "change_konfery_ucastnici", - "ct_app_label": "seminar", + "ct_app_label": "soustredeni", "ct_model": "konfery_ucastnici" }, { "codename": "delete_konfery_ucastnici", - "ct_app_label": "seminar", + "ct_app_label": "soustredeni", "ct_model": "konfery_ucastnici" }, { "codename": "view_konfery_ucastnici", - "ct_app_label": "seminar", + "ct_app_label": "soustredeni", "ct_model": "konfery_ucastnici" }, { "codename": "add_nastaveni", - "ct_app_label": "seminar", + "ct_app_label": "various", "ct_model": "nastaveni" }, { "codename": "change_nastaveni", - "ct_app_label": "seminar", + "ct_app_label": "various", "ct_model": "nastaveni" }, { "codename": "delete_nastaveni", - "ct_app_label": "seminar", + "ct_app_label": "various", "ct_model": "nastaveni" }, { "codename": "view_nastaveni", - "ct_app_label": "seminar", + "ct_app_label": "various", "ct_model": "nastaveni" }, { @@ -351,22 +351,22 @@ }, { "codename": "change_organizator", - "ct_app_label": "seminar", + "ct_app_label": "personalni", "ct_model": "organizator" }, { "codename": "view_organizator", - "ct_app_label": "seminar", + "ct_app_label": "personalni", "ct_model": "organizator" }, { "codename": "change_osoba", - "ct_app_label": "seminar", + "ct_app_label": "personalni", "ct_model": "osoba" }, { "codename": "view_osoba", - "ct_app_label": "seminar", + "ct_app_label": "personalni", "ct_model": "osoba" }, { @@ -391,22 +391,22 @@ }, { "codename": "add_prijemce", - "ct_app_label": "seminar", + "ct_app_label": "personalni", "ct_model": "prijemce" }, { "codename": "change_prijemce", - "ct_app_label": "seminar", + "ct_app_label": "personalni", "ct_model": "prijemce" }, { "codename": "delete_prijemce", - "ct_app_label": "seminar", + "ct_app_label": "personalni", "ct_model": "prijemce" }, { "codename": "view_prijemce", - "ct_app_label": "seminar", + "ct_app_label": "personalni", "ct_model": "prijemce" }, { @@ -431,12 +431,12 @@ }, { "codename": "change_resitel", - "ct_app_label": "seminar", + "ct_app_label": "personalni", "ct_model": "resitel" }, { "codename": "view_resitel", - "ct_app_label": "seminar", + "ct_app_label": "personalni", "ct_model": "resitel" }, { @@ -461,82 +461,82 @@ }, { "codename": "add_skola", - "ct_app_label": "seminar", + "ct_app_label": "personalni", "ct_model": "skola" }, { "codename": "change_skola", - "ct_app_label": "seminar", + "ct_app_label": "personalni", "ct_model": "skola" }, { "codename": "delete_skola", - "ct_app_label": "seminar", + "ct_app_label": "personalni", "ct_model": "skola" }, { "codename": "view_skola", - "ct_app_label": "seminar", + "ct_app_label": "personalni", "ct_model": "skola" }, { "codename": "add_soustredeni", - "ct_app_label": "seminar", + "ct_app_label": "soustredeni", "ct_model": "soustredeni" }, { "codename": "change_soustredeni", - "ct_app_label": "seminar", + "ct_app_label": "soustredeni", "ct_model": "soustredeni" }, { "codename": "delete_soustredeni", - "ct_app_label": "seminar", + "ct_app_label": "soustredeni", "ct_model": "soustredeni" }, { "codename": "view_soustredeni", - "ct_app_label": "seminar", + "ct_app_label": "soustredeni", "ct_model": "soustredeni" }, { "codename": "add_soustredeni_organizatori", - "ct_app_label": "seminar", + "ct_app_label": "soustredeni", "ct_model": "soustredeni_organizatori" }, { "codename": "change_soustredeni_organizatori", - "ct_app_label": "seminar", + "ct_app_label": "soustredeni", "ct_model": "soustredeni_organizatori" }, { "codename": "delete_soustredeni_organizatori", - "ct_app_label": "seminar", + "ct_app_label": "soustredeni", "ct_model": "soustredeni_organizatori" }, { "codename": "view_soustredeni_organizatori", - "ct_app_label": "seminar", + "ct_app_label": "soustredeni", "ct_model": "soustredeni_organizatori" }, { "codename": "add_soustredeni_ucastnici", - "ct_app_label": "seminar", + "ct_app_label": "soustredeni", "ct_model": "soustredeni_ucastnici" }, { "codename": "change_soustredeni_ucastnici", - "ct_app_label": "seminar", + "ct_app_label": "soustredeni", "ct_model": "soustredeni_ucastnici" }, { "codename": "delete_soustredeni_ucastnici", - "ct_app_label": "seminar", + "ct_app_label": "soustredeni", "ct_model": "soustredeni_ucastnici" }, { "codename": "view_soustredeni_ucastnici", - "ct_app_label": "seminar", + "ct_app_label": "soustredeni", "ct_model": "soustredeni_ucastnici" }, { @@ -619,4 +619,4 @@ "ct_app_label": "taggit", "ct_model": "taggeditem" } -] \ No newline at end of file +] diff --git a/galerie/migrations/0011_pre_split_soustredeni.py b/galerie/migrations/0011_pre_split_soustredeni.py new file mode 100644 index 00000000..a038ca44 --- /dev/null +++ b/galerie/migrations/0011_pre_split_soustredeni.py @@ -0,0 +1,13 @@ +# Generated by Django 4.2.11 on 2024-04-30 21:53 + +from django.db import migrations + + +class Migration(migrations.Migration): + + dependencies = [ + ('galerie', '0010_auto_20200819_0947'), + ] + + operations = [ + ] diff --git a/galerie/migrations/0012_soustredeni_relink.py b/galerie/migrations/0012_soustredeni_relink.py new file mode 100644 index 00000000..0b8cbaff --- /dev/null +++ b/galerie/migrations/0012_soustredeni_relink.py @@ -0,0 +1,20 @@ +# Generated by Django 4.2.11 on 2024-05-01 13:07 + +from django.db import migrations, models +import django.db.models.deletion + + +class Migration(migrations.Migration): + + dependencies = [ + ('soustredeni', '0001_split_from_seminar'), + ('galerie', '0011_pre_split_soustredeni'), + ] + + operations = [ + migrations.AlterField( + model_name='galerie', + name='soustredeni', + field=models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.PROTECT, to='soustredeni.soustredeni'), + ), + ] diff --git a/galerie/migrations/0013_post_split_soustredeni.py b/galerie/migrations/0013_post_split_soustredeni.py new file mode 100644 index 00000000..de3cfa60 --- /dev/null +++ b/galerie/migrations/0013_post_split_soustredeni.py @@ -0,0 +1,14 @@ +# Generated by Django 4.2.11 on 2024-05-01 13:35 + +from django.db import migrations + + +class Migration(migrations.Migration): + + dependencies = [ + ('galerie', '0012_soustredeni_relink'), + ('soustredeni', '0003_post_split_soustredeni'), + ] + + operations = [ + ] diff --git a/galerie/models.py b/galerie/models.py index 78551969..96225101 100644 --- a/galerie/models.py +++ b/galerie/models.py @@ -7,7 +7,7 @@ from imagekit.processors import ResizeToFit, Transpose import os -from seminar.models import Soustredeni +from soustredeni.models import Soustredeni VZDY=0 ORG=1 diff --git a/korektury/migrations/0021_auto_20240312_2124.py b/korektury/migrations/0021_auto_20240312_2124.py new file mode 100644 index 00000000..ee2eb53d --- /dev/null +++ b/korektury/migrations/0021_auto_20240312_2124.py @@ -0,0 +1,13 @@ +# Generated by Django 4.2.8 on 2024-03-12 20:24 + +from django.db import migrations + + +class Migration(migrations.Migration): + + dependencies = [ + ('korektury', '0020_lepsi_popis_nazvu_PDF_v_adminu'), + ] + + operations = [ + ] diff --git a/korektury/migrations/0022_alter_komentar_autor_alter_korekturovanepdf_org_and_more.py b/korektury/migrations/0022_alter_komentar_autor_alter_korekturovanepdf_org_and_more.py new file mode 100644 index 00000000..4e063a89 --- /dev/null +++ b/korektury/migrations/0022_alter_komentar_autor_alter_korekturovanepdf_org_and_more.py @@ -0,0 +1,30 @@ +# Generated by Django 4.2.11 on 2024-03-19 21:35 + +from django.db import migrations, models +import django.db.models.deletion + + +class Migration(migrations.Migration): + + dependencies = [ + ('personalni', '0003_initial'), + ('korektury', '0021_auto_20240312_2124'), + ] + + operations = [ + migrations.AlterField( + model_name='komentar', + name='autor', + field=models.ForeignKey(blank=True, help_text='Autor komentáře', null=True, on_delete=django.db.models.deletion.SET_NULL, to='personalni.organizator'), + ), + migrations.AlterField( + model_name='korekturovanepdf', + name='org', + field=models.ForeignKey(blank=True, default=None, help_text='Zodpovědný organizátor za obsah', null=True, on_delete=django.db.models.deletion.SET_NULL, to='personalni.organizator'), + ), + migrations.AlterField( + model_name='oprava', + name='autor', + field=models.ForeignKey(blank=True, help_text='Autor opravy', null=True, on_delete=django.db.models.deletion.SET_NULL, to='personalni.organizator'), + ), + ] diff --git a/korektury/migrations/0023_personalni_post_migrate.py b/korektury/migrations/0023_personalni_post_migrate.py new file mode 100644 index 00000000..048ece7a --- /dev/null +++ b/korektury/migrations/0023_personalni_post_migrate.py @@ -0,0 +1,14 @@ +# Generated by Django 4.2.11 on 2024-03-26 21:25 + +from django.db import migrations + + +class Migration(migrations.Migration): + + dependencies = [ + ('korektury', '0022_alter_komentar_autor_alter_korekturovanepdf_org_and_more'), + ('personalni', '0005_personalni_post_migrate'), + ] + + operations = [ + ] diff --git a/korektury/models.py b/korektury/models.py index c9d47dfa..ca1bb877 100644 --- a/korektury/models.py +++ b/korektury/models.py @@ -20,7 +20,7 @@ from django.core.exceptions import ObjectDoesNotExist from django.utils.functional import cached_property from django.utils.text import get_valid_filename -from seminar.models import Organizator +from personalni.models import Organizator import subprocess from reversion import revisions as reversion diff --git a/personalni/migrations/0002_auto_20240312_2118.py b/personalni/migrations/0002_auto_20240312_2118.py new file mode 100644 index 00000000..62a0b0d2 --- /dev/null +++ b/personalni/migrations/0002_auto_20240312_2118.py @@ -0,0 +1,13 @@ +# Generated by Django 4.2.8 on 2024-03-12 20:18 + +from django.db import migrations + + +class Migration(migrations.Migration): + + dependencies = [ + ('personalni', '0001_skupiny'), + ] + + operations = [ + ] diff --git a/personalni/migrations/0003_initial.py b/personalni/migrations/0003_initial.py new file mode 100644 index 00000000..4103295e --- /dev/null +++ b/personalni/migrations/0003_initial.py @@ -0,0 +1,146 @@ +# Generated by Django 4.2.8 on 2024-03-12 21:10 + +from django.db import migrations, models +import django.utils.timezone +import django_countries.fields +import imagekit.models.fields + +from django.conf import settings +import django.db.models.deletion + +def nastav_nove_contenttypes(apps, schema_editor): + ContentType = apps.get_model('contenttypes', 'ContentType') + for m in ('resitel', 'organizator', 'osoba', 'skola', 'prijemce'): + oct = ContentType.objects.filter(app_label='seminar', model=m) + oct.update(app_label='personalni') + +def nastav_stare_contenttypes(apps, schema_editor): + ContentType = apps.get_model('contenttypes', 'ContentType') + for m in ('resitel', 'organizator', 'osoba', 'skola', 'prijemce'): + nct = ContentType.objects.filter(app_label='personalni', model=m) + nct.update(app_label='seminar') + +class Migration(migrations.Migration): + + initial = True + + dependencies = [ + ('personalni', '0002_auto_20240312_2118'), + ('seminar', '0118_alter_organizator_options_alter_osoba_options_and_more'), + ] + + operations = [ + migrations.RunPython(nastav_nove_contenttypes, nastav_stare_contenttypes), + migrations.CreateModel( + name='Organizator', + fields=[ + ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')), + ('vytvoreno', models.DateTimeField(blank=True, default=django.utils.timezone.now, editable=False, verbose_name='Vytvořeno')), + ('organizuje_od', models.DateTimeField(blank=True, null=True, verbose_name='Organizuje od')), + ('organizuje_do', models.DateTimeField(blank=True, null=True, verbose_name='Organizuje do')), + ('studuje', models.CharField(blank=True, help_text="Např. 'Studuje Obecnou fyziku (Bc.), 3. ročník', 'Vystudovala Diskrétní modely a algoritmy (Mgr.)' nebo 'Přednáší na MFF'", max_length=256, null=True, verbose_name='Studium aj.')), + ('strucny_popis_organizatora', models.TextField(blank=True, null=True, verbose_name='Stručný popis organizátora')), + ('skola', models.CharField(blank=True, help_text='Škola, např. MFF, VŠCHT, VUT, ... prostě aby se nemuselo psát do studuješkolu, ale jen obor, možnost zobrazit zvlášť', max_length=256, null=True, verbose_name='Škola, kterou studuje')), + ('osoba', models.OneToOneField(help_text='osobní údaje organizátora', on_delete=django.db.models.deletion.PROTECT, related_name='org', to='personalni.osoba', verbose_name='osoba')), + ], + options={ + 'verbose_name': 'Organizátor', + 'verbose_name_plural': 'Organizátoři', + 'db_table': 'seminar_organizator', + 'ordering': ['-organizuje_do', 'osoba__jmeno', 'osoba__prijmeni'], + 'managed': False, + }, + ), + migrations.CreateModel( + name='Osoba', + fields=[ + ('id', models.AutoField(primary_key=True, serialize=False)), + ('jmeno', models.CharField(max_length=256, verbose_name='jméno')), + ('prijmeni', models.CharField(max_length=256, verbose_name='příjmení')), + ('prezdivka', models.CharField(blank=True, max_length=256, null=True, verbose_name='přezdívka')), + ('pohlavi_muz', models.BooleanField(default=False, verbose_name='pohlaví (muž)')), + ('email', models.EmailField(blank=True, default='', max_length=256, verbose_name='e-mail')), + ('telefon', models.CharField(blank=True, default='', max_length=256, verbose_name='telefon')), + ('datum_narozeni', models.DateField(blank=True, null=True, verbose_name='datum narození')), + ('datum_souhlasu_udaje', models.DateField(blank=True, help_text='Datum souhlasu se zpracováním osobních údajů', null=True, verbose_name='datum souhlasu (údaje)')), + ('datum_souhlasu_zasilani', models.DateField(blank=True, help_text='Datum souhlasu se zasíláním MFF materiálů', null=True, verbose_name='datum souhlasu (spam)')), + ('datum_registrace', models.DateField(default=django.utils.timezone.now, verbose_name='datum registrace do semináře')), + ('ulice', models.CharField(blank=True, default='', max_length=256, verbose_name='ulice')), + ('mesto', models.CharField(blank=True, default='', max_length=256, verbose_name='město')), + ('psc', models.CharField(blank=True, default='', max_length=32, verbose_name='PSČ')), + ('stat', django_countries.fields.CountryField(default='CZ', help_text='ISO 3166-1 kód země velkými písmeny (CZ, SK, ...)', max_length=2, verbose_name='stát')), + ('jak_se_dozvedeli', models.TextField(blank=True, verbose_name='Jak se dozvěděli')), + ('poznamka', models.TextField(blank=True, help_text='Neveřejná poznámka k osobě (plain text)', verbose_name='neveřejná poznámka')), + ('foto', imagekit.models.fields.ProcessedImageField(blank=True, help_text='Vlož fotografii osoby o libovolné velikosti', null=True, upload_to='image_osoby/velke/%Y/', verbose_name='Fotografie osoby')), + ('user', models.OneToOneField(blank=True, null=True, on_delete=django.db.models.deletion.DO_NOTHING, to=settings.AUTH_USER_MODEL, verbose_name='uživatel')), + ], + options={ + 'verbose_name': 'Osoba', + 'verbose_name_plural': 'Osoby', + 'db_table': 'seminar_osoby', + 'ordering': ['prijmeni', 'jmeno'], + 'managed': False, + }, + ), + migrations.CreateModel( + name='Prijemce', + fields=[ + ('id', models.AutoField(primary_key=True, serialize=False)), + ('poznamka', models.TextField(blank=True, help_text='Neveřejná poznámka k příemci čísel (plain text)', verbose_name='neveřejná poznámka')), + ('zasilat_cislo_emailem', models.BooleanField(default=False, help_text='True pokud chce příjemce dostávat číslo emailem', verbose_name='zasílat číslo emailem')), + ('osoba', models.OneToOneField(help_text='Které osobě či na jakou adresu se mají zasílat čísla', on_delete=django.db.models.deletion.CASCADE, to='personalni.osoba', verbose_name='komu')), + ], + options={ + 'verbose_name': 'příjemce', + 'verbose_name_plural': 'příjemce', + 'db_table': 'seminar_prijemce', + 'managed': False, + }, + ), + migrations.CreateModel( + name='Resitel', + fields=[ + ('id', models.AutoField(primary_key=True, serialize=False)), + ('prezdivka_resitele', models.CharField(blank=True, max_length=256, null=True, unique=True, verbose_name='přezdívka řešitele')), + ('rok_maturity', models.IntegerField(blank=True, null=True, verbose_name='rok maturity')), + ('zasilat', models.CharField(choices=[('domu', 'Domů'), ('do_skoly', 'Do školy'), ('nikam', 'Nezasílat papírově')], default='domu', max_length=32, verbose_name='kam zasílat')), + ('zasilat_cislo_emailem', models.BooleanField(default=False, help_text='True pokud chce řešitel dostávat číslo emailem', verbose_name='zasílat číslo emailem')), + ('zasilat_cislo_papirove', models.BooleanField(default=True, help_text='True pokud chce řešitel dostávat číslo papírově', verbose_name='zasílat číslo papírově')), + ('poznamka', models.TextField(blank=True, help_text='Neveřejná poznámka k řešiteli (plain text)', verbose_name='neveřejná poznámka')), + ('osoba', models.OneToOneField(on_delete=django.db.models.deletion.PROTECT, to='personalni.osoba', verbose_name='osoba')), + ('skola', models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.SET_NULL, to='personalni.skola', verbose_name='škola')), + ], + options={ + 'verbose_name': 'Řešitel', + 'verbose_name_plural': 'Řešitelé', + 'db_table': 'seminar_resitele', + 'ordering': ['osoba'], + 'managed': False, + }, + ), + migrations.CreateModel( + name='Skola', + fields=[ + ('id', models.AutoField(primary_key=True, serialize=False)), + ('aesop_id', models.CharField(blank=True, default='', help_text='Aesopi ID typu "izo:..." nebo "aesop:..."', max_length=32, verbose_name='Aesop ID')), + ('izo', models.CharField(blank=True, help_text='IZO školy (jen české školy)', max_length=32, verbose_name='IZO')), + ('nazev', models.CharField(help_text='Celý název školy', max_length=256, verbose_name='název')), + ('kratky_nazev', models.CharField(blank=True, help_text='Zkrácený název pro zobrazení ve výsledkovce', max_length=256, verbose_name='zkrácený název')), + ('ulice', models.CharField(max_length=256, verbose_name='ulice')), + ('mesto', models.CharField(max_length=256, verbose_name='město')), + ('psc', models.CharField(max_length=32, verbose_name='PSČ')), + ('stat', django_countries.fields.CountryField(default='CZ', help_text='ISO 3166-1 kód země velkými písmeny (CZ, SK, ...)', max_length=2, verbose_name='stát')), + ('je_zs', models.BooleanField(default=True, verbose_name='základní stupeň')), + ('je_ss', models.BooleanField(default=True, verbose_name='střední stupeň')), + ('poznamka', models.TextField(blank=True, help_text='Neveřejná poznámka ke škole (plain text)', verbose_name='neveřejná poznámka')), + ('kontaktni_osoba', models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.SET_NULL, to='personalni.osoba', verbose_name='Kontaktní osoba')), + ], + options={ + 'verbose_name': 'Škola', + 'verbose_name_plural': 'Školy', + 'db_table': 'seminar_skoly', + 'ordering': ['mesto', 'nazev'], + 'managed': False, + }, + ), + ] diff --git a/personalni/migrations/0004_alter_organizator_options_alter_osoba_options_and_more.py b/personalni/migrations/0004_alter_organizator_options_alter_osoba_options_and_more.py new file mode 100644 index 00000000..6065e58f --- /dev/null +++ b/personalni/migrations/0004_alter_organizator_options_alter_osoba_options_and_more.py @@ -0,0 +1,34 @@ +# Generated by Django 4.2.11 on 2024-03-26 21:11 + +from django.db import migrations + + +class Migration(migrations.Migration): + + dependencies = [ + ('personalni', '0003_initial'), + ('seminar', '0120_remove_osoba_user_remove_prijemce_osoba_and_more'), + ] + + operations = [ + migrations.AlterModelOptions( + name='organizator', + options={'ordering': ['-organizuje_do', 'osoba__jmeno', 'osoba__prijmeni'], 'verbose_name': 'Organizátor', 'verbose_name_plural': 'Organizátoři'}, + ), + migrations.AlterModelOptions( + name='osoba', + options={'ordering': ['prijmeni', 'jmeno'], 'verbose_name': 'Osoba', 'verbose_name_plural': 'Osoby'}, + ), + migrations.AlterModelOptions( + name='prijemce', + options={'verbose_name': 'příjemce', 'verbose_name_plural': 'příjemce'}, + ), + migrations.AlterModelOptions( + name='resitel', + options={'ordering': ['osoba'], 'verbose_name': 'Řešitel', 'verbose_name_plural': 'Řešitelé'}, + ), + migrations.AlterModelOptions( + name='skola', + options={'ordering': ['mesto', 'nazev'], 'verbose_name': 'Škola', 'verbose_name_plural': 'Školy'}, + ), + ] diff --git a/personalni/migrations/0005_personalni_post_migrate.py b/personalni/migrations/0005_personalni_post_migrate.py new file mode 100644 index 00000000..72d1571a --- /dev/null +++ b/personalni/migrations/0005_personalni_post_migrate.py @@ -0,0 +1,13 @@ +# Generated by Django 4.2.11 on 2024-03-26 21:25 + +from django.db import migrations + + +class Migration(migrations.Migration): + + dependencies = [ + ('personalni', '0004_alter_organizator_options_alter_osoba_options_and_more'), + ] + + operations = [ + ] diff --git a/personalni/migrations/0006_pre_split_soustredeni.py b/personalni/migrations/0006_pre_split_soustredeni.py new file mode 100644 index 00000000..ce2b4de1 --- /dev/null +++ b/personalni/migrations/0006_pre_split_soustredeni.py @@ -0,0 +1,13 @@ +# Generated by Django 4.2.11 on 2024-04-30 21:53 + +from django.db import migrations + + +class Migration(migrations.Migration): + + dependencies = [ + ('personalni', '0005_personalni_post_migrate'), + ] + + operations = [ + ] diff --git a/seminar/models/personalni.py b/personalni/models.py similarity index 98% rename from seminar/models/personalni.py rename to personalni/models.py index f93e35b0..d7beb22a 100644 --- a/seminar/models/personalni.py +++ b/personalni/models.py @@ -12,7 +12,7 @@ from django_countries.fields import CountryField from reversion import revisions as reversion -from .base import SeminarModelBase +from seminar.models.base import SeminarModelBase logger = logging.getLogger(__name__) @@ -297,7 +297,7 @@ class Resitel(SeminarModelBase): def vsechny_body(self): "Spočítá body odjakživa." vsechna_reseni = self.reseni_set.all() - from .odevzdavatko import Hodnoceni + from seminar.models.odevzdavatko import Hodnoceni vsechna_hodnoceni = Hodnoceni.objects.filter( reseni__in=vsechna_reseni) return sum(h.body for h in list(vsechna_hodnoceni) if h.body is not None) @@ -344,7 +344,7 @@ class Resitel(SeminarModelBase): # - body z 25. ročníku a dříve byly shledány dvakrát hodnotnějšími # - proto se započítávají dvojnásobně a byly posunuté hranice titulů # - staré tituly se ale nemají odebrat, pokud řešitel v t.č. minulém (26.) ročníku měl titul, má ho mít pořád. - from .odevzdavatko import Hodnoceni + from seminar.models.odevzdavatko import Hodnoceni hodnoceni_do_25_rocniku = Hodnoceni.objects.filter(deadline_body__cislo__rocnik__rocnik__lte=25,reseni__in=self.reseni_set.all()) novejsi_hodnoceni = Hodnoceni.objects.filter(reseni__in=self.reseni_set.all()).difference(hodnoceni_do_25_rocniku) @@ -382,7 +382,7 @@ class Resitel(SeminarModelBase): else: return Titul.akad - from .odevzdavatko import Hodnoceni + from seminar.models.odevzdavatko import Hodnoceni hodnoceni_do_26_rocniku = Hodnoceni.objects.filter(deadline_body__cislo__rocnik__rocnik__lte=26,reseni__in=self.reseni_set.all()) novejsi_body = body_z_hodnoceni( Hodnoceni.objects.filter(reseni__in=self.reseni_set.all()) @@ -411,6 +411,17 @@ class Resitel(SeminarModelBase): @reversion.register(ignore_duplicates=True) class Organizator(SeminarModelBase): + + class Meta: + verbose_name = 'Organizátor' + verbose_name_plural = 'Organizátoři' + # Řadí aktivní orgy na začátek, pod tím v pořadí od nejstarších neaktivní orgy. + # TODO: Chtěl bych spíš mít nejstarší orgy dole. + # TODO: Zohledňovat přezdívky? + # TODO: Sjednotit s tím, jak se řadí organizátoři v seznau orgů na webu + db_table = 'seminar_organizator' + ordering = ['-organizuje_do', 'osoba__jmeno', 'osoba__prijmeni'] + osoba = models.OneToOneField(Osoba, verbose_name='osoba', related_name='org', help_text='osobní údaje organizátora', null=False, blank=False, on_delete=models.PROTECT) @@ -452,12 +463,3 @@ class Organizator(SeminarModelBase): self.osoba.prijmeni) else: return "{} {}".format(self.osoba.jmeno, self.osoba.prijmeni) - - class Meta: - verbose_name = 'Organizátor' - verbose_name_plural = 'Organizátoři' - # Řadí aktivní orgy na začátek, pod tím v pořadí od nejstarších neaktivní orgy. - # TODO: Chtěl bych spíš mít nejstarší orgy dole. - # TODO: Zohledňovat přezdívky? - # TODO: Sjednotit s tím, jak se řadí organizátoři v seznau orgů na webu - ordering = ['-organizuje_do', 'osoba__jmeno', 'osoba__prijmeni'] diff --git a/personalni/templates/personalni/profil/orgorozcestnik.html b/personalni/templates/personalni/profil/orgorozcestnik.html index 34c4daba..46a26826 100644 --- a/personalni/templates/personalni/profil/orgorozcestnik.html +++ b/personalni/templates/personalni/profil/orgorozcestnik.html @@ -13,18 +13,18 @@
  • soustředění
  • -
  • přidat novinku na web
  • +
  • přidat novinku na web

  • Tvorba čísla