diff options
Diffstat (limited to 'app/posts/views')
-rw-r--r-- | app/posts/views/essay_views.py | 54 | ||||
-rw-r--r-- | app/posts/views/guide_views.py | 42 |
2 files changed, 54 insertions, 42 deletions
diff --git a/app/posts/views/essay_views.py b/app/posts/views/essay_views.py new file mode 100644 index 0000000..ca1697f --- /dev/null +++ b/app/posts/views/essay_views.py @@ -0,0 +1,54 @@ +from django.views.generic import ListView +from django.views.generic.detail import DetailView +from django.contrib.syndication.views import Feed +from django.apps import apps +from django.conf import settings + +from utils.views import PaginatedListView, LuxDetailView + +from ..models import Post, PostType +from taxonomy.models import Category + + +class EssayListView(PaginatedListView): + model = Post + template_name = "posts/essay_list.html" + + def get_queryset(self): + queryset = super(EssayListView, self).get_queryset() + return queryset.filter(site__domain='luxagraf.net').filter(post_type__in=[PostType.ESSAY]).filter(status__exact=1).order_by('-pub_date').prefetch_related('location').prefetch_related('featured_image') + + def get_context_data(self, **kwargs): + ''' + override for custom breadcrumb path + ''' + # Call the base implementation first to get a context + context = super(EssayListView, self).get_context_data(**kwargs) + context['breadcrumbs'] = ('Essay',) + return context + + +class EssayDetailView(LuxDetailView): + model = Post + slug_field = "slug" + + def get_queryset(self): + queryset = super(EssayDetailView, self).get_queryset() + return queryset.select_related('location').prefetch_related('field_notes') + + def get_context_data(self, **kwargs): + context = super(EssayDetailView, self).get_context_data(**kwargs) + related = [] + for obj in self.object.related.all(): + model = apps.get_model(obj.model_name.app_label, obj.model_name.model) + related.append(model.objects.get(slug=obj.slug, pub_date=obj.pub_date)) + context['related'] = related + return context + + def get_template_names(self): + obj = self.get_object() + return ["posts/essay_detail.html"] + + +class EssayDetailViewTXT(EssayDetailView): + template_name = "posts/entry_detail.txt" diff --git a/app/posts/views/guide_views.py b/app/posts/views/guide_views.py index c5fdd55..346fcc7 100644 --- a/app/posts/views/guide_views.py +++ b/app/posts/views/guide_views.py @@ -58,48 +58,6 @@ class ReviewsListView(GuideListView): return context -class NotesListView(PaginatedListView): - model = Post - template_name = "posts/note_list.html" - - def get_queryset(self): - queryset = super(NotesListView, self).get_queryset() - return queryset.filter(site__domain='luxagraf.net').filter(post_type__in=[PostType.NOTE]).filter(status__exact=1).order_by('-pub_date').prefetch_related('location').prefetch_related('featured_image') - - def get_context_data(self, **kwargs): - ''' - override for custom breadcrumb path - ''' - # Call the base implementation first to get a context - context = super(NotesListView, self).get_context_data(**kwargs) - context['breadcrumbs'] = ('Notes',) - return context - - - -class NoteDetailView(LuxDetailView): - model = Post - slug_field = "slug" - - def get_queryset(self): - queryset = super(EssayDetailView, self).get_queryset() - return queryset.select_related('location').prefetch_related('field_notes') - - def get_context_data(self, **kwargs): - context = super(EssayDetailView, self).get_context_data(**kwargs) - related = [] - for obj in self.object.related.all(): - model = apps.get_model(obj.model_name.app_label, obj.model_name.model) - related.append(model.objects.get(slug=obj.slug, pub_date=obj.pub_date)) - context['related'] = related - return context - - def get_template_names(self): - obj = self.get_object() - return ["posts/%s_detail.html" % obj.get_post_type_display(), 'posts/post_detail.html'] - - - class PostDetailView(LuxDetailView): model = Post slug_field = "slug" |