From 9181d37d7399c276b4c5ee50361b8c0d4017a7d3 Mon Sep 17 00:00:00 2001 From: Raphael Odini Date: Thu, 7 Mar 2024 17:57:44 +0100 Subject: [PATCH] =?UTF-8?q?feat(Besoins):=20Admin=20:=20Connaitre=20le=20n?= =?UTF-8?q?ombre=20de=20besoins=20d=C3=A9pos=C3=A9s=20par=20chaque=20entre?= =?UTF-8?q?prise=20(#1120)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- lemarche/companies/admin.py | 24 +++++++++++++++++++++--- lemarche/companies/models.py | 8 +++++++- lemarche/companies/tests.py | 7 +++++++ 3 files changed, 35 insertions(+), 4 deletions(-) diff --git a/lemarche/companies/admin.py b/lemarche/companies/admin.py index c6d46ba8c..05372f155 100644 --- a/lemarche/companies/admin.py +++ b/lemarche/companies/admin.py @@ -41,12 +41,22 @@ def queryset(self, request, queryset): @admin.register(Company, site=admin_site) class CompanyAdmin(admin.ModelAdmin, DynamicArrayMixin): - list_display = ["id", "name", "user_count_annotated_with_link", "created_at"] + list_display = [ + "id", + "name", + "user_count_annotated_with_link", + "user_tender_count_annotated_with_link", + "created_at", + ] list_filter = [HasUserFilter, HasEmailDomainFilter] search_fields = ["id", "name"] search_help_text = "Cherche sur les champs : ID, Nom" - readonly_fields = ["logo_url_display", "user_count_annotated_with_link", "created_at", "updated_at"] + readonly_fields = [ + "logo_url_display", + "user_count_annotated_with_link", + "user_tender_count_annotated_with_link", + ] + Company.READONLY_FIELDS fieldsets = ( ( @@ -57,6 +67,7 @@ class CompanyAdmin(admin.ModelAdmin, DynamicArrayMixin): ), ("Logo", {"fields": ("logo_url", "logo_url_display")}), ("Utilisateurs", {"fields": ("user_count_annotated_with_link",)}), + ("Besoins", {"fields": ("user_tender_count_annotated_with_link",)}), ("Dates", {"fields": ("created_at", "updated_at")}), ) @@ -93,5 +104,12 @@ def user_count_annotated_with_link(self, company): url = reverse("admin:users_user_changelist") + f"?company__id__exact={company.id}" return format_html(f'{company.user_count_annotated}') - user_count_annotated_with_link.short_description = "Nombre d'utilisateurs rattachés" + user_count_annotated_with_link.short_description = "Utilisateurs rattachés" user_count_annotated_with_link.admin_order_field = "user_count_annotated" + + def user_tender_count_annotated_with_link(self, company): + url = reverse("admin:tenders_tender_changelist") + f"?author__company_id__exact={company.id}" + return format_html(f'{company.user_tender_count_annotated}') + + user_tender_count_annotated_with_link.short_description = "Besoins déposés par les utilisateurs" + user_tender_count_annotated_with_link.admin_order_field = "user_tender_count_annotated" diff --git a/lemarche/companies/models.py b/lemarche/companies/models.py index d1cf06dea..140339f3b 100644 --- a/lemarche/companies/models.py +++ b/lemarche/companies/models.py @@ -13,10 +13,16 @@ def has_email_domain(self): return self.exclude(email_domain_list=[]) def with_user_stats(self): - return self.annotate(user_count_annotated=Count("users", distinct=True)) + return self.annotate(user_count_annotated=Count("users", distinct=True)).annotate( + user_tender_count_annotated=Count("users__tenders", distinct=True) + ) class Company(models.Model): + FIELDS_STATS_COUNT = ["user_count"] + FIELDS_STATS_TIMESTAMPS = ["created_at", "updated_at"] + READONLY_FIELDS = FIELDS_STATS_COUNT + FIELDS_STATS_TIMESTAMPS + name = models.CharField(verbose_name="Nom", max_length=255) slug = models.SlugField(verbose_name="Slug", max_length=255, unique=True) description = models.TextField(verbose_name="Description", blank=True) diff --git a/lemarche/companies/tests.py b/lemarche/companies/tests.py index 8958ee6a8..a334b8194 100644 --- a/lemarche/companies/tests.py +++ b/lemarche/companies/tests.py @@ -2,6 +2,7 @@ from lemarche.companies.factories import CompanyFactory from lemarche.companies.models import Company +from lemarche.tenders.factories import TenderFactory from lemarche.users.factories import UserFactory @@ -22,10 +23,16 @@ class CompanyQuerysetTest(TestCase): def setUpTestData(cls): cls.user_1 = UserFactory() cls.user_2 = UserFactory() + TenderFactory(author=cls.user_1) + TenderFactory(author=cls.user_1) cls.company_with_users = CompanyFactory(users=[cls.user_1, cls.user_2]) cls.company = CompanyFactory() def test_with_user_stats(self): company_queryset = Company.objects.with_user_stats() + # user_count self.assertEqual(company_queryset.get(id=self.company.id).user_count_annotated, 0) self.assertEqual(company_queryset.get(id=self.company_with_users.id).user_count_annotated, 2) + # user_tender_count + self.assertEqual(company_queryset.get(id=self.company.id).user_tender_count_annotated, 0) + self.assertEqual(company_queryset.get(id=self.company_with_users.id).user_tender_count_annotated, 2)