Minor upgrades and test fixes.
[wolnelektury.git] / src / catalogue / admin.py
index 9008df1..d1e3c1f 100644 (file)
@@ -1,10 +1,13 @@
-# This file is part of Wolnelektury, licensed under GNU Affero GPLv3 or later.
-# Copyright © Fundacja Nowoczesna Polska. See NOTICE for more information.
+# This file is part of Wolne Lektury, licensed under GNU Affero GPLv3 or later.
+# Copyright © Fundacja Wolne Lektury. See NOTICE for more information.
 #
 from django.contrib import admin
-from django import forms
+from catalogue.models import Tag, Book, Fragment, BookMedia, Collection, Source, Snippet
+from pz.admin import EmptyFieldListFilter
 
-from catalogue.models import Tag, Book, Fragment, BookMedia, Collection, Source
+
+class BlankFieldListFilter(EmptyFieldListFilter):
+    with_empty_str = True
 
 
 class TagAdmin(admin.ModelAdmin):
@@ -13,6 +16,7 @@ class TagAdmin(admin.ModelAdmin):
     search_fields = ('name',)
     ordering = ('name',)
     readonly_fields = ('occurrences',)
+    raw_id_fields = ['user']
 
     def occurrences(self, tag):
         return tag.items.count()
@@ -29,7 +33,16 @@ class MediaInline(admin.TabularInline):
 
 
 class BookAdmin(admin.ModelAdmin):
-    list_display = ('title', 'slug', 'created_at', 'has_epub_file', 'has_html_file', 'has_description',)
+    list_display = (
+        'title', 'slug', 'created_at', 'has_epub_file', 'has_html_file', 'has_description',
+    )
+    list_filter = [
+            'print_on_demand',
+            ('wiki_link', BlankFieldListFilter),
+            ('parent', EmptyFieldListFilter),
+            ('media', admin.EmptyFieldListFilter),
+            ]
+    date_hierarchy = 'created_at'
     search_fields = ('title',)
     ordering = ('title',)
 
@@ -42,6 +55,7 @@ class FragmentAdmin(admin.ModelAdmin):
 
 
 class CollectionAdmin(admin.ModelAdmin):
+    list_display = ('title', 'listed', 'role')
     prepopulated_fields = {'slug': ('title',)}
 
 
@@ -54,3 +68,6 @@ admin.site.register(Book, BookAdmin)
 admin.site.register(Fragment, FragmentAdmin)
 admin.site.register(Collection, CollectionAdmin)
 admin.site.register(Source, SourceAdmin)
+
+
+admin.site.register(Snippet)