Added short_html method to Book model and removed (no longer used) book template...
authorMarek Stępniowski <marek@stepniowski.com>
Thu, 4 Sep 2008 12:34:09 +0000 (14:34 +0200)
committerMarek Stępniowski <marek@stepniowski.com>
Thu, 4 Sep 2008 12:34:09 +0000 (14:34 +0200)
catalogue/models.py
catalogue/templatetags/catalogue_tags.py
templates/catalogue/_book.html [deleted file]
templates/catalogue/book_short.html [new file with mode: 0644]
templates/catalogue/tagged_book_list.html

index 9f035b5..11d1aa7 100644 (file)
@@ -1,9 +1,11 @@
 # -*- coding: utf-8 -*-
 from django.db import models
 # -*- coding: utf-8 -*-
 from django.db import models
-from django.db.models import permalink
+from django.db.models import permalink, Q
 from django.utils.translation import ugettext_lazy as _
 from django.contrib.auth.models import User
 from django.core.files import File
 from django.utils.translation import ugettext_lazy as _
 from django.contrib.auth.models import User
 from django.core.files import File
+from django.template.loader import render_to_string
+from django.utils.safestring import mark_safe
 
 from newtagging.models import TagBase
 from newtagging import managers
 
 from newtagging.models import TagBase
 from newtagging import managers
@@ -71,6 +73,7 @@ class Book(models.Model):
     slug = models.SlugField(_('slug'), unique=True, db_index=True)
     description = models.TextField(_('description'), blank=True)
     created_at = models.DateTimeField(_('creation date'), auto_now=True)
     slug = models.SlugField(_('slug'), unique=True, db_index=True)
     description = models.TextField(_('description'), blank=True)
     created_at = models.DateTimeField(_('creation date'), auto_now=True)
+    _short_html = models.TextField(_('short HTML'))
     
     # Formats
     xml_file = models.FileField(_('XML file'), upload_to='books/xml', blank=True)
     
     # Formats
     xml_file = models.FileField(_('XML file'), upload_to='books/xml', blank=True)
@@ -81,6 +84,26 @@ class Book(models.Model):
     objects = managers.ModelTaggedItemManager(Tag)
     tags = managers.TagDescriptor(Tag)
     
     objects = managers.ModelTaggedItemManager(Tag)
     tags = managers.TagDescriptor(Tag)
     
+    def short_html(self):
+        if len(self._short_html):
+            return mark_safe(self._short_html)
+        else:
+            tags = self.tags.filter(~Q(category__in=('set', 'theme')))
+            tags = [u'<a href="%s">%s</a>' % (tag.get_absolute_url(), tag.name) for tag in tags]
+
+            formats = []
+            if self.html_file:
+                formats.append(u'<a href="%s">Czytaj online</a>' % self.html_file.url)
+            if self.pdf_file:
+                formats.append(u'<a href="%s">Plik PDF</a>' % self.pdf_file.url)
+            if self.odt_file:
+                formats.append(u'<a href="%s">Plik ODT</a>' % self.odt_file.url)
+            
+            self._short_html = render_to_string('catalogue/book_short.html',
+                {'book': self, 'tags': tags, 'formats': formats})
+            self.save()
+            return mark_safe(self._short_html)
+    
     def has_description(self):
         return len(self.description) > 0
     has_description.short_description = _('description')
     def has_description(self):
         return len(self.description) > 0
     has_description.short_description = _('description')
index cf4abe7..20c7abd 100644 (file)
@@ -117,22 +117,6 @@ def breadcrumbs(tags, search_form=True):
     return context
 
 
     return context
 
 
-@register.inclusion_tag('catalogue/_book.html')
-def book(request, book):
-    tags = book.tags.filter(~Q(category__in=('set', 'theme')))
-    tags = [u'<a href="%s">%s</a>' % (tag.get_absolute_url(), tag.name) for tag in tags]
-    
-    formats = []
-    if book.html_file:
-        formats.append(u'<a href="%s">Czytaj online</a>' % book.html_file.url)
-    if book.pdf_file:
-        formats.append(u'<a href="%s">Plik PDF</a>' % book.pdf_file.url)
-    if book.odt_file:
-        formats.append(u'<a href="%s">Plik ODT</a>' % book.odt_file.url)
-        
-    return locals()
-
-
 @register.tag
 def catalogue_url(parser, token):
     bits = token.split_contents()
 @register.tag
 def catalogue_url(parser, token):
     bits = token.split_contents()
diff --git a/templates/catalogue/_book.html b/templates/catalogue/_book.html
deleted file mode 100644 (file)
index 08cb12c..0000000
+++ /dev/null
@@ -1,13 +0,0 @@
-<div class="book">
-    {% if request.user.is_authenticated %}
-    <div class="change-sets">
-        <a href="{% url catalogue.views.book_sets book.slug %}" class="jqm-trigger">Zestawy</a>
-    </div>
-    {% endif %}
-    <div class="book-thumbnail"></div>
-    <div class="book-description">
-        <h2><a href="{{ book.get_absolute_url }}">{{ book.title }}</a></h2>
-        <p style="margin: 0">Formaty: {{ formats|join:", "|safe }}</p>
-        <p style="margin: 0">Utwór w kategoriach: {{ tags|join:", "|safe }}</p>
-    </div>
-</div>
\ No newline at end of file
diff --git a/templates/catalogue/book_short.html b/templates/catalogue/book_short.html
new file mode 100644 (file)
index 0000000..eca279e
--- /dev/null
@@ -0,0 +1,13 @@
+<div class="book">
+    {# {% if request.user.is_authenticated %} #}
+    <div class="change-sets">
+        <a href="{% url catalogue.views.book_sets book.slug %}" class="jqm-trigger">Zestawy</a>
+    </div>
+    {# {% endif %} #}
+    <div class="book-thumbnail"></div>
+    <div class="book-description">
+        <h2><a href="{{ book.get_absolute_url }}">{{ book.title }}</a></h2>
+        <p style="margin: 0">Formaty: {{ formats|join:", "|safe }}</p>
+        <p style="margin: 0">Utwór w kategoriach: {{ tags|join:", "|safe }}</p>
+    </div>
+</div>
index 743035b..12c0981 100644 (file)
@@ -68,7 +68,7 @@
         {% endwith %}
         <ol>
         {% for book in object_list %}
         {% endwith %}
         <ol>
         {% for book in object_list %}
-            <li>{% book request book %}</li>
+            <li>{{ book.short_html }}</li>
         {% endfor %}
         </ol>
         {% paginate %}
         {% endfor %}
         </ol>
         {% paginate %}