From 51ae429040410e23fdef94a4b901dac342f3af57 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Mat=C4=9Bj=20Koci=C3=A1n?= Date: Sun, 18 Sep 2016 23:16:44 +0200 Subject: [PATCH 1/5] =?UTF-8?q?git=20hooks:=20lok=C3=A1ln=C3=AD=20flake8?= =?UTF-8?q?=20a=20jen=20kdy=C5=BE=20jsou=20zm=C4=9Bny?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- _git_hooks/pre-commit | 18 +++++++++++++++++- 1 file changed, 17 insertions(+), 1 deletion(-) diff --git a/_git_hooks/pre-commit b/_git_hooks/pre-commit index bdea5060..3ba59e0a 100755 --- a/_git_hooks/pre-commit +++ b/_git_hooks/pre-commit @@ -3,4 +3,20 @@ # Git hook script to verify what is about to be committed. # Checks that the changes don't introduce new flake8 errors. -git diff --unified=1 --cached HEAD -- '*py' | flake8 --diff +TMPDIFF=`tempfile` +FLAKE8="`git rev-parse --show-toplevel`/bin/flake8" + +status=0 + +git diff --unified=1 --cached HEAD -- '*py' > $TMPDIFF + +# only do the check when there are some changes to be commited +# otherwise flake8 would hang waiting for input +if [ -s $TMPDIFF ] ; then + cat $TMPDIFF | $FLAKE8 --diff + status=$? +fi + +rm -f $TMPDIFF + +exit $status From 5196b7a6e01d6bd3cac93a8e552d0494b281f77b Mon Sep 17 00:00:00 2001 From: "Tomas \"Jethro\" Pokorny" Date: Thu, 29 Sep 2016 01:19:35 +0200 Subject: [PATCH 2/5] Priprava na odstraneni stareho Seznamu. --- prednasky/admin.py | 15 ++++- .../migrations/0003_auto_20160929_0117.py | 64 +++++++++++++++++++ prednasky/models.py | 53 +++++++++++++-- prednasky/views.py | 4 +- 4 files changed, 125 insertions(+), 11 deletions(-) create mode 100644 prednasky/migrations/0003_auto_20160929_0117.py diff --git a/prednasky/admin.py b/prednasky/admin.py index bbcea848..555c72fa 100644 --- a/prednasky/admin.py +++ b/prednasky/admin.py @@ -1,7 +1,16 @@ from django.contrib import admin +from reversion.admin import VersionAdmin -from models import Prednaska, Seznam, Hlasovani +from models import Prednaska, Hlasovani -admin.site.register(Seznam) -admin.site.register(Prednaska) admin.site.register(Hlasovani) + +class PrednaskaAdmin(VersionAdmin): +# fieldsets = [ +# (None, {'fields': ['pdf', 'cas', 'stran', 'nazev', 'komentar']}), +# ] + list_display = ['nazev', 'org', 'obor'] + list_filter = ['org','obor'] + search_fields = [] + +admin.site.register(Prednaska,PrednaskaAdmin) diff --git a/prednasky/migrations/0003_auto_20160929_0117.py b/prednasky/migrations/0003_auto_20160929_0117.py new file mode 100644 index 00000000..c72e565b --- /dev/null +++ b/prednasky/migrations/0003_auto_20160929_0117.py @@ -0,0 +1,64 @@ +# -*- coding: utf-8 -*- +from __future__ import unicode_literals + +from django.db import migrations, models + + +class Migration(migrations.Migration): + + dependencies = [ + ('prednasky', '0002_auto_20160417_2347'), + ] + + operations = [ + migrations.RenameModel( + old_name='Seznam', + new_name='Seznam_old', + ), + migrations.AlterModelOptions( + name='hlasovani', + options={'ordering': ['ucastnik', 'prednaska'], 'verbose_name': 'Hlasov\xe1n\xed', 'verbose_name_plural': 'Hlasov\xe1n\xed'}, + ), + migrations.AlterModelOptions( + name='prednaska', + options={'ordering': ['org', 'nazev'], 'verbose_name': 'P\u0159edn\xe1\u0161ka', 'verbose_name_plural': 'P\u0159edn\xe1\u0161ky'}, + ), + migrations.AddField( + model_name='prednaska', + name='popis', + field=models.TextField(help_text=b'Neve\xc5\x99ejn\xc3\xbd popis pro ostatn\xc3\xad orgy', null=True, verbose_name=b'Popis pro orgy'), + ), + migrations.AlterField( + model_name='hlasovani', + name='id', + field=models.AutoField(serialize=False, primary_key=True), + ), + migrations.AlterField( + model_name='prednaska', + name='anotace', + field=models.TextField(help_text=b'Ve\xc5\x99ejn\xc3\xa1 anotace v hlasov\xc3\xa1n\xc3\xad', null=True, verbose_name=b'Anotace'), + ), + migrations.AlterField( + model_name='prednaska', + name='id', + field=models.AutoField(serialize=False, primary_key=True), + ), + migrations.AlterField( + model_name='prednaska', + name='obor', + field=models.CharField(help_text=b'Podmno\xc5\xbeina MFIOB', max_length=5, verbose_name=b'Obor'), + ), + migrations.AlterField( + model_name='prednaska', + name='seznam', + field=models.ForeignKey(to='prednasky.Seznam'), + ), + migrations.AlterModelTable( + name='hlasovani', + table='prednasky_hlasovani', + ), + migrations.AlterModelTable( + name='prednaska', + table='prednasky_prednaska', + ), + ] diff --git a/prednasky/models.py b/prednasky/models.py index 0f94f500..a405ce12 100644 --- a/prednasky/models.py +++ b/prednasky/models.py @@ -1,10 +1,27 @@ # -*- coding: utf-8 -*- from django.db import models -from seminar.models import Organizator +from seminar.models import Organizator,Soustredeni + +CHOICES_STAV = ( +(1, 'Návrh'), +(2, 'Bude') +) + +class Seznam_old(models.Model): + pass + +#class Seznam(models.Model): +# class Meta: +# db_table = 'prednasky_seznam' +# verbose_name = u'Seznam přednášek' +# verbose_name_plural = u'Seznamy přednášek' +# ordering = ['soustredeni', 'stav'] +# +# id = models.AutoField(primary_key = True) +# soustredeni = models.ForeignKey(Soustredeni,null = True, default = None) +# stav = models.IntegerField('Stav',choices=CHOICES_STAV,default = 2) -class Seznam(models.Model): - pass CHOICES_OBTIZNOST = ( (1, 'Lehká'), @@ -19,15 +36,39 @@ CHOICES_BODY = ( ) class Prednaska(models.Model): + class Meta: + db_table = 'prednasky_prednaska' + verbose_name = u'Přednáška' + verbose_name_plural = u'Přednášky' + ordering = ['org', 'nazev'] + + id = models.AutoField(primary_key = True) nazev = models.CharField('Název', max_length = 300) org = models.ForeignKey(Organizator) - anotace = models.TextField('Anotace') + popis = models.TextField('Popis pro orgy',null = True,help_text = 'Neveřejný popis pro ostatní orgy') + anotace = models.TextField('Anotace',null = True, help_text = 'Veřejná anotace v hlasování') obtiznost = models.IntegerField('Obtížnost', choices=CHOICES_OBTIZNOST) - obor = models.CharField('Obor', max_length = 5) + obor = models.CharField('Obor', max_length = 5, help_text = 'Podmnožina MFIOB') klicova = models.CharField('Klíčová slova', max_length = 200, null = True, blank = True) - seznam = models.ForeignKey(Seznam, blank = True, default = None) + seznam = models.ForeignKey(Seznam_old) + +#class Prednaska_Seznam(models.Model): +# class Meta: +# db_table = 'prednasky_prednaska_seznam' +# verbose_name = u'Přednáška v seznamu' +# verbose_name_plural = u'Přednášky v seznamech' +# id = models.AutoField(primary_key = True) +# prednaska = models.ForeignKey(Prednaska) +# seznam = models.ForeignKey(Seznam) +# class Hlasovani(models.Model): + class Meta: + db_table = 'prednasky_hlasovani' + verbose_name = u'Hlasování' + verbose_name_plural = u'Hlasování' + ordering = ['ucastnik', 'prednaska'] + id = models.AutoField(primary_key = True) prednaska = models.ForeignKey(Prednaska) body = models.IntegerField('Body', default = 0, choices = CHOICES_BODY) ucastnik = models.CharField('Účastník', max_length = 100) diff --git a/prednasky/views.py b/prednasky/views.py index bcaa32f5..e9f29a33 100644 --- a/prednasky/views.py +++ b/prednasky/views.py @@ -1,11 +1,11 @@ from django.shortcuts import render from prednasky.forms import NewPrednaskyForm -from prednasky.models import Seznam, Hlasovani, Prednaska +from prednasky.models import Seznam_old, Hlasovani, Prednaska from django.shortcuts import HttpResponseRedirect def newPrednaska(request): # zjistime k jakemu soustredeni se vaze nove vytvarena galerie - prednasky = Seznam.objects.first() + prednasky = Seznam_old.objects.first() # obsluha formulare umoznujiciho multiple nahravani fotek if request.method == 'POST': form = NewPrednaskyForm(request.POST, request.FILES) From c803014e774316466ad1205468edcef56469baa8 Mon Sep 17 00:00:00 2001 From: "Tomas \"Jethro\" Pokorny" Date: Thu, 29 Sep 2016 01:54:22 +0200 Subject: [PATCH 3/5] Migrace na novy model. Predchozi commit nefunguje, pouzijte tento. --- .../migrations/0003_auto_20160929_0117.py | 2 +- .../0004_remove_prednaska_seznam.py | 18 +++++++ .../migrations/0005_auto_20160929_0153.py | 49 +++++++++++++++++++ prednasky/models.py | 44 ++++++++--------- prednasky/views.py | 4 +- 5 files changed, 92 insertions(+), 25 deletions(-) create mode 100644 prednasky/migrations/0004_remove_prednaska_seznam.py create mode 100644 prednasky/migrations/0005_auto_20160929_0153.py diff --git a/prednasky/migrations/0003_auto_20160929_0117.py b/prednasky/migrations/0003_auto_20160929_0117.py index c72e565b..9e2cfb17 100644 --- a/prednasky/migrations/0003_auto_20160929_0117.py +++ b/prednasky/migrations/0003_auto_20160929_0117.py @@ -51,7 +51,7 @@ class Migration(migrations.Migration): migrations.AlterField( model_name='prednaska', name='seznam', - field=models.ForeignKey(to='prednasky.Seznam'), + field=models.ForeignKey(to='prednasky.Seznam_old'), ), migrations.AlterModelTable( name='hlasovani', diff --git a/prednasky/migrations/0004_remove_prednaska_seznam.py b/prednasky/migrations/0004_remove_prednaska_seznam.py new file mode 100644 index 00000000..d149199f --- /dev/null +++ b/prednasky/migrations/0004_remove_prednaska_seznam.py @@ -0,0 +1,18 @@ +# -*- coding: utf-8 -*- +from __future__ import unicode_literals + +from django.db import migrations, models + + +class Migration(migrations.Migration): + + dependencies = [ + ('prednasky', '0003_auto_20160929_0117'), + ] + + operations = [ + migrations.RemoveField( + model_name='prednaska', + name='seznam', + ), + ] diff --git a/prednasky/migrations/0005_auto_20160929_0153.py b/prednasky/migrations/0005_auto_20160929_0153.py new file mode 100644 index 00000000..8aacd6fd --- /dev/null +++ b/prednasky/migrations/0005_auto_20160929_0153.py @@ -0,0 +1,49 @@ +# -*- coding: utf-8 -*- +from __future__ import unicode_literals + +from django.db import migrations, models + + +class Migration(migrations.Migration): + + dependencies = [ + ('seminar', '0041_konfery'), + ('prednasky', '0004_remove_prednaska_seznam'), + ] + + operations = [ + migrations.CreateModel( + name='Prednaska_Seznam', + fields=[ + ('id', models.AutoField(serialize=False, primary_key=True)), + ('prednaska', models.ForeignKey(to='prednasky.Prednaska')), + ], + options={ + 'db_table': 'prednasky_prednaska_seznam', + 'verbose_name': 'P\u0159edn\xe1\u0161ka v seznamu', + 'verbose_name_plural': 'P\u0159edn\xe1\u0161ky v seznamech', + }, + ), + migrations.CreateModel( + name='Seznam', + fields=[ + ('id', models.AutoField(serialize=False, primary_key=True)), + ('stav', models.IntegerField(default=2, verbose_name=b'Stav', choices=[(1, b'N\xc3\xa1vrh'), (2, b'Bude')])), + ('soustredeni', models.ForeignKey(default=None, to='seminar.Soustredeni', null=True)), + ], + options={ + 'ordering': ['soustredeni', 'stav'], + 'db_table': 'prednasky_seznam', + 'verbose_name': 'Seznam p\u0159edn\xe1\u0161ek', + 'verbose_name_plural': 'Seznamy p\u0159edn\xe1\u0161ek', + }, + ), + migrations.DeleteModel( + name='Seznam_old', + ), + migrations.AddField( + model_name='prednaska_seznam', + name='seznam', + field=models.ForeignKey(to='prednasky.Seznam'), + ), + ] diff --git a/prednasky/models.py b/prednasky/models.py index a405ce12..1b069e3b 100644 --- a/prednasky/models.py +++ b/prednasky/models.py @@ -8,19 +8,19 @@ CHOICES_STAV = ( (2, 'Bude') ) -class Seznam_old(models.Model): - pass +#class Seznam_old(models.Model): +# pass -#class Seznam(models.Model): -# class Meta: -# db_table = 'prednasky_seznam' -# verbose_name = u'Seznam přednášek' -# verbose_name_plural = u'Seznamy přednášek' -# ordering = ['soustredeni', 'stav'] -# -# id = models.AutoField(primary_key = True) -# soustredeni = models.ForeignKey(Soustredeni,null = True, default = None) -# stav = models.IntegerField('Stav',choices=CHOICES_STAV,default = 2) +class Seznam(models.Model): + class Meta: + db_table = 'prednasky_seznam' + verbose_name = u'Seznam přednášek' + verbose_name_plural = u'Seznamy přednášek' + ordering = ['soustredeni', 'stav'] + + id = models.AutoField(primary_key = True) + soustredeni = models.ForeignKey(Soustredeni,null = True, default = None) + stav = models.IntegerField('Stav',choices=CHOICES_STAV,default = 2) CHOICES_OBTIZNOST = ( @@ -50,17 +50,17 @@ class Prednaska(models.Model): obtiznost = models.IntegerField('Obtížnost', choices=CHOICES_OBTIZNOST) obor = models.CharField('Obor', max_length = 5, help_text = 'Podmnožina MFIOB') klicova = models.CharField('Klíčová slova', max_length = 200, null = True, blank = True) - seznam = models.ForeignKey(Seznam_old) +# seznam = models.ForeignKey(Seznam_old) + +class Prednaska_Seznam(models.Model): + class Meta: + db_table = 'prednasky_prednaska_seznam' + verbose_name = u'Přednáška v seznamu' + verbose_name_plural = u'Přednášky v seznamech' + id = models.AutoField(primary_key = True) + prednaska = models.ForeignKey(Prednaska) + seznam = models.ForeignKey(Seznam) -#class Prednaska_Seznam(models.Model): -# class Meta: -# db_table = 'prednasky_prednaska_seznam' -# verbose_name = u'Přednáška v seznamu' -# verbose_name_plural = u'Přednášky v seznamech' -# id = models.AutoField(primary_key = True) -# prednaska = models.ForeignKey(Prednaska) -# seznam = models.ForeignKey(Seznam) -# class Hlasovani(models.Model): class Meta: diff --git a/prednasky/views.py b/prednasky/views.py index e9f29a33..bcaa32f5 100644 --- a/prednasky/views.py +++ b/prednasky/views.py @@ -1,11 +1,11 @@ from django.shortcuts import render from prednasky.forms import NewPrednaskyForm -from prednasky.models import Seznam_old, Hlasovani, Prednaska +from prednasky.models import Seznam, Hlasovani, Prednaska from django.shortcuts import HttpResponseRedirect def newPrednaska(request): # zjistime k jakemu soustredeni se vaze nove vytvarena galerie - prednasky = Seznam_old.objects.first() + prednasky = Seznam.objects.first() # obsluha formulare umoznujiciho multiple nahravani fotek if request.method == 'POST': form = NewPrednaskyForm(request.POST, request.FILES) From 0c67eccd9209ea45809312dbd903cd1a7d280a52 Mon Sep 17 00:00:00 2001 From: "Tomas \"Jethro\" Pokorny" Date: Thu, 29 Sep 2016 03:59:28 +0200 Subject: [PATCH 4/5] Fungujici verze spravy prednasek a hlasovani. --- prednasky/admin.py | 59 ++++++++++++++++--- prednasky/migrations/0006_hlasovani_seznam.py | 20 +++++++ .../migrations/0007_prednaska_seznamy.py | 19 ++++++ .../migrations/0008_auto_20160929_0225.py | 25 ++++++++ .../migrations/0009_auto_20160929_0354.py | 49 +++++++++++++++ prednasky/models.py | 53 ++++++++++------- prednasky/views.py | 15 +++-- 7 files changed, 206 insertions(+), 34 deletions(-) create mode 100644 prednasky/migrations/0006_hlasovani_seznam.py create mode 100644 prednasky/migrations/0007_prednaska_seznamy.py create mode 100644 prednasky/migrations/0008_auto_20160929_0225.py create mode 100644 prednasky/migrations/0009_auto_20160929_0354.py diff --git a/prednasky/admin.py b/prednasky/admin.py index 555c72fa..a1d0e63c 100644 --- a/prednasky/admin.py +++ b/prednasky/admin.py @@ -1,16 +1,59 @@ +# -*- coding: utf-8 -*- from django.contrib import admin +from django.contrib import messages +from django import forms from reversion.admin import VersionAdmin +from autocomplete_light import shortcuts as autocomplete_light +from django.db import models -from models import Prednaska, Hlasovani +from models import Prednaska, Seznam, STAV_NAVRH +from seminar.models import Soustredeni + +class Seznam_PrednaskaInline(admin.TabularInline): +# form = autocomplete_light.modelform_factory(Prednaska, autocomplete_fields=['nazev'], fields=['nazev']) + model = Prednaska.seznamy.through +# fields = ['nazev', 'org', 'obor' ] +# extra = 0 +# formfield_overrides = { +# models.TextField: {'widget': forms.TextInput}, +# } + +# def get_queryset(self, request): +# qs = super(Seznam_PrednaskaInline, self).get_queryset(request) +# return qs.select_related('seznam', 'prednaska') + +class SeznamAdmin(VersionAdmin): + list_display = ['soustredeni','stav'] + inlines = [Seznam_PrednaskaInline] + +admin.site.register(Seznam,SeznamAdmin) -admin.site.register(Hlasovani) class PrednaskaAdmin(VersionAdmin): -# fieldsets = [ -# (None, {'fields': ['pdf', 'cas', 'stran', 'nazev', 'komentar']}), -# ] - list_display = ['nazev', 'org', 'obor'] - list_filter = ['org','obor'] - search_fields = [] + list_display = ['nazev', 'org', 'obor'] + list_filter = ['org','obor'] + search_fields = [] + + actions = ['move_to_soustredeni'] + + def move_to_soustredeni(self,request,queryset): + sous = Soustredeni.objects.first() + seznam = Seznam.objects.filter(soustredeni=sous,stav=STAV_NAVRH) + if len(seznam) == 0: + self.message_user(request,u"Není definován seznam pro aktuální soustředění, nic se neprovedlo",messages.ERROR) + return + seznam = seznam[0] + for prednaska in queryset: + prednaska.seznamy.add(seznam) + prednaska.save() + + self.message_user(request,u"Vybrané přednášky ({}) přidány jako návrhy na nejbližší soustředění".format(len(queryset))) + + move_to_soustredeni.short_description=u"Přidat přednášky do návrhu na nejbližší soustředění" + + + + + admin.site.register(Prednaska,PrednaskaAdmin) diff --git a/prednasky/migrations/0006_hlasovani_seznam.py b/prednasky/migrations/0006_hlasovani_seznam.py new file mode 100644 index 00000000..c6c1e609 --- /dev/null +++ b/prednasky/migrations/0006_hlasovani_seznam.py @@ -0,0 +1,20 @@ +# -*- coding: utf-8 -*- +from __future__ import unicode_literals + +from django.db import migrations, models + + +class Migration(migrations.Migration): + + dependencies = [ + ('prednasky', '0005_auto_20160929_0153'), + ] + + operations = [ + migrations.AddField( + model_name='hlasovani', + name='seznam', + field=models.ForeignKey(default=1, to='prednasky.Seznam'), + preserve_default=False, + ), + ] diff --git a/prednasky/migrations/0007_prednaska_seznamy.py b/prednasky/migrations/0007_prednaska_seznamy.py new file mode 100644 index 00000000..8f054e17 --- /dev/null +++ b/prednasky/migrations/0007_prednaska_seznamy.py @@ -0,0 +1,19 @@ +# -*- coding: utf-8 -*- +from __future__ import unicode_literals + +from django.db import migrations, models + + +class Migration(migrations.Migration): + + dependencies = [ + ('prednasky', '0006_hlasovani_seznam'), + ] + + operations = [ + migrations.AddField( + model_name='prednaska', + name='seznamy', + field=models.ManyToManyField(to='prednasky.Seznam'), + ), + ] diff --git a/prednasky/migrations/0008_auto_20160929_0225.py b/prednasky/migrations/0008_auto_20160929_0225.py new file mode 100644 index 00000000..a5bbb92e --- /dev/null +++ b/prednasky/migrations/0008_auto_20160929_0225.py @@ -0,0 +1,25 @@ +# -*- coding: utf-8 -*- +from __future__ import unicode_literals + +from django.db import migrations, models + + +class Migration(migrations.Migration): + + dependencies = [ + ('prednasky', '0007_prednaska_seznamy'), + ] + + operations = [ + migrations.RemoveField( + model_name='prednaska_seznam', + name='prednaska', + ), + migrations.RemoveField( + model_name='prednaska_seznam', + name='seznam', + ), + migrations.DeleteModel( + name='Prednaska_Seznam', + ), + ] diff --git a/prednasky/migrations/0009_auto_20160929_0354.py b/prednasky/migrations/0009_auto_20160929_0354.py new file mode 100644 index 00000000..6b4f9486 --- /dev/null +++ b/prednasky/migrations/0009_auto_20160929_0354.py @@ -0,0 +1,49 @@ +# -*- coding: utf-8 -*- +from __future__ import unicode_literals + +from django.db import migrations, models + + +class Migration(migrations.Migration): + + dependencies = [ + ('prednasky', '0008_auto_20160929_0225'), + ] + + operations = [ + migrations.AlterField( + model_name='prednaska', + name='anotace', + field=models.TextField(help_text='Ve\u0159ejn\xe1 anotace v hlasov\xe1n\xed', null=True, verbose_name=b'Anotace'), + ), + migrations.AlterField( + model_name='prednaska', + name='klicova', + field=models.CharField(max_length=200, null=True, verbose_name='Kl\xed\u010dov\xe1 slova', blank=True), + ), + migrations.AlterField( + model_name='prednaska', + name='nazev', + field=models.CharField(max_length=300, verbose_name='N\xe1zev'), + ), + migrations.AlterField( + model_name='prednaska', + name='obor', + field=models.CharField(help_text='Podmno\u017eina MFIOB', max_length=5, verbose_name='Obor'), + ), + migrations.AlterField( + model_name='prednaska', + name='obtiznost', + field=models.IntegerField(verbose_name='Obt\xed\u017enost', choices=[(1, b'Lehk\xc3\xa1'), (2, b'St\xc5\x99edn\xc3\xad'), (3, b'T\xc4\x9b\xc5\xbek\xc3\xa1')]), + ), + migrations.AlterField( + model_name='prednaska', + name='popis', + field=models.TextField(help_text='Neve\u0159ejn\xfd popis pro ostatn\xed orgy', null=True, verbose_name='Popis pro orgy'), + ), + migrations.AlterField( + model_name='seznam', + name='stav', + field=models.IntegerField(default=1, verbose_name=b'Stav', choices=[(1, b'N\xc3\xa1vrh'), (2, b'Bude')]), + ), + ] diff --git a/prednasky/models.py b/prednasky/models.py index 1b069e3b..75bb8cb0 100644 --- a/prednasky/models.py +++ b/prednasky/models.py @@ -1,16 +1,22 @@ # -*- coding: utf-8 -*- from django.db import models +from django.utils.encoding import python_2_unicode_compatible +from django.utils.encoding import force_unicode + from seminar.models import Organizator,Soustredeni -CHOICES_STAV = ( -(1, 'Návrh'), -(2, 'Bude') +STAV_NAVRH = 1 +STAV_BUDE = 2 + + +STAV_CHOICES = ( +(STAV_NAVRH, 'Návrh'), +(STAV_BUDE, 'Bude') ) -#class Seznam_old(models.Model): -# pass +@python_2_unicode_compatible class Seznam(models.Model): class Meta: db_table = 'prednasky_seznam' @@ -20,7 +26,10 @@ class Seznam(models.Model): id = models.AutoField(primary_key = True) soustredeni = models.ForeignKey(Soustredeni,null = True, default = None) - stav = models.IntegerField('Stav',choices=CHOICES_STAV,default = 2) + stav = models.IntegerField('Stav',choices=STAV_CHOICES,default = STAV_NAVRH) + + def __str__(self): + return force_unicode(u"Seznam {}přednášek na {}".format(u"návrhů " if self.stav == STAV_NAVRH else "",self.soustredeni)) CHOICES_OBTIZNOST = ( @@ -35,6 +44,7 @@ CHOICES_BODY = ( (1, '1'), ) +@python_2_unicode_compatible class Prednaska(models.Model): class Meta: db_table = 'prednasky_prednaska' @@ -43,25 +53,20 @@ class Prednaska(models.Model): ordering = ['org', 'nazev'] id = models.AutoField(primary_key = True) - nazev = models.CharField('Název', max_length = 300) + nazev = models.CharField(u'Název', max_length = 300) org = models.ForeignKey(Organizator) - popis = models.TextField('Popis pro orgy',null = True,help_text = 'Neveřejný popis pro ostatní orgy') - anotace = models.TextField('Anotace',null = True, help_text = 'Veřejná anotace v hlasování') - obtiznost = models.IntegerField('Obtížnost', choices=CHOICES_OBTIZNOST) - obor = models.CharField('Obor', max_length = 5, help_text = 'Podmnožina MFIOB') - klicova = models.CharField('Klíčová slova', max_length = 200, null = True, blank = True) -# seznam = models.ForeignKey(Seznam_old) - -class Prednaska_Seznam(models.Model): - class Meta: - db_table = 'prednasky_prednaska_seznam' - verbose_name = u'Přednáška v seznamu' - verbose_name_plural = u'Přednášky v seznamech' - id = models.AutoField(primary_key = True) - prednaska = models.ForeignKey(Prednaska) - seznam = models.ForeignKey(Seznam) + popis = models.TextField(u'Popis pro orgy',null = True,help_text = u'Neveřejný popis pro ostatní orgy') + anotace = models.TextField('Anotace',null = True, help_text = u'Veřejná anotace v hlasování') + obtiznost = models.IntegerField(u'Obtížnost', choices=CHOICES_OBTIZNOST) + obor = models.CharField(u'Obor', max_length = 5, help_text = u'Podmnožina MFIOB') + klicova = models.CharField(u'Klíčová slova', max_length = 200, null = True, blank = True) + seznamy = models.ManyToManyField(Seznam) + + def __str__(self): + return force_unicode(u"{} ({})".format(self.nazev,self.org)) +@python_2_unicode_compatible class Hlasovani(models.Model): class Meta: db_table = 'prednasky_hlasovani' @@ -72,4 +77,8 @@ class Hlasovani(models.Model): prednaska = models.ForeignKey(Prednaska) body = models.IntegerField('Body', default = 0, choices = CHOICES_BODY) ucastnik = models.CharField('Účastník', max_length = 100) + seznam = models.ForeignKey(Seznam) + + def __str__(self): + return force_unicode(u"{} dal {} bodů {} v seznamu {}".format(self.ucastnik, self.body, self.prednaska,self.seznam)) diff --git a/prednasky/views.py b/prednasky/views.py index bcaa32f5..ede98aee 100644 --- a/prednasky/views.py +++ b/prednasky/views.py @@ -3,10 +3,16 @@ from prednasky.forms import NewPrednaskyForm from prednasky.models import Seznam, Hlasovani, Prednaska from django.shortcuts import HttpResponseRedirect + +from models import Prednaska, Seznam, STAV_NAVRH +from seminar.models import Soustredeni + def newPrednaska(request): - # zjistime k jakemu soustredeni se vaze nove vytvarena galerie - prednasky = Seznam.objects.first() - # obsluha formulare umoznujiciho multiple nahravani fotek + # hlasovani se vztahuje k nejnovejsimu soustredeni + sous = Soustredeni.objects.first() + seznam = Seznam.objects.filter(soustredeni = sous, stav = STAV_NAVRH).first() + print seznam + # obsluha formulare if request.method == 'POST': form = NewPrednaskyForm(request.POST, request.FILES) if form.is_valid(): @@ -18,6 +24,7 @@ def newPrednaska(request): hlasovani.prednaska = Prednaska.objects.filter(pk = int(i[1:]))[0] hlasovani.body = int(request.POST[i]) hlasovani.ucastnik = jmeno + hlasovani.seznam = seznam hlasovani.save() # presmerovani na prave vzniklou galerii @@ -28,7 +35,7 @@ def newPrednaska(request): return render(request, 'prednasky/Base.html', { 'form' : form, - 'prednasky' : prednasky, + 'prednasky' : seznam, }) def Prednaska_hotovo(request): From 67c02ca43764f5e82326338b0beae60eb9702e2f Mon Sep 17 00:00:00 2001 From: "Tomas \"Jethro\" Pokorny" Date: Thu, 29 Sep 2016 05:08:42 +0200 Subject: [PATCH 5/5] Prednasky (skoro) funkcni. Zobrazeni daneho seznamu pretezuje server, jinak vse ok. --- .../migrations/0010_auto_20160929_0508.py | 24 +++++++++++++++++++ prednasky/models.py | 4 ++-- 2 files changed, 26 insertions(+), 2 deletions(-) create mode 100644 prednasky/migrations/0010_auto_20160929_0508.py diff --git a/prednasky/migrations/0010_auto_20160929_0508.py b/prednasky/migrations/0010_auto_20160929_0508.py new file mode 100644 index 00000000..b654e23f --- /dev/null +++ b/prednasky/migrations/0010_auto_20160929_0508.py @@ -0,0 +1,24 @@ +# -*- coding: utf-8 -*- +from __future__ import unicode_literals + +from django.db import migrations, models + + +class Migration(migrations.Migration): + + dependencies = [ + ('prednasky', '0009_auto_20160929_0354'), + ] + + operations = [ + migrations.AlterField( + model_name='prednaska', + name='anotace', + field=models.TextField(help_text='Ve\u0159ejn\xe1 anotace v hlasov\xe1n\xed', null=True, verbose_name=b'Anotace', blank=True), + ), + migrations.AlterField( + model_name='prednaska', + name='popis', + field=models.TextField(help_text='Neve\u0159ejn\xfd popis pro ostatn\xed orgy', null=True, verbose_name='Popis pro orgy', blank=True), + ), + ] diff --git a/prednasky/models.py b/prednasky/models.py index 75bb8cb0..d05ba76d 100644 --- a/prednasky/models.py +++ b/prednasky/models.py @@ -55,8 +55,8 @@ class Prednaska(models.Model): id = models.AutoField(primary_key = True) nazev = models.CharField(u'Název', max_length = 300) org = models.ForeignKey(Organizator) - popis = models.TextField(u'Popis pro orgy',null = True,help_text = u'Neveřejný popis pro ostatní orgy') - anotace = models.TextField('Anotace',null = True, help_text = u'Veřejná anotace v hlasování') + popis = models.TextField(u'Popis pro orgy',null = True, blank = True,help_text = u'Neveřejný popis pro ostatní orgy') + anotace = models.TextField('Anotace',null = True, blank = True, help_text = u'Veřejná anotace v hlasování') obtiznost = models.IntegerField(u'Obtížnost', choices=CHOICES_OBTIZNOST) obor = models.CharField(u'Obor', max_length = 5, help_text = u'Podmnožina MFIOB') klicova = models.CharField(u'Klíčová slova', max_length = 200, null = True, blank = True)