X-Git-Url: https://git.mdrn.pl/redakcja.git/blobdiff_plain/8161763bf98b7f396ecc349ccd4670b8de592f40..5b1643ef60b2e2c6e045ecbf0042237bf446d721:/src/catalogue/admin.py diff --git a/src/catalogue/admin.py b/src/catalogue/admin.py index 213e9ca7..af77e26f 100644 --- a/src/catalogue/admin.py +++ b/src/catalogue/admin.py @@ -42,10 +42,11 @@ class AuthorAdmin(WikidataAdminMixin, TabbedTranslationAdmin): "status", "gender", "nationality", + ("genitive", admin.EmptyFieldListFilter) ] list_per_page = 10000000 search_fields = ["first_name", "last_name", "wikidata"] - readonly_fields = ["wikidata_link"] + readonly_fields = ["wikidata_link", "description_preview"] fieldsets = [ (None, {"fields": [("wikidata", "wikidata_link")]}), @@ -55,11 +56,12 @@ class AuthorAdmin(WikidataAdminMixin, TabbedTranslationAdmin): "fields": [ ("first_name", "last_name"), "slug", + "genitive", "gender", "nationality", ("date_of_birth", "year_of_birth", "year_of_birth_inexact", "year_of_birth_range", "place_of_birth"), ("date_of_death", "year_of_death", "year_of_death_inexact", "year_of_death_range", "place_of_death"), - "description", + ("description", "description_preview"), "status", "collections", "priority", @@ -67,6 +69,8 @@ class AuthorAdmin(WikidataAdminMixin, TabbedTranslationAdmin): "notes", "gazeta_link", "culturepl_link", + "plwiki", + "photo", "photo_source", "photo_attribution", ] }, ), @@ -78,6 +82,9 @@ class AuthorAdmin(WikidataAdminMixin, TabbedTranslationAdmin): NotableBookInline, ] + def description_preview(self, obj): + return obj.generate_description() + admin.site.register(models.Author, AuthorAdmin) @@ -182,8 +189,10 @@ class BookAdmin(WikidataAdminMixin, NumericFilterModelAdmin): "wikidata", "slug", "title", - "authors_str", # authors? - "translators_str", # translators? + "authors_first_names", + "authors_last_names", + "translators_first_names", + "translators_last_names", "language", "based_on", "scans_source", @@ -209,6 +218,7 @@ class BookAdmin(WikidataAdminMixin, NumericFilterModelAdmin): "translators", "language", "based_on", + "original_year", "pd_year", ] }, @@ -306,7 +316,7 @@ class CollectionAdmin(admin.ModelAdmin): autocomplete_fields = [] prepopulated_fields = {"slug": ("name",)} search_fields = ["name"] - fields = ['name', 'slug', 'category', 'notes', 'estimated_costs'] + fields = ['name', 'slug', 'category', 'description', 'notes', 'estimated_costs'] readonly_fields = ['estimated_costs'] inlines = [AuthorInline, BookInline] @@ -327,9 +337,20 @@ admin.site.register(models.Collection, CollectionAdmin) class CategoryAdmin(admin.ModelAdmin): search_fields = ["name"] -admin.site.register(models.Epoch, CategoryAdmin) -admin.site.register(models.Genre, CategoryAdmin) -admin.site.register(models.Kind, CategoryAdmin) + +@admin.register(models.Epoch) +class EpochAdmin(CategoryAdmin): + list_display = ['name', 'adjective_feminine_singular', 'adjective_nonmasculine_plural'] + + +@admin.register(models.Genre) +class GenreAdmin(CategoryAdmin): + list_display = ['name', 'plural', 'is_epoch_specific'] + + +@admin.register(models.Kind) +class KindAdmin(CategoryAdmin): + list_display = ['name', 'collective_noun']