diff options
Diffstat (limited to 'hyperkitty/views')
-rw-r--r-- | hyperkitty/views/list.py | 20 | ||||
-rw-r--r-- | hyperkitty/views/message.py | 16 |
2 files changed, 6 insertions, 30 deletions
diff --git a/hyperkitty/views/list.py b/hyperkitty/views/list.py index a61f0a9..4857c27 100644 --- a/hyperkitty/views/list.py +++ b/hyperkitty/views/list.py @@ -31,9 +31,10 @@ from django.utils.dateformat import format as date_format from django.utils.timezone import utc from django.http import Http404 -from hyperkitty.models import Tag, Favorite, LastView +from hyperkitty.models import Tag, Favorite from hyperkitty.lib import get_months, get_store, get_display_dates, daterange from hyperkitty.lib import FLASH_MESSAGES, paginate, get_category_widget +from hyperkitty.lib import is_thread_unread from hyperkitty.lib.voting import get_votes, set_message_votes, set_thread_votes @@ -43,7 +44,7 @@ if settings.USE_MOCKUPS: Thread = namedtuple('Thread', [ "thread_id", "subject", "participants", "length", "date_active", - "likes", "dislikes", "likestatus", "category", + "likes", "dislikes", "likestatus", "category", "unread", ]) @@ -112,19 +113,7 @@ def _thread_list(request, mlist, threads, template_name='thread_list.html', extr get_category_widget(request, thread.category) # Unread status - thread.unread = False - if request.user.is_authenticated(): - try: - last_view_obj = LastView.objects.get( - list_address=mlist.name, - threadid=thread.thread_id, - user=request.user) - except LastView.DoesNotExist: - thread.unread = True - else: - if thread.date_active.replace(tzinfo=utc) \ - > last_view_obj.view_date: - thread.unread = True + thread.unread = is_thread_unread(request, mlist.name, thread) threads = paginate(threads, request.GET.get('page')) @@ -175,6 +164,7 @@ def overview(request, mlist_fqdn=None): thread_obj.likes, thread_obj.dislikes, thread_obj.likestatus, get_category_widget(None, thread_obj.category)[0], + is_thread_unread(request, mlist.name, thread_obj), ) # Statistics on how many participants and threads this month participants.update(thread.participants) diff --git a/hyperkitty/views/message.py b/hyperkitty/views/message.py index 4266877..66cc314 100644 --- a/hyperkitty/views/message.py +++ b/hyperkitty/views/message.py @@ -33,7 +33,7 @@ from django.contrib.auth.decorators import login_required from hyperkitty.lib import get_store, get_months, post_to_list, PostingFailed from hyperkitty.lib.voting import set_message_votes -from hyperkitty.models import Rating, LastView +from hyperkitty.models import Rating from forms import ReplyForm, PostForm @@ -50,26 +50,12 @@ def index(request, mlist_fqdn, message_id_hash): set_message_votes(message, request.user) mlist = store.get_list(mlist_fqdn) - # Last thread view - last_view = None - if request.user.is_authenticated(): - try: - last_view_obj = LastView.objects.get( - list_address=mlist.name, - threadid=message.thread_id, - user=request.user) - except LastView.DoesNotExist: - pass - else: - last_view = last_view_obj.view_date - context = { 'mlist' : mlist, 'message': message, 'message_id_hash' : message_id_hash, 'months_list': get_months(store, mlist.name), 'reply_form': ReplyForm(), - 'last_view': last_view, } return render(request, "message.html", context) |