Bug: Affichage des details de la reservation

This commit is contained in:
2026-04-30 13:59:00 +02:00
committed by Soriba SYLLA
parent 6026af5498
commit ab87baaa3a
3 changed files with 101 additions and 73 deletions

View File

@@ -170,9 +170,9 @@ tableau_reservation_attente.on("rowClick", (row, rowData) => {
$("lien_zoom_container").className = 'd-none'; $("lien_zoom_container").className = 'd-none';
} }
if(data.statut !== "refusee"){ // if(data.statut !== "refusee"){
$("motif_refus_container").className = 'd-none'; // $("motif_refus_container").className = 'd-none';
} // }
$("id_reservation_detail").value = data.id; $("id_reservation_detail").value = data.id;
$("id_reservation_refus").value = data.id; $("id_reservation_refus").value = data.id;
@@ -181,14 +181,15 @@ tableau_reservation_attente.on("rowClick", (row, rowData) => {
$("employe").value=data.employe; $("employe").value=data.employe;
$("salle").value=data.salle; $("salle").value=data.salle;
$("statut-reservation").innerHTML=data.statut; $("statut-reservation").innerHTML=data.statut;
$("date_evenement").value=data.date_debut; $("date_debut").value = data.date_debut;
$("date_fin").value = data.date_fin;
$("heure_debut").value=data.heure_debut; $("heure_debut").value=data.heure_debut;
$("heure_fin").value=data.heure_fin; $("heure_fin").value=data.heure_fin;
$("motif_reservation").value=data.motif_reservation; $("motif_reservation").value=data.motif_reservation;
$("besoin_zoom").checked=data.besoin_zoom; $("besoin_zoom").checked=data.besoin_zoom;
$("besoin_ordinateur").checked=data.besoin_ordi; $("besoin_ordinateur").checked=data.besoin_ordi;
$("lien_zoom").value=data.lien_zoom; $("lien_zoom").value=data.lien_zoom;
$("motif_refus").value=data.motif_refus; // $("motif_refus").value=data.motif_refus;
const modal = new bootstrap.Modal($("modalDetailReservation")); const modal = new bootstrap.Modal($("modalDetailReservation"));
bootstrap.Modal.getOrCreateInstance($("modalReservationAttente")).hide(); bootstrap.Modal.getOrCreateInstance($("modalReservationAttente")).hide();

View File

@@ -21,8 +21,12 @@
<input class="form-control" id="salle" readonly> <input class="form-control" id="salle" readonly>
</div> </div>
<div class="form-group mb-2"> <div class="form-group mb-2">
<label>Date de l'évènement :</label> <label>Date de debut :</label>
<input type='date' class="form-control" id="date_evenement" readonly > <input type='date' class="form-control" id="date_debut" readonly >
</div>
<div class="form-group mb-2">
<label>Date de fin :</label>
<input type='date' class="form-control" id="date_fin" readonly >
</div> </div>
<div class="form-group mb-2"> <div class="form-group mb-2">
<label>Heure de début :</label> <label>Heure de début :</label>
@@ -48,21 +52,16 @@
<label label="form-check-label">Besoin d'un ordinateur</label> <label label="form-check-label">Besoin d'un ordinateur</label>
<input type="checkbox" class="form-check-input" id="besoin_ordinateur" readonly > <input type="checkbox" class="form-check-input" id="besoin_ordinateur" readonly >
</div> </div>
<div class="form-group mb-2" id='motif_refus_container'>
<label>Motif de refus de la reservation :</label>
<textarea class="form-control" id="motif_refus" readonly></textarea>
</div>
<div class='d-flex justify-content-around mt-2'> <div class='d-flex justify-content-around mt-2'>
{% if appartient_au_departement_informatique %} {% if appartient_au_departement_informatique %}
<button class="btn btn-primary" id="ajoutZoom">Ajout du lien zoom</button> <button class="btn btn-primary" id="ajoutZoom">Ajout du lien zoom</button>
{% endif %} {% endif %}
{% if appartient_direction and reservation.statut == "en_attente" %} {% if appartient_direction and reservation.statut == "en_attente" %}
<button class="btn btn-danger" id="refuserReservation" data-lienrefus="{% url 'gestion_salle:refuser-reservation' %}">Refuser</button> <button class="btn btn-danger" id="refuserReservation" data-lienrefus="{% url 'gestion_salle:refuser-reservation' %}">Refuser</button>
{% endif %}
<button class="btn btn-danger" id="bouton-annuler">Annuler</button>
{% if appartient_direction %}
<button class="btn btn-success" id="bouton-valider">Valider</button> <button class="btn btn-success" id="bouton-valider">Valider</button>
{% endif %} {% endif %}
<span id="current-user-id" data-user-id="{{ request.user.id }}"></span>
<button class="btn btn-danger" id="bouton-annuler">Annuler</button>
</div> </div>
</form> </form>
</div> </div>

View File

@@ -1,4 +1,3 @@
import json
from datetime import timedelta from datetime import timedelta
from django.contrib import messages from django.contrib import messages
from django.contrib.auth.decorators import login_required from django.contrib.auth.decorators import login_required
@@ -10,71 +9,97 @@ from gestion_employe.models import Employe
from gestion_salle.forms import ReservationForm from gestion_salle.forms import ReservationForm
from .models import Reservation from .models import Reservation
@login_required @login_required
def index(request:HttpRequest): def index(request: HttpRequest):
"""Vue de gestion de la reservation de la salle"""
try: try:
employe = Employe.objects.get(user=request.user) employe = Employe.objects.get(user=request.user)
except Employe.DoesNotExist: except Employe.DoesNotExist:
messages.error(request, "Impossible d'accéder au menu 'Reservation de salle' car votre profil Utilisateur n'est lié à aucun profil Employe. Veuillez contacter l'administrateur.") messages.error(request, "Profil employé introuvable.")
return redirect('gestion_conges:conge') return redirect('gestion_conges:conge')
if request.method == "POST": if request.method == "POST":
form = ReservationForm(request.POST) form = ReservationForm(request.POST)
if form.is_valid(): if form.is_valid():
date_debut = form.cleaned_data.get('date_debut') date_debut = form.cleaned_data['date_debut']
date_fin = form.cleaned_data.get('date_fin') date_fin = form.cleaned_data['date_fin']
salle = form.cleaned_data.get('salle') salle = form.cleaned_data['salle']
heure_debut = form.cleaned_data.get('heure_debut') heure_debut = form.cleaned_data['heure_debut']
heure_fin = form.cleaned_data.get('heure_fin') heure_fin = form.cleaned_data['heure_fin']
motif_reservation = form.cleaned_data.get('motif_reservation') motif = form.cleaned_data['motif_reservation']
besoin_zoom = form.cleaned_data.get('besoin_zoom') besoin_zoom = form.cleaned_data['besoin_zoom']
besoin_ordi = form.cleaned_data.get('besoin_ordi') besoin_ordi = form.cleaned_data['besoin_ordi']
while date_debut <= date_fin : if date_fin < date_debut:
reservation = Reservation( messages.error(request, "Date fin invalide.")
employe = employe, return redirect('gestion_salle:reservation-salle')
date_debut = date_debut,
date_fin = date_debut, if heure_fin <= heure_debut:
salle = salle, messages.error(request, "Heure invalide.")
heure_debut = heure_debut, return redirect('gestion_salle:reservation-salle')
heure_fin = heure_fin,
besoin_zoom = besoin_zoom, if not request.user.first_name.strip() or not request.user.last_name.strip():
besoin_ordi = besoin_ordi, messages.error(
motif_reservation=motif_reservation, request,
"Veuillez renseigner votre nom et prénom pour pouvoir faire une réservation."
) )
reservation.save() return redirect('gestion_salle:reservation-salle')
date_debut = date_debut + timedelta(days=1)
messages.success(request, "Réservation(s) créées avec succès.") created = []
current_date = date_debut
while current_date <= date_fin:
reservation = Reservation.objects.create(
employe=employe,
date_debut=current_date,
date_fin=current_date,
salle=salle,
heure_debut=heure_debut,
heure_fin=heure_fin,
besoin_zoom=besoin_zoom,
besoin_ordi=besoin_ordi,
motif_reservation=motif,
statut="en_attente"
)
created.append(reservation)
current_date += timedelta(days=1)
messages.success(request, "Réservation(s) créée(s) avec succès.")
if fonctions_utilitaire.EMAIL_ASSISTANTE_DE_DIRECTION: if fonctions_utilitaire.EMAIL_ASSISTANTE_DE_DIRECTION:
fonctions_utilitaire.envoyer_mail( fonctions_utilitaire.envoyer_mail(
sujet = "Reservation de salle", sujet = "Reservation de salle",
message = f""" message = f"""
Une nouvelle demande de réservation de la {dict(Reservation.TYPE_CHOICES).get(salle)} a été effectuée par {employe.user.first_name} {employe.user.last_name} du {form.cleaned_data.get('date_debut').strftime('%d/%m/%Y')} au {form.cleaned_data.get('date_fin').strftime('%d/%m/%Y')} pour motif "{motif_reservation}". Une nouvelle demande de réservation de la {dict(Reservation.TYPE_CHOICES).get(salle)} a été effectuée par {employe.user.first_name} {employe.user.last_name} du {form.cleaned_data.get('date_debut').strftime('%d/%m/%Y')} au {form.cleaned_data.get('date_fin').strftime('%d/%m/%Y')} pour motif "{motif}".
Veuillez vous connecter à la plateforme pour plus de détails.""", Veuillez vous connecter à la plateforme pour plus de détails.""",
destinataires = list(fonctions_utilitaire.EMAIL_ASSISTANTE_DE_DIRECTION) destinataires = list(fonctions_utilitaire.EMAIL_ASSISTANTE_DE_DIRECTION)
) )
return redirect('gestion_salle:reservation-salle') return redirect('gestion_salle:reservation-salle')
formulaire_reservation = ReservationForm() formulaire_reservation = ReservationForm()
departement = Employe.objects.get(user__username=request.user).departement departement = employe.departement
appartient_direction = 'direction' in request.user.groups.values_list('name', flat=True)
liste_demande_reservation = [ appartient_direction = request.user.groups.filter(name='direction').exists()
reservation.id for reservation in
Reservation.objects.filter(employe=employe, statut='en_attente') liste_demande_reservation = Reservation.objects.filter(
] employe=employe,
statut='en_attente'
).values_list('id', flat=True)
context = { context = {
'formulaire_reservation': formulaire_reservation, 'formulaire_reservation': formulaire_reservation,
'nb_reservation_attente': Reservation.objects.filter(statut='en_attente').count(), 'nb_reservation_attente': Reservation.objects.filter(statut='en_attente').count(),
'appartient_au_departement_informatique': 'Informatique' == departement.nom if departement else False, 'appartient_au_departement_informatique': departement and departement.nom == "Systeme informatique",
'appartient_direction': appartient_direction, 'appartient_direction': appartient_direction,
'liste_demande_reservation': liste_demande_reservation 'liste_demande_reservation': list(liste_demande_reservation),
} }
return render(request, "gestion_salle/index.html", context)
return render(request, "gestion_salle/index.html", context)
def liste_reservation(request:HttpRequest): def liste_reservation(request:HttpRequest):
"""Vue d'affichage des creneaux disponibles""" """Vue d'affichage des creneaux disponibles"""
reservations = Reservation.objects.filter(statut = "validee") reservations = Reservation.objects.filter(statut = "validee")
@@ -96,7 +121,6 @@ def liste_reservation(request:HttpRequest):
"end": reservation.heure_fin, "end": reservation.heure_fin,
"color": color, "color": color,
}) })
return JsonResponse(liste_reservation, safe=False) return JsonResponse(liste_reservation, safe=False)
@login_required @login_required
@@ -113,10 +137,12 @@ def liste_reservation_attente(request):
return JsonResponse(liste_reservation, safe=False) return JsonResponse(liste_reservation, safe=False)
def detail_reservation(request:HttpRequest, reservation_id:int): def detail_reservation(request:HttpRequest, reservation_id:int):
reservation = Reservation.objects.get(id=reservation_id) reservation = Reservation.objects.get(id=reservation_id)
employe = reservation.employe.user employe = reservation.employe.user
reservation_json = { reservation_json = {
'id_reservation': reservation_id, 'id_reservation': reservation_id,
'employe': f"{employe.first_name} {employe.last_name}", 'employe': f"{employe.first_name} {employe.last_name}",
'salle': reservation.salle, 'salle': reservation.salle,
@@ -129,7 +155,6 @@ def detail_reservation(request:HttpRequest, reservation_id:int):
'besoin_ordinateur': reservation.besoin_ordi, 'besoin_ordinateur': reservation.besoin_ordi,
'lien_zoom': reservation.lien_zoom or '', 'lien_zoom': reservation.lien_zoom or '',
} }
return JsonResponse(reservation_json, safe=True) return JsonResponse(reservation_json, safe=True)
@login_required @login_required
@@ -175,14 +200,15 @@ def annuler_reservation(request:HttpRequest):
return redirect('gestion_salle:reservation-salle') return redirect('gestion_salle:reservation-salle')
@login_required @login_required
def valider_reservation(request:HttpRequest): def valider_reservation(request: HttpRequest):
"""Vue de gestion de l'annulation de la reservation""" """Validation d'une réservation"""
if request.method == 'POST': if request.method == 'POST':
reservation_id= request.POST['id_reservation'] reservation_id = request.POST.get('id_reservation')
try: try:
reservation = Reservation.objects.get(id=reservation_id) reservation = Reservation.objects.get(id=reservation_id)
except reservation.DoesNotExist: except Reservation.DoesNotExist:
messages.error(request, "La resevertion selectionné n'existe pas.") messages.error(request, "La réservation sélectionnée n'existe pas.")
return redirect("salle") return redirect("salle")
reservation.statut = 'validee' reservation.statut = 'validee'
@@ -198,16 +224,18 @@ def valider_reservation(request:HttpRequest):
return redirect('gestion_salle:reservation-salle') return redirect('gestion_salle:reservation-salle')
@login_required @login_required
def refuser_reservation(request:HttpRequest): def refuser_reservation(request: HttpRequest):
"""Vue de gestion de refus de la reservation""" """Refuser une réservation"""
data = json.loads(request.body) if request.method == 'POST':
reservation_id = data.get("id_reservation") reservation_id = request.POST.get('id_reservation')
try:
reservation = Reservation.objects.get(id=reservation_id) try:
except Reservation.DoesNotExist and ValueError: reservation = Reservation.objects.get(id=reservation_id)
return JsonResponse({"message": "La resevertion selectionné n'existe pas."}) except Reservation.DoesNotExist:
else: messages.error(request, "La réservation n'existe pas.")
reservation.statut = "refusee" return redirect("salle")
reservation.statut = 'refusee'
reservation.save() reservation.save()
if fonctions_utilitaire.EMAIL_ASSISTANTE_DE_DIRECTION: if fonctions_utilitaire.EMAIL_ASSISTANTE_DE_DIRECTION: