diff options
Diffstat (limited to 'sublab_project/news')
-rw-r--r-- | sublab_project/news/feeds.py | 32 | ||||
-rw-r--r-- | sublab_project/news/templates/news/news_detail.html | 6 | ||||
-rw-r--r-- | sublab_project/news/templates/news/news_list.html | 6 | ||||
-rw-r--r-- | sublab_project/news/urls.py | 3 |
4 files changed, 39 insertions, 8 deletions
diff --git a/sublab_project/news/feeds.py b/sublab_project/news/feeds.py new file mode 100644 index 0000000..011cee5 --- /dev/null +++ b/sublab_project/news/feeds.py @@ -0,0 +1,32 @@ +from django.contrib.syndication.views import Feed +from django.utils.feedgenerator import Atom1Feed +from django.core.urlresolvers import reverse +from django.utils.html import strip_tags + +from news.models import News + +class NewsFeed(Feed): + title = "sublab.org news" + description = "the latest news from your sublab" + + def link(self): + return reverse(self) + + def items(self): + return News.objects.order_by('-date_updated')[:10] + + def item_author_name(self, item): + return item.author + + def item_description(self, item): + return strip_tags(item.content_html) + + def item_title(self, item): + return item.title + + def item_pubdate(self, item): + return item.date_created + +class NewsFeedAtom(NewsFeed): + feed_type = Atom1Feed + subtitle = NewsFeed.description diff --git a/sublab_project/news/templates/news/news_detail.html b/sublab_project/news/templates/news/news_detail.html index 49d2b7a..27c7449 100644 --- a/sublab_project/news/templates/news/news_detail.html +++ b/sublab_project/news/templates/news/news_detail.html @@ -5,9 +5,7 @@ {% block content %} <p class="news_date">{{ object.date_updated|date:"DATETIME_FORMAT" }}</p> <h2 id="{{ object.slug }}">{{ object.title }}</h3> - <p> - {% if object.image %}<img src="{{ MEDIA_URL }}{{ object.image }}" width="{{ object.image_width }}" height="{{ object.image_height }}" align="right" />{% endif %} - {{ object.content_html|safe }} - </p> + {% if object.image %}<img src="{{ MEDIA_URL }}{{ object.image }}" width="{{ object.image_width }}" height="{{ object.image_height }}" align="right" />{% endif %} + {{ object.content_html|safe }} <p class="header">{{ object.author }}</p> {% endblock content %} diff --git a/sublab_project/news/templates/news/news_list.html b/sublab_project/news/templates/news/news_list.html index 52ded72..080feaf 100644 --- a/sublab_project/news/templates/news/news_list.html +++ b/sublab_project/news/templates/news/news_list.html @@ -6,10 +6,8 @@ <h3 id="{{ post.slug }}"> <a href="{{ post.get_absolute_url }}">{{ post.date_updated|date }} - {{ post.title }}</a> </h3> - <p> - {% if post.image %}<img src="{{ MEDIA_URL }}{{ post.image }}" width="{{ post.image_width }}" height="{{ post.image_height }}" align="right" />{% endif %} - {{ post.content_html|safe }} - </p> + {% if post.image %}<img src="{{ MEDIA_URL }}{{ post.image }}" width="{{ post.image_width }}" height="{{ post.image_height }}" align="right" />{% endif %} + {{ post.content_html|safe }} {% endfor %} {% if is_paginated %} <p> diff --git a/sublab_project/news/urls.py b/sublab_project/news/urls.py index fe682ad..7f2029c 100644 --- a/sublab_project/news/urls.py +++ b/sublab_project/news/urls.py @@ -2,9 +2,12 @@ from django.conf.urls.defaults import patterns, include, url from django.views.generic import DetailView from news.models import News +from news.feeds import NewsFeed, NewsFeedAtom from news.views import NewsListView urlpatterns = patterns('', url(r'^$', NewsListView.as_view(), name='news_list'), url(r'^news/(?P<slug>[-\w]+)/$', DetailView.as_view(model=News), name='news_detail'), + url(r'^newsfeed/rss/$', NewsFeed(), name='news_feed'), + url(r'^newsfeed/atom/$', NewsFeedAtom(), name='news_feed_atom'), ) |