X-Git-Url: https://git.openstreetmap.org./osqa.git/blobdiff_plain/0f2d00f9d7d5d28149707f66c719b28edfe51aed..47bc0543a1d3f25ec90311883b4e28186a3ddd7e:/forum/views/readers.py diff --git a/forum/views/readers.py b/forum/views/readers.py index 819384f..5f58344 100644 --- a/forum/views/readers.py +++ b/forum/views/readers.py @@ -56,11 +56,11 @@ def _get_tags_cache_json():#service routine used by views requiring tag list in @decorators.render('index.html') def index(request): - return question_list(request, Question.objects.all(), sort='latest', base_path=reverse('questions')) + return question_list(request, Question.objects.all(), sort='active', base_path=reverse('questions')) @decorators.render('questions.html', 'unanswered') def unanswered(request): - return question_list(request, Question.objects.filter(answer_accepted=False), + return question_list(request, Question.objects.filter(accepted_answer=None), _('Open questions without an accepted answer')) @decorators.render('questions.html', 'questions') @@ -83,14 +83,15 @@ def question_list(request, initial, list_description=_('questions'), sort=None, questions = questions.filter( ~Q(tags__id__in=request.user.marked_tags.filter(user_selections__reason='bad'))) - if sort is None: - sort = request.utils.sort_method('latest') - else: - request.utils.set_sort_method(sort) - - view_dic = {"latest":"-added_at", "active":"-last_activity_at", "hottest":"-answer_count", "mostvoted":"-score" } + if sort is not False: + if sort is None: + sort = request.utils.sort_method('latest') + else: + request.utils.set_sort_method(sort) - questions=questions.order_by(view_dic.get(sort, '-added_at')) + view_dic = {"latest":"-added_at", "active":"-last_activity_at", "hottest":"-answer_count", "mostvoted":"-score" } + + questions=questions.order_by(view_dic.get(sort, '-added_at')) return { "questions" : questions, @@ -128,7 +129,7 @@ def question_search(request, keywords): initial = question_search(keywords) return question_list(request, initial, _("questions matching '%(keywords)s'") % {'keywords': keywords}, - base_path="%s?t=question&q=%s" % (reverse('search'), django_urlquote(keywords))) + base_path="%s?t=question&q=%s" % (reverse('search'), django_urlquote(keywords)), sort=False) def tags(request):#view showing a listing of available tags - plain list @@ -186,21 +187,42 @@ def get_answer_sort_order(request): return (view_id, view_dic[view_id]) def update_question_view_times(request, question): - if not 'question_view_times' in request.session: - request.session['question_view_times'] = {} + if not 'last_seen_in_question' in request.session: + request.session['last_seen_in_question'] = {} - last_seen = request.session['question_view_times'].get(question.id,None) + last_seen = request.session['last_seen_in_question'].get(question.id,None) - if not last_seen or last_seen < question.last_activity_at: + if (not last_seen) or last_seen < question.last_activity_at: question_view.send(sender=update_question_view_times, instance=question, user=request.user) - request.session['question_view_times'][question.id] = datetime.datetime.now() + request.session['last_seen_in_question'][question.id] = datetime.datetime.now() + + request.session['last_seen_in_question'][question.id] = datetime.datetime.now() - request.session['question_view_times'][question.id] = datetime.datetime.now() +def match_question_slug(slug): + slug_words = slug.split('-') + qs = Question.objects.filter(title__istartswith=slug_words[0]) + + for q in qs: + if slug == urlquote(slugify(q.title)): + return q + + return None def question(request, id, slug): - question = get_object_or_404(Question, id=id) + try: + question = Question.objects.get(id=id) + except: + question = match_question_slug(slug) + if question is not None: + return HttpResponseRedirect(question.get_absolute_url()) + else: + raise Http404() if slug != urlquote(slugify(question.title)): + match = match_question_slug(slug) + if match is not None: + return HttpResponseRedirect(match.get_absolute_url()) + return HttpResponseRedirect(question.get_absolute_url()) page = int(request.GET.get('page', 1))