Refs #25513 -- Fixed admin pagination elision bounds.
It doesn't make sense to elide a single page number which could be a clickable link to that page. We only want to elide two or more pages.
This commit is contained in:
parent
b203ec70fd
commit
f35840c196
|
@ -67,14 +67,14 @@ def pagination(cl):
|
||||||
# links at either end of the list of pages, and there are always
|
# links at either end of the list of pages, and there are always
|
||||||
# ON_EACH_SIDE links at either end of the "current page" link.
|
# ON_EACH_SIDE links at either end of the "current page" link.
|
||||||
page_range = []
|
page_range = []
|
||||||
if page_num > (1 + ON_EACH_SIDE + ON_ENDS):
|
if page_num > (1 + ON_EACH_SIDE + ON_ENDS) + 1:
|
||||||
page_range += [
|
page_range += [
|
||||||
*range(1, ON_ENDS + 1), DOT,
|
*range(1, ON_ENDS + 1), DOT,
|
||||||
*range(page_num - ON_EACH_SIDE, page_num + 1),
|
*range(page_num - ON_EACH_SIDE, page_num + 1),
|
||||||
]
|
]
|
||||||
else:
|
else:
|
||||||
page_range.extend(range(1, page_num + 1))
|
page_range.extend(range(1, page_num + 1))
|
||||||
if page_num < (paginator.num_pages - ON_EACH_SIDE - ON_ENDS):
|
if page_num < (paginator.num_pages - ON_EACH_SIDE - ON_ENDS) - 1:
|
||||||
page_range += [
|
page_range += [
|
||||||
*range(page_num + 1, page_num + ON_EACH_SIDE + 1), DOT,
|
*range(page_num + 1, page_num + ON_EACH_SIDE + 1), DOT,
|
||||||
*range(paginator.num_pages - ON_ENDS + 1, paginator.num_pages + 1)
|
*range(paginator.num_pages - ON_ENDS + 1, paginator.num_pages + 1)
|
||||||
|
|
|
@ -1246,22 +1246,28 @@ class ChangeListTests(TestCase):
|
||||||
|
|
||||||
for page_num, objects_count, expected_page_range in [
|
for page_num, objects_count, expected_page_range in [
|
||||||
(1, per_page, []),
|
(1, per_page, []),
|
||||||
(1, per_page * 2, list(range(1, 3))),
|
(1, per_page * 2, [1, 2]),
|
||||||
(6, per_page * 11, list(range(1, 12))),
|
(6, per_page * 11, [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11]),
|
||||||
(6, per_page * 12, [1, 2, 3, 4, 5, 6, 7, 8, 9, '.', 11, 12]),
|
(6, per_page * 12, [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12]),
|
||||||
(7, per_page * 12, [1, 2, '.', 4, 5, 6, 7, 8, 9, 10, 11, 12]),
|
(6, per_page * 13, [1, 2, 3, 4, 5, 6, 7, 8, 9, '.', 12, 13]),
|
||||||
(7, per_page * 13, [1, 2, '.', 4, 5, 6, 7, 8, 9, 10, '.', 12, 13]),
|
(7, per_page * 12, [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12]),
|
||||||
|
(7, per_page * 13, [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13]),
|
||||||
|
(7, per_page * 14, [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, '.', 13, 14]),
|
||||||
|
(8, per_page * 13, [1, 2, '.', 5, 6, 7, 8, 9, 10, 11, 12, 13]),
|
||||||
|
(8, per_page * 14, [1, 2, '.', 5, 6, 7, 8, 9, 10, 11, 12, 13, 14]),
|
||||||
|
(8, per_page * 15, [1, 2, '.', 5, 6, 7, 8, 9, 10, 11, '.', 14, 15]),
|
||||||
]:
|
]:
|
||||||
# assuming we have exactly `objects_count` objects
|
with self.subTest(number=number, pages=pages):
|
||||||
Group.objects.all().delete()
|
# assuming exactly `objects_count` objects
|
||||||
for i in range(objects_count):
|
Group.objects.all().delete()
|
||||||
Group.objects.create(name='test band')
|
for i in range(objects_count):
|
||||||
|
Group.objects.create(name='test band')
|
||||||
|
|
||||||
# setting page number and calculating page range
|
# setting page number and calculating page range
|
||||||
cl.page_num = page_num
|
cl.page_num = page_num
|
||||||
cl.get_results(request)
|
cl.get_results(request)
|
||||||
real_page_range = pagination(cl)['page_range']
|
real_page_range = pagination(cl)['page_range']
|
||||||
self.assertEqual(expected_page_range, list(real_page_range))
|
self.assertEqual(expected_page_range, list(real_page_range))
|
||||||
|
|
||||||
def test_object_tools_displayed_no_add_permission(self):
|
def test_object_tools_displayed_no_add_permission(self):
|
||||||
"""
|
"""
|
||||||
|
|
Loading…
Reference in New Issue