Commit e7efcb5d2c9204bad02b4fbcc04e6e903181b458
1 parent
69786057
Exists in
master
and in
4 other branches
Added get_list view using list_name and MAX
Signed-off-by: Macartur Sousa <macartur.sc@gmail.com> Signed-off-by: Alexandre Barbosa <alexandrealmeidabarbosa@gmail.com>
Showing
3 changed files
with
89 additions
and
4 deletions
Show diff stats
colab_spb/views.py
| 1 | 1 | from django.shortcuts import render |
| 2 | -from django.http import HttpResponse | |
| 2 | +from django.utils.translation import ugettext as _ | |
| 3 | +from colab.super_archives.models import MailingList, Thread | |
| 4 | +from colab.accounts.utils import mailman | |
| 3 | 5 | |
| 4 | -def get_list(request,path=None,list_name=None): | |
| 5 | - return HttpResponse('Hello Word') | |
| 6 | +def get_list(request): | |
| 7 | + list_name = None | |
| 8 | + MAX = 0 | |
| 9 | + if request.GET.get('list_name'): | |
| 10 | + list_name = request.GET['list_name'] | |
| 11 | + if request.GET.get('MAX'): | |
| 12 | + MAX = request.GET['MAX'] | |
| 13 | + | |
| 14 | + context = {} | |
| 15 | + | |
| 16 | + all_privates = {} | |
| 17 | + private_mailinglist = MailingList.objects.filter(is_private=True) | |
| 18 | + for mailinglist in private_mailinglist: | |
| 19 | + all_privates[mailinglist.name] = True | |
| 20 | + | |
| 21 | + context['lists'] = [] | |
| 22 | + | |
| 23 | + lists_for_user = [] | |
| 24 | + if request.user.is_authenticated(): | |
| 25 | + user = User.objects.get(username=request.user) | |
| 26 | + lists_for_user = mailman.get_user_mailinglists(user) | |
| 27 | + | |
| 28 | + for list_ in MailingList.objects.filter(name=list_name): | |
| 29 | + if list_.name not in all_privates or list_.name in lists_for_user: | |
| 30 | + context['lists'].append(( | |
| 31 | + list_.name, | |
| 32 | + mailman.get_list_description(list_.name), | |
| 33 | + list_.thread_set.filter(spam=False).order_by( | |
| 34 | + '-latest_message__received_time' | |
| 35 | + )[:MAX], | |
| 36 | + [t.latest_message for t in Thread.highest_score.filter( | |
| 37 | + mailinglist__name=list_.name)[:MAX]], | |
| 38 | + len(mailman.list_users(list_.name)), | |
| 39 | + )) | |
| 40 | + | |
| 41 | + return render(request,"discussion.html",context) | ... | ... |
| ... | ... | @@ -0,0 +1,49 @@ |
| 1 | + | |
| 2 | + {% load i18n %} | |
| 3 | + <h2>{% trans 'Groups'|title %}</h2> | |
| 4 | + <hr/> | |
| 5 | + | |
| 6 | + {% for listname, description, latest, most_relevant, number_of_users in lists %} | |
| 7 | + {% if latest or most_relevant %} | |
| 8 | + <h3><b>{{ listname|title|lower }} {% if description %} ({{ description }}){% endif %}</b></h3> | |
| 9 | + <div class="btn-group btn-group-sm"> | |
| 10 | + <a href="#" class="btn btn-default" disabled="disabled">{% blocktrans %}{{ number_of_users }} members{% endblocktrans %}</a> | |
| 11 | + {% if proxy.trac %} | |
| 12 | + <a href="/wiki/grupos/{{ listname }}" class="btn btn-default">Wiki</a> | |
| 13 | + {% endif %} | |
| 14 | + </div> | |
| 15 | + <hr/> | |
| 16 | + | |
| 17 | + <div class="row"> | |
| 18 | + <div class="col-lg-6 col-md-6 col-sm-12 col-xs-12"> | |
| 19 | + <h4>{% trans 'latest'|title %}</h4> | |
| 20 | + <ul class="message-list"> | |
| 21 | + {% for thread in latest %} | |
| 22 | + {% include "message-preview.html" with result=thread.latest_message %} | |
| 23 | + {% endfor %} | |
| 24 | + </ul> | |
| 25 | + <div class="text-right"> | |
| 26 | + <a href="{% url 'haystack_search' %}?order=latest&list={{ listname }}&type=thread"> | |
| 27 | + {% trans "more..." %} | |
| 28 | + </a> | |
| 29 | + </div> | |
| 30 | + </div> | |
| 31 | + | |
| 32 | + <div class="col-lg-6 col-md-6 col-sm-12 col-xs-12"> | |
| 33 | + <h4>{% trans 'most relevant'|title %}</h4> | |
| 34 | + <ul class="message-list"> | |
| 35 | + {% for thread in most_relevant %} | |
| 36 | + {% include "message-preview.html" with result=thread %} | |
| 37 | + {% endfor %} | |
| 38 | + </ul> | |
| 39 | + <div class="text-right"> | |
| 40 | + <a href="{% url 'haystack_search' %}?list={{ listname }}&type=thread"> | |
| 41 | + {% trans "more..." %} | |
| 42 | + </a> | |
| 43 | + </div> | |
| 44 | + </div> | |
| 45 | + </div> | |
| 46 | + | |
| 47 | + | |
| 48 | + {% endif %} | |
| 49 | + {% endfor %} | ... | ... |
urls.py