update
[wolnelektury.git] / src / catalogue / admin.py
index 44b6fb7..420cd3f 100644 (file)
@@ -2,10 +2,12 @@
 # Copyright © Fundacja Nowoczesna Polska. See NOTICE for more information.
 #
 from django.contrib import admin
 # Copyright © Fundacja Nowoczesna Polska. See NOTICE for more information.
 #
 from django.contrib import admin
-from django import forms
-
-from newtagging.admin import TaggableModelAdmin, TaggableModelForm
 from catalogue.models import Tag, Book, Fragment, BookMedia, Collection, Source
 from catalogue.models import Tag, Book, Fragment, BookMedia, Collection, Source
+from pz.admin import EmptyFieldListFilter
+
+
+class BlankFieldListFilter(EmptyFieldListFilter):
+    with_empty_str = True
 
 
 class TagAdmin(admin.ModelAdmin):
 
 
 class TagAdmin(admin.ModelAdmin):
@@ -17,7 +19,7 @@ class TagAdmin(admin.ModelAdmin):
 
     def occurrences(self, tag):
         return tag.items.count()
 
     def occurrences(self, tag):
         return tag.items.count()
-    occurrences.short_description = u'Wystąpienia'
+    occurrences.short_description = 'Wystąpienia'
 
     prepopulated_fields = {'slug': ('name',), 'sort_key': ('name',)}
     radio_fields = {'category': admin.HORIZONTAL}
 
     prepopulated_fields = {'slug': ('name',), 'sort_key': ('name',)}
     radio_fields = {'category': admin.HORIZONTAL}
@@ -29,29 +31,30 @@ class MediaInline(admin.TabularInline):
     extra = 0
 
 
     extra = 0
 
 
-#FIXME: Taggable admin is broken.
-#class BookAdmin(TaggableModelAdmin):
 class BookAdmin(admin.ModelAdmin):
 class BookAdmin(admin.ModelAdmin):
-    #tag_model = Tag
-    #form = TaggableModelForm
-
-    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',)
 
     inlines = [MediaInline]
 
 
     search_fields = ('title',)
     ordering = ('title',)
 
     inlines = [MediaInline]
 
 
-#FIXME: Taggable admin is broken.
-#class FragmentAdmin(TaggableModelAdmin):
 class FragmentAdmin(admin.ModelAdmin):
 class FragmentAdmin(admin.ModelAdmin):
-    #tag_model = Tag
-
     list_display = ('book', 'anchor',)
     ordering = ('book', 'anchor',)
 
 
 class CollectionAdmin(admin.ModelAdmin):
     list_display = ('book', 'anchor',)
     ordering = ('book', 'anchor',)
 
 
 class CollectionAdmin(admin.ModelAdmin):
+    list_display = ('title', 'listed', 'role')
     prepopulated_fields = {'slug': ('title',)}
 
 
     prepopulated_fields = {'slug': ('title',)}