From 015dbffe198e2e61f4feb57f436bba959d219961 Mon Sep 17 00:00:00 2001 From: Xavier Fernandez Date: Thu, 13 Jun 2024 12:01:10 +0200 Subject: [PATCH] dashboard: conditional admonition --- .../includes/employer_geiq_card.html | 30 ++++++++++--------- tests/www/dashboard/tests.py | 28 +++++++++++++++-- 2 files changed, 41 insertions(+), 17 deletions(-) diff --git a/itou/templates/dashboard/includes/employer_geiq_card.html b/itou/templates/dashboard/includes/employer_geiq_card.html index e27145997a9..b518f0860f0 100644 --- a/itou/templates/dashboard/includes/employer_geiq_card.html +++ b/itou/templates/dashboard/includes/employer_geiq_card.html @@ -18,23 +18,25 @@ -
-

+ {% if not last_geiq_execution_assessment.submitted_at %} +
+

-
-
- -
-
-

- Validez votre bilan {{ last_geiq_execution_assessment.campaign.year }} -

-

- Vous avez jusqu’au {{ last_geiq_execution_assessment.campaign.submission_deadline|date:"d/m/Y" }} pour valider le dossier de votre bilan d’exécution qui sera automatiquement transmis à votre DDETS/DREETS. -

+
+
+ +
+
+

+ Validez votre bilan {{ last_geiq_execution_assessment.campaign.year }} +

+

+ Vous avez jusqu’au {{ last_geiq_execution_assessment.campaign.submission_deadline|date:"d/m/Y" }} pour valider le dossier de votre bilan d’exécution qui sera automatiquement transmis à votre DDETS/DREETS. +

+
-
+ {% endif %}
diff --git a/tests/www/dashboard/tests.py b/tests/www/dashboard/tests.py index 6ced78e940c..bf4c35b7cd5 100644 --- a/tests/www/dashboard/tests.py +++ b/tests/www/dashboard/tests.py @@ -49,6 +49,7 @@ CompanyPendingGracePeriodFactory, ) from tests.employee_record.factories import EmployeeRecordFactory +from tests.files.factories import FileFactory from tests.geiq.factories import ImplementationAssessmentCampaignFactory, ImplementationAssessmentFactory from tests.institutions.factories import InstitutionFactory, InstitutionMembershipFactory, LaborInspectorFactory from tests.job_applications.factories import JobApplicationFactory, JobApplicationSentByPrescriberFactory @@ -91,7 +92,6 @@ class DashboardViewTest(ParametrizedTestCase, TestCase): HIRE_LINK_LABEL = "Déclarer une embauche" DORA_LABEL = "DORA" DORA_CARD_MSG = "Consultez l’offre de service de vos partenaires" - IMPLEMENTATION_ASSESSMENT = "Bilan d’exécution & salariés" @staticmethod def apply_start_url(company): @@ -789,6 +789,8 @@ def test_institution_with_geiq_assessment_campaign( @freeze_time("2024-03-10") def test_geiq_implement_assessment_card(self): + IMPLEMENTATION_ASSESSMENT = "Bilan d’exécution & salariés" + VALIDATE_ADMONITION = "Validez votre bilan" campaign = ImplementationAssessmentCampaignFactory( year=2022, submission_deadline=date(2023, 7, 1), @@ -798,10 +800,12 @@ def test_geiq_implement_assessment_card(self): user = membership.user self.client.force_login(user) response = self.client.get(reverse("dashboard:index")) - self.assertNotContains(response, self.IMPLEMENTATION_ASSESSMENT) + self.assertNotContains(response, IMPLEMENTATION_ASSESSMENT) + self.assertNotContains(response, VALIDATE_ADMONITION) assessment = ImplementationAssessmentFactory(campaign=campaign, company=membership.company) response = self.client.get(reverse("dashboard:index")) - self.assertContains(response, self.IMPLEMENTATION_ASSESSMENT) + self.assertContains(response, IMPLEMENTATION_ASSESSMENT) + self.assertContains(response, VALIDATE_ADMONITION) self.assertContains(response, reverse("geiq:assessment_info", kwargs={"assessment_pk": assessment.pk})) self.assertContains( response, @@ -809,9 +813,27 @@ def test_geiq_implement_assessment_card(self): "geiq:employee_list", kwargs={"assessment_pk": assessment.pk, "info_type": "personal-information"} ), ) + assessment.last_synced_at = timezone.now() + assessment.submitted_at = timezone.now() + assessment.activity_report_file = FileFactory() + assessment.save() + # submitted assessment + response = self.client.get(reverse("dashboard:index")) + self.assertContains(response, IMPLEMENTATION_ASSESSMENT) + self.assertNotContains(response, VALIDATE_ADMONITION) + self.assertContains(response, reverse("geiq:assessment_info", kwargs={"assessment_pk": assessment.pk})) + self.assertContains( + response, + reverse( + "geiq:employee_list", kwargs={"assessment_pk": assessment.pk, "info_type": "personal-information"} + ), + ) + # With several assessments, the last one is shown new_assessment = ImplementationAssessmentFactory(campaign__year=2023, company=membership.company) response = self.client.get(reverse("dashboard:index")) + self.assertContains(response, IMPLEMENTATION_ASSESSMENT) + self.assertContains(response, VALIDATE_ADMONITION) self.assertContains(response, reverse("geiq:assessment_info", kwargs={"assessment_pk": new_assessment.pk})) self.assertContains( response,