book admin title readonly in basic mode, requirements-test fix
[wolnelektury.git] / apps / catalogue / admin.py
index 0275094..050d4e1 100644 (file)
@@ -5,7 +5,7 @@
 from django.contrib import admin
 
 from newtagging.admin import TaggableModelAdmin
-from catalogue.models import Tag, Book, Fragment, BookStub
+from catalogue.models import Tag, Book, Fragment, BookMedia
 
 
 class TagAdmin(admin.ModelAdmin):
@@ -21,11 +21,26 @@ class TagAdmin(admin.ModelAdmin):
 class BookAdmin(TaggableModelAdmin):
     tag_model = Tag
 
-    list_display = ('title', 'slug', 'has_pdf_file', 'has_epub_file', 'has_odt_file', 'has_html_file', 'has_description',)
+    list_display = ('title', 'slug', 'created_at', 'has_pdf_file', 'has_epub_file', 'has_html_file', 'has_description',)
     search_fields = ('title',)
     ordering = ('title',)
 
-    prepopulated_fields = {'slug': ('title',)}
+    filter_horizontal = ('medias',)
+
+    def change_view(self, request, object_id, extra_context=None):
+        #my_context = {
+        #    'osm_data': self.get_osm_info(),
+        #}
+        print request.GET.keys()
+        if not request.GET.has_key('advanced'):
+            self.fields = ('title', 'description', 'gazeta_link', 'wiki_link', 'pdf_file', 'medias',)
+            self.readonly_fields = ('title', 'slug',)
+        else:
+            self.fields = None
+            self.readonly_fields = ()
+        return super(BookAdmin, self).change_view(request, object_id,
+            extra_context=extra_context)
+
 
 
 class FragmentAdmin(TaggableModelAdmin):
@@ -35,18 +50,16 @@ class FragmentAdmin(TaggableModelAdmin):
     ordering = ('book', 'anchor',)
 
 
-class BookStubAdmin(admin.ModelAdmin):
-    # tag_model = Tag
+class MediaAdmin(admin.ModelAdmin):
+    #tag_model = BookMedia
 
-    list_display = ('title', 'author', 'slug','pd')
-    search_fields = ('title','author')
-    ordering = ('title',)
+    list_display = ('name', 'type', 'uploaded_at')
+    ordering = ('name', 'type')
+    search_fields = ('name',)
 
-    prepopulated_fields = {'slug': ('title',)}
 
 
-admin.site.register(BookStub, BookStubAdmin)
 admin.site.register(Tag, TagAdmin)
 admin.site.register(Book, BookAdmin)
 admin.site.register(Fragment, FragmentAdmin)
-
+admin.site.register(BookMedia, MediaAdmin)