diff options
author | luxagraf <sng@luxagraf.net> | 2024-02-25 16:43:51 -0600 |
---|---|---|
committer | luxagraf <sng@luxagraf.net> | 2024-02-25 16:43:51 -0600 |
commit | 164eee8075761c46add169fe5631f45f1ec8746d (patch) | |
tree | 59118b702104e356e301bb86e6a6edb060311931 /app/posts/views/review_views.py | |
parent | dfdfae5272f36f0b21ac895a880237a5c0e61f04 (diff) |
jrnl: re-arranged to make Range a repository for everything.
Diffstat (limited to 'app/posts/views/review_views.py')
-rw-r--r-- | app/posts/views/review_views.py | 53 |
1 files changed, 53 insertions, 0 deletions
diff --git a/app/posts/views/review_views.py b/app/posts/views/review_views.py new file mode 100644 index 0000000..353a5e9 --- /dev/null +++ b/app/posts/views/review_views.py @@ -0,0 +1,53 @@ +from django.views.generic import ListView +from django.views.generic.detail import DetailView +from django.contrib.syndication.views import Feed +from django.urls import reverse +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 ReviewListView(PaginatedListView): + model = Post + template_name = "posts/review_list.html" + + def get_queryset(self): + queryset = super(ReviewListView, self).get_queryset() + return queryset.filter(site__domain='luxagraf.net').filter(post_type__in=[PostType.REVIEW]).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(ReviewListView, self).get_context_data(**kwargs) + context['breadcrumbs'] = ('Reviews',) + return context + + +class ReviewDetailView(LuxDetailView): + model = Post + slug_field = "slug" + + def get_context_data(self, **kwargs): + context = super(ReviewDetailView, 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 + context['breadcrumbs'] = ('Range',) + context['crumb_url'] = reverse('range:range-list') + return context + + def get_template_names(self): + obj = self.get_object() + return ["posts/review_detail.html"] + + +class ReviewDetailViewTXT(ReviewDetailView): + template_name = "posts/entry_detail.txt" |