Mercurial > public > sg101
view gpp/ygroup/views.py @ 363:9d470c7a2b93
Following up on #168; redo some code to make it more DRY. Added a function on the profile to reset the text fields.
author | Brian Neal <bgneal@gmail.com> |
---|---|
date | Sat, 05 Mar 2011 04:03:30 +0000 |
parents | 0c18dfb1da1c |
children |
line wrap: on
line source
""" Views for the ygroup (Yahoo Group Archive) application. """ from django.shortcuts import get_object_or_404 from django.views.generic import ListView from ygroup.models import Thread, Post from core.paginator import DiggPaginator THREADS_PER_PAGE = 40 POSTS_PER_PAGE = 20 class ThreadIndexView(ListView): """ This generic view displays the list of threads available. """ model = Thread paginate_by = THREADS_PER_PAGE def get_paginator(self, queryset, per_page, **kwargs): """ Return an instance of the paginator for this view. """ return DiggPaginator(queryset, per_page, body=5, tail=2, margin=3, padding=2, **kwargs) class ThreadView(ListView): """ This generic view displays the posts in a thread. """ context_object_name = "post_list" template_name = "ygroup/thread.html" paginate_by = POSTS_PER_PAGE def get_queryset(self): self.thread = get_object_or_404(Thread, pk=self.args[0]) return Post.objects.filter(thread=self.thread) def get_context_data(self, **kwargs): context = super(ThreadView, self).get_context_data(**kwargs) context['thread'] = self.thread return context def get_paginator(self, queryset, per_page, **kwargs): """ Return an instance of the paginator for this view. """ return DiggPaginator(queryset, per_page, body=5, tail=2, margin=3, padding=2, **kwargs)