diff --git a/avisstage/forms.py b/avisstage/forms.py index 2e321c8..2b212b3 100644 --- a/avisstage/forms.py +++ b/avisstage/forms.py @@ -4,6 +4,17 @@ from django import forms from avisstage.models import Normalien, Stage, Lieu, AvisLieu, AvisStage from widget import LatLonField + +class AvisStageForm(forms.ModelForm): + class Meta: + model = AvisStage + fields = ['chapo', 'avis_ambiance', 'avis_sujet', 'avis_admin', 'les_plus', 'les_moins'] + +class AvisLieuForm(forms.ModelForm): + class Meta: + model = AvisLieu + fields = ['lieu', 'chapo', 'avis_lieustage', 'avis_pratique', 'avis_tourisme', 'les_plus', 'les_moins'] + class StageForm(forms.ModelForm): date_widget = forms.DateInput(attrs={"class":"datepicker"}) date_debut = forms.DateField(input_formats=["%d/%m/%Y"], widget=date_widget) @@ -11,60 +22,19 @@ class StageForm(forms.ModelForm): class Meta: model = Stage - fields = ['sujet', 'date_debut', 'date_fin', 'type_stage', 'thematiques', 'matieres', 'encadrants', 'lieux'] + fields = ['sujet', 'date_debut', 'date_fin', 'type_stage', 'thematiques', 'matieres', 'encadrants'] def __init__(self, *args, **kwargs): if "request" in kwargs: self.request = kwargs.pop("request") super(StageForm, self).__init__(*args, **kwargs) - if hasattr(self, 'instance'): - self.prev_lieux = self.instance.avislieu_set.all() - else: - self.prev_lieux = None - + def save(self, commit=True): - if self.instance.id is None: + if self.instance.id is None and hasattr(self, 'request'): self.instance.auteur = self.request.user.profil - stage = super(StageForm, self).save(commit=False) - - if commit: - stage.save() - - # Lecture des lieux, conservation des critiques précédentes - alieux = self.cleaned_data['lieux'] - new_lieux = [] - #print self.instance.lieux - if not (self.prev_lieux is None) and len(self.prev_lieux) > 0: - old_avislieux = {avis.lieu_id: avis for avis in self.prev_lieux} - for (k, nlieu) in enumerate(alieux): - if nlieu in old_avislieux: - # Ce lien existait déjà avant - # mise à jour de l'ordre - old_avislieu[nlieu].order = k - old_avi_lieu[nlieu].save() - # Rien d'autre à faire - del old_avislieux[nlieu] - else: - # C'est un nouveau lien - new_lieux.append((k, nlieu)) - - old_avislieux = old_avislieux.values() - for k, avislieu in enumerate(old_avislieux): - if k > len(new_lieux): - # Avis à supprimer - avislieu.delete() - else: - # On récupère le(s) avis pour le(s) nouveau(x) lieu(x) - avislieu.lieu, avislieu.order = new_lieux[k] - avislieu.save() - new_lieux = new_lieux[len(old_avislieux):] - else: - new_lieux = enumerate(alieux) - print(new_lieux) - # On crée les nouveaux avislieu qui vont bien - AvisLieu.objects.bulk_create([AvisLieu(lieu=lieu, stage=stage, order=k) - for (lieu, k) in new_lieux]) + stage = super(StageForm, self).save(commit=commit) + return stage class LieuForm(forms.ModelForm): @@ -74,17 +44,3 @@ class LieuForm(forms.ModelForm): model = Lieu fields = ['nom', 'type_lieu', 'ville', 'pays', 'coord'] - - -class AvisStageForm(forms.ModelForm): - - class Meta: - model = AvisStage - fields = ['chapo', 'avis_ambiance', 'avis_sujet', 'avis_admin', 'les_plus', 'les_moins'] - -class AvisLieuForm(forms.ModelForm): - - class Meta: - model = AvisLieu - fields = ['chapo', 'avis_lieustage', 'avis_pratique', 'avis_tourisme', 'les_plus', 'les_moins'] - diff --git a/avisstage/templates/avisstage/formulaires/stage.html b/avisstage/templates/avisstage/formulaires/stage.html index 00d9c69..458eb27 100644 --- a/avisstage/templates/avisstage/formulaires/stage.html +++ b/avisstage/templates/avisstage/formulaires/stage.html @@ -19,6 +19,8 @@
{% endblock %} diff --git a/avisstage/urls.py b/avisstage/urls.py index 76f9c92..07a7bdc 100644 --- a/avisstage/urls.py +++ b/avisstage/urls.py @@ -4,9 +4,9 @@ from . import views urlpatterns = [ url(r'^$', views.index, name='index'), url(r'^perso/$', views.perso, name='perso'), - url(r'^stage/nouveau/$', views.StageAjout.as_view(), name='stage_ajout'), + url(r'^stage/nouveau/$', views.manage_stage, name='stage_ajout'), url(r'^stage/(?P