From 2eec2a7875290f1c6b1008c7fcce2e803c3ef31d Mon Sep 17 00:00:00 2001 From: Alessandro Date: Tue, 22 Oct 2024 15:34:17 +0200 Subject: [PATCH] OSIS-1306: Adpat screen for previous_experience --- templates/admission/previous_experience.html | 27 +++---- views/services/previous_experience.py | 78 ++++++++++++++++---- 2 files changed, 76 insertions(+), 29 deletions(-) diff --git a/templates/admission/previous_experience.html b/templates/admission/previous_experience.html index 090b524d2..d381763e0 100644 --- a/templates/admission/previous_experience.html +++ b/templates/admission/previous_experience.html @@ -42,13 +42,14 @@
{% trans 'Secondary school or alternative' %}
+ {% endif %} + /> {{ experience.annees|display_as_academic_year }} {{ experience.nom_formation|default_if_none_or_empty:'-' }} @@ -69,7 +70,7 @@
{% trans 'Secondary school or alternative' %}
{% empty %} - + {% trans 'No data' context 'admission' %} @@ -107,11 +108,11 @@
{% trans 'Academic course' %}
{{ experience.nom_formation|default_if_none_or_empty:'-' }} {{ experience.nom_institut|default_if_none_or_empty:'-' }} - {% if experience.uuid in mergeable_experiences_uuids %} -
Connue UCL
- {% else %} + {% if experience.source == 'CANDIDAT' %}
Candidat
- {% endif %} + {% else %} +
Connue UCL
+ {% endif %} {% empty %} @@ -160,10 +161,10 @@
{% trans 'Non-academic activity' %}
{{ experience.fonction|default_if_none_or_empty:'-' }} {{ experience.employeur|default_if_none_or_empty:'-' }} - {% if experience.uuid in mergeable_experiences_uuids %} -
Connue UCL
- {% else %} + {% if experience.source == 'CANDIDAT' %}
Candidat
+ {% else %} +
Connue UCL
{% endif %} diff --git a/views/services/previous_experience.py b/views/services/previous_experience.py index c8c110fb9..7d9c6f0bb 100644 --- a/views/services/previous_experience.py +++ b/views/services/previous_experience.py @@ -131,19 +131,22 @@ def get_context_data(self, **kwargs): return context def get_secondary_school_or_alternative_experiences(self): - secondary_school_or_alternative_experiences = [ - SimpleNamespace( - uuid=self.etudes_secondaires_candidat.uuid, - annees=self.etudes_secondaires_candidat.annee_diplome_etudes_secondaires, - nom_formation=self._get_nom_formation_etude_secondaire(self.etudes_secondaires_candidat), - nom_institut=self._get_nom_institut_etude_secondaire(self.etudes_secondaires_candidat), - est_experience_belge=isinstance( - self.etudes_secondaires_candidat.experience, DiplomeBelgeEtudesSecondairesDTO - ), - source='CANDIDAT', + secondary_school_or_alternative_experiences = [] + if self.etudes_secondaires_candidat.experience is not None: + secondary_school_or_alternative_experiences.append( + SimpleNamespace( + uuid=self.etudes_secondaires_candidat.uuid, + annees=self.etudes_secondaires_candidat.annee_diplome_etudes_secondaires, + nom_formation=self._get_nom_formation_etude_secondaire(self.etudes_secondaires_candidat), + nom_institut=self._get_nom_institut_etude_secondaire(self.etudes_secondaires_candidat), + est_experience_belge=isinstance( + self.etudes_secondaires_candidat.experience, DiplomeBelgeEtudesSecondairesDTO + ), + source='CANDIDAT', + is_checked=True, + ) ) - ] - if self.etudes_secondaires_personne_connue: + if self.etudes_secondaires_personne_connue and self.etudes_secondaires_personne_connue.experience is not None: secondary_school_or_alternative_experiences.append( SimpleNamespace( uuid=self.etudes_secondaires_personne_connue.uuid, @@ -154,6 +157,7 @@ def get_secondary_school_or_alternative_experiences(self): self.etudes_secondaires_candidat.experience, DiplomeBelgeEtudesSecondairesDTO ), source='PERSONNE_CONNUE', + is_checked=len(secondary_school_or_alternative_experiences) == 0, ) ) return secondary_school_or_alternative_experiences @@ -180,15 +184,57 @@ def _get_nom_institut_etude_secondaire(self, etude_secondaire: EtudesSecondaires return getattr(etude_secondaire.experience, 'pays_nom', '') def get_professional_experiences(self): - professional_experiences = self.curriculum_candidat.experiences_non_academiques + professional_experiences = [ + SimpleNamespace( + uuid=experience_non_academique.uuid, + date_debut=experience_non_academique.date_debut, + date_fin=experience_non_academique.date_fin, + type=experience_non_academique.type, + secteur=experience_non_academique.secteur, + autre_activite=experience_non_academique.autre_activite, + fonction=experience_non_academique.fonction, + employeur=experience_non_academique.employeur, + source='CANDIDAT', + ) for experience_non_academique in self.curriculum_candidat.experiences_non_academiques + ] if self.curriculum_personne_connue: - professional_experiences += self.curriculum_personne_connue.experiences_non_academiques + professional_experiences += [ + SimpleNamespace( + uuid=experience_non_academique.uuid, + date_debut=experience_non_academique.date_debut, + date_fin=experience_non_academique.date_fin, + type=experience_non_academique.type, + secteur=experience_non_academique.secteur, + autre_activite=experience_non_academique.autre_activite, + fonction=experience_non_academique.fonction, + employeur=experience_non_academique.employeur, + source='PERSONNE_CONNUE', + ) for experience_non_academique in self.curriculum_personne_connue.experiences_non_academiques + ] return sorted(professional_experiences, key=lambda exp: (exp.date_debut, exp.date_fin), reverse=True) def get_educational_experiences(self): - educational_experiences = self.curriculum_candidat.experiences_academiques + educational_experiences = [ + SimpleNamespace( + uuid=educational_experiences.uuid, + titre_formate=educational_experiences.titre_formate, + annees=educational_experiences.annees, + nom_formation=educational_experiences.nom_formation, + nom_institut=educational_experiences.nom_institut, + source='CANDIDAT', + ) for educational_experiences in self.curriculum_candidat.experiences_academiques + ] if self.curriculum_personne_connue: - educational_experiences += self.curriculum_personne_connue.experiences_academiques + educational_experiences += [ + SimpleNamespace( + uuid=educational_experiences.uuid, + titre_formate=educational_experiences.titre_formate, + annees=educational_experiences.annees, + nom_formation=educational_experiences.nom_formation, + nom_institut=educational_experiences.nom_institut, + source='PERSONNE_CONNUE', + ) for educational_experiences in self.curriculum_personne_connue.experiences_academiques + ] return sorted(educational_experiences, key=lambda exp: exp.titre_formate, reverse=True) def get_mergeable_experiences_uuids(self):