Commit e7efcb5d2c9204bad02b4fbcc04e6e903181b458
1 parent
69786057
Exists in
master
and in
34 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