mamweb/prednasky/views.py

118 lines
3.8 KiB
Python
Raw Normal View History

2017-10-06 00:37:08 +02:00
from django.shortcuts import render, get_object_or_404
from django.views import generic
2016-04-18 01:14:08 +02:00
from django.shortcuts import HttpResponseRedirect
2017-10-06 00:37:08 +02:00
from django.core.exceptions import ObjectDoesNotExist
from django.db.models import Sum
from django.forms import Form
2016-04-18 01:14:08 +02:00
2017-10-06 01:15:20 +02:00
from prednasky.models import Prednaska, Hlasovani, Seznam, STAV_NAVRH
from soustredeni.models import Soustredeni
from personalni.models import Osoba
2016-04-18 01:14:08 +02:00
def newPrednaska(request):
2019-05-11 01:15:05 +02:00
# hlasovani se vztahuje k nejnovejsimu soustredeni
sous = Soustredeni.objects.first()
seznam = Seznam.objects.filter(soustredeni = sous, stav = STAV_NAVRH).first()
osoba = Osoba.objects.filter(user=request.user).first()
ucastnik = osoba.plne_jmeno() + ' ' + str(osoba.id)
2019-05-11 01:15:05 +02:00
# obsluha formulare
if request.method == 'POST':
form = Form(request.POST, request.FILES)
2019-05-11 01:15:05 +02:00
if form.is_valid():
# id z důvodu duplicitních jmen (přechod z jména na objekt Osoby nějak kape na tom,
# že všechna předchozí hlasování zde mají náhodný string…)
# TODO Změnit to na Osobu
# TODO v následujících řádcích je zbytečně mnoho dotazů na QuerySet (pokud účastník hlasoval, hlasoval u všech)
2019-05-11 01:15:05 +02:00
for i in request.POST:
2019-05-11 01:49:01 +02:00
if i[0] == 'q':
prednaska = Prednaska.objects.filter(pk=int(i[1:]))[0]
hlasovani = Hlasovani.objects.filter(ucastnik=ucastnik, prednaska=prednaska).first()
if not hlasovani:
hlasovani = Hlasovani()
hlasovani.prednaska = prednaska
hlasovani.ucastnik = ucastnik
hlasovani.seznam = seznam
2019-05-11 01:49:01 +02:00
hlasovani.body = int(request.POST[i])
hlasovani.save()
2019-05-11 01:15:05 +02:00
# presmerovani na prave vzniklou galerii
return HttpResponseRedirect('./hotovo')
def prednaska_hodnoceni(prednaska):
h = Hlasovani.objects.filter(ucastnik=ucastnik, prednaska=prednaska).first()
if h:
return prednaska, h.body
else:
return prednaska, 0
2019-05-11 01:15:05 +02:00
return render(
request,
'prednasky/base.html',
{'prednasky': map(prednaska_hodnoceni, seznam.prednaska_set.all())}
2019-05-11 01:15:05 +02:00
)
2017-10-06 01:37:09 +02:00
2016-04-18 01:14:08 +02:00
2016-04-18 01:27:05 +02:00
def Prednaska_hotovo(request):
2019-05-11 01:15:05 +02:00
return render(request, 'prednasky/hotovo.html')
2016-04-17 23:48:39 +02:00
class MetaSeznamListView(generic.ListView):
2019-05-11 01:15:05 +02:00
model = Seznam
template_name = 'prednasky/metaseznam_prednasek.html'
2017-10-06 01:15:20 +02:00
class SeznamListView(generic.ListView):
2019-05-11 01:15:05 +02:00
template_name = 'prednasky/seznam_prednasek.html'
2017-10-06 01:15:20 +02:00
2019-05-11 01:15:05 +02:00
def get_queryset(self):
self.seznam = get_object_or_404(Seznam, id=self.kwargs["seznam"])
prednasky = Prednaska.objects.filter(seznamy=self.seznam).order_by(
2024-12-10 16:33:25 +01:00
'org__osoba__user__first_name', 'org__osoba__user__last_name'
)
2019-05-11 01:15:05 +02:00
return prednasky
2020-08-19 10:00:04 +02:00
# FIXME nahradit anotaci s filtrem po prechodu na Django 2.2
def get_context_data(self,**kwargs):
context = super(SeznamListView, self).get_context_data(**kwargs)
2020-08-19 10:00:04 +02:00
# hlasovani se vztahuje k nejnovejsimu soustredeni
sous = Soustredeni.objects.first()
seznam = Seznam.objects.filter(soustredeni = sous, stav = STAV_NAVRH).first()
2020-08-19 10:00:04 +02:00
for obj in self.object_list:
hlasovani_set = obj.hlasovani_set.filter(seznam=seznam).only('body')
obj.body = sum(map(lambda x: x.body,hlasovani_set))
2020-08-19 10:00:04 +02:00
return context
2017-10-06 00:37:08 +02:00
def SeznamExportView(request, seznam):
"""Vypíše výsledky hlasování ve formátu pro prologovský optimalizátor"""
2019-05-11 01:15:05 +02:00
# TODO zřejmě se nepoužívá, časem vyřadit? nahradit tabulkou vhodnější pro
# lidi?
hlasovani = Hlasovani.objects.filter(seznam=seznam)
prednasky = Prednaska.objects.filter(seznamy=seznam)
orgove = set(p.org for p in prednasky)
ucastnici = set(h.ucastnik for h in hlasovani)
for p in prednasky:
p.body = []
for u in ucastnici:
try:
p.body.append(hlasovani.get(ucastnik=u, prednaska=p).body)
except ObjectDoesNotExist:
# účastník nehlasoval
p.body.append("?")
for h in hlasovani:
h.ucastnik = hash(h.ucastnik)
return render(
request,
'prednasky/seznam_prednasek_export.txt',
{"hlasovani": hlasovani, "prednasky": prednasky, "orgove": orgove},
content_type="text/plain"
)