diff --git a/korektury/templates/korektury/opraf.html b/korektury/templates/korektury/opraf.html index 04cfc2de..6a92f28c 100644 --- a/korektury/templates/korektury/opraf.html +++ b/korektury/templates/korektury/opraf.html @@ -7,7 +7,7 @@ <script src="{% static "korektury/opraf.js"%}"></script> <title>Korektury {{pdf.nazev}}</title> </head> -<body {% if pdf.status = 'zanaseni'%} class="comitting" {% elif pdf.status = 'zastarale' %} class="deprecated" {% endif %}> +<body {% if pdf.status = 'zanaseni'%} class="comitting" {% elif pdf.status = 'zastarale' %} class="deprecated" {% endif %} onload='place_comments()'> <h1>Korektury {{pdf.nazev}}</h1> {% if pdf.status = 'zanaseni' %} <h2> Probíhá zanášení korektur, zvažte, zda chcete přidávat nové </h2> {% endif %} {% if pdf.status = 'zastarale' %} <h2> Toto PDF je již zastaralé, nepřidávejte nové korektury </h2> {% endif %} @@ -192,9 +192,11 @@ ["img-{{s.strana}}", [{% for o in s.op_id %}["op{{o.id}}",{{o.x}},{{o.y}}],{% endfor %}[]]], {% endfor %} []] - for (var i=0;i<comments.length-1;i++){ - place_comments_one_div(comments[i][0], comments[i][1]) - } + function place_comments() { + for (var i=0; i < comments.length-1; i++) { + place_comments_one_div(comments[i][0], comments[i][1]) + } + } {% if scroll %} window.scrollTo(0,{{scroll}}); {% endif %} diff --git a/korektury/views.py b/korektury/views.py index 5eb42bd1..70cfaf6e 100644 --- a/korektury/views.py +++ b/korektury/views.py @@ -135,21 +135,32 @@ class KorekturyView(generic.TemplateView): # Prijemci e-mailu emails = set() + # e-mail autora korektury email = oprava.autor.user.email - # nalezeni e-mailu na organizatory komentaru + if email: + emails.add(email) + + # nalezeni e-mailu na autory komentaru for komentar in oprava.komentar_set.all(): - email = komentar.autor.user.email - if email: - emails.add(email) + email_komentujiciho = komentar.autor.user.email + if email_komentujiciho: + emails.add(email_komentujiciho) + # zodpovedny org if oprava.pdf.org: email_zobpovedny = oprava.pdf.org.user.email if email_zobpovedny: emails.add(email_zobpovedny) + # odstran e-mail autora opravy + email = autor.user.email if email: emails.discard(email) + if not settings.SEND_EMAIL_NOTIFICATIONS: + print "Poslal bych upozornění na tyto adresy: ", " ".join(emails) + return + send_mail(subject, text, from_email, list(emails)) def get_context_data(self, **kwargs): diff --git a/mamweb/settings_common.py b/mamweb/settings_common.py index a1025b07..ad2b7fd7 100644 --- a/mamweb/settings_common.py +++ b/mamweb/settings_common.py @@ -242,6 +242,10 @@ LOGGING = { SEMINAR_RESENI_DIR = os.path.join('reseni') SEMINAR_KONFERY_DIR = os.path.join('konfery') -KOREKTURY_PDF_DIR = os.path.join('korektury','pdf') -KOREKTURY_IMG_DIR = os.path.join('korektury','img') -CISLO_IMG_DIR = os.path.join('cislo','img') +KOREKTURY_PDF_DIR = os.path.join('korektury', 'pdf') +KOREKTURY_IMG_DIR = os.path.join('korektury', 'img') +CISLO_IMG_DIR = os.path.join('cislo', 'img') + + +# E-MAIL NOTIFICATIONS +SEND_EMAIL_NOTIFICATIONS = False diff --git a/mamweb/settings_prod.py b/mamweb/settings_prod.py index b56a9380..8b75ce74 100644 --- a/mamweb/settings_prod.py +++ b/mamweb/settings_prod.py @@ -67,3 +67,5 @@ LOGGING['loggers']['']['handlers'] = ['console', 'mail_admins'] LOGGING['loggers']['django']['handlers'] = ['console', 'mail_admins'] +# E-MAIL NOTIFICATIONS +SEND_EMAIL_NOTIFICATIONS = True diff --git a/mamweb/settings_test.py b/mamweb/settings_test.py index 3d1b0010..7ca1c627 100644 --- a/mamweb/settings_test.py +++ b/mamweb/settings_test.py @@ -10,7 +10,7 @@ import os.path # # Import common settings -from .settings_common import * +from .settings_common import * # zatim nutne, casem snad vyresime # noqa # Quick-start development settings - unsuitable for production @@ -63,6 +63,3 @@ CSRF_COOKIE_SECURE = True LOGGING['loggers']['']['handlers'] = ['console', 'mail_admins'] LOGGING['loggers']['django']['handlers'] = ['console', 'mail_admins'] - - - diff --git a/seminar/static/seminar/stvrzenka.sty b/seminar/static/seminar/stvrzenka.sty new file mode 100644 index 00000000..aa3122a1 --- /dev/null +++ b/seminar/static/seminar/stvrzenka.sty @@ -0,0 +1,24 @@ +\newcommand{\stvrzenka}[6]{ + \removelastskip\bigskip + \newpage + + \noindent\textbf{Dodavatel:}\hfill\textbf{Stvrzenka č. {\Large #1}} + + {Univerzita Karlova \\ + \indent Matematicko-fyzikální fakulta \\ + \indent OVVP, M\&M \\ + \indent Ke Karlovu 3, 120 00 Praha 2 \\ + \indent IČ: 00216208 DIČ: CZ00216208} + + \parindent=0pt + \parskip=0.2in + + \textbf{Celkem Kč:} 700,- \\ + \textbf{Slovy:} sedmset korun českých + + \textbf{Přijato od (firma, jméno, adresa):} #2 #3, #4, #5 #6 + + \textbf{Účel platby:} příspěvek na stravování + + ze dne \datum \hfill Přijal:\hspace{3cm} +} diff --git a/seminar/static/seminar/stvrzenky.tex b/seminar/static/seminar/stvrzenky.tex new file mode 100644 index 00000000..b3c21cfc --- /dev/null +++ b/seminar/static/seminar/stvrzenky.tex @@ -0,0 +1,13 @@ +\documentclass[12pt,a4paper]{article} +\usepackage[czech]{babel} +\usepackage[utf8]{inputenc} +\usepackage[margin=1in]{geometry} + +\usepackage{stvrzenka} + +\pagestyle{empty} +\begin{document} + +\input{ucastnici} + +\end{document} diff --git a/seminar/templates/seminar/soustredeni/seznam_soustredeni.html b/seminar/templates/seminar/soustredeni/seznam_soustredeni.html index 6176b3e9..18447a67 100644 --- a/seminar/templates/seminar/soustredeni/seznam_soustredeni.html +++ b/seminar/templates/seminar/soustredeni/seznam_soustredeni.html @@ -49,7 +49,8 @@ <a href="../{{soustredeni.pk}}/obalky.pdf">Vygenerovat obálky pro účastníky</a><br> Seznam účastníků - <a href="../{{soustredeni.pk}}/seznam_ucastniku">HTML tabulka pro tisk</a>, - <a href="../{{soustredeni.pk}}/export_ucastniku">CSV</a> + <a href="../{{soustredeni.pk}}/export_ucastniku">CSV</a><br> + <a href="../{{soustredeni.pk}}/stvrzenky/42">Stvrzenky <i>(42 v URL nahraďte prvním číslem z rozsahu)</i></a> </div> {% endif %} diff --git a/seminar/templates/seminar/soustredeni/ucastnici.tex b/seminar/templates/seminar/soustredeni/ucastnici.tex new file mode 100644 index 00000000..a39885a6 --- /dev/null +++ b/seminar/templates/seminar/soustredeni/ucastnici.tex @@ -0,0 +1,5 @@ +{% load tex %} +\newcommand{\datum}{{datum|date:"j. n. Y"|sloz}} +{% for u in ucastnici %} +\stvrzenka{{u.cislo_stvrzenky|sloz}}{{u.jmeno|sloz}}{{u.prijmeni|sloz}}{{u.ulice|sloz}}{{u.psc|sloz}}{{u.mesto|sloz}} +{% endfor %} diff --git a/seminar/urls.py b/seminar/urls.py index 2c06e0fb..f7228b47 100644 --- a/seminar/urls.py +++ b/seminar/urls.py @@ -29,6 +29,7 @@ urlpatterns = [ name = 'seminar_seznam_soustredeni'), url(r'^soustredeni/probehlo/(?P<soustredeni>\d+)/$', views.SoustredeniView.as_view(), name='seminar_soustredeni'), url(r'^soustredeni/(?P<soustredeni>\d+)/seznam_ucastniku$', staff_member_required(views.SoustredeniUcastniciView.as_view()), name='soustredeni_ucastnici'), + url(r'^soustredeni/(?P<soustredeni>\d+)/stvrzenky/(?P<first_num>\d+)$', staff_member_required(views.soustredeniStvrzenkyExportView), name='soustredeni_stvrzenky'), url(r'^soustredeni/(?P<soustredeni>\d+)/export_ucastniku$', staff_member_required(views.soustredeniUcastniciExportView), name='soustredeni_ucastnici_export'), url(r'^soustredeni/(?P<soustredeni>\d+)/fotogalerie/', include('galerie.urls')), diff --git a/seminar/views.py b/seminar/views.py index 95df1a2e..141e9492 100644 --- a/seminar/views.py +++ b/seminar/views.py @@ -6,7 +6,7 @@ from django.core.urlresolvers import reverse from django.core.exceptions import PermissionDenied, ObjectDoesNotExist from django.views import generic from django.utils.translation import ugettext as _ -from django.http import Http404 +from django.http import Http404,HttpResponseBadRequest from django.db.models import Q from django.views.decorators.csrf import ensure_csrf_cookie from django.contrib.auth import authenticate, login @@ -530,7 +530,7 @@ class SoustredeniView(generic.DetailView): template_name = 'seminar/archiv/soustredeni.html' def soustredeniObalkyView(request,soustredeni): - soustredeni = Soustredeni.objects.filter(id = soustredeni)[0] + soustredeni = get_object_or_404(Soustredeni,id = soustredeni) return obalkyView(request,soustredeni.ucastnici.all()) class SoustredeniUcastniciView(generic.ListView): @@ -541,8 +541,31 @@ class SoustredeniUcastniciView(generic.ListView): self.soustredeni = get_object_or_404(Soustredeni, id=self.kwargs["soustredeni"]) return Soustredeni_Ucastnici.objects.filter(soustredeni=self.soustredeni).select_related('resitel') +def soustredeniStvrzenkyExportView(request,soustredeni,first_num): + first_num = int(first_num) + soustredeni = get_object_or_404(Soustredeni,id = soustredeni) + ucastnici = Resitel.objects.filter(soustredeni=soustredeni) + for (idx,u) in enumerate(ucastnici): + u.cislo_stvrzenky = first_num+idx; + tex = render(request,'seminar/soustredeni/ucastnici.tex', {'ucastnici': ucastnici, 'datum':soustredeni.datum_zacatku }).content + + tempdir = tempfile.mkdtemp() + with open(tempdir+"/ucastnici.tex","w") as texfile: + # Pokud TeX chce ISO Latin, tak se da encode nastavit + texfile.write(tex.decode("utf-8").encode("utf-8")) + shutil.copy(os.path.join(settings.STATIC_ROOT, 'seminar/stvrzenka.sty'),tempdir) + shutil.copy(os.path.join(settings.STATIC_ROOT, 'seminar/stvrzenky.tex'),tempdir) + subprocess.call(["cslatex","stvrzenky.tex"],cwd = tempdir) + subprocess.call(["dvipdf","stvrzenky.dvi"],cwd = tempdir) + + with open(tempdir+"/stvrzenky.pdf","rb") as pdffile: + response = HttpResponse(pdffile.read(),content_type='application/pdf') + shutil.rmtree(tempdir) + return response + + def soustredeniUcastniciExportView(request,soustredeni): - soustredeni = Soustredeni.objects.filter(id = soustredeni)[0] + soustredeni = get_object_or_404(Soustredeni,id = soustredeni) ucastnici = Resitel.objects.filter(soustredeni=soustredeni) response = HttpResponse(content_type='text/csv') response['Content-Disposition'] = 'attachment; filename="ucastnici.csv"'