2022-02-15 17:48:16 +01:00
|
|
|
"""
|
|
|
|
Soubor sloužící k deklaraci jednotlivých „views“ (nejčastěji funkce beroucí request
|
|
|
|
a vracející :func:`django.shortcuts.render` respektive nějakou response, nebo
|
|
|
|
třídy většinou rozšiřující nějakou třídu z :mod:`django.views.generic`)
|
|
|
|
"""
|
2021-10-05 00:25:15 +02:00
|
|
|
import django
|
|
|
|
from django.shortcuts import get_object_or_404
|
2015-06-29 00:27:02 +02:00
|
|
|
from django.http import HttpResponse
|
2019-06-10 23:55:45 +02:00
|
|
|
from django.urls import reverse
|
2015-05-06 17:07:32 +02:00
|
|
|
from django.views import generic
|
2015-06-29 00:27:02 +02:00
|
|
|
from django.utils.encoding import force_text
|
|
|
|
|
2021-10-05 00:25:15 +02:00
|
|
|
from .utils import default_ovvpfile
|
|
|
|
from seminar.models import Rocnik, Soustredeni
|
2021-10-07 19:30:28 +02:00
|
|
|
from vysledkovky import utils
|
2020-06-26 13:02:09 +02:00
|
|
|
from seminar.utils import aktivniResitele
|
2015-06-29 00:27:02 +02:00
|
|
|
|
|
|
|
class ExportIndexView(generic.View):
|
2020-06-03 23:25:02 +02:00
|
|
|
def get(self, request):
|
|
|
|
ls = []
|
|
|
|
for r in Rocnik.objects.filter(exportovat = True):
|
|
|
|
url = reverse('seminar_export_rocnik', kwargs={'prvni_rok': r.prvni_rok})
|
|
|
|
ls.append(url.split('/')[-1])
|
|
|
|
for s in Soustredeni.objects.filter(exportovat = True):
|
|
|
|
url = reverse('seminar_export_sous', kwargs={'datum_zacatku': s.datum_zacatku.isoformat()})
|
|
|
|
ls.append(url.split('/')[-1])
|
2015-06-29 00:27:02 +02:00
|
|
|
|
2020-06-03 23:25:02 +02:00
|
|
|
return HttpResponse('\n'.join(ls) + '\n', content_type='text/plain; charset=utf-8')
|
2015-05-06 17:07:32 +02:00
|
|
|
|
|
|
|
|
2015-06-29 00:27:02 +02:00
|
|
|
class ExportSousView(generic.View):
|
|
|
|
|
2020-06-03 23:25:02 +02:00
|
|
|
def get(self, request, datum_zacatku=None):
|
|
|
|
try:
|
|
|
|
dz = django.utils.dateparse.parse_date(datum_zacatku)
|
|
|
|
except:
|
|
|
|
dz = None
|
|
|
|
if dz is None:
|
|
|
|
raise django.http.Http404()
|
|
|
|
|
|
|
|
s = get_object_or_404(Soustredeni, datum_zacatku=dz, exportovat=True)
|
|
|
|
|
|
|
|
akce = {Soustredeni.TYP_JARNI: 'MaM.sous.jaro',
|
|
|
|
Soustredeni.TYP_PODZIMNI: 'MaM.sous.podzim',
|
|
|
|
Soustredeni.TYP_VIKEND: 'MaM.vikend',
|
|
|
|
}[s.typ]
|
|
|
|
|
|
|
|
of = default_ovvpfile(akce, s.rocnik)
|
|
|
|
of.headers['x-event-begin'] = s.datum_zacatku.isoformat()
|
|
|
|
of.headers['x-event-end'] = s.datum_konce.isoformat()
|
|
|
|
of.headers['x-event-location'] = s.misto
|
|
|
|
of.headers['comment'] = u'MaM-Web export ucastniku soustredeni v {x-event-location} od {x-event-begin} do {x-event-end}'.format(**of.headers)
|
|
|
|
of.columns = ['id', 'name', 'surname', 'gender', 'email', 'end-year', 'school', 'school-name']
|
|
|
|
|
|
|
|
for u in s.ucastnici.all():
|
|
|
|
of.rows.append(u.export_row())
|
|
|
|
|
|
|
|
return of.to_HttpResponse()
|
|
|
|
|
|
|
|
# POZOR! Předělání na nový model neotestováno v reálu (ale zase jen drobné změny)
|
2015-06-29 00:27:02 +02:00
|
|
|
class ExportRocnikView(generic.View):
|
|
|
|
|
2020-06-03 23:25:02 +02:00
|
|
|
def get(self, request, prvni_rok=None):
|
|
|
|
try:
|
|
|
|
pr = int(prvni_rok)
|
|
|
|
except:
|
|
|
|
pr = None
|
|
|
|
if pr is None:
|
|
|
|
raise django.http.Http404()
|
|
|
|
|
|
|
|
rocnik = get_object_or_404(Rocnik, prvni_rok=pr, exportovat=True)
|
|
|
|
cislo = rocnik.posledni_zverejnena_vysledkovka_cislo()
|
2020-06-26 13:02:09 +02:00
|
|
|
resitele = aktivniResitele(cislo, True)
|
2021-10-07 19:30:28 +02:00
|
|
|
slovnik_body = utils.secti_body_za_rocnik(cislo, resitele, False)
|
|
|
|
setrizeni_resitele, body = utils.setrid_resitele_a_body(slovnik_body)
|
2020-06-03 23:25:02 +02:00
|
|
|
|
|
|
|
of = default_ovvpfile('MaM.rocnik', rocnik)
|
|
|
|
of.headers['comment'] = u'MaM-Web export aktivnich resitelu rocniku {rocnik} do cisla {cislo}'.format(rocnik=rocnik, cislo=cislo)
|
|
|
|
of.columns = ['id', 'name', 'surname', 'gender', 'born', 'email', 'end-year',
|
|
|
|
'street', 'town', 'postcode', 'country', 'spam-flag', 'spam-date',
|
|
|
|
'school', 'school-name', 'points', 'rank',]
|
2021-05-25 20:07:45 +02:00
|
|
|
|
|
|
|
resitele_slovnik = {}
|
|
|
|
for r in resitele:
|
|
|
|
resitele_slovnik[r.id] = r
|
|
|
|
|
2020-06-03 23:25:02 +02:00
|
|
|
# počítání pořadí řešitelů
|
|
|
|
posledni_body = 100000
|
|
|
|
posledni_poradi = 0
|
|
|
|
for i in range(len(setrizeni_resitele)):
|
2021-05-25 20:07:45 +02:00
|
|
|
rd = resitele_slovnik[setrizeni_resitele[i]].export_row()
|
2020-06-03 23:25:02 +02:00
|
|
|
|
|
|
|
if posledni_body > body[i]:
|
|
|
|
posledni_body = body[i]
|
|
|
|
posledni_poradi = i + 1
|
|
|
|
rd['rank'] = posledni_poradi
|
|
|
|
rd['points'] = body[i]
|
|
|
|
|
|
|
|
of.rows.append(rd)
|
|
|
|
|
|
|
|
return of.to_HttpResponse()
|