add a context menu package
[redakcja.git] / apps / catalogue / views.py
index d234ab0..f8ff599 100644 (file)
@@ -10,14 +10,16 @@ from django.contrib.auth.models import User
 from django.contrib.auth.decorators import login_required, permission_required
 from django.core.urlresolvers import reverse
 from django.db.models import Count, Q
+from django.db import transaction
 from django import http
 from django.http import Http404, HttpResponse, HttpResponseForbidden
-from django.shortcuts import get_object_or_404, render
+from django.shortcuts import get_object_or_404, render, render_to_response
 from django.utils.encoding import iri_to_uri
 from django.utils.http import urlquote_plus
 from django.utils.translation import ugettext_lazy as _
 from django.views.decorators.http import require_POST
 from django.views.generic.simple import direct_to_template
+from django.template import RequestContext
 
 from apiclient import NotAuthorizedError
 from catalogue import forms
@@ -224,10 +226,21 @@ def book_html(request, slug):
     if not book.accessible(request):
         return HttpResponseForbidden("Not authorized.")
 
-    doc = book.wldocument()
-    html = doc.as_html(parse_dublincore=False, flags=['full-page']).get_string()
-    response = http.HttpResponse(html, content_type='text/html', mimetype='text/html')
-    return response
+    doc = book.wldocument(parse_dublincore=False)
+    html = doc.as_html()
+
+    html = html.get_string() if html is not None else ''
+    # response = http.HttpResponse(html, content_type='text/html', mimetype='text/html')
+    # return response
+    # book_themes = {}
+    # for fragment in book.fragments.all().iterator():
+    #     for theme in fragment.tags.filter(category='theme').iterator():
+    #         book_themes.setdefault(theme, []).append(fragment)
+
+    # book_themes = book_themes.items()
+    # book_themes.sort(key=lambda s: s[0].sort_key)
+    return render_to_response('catalogue/book_text.html', locals(),
+        context_instance=RequestContext(request))
 
 
 @never_cache
@@ -375,6 +388,26 @@ def chunk_edit(request, slug, chunk):
     })
 
 
+@transaction.commit_on_success
+def chunk_mass_edit(request):
+    if request.method == 'POST':
+        ids = map(int, request.POST.get('ids').split(','))
+        chunks = map(lambda i: Chunk.objects.get(id=i), ids)
+        try:
+            stage = Chunk.tag_model.objects.get(slug=request.POST.get('stage'))
+            for c in chunks: c.stage = stage
+        except KeyError: pass
+
+        try:
+            user = User.objects.get(username=request.POST.get('user'))
+            for c in chunks: c.user = user
+        except KeyError: pass
+
+        for c in chunks: c.save()
+    else:
+        raise Http404
+
+
 @permission_required('catalogue.change_book')
 def book_append(request, slug):
     book = get_object_or_404(Book, slug=slug)