From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.3.2 (2011-06-06) on dcvr.yhbt.net X-Spam-Level: X-Spam-ASN: X-Spam-Status: No, score=-2.4 required=3.0 tests=ALL_TRUSTED,AWL,BAYES_00, RP_MATCHES_RCVD shortcircuit=no autolearn=no version=3.3.2 X-Original-To: meta@public-inbox.org Received: from localhost (dcvr.yhbt.net [127.0.0.1]) by dcvr.yhbt.net (Postfix) with ESMTP id 251261F436; Mon, 15 Sep 2014 04:23:28 +0000 (UTC) From: Eric Wong To: meta@public-inbox.org Cc: Eric Wong Subject: [PATCH 2/2] index: add prev/next index navigation Date: Mon, 15 Sep 2014 04:23:22 +0000 Message-Id: <1410755002-15885-2-git-send-email-e@80x24.org> X-Mailer: git-send-email 2.1.0.243.g30d45f7 In-Reply-To: <1410755002-15885-1-git-send-email-e@80x24.org> References: <1410755002-15885-1-git-send-email-e@80x24.org> List-Id: This helps readers jump around more quickly when there are large messages. --- lib/PublicInbox/Feed.pm | 19 +++++++++++-------- lib/PublicInbox/View.pm | 10 +++++++++- 2 files changed, 20 insertions(+), 9 deletions(-) diff --git a/lib/PublicInbox/Feed.pm b/lib/PublicInbox/Feed.pm index 1fa38bf..791d198 100644 --- a/lib/PublicInbox/Feed.pm +++ b/lib/PublicInbox/Feed.pm @@ -87,30 +87,33 @@ sub generate_html_index { }); # except we sort top-level messages reverse chronologically - my $state = [ time, {}, $first ]; + my $state = [ time, {}, $first, 0 ]; for (sort { (eval { $b->message->header('X-PI-Date') } || 0) <=> (eval { $a->message->header('X-PI-Date') } || 0) } $th->rootset) { dump_msg($_, 0, \$html, $state); } - $state = undef; Email::Address->purge_cache; - my $footer = nav_footer($args->{cgi}, $first, $last, $feed_opts); - my $list_footer = $args->{footer}; - $footer .= "\n" . $list_footer if ($footer && $list_footer); - $footer = "
" . PRE_WRAP . "$footer" if $footer; + my $footer = nav_footer($args->{cgi}, $last, $feed_opts, $state); + if ($footer) { + my $list_footer = $args->{footer}; + $footer .= "\n" . $list_footer if $list_footer; + $footer = "
" . PRE_WRAP . "$footer"; + } $html . "$footer"; } # private subs sub nav_footer { - my ($cgi, $first, $last, $feed_opts) = @_; + my ($cgi, $last, $feed_opts, $state) = @_; $cgi or return ''; my $old_r = $cgi->param('r'); my $head = ' '; my $next = ' '; + my $first = $state->[2]; + my $anchor = $state->[3]; if ($last) { $next = qq!next!; @@ -121,7 +124,7 @@ sub nav_footer { } my $atom = "{atomurl}\">atom"; my $permalink = "permalink"; - "$next $head $atom $permalink"; + "page: $next $head $atom $permalink"; } sub each_recent_blob { diff --git a/lib/PublicInbox/View.pm b/lib/PublicInbox/View.pm index b3797d3..ce63f7d 100644 --- a/lib/PublicInbox/View.pm +++ b/lib/PublicInbox/View.pm @@ -45,6 +45,8 @@ sub feed_entry { sub index_entry { my ($class, $mime, $level, $state) = @_; my ($now, $seen, $first) = @$state; + my $midx = $state->[3]++; + my ($prev, $next) = ($midx - 1, $midx + 1); my $rv = ''; my $part_nr = 0; my $enc_msg = enc_for($mime->header("Content-Type")); @@ -75,7 +77,13 @@ sub index_entry { } $ts = POSIX::strftime($fmt, gmtime($ts)); - $rv .= "$pfx$subj $from - $ts\n\n"; + $rv .= "$pfx" . + "" . + "$subj $from - $ts\n" . + "$pfxnext"; + + $rv .= " prev" if $prev >= 0; + $rv .= "\n"; my $irp = $header_obj->header_raw('In-Reply-To'); my ($anchor_idx, $anchor); -- EW