X-Git-Url: https://git.mdrn.pl/wolnelektury.git/blobdiff_plain/d99d71844b7b97800dcab7cbb81c3a4185acbb48..cd21f43fa5074d843235639ba14b699d4eadc131:/apps/catalogue/admin.py diff --git a/apps/catalogue/admin.py b/apps/catalogue/admin.py index 5739cdca2..aca4f0756 100644 --- a/apps/catalogue/admin.py +++ b/apps/catalogue/admin.py @@ -3,8 +3,9 @@ # Copyright © Fundacja Nowoczesna Polska. See NOTICE for more information. # from django.contrib import admin +from django import forms -from newtagging.admin import TaggableModelAdmin +from newtagging.admin import TaggableModelAdmin, TaggableModelForm from catalogue.models import Tag, Book, Fragment, BookMedia @@ -25,7 +26,20 @@ class BookAdmin(TaggableModelAdmin): search_fields = ('title',) ordering = ('title',) - prepopulated_fields = {'slug': ('title',)} + filter_horizontal = ('medias',) + + 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', 'pdf_file', 'medias',) + 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): @@ -35,11 +49,22 @@ class FragmentAdmin(TaggableModelAdmin): ordering = ('book', 'anchor',) + +class BookMediaAdminForm(forms.ModelForm): + books = forms.CharField(required=False) + + class Meta: + model = BookMedia + + class MediaAdmin(admin.ModelAdmin): - #tag_model = BookMedia + form = BookMediaAdminForm - list_display = ('type', 'name') - ordering = ('type', 'name') + list_display = ('name', 'type', 'book_count', 'uploaded_at') + ordering = ('name', 'type') + search_fields = ('name',) + fields = ('type', 'name', 'file', 'books') + readonly_fields = ('books',)