2020-03-03 21:48:55 +01:00
|
|
|
from dal import autocomplete
|
|
|
|
from django.shortcuts import get_object_or_404
|
2021-01-26 21:01:19 +01:00
|
|
|
from django.db.models import Q
|
2020-03-03 21:48:55 +01:00
|
|
|
|
|
|
|
import seminar.models as m
|
|
|
|
from .helpers import LoginRequiredAjaxMixin
|
|
|
|
|
2021-10-11 19:18:35 +02:00
|
|
|
# TODO filosofie - zkratky, jak v databázi, tak ve vyhledávání (SPŠE, GASOŠ, Kpt., soukr)
|
2020-03-03 21:48:55 +01:00
|
|
|
class SkolaAutocomplete(autocomplete.Select2QuerySetView):
|
|
|
|
def get_queryset(self):
|
|
|
|
# Don't forget to filter out results depending on the visitor !
|
|
|
|
qs = m.Skola.objects.all()
|
|
|
|
if self.q:
|
2021-10-11 19:18:35 +02:00
|
|
|
words = self.q.split(' ') #TODO re split podle bileho znaku
|
|
|
|
partq = Q()
|
|
|
|
for w in words: # Hledej po slovech, zahoď čárky a tečky z konců.
|
|
|
|
if w[-1] in (".",","):
|
|
|
|
w = w[:-1]
|
|
|
|
|
|
|
|
partq &= (Q(nazev__icontains=w)|Q(kratky_nazev__icontains=w)|Q(ulice__icontains=w)|Q(mesto__icontains=w))
|
|
|
|
qs = qs.filter(partq)
|
2020-03-03 21:48:55 +01:00
|
|
|
|
|
|
|
return qs
|
|
|
|
|
|
|
|
class ResitelAutocomplete(LoginRequiredAjaxMixin,autocomplete.Select2QuerySetView):
|
|
|
|
def get_queryset(self):
|
|
|
|
qs = m.Resitel.objects.all()
|
|
|
|
if self.q:
|
|
|
|
qs = qs.filter(
|
2021-09-16 15:42:56 +02:00
|
|
|
Q(osoba__jmeno__istartswith=self.q)|
|
|
|
|
Q(osoba__prijmeni__istartswith=self.q)|
|
|
|
|
Q(osoba__prezdivka__istartswith=self.q)
|
2020-03-03 21:48:55 +01:00
|
|
|
)
|
|
|
|
return qs
|
|
|
|
|
|
|
|
class OdevzdatelnyProblemAutocomplete(autocomplete.Select2QuerySetView):
|
|
|
|
def get_queryset(self):
|
|
|
|
nastaveni = get_object_or_404(m.Nastaveni)
|
|
|
|
rocnik = nastaveni.aktualni_rocnik
|
2021-09-04 17:43:32 +02:00
|
|
|
# Od tohoto místa dál jsem zkoušel spoustu variací podle https://django-polymorphic.readthedocs.io/en/stable/advanced.html
|
|
|
|
temaQ = Q(Tema___rocnik = rocnik, stav=m.Problem.STAV_ZADANY)
|
2021-09-06 01:12:27 +02:00
|
|
|
ulohaQ = Q(Uloha___cislo_zadani__rocnik = rocnik, stav=m.Problem.STAV_ZADANY)
|
2021-09-04 17:43:32 +02:00
|
|
|
clanekQ = Q(Clanek___cislo__rocnik = rocnik, stav=m.Problem.STAV_ZADANY)
|
|
|
|
qs = m.Problem.objects.filter(temaQ | ulohaQ | clanekQ)
|
|
|
|
#print(temata, ulohy, clanky)
|
|
|
|
#ulohy.union(temata, all=True)
|
|
|
|
#print(ulohy)
|
|
|
|
#ulohy.union(clanky, all=True)
|
|
|
|
#print(ulohy)
|
|
|
|
#qs = ulohy
|
2021-09-02 20:37:42 +02:00
|
|
|
print(qs)
|
2020-03-03 21:48:55 +01:00
|
|
|
if self.q:
|
|
|
|
qs = qs.filter(
|
2021-09-04 21:19:13 +02:00
|
|
|
Q(nazev__icontains=self.q))
|
2020-03-03 21:48:55 +01:00
|
|
|
return qs
|
|
|
|
|
|
|
|
# Ceka na autocomplete v3
|
|
|
|
# class OrganizatorAutocomplete(autocomplete.Select2QuerySetView):
|
|
|
|
# def get_queryset(self):
|
|
|
|
# if not self.request.user.is_authenticated():
|
|
|
|
# return Organizator.objects.none()
|
|
|
|
#
|
|
|
|
# qs = aktivniOrganizatori()
|
|
|
|
#
|
|
|
|
# if self.q:
|
|
|
|
# if self.q[0] == "!":
|
|
|
|
# qs = Organizator.objects.all()
|
|
|
|
# query = self.q[1:]
|
|
|
|
# else:
|
|
|
|
# query = self.q
|
|
|
|
# qs = qs.filter(
|
|
|
|
# Q(prezdivka__isstartswith=query)|
|
|
|
|
# Q(user__first_name__isstartswith=query)|
|
|
|
|
# Q(user__last_name__isstartswith=query))
|
|
|
|
#
|
|
|
|
# return qs
|