2021-11-04 13:49:07 +01:00
|
|
|
from django.shortcuts import render, get_object_or_404
|
2021-11-03 06:19:59 +01:00
|
|
|
from django.contrib.auth.decorators import login_required
|
2021-11-04 13:49:07 +01:00
|
|
|
from django.views.decorators.http import require_http_methods
|
|
|
|
from django.http import HttpResponse, HttpResponseRedirect
|
2021-11-11 15:21:48 +01:00
|
|
|
from django.db.models import Q
|
2021-11-02 14:05:32 +01:00
|
|
|
|
2021-11-17 10:39:16 +01:00
|
|
|
from people.models import Gymnast
|
2021-11-24 13:24:03 +01:00
|
|
|
from .models import Chrono, Point, Accident
|
2021-11-18 21:36:15 +01:00
|
|
|
from .forms import ChronoForm, LearnedSkillForm, ScoreForm, AccidentForm
|
2021-11-13 14:45:02 +01:00
|
|
|
|
|
|
|
import simplejson
|
2021-11-04 13:49:07 +01:00
|
|
|
|
|
|
|
@login_required
|
2021-11-11 15:21:48 +01:00
|
|
|
@require_http_methods(["GET"])
|
2021-11-04 13:49:07 +01:00
|
|
|
def chrono_listing(request):
|
|
|
|
""" Récupère la liste des chronos """
|
2021-11-11 15:21:48 +01:00
|
|
|
|
2021-11-04 13:49:07 +01:00
|
|
|
chrono_list = Chrono.objects.all()
|
|
|
|
context = {'chrono_list': chrono_list}
|
2021-11-17 10:39:16 +01:00
|
|
|
return render(request, "followup/chronos/list.html", context)
|
2021-11-04 13:49:07 +01:00
|
|
|
|
|
|
|
|
|
|
|
@login_required
|
|
|
|
@require_http_methods(["GET", "POST"])
|
2021-11-17 10:39:16 +01:00
|
|
|
def chrono_create_or_update(request, chronoid=None, gymnastid=None):
|
2021-11-11 19:45:39 +01:00
|
|
|
""" Création ou modification d'un chrono """
|
2021-11-04 13:49:07 +01:00
|
|
|
|
|
|
|
if chronoid:
|
|
|
|
chrono = get_object_or_404(Chrono, pk=chronoid)
|
|
|
|
data = {
|
2021-11-17 10:39:16 +01:00
|
|
|
"gymnast": chrono.gymnast.id,
|
|
|
|
"gymnast_related": str(chrono.gymnast),
|
2021-11-04 13:49:07 +01:00
|
|
|
}
|
|
|
|
else:
|
|
|
|
chrono = None
|
|
|
|
data = None
|
|
|
|
|
|
|
|
if request.method == "POST":
|
|
|
|
form = ChronoForm(request.POST, instance=chrono)
|
|
|
|
|
|
|
|
if form.is_valid():
|
2021-11-18 21:36:15 +01:00
|
|
|
new_chrono = form.save(commit=False)
|
2021-11-17 10:39:16 +01:00
|
|
|
# Calcul du ToF
|
2021-11-18 21:36:15 +01:00
|
|
|
if new_chrono.score_type == 1:
|
|
|
|
new_chrono.tof = new_chrono.score
|
2021-11-17 10:39:16 +01:00
|
|
|
else:
|
2021-11-18 21:36:15 +01:00
|
|
|
tof = round(( new_chrono.score * 13 ) / 15, 3) * 1000
|
2021-11-17 10:39:16 +01:00
|
|
|
tof = tof - (tof % 5)
|
2021-11-18 21:36:15 +01:00
|
|
|
new_chrono.tof = tof / 1000
|
2021-11-17 10:39:16 +01:00
|
|
|
|
2021-11-18 21:36:15 +01:00
|
|
|
new_chrono.save()
|
|
|
|
return HttpResponseRedirect("/gymnast/details/" + str(new_chrono.gymnast.id) + "/")
|
2021-11-04 13:49:07 +01:00
|
|
|
|
|
|
|
else:
|
2021-11-17 10:39:16 +01:00
|
|
|
if data is None and gymnastid is not None:
|
|
|
|
gymnast = get_object_or_404(Gymnast, pk=gymnastid)
|
|
|
|
data = {"gymnast": gymnastid, "gymnast_related": gymnast}
|
2021-11-04 13:49:07 +01:00
|
|
|
|
|
|
|
form = ChronoForm(instance=chrono, initial=data)
|
|
|
|
|
|
|
|
context = {"form": form, "chronoid": chronoid}
|
2021-11-17 10:39:16 +01:00
|
|
|
return render(request, "followup/chronos/create.html", context)
|
2021-11-11 15:21:48 +01:00
|
|
|
|
|
|
|
|
2021-11-13 14:45:02 +01:00
|
|
|
@login_required
|
|
|
|
@require_http_methods(["GET", "POST"])
|
2021-11-17 10:39:16 +01:00
|
|
|
def learnedskill_create_or_update(request, gymnastid=None):
|
2021-11-13 14:45:02 +01:00
|
|
|
"""
|
|
|
|
Formulaire de creation et modification d'un lien skill/gymnaste.
|
|
|
|
"""
|
|
|
|
|
2021-11-17 10:39:16 +01:00
|
|
|
if gymnastid:
|
|
|
|
gymnast = get_object_or_404(Gymnast, pk=gymnastid)
|
2021-11-13 14:45:02 +01:00
|
|
|
data = {
|
2021-11-17 10:39:16 +01:00
|
|
|
"gymnast": gymnast.id,
|
|
|
|
"gymnast_related": str(gymnast),
|
2021-11-13 14:45:02 +01:00
|
|
|
}
|
|
|
|
else:
|
|
|
|
data = {}
|
|
|
|
|
|
|
|
if request.method == "POST":
|
|
|
|
learnedskill_form = LearnedSkillForm(request.POST)
|
|
|
|
|
|
|
|
if learnedskill_form.is_valid():
|
|
|
|
learnedskill_form.save()
|
2021-11-17 10:39:16 +01:00
|
|
|
return HttpResponseRedirect("/gymnast/details/" + str(learnedskill_form.cleaned_data['gymnast'].id))
|
2021-11-13 14:45:02 +01:00
|
|
|
else:
|
|
|
|
print(learnedskill_form.errors)
|
|
|
|
|
|
|
|
form = LearnedSkillForm(initial=data)
|
|
|
|
|
2021-11-17 10:39:16 +01:00
|
|
|
context = {"form": form, "gymnastid": gymnastid}
|
|
|
|
return render(request, "followup/learnedskills/create.html", context)
|
|
|
|
|
|
|
|
|
|
|
|
@login_required
|
|
|
|
@require_http_methods(["GET", "POST"])
|
|
|
|
def score_create_or_update(request, scoreid=None, gymnastid=None):
|
|
|
|
"""
|
|
|
|
Formulaire de création d'un nouveau score.
|
|
|
|
"""
|
|
|
|
|
|
|
|
if scoreid:
|
|
|
|
score = get_object_or_404(Point, pk=scoreid)
|
|
|
|
data = {
|
|
|
|
"gymnast_related": str(score.gymnast),
|
|
|
|
"event_related": str(score.event),
|
|
|
|
}
|
|
|
|
else:
|
|
|
|
score = None
|
|
|
|
data = {}
|
|
|
|
if gymnastid is not None:
|
|
|
|
gymnast = get_object_or_404(Gymnast, pk=gymnastid)
|
|
|
|
data["gymnast"] = gymnastid
|
|
|
|
data["gymnast_related"] = str(gymnast)
|
|
|
|
|
|
|
|
if request.method == "POST":
|
|
|
|
form = ScoreForm(request.POST, instance=score)
|
|
|
|
|
|
|
|
if form.is_valid():
|
2021-11-24 13:24:03 +01:00
|
|
|
print(form.cleaned_data)
|
2021-11-17 10:39:16 +01:00
|
|
|
form.save()
|
|
|
|
return HttpResponseRedirect(
|
2021-11-24 13:24:03 +01:00
|
|
|
# "/gymnast/" + str(form.cleaned_data["gymnast"].id) + "/tab/scores/"
|
|
|
|
"/gymnast/details/" + str(form.cleaned_data["gymnast"].id) + "/"
|
2021-11-17 10:39:16 +01:00
|
|
|
)
|
|
|
|
# return HttpResponseRedirect("/score/")
|
2021-11-24 13:24:03 +01:00
|
|
|
else:
|
|
|
|
print(form.errors)
|
2021-11-17 10:39:16 +01:00
|
|
|
else:
|
|
|
|
form = ScoreForm(instance=score, initial=data)
|
|
|
|
|
|
|
|
context = {"form": form, "scoreid": scoreid}
|
|
|
|
return render(request, "followup/scores/create.html", context)
|
|
|
|
|
|
|
|
|
|
|
|
@login_required
|
|
|
|
@require_http_methods(["GET"])
|
|
|
|
def score_listing(request):
|
|
|
|
"""
|
|
|
|
Revoie la liste des scores
|
|
|
|
"""
|
|
|
|
|
|
|
|
pattern = request.GET.get("pattern", None)
|
|
|
|
|
|
|
|
if pattern:
|
|
|
|
score_list = Point.objects.filter(
|
|
|
|
Q(event__icontains=pattern) | Q(gymnast__icontains=pattern)
|
|
|
|
)
|
|
|
|
else:
|
|
|
|
score_list = Point.objects.all()
|
|
|
|
|
|
|
|
context = {"score_list": score_list}
|
|
|
|
return render(request, "followup/scores/list.html", context)
|
2021-11-18 21:36:15 +01:00
|
|
|
|
|
|
|
|
|
|
|
@login_required
|
|
|
|
@require_http_methods(["GET"])
|
|
|
|
def accident_listing(request):
|
|
|
|
"""
|
|
|
|
Récupère la liste des accidents suivant un pattern si celui-ci est définit.
|
|
|
|
"""
|
|
|
|
pattern = request.GET.get("pattern", None)
|
|
|
|
|
|
|
|
if pattern:
|
|
|
|
accident_list = Accident.objects.filter(
|
|
|
|
Q(gymnast__lastname__icontains=pattern)
|
|
|
|
| Q(gymnast__firstname__icontains=pattern)
|
|
|
|
)
|
|
|
|
else:
|
|
|
|
accident_list = Accident.objects.all()
|
|
|
|
|
|
|
|
context = {"accident_list": accident_list}
|
|
|
|
return render(request, "followup/accidents/list.html", context)
|
|
|
|
|
|
|
|
|
|
|
|
@login_required
|
|
|
|
@require_http_methods(["GET", "POST"])
|
|
|
|
def accident_create_or_update(request, accidentid=None):
|
|
|
|
"""
|
|
|
|
Formulaire de création d'un nouvel accident.
|
|
|
|
"""
|
|
|
|
|
|
|
|
if accidentid:
|
|
|
|
accident = get_object_or_404(Accident, pk=accidentid)
|
|
|
|
data = {
|
|
|
|
"gymnast_related": accident.gymnast,
|
2021-11-21 10:45:55 +01:00
|
|
|
# "educative_related": accident.educative,
|
2021-11-18 21:36:15 +01:00
|
|
|
}
|
|
|
|
else:
|
|
|
|
accident = None
|
|
|
|
data = {}
|
|
|
|
|
|
|
|
if request.method == "POST":
|
|
|
|
form = AccidentForm(request.POST, instance=accident)
|
|
|
|
|
|
|
|
if form.is_valid():
|
|
|
|
form.save()
|
|
|
|
if accidentid:
|
|
|
|
return HttpResponseRedirect("/accident/" + str(accidentid) + "/")
|
|
|
|
else:
|
|
|
|
return HttpResponseRedirect("/accident/")
|
|
|
|
else:
|
|
|
|
|
|
|
|
form = AccidentForm(instance=accident, initial=data)
|
|
|
|
|
|
|
|
context = {"form": form, "accidentid": accidentid}
|
|
|
|
return render(request, "followup/accidents/create.html", context)
|
|
|
|
|
|
|
|
|
|
|
|
@login_required
|
|
|
|
@require_http_methods(["GET"])
|
|
|
|
def accident_detail(request, accidentid):
|
|
|
|
"""
|
|
|
|
Récupère toutes les informations d'un accident.
|
|
|
|
"""
|
|
|
|
accident = get_object_or_404(Accident, pk=accidentid)
|
|
|
|
context = {"accident": accident}
|
|
|
|
return render(request, "followup/accidents/details.html", context)
|
|
|
|
|