]> Sergey Matveev's repositories - public-inbox.git/commitdiff
www: more descriptive pagination
authorEric Wong <e@yhbt.net>
Thu, 27 Aug 2020 22:05:00 +0000 (22:05 +0000)
committerEric Wong <e@yhbt.net>
Fri, 28 Aug 2020 04:25:33 +0000 (04:25 +0000)
Being an easily confused person, I find "next" and "prev"
ambiguous as to whether messages on the next or previous page
will be newer or older than the current page.  Clarify that for
the threaded /$INBOX/ view and search results.

For search results sorted by relevance, we'll use "[>= $SCORE]"
or "[<= $SCORE]" to indicate to indicate directionality.

This also fixes $INBOX/new.html for unindexed v1 inboxes.

lib/PublicInbox/Feed.pm
lib/PublicInbox/SearchView.pm
lib/PublicInbox/View.pm

index bf095a2cc8e3f7540e4baa66a792781956617431..cbdf5db99f8b8486e8a14caff84259c63e560fd9 100644 (file)
@@ -133,7 +133,10 @@ sub recent_msgs {
                }
        }
 
-       $ctx->{next_page} = "r=$last_commit" if $last_commit;
+       $last_commit and
+               $ctx->{next_page} = qq[<a\nhref="?r=$last_commit"\nrel=next>] .
+                                       'next (older)</a>';
+
        [ map { bless {blob => $_ }, 'PublicInbox::Smsg' } @oids ];
 }
 
index 7521a66ddb82c51bc2a6b9b7b1b77772403d2531..892e8fdae14038098bc9cd9ae21f5dcd97b2a1fc 100644 (file)
@@ -5,7 +5,7 @@
 package PublicInbox::SearchView;
 use strict;
 use v5.10.1;
-use List::Util qw(max);
+use List::Util qw(min max);
 use URI::Escape qw(uri_unescape);
 use PublicInbox::Smsg;
 use PublicInbox::Hval qw(ascii_html obfuscate_addrs mid_href fmt_ts);
@@ -98,6 +98,7 @@ sub mset_summary {
        my $obfs_ibx = $ibx->{obfuscate} ? $ibx : undef;
        my @nums = @{$ibx->search->mset_to_artnums($mset)};
        my %num2msg = map { $_->{num} => $_ } @{$ibx->over->get_all(@nums)};
+       my ($min, $max);
 
        foreach my $m ($mset->items) {
                my $rank = sprintf("%${pad}d", $m->get_rank + 1);
@@ -112,6 +113,11 @@ sub mset_summary {
                };
                $ctx->{-t_max} //= $smsg->{ts};
 
+               # only when sorting by relevance, ->items is always
+               # ordered descending:
+               $max //= $pct;
+               $min = $pct;
+
                my $s = ascii_html($smsg->{subject});
                my $f = ascii_html($smsg->{from_name});
                if ($obfs_ibx) {
@@ -125,6 +131,10 @@ sub mset_summary {
                        $s . "</a></b>\n";
                $$res .= "$pfx  - by $f @ $date UTC [$pct%]\n\n";
        }
+       if ($q->{r}) { # for descriptions in search_nav_bot
+               $q->{-min_pct} = $min;
+               $q->{-max_pct} = $max;
+       }
        $$res .= search_nav_bot($mset, $q);
        undef;
 }
@@ -218,42 +228,46 @@ sub search_nav_bot {
        my $beg = $off + 1;
 
        if ($beg <= $end) {
-               $rv .= "Results $beg-$end of $total";
-               $rv .= ' (estimated)' if $end != $total;
+               my $approx = $end == $total ? '' : '~';
+               $rv .= "Results $beg-$end of $approx$total";
        } else {
                $rv .= "No more results, only $total";
        }
-       my ($next, $join, $prev);
+       my ($next, $join, $prev, $nd, $pd);
 
        if ($o >= 0) { # sort descending
                my $n = $o + $l;
                if ($n < $total) {
                        $next = $q->qs_html(o => $n, l => $l);
+                       $nd = $q->{r} ? "[&lt;= $q->{-min_pct}%]" : '(older)';
                }
                if ($o > 0) {
-                       $join = $n < $total ? '/' : '       ';
+                       $join = $n < $total ? ' | ' : "\t";
                        my $p = $o - $l;
                        $prev = $q->qs_html(o => ($p > 0 ? $p : 0));
+                       $pd = $q->{r} ? "[&gt;= $q->{-max_pct}%]" : '(newer)';
                }
        } else { # o < 0, sort ascending
                my $n = $o - $l;
 
                if (-$n < $total) {
                        $next = $q->qs_html(o => $n, l => $l);
+                       $nd = $q->{r} ? "[&lt;= $q->{-min_pct}%]" : '(newer)';
                }
                if ($o < -1) {
-                       $join = -$n < $total ? '/' : '       ';
+                       $join = -$n < $total ? ' | ' : "\t";
                        my $p = $o + $l;
                        $prev = $q->qs_html(o => ($p < 0 ? $p : 0));
+                       $pd = $q->{r} ? "[&gt;= $q->{-max_pct}%]" : '(older)';
                }
        }
 
-       $rv .= qq{  <a\nhref="?$next"\nrel=next>next</a>} if $next;
+       $rv .= qq{  <a\nhref="?$next"\nrel=next>next $nd</a>} if $next;
        $rv .= $join if $join;
-       $rv .= qq{<a\nhref="?$prev"\nrel=prev>prev</a>} if $prev;
+       $rv .= qq{<a\nhref="?$prev"\nrel=prev>prev $pd</a>} if $prev;
 
        my $rev = $q->qs_html(o => $o < 0 ? 0 : -1);
-       $rv .= qq{ | <a\nhref="?$rev">reverse results</a></pre>};
+       $rv .= qq{ | <a\nhref="?$rev">reverse</a></pre>};
 }
 
 sub sort_relevance {
@@ -279,6 +293,11 @@ sub mset_thread {
        my $msgs = $ibx->over->get_all(keys %pct);
        $_->{pct} = $pct{$_->{num}} for @$msgs;
        my $r = $q->{r};
+       if ($r) { # for descriptions in search_nav_bot
+               my @pct = values %pct;
+               $q->{-min_pct} = min(@pct);
+               $q->{-max_pct} = max(@pct);
+       }
        my $rootset = PublicInbox::SearchThread::thread($msgs,
                $r ? \&sort_relevance : \&PublicInbox::View::sort_ds,
                $ctx);
index 9c3ef104f1a83ab28edfce75cf2ce2308ad3af76..3055da20890260d473f11d5ca9c6c0800cb75af7 100644 (file)
@@ -1175,9 +1175,9 @@ sub pagination_footer ($$) {
        my ($ctx, $latest) = @_;
        my $next = $ctx->{next_page} || '';
        my $prev = $ctx->{prev_page} || '';
-       if ($prev) {
-               $next = $next ? "$next " : '     ';
-               $prev .= qq! <a\nhref='$latest'>latest</a>!;
+       if ($prev) {  # aligned padding for: 'next (older) | '
+               $next = $next ? "$next | " : '             | ';
+               $prev .= qq[ | <a\nhref="$latest">latest</a>];
        }
        "<hr><pre>page: $next$prev</pre>";
 }
@@ -1215,11 +1215,13 @@ sub paginate_recent ($$) {
        }
        if (defined($oldest) && $more) {
                my $s = ts2str($oldest);
-               $ctx->{next_page} = qq!<a\nhref="?t=$s"\nrel=next>next</a>!;
+               $ctx->{next_page} = qq[<a\nhref="?t=$s"\nrel=next>] .
+                                       'next (older)</a>';
        }
        if (defined($newest) && (defined($before) || defined($after))) {
                my $s = ts2str($newest);
-               $ctx->{prev_page} = qq!<a\nhref="?t=$s-"\nrel=prev>prev</a>!;
+               $ctx->{prev_page} = qq[<a\nhref="?t=$s-"\nrel=prev>] .
+                                       'prev (newer)</a>';
        }
        $msgs;
 }