X-Git-Url: https://git.mdrn.pl/wolnelektury.git/blobdiff_plain/e432f8579852df4ffc3010bc54bbabe452591956..0bd51a33b9ffe994541ccd02fc850d47ac82ccec:/apps/catalogue/admin.py diff --git a/apps/catalogue/admin.py b/apps/catalogue/admin.py index 8a718ffd0..28cf53c37 100644 --- a/apps/catalogue/admin.py +++ b/apps/catalogue/admin.py @@ -3,13 +3,14 @@ # Copyright © Fundacja Nowoczesna Polska. See NOTICE for more information. # from django.contrib import admin +from django import forms -from newtagging.admin import TaggableModelAdmin -from catalogue.models import Tag, Book, Fragment, BookStub +from newtagging.admin import TaggableModelAdmin, TaggableModelForm +from catalogue.models import Tag, Book, Fragment, BookMedia, Collection, Source class TagAdmin(admin.ModelAdmin): - list_display = ('name', 'slug', 'sort_key', 'category', 'has_description', 'main_page',) + list_display = ('name', 'slug', 'sort_key', 'category', 'has_description',) list_filter = ('category',) search_fields = ('name',) ordering = ('name',) @@ -18,35 +19,51 @@ class TagAdmin(admin.ModelAdmin): radio_fields = {'category': admin.HORIZONTAL} +class MediaInline(admin.TabularInline): + model = BookMedia + readonly_fields = ['source_sha1'] + extra = 0 + + class BookAdmin(TaggableModelAdmin): tag_model = Tag - - list_display = ('title', 'slug', 'has_pdf_file', 'has_odt_file', 'has_html_file', 'has_description',) + + list_display = ('title', 'slug', 'created_at', 'has_epub_file', 'has_html_file', 'has_description',) search_fields = ('title',) ordering = ('title',) - prepopulated_fields = {'slug': ('title',)} + inlines = [MediaInline] + + def change_view(self, request, object_id, extra_context=None): + if not request.GET.has_key('advanced'): + self.form = forms.ModelForm + self.fields = ('title', 'description', 'gazeta_link', 'wiki_link') + self.readonly_fields = ('title',) + else: + self.form = TaggableModelForm + self.fields = None + self.readonly_fields = () + return super(BookAdmin, self).change_view(request, object_id, + extra_context=extra_context) class FragmentAdmin(TaggableModelAdmin): tag_model = Tag - + list_display = ('book', 'anchor',) ordering = ('book', 'anchor',) -class BookStubAdmin(admin.ModelAdmin): - # tag_model = Tag - - list_display = ('title', 'author', 'slug','pd') - search_fields = ('title','author') - ordering = ('title',) - +class CollectionAdmin(admin.ModelAdmin): prepopulated_fields = {'slug': ('title',)} -admin.site.register(BookStub, BookStubAdmin) +class SourceAdmin(admin.ModelAdmin): + list_display = ('netloc', 'name') + + admin.site.register(Tag, TagAdmin) admin.site.register(Book, BookAdmin) admin.site.register(Fragment, FragmentAdmin) - +admin.site.register(Collection, CollectionAdmin) +admin.site.register(Source, SourceAdmin)