forked from DGNum/gestioCOF
Use form to clean data
This commit is contained in:
parent
205dc93f4b
commit
49591fa67e
1 changed files with 24 additions and 19 deletions
|
@ -15,7 +15,7 @@ from django.contrib.messages.views import SuccessMessageMixin
|
||||||
from django.db import transaction
|
from django.db import transaction
|
||||||
from django.db.models import Count, F, Prefetch, Q, Sum
|
from django.db.models import Count, F, Prefetch, Q, Sum
|
||||||
from django.forms import formset_factory
|
from django.forms import formset_factory
|
||||||
from django.http import Http404, JsonResponse
|
from django.http import Http404, HttpResponseBadRequest, JsonResponse
|
||||||
from django.shortcuts import get_object_or_404, redirect, render
|
from django.shortcuts import get_object_or_404, redirect, render
|
||||||
from django.urls import reverse, reverse_lazy
|
from django.urls import reverse, reverse_lazy
|
||||||
from django.utils import timezone
|
from django.utils import timezone
|
||||||
|
@ -1407,12 +1407,17 @@ def cancel_operations(request):
|
||||||
@login_required
|
@login_required
|
||||||
def history_json(request):
|
def history_json(request):
|
||||||
# Récupération des paramètres
|
# Récupération des paramètres
|
||||||
from_date = request.POST.get("from", None)
|
form = FilterHistoryForm(request.GET)
|
||||||
to_date = request.POST.get("to", None)
|
|
||||||
checkouts = request.POST.getlist("checkouts[]", None)
|
if not form.is_valid():
|
||||||
accounts = request.POST.getlist("accounts[]", None)
|
return HttpResponseBadRequest()
|
||||||
transfers_only = request.POST.get("transfersonly", False)
|
|
||||||
opes_only = request.POST.get("opesonly", False)
|
start = form.cleaned_data["start"]
|
||||||
|
end = form.cleaned_data["end"]
|
||||||
|
account = form.cleaned_data["account"]
|
||||||
|
checkout = form.cleaned_data["checkout"]
|
||||||
|
transfers_only = form.cleaned_data["transfers_only"]
|
||||||
|
opes_only = form.cleaned_data["opes_only"]
|
||||||
|
|
||||||
# Construction de la requête (sur les transferts) pour le prefetch
|
# Construction de la requête (sur les transferts) pour le prefetch
|
||||||
|
|
||||||
|
@ -1421,9 +1426,9 @@ def history_json(request):
|
||||||
)
|
)
|
||||||
|
|
||||||
# Le check sur les comptes est dans le prefetch pour les transferts
|
# Le check sur les comptes est dans le prefetch pour les transferts
|
||||||
if accounts:
|
if account:
|
||||||
transfer_queryset_prefetch = transfer_queryset_prefetch.filter(
|
transfer_queryset_prefetch = transfer_queryset_prefetch.filter(
|
||||||
Q(from_acc__in=accounts) | Q(to_acc__in=accounts)
|
Q(from_acc=account) | Q(to_acc=account)
|
||||||
)
|
)
|
||||||
|
|
||||||
if not request.user.has_perm("kfet.is_team"):
|
if not request.user.has_perm("kfet.is_team"):
|
||||||
|
@ -1458,21 +1463,21 @@ def history_json(request):
|
||||||
)
|
)
|
||||||
|
|
||||||
# Application des filtres
|
# Application des filtres
|
||||||
if from_date:
|
if start:
|
||||||
opegroups = opegroups.filter(at__gte=from_date)
|
opegroups = opegroups.filter(at__gte=start)
|
||||||
transfergroups = transfergroups.filter(at__gte=from_date)
|
transfergroups = transfergroups.filter(at__gte=start)
|
||||||
if to_date:
|
if end:
|
||||||
opegroups = opegroups.filter(at__lt=to_date)
|
opegroups = opegroups.filter(at__lt=end)
|
||||||
transfergroups = transfergroups.filter(at__lt=to_date)
|
transfergroups = transfergroups.filter(at__lt=end)
|
||||||
if checkouts:
|
if checkout:
|
||||||
opegroups = opegroups.filter(checkout__in=checkouts)
|
opegroups = opegroups.filter(checkout__in=checkout)
|
||||||
transfergroups = TransferGroup.objects.none()
|
transfergroups = TransferGroup.objects.none()
|
||||||
if transfers_only:
|
if transfers_only:
|
||||||
opegroups = OperationGroup.objects.none()
|
opegroups = OperationGroup.objects.none()
|
||||||
if opes_only:
|
if opes_only:
|
||||||
transfergroups = TransferGroup.objects.none()
|
transfergroups = TransferGroup.objects.none()
|
||||||
if accounts:
|
if account:
|
||||||
opegroups = opegroups.filter(on_acc__in=accounts)
|
opegroups = opegroups.filter(on_acc=account)
|
||||||
# Un non-membre de l'équipe n'a que accès à son historique
|
# Un non-membre de l'équipe n'a que accès à son historique
|
||||||
if not request.user.has_perm("kfet.is_team"):
|
if not request.user.has_perm("kfet.is_team"):
|
||||||
opegroups = opegroups.filter(on_acc=request.user.profile.account_kfet)
|
opegroups = opegroups.filter(on_acc=request.user.profile.account_kfet)
|
||||||
|
|
Loading…
Reference in a new issue