From 81591fdb40a718c4e5b631cc4f940865540695d3 Mon Sep 17 00:00:00 2001 From: Ross Poulton Date: Tue, 18 Aug 2009 12:12:35 +0000 Subject: [PATCH] Fix issue #97 and issue #79: * Errors with invalid page number for paginaton code * Comment / Resolution not always saved. --- forms.py | 1 + views/staff.py | 19 ++++++++++--------- 2 files changed, 11 insertions(+), 9 deletions(-) diff --git a/forms.py b/forms.py index 1f53df16..1e842147 100644 --- a/forms.py +++ b/forms.py @@ -132,6 +132,7 @@ class TicketForm(forms.Form): context = { 'ticket': t, 'queue': q, + 'comment': f.comment, } messages_sent_to = [] diff --git a/views/staff.py b/views/staff.py index 6eba78b6..b9178d58 100644 --- a/views/staff.py +++ b/views/staff.py @@ -14,7 +14,7 @@ from django.contrib.auth.models import User from django.contrib.auth.decorators import login_required, user_passes_test from django.core.files.base import ContentFile from django.core.urlresolvers import reverse -from django.core.paginator import Paginator +from django.core import paginator from django.db import connection from django.db.models import Q from django.http import HttpResponseRedirect, Http404, HttpResponse, HttpResponseForbidden @@ -235,11 +235,12 @@ def update_ticket(request, ticket_id, public=False): messages_sent_to = [] + context.update( + resolution=ticket.resolution, + comment=f.comment, + ) + if ticket.submitter_email and public and (f.comment or (f.new_status in (Ticket.RESOLVED_STATUS, Ticket.CLOSED_STATUS))): - context.update( - resolution=ticket.resolution, - comment=f.comment, - ) if f.new_status == Ticket.RESOLVED_STATUS: template = 'resolved_submitter' @@ -504,16 +505,16 @@ def ticket_list(request): query_params['sortreverse'] = sortreverse ticket_qs = apply_query(Ticket.objects.select_related(), query_params) - paginator = Paginator(ticket_qs, request.user.usersettings.settings.get('tickets_per_page', 20)) + ticket_paginator = paginator.Paginator(ticket_qs, request.user.usersettings.settings.get('tickets_per_page', 20)) try: page = int(request.GET.get('page', '1')) except ValueError: page = 1 try: - tickets = paginator.page(page) - except (EmptyPage, InvalidPage): - tickets = paginator.page(paginator.num_pages) + tickets = ticket_paginator.page(page) + except (paginator.EmptyPage, paginator.InvalidPage): + tickets = ticket_paginator.page(ticket_paginator.num_pages) search_message = '' if context.has_key('query') and settings.DATABASE_ENGINE.startswith('sqlite'):