mirror of
https://github.com/phpbb/phpbb.git
synced 2025-10-24 05:06:09 +02:00
Merge pull request #1673 from nickvergessen/ticket/11805
[ticket/11805] Allow specifying the page in the route for pagination
This commit is contained in:
@@ -2205,6 +2205,32 @@ function tracking_unserialize($string, $max_depth = 3)
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Pagination functions
|
// Pagination functions
|
||||||
|
/**
|
||||||
|
* Generate a pagination link based on the url and the page information
|
||||||
|
*
|
||||||
|
* @param string $base_url is url prepended to all links generated within the function
|
||||||
|
* If you use page numbers inside your controller route, base_url should contains a placeholder (%d)
|
||||||
|
* for the page. Also be sure to specify the pagination path information into the start_name argument
|
||||||
|
* @param string $on_page is the page for which we want to generate the link
|
||||||
|
* @param string $start_name is the name of the parameter containing the first item of the given page (example: start=20)
|
||||||
|
* If you use page numbers inside your controller route, start name should be the string
|
||||||
|
* that should be removed for the first page (example: /page/%d)
|
||||||
|
* @param int $per_page the number of items, posts, etc. to display per page, used to determine the number of pages to produce
|
||||||
|
* @return URL for the requested page
|
||||||
|
*/
|
||||||
|
function phpbb_generate_page_link($base_url, $on_page, $start_name, $per_page)
|
||||||
|
{
|
||||||
|
|
||||||
|
if (strpos($start_name, '%d') !== false)
|
||||||
|
{
|
||||||
|
return ($on_page > 1) ? sprintf($base_url, (int) $on_page) : str_replace($start_name, '', $base_url);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
$url_delim = (strpos($base_url, '?') === false) ? '?' : ((strpos($base_url, '?') === strlen($base_url) - 1) ? '' : '&');
|
||||||
|
return ($on_page > 1) ? $base_url . $url_delim . $start_name . '=' . (($on_page - 1) * $per_page) : $base_url;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Generate template rendered pagination
|
* Generate template rendered pagination
|
||||||
@@ -2212,8 +2238,12 @@ function tracking_unserialize($string, $max_depth = 3)
|
|||||||
*
|
*
|
||||||
* @param object $template the template object
|
* @param object $template the template object
|
||||||
* @param string $base_url is url prepended to all links generated within the function
|
* @param string $base_url is url prepended to all links generated within the function
|
||||||
|
* If you use page numbers inside your controller route, base_url should contains a placeholder (%d)
|
||||||
|
* for the page. Also be sure to specify the pagination path information into the start_name argument
|
||||||
* @param string $block_var_name is the name assigned to the pagination data block within the template (example: <!-- BEGIN pagination -->)
|
* @param string $block_var_name is the name assigned to the pagination data block within the template (example: <!-- BEGIN pagination -->)
|
||||||
* @param string $start_name is the name of the parameter containing the first item of the given page (example: start=20)
|
* @param string $start_name is the name of the parameter containing the first item of the given page (example: start=20)
|
||||||
|
* If you use page numbers inside your controller route, start name should be the string
|
||||||
|
* that should be removed for the first page (example: /page/%d)
|
||||||
* @param int $num_items the total number of items, posts, etc., used to determine the number of pages to produce
|
* @param int $num_items the total number of items, posts, etc., used to determine the number of pages to produce
|
||||||
* @param int $per_page the number of items, posts, etc. to display per page, used to determine the number of pages to produce
|
* @param int $per_page the number of items, posts, etc. to display per page, used to determine the number of pages to produce
|
||||||
* @param int $start_item the item which should be considered currently active, used to determine the page we're on
|
* @param int $start_item the item which should be considered currently active, used to determine the page we're on
|
||||||
@@ -2233,7 +2263,6 @@ function phpbb_generate_template_pagination($template, $base_url, $block_var_nam
|
|||||||
}
|
}
|
||||||
|
|
||||||
$on_page = floor($start_item / $per_page) + 1;
|
$on_page = floor($start_item / $per_page) + 1;
|
||||||
$url_delim = (strpos($base_url, '?') === false) ? '?' : ((strpos($base_url, '?') === strlen($base_url) - 1) ? '' : '&');
|
|
||||||
|
|
||||||
if ($reverse_count)
|
if ($reverse_count)
|
||||||
{
|
{
|
||||||
@@ -2261,11 +2290,14 @@ function phpbb_generate_template_pagination($template, $base_url, $block_var_nam
|
|||||||
$end_page = ($total_pages > 5) ? max(min($total_pages, $on_page + 3), 5) : $total_pages;
|
$end_page = ($total_pages > 5) ? max(min($total_pages, $on_page + 3), 5) : $total_pages;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$u_previous_page = $u_next_page = '';
|
||||||
if ($on_page != 1)
|
if ($on_page != 1)
|
||||||
{
|
{
|
||||||
|
$u_previous_page = phpbb_generate_page_link($base_url, $on_page - 1, $start_name, $per_page);
|
||||||
|
|
||||||
$template->assign_block_vars($block_var_name, array(
|
$template->assign_block_vars($block_var_name, array(
|
||||||
'PAGE_NUMBER' => '',
|
'PAGE_NUMBER' => '',
|
||||||
'PAGE_URL' => $base_url . $url_delim . $start_name . '=' . (($on_page - 2) * $per_page),
|
'PAGE_URL' => $u_previous_page,
|
||||||
'S_IS_CURRENT' => false,
|
'S_IS_CURRENT' => false,
|
||||||
'S_IS_PREV' => true,
|
'S_IS_PREV' => true,
|
||||||
'S_IS_NEXT' => false,
|
'S_IS_NEXT' => false,
|
||||||
@@ -2279,15 +2311,13 @@ function phpbb_generate_template_pagination($template, $base_url, $block_var_nam
|
|||||||
$at_page = 1;
|
$at_page = 1;
|
||||||
do
|
do
|
||||||
{
|
{
|
||||||
$page_url = $base_url . (($at_page == 1) ? '' : $url_delim . $start_name . '=' . (($at_page - 1) * $per_page));
|
|
||||||
|
|
||||||
// We decide whether to display the ellipsis during the loop. The ellipsis is always
|
// We decide whether to display the ellipsis during the loop. The ellipsis is always
|
||||||
// displayed as either the second or penultimate item in the list. So are we at either
|
// displayed as either the second or penultimate item in the list. So are we at either
|
||||||
// of those points and of course do we even need to display it, i.e. is the list starting
|
// of those points and of course do we even need to display it, i.e. is the list starting
|
||||||
// on at least page 3 and ending three pages before the final item.
|
// on at least page 3 and ending three pages before the final item.
|
||||||
$template->assign_block_vars($block_var_name, array(
|
$template->assign_block_vars($block_var_name, array(
|
||||||
'PAGE_NUMBER' => $at_page,
|
'PAGE_NUMBER' => $at_page,
|
||||||
'PAGE_URL' => $page_url,
|
'PAGE_URL' => phpbb_generate_page_link($base_url, $at_page, $start_name, $per_page),
|
||||||
'S_IS_CURRENT' => (!$ignore_on_page && $at_page == $on_page),
|
'S_IS_CURRENT' => (!$ignore_on_page && $at_page == $on_page),
|
||||||
'S_IS_NEXT' => false,
|
'S_IS_NEXT' => false,
|
||||||
'S_IS_PREV' => false,
|
'S_IS_PREV' => false,
|
||||||
@@ -2317,9 +2347,11 @@ function phpbb_generate_template_pagination($template, $base_url, $block_var_nam
|
|||||||
|
|
||||||
if ($on_page != $total_pages)
|
if ($on_page != $total_pages)
|
||||||
{
|
{
|
||||||
|
$u_next_page = phpbb_generate_page_link($base_url, $on_page + 1, $start_name, $per_page);
|
||||||
|
|
||||||
$template->assign_block_vars($block_var_name, array(
|
$template->assign_block_vars($block_var_name, array(
|
||||||
'PAGE_NUMBER' => '',
|
'PAGE_NUMBER' => '',
|
||||||
'PAGE_URL' => $base_url . $url_delim . $start_name . '=' . ($on_page * $per_page),
|
'PAGE_URL' => $u_next_page,
|
||||||
'S_IS_CURRENT' => false,
|
'S_IS_CURRENT' => false,
|
||||||
'S_IS_PREV' => false,
|
'S_IS_PREV' => false,
|
||||||
'S_IS_NEXT' => true,
|
'S_IS_NEXT' => true,
|
||||||
@@ -2344,13 +2376,11 @@ function phpbb_generate_template_pagination($template, $base_url, $block_var_nam
|
|||||||
}
|
}
|
||||||
$tpl_prefix = ($tpl_prefix == 'PAGINATION') ? '' : $tpl_prefix . '_';
|
$tpl_prefix = ($tpl_prefix == 'PAGINATION') ? '' : $tpl_prefix . '_';
|
||||||
|
|
||||||
$previous_page = ($on_page != 1) ? $base_url . $url_delim . $start_name . '=' . (($on_page - 2) * $per_page) : '';
|
|
||||||
|
|
||||||
$template_array = array(
|
$template_array = array(
|
||||||
$tpl_prefix . 'BASE_URL' => $base_url,
|
$tpl_prefix . 'BASE_URL' => $base_url,
|
||||||
$tpl_prefix . 'PER_PAGE' => $per_page,
|
$tpl_prefix . 'PER_PAGE' => $per_page,
|
||||||
'U_' . $tpl_prefix . 'PREVIOUS_PAGE' => $previous_page,
|
'U_' . $tpl_prefix . 'PREVIOUS_PAGE' => ($on_page != 1) ? $u_previous_page : '',
|
||||||
'U_' . $tpl_prefix . 'NEXT_PAGE' => ($on_page != $total_pages) ? $base_url . $url_delim . $start_name . '=' . ($on_page * $per_page) : '',
|
'U_' . $tpl_prefix . 'NEXT_PAGE' => ($on_page != $total_pages) ? $u_next_page : '',
|
||||||
$tpl_prefix . 'TOTAL_PAGES' => $total_pages,
|
$tpl_prefix . 'TOTAL_PAGES' => $total_pages,
|
||||||
$tpl_prefix . 'CURRENT_PAGE' => $on_page,
|
$tpl_prefix . 'CURRENT_PAGE' => $on_page,
|
||||||
);
|
);
|
||||||
|
@@ -40,10 +40,14 @@ function jumpto(item) {
|
|||||||
page = prompt(jump_page, on_page);
|
page = prompt(jump_page, on_page);
|
||||||
|
|
||||||
if (page !== null && !isNaN(page) && page == Math.floor(page) && page > 0) {
|
if (page !== null && !isNaN(page) && page == Math.floor(page) && page > 0) {
|
||||||
if (base_url.indexOf('?') === -1) {
|
if (base_url.indexOf('%d') === -1) {
|
||||||
document.location.href = base_url + '?start=' + ((page - 1) * per_page);
|
if (base_url.indexOf('?') === -1) {
|
||||||
|
document.location.href = base_url + '?start=' + ((page - 1) * per_page);
|
||||||
|
} else {
|
||||||
|
document.location.href = base_url.replace(/&/g, '&') + '&start=' + ((page - 1) * per_page);
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
document.location.href = base_url.replace(/&/g, '&') + '&start=' + ((page - 1) * per_page);
|
document.location.href = base_url.replace('%d', page);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
111
tests/pagination/generate_template_test.php
Normal file
111
tests/pagination/generate_template_test.php
Normal file
@@ -0,0 +1,111 @@
|
|||||||
|
<?php
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @package testing
|
||||||
|
* @copyright (c) 2013 phpBB Group
|
||||||
|
* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
require_once dirname(__FILE__) . '/../../phpBB/includes/functions.php';
|
||||||
|
require_once dirname(__FILE__) . '/../template/template_test_case.php';
|
||||||
|
|
||||||
|
class phpbb_pagination_generate_template_test extends phpbb_template_template_test_case
|
||||||
|
{
|
||||||
|
protected $test_path = 'tests/pagination';
|
||||||
|
|
||||||
|
public function phpbb_generate_template_pagination_data()
|
||||||
|
{
|
||||||
|
return array(
|
||||||
|
array(
|
||||||
|
'page.php',
|
||||||
|
'start',
|
||||||
|
95,
|
||||||
|
10,
|
||||||
|
10,
|
||||||
|
'pagination
|
||||||
|
:previous::page.php
|
||||||
|
:else:1:page.php
|
||||||
|
:current:2:page.php?start=10
|
||||||
|
:else:3:page.php?start=20
|
||||||
|
:else:4:page.php?start=30
|
||||||
|
:else:5:page.php?start=40
|
||||||
|
:ellipsis:9:page.php?start=80
|
||||||
|
:else:10:page.php?start=90
|
||||||
|
:next::page.php?start=20
|
||||||
|
:u_prev:page.php
|
||||||
|
:u_next:page.php?start=20',
|
||||||
|
),
|
||||||
|
array(
|
||||||
|
'page.php',
|
||||||
|
'start',
|
||||||
|
95,
|
||||||
|
10,
|
||||||
|
20,
|
||||||
|
'pagination
|
||||||
|
:previous::page.php?start=10
|
||||||
|
:else:1:page.php
|
||||||
|
:else:2:page.php?start=10
|
||||||
|
:current:3:page.php?start=20
|
||||||
|
:else:4:page.php?start=30
|
||||||
|
:else:5:page.php?start=40
|
||||||
|
:else:6:page.php?start=50
|
||||||
|
:ellipsis:9:page.php?start=80
|
||||||
|
:else:10:page.php?start=90
|
||||||
|
:next::page.php?start=30
|
||||||
|
:u_prev:page.php?start=10
|
||||||
|
:u_next:page.php?start=30',
|
||||||
|
),
|
||||||
|
array(
|
||||||
|
'test/page/%d',
|
||||||
|
'/page/%d',
|
||||||
|
95,
|
||||||
|
10,
|
||||||
|
10,
|
||||||
|
'pagination
|
||||||
|
:previous::test
|
||||||
|
:else:1:test
|
||||||
|
:current:2:test/page/2
|
||||||
|
:else:3:test/page/3
|
||||||
|
:else:4:test/page/4
|
||||||
|
:else:5:test/page/5
|
||||||
|
:ellipsis:9:test/page/9
|
||||||
|
:else:10:test/page/10
|
||||||
|
:next::test/page/3
|
||||||
|
:u_prev:test
|
||||||
|
:u_next:test/page/3',
|
||||||
|
),
|
||||||
|
array(
|
||||||
|
'test/page/%d',
|
||||||
|
'/page/%d',
|
||||||
|
95,
|
||||||
|
10,
|
||||||
|
20,
|
||||||
|
'pagination
|
||||||
|
:previous::test/page/2
|
||||||
|
:else:1:test
|
||||||
|
:else:2:test/page/2
|
||||||
|
:current:3:test/page/3
|
||||||
|
:else:4:test/page/4
|
||||||
|
:else:5:test/page/5
|
||||||
|
:else:6:test/page/6
|
||||||
|
:ellipsis:9:test/page/9
|
||||||
|
:else:10:test/page/10
|
||||||
|
:next::test/page/4
|
||||||
|
:u_prev:test/page/2
|
||||||
|
:u_next:test/page/4',
|
||||||
|
),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @dataProvider phpbb_generate_template_pagination_data
|
||||||
|
*/
|
||||||
|
public function test_phpbb_generate_template_pagination($base_url, $start_name, $num_items, $per_page, $start_item, $expect)
|
||||||
|
{
|
||||||
|
phpbb_generate_template_pagination($this->template, $base_url, 'pagination', $start_name, $num_items, $per_page, $start_item);
|
||||||
|
$this->template->set_filenames(array('test' => 'pagination.html'));
|
||||||
|
|
||||||
|
$this->assertEquals(str_replace("\t", '', $expect), $this->display('test'));
|
||||||
|
}
|
||||||
|
}
|
12
tests/pagination/templates/pagination.html
Normal file
12
tests/pagination/templates/pagination.html
Normal file
@@ -0,0 +1,12 @@
|
|||||||
|
pagination
|
||||||
|
<!-- BEGIN pagination -->
|
||||||
|
<!-- IF pagination.S_IS_PREV -->:previous:{pagination.PAGE_NUMBER}:{pagination.PAGE_URL}
|
||||||
|
<!-- ELSEIF pagination.S_IS_CURRENT -->:current:{pagination.PAGE_NUMBER}:{pagination.PAGE_URL}
|
||||||
|
<!-- ELSEIF pagination.S_IS_ELLIPSIS -->:ellipsis:{pagination.PAGE_NUMBER}:{pagination.PAGE_URL}
|
||||||
|
<!-- ELSEIF pagination.S_IS_NEXT -->:next:{pagination.PAGE_NUMBER}:{pagination.PAGE_URL}
|
||||||
|
<!-- ELSE -->:else:{pagination.PAGE_NUMBER}:{pagination.PAGE_URL}
|
||||||
|
<!-- ENDIF -->
|
||||||
|
<!-- END pagination -->
|
||||||
|
<!-- IF U_PREVIOUS_PAGE -->:u_prev:{U_PREVIOUS_PAGE}<!-- ENDIF -->
|
||||||
|
|
||||||
|
<!-- IF U_NEXT_PAGE -->:u_next:{U_NEXT_PAGE}<!-- ENDIF -->
|
Reference in New Issue
Block a user