From 94bfc24e8c353a678b72f37c86adf9a4a7a78ffd Mon Sep 17 00:00:00 2001 From: =?utf8?q?Marek=20St=C4=99pniowski?= Date: Wed, 3 Dec 2008 21:13:38 +0100 Subject: [PATCH] Added import book form to admin. --- apps/catalogue/views.py | 23 ++++++++++++++++++- .../admin/catalogue/book/change_list.html | 8 +++++++ wolnelektury/urls.py | 1 + 3 files changed, 31 insertions(+), 1 deletion(-) create mode 100644 wolnelektury/templates/admin/catalogue/book/change_list.html diff --git a/apps/catalogue/views.py b/apps/catalogue/views.py index 7870cba4f..b61d5e803 100644 --- a/apps/catalogue/views.py +++ b/apps/catalogue/views.py @@ -7,7 +7,7 @@ from django.shortcuts import render_to_response, get_object_or_404 from django.http import HttpResponse, HttpResponseRedirect, Http404 from django.core.urlresolvers import reverse from django.db.models import Q -from django.contrib.auth.decorators import login_required +from django.contrib.auth.decorators import login_required, user_passes_test from django.utils.datastructures import SortedDict from django.views.decorators.http import require_POST from django.contrib import auth @@ -23,6 +23,9 @@ from catalogue.utils import split_tags from newtagging import views as newtagging_views +staff_required = user_passes_test(lambda user: user.is_staff) + + class LazyEncoder(simplejson.JSONEncoder): def default(self, obj): if isinstance(obj, Promise): @@ -355,3 +358,21 @@ def logout_then_redirect(request): auth.logout(request) return HttpResponseRedirect(request.GET.get('next', '/')) + + +# ========= +# = Admin = +# ========= +@login_required +@staff_required +def import_book(request): + """docstring for import_book""" + book_import_form = forms.BookImportForm(request.POST, request.FILES) + if book_import_form.is_valid(): + # try: + book_import_form.save() + # except: + # return HttpResponse("Error importing book: %r" % (sys.exc_info(),)) + return HttpResponse("Book imported successfully") + else: + return HttpResponse("Error importing file: %r" % book_import_form.errors) \ No newline at end of file diff --git a/wolnelektury/templates/admin/catalogue/book/change_list.html b/wolnelektury/templates/admin/catalogue/book/change_list.html new file mode 100644 index 000000000..3ded50367 --- /dev/null +++ b/wolnelektury/templates/admin/catalogue/book/change_list.html @@ -0,0 +1,8 @@ +{% extends "admin/change_list.html" %} + +{% block content %} +
+

+
+ {{ block.super }} +{% endblock content %} \ No newline at end of file diff --git a/wolnelektury/urls.py b/wolnelektury/urls.py index 58e3c747a..a142c739b 100644 --- a/wolnelektury/urls.py +++ b/wolnelektury/urls.py @@ -23,6 +23,7 @@ urlpatterns = patterns('', name='about_us'), # Admin panel + url(r'^admin/catalogue/book/import$', 'catalogue.views.import_book', name='import_book'), url(r'^admin/doc/', include('django.contrib.admindocs.urls')), url(r'^admin/(.*)$', admin.site.root), -- 2.20.1