Show More
@@ -6,6 +6,7 b' import time' | |||||
6 | import math |
|
6 | import math | |
7 | import re |
|
7 | import re | |
8 | from django.core.cache import cache |
|
8 | from django.core.cache import cache | |
|
9 | from django.core.paginator import Paginator | |||
9 |
|
10 | |||
10 | from django.db import models |
|
11 | from django.db import models | |
11 | from django.http import Http404 |
|
12 | from django.http import Http404 | |
@@ -126,28 +127,12 b' class PostManager(models.Manager):' | |||||
126 | threads = threads.filter(archived=archived).order_by(order_by) |
|
127 | threads = threads.filter(archived=archived).order_by(order_by) | |
127 |
|
128 | |||
128 | if page != ALL_PAGES: |
|
129 | if page != ALL_PAGES: | |
129 | thread_count = threads.count() |
|
130 | threads = Paginator(threads, settings.THREADS_PER_PAGE).page( | |
130 |
|
131 | page).object_list | ||
131 | if page < self._get_page_count(thread_count): |
|
|||
132 | start_thread = page * settings.THREADS_PER_PAGE |
|
|||
133 | end_thread = min(start_thread + settings.THREADS_PER_PAGE, |
|
|||
134 | thread_count) |
|
|||
135 | threads = threads[start_thread:end_thread] |
|
|||
136 |
|
132 | |||
137 | return threads |
|
133 | return threads | |
138 |
|
134 | |||
139 | # TODO Move this method to thread manager |
|
135 | # TODO Move this method to thread manager | |
140 | def get_thread_page_count(self, tag=None, archived=False): |
|
|||
141 | if tag: |
|
|||
142 | threads = Thread.objects.filter(tags=tag) |
|
|||
143 | else: |
|
|||
144 | threads = Thread.objects.all() |
|
|||
145 |
|
||||
146 | threads = threads.filter(archived=archived) |
|
|||
147 |
|
||||
148 | return self._get_page_count(threads.count()) |
|
|||
149 |
|
||||
150 | # TODO Move this method to thread manager |
|
|||
151 | def _delete_old_threads(self): |
|
136 | def _delete_old_threads(self): | |
152 | """ |
|
137 | """ | |
153 | Preserves maximum thread count. If there are too many threads, |
|
138 | Preserves maximum thread count. If there are too many threads, | |
@@ -180,13 +165,6 b' class PostManager(models.Manager):' | |||||
180 | referenced_post.last_edit_time = post.pub_time |
|
165 | referenced_post.last_edit_time = post.pub_time | |
181 | referenced_post.save() |
|
166 | referenced_post.save() | |
182 |
|
167 | |||
183 | def _get_page_count(self, thread_count): |
|
|||
184 | """ |
|
|||
185 | Get number of pages that will be needed for all threads |
|
|||
186 | """ |
|
|||
187 |
|
||||
188 | return int(math.ceil(thread_count / float(settings.THREADS_PER_PAGE))) |
|
|||
189 |
|
||||
190 | def get_posts_per_day(self): |
|
168 | def get_posts_per_day(self): | |
191 | """ |
|
169 | """ | |
192 | Get average count of posts per day for the last 7 days |
|
170 | Get average count of posts per day for the last 7 days |
@@ -6,23 +6,23 b'' | |||||
6 | {% load static %} |
|
6 | {% load static %} | |
7 |
|
7 | |||
8 | {% block head %} |
|
8 | {% block head %} | |
9 |
|
|
9 | <title>Neboard - {% trans 'Archive' %}</title> | |
10 |
|
10 | |||
11 |
{% if |
|
11 | {% if current_page.has_previous %} | |
12 |
<link rel=" |
|
12 | <link rel="prev" href=" | |
13 | {% if tag %} |
|
13 | {% if tag %} | |
14 | {% url "tag" tag_name=tag page=prev_page %} |
|
14 | {% url "tag" tag_name=tag page=current_page.previous_page_number %} | |
15 | {% else %} |
|
15 | {% else %} | |
16 | {% url "index" page=prev_page %} |
|
16 | {% url "index" page=current_page.previous_page_number %} | |
17 | {% endif %} |
|
17 | {% endif %} | |
18 | " /> |
|
18 | " /> | |
19 | {% endif %} |
|
19 | {% endif %} | |
20 |
{% if |
|
20 | {% if current_page.has_next %} | |
21 | <link rel="next" href=" |
|
21 | <link rel="next" href=" | |
22 | {% if tag %} |
|
22 | {% if tag %} | |
23 | {% url "tag" tag_name=tag page=next_page %} |
|
23 | {% url "tag" tag_name=tag page=current_page.next_page_number %} | |
24 | {% else %} |
|
24 | {% else %} | |
25 | {% url "index" page=next_page %} |
|
25 | {% url "index" page=current_page.next_page_number %} | |
26 | {% endif %} |
|
26 | {% endif %} | |
27 | " /> |
|
27 | " /> | |
28 | {% endif %} |
|
28 | {% endif %} | |
@@ -34,9 +34,9 b'' | |||||
34 | {% get_current_language as LANGUAGE_CODE %} |
|
34 | {% get_current_language as LANGUAGE_CODE %} | |
35 |
|
35 | |||
36 | {% if threads %} |
|
36 | {% if threads %} | |
37 |
{% if |
|
37 | {% if current_page.has_previous %} | |
38 | <div class="page_link"> |
|
38 | <div class="page_link"> | |
39 | <a href="{% url "archive" page=prev_page %}">{% trans "Previous page" %}</a> |
|
39 | <a href="{% url "archive" page=current_page.previous_page_number %}">{% trans "Previous page" %}</a> | |
40 | </div> |
|
40 | </div> | |
41 | {% endif %} |
|
41 | {% endif %} | |
42 |
|
42 | |||
@@ -111,9 +111,9 b'' | |||||
111 | {% endcache %} |
|
111 | {% endcache %} | |
112 | {% endfor %} |
|
112 | {% endfor %} | |
113 |
|
113 | |||
114 |
{% if |
|
114 | {% if current_page.has_next %} | |
115 | <div class="page_link"> |
|
115 | <div class="page_link"> | |
116 | <a href="{% url "archive" page=next_page %}">{% trans "Next page" %}</a> |
|
116 | <a href="{% url "archive" page=current_page.next_page_number %}">{% trans "Next page" %}</a> | |
117 | </div> |
|
117 | </div> | |
118 | {% endif %} |
|
118 | {% endif %} | |
119 | {% else %} |
|
119 | {% else %} | |
@@ -126,11 +126,11 b'' | |||||
126 | {% block metapanel %} |
|
126 | {% block metapanel %} | |
127 |
|
127 | |||
128 | <span class="metapanel"> |
|
128 | <span class="metapanel"> | |
129 |
<b><a href="{% url "authors" %}">Neboard</a> 1. |
|
129 | <b><a href="{% url "authors" %}">Neboard</a> 1.6 Amon</b> | |
130 | {% trans "Pages:" %}[ |
|
130 | {% trans "Pages:" %}[ | |
131 |
{% for page in pag |
|
131 | {% for page in paginator.page_range %} | |
132 | <a |
|
132 | <a | |
133 | {% ifequal page current_page %} |
|
133 | {% ifequal page current_page.number %} | |
134 | class="current_page" |
|
134 | class="current_page" | |
135 | {% endifequal %} |
|
135 | {% endifequal %} | |
136 | href=" |
|
136 | href=" |
@@ -12,21 +12,21 b'' | |||||
12 | <title>Neboard</title> |
|
12 | <title>Neboard</title> | |
13 | {% endif %} |
|
13 | {% endif %} | |
14 |
|
14 | |||
15 |
{% if |
|
15 | {% if current_page.has_previous %} | |
16 |
<link rel=" |
|
16 | <link rel="prev" href=" | |
17 | {% if tag %} |
|
17 | {% if tag %} | |
18 | {% url "tag" tag_name=tag page=prev_page %} |
|
18 | {% url "tag" tag_name=tag page=current_page.previous_page_number %} | |
19 | {% else %} |
|
19 | {% else %} | |
20 | {% url "index" page=prev_page %} |
|
20 | {% url "index" page=current_page.previous_page_number %} | |
21 | {% endif %} |
|
21 | {% endif %} | |
22 | " /> |
|
22 | " /> | |
23 | {% endif %} |
|
23 | {% endif %} | |
24 |
{% if |
|
24 | {% if current_page.has_next %} | |
25 | <link rel="next" href=" |
|
25 | <link rel="next" href=" | |
26 | {% if tag %} |
|
26 | {% if tag %} | |
27 | {% url "tag" tag_name=tag page=next_page %} |
|
27 | {% url "tag" tag_name=tag page=current_page.next_page_number %} | |
28 | {% else %} |
|
28 | {% else %} | |
29 | {% url "index" page=next_page %} |
|
29 | {% url "index" page=current_page.next_page_number %} | |
30 | {% endif %} |
|
30 | {% endif %} | |
31 | " /> |
|
31 | " /> | |
32 | {% endif %} |
|
32 | {% endif %} | |
@@ -53,13 +53,13 b'' | |||||
53 | {% endif %} |
|
53 | {% endif %} | |
54 |
|
54 | |||
55 | {% if threads %} |
|
55 | {% if threads %} | |
56 |
{% if |
|
56 | {% if current_page.has_previous %} | |
57 | <div class="page_link"> |
|
57 | <div class="page_link"> | |
58 | <a href=" |
|
58 | <a href=" | |
59 | {% if tag %} |
|
59 | {% if tag %} | |
60 | {% url "tag" tag_name=tag page=prev_page %} |
|
60 | {% url "tag" tag_name=tag page=current_page.previous_page_number %} | |
61 | {% else %} |
|
61 | {% else %} | |
62 | {% url "index" page=prev_page %} |
|
62 | {% url "index" page=current_page.previous_page_number %} | |
63 | {% endif %} |
|
63 | {% endif %} | |
64 | ">{% trans "Previous page" %}</a> |
|
64 | ">{% trans "Previous page" %}</a> | |
65 | </div> |
|
65 | </div> | |
@@ -69,9 +69,9 b'' | |||||
69 | {% cache 600 thread_short thread.id thread.thread.last_edit_time moderator LANGUAGE_CODE %} |
|
69 | {% cache 600 thread_short thread.id thread.thread.last_edit_time moderator LANGUAGE_CODE %} | |
70 | <div class="thread"> |
|
70 | <div class="thread"> | |
71 | {% if thread.bumpable %} |
|
71 | {% if thread.bumpable %} | |
72 |
|
|
72 | <div class="post" id="{{ thread.op.id }}"> | |
73 | {% else %} |
|
73 | {% else %} | |
74 |
|
|
74 | <div class="post dead_post" id="{{ thread.op.id }}"> | |
75 | {% endif %} |
|
75 | {% endif %} | |
76 | {% if thread.op.image %} |
|
76 | {% if thread.op.image %} | |
77 | <div class="image"> |
|
77 | <div class="image"> | |
@@ -192,13 +192,13 b'' | |||||
192 | {% endcache %} |
|
192 | {% endcache %} | |
193 | {% endfor %} |
|
193 | {% endfor %} | |
194 |
|
194 | |||
195 |
{% if |
|
195 | {% if current_page.has_next %} | |
196 | <div class="page_link"> |
|
196 | <div class="page_link"> | |
197 | <a href=" |
|
197 | <a href=" | |
198 | {% if tag %} |
|
198 | {% if tag %} | |
199 | {% url "tag" tag_name=tag page=next_page %} |
|
199 | {% url "tag" tag_name=tag page=current_page.next_page_number %} | |
200 | {% else %} |
|
200 | {% else %} | |
201 | {% url "index" page=next_page %} |
|
201 | {% url "index" page=current_page.next_page_number %} | |
202 | {% endif %} |
|
202 | {% endif %} | |
203 | ">{% trans "Next page" %}</a> |
|
203 | ">{% trans "Next page" %}</a> | |
204 | </div> |
|
204 | </div> | |
@@ -233,9 +233,9 b'' | |||||
233 | <span class="metapanel"> |
|
233 | <span class="metapanel"> | |
234 | <b><a href="{% url "authors" %}">Neboard</a> 1.6 Amon</b> |
|
234 | <b><a href="{% url "authors" %}">Neboard</a> 1.6 Amon</b> | |
235 | {% trans "Pages:" %}[ |
|
235 | {% trans "Pages:" %}[ | |
236 |
{% for page in pag |
|
236 | {% for page in paginator.page_range %} | |
237 | <a |
|
237 | <a | |
238 | {% ifequal page current_page %} |
|
238 | {% ifequal page current_page.number %} | |
239 | class="current_page" |
|
239 | class="current_page" | |
240 | {% endifequal %} |
|
240 | {% endifequal %} | |
241 | href=" |
|
241 | href=" |
@@ -22,13 +22,14 b' from django.utils import timezone' | |||||
22 | from django.db import transaction |
|
22 | from django.db import transaction | |
23 | from django.views.decorators.cache import cache_page |
|
23 | from django.views.decorators.cache import cache_page | |
24 | from django.views.i18n import javascript_catalog |
|
24 | from django.views.i18n import javascript_catalog | |
|
25 | from django.core.paginator import Paginator | |||
25 |
|
26 | |||
26 | from boards import forms |
|
27 | from boards import forms | |
27 | import boards |
|
28 | import boards | |
28 | from boards import utils |
|
29 | from boards import utils | |
29 | from boards.forms import ThreadForm, PostForm, SettingsForm, PlainErrorList, \ |
|
30 | from boards.forms import ThreadForm, PostForm, SettingsForm, PlainErrorList, \ | |
30 | ThreadCaptchaForm, PostCaptchaForm, LoginForm, ModeratorSettingsForm |
|
31 | ThreadCaptchaForm, PostCaptchaForm, LoginForm, ModeratorSettingsForm | |
31 | from boards.models import Post, Tag, Ban, User |
|
32 | from boards.models import Post, Tag, Ban, User, Thread | |
32 | from boards.models.post import SETTING_MODERATE, REGEX_REPLY |
|
33 | from boards.models.post import SETTING_MODERATE, REGEX_REPLY | |
33 | from boards.models.user import RANK_USER |
|
34 | from boards.models.user import RANK_USER | |
34 | from boards import authors |
|
35 | from boards import authors | |
@@ -40,8 +41,10 b" BAN_REASON_SPAM = 'Autoban: spam bot'" | |||||
40 | MODE_GALLERY = 'gallery' |
|
41 | MODE_GALLERY = 'gallery' | |
41 | MODE_NORMAL = 'normal' |
|
42 | MODE_NORMAL = 'normal' | |
42 |
|
43 | |||
|
44 | DEFAULT_PAGE = 1 | |||
43 |
|
45 | |||
44 | def index(request, page=0): |
|
46 | ||
|
47 | def index(request, page=DEFAULT_PAGE): | |||
45 | context = _init_default_context(request) |
|
48 | context = _init_default_context(request) | |
46 |
|
49 | |||
47 | if utils.need_include_captcha(request): |
|
50 | if utils.need_include_captcha(request): | |
@@ -71,21 +74,16 b' def index(request, page=0):' | |||||
71 | # TODO Make this generic for tag and threads list pages |
|
74 | # TODO Make this generic for tag and threads list pages | |
72 | context['threads'] = None if len(threads) == 0 else threads |
|
75 | context['threads'] = None if len(threads) == 0 else threads | |
73 | context['form'] = form |
|
76 | context['form'] = form | |
74 | context['current_page'] = int(page) |
|
|||
75 |
|
77 | |||
76 | page_count = Post.objects.get_thread_page_count() |
|
78 | paginator = Paginator(Thread.objects.filter(archived=False), | |
77 | context['pages'] = range(page_count) if page_count > 0 else [0] |
|
79 | neboard.settings.THREADS_PER_PAGE) | |
78 | page = int(page) |
|
80 | _get_page_context(paginator, context, page) | |
79 | if page < page_count - 1: |
|
|||
80 | context['next_page'] = str(page + 1) |
|
|||
81 | if page > 0: |
|
|||
82 | context['prev_page'] = str(page - 1) |
|
|||
83 |
|
81 | |||
84 | return render(request, 'boards/posting_general.html', |
|
82 | return render(request, 'boards/posting_general.html', | |
85 | context) |
|
83 | context) | |
86 |
|
84 | |||
87 |
|
85 | |||
88 |
def archive(request, page= |
|
86 | def archive(request, page=DEFAULT_PAGE): | |
89 | context = _init_default_context(request) |
|
87 | context = _init_default_context(request) | |
90 |
|
88 | |||
91 | threads = [] |
|
89 | threads = [] | |
@@ -94,15 +92,10 b' def archive(request, page=0):' | |||||
94 | threads.append(_get_template_thread(thread_to_show)) |
|
92 | threads.append(_get_template_thread(thread_to_show)) | |
95 |
|
93 | |||
96 | context['threads'] = threads |
|
94 | context['threads'] = threads | |
97 | context['current_page'] = int(page) |
|
|||
98 |
|
95 | |||
99 |
pag |
|
96 | paginator = Paginator(Thread.objects.filter(archived=True), | |
100 | context['pages'] = range(page_count) if page_count > 0 else [0] |
|
97 | neboard.settings.THREADS_PER_PAGE) | |
101 | page = int(page) |
|
98 | _get_page_context(paginator, context, page) | |
102 | if page < page_count - 1: |
|
|||
103 | context['next_page'] = str(page + 1) |
|
|||
104 | if page > 0: |
|
|||
105 | context['prev_page'] = str(page - 1) |
|
|||
106 |
|
99 | |||
107 | return render(request, 'boards/archive.html', context) |
|
100 | return render(request, 'boards/archive.html', context) | |
108 |
|
101 | |||
@@ -158,10 +151,10 b' def _new_post(request, form, opening_pos' | |||||
158 | return redirect(thread, post_id=thread_to_show) |
|
151 | return redirect(thread, post_id=thread_to_show) | |
159 |
|
152 | |||
160 |
|
153 | |||
161 |
def tag(request, tag_name, page= |
|
154 | def tag(request, tag_name, page=DEFAULT_PAGE): | |
162 | """ |
|
155 | """ | |
163 | Get all tag threads. Threads are split in pages, so some page is |
|
156 | Get all tag threads. Threads are split in pages, so some page is | |
164 | requested. Default page is 0. |
|
157 | requested. | |
165 | """ |
|
158 | """ | |
166 |
|
159 | |||
167 | tag = get_object_or_404(Tag, name=tag_name) |
|
160 | tag = get_object_or_404(Tag, name=tag_name) | |
@@ -186,15 +179,10 b' def tag(request, tag_name, page=0):' | |||||
186 | context = _init_default_context(request) |
|
179 | context = _init_default_context(request) | |
187 | context['threads'] = None if len(threads) == 0 else threads |
|
180 | context['threads'] = None if len(threads) == 0 else threads | |
188 | context['tag'] = tag |
|
181 | context['tag'] = tag | |
189 | context['current_page'] = int(page) |
|
|||
190 |
|
182 | |||
191 |
pag |
|
183 | paginator = Paginator(Post.objects.get_threads(tag=tag), | |
192 | context['pages'] = range(page_count) |
|
184 | neboard.settings.THREADS_PER_PAGE) | |
193 | page = int(page) |
|
185 | _get_page_context(paginator, context, page) | |
194 | if page < page_count - 1: |
|
|||
195 | context['next_page'] = str(page + 1) |
|
|||
196 | if page > 0: |
|
|||
197 | context['prev_page'] = str(page - 1) |
|
|||
198 |
|
186 | |||
199 | context['form'] = form |
|
187 | context['form'] = form | |
200 |
|
188 | |||
@@ -602,3 +590,12 b' def _delete_old_users():' | |||||
602 | tags_count=0).filter(registration_time__lt=old_registration_date): |
|
590 | tags_count=0).filter(registration_time__lt=old_registration_date): | |
603 | if not Post.objects.filter(user=user).exists(): |
|
591 | if not Post.objects.filter(user=user).exists(): | |
604 | user.delete() |
|
592 | user.delete() | |
|
593 | ||||
|
594 | ||||
|
595 | def _get_page_context(paginator, context, page): | |||
|
596 | """ | |||
|
597 | Get pagination context variables | |||
|
598 | """ | |||
|
599 | ||||
|
600 | context['paginator'] = paginator | |||
|
601 | context['current_page'] = paginator.page(int(page)) |
General Comments 0
You need to be logged in to leave comments.
Login now