Fixes for previous/next page links, props Viper007Bond, fixes #8058

git-svn-id: https://develop.svn.wordpress.org/trunk@9632 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
Andrew Ozz 2008-11-12 10:13:50 +00:00
parent 521d3c0998
commit 6b1aec92f5

View File

@ -1054,38 +1054,60 @@ function get_next_posts_page_link($max_page = 0) {
} }
/** /**
* Display the next posts pages link. * Display or return the next posts pages link.
* *
* @since 0.71 * @since 0.71
* *
* @param int $max_page Optional. Max pages. * @param int $max_page Optional. Max pages.
* @param boolean $echo Optional. Echo or return;
*/ */
function next_posts($max_page = 0) { function next_posts( $max_page = 0, $echo = true ) {
echo clean_url(get_next_posts_page_link($max_page)); $output = clean_url( get_next_posts_page_link( $max_page ) );
if ( $echo )
echo $output;
else
return $output;
}
/**
* Return the next posts pages link.
*
* @since 2.7.0
*
* @param string $label Content for link text.
* @param int $max_page Optional. Max pages.
* @return string|null
*/
function get_next_posts_link( $label = 'Next Page »', $max_page = 0 ) {
global $paged, $wp_query;
if ( !$max_page ) {
$max_page = $wp_query->max_num_pages;
}
if ( !$paged )
$paged = 1;
$nextpage = intval($paged) + 1;
if ( !is_single() && ( empty($paged) || $nextpage <= $max_page) ) {
$attr = apply_filters( 'next_posts_link_attributes', '' );
return '<a href="' . next_posts( $max_page, false ) . "\" $attr>". preg_replace('/&([^#])(?![a-z]{1,8};)/', '&#038;$1', $label) .'</a>';
}
} }
/** /**
* Display the next posts pages link. * Display the next posts pages link.
* *
* @since 0.71 * @since 0.71
* @uses get_next_posts_link()
* *
* @param string $label Content for link text. * @param string $label Content for link text.
* @param int $max_page Optional. Max pages. * @param int $max_page Optional. Max pages.
*/ */
function next_posts_link( $label = 'Next Page &raquo;', $max_page = 0 ) { function next_posts_link( $label = 'Next Page &raquo;', $max_page = 0 ) {
global $paged, $wp_query; echo get_next_posts_link( $label, $max_page );
if ( !$max_page ) {
$max_page = $wp_query->max_num_pages;
}
if ( !$paged )
$paged = 1;
$nextpage = intval($paged) + 1;
if ( (! is_single()) && (empty($paged) || $nextpage <= $max_page) ) {
echo '<a href="';
next_posts($max_page);
$attr = apply_filters( 'next_posts_link_attributes', '' );
echo "\" $attr>". preg_replace('/&([^#])(?![a-z]{1,8};)/', '&#038;$1', $label) .'</a>';
}
} }
/** /**
@ -1111,29 +1133,48 @@ function get_previous_posts_page_link() {
} }
/** /**
* Display previous posts pages link. * Display or return the previous posts pages link.
* *
* @since 0.71 * @since 0.71
*
* @param boolean $echo Optional. Echo or return;
*/ */
function previous_posts() { function previous_posts( $echo = true ) {
echo clean_url(get_previous_posts_page_link()); $output = clean_url( get_previous_posts_page_link() );
if ( $echo )
echo $output;
else
return $output;
} }
/** /**
* Display previous posts page link. * Return the previous posts pages link.
*
* @since 2.7.0
*
* @param string $label Optional. Previous page link text.
* @return string|null
*/
function get_previous_posts_link( $label = '&laquo; Previous Page' ) {
global $paged;
if ( !is_single() && $paged > 1 ) {
$attr = apply_filters( 'previous_posts_link_attributes', '' );
return '<a href="' . previous_posts( false ) . "\" $attr>". preg_replace( '/&([^#])(?![a-z]{1,8};)/', '&#038;$1', $label ) .'</a>';
}
}
/**
* Display the previous posts page link.
* *
* @since 0.71 * @since 0.71
* @uses get_previous_posts_link()
* *
* @param string $label Optional. Previous page link text. * @param string $label Optional. Previous page link text.
*/ */
function previous_posts_link( $label = '&laquo; Previous Page' ) { function previous_posts_link( $label = '&laquo; Previous Page' ) {
global $paged; echo get_previous_posts_link( $label );
if ( (!is_single()) && ($paged > 1) ) {
echo '<a href="';
previous_posts();
$attr = apply_filters( 'previous_posts_link_attributes', '' );
echo "\" $attr>". preg_replace('/&([^#])(?![a-z]{1,8};)/', '&#038;$1', $label) .'</a>';
}
} }
/** /**