Merge branch 'dsprenkels/songs-reportnote-filter' into 'marietje-zuid'

Add a filter on reportnote count in the Songs admin list

See merge request dsprenkels/MarietjeDjango!52
This commit is contained in:
Daan Sprenkels
2020-06-15 18:08:26 +02:00

View File

@ -1,4 +1,5 @@
from django.contrib import admin
from django.db.models import Count
from django.urls import reverse
from django.utils.html import format_html
@ -10,16 +11,38 @@ class ReportNoteInline(admin.StackedInline):
extra = 0
autocomplete_fields = ('user',)
class SongHasReportNoteFilter(admin.SimpleListFilter):
title = 'report notes'
parameter_name = 'reportnotes'
def lookups(self, request, model_admin):
return (
('yes', 'yes'),
('no', 'no'),
)
def queryset(self, request, queryset):
queryset = queryset.annotate(num_reports=Count('reportnote'))
if self.value() == 'yes':
return queryset.exclude(num_reports=0)
if self.value() == 'no':
return queryset.filter(num_reports=0)
return queryset
@admin.register(Song)
class SongAdmin(admin.ModelAdmin):
list_display = ('artist', 'title', 'user_name', 'reports')
list_display_links = ('artist', 'title')
list_filter = (SongHasReportNoteFilter,)
search_fields = ('artist', 'title', 'user__name')
inlines = [ReportNoteInline]
autocomplete_fields = ('user',)
@staticmethod
def reports(song):
return ReportNote.objects.filter(song=song).count()
# num_reports is annotated by SongHasReportNoteFilter
return song.num_reports
@staticmethod
def user_name(song):