X-Git-Url: http://git.ithinksw.org/philo.git/blobdiff_plain/2628ac11201c749bbd3aea23597af8238b3a3e5a..43a0fca55725921fd0748de90479ee2fa9cdbc6f:/contrib/penfield/models.py diff --git a/contrib/penfield/models.py b/contrib/penfield/models.py index 3cbff52..555d9a2 100644 --- a/contrib/penfield/models.py +++ b/contrib/penfield/models.py @@ -10,6 +10,8 @@ from philo.utils import paginate from philo.contrib.penfield.validators import validate_pagination_count from django.utils.feedgenerator import Atom1Feed, Rss201rev2Feed from philo.contrib.penfield.utils import FeedMultiViewMixin +from philo.contrib.penfield.embed import * +from django.template import add_to_builtins as register_templatetags class Blog(Entity, Titled): @@ -75,10 +77,6 @@ class BlogView(MultiView, FeedMultiViewMixin): def per_page(self): return self.entries_per_page - @property - def feed_title(self): - return self.blog.title - def get_subpath(self, obj): if isinstance(obj, BlogEntry): if obj.blog == self.blog: @@ -211,6 +209,19 @@ class BlogView(MultiView, FeedMultiViewMixin): defaults.update(kwargs or {}) super(BlogView, self).add_item(feed, obj, defaults) + def get_feed(self, feed_type, extra_context, kwargs=None): + tags = (extra_context or {}).get('tags', None) + title = self.blog.title + + if tags is not None: + title += " - %s" % ', '.join([tag.name for tag in tags]) + + defaults = { + 'title': title + } + defaults.update(kwargs or {}) + return super(BlogView, self).get_feed(feed_type, extra_context, defaults) + def entry_view(self, request, slug, year=None, month=None, day=None, node=None, extra_context=None): entries = self.blog.entries.all() if year: @@ -301,10 +312,6 @@ class NewsletterView(MultiView, FeedMultiViewMixin): def __unicode__(self): return self.newsletter.__unicode__() - @property - def feed_title(self): - return self.newsletter.title - def get_subpath(self, obj): if isinstance(obj, NewsletterArticle): if obj.newsletter == self.newsletter: @@ -424,4 +431,16 @@ class NewsletterView(MultiView, FeedMultiViewMixin): 'categories': [tag.name for tag in obj.tags.all()] } defaults.update(kwargs or {}) - super(NewsletterView, self).add_item(feed, obj, defaults) \ No newline at end of file + super(NewsletterView, self).add_item(feed, obj, defaults) + + def get_feed(self, feed_type, extra_context, kwargs=None): + title = self.newsletter.title + + defaults = { + 'title': title + } + defaults.update(kwargs or {}) + return super(NewsletterView, self).get_feed(feed_type, extra_context, defaults) + + +register_templatetags('philo.contrib.penfield.templatetags.embed') \ No newline at end of file