X-Git-Url: https://git.openstreetmap.org./osqa.git/blobdiff_plain/f1defc59ca7a7b15e17e8a59c72a726ae937d8e5..99d077e46d0eb3efd5e96a65f120e6e4b6197db0:/forum/views/writers.py diff --git a/forum/views/writers.py b/forum/views/writers.py index 41a1320..85f40de 100644 --- a/forum/views/writers.py +++ b/forum/views/writers.py @@ -1,19 +1,23 @@ # encoding:utf-8 import os.path -from django.views.decorators.csrf import csrf_exempt +import datetime + +from django.core.urlresolvers import reverse from django.core.files.storage import FileSystemStorage +from django.views.decorators.csrf import csrf_exempt from django.shortcuts import render_to_response, get_object_or_404 -from django.http import HttpResponseRedirect, HttpResponse, Http404 from django.template import RequestContext +from django.http import HttpResponseRedirect, HttpResponse, Http404 from django.utils.html import * from django.utils.translation import ugettext as _ +from django.contrib import messages + from forum.actions import AskAction, AnswerAction, ReviseAction, RollbackAction, RetagAction, AnswerToQuestionAction, CommentToQuestionAction from forum.forms import * from forum.models import * from forum.utils import html - from forum.http_responses import HttpResponseUnauthorized from vars import PENDING_SUBMISSION_SESSION_ATTR @@ -64,7 +68,7 @@ def upload(request):#ajax upload file to a question or answer except Exception, e: result = xml_template % ('', _('Error uploading file. Please contact the site administrator. Thank you. %s' % e), '') - return HttpResponse(result, mimetype="application/xml") + return HttpResponse(result, content_type="application/xml") def ask(request): form = None @@ -93,8 +97,8 @@ def ask(request): } if request.user.is_authenticated(): - request.user.message_set.create(message=_("Your question is pending until you %s.") % html.hyperlink( - reverse('send_validation_email'), _("validate your email") + messages.info(request, _("Your question is pending until you %s.") % html.hyperlink( + django_settings.APP_URL + reverse('send_validation_email', prefix='/'), _("validate your email") )) return HttpResponseRedirect(reverse('index')) else: @@ -154,7 +158,8 @@ def _retag_question(request, question): #'tags' : _get_tags_cache_json(), }, context_instance=RequestContext(request)) -def _edit_question(request, question, template='question_edit.html', summary='', action_class=ReviseAction, allow_rollback=True, url_getter=lambda q: q.get_absolute_url()): +def _edit_question(request, question, template='question_edit.html', summary='', action_class=ReviseAction, + allow_rollback=True, url_getter=lambda q: q.get_absolute_url(), additional_context=None): if request.method == 'POST': revision_form = RevisionForm(question, data=request.POST) revision_form.is_valid() @@ -186,11 +191,16 @@ def _edit_question(request, question, template='question_edit.html', summary='', revision_form = RevisionForm(question) form = EditQuestionForm(question, request.user, initial={'summary': summary}) - return render_to_response(template, { + context = { 'question': question, 'revision_form': revision_form, 'form' : form, - }, context_instance=RequestContext(request)) + } + + if not (additional_context is None): + context.update(additional_context) + + return render_to_response(template, context, context_instance=RequestContext(request)) def edit_answer(request, id): @@ -262,8 +272,8 @@ def answer(request, id): } if request.user.is_authenticated(): - request.user.message_set.create(message=_("Your answer is pending until you %s.") % html.hyperlink( - reverse('send_validation_email'), _("validate your email") + messages.info(request, _("Your answer is pending until you %s.") % html.hyperlink( + django_settings.APP_URL + reverse('send_validation_email', prefix='/'), _("validate your email") )) return HttpResponseRedirect(question.get_absolute_url()) else: