Merge branch 'treenode_editor' of gimli.ms.mff.cuni.cz:/akce/mam/git/mamweb into treenode_editor
This commit is contained in:
commit
fd0f4cf98f
5 changed files with 58 additions and 6 deletions
|
@ -10,6 +10,21 @@ import seminar.models as m
|
||||||
from datetime import date
|
from datetime import date
|
||||||
import logging
|
import logging
|
||||||
|
|
||||||
|
# pro přidání políčka do formuláře je potřeba
|
||||||
|
# - mít v modelu tu položku, kterou chci upravovat
|
||||||
|
# - přidat do views (prihlaskaView, resitelEditView)
|
||||||
|
# - přidat do forms
|
||||||
|
# - includovat do html
|
||||||
|
|
||||||
|
class DateInput(forms.DateInput):
|
||||||
|
# aby se datum dalo vybírat z kalendáře
|
||||||
|
input_type = 'date'
|
||||||
|
|
||||||
|
class TelInput(forms.TextInput):
|
||||||
|
# tohle je možná k niřemu, ale alepsoň to mění input type a nic to nekazí
|
||||||
|
input_type = 'tel'
|
||||||
|
input_pattern="^[+]?[()/0-9. -]{9,}$"
|
||||||
|
|
||||||
class LoginForm(forms.Form):
|
class LoginForm(forms.Form):
|
||||||
username = forms.CharField(label='Přihlašovací jméno',
|
username = forms.CharField(label='Přihlašovací jméno',
|
||||||
max_length=256,
|
max_length=256,
|
||||||
|
@ -42,8 +57,8 @@ class PrihlaskaForm(forms.Form):
|
||||||
pohlavi_muz = forms.ChoiceField(label='Pohlaví',
|
pohlavi_muz = forms.ChoiceField(label='Pohlaví',
|
||||||
choices = ((True,'muž'),(False,'žena')), required=True)
|
choices = ((True,'muž'),(False,'žena')), required=True)
|
||||||
email = forms.EmailField(label='E-mail',max_length=256, required=True)
|
email = forms.EmailField(label='E-mail',max_length=256, required=True)
|
||||||
telefon = forms.CharField(label='Telefon',max_length=256, required=False)
|
telefon = forms.CharField(widget=TelInput(),label='Telefon',max_length=256, required=False)
|
||||||
datum_narozeni = forms.DateField(label='Datum narození', required=False)
|
datum_narozeni = forms.DateField(widget=DateInput(),label='Datum narození', required=False)
|
||||||
ulice = forms.CharField(label='Ulice', max_length=256, required=False)
|
ulice = forms.CharField(label='Ulice', max_length=256, required=False)
|
||||||
mesto = forms.CharField(label='Město', max_length=256, required=False)
|
mesto = forms.CharField(label='Město', max_length=256, required=False)
|
||||||
psc = forms.CharField(label='PSČ', max_length=32, required=False)
|
psc = forms.CharField(label='PSČ', max_length=32, required=False)
|
||||||
|
@ -74,6 +89,8 @@ class PrihlaskaForm(forms.Form):
|
||||||
max_value=date.today().year+8,
|
max_value=date.today().year+8,
|
||||||
required=True)
|
required=True)
|
||||||
zasilat = forms.ChoiceField(label='Kam zasílat čísla a řešení',choices = Resitel.ZASILAT_CHOICES, required=True)
|
zasilat = forms.ChoiceField(label='Kam zasílat čísla a řešení',choices = Resitel.ZASILAT_CHOICES, required=True)
|
||||||
|
zasilat_cislo_emailem = forms.BooleanField(label='Chci dostávat emailem upozornění na vydání nového čísla', required=True)
|
||||||
|
|
||||||
gdpr = forms.BooleanField(label='Souhlasím se zpracováním osobních údajů', required=True)
|
gdpr = forms.BooleanField(label='Souhlasím se zpracováním osobních údajů', required=True)
|
||||||
spam = forms.BooleanField(label='Souhlasím se zasíláním materiálů od MFF UK', required=False)
|
spam = forms.BooleanField(label='Souhlasím se zasíláním materiálů od MFF UK', required=False)
|
||||||
|
|
||||||
|
@ -135,8 +152,8 @@ class ProfileEditForm(forms.Form):
|
||||||
pohlavi_muz = forms.ChoiceField(label='Pohlaví',
|
pohlavi_muz = forms.ChoiceField(label='Pohlaví',
|
||||||
choices = ((True,'muž'),(False,'žena')), required=True)
|
choices = ((True,'muž'),(False,'žena')), required=True)
|
||||||
email = forms.EmailField(label='E-mail',max_length=256, required=True)
|
email = forms.EmailField(label='E-mail',max_length=256, required=True)
|
||||||
telefon = forms.CharField(label='Telefon',max_length=256, required=False)
|
telefon = forms.CharField(widget=TelInput(),label='Telefon',max_length=256, required=False)
|
||||||
datum_narozeni = forms.DateField(label='Datum narození', required=False)
|
datum_narozeni = forms.DateField(widget=DateInput(),label='Datum narození', required=False)
|
||||||
ulice = forms.CharField(label='Ulice', max_length=256, required=False)
|
ulice = forms.CharField(label='Ulice', max_length=256, required=False)
|
||||||
mesto = forms.CharField(label='Město', max_length=256, required=False)
|
mesto = forms.CharField(label='Město', max_length=256, required=False)
|
||||||
psc = forms.CharField(label='PSČ', max_length=32, required=False)
|
psc = forms.CharField(label='PSČ', max_length=32, required=False)
|
||||||
|
@ -167,6 +184,8 @@ class ProfileEditForm(forms.Form):
|
||||||
max_value=date.today().year+8,
|
max_value=date.today().year+8,
|
||||||
required=True)
|
required=True)
|
||||||
zasilat = forms.ChoiceField(label='Kam zasílat čísla a řešení',choices = Resitel.ZASILAT_CHOICES, required=True)
|
zasilat = forms.ChoiceField(label='Kam zasílat čísla a řešení',choices = Resitel.ZASILAT_CHOICES, required=True)
|
||||||
|
zasilat_cislo_emailem = forms.BooleanField(label='Chci dostávat email s upozorněním na vydání nového čísla', required=True)
|
||||||
|
|
||||||
spam = forms.BooleanField(label='Souhlasím se zasíláním materiálů od MFF UK', required=False)
|
spam = forms.BooleanField(label='Souhlasím se zasíláním materiálů od MFF UK', required=False)
|
||||||
# def clean_username(self):
|
# def clean_username(self):
|
||||||
# err_logger = logging.getLogger('seminar.prihlaska.problem')
|
# err_logger = logging.getLogger('seminar.prihlaska.problem')
|
||||||
|
@ -234,7 +253,7 @@ class VlozReseniForm(forms.Form):
|
||||||
#resitele = models.ManyToManyField(Resitel, verbose_name='autoři řešení',
|
#resitele = models.ManyToManyField(Resitel, verbose_name='autoři řešení',
|
||||||
# help_text='Seznam autorů řešení', through='Reseni_Resitele')
|
# help_text='Seznam autorů řešení', through='Reseni_Resitele')
|
||||||
|
|
||||||
cas_doruceni = forms.DateField(label="Čas doručení")
|
cas_doruceni = forms.DateField(widget=DateInput(),label="Čas doručení")
|
||||||
|
|
||||||
#cas_doruceni = models.DateTimeField('čas_doručení', default=timezone.now, blank=True)
|
#cas_doruceni = models.DateTimeField('čas_doručení', default=timezone.now, blank=True)
|
||||||
|
|
||||||
|
|
|
@ -260,8 +260,10 @@ class Resitel(SeminarModelBase):
|
||||||
(ZASILAT_DO_SKOLY, 'Do školy'),
|
(ZASILAT_DO_SKOLY, 'Do školy'),
|
||||||
(ZASILAT_NIKAM, 'Nikam'),
|
(ZASILAT_NIKAM, 'Nikam'),
|
||||||
]
|
]
|
||||||
|
|
||||||
zasilat = models.CharField('kam zasílat', max_length=32, choices=ZASILAT_CHOICES, blank=False, default=ZASILAT_DOMU)
|
zasilat = models.CharField('kam zasílat', max_length=32, choices=ZASILAT_CHOICES, blank=False, default=ZASILAT_DOMU)
|
||||||
|
|
||||||
|
zasilat_cislo_emailem = models.BooleanField('zasílat číslo emailem', help_text='True pokud chce řešitel dostávat číslo emailem', default=False)
|
||||||
|
|
||||||
poznamka = models.TextField('neveřejná poznámka', blank=True,
|
poznamka = models.TextField('neveřejná poznámka', blank=True,
|
||||||
help_text='Neveřejná poznámka k řešiteli (plain text)')
|
help_text='Neveřejná poznámka k řešiteli (plain text)')
|
||||||
|
|
|
@ -6,6 +6,17 @@
|
||||||
{{form.media}}
|
{{form.media}}
|
||||||
<script src="{% static 'seminar/prihlaska.js' %}"></script>
|
<script src="{% static 'seminar/prihlaska.js' %}"></script>
|
||||||
{% endblock %}
|
{% endblock %}
|
||||||
|
|
||||||
|
<!--
|
||||||
|
|
||||||
|
# pro přidání políčka do formuláře je potřeba
|
||||||
|
# - mít v modelu tu položku, kterou chci upravovat
|
||||||
|
# - přidat do views (prihlaskaView, resitelEditView)
|
||||||
|
# - přidat do forms
|
||||||
|
# - includovat do html
|
||||||
|
|
||||||
|
-->
|
||||||
|
|
||||||
{% block content %}
|
{% block content %}
|
||||||
<h1>
|
<h1>
|
||||||
{% block nadpis1a %}{% block nadpis1b %}
|
{% block nadpis1a %}{% block nadpis1b %}
|
||||||
|
@ -73,6 +84,7 @@
|
||||||
</h4>
|
</h4>
|
||||||
<table class="form">
|
<table class="form">
|
||||||
{% include "seminar/profil/prihlaska_field.html" with field=form.zasilat %}
|
{% include "seminar/profil/prihlaska_field.html" with field=form.zasilat %}
|
||||||
|
{% include "seminar/profil/prihlaska_field.html" with field=form.zasilat_cislo_emailem %}
|
||||||
</table>
|
</table>
|
||||||
|
|
||||||
<hr>
|
<hr>
|
||||||
|
|
|
@ -7,6 +7,16 @@
|
||||||
<script src="{% static 'seminar/prihlaska.js' %}"></script>
|
<script src="{% static 'seminar/prihlaska.js' %}"></script>
|
||||||
{% endblock %}
|
{% endblock %}
|
||||||
|
|
||||||
|
<!--
|
||||||
|
|
||||||
|
# pro přidání políčka do formuláře je potřeba
|
||||||
|
# - mít v modelu tu položku, kterou chci upravovat
|
||||||
|
# - přidat do views (prihlaskaView, resitelEditView)
|
||||||
|
# - přidat do forms
|
||||||
|
# - includovat do html
|
||||||
|
|
||||||
|
-->
|
||||||
|
|
||||||
{% block content %}
|
{% block content %}
|
||||||
<h1>
|
<h1>
|
||||||
{% block nadpis1a %}{% block nadpis1b %}
|
{% block nadpis1a %}{% block nadpis1b %}
|
||||||
|
@ -77,6 +87,7 @@
|
||||||
</h4>
|
</h4>
|
||||||
<table class="form">
|
<table class="form">
|
||||||
{% include "seminar/profil/prihlaska_field.html" with field=form.zasilat %}
|
{% include "seminar/profil/prihlaska_field.html" with field=form.zasilat %}
|
||||||
|
{% include "seminar/profil/prihlaska_field.html" with field=form.zasilat_cislo_emailem %}
|
||||||
</table>
|
</table>
|
||||||
<hr>
|
<hr>
|
||||||
|
|
||||||
|
|
|
@ -1332,6 +1332,12 @@ class ResitelView(LoginRequiredMixin,generic.DetailView):
|
||||||
|
|
||||||
### Formulare
|
### Formulare
|
||||||
|
|
||||||
|
# pro přidání políčka do formuláře je potřeba
|
||||||
|
# - mít v modelu tu položku, kterou chci upravovat
|
||||||
|
# - přidat do views (prihlaskaView, resitelEditView)
|
||||||
|
# - přidat do forms
|
||||||
|
# - includovat do html
|
||||||
|
|
||||||
class AddSolutionView(LoginRequiredMixin, FormView):
|
class AddSolutionView(LoginRequiredMixin, FormView):
|
||||||
template_name = 'seminar/org/vloz_reseni.html'
|
template_name = 'seminar/org/vloz_reseni.html'
|
||||||
form_class = f.VlozReseniForm
|
form_class = f.VlozReseniForm
|
||||||
|
@ -1448,6 +1454,7 @@ def resitelEditView(request):
|
||||||
resitel_edit.skola = fcd['skola']
|
resitel_edit.skola = fcd['skola']
|
||||||
resitel_edit.rok_maturity = fcd['rok_maturity']
|
resitel_edit.rok_maturity = fcd['rok_maturity']
|
||||||
resitel_edit.zasilat = fcd['zasilat']
|
resitel_edit.zasilat = fcd['zasilat']
|
||||||
|
resitel_edit.zasilat_cislo_emailem = fcd['zasilat_cislo_emailem']
|
||||||
if fcd.get('skola'):
|
if fcd.get('skola'):
|
||||||
resitel_edit.skola = fcd['skola']
|
resitel_edit.skola = fcd['skola']
|
||||||
else:
|
else:
|
||||||
|
@ -1511,7 +1518,8 @@ def prihlaskaView(request):
|
||||||
|
|
||||||
r = Resitel(
|
r = Resitel(
|
||||||
rok_maturity = fcd['rok_maturity'],
|
rok_maturity = fcd['rok_maturity'],
|
||||||
zasilat = fcd['zasilat']
|
zasilat = fcd['zasilat'],
|
||||||
|
zasilat_cislo_emailem = fcd['zasilat_cislo_emailem']
|
||||||
)
|
)
|
||||||
|
|
||||||
r.save()
|
r.save()
|
||||||
|
|
Loading…
Reference in a new issue