Sith/counter/views/student_card.py

114 lines
3.9 KiB
Python
Raw Normal View History

#
# Copyright 2023 © AE UTBM
# ae@utbm.fr / ae.info@utbm.fr
#
# This file is part of the website of the UTBM Student Association (AE UTBM),
# https://ae.utbm.fr.
#
# You can find the source code of the website at https://github.com/ae-utbm/sith
#
# LICENSED UNDER THE GNU GENERAL PUBLIC LICENSE VERSION 3 (GPLv3)
2024-09-23 08:25:27 +00:00
# SEE : https://raw.githubusercontent.com/ae-utbm/sith/master/LICENSE
# OR WITHIN THE LOCAL FILE "LICENSE"
#
#
2024-12-07 16:28:34 +00:00
2024-06-24 11:07:36 +00:00
from django.core.exceptions import PermissionDenied
from django.http import Http404, HttpRequest, HttpResponse
2024-12-06 23:06:33 +00:00
from django.shortcuts import get_object_or_404
from django.urls import reverse
from django.utils.translation import gettext as _
2024-12-06 23:06:33 +00:00
from django.views.generic.edit import DeleteView, FormView
2016-03-28 12:54:35 +00:00
from core.auth.mixins import can_edit
from core.utils import FormFragmentTemplateData
2024-12-06 23:06:33 +00:00
from counter.forms import StudentCardForm
2024-12-07 16:28:34 +00:00
from counter.models import Customer, StudentCard
from counter.utils import is_logged_in_counter
2024-10-06 11:22:09 +00:00
2017-06-12 07:47:24 +00:00
class StudentCardDeleteView(DeleteView):
"""View used to delete a card from a user. This is a fragment view !"""
model = StudentCard
template_name = "counter/fragments/delete_student_card.jinja"
def dispatch(self, request: HttpRequest, *args, **kwargs):
self.customer = get_object_or_404(Customer, pk=kwargs["customer_id"])
if not is_logged_in_counter(request) and not can_edit(
self.get_object(), request.user
):
raise PermissionDenied()
2024-06-27 12:46:43 +00:00
return super().dispatch(request, *args, **kwargs)
def get_context_data(self, **kwargs):
context = super().get_context_data(**kwargs)
context["action"] = self.request.path
context["action_cancel"] = self.get_success_url()
return context
def get_object(self, queryset=None):
if not hasattr(self.customer, "student_card"):
raise Http404(
_("%(name)s has no registered student card")
% {"name": self.customer.user.get_full_name()}
)
return self.customer.student_card
def get_success_url(self, **kwargs):
return reverse(
"counter:add_student_card", kwargs={"customer_id": self.customer.pk}
)
2024-12-07 16:28:34 +00:00
class StudentCardFormView(FormView):
"""Add a new student card. This is a fragment view !"""
form_class = StudentCardForm
2024-12-07 16:28:34 +00:00
template_name = "counter/fragments/create_student_card.jinja"
2024-12-07 23:32:28 +00:00
@classmethod
def get_template_data(
cls, customer: Customer, *, form_instance: form_class | None = None
) -> FormFragmentTemplateData[form_class]:
2024-12-07 23:32:28 +00:00
"""Get necessary data to pre-render the fragment"""
2024-12-17 00:41:45 +00:00
return FormFragmentTemplateData(
form=form_instance if form_instance else cls.form_class(),
2024-12-07 23:32:28 +00:00
template=cls.template_name,
context={
"action": reverse(
2024-12-07 23:32:28 +00:00
"counter:add_student_card", kwargs={"customer_id": customer.pk}
),
"customer": customer,
},
)
2024-12-07 16:28:34 +00:00
def dispatch(self, request: HttpRequest, *args, **kwargs):
self.customer = get_object_or_404(
Customer.objects.select_related("student_card"), pk=kwargs["customer_id"]
)
2024-12-07 16:28:34 +00:00
if not is_logged_in_counter(request) and not StudentCard.can_create(
self.customer, request.user
):
raise PermissionDenied
2024-12-07 16:28:34 +00:00
return super().dispatch(request, *args, **kwargs)
def form_valid(self, form: StudentCardForm) -> HttpResponse:
data = form.clean()
StudentCard.objects.update_or_create(
customer=self.customer, defaults={"uid": data["uid"]}
)
return super().form_valid(form)
def get_context_data(self, **kwargs):
context = super().get_context_data(**kwargs)
data = self.get_template_data(self.customer, form_instance=context["form"])
2024-12-07 23:32:28 +00:00
context.update(data.context)
return context
def get_success_url(self, **kwargs):
2024-12-07 16:28:34 +00:00
return self.request.path