WordPress.org

Make WordPress Core

Ticket #7769: 7769.diff

File 7769.diff, 8.2 KB (added by ryan, 10 years ago)

Partial implementation.

  • wp-includes/comment-template.php

     
    973973 * @uses Walker_Comment
    974974 *
    975975 * @param $args string|array Formatting options
    976         * @param $comments array Optional array of comment objects.  Defaults to $wp_query->comments
     976 * @param $comments array Optional array of comment objects.  Defaults to $wp_query->comments
    977977 */
    978978function wp_list_comments($args = array(), $comments = null ) {
    979979        global $wp_query;
    980980
    981         $defaults = array('walker' => null, 'depth' => 3, 'style' => 'ul', 'callback' => null, 'end-callback' => null, 'type' => 'all');
     981        $defaults = array('walker' => null, 'depth' => 10, 'style' => 'ul', 'callback' => null, 'end-callback' => null, 'type' => 'all',
     982                'page' => get_query_var('cpage'), 'per_page' => get_query_var('comments_per_page'));
    982983
    983984        $r = wp_parse_args( $args, $defaults );
     985        $r['per_page'] = 2; // Hardcoded for testing
     986        if ( empty($r['per_page']) ) {
     987                $r['page'] = 0;
     988        } else {
     989                $r['page'] = intval($r['page']);
     990                if ( empty($r['page']) )
     991                        $r['page'] = 1;
     992        }
    984993
    985994        extract( $r, EXTR_SKIP );
    986995
     
    9951004                                $wp_query->comments_by_type = &separate_comments($wp_query->comments);
    9961005                        if ( empty($wp_query->comments_by_type[$type]) )
    9971006                                return;
    998                         return $walker->walk($wp_query->comments_by_type[$type], $depth, $r);
     1007                        $walker->paged_walk($wp_query->comments_by_type[$type], $depth, $page, $per_page, $r);
     1008                        $wp_query->max_num_comment_pages = $walker->max_pages;
     1009                        return;
    9991010                }
    1000                 $walker->walk($wp_query->comments, $depth, $r);
     1011                $walker->paged_walk($wp_query->comments, $depth, $page, $per_page, $r);
     1012                $wp_query->max_num_comment_pages = $walker->max_pages;
    10011013        } else {
    10021014                if ( empty($comments) )
    10031015                        return;
    10041016                if ( 'all' != $type ) {
    1005                         $comments_by_type = separate_comments($comments);
     1017                        $comments_by_type = &separate_comments($comments);
    10061018                        if ( empty($comments_by_type[$type]) )
    10071019                                return;
    1008                         return $walker->walk($comments_by_type[$type], $depth, $r);
     1020                        $walker->paged_walk($comments_by_type[$type], $depth, $page, $per_page, $r);
     1021                        $wp_query->max_num_comment_pages = $walker->max_pages;
     1022                        return;
    10091023                }
    1010                 $walker->walk($comments, $depth, $r);
     1024                $walker->paged_walk($comments, $depth, $page, $per_page, $r);
     1025                $wp_query->max_num_comment_pages = $walker->max_pages;
    10111026        }
    10121027}
    10131028
  • wp-includes/query.php

     
    844844        var $max_num_pages = 0;
    845845
    846846        /**
     847         * The amount of comment pages.
     848         *
     849         * @since 2.7.0
     850         * @access public
     851         * @var int
     852         */
     853        var $max_num_comment_pages = 0;
     854
     855        /**
    847856         * Set if query is single post.
    848857         *
    849858         * @since 1.5.0
     
    16121621                else if ( $q['posts_per_page'] == 0 )
    16131622                        $q['posts_per_page'] = 1;
    16141623
     1624                if ( !isset($q['comments_per_page']) || $q['comments_per_page'] == 0 )
     1625                        $q['comments_per_page'] = get_option('comments_per_page');
     1626
    16151627                if ( $this->is_home && (empty($this->query) || $q['preview'] == 'true') && ( 'page' == get_option('show_on_front') ) && get_option('page_on_front') ) {
    16161628                        $this->is_page = true;
    16171629                        $this->is_home = false;
  • wp-includes/link-template.php

     
    793793        }
    794794}
    795795
     796function get_comments_pagenum_link($pagenum = 1) {
     797        global $wp_rewrite;
     798
     799        $pagenum = (int) $pagenum;
     800
     801        $request = remove_query_arg( 'cpage' );
     802
     803        $home_root = parse_url(get_option('home'));
     804        $home_root = ( isset($home_root['path']) ) ? $home_root['path'] : '';
     805        $home_root = preg_quote( trailingslashit( $home_root ), '|' );
     806
     807        $request = preg_replace('|^'. $home_root . '|', '', $request);
     808        $request = preg_replace('|^/+|', '', $request);
     809
     810        $base = trailingslashit( get_bloginfo( 'home' ) );
     811
     812        if ( $pagenum > 1 ) {
     813                $result = add_query_arg( 'cpage', $pagenum, $base . $request );
     814        } else {
     815                $result = $base . $request;
     816        }
     817
     818        $result = apply_filters('get_comments_pagenum_link', $result);
     819
     820        return $result;
     821}
     822
     823function next_comments_link($label='', $max_page = 0) {
     824        global $wp_query;
     825
     826        if ( !is_singular() )
     827                return;
     828
     829        $page = get_query_var('cpage');
     830
     831        if ( !$page )
     832                $page = 1;
     833        $nextpage = intval($page) + 1;
     834
     835        if ( empty($max_page) )
     836                $max_page = $wp_query->max_num_comment_pages;
     837
     838        if ( empty($label) )
     839                $label = __('» Newer Comments');
     840
     841        if ( $nextpage > $max_page )
     842                return;
     843
     844        echo '<a href="' . clean_url(get_comments_pagenum_link($nextpage));
     845        $attr = apply_filters( 'next_comments_link_attributes', '' );
     846        echo "\" $attr>". preg_replace('/&([^#])(?![a-z]{1,8};)/', '&#038;$1', $label) .'</a>';
     847}
     848
    796849function get_shortcut_link() {
    797850        $link = "javascript:
    798851                        var d=document,
  • wp-includes/classes.php

     
    2626         * @access public
    2727         * @var array
    2828         */
    29         var $public_query_vars = array('m', 'p', 'posts', 'w', 'cat', 'withcomments', 'withoutcomments', 's', 'search', 'exact', 'sentence', 'debug', 'calendar', 'page', 'paged', 'more', 'tb', 'pb', 'author', 'order', 'orderby', 'year', 'monthnum', 'day', 'hour', 'minute', 'second', 'name', 'category_name', 'tag', 'feed', 'author_name', 'static', 'pagename', 'page_id', 'error', 'comments_popup', 'attachment', 'attachment_id', 'subpost', 'subpost_id', 'preview', 'robots', 'taxonomy', 'term');
     29        var $public_query_vars = array('m', 'p', 'posts', 'w', 'cat', 'withcomments', 'withoutcomments', 's', 'search', 'exact', 'sentence', 'debug', 'calendar', 'page', 'paged', 'more', 'tb', 'pb', 'author', 'order', 'orderby', 'year', 'monthnum', 'day', 'hour', 'minute', 'second', 'name', 'category_name', 'tag', 'feed', 'author_name', 'static', 'pagename', 'page_id', 'error', 'comments_popup', 'attachment', 'attachment_id', 'subpost', 'subpost_id', 'preview', 'robots', 'taxonomy', 'term', 'cpage');
    3030
    3131        /**
    3232         * Private query variables.
     
    3636         * @since 2.0.0
    3737         * @var array
    3838         */
    39         var $private_query_vars = array('offset', 'posts_per_page', 'posts_per_archive_page', 'what_to_show', 'showposts', 'nopaging', 'post_type', 'post_status', 'category__in', 'category__not_in', 'category__and', 'tag__in', 'tag__not_in', 'tag__and', 'tag_slug__in', 'tag_slug__and', 'tag_id', 'post_mime_type', 'perm');
     39        var $private_query_vars = array('offset', 'posts_per_page', 'posts_per_archive_page', 'what_to_show', 'showposts', 'nopaging', 'post_type', 'post_status', 'category__in', 'category__not_in', 'category__and', 'tag__in', 'tag__not_in', 'tag__and', 'tag_slug__in', 'tag_slug__and', 'tag_id', 'post_mime_type', 'perm', 'comments_per_page');
    4040
    4141        /**
    4242         * Extra query variables set by the user.
     
    731731        var $db_fields;
    732732
    733733        /**
     734         * Max number of pages walked by the paged walker
     735         *
     736         * @since 2.7.0
     737         * @var int
     738         * @access protected
     739         */
     740        var $max_pages = 1;
     741
     742        /**
    734743         * Starts the list before the elements are added.
    735744         *
    736745         * Additional parameters are used in child classes. The args parameter holds
     
    975984                if ( $page_num < 1 || $per_page < 0  ) {
    976985                        $start = 0;
    977986                        $end = $total_top;
     987                        $this->max_pages = 1;
    978988                } else {
    979989                        $start = ( (int)$page_num - 1 ) * (int)$per_page;
    980990                        $end   = $start + $per_page;
     991                        $this->max_pages = ceil($total_top / $per_page);
    981992                }
    982993
    983994                foreach( $top_level_elements as $e ){
  • wp-content/themes/default/comments.php

     
    1515        <h3 id="comments"><?php comments_number('No Responses', 'One Response', '% Responses' );?> to &#8220;<?php the_title(); ?>&#8221;</h3>
    1616
    1717        <ol class="commentlist">
    18         <?php wp_list_comments($comments); ?>
     18        <?php wp_list_comments(); ?>
    1919        </ol>
    20 
     20        <?php next_comments_link(); ?>
    2121 <?php else : // this is displayed if there are no comments so far ?>
    2222
    2323        <?php if ('open' == $post->comment_status) : ?>