Fonctionnalite: verifier qu'aucun contrat n'est actif avant la creation d'un nouveau pour un employe
All checks were successful
Organisation/sirh/pipeline/head This commit looks good
All checks were successful
Organisation/sirh/pipeline/head This commit looks good
This commit is contained in:
BIN
gestion_employe/__pycache__/__init__.cpython-310.pyc
Normal file
BIN
gestion_employe/__pycache__/__init__.cpython-310.pyc
Normal file
Binary file not shown.
BIN
gestion_employe/__pycache__/admin.cpython-310.pyc
Normal file
BIN
gestion_employe/__pycache__/admin.cpython-310.pyc
Normal file
Binary file not shown.
BIN
gestion_employe/__pycache__/forms.cpython-310.pyc
Normal file
BIN
gestion_employe/__pycache__/forms.cpython-310.pyc
Normal file
Binary file not shown.
BIN
gestion_employe/__pycache__/models.cpython-310.pyc
Normal file
BIN
gestion_employe/__pycache__/models.cpython-310.pyc
Normal file
Binary file not shown.
BIN
gestion_employe/__pycache__/urls.cpython-310.pyc
Normal file
BIN
gestion_employe/__pycache__/urls.cpython-310.pyc
Normal file
Binary file not shown.
BIN
gestion_employe/__pycache__/views.cpython-310.pyc
Normal file
BIN
gestion_employe/__pycache__/views.cpython-310.pyc
Normal file
Binary file not shown.
Binary file not shown.
@@ -1,5 +1,5 @@
|
||||
import json
|
||||
from datetime import timedelta, datetime
|
||||
from datetime import date, timedelta, datetime
|
||||
from dateutil.relativedelta import relativedelta
|
||||
|
||||
from django.utils import timezone
|
||||
@@ -247,14 +247,25 @@ def suppression_affectation(request):
|
||||
return JsonResponse({"message": "Affectation supprimée avec succès."})
|
||||
|
||||
def creation_contrat(request):
|
||||
"""Vue pour permettre à un utilisateur de créer un contrat pour un employé"""
|
||||
"""Créer un contrat pour un employé (avec contrôle d'existence de contrat actif)"""
|
||||
|
||||
try:
|
||||
employe = Employe.objects.get(id=request.POST.get('employe_id'))
|
||||
except Employe.DoesNotExist:
|
||||
messages.error(request, "Employé non trouvé.")
|
||||
return redirect('employe-index')
|
||||
|
||||
contrat_actif = Contrat.objects.filter(
|
||||
employe=employe,
|
||||
date_fin__gte=date.today()
|
||||
).exists()
|
||||
|
||||
if request.method == "POST":
|
||||
if contrat_actif:
|
||||
messages.error(
|
||||
request,
|
||||
"Impossible de créer un contrat : cet employé a déjà un contrat actif."
|
||||
)
|
||||
return redirect('gestion_employe:index')
|
||||
form = ContratForm(request.POST, request.FILES)
|
||||
if form.is_valid():
|
||||
contrat = form.save(commit=False)
|
||||
@@ -263,9 +274,13 @@ def creation_contrat(request):
|
||||
messages.success(request, "Contrat créé avec succès.")
|
||||
return redirect('gestion_employe:index')
|
||||
messages.error(request, "Formulaire non valide")
|
||||
|
||||
else:
|
||||
form = ContratForm(initial={'employe': employe})
|
||||
return render(request, 'gestion_employe/index.html', {'contrat_form': form})
|
||||
|
||||
return render(request, 'gestion_employe/index.html', {
|
||||
'contrat_form': form
|
||||
})
|
||||
|
||||
@login_required
|
||||
def enregistrer_detail_employe(request):
|
||||
|
||||
Reference in New Issue
Block a user